/* custom-bootstrap.css */

* {
    margin: 0;
    padding: 0;
}

.container, .container-fluid, .container-lg, .container-md, .container-sm, .container-xl, .container-xxl {
    --bs-gutter-x: 0;
    --bs-gutter-y: 0;
    width: 100%;
    padding-right: calc(var(--bs-gutter-x) * .5);
    padding-left: calc(var(--bs-gutter-x) * .5);
    margin-right: auto;
    margin-left: auto;
}

/* Переопределение основных цветов Bootstrap */
:root {
    --bs-blue: #0d6efd;
    --bs-indigo: #6610f2;
    --bs-purple: #6f42c1;
    --bs-pink: #d63384;
    --bs-red: #dc3545;
    --bs-orange: #fd7e14;
    --bs-yellow: #ffc107;
    --bs-green: #198754;
    --bs-teal: #20c997;
    --bs-cyan: #0dcaf0;
    --bs-white: #fff;
    --bs-gray: #6c757d;
    --bs-gray-dark: #343a40;
    
    /* Ваш кастомный primary цвет */
    --bs-primary: #2A2F35;
    --bs-primary-rgb: 42, 47, 53;
    
    --bs-secondary: #6c757d;
    --bs-success: #198754;
    --bs-info: #0dcaf0;
    --bs-warning: #ffc107;
    --bs-danger: #dc3545;
    --bs-light: #f8f9fa;
    --bs-dark: #212529;
    
    /* Дополнительные цвета если нужно */
    --bs-domophon: #EE483A; /* Красный из вашего дизайна */
    --bs-domophon-rgb: 238, 72, 58;
}

/* Классы с вашим кастомным primary цветом */
.text-primary { color: var(--bs-primary) !important; }
.bg-primary { background-color: var(--bs-primary) !important; }
.border-primary { border-color: var(--bs-primary) !important; }

/* Кнопки с primary цветом */
.btn-primary {
    background-color: var(--bs-primary);
    border-color: var(--bs-primary);
}

.btn-primary:hover {
    background-color: #1f2328; /* Более темный оттенок */
    border-color: #1f2328;
}

.btn-outline-primary {
    color: var(--bs-primary);
    border-color: var(--bs-primary);
}

.btn-outline-primary:hover {
    background-color: var(--bs-primary);
    border-color: var(--bs-primary);
}

/* Кастомный цвет для домофона */
.text-domophon { color: var(--bs-domophon) !important; }
.bg-domophon { background-color: var(--bs-domophon) !important; }
.btn-domophon {
    background-color: var(--bs-domophon);
    border-color: var(--bs-domophon);
}
.btn-domophon:hover {
    background-color: #d93c2c;
    border-color: #d93c2c;
}

/* Стили для формы с возможностью легкой настройки */
:root {
  /* ШРИФТЫ */
  --form-font-family: system-ui, -apple-system, sans-serif;
  
  /* ЦВЕТА РАМОК */
  --form-border-color: #ced4da;
  --form-border-focus-color: #86b7fe;
  --form-border-error-color: #dc3545;
  
  /* РАЗМЕРЫ */
  --form-border-width: 1px;
  --form-border-focus-width: 1px;
}

/* Базовые стили формы */
#contact-form {
  font-family: var(--form-font-family);
}

/* Заголовок формы */
#contact-form .heading h3 {
  font-family: var(--form-font-family, var(--form-font-family));
  color: inherit;
}

/* Стили для всех полей ввода */
#contact-form .form-control {
  font-family: var(--form-font-family);
  border-radius: 0px;
  padding: 0.5rem 0.75rem;
  font-size: 1rem;
  line-height: 1.5;
  color: #212529;
  background-color: #fff;
  transition: border-color 0.15s ease-in-out, box-shadow 0.15s ease-in-out;
}

/* Стили для текстовых полей и textarea */
#contact-form input[type="text"],
#contact-form input[type="email"],
#contact-form input[type="tel"],
#contact-form textarea {
    width: 100%;
    border: 1px solid #ddd;
    color: #171313;
    font-size: 16px;
    font-weight: 400;
    padding-left: 10px;
    outline: none;
    -webkit-transition: .5s;
    transition: .5s;
}

/* Стили при фокусе на поле */
#contact-form input:focus,
#contact-form textarea:focus {
  border-color: var(--form-border-focus-color);
  outline: 0;
  box-shadow: 0 0 0 0.25rem rgba(13, 110, 253, 0.25);
}

/* Кнопка отправки */
#contact-form .btn {
  font-family: var(--form-font-family);
  border: var(--form-border-width) solid transparent;
  border-radius: var(--form-border-radius);
  padding: 0.5rem 1rem;
  font-size: 1rem;
  line-height: 1.5;
  cursor: pointer;
  transition: all 0.15s ease-in-out;
}

#contact-form ::placeholder {
  color: #6c757d;
  opacity: 1;
}

/* Стили для ошибок */
.form-control.error {
  border-color: var(--form-border-error-color) !important;
}

/* Для класса form-control-lg */
#contact-form .form-control-lg {
  font-size: 1.25rem;
  padding: 0.5rem 1rem;
}