/* ==========================================================================
   0. ПЕРЕМЕННЫЕ И БАЗОВЫЕ НАСТРОЙКИ
   ========================================================================== */
:root {
    --brand-gold: #c5a021;
    --brand-black: #1a1a1a;
    --bg-ivory: #fAf9f6;
    --bg-olive: #e8e9e3;
    --dark-olive: #656c5a;
    --text-muted: #707070;
}

body {
    background-color: var(--bg-ivory);
    color: var(--brand-black);
    font-family: 'Montserrat', sans-serif;
    margin: 0;
    padding: 0;
    -webkit-font-smoothing: antialiased;
    padding-right: 0 !important;
}

html, body {
    width: 100% !important;
    max-width: 100% !important;
    overflow-x: hidden !important;
    position: relative;
}

.raffia-header,
.raffia-menu-wrapper,
header, 
#top, 
.navbar {
    padding-right: 0 !important;
    border-bottom: none !important;
    box-shadow: none !important;
}

/* Базовый класс для всех кнопок */
.btn-raffia {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    height: 45px;
    padding: 0 20px;
    font-size: 13px;
    font-weight: 500;
    text-transform: uppercase;
    letter-spacing: 1px;
    text-decoration: none !important;
    transition: all 0.3s ease;
    border: 1px solid transparent;
    cursor: pointer;
    white-space: nowrap;
    border-radius: 4px;
}

/* 1. Основная (Золотая) */
.btn-gold {
    border-color: var(--brand-gold);
    color: var(--brand-gold);
    background: transparent;
}
.btn-gold:hover {
    background: var(--brand-gold);
    color: #fdf5e6; /* Слоновая кость */
}

/* 2. Неактивная (Черная) */
.btn-black {
    border-color: #000;
    color: #000;
    background: transparent;
}
.btn-black:hover {
    background: #000;
    color: #fdf5e6;
}

/* Универсальный строгий заголовок (как вкладки) */
.raffia-auth-heading {
    font-family: 'Montserrat', sans-serif;
    font-size: 14px;
    font-weight: 500;
    text-transform: uppercase;
    letter-spacing: 1.5px;
    color: var(--brand-black);
    margin-bottom: 1.5rem; /* это заменит класс mb-4 */
    text-align: center;    /* это заменит класс text-center */
}

/* 3. Футерная (Темная олива) */
.btn-olive {
    border-color: #556b2f; /* Замени на свой код оливы */
    color: #556b2f;
    background: transparent;
}
.btn-olive:hover {
    background: #556b2f;
    color: #fdf5e6;
}

/* 4. Второстепенная (Серая) */
.btn-grey {
    border-color: #ccc;
    color: #888;
    background: transparent;
}
.btn-grey:hover {
    background: #ccc;
    color: #fdf5e6;
}

/* Стили для цитат и важных предупреждений (например, в Оферте) */
blockquote {
    background-color: #fcfbf9;
    border-left: 4px solid #d4c5b9;
    margin: 20px 0;
    padding: 15px 20px;
    font-style: italic;
    color: #555;
    border-radius: 0 4px 4px 0;
}

blockquote p:last-child {
    margin-bottom: 0;
}

/* ==========================================================================
   1. ШАПКА САЙТА (ХЕДЕР): СТРУКТУРА И ЛОГОТИП
   ========================================================================== */
.raffia-header {
    background-color: var(--bg-ivory);
    padding: 40px 0 20px 0;
}

.raffia-header-inner {
    display: flex;
    justify-content: space-between;
    align-items: center;
    width: 100%;
    padding: 0 5%;
    position: relative;
}

.header-center {
    position: absolute;
    left: 50%;
    transform: translateX(-50%);
    display: flex;
    justify-content: center;
    align-items: center;
    z-index: 10;
}

.header-center img {
    height: 65px;
    width: auto;
    display: block;
    margin: 0 auto;
}

.raffia-logo-text {
    font-family: 'Playfair Display', serif;
    font-size: 32px;
    font-weight: 400;
    color: var(--brand-gold);
    text-transform: uppercase;
    letter-spacing: 6px;
    text-decoration: none;
    display: block;
}

/* ==========================================================================
   2. БОКОВЫЕ БЛОКИ ИКОНОК И ПОИСК (ДЕСКТОП)
   ========================================================================== */
.header-left, 
.header-right {
    flex: 1;
    display: flex;
    align-items: center;
    gap: 25px;
}

.header-left { justify-content: flex-start; }
.header-right { justify-content: flex-end; }

.raffia-icon-link {
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--brand-gold) !important;
    text-decoration: none;
    transition: color 0.3s ease;
}

.raffia-icon-link svg {
    width: 22px;
    height: 22px;
    stroke-width: 1.7px !important; 
    transition: stroke-width 0.3s ease;
}

.raffia-icon-link:hover {
    color: var(--brand-black) !important;
}

.raffia-search-inline-wrapper {
    position: relative;
    display: flex;
    align-items: center;
}

.raffia-search-btn-trigger {
    position: relative;
    z-index: 1100;
    display: flex;
    align-items: center;
    justify-content: center;
    background: transparent;
    border: none;
    padding: 0;
    margin: 0;
    line-height: 0;
    cursor: pointer;
    color: var(--brand-gold);
    transition: color 0.3s ease;
}

.raffia-search-btn-trigger:hover { color: var(--brand-black); }
.raffia-search-btn-trigger svg { width: 22px; height: 22px; stroke-width: 1.7px; }

.raffia-search-slide-panel {
    right: 0; 
    padding-right: 35px;
    width: 280px; 
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
    transition: all 0.3s ease-in-out;
    z-index: 10; 
}

.raffia-search-inline-wrapper:hover .raffia-search-slide-panel,
.raffia-search-slide-panel:focus-within {
    transform: translateY(-50%) translateX(-5px);
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
}

.raffia-search-slide-input {
    width: 100%;
    border: none;
    border-bottom: 1.5px solid var(--brand-gold);
    background-color: rgba(197, 160, 33, 0.03) !important;
    padding: 5px 0;
    font-family: 'Montserrat', sans-serif;
    font-size: 14px;
    color: var(--brand-black);
    outline: none;
    transition: border-color 0.3s ease;
}

.raffia-search-slide-input:focus {
    background-color: rgba(197, 160, 33, 0.06) !important;
}

.raffia-search-slide-input::placeholder { color: var(--text-muted); font-weight: 300; }

/* ==========================================================================
   3. МОБИЛЬНАЯ ШАПКА И ПОИСК (Работает ТОЛЬКО на экранах до 767px)
   ========================================================================== */
@media (max-width: 767px) {
    
    /* --- 1. ФУНДАМЕНТ ШАПКИ --- */
    .raffia-header {
        padding: 15px 0 !important;
        min-height: 75px !important;
        display: flex;
        align-items: center;
        position: relative !important; /* ВАЖНО: Вся шапка теперь точка отсчета для поиска */
    }
    
    .raffia-header-inner {
        position: static !important; /* Снимаем ограничения с внутренней обертки */
        padding: 0 15px;
    }

    /* --- 2. ЛЕВАЯ ЧАСТЬ (Гамбургер) --- */
    /* Прячем языки и валюту (они переехали в гамбургер) */
    /* ВНИМАНИЕ: Проверь, чтобы классы совпадали с твоими в HTML */
    .header-left .language-wrapper, 
    .header-left .currency-wrapper {
        display: none !important;
    }

    /* --- 3. ЦЕНТР (Логотип) --- */
    /* Жестко центрируем логотип относительно всей шапки */
    .header-center {
        position: absolute !important;
        left: 50% !important;
        top: 50% !important;
        transform: translate(-50%, -50%) !important;
        z-index: 10;
    }
    .header-center img { height: 45px; }

    /* --- 4. ПРАВАЯ ЧАСТЬ (Человечек и Корзина) --- */
    /* Даем им высокий приоритет, чтобы они кликались, пока поиск закрыт */
    .dropdown.d-flex.align-items-center,
    .cart-wrapper { /* Подставь свой класс корзины, если он другой */
        position: relative;
        z-index: 1050;
    }

    /* --- 5. ПОИСК: БАЗОВОЕ СОСТОЯНИЕ (ЗАКРЫТ) --- */
    .raffia-search-takeover {
        position: absolute !important;
        left: 55px !important; /* Лупа стоит ровно после гамбургера */
        top: 50% !important;
        transform: translateY(-50%) !important;
        z-index: 1050;
        display: flex;
        align-items: center;
    }

    /* Прячем само поле ввода и крестик */
    .raffia-search-takeover .raffia-search-slide-panel,
    .raffia-search-close {
        display: none !important;
    }

    /* Показываем только золотую лупу */
    .raffia-search-takeover .raffia-search-btn-trigger {
        display: flex !important;
        color: var(--brand-gold) !important;
    }

    /* --- 6. ПОИСК: АКТИВНОЕ СОСТОЯНИЕ (ОТКРЫТ) --- */
    /* Главная магия: когда поиск открыт, мы скрываем человечка и корзину, чтобы они не мешали и не просвечивали! */
    .raffia-search-takeover.is-active ~ .dropdown,
    .raffia-search-takeover.is-active ~ .cart-wrapper {
        display: none !important;
    }

    /* Растягиваем форму на 100% шапки */
    .raffia-search-takeover.is-active {
        left: 0 !important;
        top: 0 !important;
        width: 100% !important;
        height: 100% !important;
        transform: none !important;
        background: var(--bg-ivory, #FAF9F6) !important;
        z-index: 1200 !important; /* Перекрывает логотип и всё остальное */
        padding: 0 15px !important;
        display: flex;
        align-items: center;
        justify-content: space-between;
    }

    .raffia-search-takeover.is-active .raffia-search-inline-wrapper {
        flex-grow: 1;
        display: flex;
        align-items: center;
        width: 100%;
    }

    /* Показываем панель с инпутом */
    .raffia-search-takeover.is-active .raffia-search-slide-panel {
        display: block !important;
        position: static !important;
        transform: none !important;
        width: 100% !important;
        padding: 0 !important;
        opacity: 1 !important;
        visibility: visible !important;
        pointer-events: auto !important;
        flex-grow: 1;
        margin-right: 15px;
    }

    /* Дизайн поля ввода: прозрачный фон + золотая линия */
    .raffia-search-takeover.is-active .raffia-search-slide-input {
        width: 100% !important;
        background-color: transparent !important;
        border: none !important;
        border-bottom: 1.5px solid var(--brand-gold) !important;
        padding: 8px 5px !important;
        font-size: 16px !important;
        border-radius: 0 !important;
        box-shadow: none !important;
        color: var(--brand-black) !important;
    }

    /* Показываем золотой крестик */
    .raffia-search-takeover.is-active .raffia-search-close {
        display: flex !important;
        background: none;
        border: none;
        color: var(--brand-gold) !important;
        padding: 5px;
        margin-left: 10px;
        cursor: pointer;
    }
}
/* ==========================================================================
   3. ОБЩАЯ МЕХАНИКА И ДИЗАЙН ВЫПАДАЮЩИХ ОКОН (DROPDOWNS)
   ========================================================================== */
.header-left .dropdown-toggle::after,
.header-right .dropdown-toggle::after,
header .dropdown.d-grid > button.btn-dark.dropdown-toggle::after {
    display: none !important; 
}

.header-left .dropdown,
.header-right .dropdown {
    display: flex;
    align-items: center;
    position: relative !important;
}

header .dropdown .dropdown-menu {
    z-index: 9999 !important;
}

.raffia-header .dropdown-menu {
    background-color: var(--bg-ivory) !important;
    border: none !important;
    box-shadow: 0 15px 30px rgba(0, 0, 0, 0.08) !important;
    border-radius: 4px !important;
}

.raffia-header .dropdown-menu .dropdown-divider,
.raffia-header .dropdown-menu hr {
    display: none !important;
}

.raffia-header .dropdown-menu li,
.raffia-header .dropdown-menu a {
    border-bottom: none !important;
}

@keyframes fadeInDropdown {
    from { opacity: 0; transform: translateY(5px); }
    to { opacity: 1; transform: translateY(0); }
}

.header-left .dropdown-menu::before,
.header-right .dropdown-menu::before {
    content: '';
    position: absolute;
    top: -15px; left: 0; right: 0; height: 15px;
    background: transparent;
    z-index: 1080;
}

@media (min-width: 769px) {
    .header-left .dropdown:hover .dropdown-menu,
    .header-right .dropdown:hover .dropdown-menu,
    .header-right .dropdown:focus-within .dropdown-menu,
    #cart:hover .dropdown-menu,
    .raffia-header #cart:hover .dropdown-menu,
    header .dropdown.d-grid:hover .dropdown-menu {
        display: block !important;
        animation: fadeInDropdown 0.2s ease-in-out forwards !important;
    }
}

/* ==========================================================================
   4. СИСТЕМНЫЕ МЕНЮ: ЯЗЫК И ВАЛЮТА
   ========================================================================== */
.header-left .dropdown-menu,
.header-right .dropdown-menu {
    position: absolute !important;
    top: 100% !important;
}

.header-left .dropdown-menu {
    margin-top: 10px !important;
    border-radius: 8px !important;
    min-width: 140px !important;
    padding: 15px 20px !important;
    left: 0 !important;
    right: auto !important;
    text-align: left;
    transform: none !important;
    inset: 100% auto auto 0 !important; 
    margin: 10px 0 0 0 !important;       
}

.header-right .dropdown-menu {
    margin-top: 15px !important;
    background-color: transparent !important;
    box-shadow: none !important;
    min-width: auto;
    padding: 0;
    right: 0 !important;
    left: auto !important;
    text-align: right;
}

.header-left .dropdown-item,
.header-right .dropdown-item {
    background-color: transparent !important; 
    color: var(--text-muted) !important;                
    padding: 8px 0 !important; 
    transition: color 0.3s ease !important;
    font-family: 'Montserrat', sans-serif !important;
    font-size: 13px !important;
    white-space: nowrap !important; 
}

.header-left .dropdown-item:hover,
.header-right .dropdown-item:hover { color: var(--brand-gold) !important; }

.raffia-active-currency {
    font-family: 'Montserrat', sans-serif;
    font-size: 24px;
    font-weight: 400;
    line-height: 1;
    display: flex;
    align-items: center;
    justify-content: center;
    width: 22px; 
    height: 22px;
}

/* ==========================================================================
   5. МЕНЮ АККАУНТА И АВТОРИЗАЦИЯ
   ========================================================================== */
#raffia-auth-dropdown {
    background-color: var(--bg-ivory) !important;
    border: none !important;
    box-shadow: 0 15px 35px rgba(0, 0, 0, 0.08) !important;
    z-index: 9999 !important;
    min-width: 320px !important;
    padding: 20px 20px 25px !important; 
    right: -48px !important; 
    border-radius: 8px !important;
    margin-top: 10px !important;
}

#raffia-auth-dropdown .dropdown-item,
#raffia-auth-dropdown a:not(.btn-raffia-submit) {
    padding: 6px 0 !important;
    font-size: 14px;
    font-weight: 300;
}

#raffia-auth-dropdown .text-end { margin-top: 5px !important; }

#raffia-auth-dropdown h2, 
#raffia-auth-dropdown #form-login p:first-of-type,
#raffia-auth-dropdown #form-forgotten h1,
#raffia-auth-dropdown #form-forgotten p { display: none !important; }

#raffia-auth-dropdown .form-control {
    background-color: rgba(197, 160, 33, 0.03) !important;
    border: 1px solid #E8E0C5 !important;
    padding: 10px 15px !important;
    font-size: 0.9rem !important;
    border-radius: 4px !important;
    color: #333 !important;
    transition: border-color 0.3s ease, background-color 0.3s ease;
}

#raffia-auth-dropdown .form-control:focus {
    border-color: #C5A059 !important;
    background-color: rgba(197, 160, 33, 0.06) !important;
    box-shadow: none !important;
}

#raffia-auth-dropdown .mb-3 { margin-bottom: 1rem !important; }
#raffia-auth-dropdown .btn-primary:hover { background-color: #B38E4D !important; }

.desktop-forgot-link,
#raffia-auth-dropdown a[href*="forgotten"] {
    display: inline-block;
    color: var(--text-muted) !important;
    text-decoration: none !important;
    font-size: 13px !important;
    font-weight: 300 !important;
    transition: color 0.3s !important;
    margin: 5px 0 15px 0;
    border-bottom: 1px solid transparent;
}

.desktop-forgot-link:hover,
#raffia-auth-dropdown a[href*="forgotten"]:hover {
    color: var(--brand-gold) !important;
    border-bottom-color: var(--brand-gold);
}

button[type="submit"].desktop-submit-btn {
    flex: 0 0 42px !important;
    width: 42px !important;
    height: 42px !important;
    padding: 0 !important;
    border-radius: 50% !important;
    border: 1px solid var(--brand-gold) !important;
    background: transparent !important;
    color: var(--brand-gold) !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    transition: all 0.3s !important;
    text-transform: none !important; 
}

button[type="submit"].desktop-submit-btn:hover { background: var(--brand-gold) !important; color: var(--bg-ivory) !important; }

#raffia-auth-dropdown .text-danger,
#raffia-auth-dropdown .auth-error-message,
#raffia-auth-dropdown .alert-danger {
    color: #e63946 !important; 
    font-size: 13px;
    text-align: center;
    margin-bottom: 15px;
    font-weight: 500;
    line-height: 1.4;
}

#raffia-auth-dropdown .dropdown-divider { margin: 1.5rem 0; border-top-style: dashed; }
#raffia-auth-dropdown .btn-outline-secondary {
    border-color: #dee2e6 !important; color: #6c757d !important; text-transform: uppercase; font-size: 0.8rem; font-weight: 600;
}

/* ==========================================================================
   ГЛОБАЛЬНЫЙ ДИЗАЙН СИСТЕМЫ ФОРМ (INPUTS, SELECTS, TEXTAREAS)
   ========================================================================== */

/* Универсальный стиль для ВСЕХ текстовых полей, выпадающих списков и областей ввода */
.form-control,
.form-select,
input[type="text"],
input[type="password"],
input[type="email"],
input[type="date"],
input[type="time"],
input[type="datetime-local"],
select,
textarea {
    width: 100% !important;
    height: auto !important;
    background-color: rgba(197, 160, 33, 0.03) !important; /* Наш фирменный беж */
    border: none !important;
    border-bottom: 1px solid rgba(197, 160, 33, 0.3) !important; 
    border-radius: 4px 4px 0 0 !important;
    padding: 12px 15px !important;
    outline: none !important;
    font-family: 'Montserrat', sans-serif !important;
    font-size: 14px !important;
    color: var(--brand-black) !important;
    box-shadow: none !important;
    transition: background-color 0.3s ease, border-color 0.3s ease !important;
}

/* Эффект фокуса для всех элементов */
.form-control:focus,
.form-select:focus,
input:focus,
select:focus,
textarea:focus {
    background-color: rgba(197, 160, 33, 0.06) !important;
    border-bottom-color: var(--brand-gold) !important;
    box-shadow: none !important;
}

/* Унификация плейсхолдеров */
::placeholder,
::-webkit-input-placeholder,
::-moz-placeholder,
:-ms-input-placeholder {
    color: var(--text-muted) !important; 
    font-weight: 400 !important; 
    opacity: 0.75 !important; 
}

/* Фикс автозаполнения браузеров */
input:-webkit-autofill,
textarea:-webkit-autofill,
select:-webkit-autofill {
    -webkit-box-shadow: 0 0 0 50px var(--bg-ivory) inset !important;
    -webkit-text-fill-color: var(--brand-black) !important;
}

/* Корректировка для выпадающих списков (выравнивание стрелочки) */
.form-select, select {
    background-position: right 15px center !important;
    padding-right: 40px !important;
}

/* ==========================================================================
   6. КОРЗИНА: ИКОНКА И ВЫПАДАЮЩЕЕ ОКНО (CSS-Override)
   ========================================================================== */
.raffia-cart-wrapper { position: relative; display: flex; align-items: center; cursor: pointer; }

.raffia-cart-badge {
    position: absolute; top: -6px; right: -8px;
    background-color: var(--brand-gold); color: var(--bg-ivory);
    font-size: 9px; font-weight: 600; font-family: 'Montserrat', sans-serif;
    width: 16px; height: 16px; border-radius: 50%;
    display: flex; justify-content: center; align-items: center;
    line-height: 1; pointer-events: none; 
}

header .dropdown.d-grid > button.btn-dark.dropdown-toggle {
    background-color: transparent !important;
    border: none !important;
    color: transparent !important; 
    font-size: 0 !important;
    font-weight: 500 !important;
    box-shadow: none !important;
    display: flex !important;
    align-items: center !important;
    padding: 0 !important;
}

header .dropdown.d-grid > button.btn-dark.dropdown-toggle > i.fa-cart-shopping {
    display: none !important;
}

header .dropdown.d-grid > button.btn-dark.dropdown-toggle::before {
    content: "" !important;
    display: inline-block !important;
    width: 24px !important;
    height: 24px !important;
    margin-right: 0 !important;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23bfa374' stroke-width='1.25' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='9' cy='21' r='1'%3E%3C/circle%3E%3Ccircle cx='20' cy='21' r='1'%3E%3C/circle%3E%3Cpath d='M1 1h4l2.68 13.39a2 2 0 0 0 2 1.61h9.72a2 2 0 0 0 2-1.61L23 6H6'%3E%3C/path%3E%3C/svg%3E") !important;
    background-size: contain !important;
    background-repeat: no-repeat !important;
}

header .dropdown.d-grid .dropdown-menu {
    background-color: var(--bg-ivory, #fff) !important;
    border: none !important;
    box-shadow: 0 15px 35px rgba(0, 0, 0, 0.08) !important;
    border-radius: 4px !important;
    margin-top: 10px !important;
    min-width: 220px !important; 
}

header .dropdown.d-grid .dropdown-menu li.text-center {
    font-size: 14px !important;       
    font-weight: 300 !important;      
    color: #666 !important;           
    padding: 20px !important;        
    white-space: nowrap !important;  
}

/* ==========================================================================
   7. ГЛАВНОЕ МЕНЮ И МЕГА-МЕНЮ (ДЕСКТОП)
   ========================================================================== */
.raffia-menu-wrapper {
    background-color: var(--bg-ivory);
    padding-bottom: 10px;
    position: relative; 
}

#menu {
    background-color: transparent !important;
    background-image: none !important;
    border: none !important;
    box-shadow: none !important;
    margin-bottom: 0;
    min-height: auto;
    display: flex;
    justify-content: center;
}

#menu .navbar-nav {
    display: flex;
    justify-content: center;
    align-items: center;
    width: 100%;
    flex-direction: row;
    margin: 0;
    padding: 0;
}

#menu .navbar-nav > li { position: static; }

#menu .navbar-nav > li > a.nav-link {
    background-color: transparent !important;
    color: var(--brand-black) !important;
    font-size: 12px;
    font-weight: 400;
    text-transform: uppercase;
    letter-spacing: 2.5px;
    padding: 15px 20px;
    transition: color 0.3s ease;
    display: block;
    text-align: center;
    text-decoration: none;
    pointer-events: auto !important;
    cursor: pointer !important;
    position: relative;
    z-index: 1060;
}

#menu .navbar-nav > li > a.nav-link svg { transition: transform 0.3s ease; }

#menu .navbar-nav > li > a.nav-link:hover, 
#menu .navbar-nav > li.has-megamenu:hover > a.nav-link {
    color: var(--brand-gold) !important;
}

#menu .navbar-nav > li.has-megamenu.show > a.nav-link,
#menu .navbar-nav > li.has-megamenu > a.nav-link:focus { pointer-events: auto !important; }

#menu .btn-navbar { background-color: var(--brand-gold); }
#menu .btn-navbar, #menu .navbar-toggler, #menu .navbar-toggler i, .navbar-light .navbar-toggler-icon {
    color: var(--brand-black) !important; 
    border-color: transparent !important; 
    background-image: none !important; 
}

.megamenu-wrapper {
    position: absolute; top: 100%; left: 50%;
    width: 100vw; margin-left: -50vw;
    background-color: var(--bg-ivory); z-index: 1050;
    display: block !important; opacity: 0; visibility: hidden; pointer-events: none;
    transform: translateY(5px);
    transition: opacity 0.3s ease, visibility 0.3s ease, transform 0.3s ease;
}

.megamenu-wrapper::before {
    content: ''; position: absolute; top: -30px; left: 0; right: 0; height: 30px; background: transparent;
}

.megamenu-container { max-width: 100%px; margin: 0 auto; padding: 0 0 30px; }
.megamenu-inner { display: flex; flex-direction: row; justify-content: flex-start; align-items: flex-start; gap: 50px; flex-wrap: nowrap; }
.megamenu-column { flex: 0 0 auto; min-width: 180px; flex-grow: 1; }

.megamenu-title {
    display: block; font-family: 'Montserrat', sans-serif; font-weight: 600; font-size: 13px;
    color: var(--brand-black) !important; text-transform: none; letter-spacing: 0.5px;
    margin-bottom: 12px; text-decoration: none; transition: color 0.3s ease;
}
.megamenu-title:hover { color: var(--brand-gold) !important; }

.megamenu-list { margin: 0; padding: 0; list-style: none; display: block !important; }
.megamenu-list li { break-inside: avoid-column; -webkit-column-break-inside: avoid; display: block; width: 100%; margin-bottom: 6px; }
.megamenu-list.cols-2, .megamenu-list.cols-3 { column-fill: balance; width: max-content; }
.megamenu-list.cols-2 { column-count: 2; column-gap: 40px; min-width: 380px; }
.megamenu-list.cols-3 { column-count: 3; column-gap: 30px; min-width: 560px; }

.megamenu-link {
    color: var(--text-muted) !important; font-family: 'Montserrat', sans-serif; font-size: 12px; font-weight: 400;
    text-transform: none; text-decoration: none; display: block; padding: 4px 0; transition: color 0.3s ease, padding-left 0.3s ease;
}
.megamenu-link:hover { color: var(--brand-gold) !important; padding-left: 5px; }

@media (min-width: 769px) {
    #menu .navbar-nav > li.has-megamenu:hover .megamenu-wrapper {
        opacity: 1; visibility: visible; pointer-events: auto; transform: translateY(0);
    }
    #menu .navbar-nav > li.has-megamenu:hover > a.nav-link svg { transform: rotate(180deg); }
    .d-none.d-lg-block .megamenu-wrapper, #menu .has-megamenu .megamenu-wrapper {
        background-color: var(--bg-ivory) !important; border: none !important; border-top: none !important; border-bottom: none !important;
        box-shadow: 0 25px 25px -15px rgba(0, 0, 0, 0.1) !important; z-index: 1050 !important; 
    }
}

/* ==========================================================================
   8. БОКОВОЕ МЕНЮ КАТЕГОРИЙ (ЛЕВАЯ/ПРАВАЯ КОЛОНКА)
   ========================================================================== */
#column-left .raffia-sidebar-menu,
#column-right .raffia-sidebar-menu { border-radius: 0; box-shadow: none; background: transparent; padding-top: 10px; }

#column-left .list-group-item,
#column-right .list-group-item {
    border: none !important; background-color: transparent !important;
    padding: 12px 0 !important; display: block; transition: color 0.3s ease, opacity 0.3s ease;
}

#column-left .list-group-item.cat-level-1 {
    color: var(--brand-black) !important; font-size: 14px; font-weight: 500; text-transform: uppercase; letter-spacing: 1.5px; 
}
#column-left .list-group-item.cat-level-1:hover, #column-left .list-group-item.cat-level-1.active { color: var(--brand-gold) !important; }

#column-left .list-group-item.cat-level-2 {
    color: var(--brand-gold) !important; font-size: 13px; font-weight: 300; text-transform: uppercase; letter-spacing: 1px; padding-left: 20px !important; opacity: 0.8; 
}
#column-left .list-group-item.cat-level-2:hover, #column-left .list-group-item.cat-level-2.active { opacity: 1; font-weight: 400; }

#column-left .list-group-item.cat-level-3 {
    color: var(--text-muted) !important; font-size: 13px; font-weight: 300; text-transform: none; padding-left: 35px !important; 
}
#column-left .list-group-item.cat-level-3:hover, #column-left .list-group-item.cat-level-3.active { color: var(--brand-gold) !important; font-weight: 400; }

/* ==========================================================================
   ХЛЕБНЫЕ КРОШКИ (BREADCRUMBS)
   ========================================================================== */
.breadcrumb {
    font-size: 11px !important; /* Делаем шрифт компактным */
    background: transparent !important;
    padding: 0 !important;
    margin-bottom: 25px !important;
    opacity: 0.7; /* Приглушаем весь блок, чтобы он не кричал */
    --bs-breadcrumb-divider: '•'; 
    --bs-breadcrumb-divider-color: var(--brand-gold); 
}

.breadcrumb a {
    color: var(--brand-black) !important; /* Ваш основной цвет текста */
    text-decoration: none !important;
    transition: color 0.3s ease, opacity 0.3s ease;
}

.breadcrumb a:hover {
    color: var(--brand-gold) !important; /* При наведении становятся золотыми */
    opacity: 1;
}

/* Красим разделитель (точечку или слеш) в нейтральный цвет */
.breadcrumb-item + .breadcrumb-item::before {
    color: #b0a090 !important; 
}

/* ==========================================================================
   10. ВСПЛЫВАЮЩЕЕ ПРИВЕТСТВИЕ (ДЕСКТОП)
   ========================================================================== */
.raffia-desktop-greeting {
    position: absolute; top: 45px; right: -10px; 
    background-color: var(--bg-ivory); color: var(--brand-gold);
    padding: 10px 20px; border-radius: 6px;
    font-family: 'Montserrat', sans-serif; font-size: 13px; font-weight: 500;
    box-shadow: 0 10px 25px rgba(0,0,0,0.1); white-space: nowrap; 
    z-index: 10000; pointer-events: none; border: 1px solid rgba(197, 160, 33, 0.2);
    opacity: 0; transform: translateY(10px); transition: opacity 0.4s ease, transform 0.4s cubic-bezier(0.175, 0.885, 0.32, 1.275);
}

.raffia-desktop-greeting::after {
    content: ''; position: absolute; top: -6px; right: 18px; 
    width: 10px; height: 10px; background-color: var(--bg-ivory);
    border-top: 1px solid rgba(197, 160, 33, 0.2); border-left: 1px solid rgba(197, 160, 33, 0.2);
    transform: rotate(45deg);
}

/* ==========================================================================
   11. МОБИЛЬНАЯ ВЕРСИЯ: OFFCANVAS И АДАПТИВНОСТЬ
   ========================================================================== */
.mobile-offcanvas-header {
    display: flex; align-items: center; justify-content: space-between; padding: 15px 20px; background-color: #FAF9F6; 
}
.mobile-header-side { display: flex; align-items: center; flex: 1; }
.mobile-header-side.left-side { justify-content: flex-start; gap: 15px; }
.mobile-header-side.right-side { justify-content: flex-end; }
.mobile-header-center { display: flex; justify-content: center; flex: 1; }

.header-icon-link {
    color: var(--brand-gold, #c5a021); display: flex; align-items: center; justify-content: center; text-decoration: none; transition: color 0.3s ease;
}
.header-icon-link:hover { color: var(--brand-black, #1a1a1a); }

.mobile-lang-wrap form, .mobile-curr-wrap form { margin: 0; display: flex; align-items: center; }
.mobile-lang-wrap .dropdown-toggle, .mobile-curr-wrap .dropdown-toggle {
    color: var(--brand-gold) !important; display: flex; align-items: center; justify-content: center; text-decoration: none; background: transparent; border: none; padding: 0;
}
.mobile-lang-wrap .dropdown-toggle:hover, .mobile-curr-wrap .dropdown-toggle:hover { color: var(--brand-black) !important; }
.mobile-lang-wrap .dropdown-toggle svg { width: 22px; height: 22px; stroke-width: 1.5px; }

.mobile-curr-wrap .dropdown-toggle, .mobile-curr-wrap .dropdown-toggle strong, .mobile-curr-wrap .dropdown-toggle span {
    font-size: 24px; line-height: 1; font-family: 'Montserrat', sans-serif; display: flex; align-items: center; transform: translateY(3px) !important;
}
.mobile-curr-wrap .dropdown-toggle strong, .mobile-curr-wrap .dropdown-toggle span { font-weight: 400 !important; margin: 0 !important; padding: 0 !important; }
.mobile-lang-wrap .dropdown-toggle::after, .mobile-curr-wrap .dropdown-toggle::after { display: none !important; }
.mobile-curr-wrap .raffia-active-currency { position: relative !important; top: 1px !important; }

.offcanvas-body .raffia-menu-wrapper, .offcanvas-body #menu, .offcanvas-body #menu .navbar-nav {
    display: block !important; visibility: visible !important; opacity: 1 !important; height: auto !important;
}

@media (max-width: 768px) {
    .raffia-header { padding: 20px 0; }
    .raffia-header-inner { padding: 0 10px; }
    .header-left, .header-right { gap: 15px; }
    .raffia-icon-link { font-size: 16px; -webkit-text-stroke: 0; }
    .header-center img { height: 50px; }
    .raffia-logo-text { font-size: 22px; letter-spacing: 3px; }
    #menu .navbar-nav { flex-direction: column; text-align: center; }
    #menu .navbar-nav > li > a.nav-link { padding: 12px 10px; }
    .carousel-inner img, .carousel-item img { object-position: center; }
    .carousel-caption { text-align: center; left: 5%; right: 5%; }
    
    .raffia-search-slide-panel {
        width: calc(100vw - 150px); background-color: var(--bg-ivory); z-index: 1050; padding: 20px 0 25px; box-shadow: -2px 0 5px var(--bg-ivory);
    }
    .raffia-search-slide-input { width: 100%; font-size: 16px; background-color: var(--bg-ivory); padding-right: 35px; }
    
    .header-right .raffia-icon-link { margin-left: 10px; }
    .raffia-menu-wrapper { display: none !important; }
    #menu { display: none !important; }
    .hide-on-mobile { display: none !important; }
}

/* ==========================================================================
   ФИКС "СХЛОПЫВАНИЯ" ВЫСОТЫ: Невидимая страховочная сетка для аккаунта
   ========================================================================== */
#raffia-auth-dropdown::after {
    content: '';
    position: absolute;
    top: 100%; 
    left: 0;
    right: 0;
    height: 300px; 
    background: transparent; 
    cursor: default;
}

/* ==========================================================================
   12. СТРАНИЦА АККАУНТА (Особистий кабінет)
   ========================================================================== */
#content h2 {
    font-family: 'Montserrat', sans-serif;
    font-size: 18px !important;
    font-weight: 500 !important;
    color: var(--brand-black) !important;
    text-transform: uppercase;
    letter-spacing: 2px;
    margin-top: 40px;
    margin-bottom: 20px;
    border-bottom: 1px solid rgba(197, 160, 33, 0.2); 
    padding-bottom: 12px;
}

#content h2:first-of-type {
    margin-top: 0; 
}

/* ==========================================================================
   13. ПЛИТОЧНЫЙ ДАШБОРД АККАУНТА
   ========================================================================== */
.raffia-account-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
    gap: 20px;
    margin-bottom: 45px;
}

.raffia-account-tile {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    text-align: center;
    background-color: var(--bg-ivory);
    border: 1px solid rgba(197, 160, 33, 0.2); 
    border-radius: 8px;
    padding: 30px 15px;
    text-decoration: none !important;
    transition: all 0.3s cubic-bezier(0.25, 0.8, 0.25, 1);
    box-shadow: 0 4px 15px rgba(0,0,0,0.02);
}

.raffia-account-tile:hover {
    border-color: var(--brand-gold);
    box-shadow: 0 10px 25px rgba(197, 160, 33, 0.15); 
    transform: translateY(-4px); 
}

.raffia-account-tile svg {
    width: 32px;
    height: 32px;
    stroke: var(--brand-gold);
    margin-bottom: 15px;
    transition: transform 0.3s ease;
}

.raffia-account-tile:hover svg {
    transform: scale(1.1); 
}

.raffia-account-tile span {
    color: var(--brand-black);
    font-family: 'Montserrat', sans-serif;
    font-size: 13px;
    font-weight: 500;
    line-height: 1.4;
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

#content ul.list-unstyled {
    display: none !important;
}

/* ==========================================================================
   25. ФУТЕР (Premium Redesign - Очищенная версия)
   ========================================================================== */
footer {
    background-color: var(--bg-olive);
    border-top: 1px solid #dcdcd6;
    margin-bottom: 0;
}

.rf-newsletter-wrapper {
    background-color: #dfdfd9; 
    border: none !important;
}

.rf-newsletter-text {
    font-family: 'Montserrat', sans-serif;
    font-size: 14px !important;
    font-weight: 500 !important;
    color: var(--brand-black) !important;
    line-height: 1.4 !important;
    margin-bottom: 0;
    text-transform: none !important;
}

.rf-premium-form input.form-control {
    height: 45px !important;
    background-color: transparent !important;
    border: none !important;
    border-bottom: 1px solid var(--dark-olive) !important;
    border-radius: 0 !important;
    font-family: 'Montserrat', sans-serif !important;
    font-size: 14px !important;
    color: var(--brand-black) !important;
    box-shadow: none !important;
    padding-left: 0 !important;
}

.rf-premium-form input.form-control:focus {
    border-bottom: 1px solid var(--brand-black) !important;
    background-color: transparent !important;
    box-shadow: none !important;
    outline: none !important;
}

.rf-premium-form input.form-control:-webkit-autofill {
    -webkit-text-fill-color: var(--brand-black) !important;
    transition: background-color 5000s ease-in-out 0s !important;
}

.rf-premium-form input.form-control::placeholder {
    color: var(--text-muted) !important;
    opacity: 0.6 !important; 
    font-weight: 400 !important; 
}

.rf-premium-form input.form-control::-webkit-input-placeholder {
    color: var(--text-muted) !important;
    opacity: 0.6 !important;
    font-weight: 400 !important;
}
.rf-premium-form input.form-control::-moz-placeholder {
    color: var(--text-muted) !important;
    opacity: 0.6 !important;
    font-weight: 400 !important;
}

.rf-premium-form button {
    height: 45px !important;
    background-color: transparent !important;
    border: 1px solid var(--dark-olive) !important;
    color: var(--dark-olive) !important;
    border-radius: 4px !important;
    font-family: 'Montserrat', sans-serif;
    font-size: 13px;
    font-weight: 500;
    text-transform: uppercase !important;
    letter-spacing: 1px;
    transition: all 0.3s ease;
    white-space: nowrap;
}

.rf-premium-form button:hover {
    background-color: var(--dark-olive) !important;
    color: var(--bg-ivory) !important;
}

.rf-brand-column {
    padding-right: 40px;
}

.rf-footer-logo-wrap {
    display: inline-block;
    text-decoration: none !important;
    margin-bottom: 15px;
}

.rf-footer-logo-img {
    max-height: 45px !important;
    width: auto;
    display: block;
}

.rf-brand-description {
    font-family: 'Montserrat', sans-serif;
    font-size: 13px;
    line-height: 1.6;
    color: var(--text-muted);
    max-width: 320px;
}

footer h5 {
    font-family: 'Montserrat', sans-serif;
    font-size: 14px;
    font-weight: 500;
    color: var(--brand-black);
    text-transform: uppercase;
    letter-spacing: 0.5px;
    margin-bottom: 20px;
}

footer .list-unstyled a {
    font-family: 'Montserrat', sans-serif;
    font-size: 13px;
    color: var(--text-muted);
    text-decoration: none;
    transition: color 0.3s ease;
    display: block;
    margin-bottom: 12px;
}

footer .list-unstyled a:hover {
    color: var(--dark-olive);
}

.rf-contact-item {
    font-family: 'Montserrat', sans-serif;
    font-size: 13px;
    color: var(--text-muted);
    margin-bottom: 15px;
}

.rf-contact-item span {
    color: var(--brand-black);
}

@media (max-width: 767px) {
    .rf-contacts-column {
        margin-left: 0 !important;
    }
    .rf-brand-column {
        padding-right: 0;
        margin-bottom: 40px;
    }
}

hr.rf-footer-divider {
    border: none;
    border-top: 1px solid rgba(101, 108, 90, 0.2);
    opacity: 1;
}

.rf-copyright-block {
    padding-bottom: 20px;
}

.rf-copyright-block p {
    font-family: 'Montserrat', sans-serif;
    font-size: 13px;
    color: var(--text-muted);
    margin-bottom: 0 !important;
}

.rf-social-link {
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--text-muted);
}

.rf-social-link svg {
    transition: stroke 0.3s ease;
}

.rf-social-link:hover svg {
    stroke: var(--brand-black) !important; 
}

.rf-copyright-text p {
    margin-bottom: 0 !important;
    line-height: 1 !important;
    color: var(--text-muted);
}

.rf-social-link {
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 10px;
    margin: -10px;
    color: var(--text-muted);
}

.rf-social-link svg {
    transition: stroke 0.3s ease;
    display: block;
}

.rf-social-link:hover svg {
    stroke: var(--brand-black) !important;
}

@media (max-width: 767px) {
    .rf-social-link {
        padding: 15px;
        margin: -15px; 
    }
    .rf-social-icons {
        gap: 24px !important; 
    }
}

/* ==========================================================================
   14. СТРАНИЦА КОНТАКТОВ (Raffia Style)
   ========================================================================== */
#information-contact {
    padding-top: 40px;
    padding-bottom: 60px;
}

#information-contact .card {
    border: 1px solid var(--bg-olive);
    background-color: #ffffff;
    border-radius: 0;
    box-shadow: none;
    margin-bottom: 40px;
}

#information-contact .card-body {
    padding: 2rem;
}

#information-contact h3 {
    color: var(--brand-black);
    font-weight: 500;
    margin-bottom: 1.5rem;
    font-family: 'Montserrat', sans-serif;
    text-transform: uppercase;
    letter-spacing: 1px;
}

#information-contact legend {
    color: var(--brand-black);
    font-weight: 500;
    margin-bottom: 1.5rem;
    font-size: 1.25rem;
    border-bottom: 1px solid var(--bg-olive);
    padding-bottom: 10px;
}

#information-contact .form-label {
    color: var(--brand-black);
    font-size: 14px;
    margin-bottom: 8px;
}

#information-contact .form-control {
    border: 1px solid var(--bg-olive);
    border-radius: 0;
    padding: 10px 15px;
    background-color: #ffffff;
    font-family: 'Montserrat', sans-serif;
}

#information-contact .form-control:focus {
    border-color: var(--dark-olive);
    box-shadow: 0 0 0 0.1rem var(--dark-olive);
}

@media (max-width: 768px) {
    #information-contact .col-md-5, 
    #information-contact .col-md-7 {
        margin-bottom: 40px;
    }
}

/* ==========================================================================
   СТРАНИЦА КОНТАКТОВ (Raffia Ukraine - Premium Style)
   ========================================================================== */
#information-contact {
    padding-top: 50px;
    padding-bottom: 70px;
    background-color: var(--bg-ivory);
}

#information-contact h3,
#information-contact legend {
    display: none !important;
}

.rf-contact-form-col {
    padding-top: 15px;
}

.form-control {
    width: 100% !important;
    background-color: rgba(197, 160, 33, 0.03) !important; 
    border: none !important;
    border-bottom: 1px solid rgba(197, 160, 33, 0.3) !important; 
    border-radius: 4px 4px 0 0 !important; 
    padding: 12px 15px !important; 
    font-family: 'Montserrat', sans-serif !important;
    font-size: 14px !important;
    color: var(--brand-black) !important;
    box-shadow: none !important;
    outline: none !important;
    transition: background-color 0.3s ease, border-color 0.3s ease;
}

.form-control:focus {
    border-color: var(--brand-gold) !important;
    background-color: rgba(197, 160, 33, 0.06) !important; 
}

textarea.form-control {
    resize: none !important;
    height: auto !important;
}

.form-control:-webkit-autofill {
    -webkit-text-fill-color: var(--brand-black) !important;
    transition: background-color 5000s ease-in-out 0s !important;
}

.form-control::placeholder,
.form-control::-webkit-input-placeholder {
    color: var(--text-muted) !important;
    opacity: 0.8 !important;
    font-weight: 300 !important;
}

/* ==========================================================================
   СТРАНИЦА АВТОРИЗАЦИИ: ЕДИНАЯ ЦЕНТРИРОВАННАЯ КАРТОЧКА
   ========================================================================== */

/* 1. Центрируем правую колонку и задаем ширину */
.raffia-centered-login-col {
    width: 100% !important;
    max-width: 500px !important;
    margin: 40px auto 60px !important; /* Отступы сверху и снизу */
    float: none !important;
    flex: 0 0 auto !important; /* Убиваем ширину колонки Bootstrap */
    padding: 0 15px !important;
}

/* 2. Дизайн самой карточки (фон, тени, углы) */
.raffia-centered-login-col .well,
.raffia-centered-login-col .card-body {
    background-color: var(--bg-ivory) !important;
    border: none !important;
    border-radius: 12px !important;
    padding: 40px 30px !important;
    box-shadow: 0 15px 50px rgba(0,0,0,0.08) !important;
}

/* 3. Прячем стандартные надписи ("E-Mail", "Пароль") - всё в плейсхолдерах */
.raffia-centered-login-col .control-label,
.raffia-centered-login-col label.col-form-label {
    display: none !important; 
}

/* 4. Поля ввода (ваш фирменный стиль) */
.raffia-centered-login-col .form-control {
    width: 100% !important;
    background-color: rgba(197, 160, 33, 0.03) !important;
    border: none !important;
    border-bottom: 1px solid rgba(197, 160, 33, 0.3) !important;
    border-radius: 4px 4px 0 0 !important;
    padding: 12px 15px !important;
    font-family: 'Montserrat', sans-serif !important;
    font-size: 14px !important;
    color: var(--brand-black) !important;
    box-shadow: none !important;
    margin-bottom: 15px !important;
    height: auto !important;
}

.raffia-centered-login-col .form-control:focus {
    border-color: var(--brand-gold) !important;
    background-color: rgba(197, 160, 33, 0.06) !important;
}

.raffia-centered-login-col .form-control::placeholder {
    color: var(--text-muted) !important;
    opacity: 0.8 !important;
    font-weight: 300 !important;
}

/* 5. Кнопка УВІЙТИ */
.raffia-centered-login-col input[type="submit"] {
    display: flex !important;
    width: 100% !important;
    align-items: center !important;
    justify-content: center !important;
    height: 45px !important;
    background-color: transparent !important;
    border: 1px solid var(--brand-gold) !important;
    color: var(--brand-gold) !important;
    font-family: 'Montserrat', sans-serif !important;
    font-size: 13px !important;
    font-weight: 500 !important;
    text-transform: uppercase !important;
    letter-spacing: 1.5px !important;
    border-radius: 4px !important;
    transition: all 0.3s ease !important;
    margin-top: 15px !important;
    cursor: pointer !important;
    padding: 0 !important;
}

.raffia-centered-login-col input[type="submit"]:hover {
    background-color: var(--brand-gold) !important;
    color: #ffffff !important;
}

/* 6. Забули пароль */
.raffia-centered-login-col a[href*="forgotten"] {
    display: block !important;
    text-align: right !important;
    color: var(--text-muted) !important;
    font-size: 13px !important;
    margin-top: -5px !important;
    margin-bottom: 20px !important;
    text-decoration: none !important;
    font-family: 'Montserrat', sans-serif !important;
}

.raffia-centered-login-col a[href*="forgotten"]:hover {
    color: var(--brand-gold) !important;
}

/* 7. Разделитель (штрихпунктир) */
hr.raffia-login-divider {
    border-top: 1px dashed rgba(197, 160, 33, 0.3) !important;
    margin: 25px 0 !important;
    border-bottom: none !important;
}

/* ==========================================================================
   СТРАНИЦА АВТОРИЗАЦИИ (ЧИСТЫЙ ШАБЛОН)
   ========================================================================== */
/* 1. Классическое размещение сверху (Десктоп) */
#account-login,
#account-register {
    padding-top: 15px !important; 
    padding-bottom: 60px !important;
}

/* 2. Мобильная адаптация */
@media (max-width: 767px) {
    #account-login,
    #account-register {
        padding-top: 10px !important; /* На мобилках делаем отступ еще аккуратнее */
        padding-bottom: 30px !important;
    }
    
    /* Делаем внутренние отступы карточки чуть меньше на узких экранах */
    .raffia-auth-page-card {
        padding: 25px 20px !important; 
    }
    
    /* Уменьшаем расстояние между табами на мобильных */
    .raffia-auth-tabs {
        gap: 20px !important;
        margin-bottom: 25px !important;
    }
}

/* Сама карточка по центру */
.raffia-auth-page-card {
    background-color: var(--bg-ivory) !important;
    border: 1px solid rgba(197, 160, 33, 0.15) !important;
    border-radius: 12px !important;
    padding: 25px 30px !important;
    box-shadow: 0 15px 50px rgba(0, 0, 0, 0.05) !important;
}

/* Ссылка Восстановления пароля */
.raffia-auth-page-card .desktop-forgot-link {
    display: inline-block;
    color: var(--text-muted) !important;
    text-decoration: none !important;
    font-size: 13px;
    font-weight: 300;
    transition: color 0.3s;
}
.raffia-auth-page-card .desktop-forgot-link:hover {
    color: var(--brand-gold) !important;
}

/* Кнопка регистрации (ссылка-блок) */
.raffia-auth-page-card .desktop-register-btn {
    display: flex !important;
    align-items: center;
    justify-content: center;
    width: 100% !important;
    height: 45px !important;
    border: 1px solid #d4c3b3 !important;
    color: #5a5a5a !important;
    font-size: 13px !important;
    letter-spacing: 1px !important;
    border-radius: 4px !important;
    text-transform: uppercase !important;
    background: transparent !important;
    transition: all 0.3s !important;
    text-decoration: none !important;
}
.raffia-auth-page-card .desktop-register-btn:hover {
    border-color: var(--brand-gold) !important;
    color: var(--brand-gold) !important;
}

/* Стили для заголовков секций в форме регистрации */
.raffia-form-legend {
    font-family: 'Montserrat', sans-serif !important;
    font-size: 14px !important;
    font-weight: 500 !important;
    color: var(--brand-black) !important;
    text-transform: uppercase !important;
    letter-spacing: 1px !important;
    border-bottom: none !important;
    margin-bottom: 15px !important;
    padding-top: 10px !important;
}

/* ==========================================================================
   ВКЛАДКИ (ТАБЫ) АВТОРИЗАЦИИ (Ультра-минимализм, без полос)
   ========================================================================== */
.raffia-auth-tabs {
    display: flex;
    justify-content: center; /* Центрируем слова */
    gap: 40px; /* Расстояние между словами ВХІД и РЕЄСТРАЦІЯ */
    margin-bottom: 35px;
}

.raffia-auth-tabs .auth-tab {
    color: var(--brand-black) !important; /* Неактивный — черный */
    text-transform: uppercase;
    font-family: 'Montserrat', sans-serif;
    font-size: 14px;
    font-weight: 500;
    text-decoration: none;
    transition: color 0.3s ease;
    padding: 5px 10px; /* Небольшая невидимая зона вокруг текста для удобства клика пальцем */
}

/* Активная вкладка */
.raffia-auth-tabs .auth-tab.active {
    color: var(--brand-gold) !important; /* Активный — золотой */
    pointer-events: none; /* Активную вкладку нельзя кликнуть */
}

/* Эффект при наведении на неактивную */
.raffia-auth-tabs .auth-tab:hover:not(.active) {
    color: var(--brand-gold) !important; /* Становится золотой при наведении */
}

/* ==========================================================================
   ФИКС СИСТЕМНОГО КОНТЕЙНЕРА УВЕДОМЛЕНИЙ (Убираем люфт экрана)
   ========================================================================== */
#alert.toast-container {
    width: auto !important;
    max-width: 100% !important;
    right: 0 !important;
    left: auto !important;
    overflow-x: hidden !important;
    pointer-events: none;
}

#alert.toast-container .toast {
    pointer-events: auto;
}

/* ==========================================================================
   ИКОНКА ПРОСМОТРА ПАРОЛЯ (ГЛАЗИК)
   ========================================================================== */
.desktop-auth-field.position-relative {
    position: relative; /* Страховка, если класс Bootstrap не подтянется */
}

.password-toggle {
    position: absolute;
    right: 10px;
    top: 50%;
    transform: translateY(-50%);
    cursor: pointer;
    color: #b0a090;
    z-index: 10;
    transition: color 0.3s ease;
    font-size: 14px;
}

.password-toggle:hover {
    color: var(--brand-gold);
}

/* ==========================================================================
   ФИНАЛЬНЫЕ ШТРИХИ: КНОПКА И ССЫЛКИ В ЧЕКБОКСАХ
   ========================================================================== */

/* 1. Делаем кнопку высотой 45px и выравниваем текст по центру */
.desktop-login-btn {
    height: 45px !important;
    display: inline-flex !important;
    align-items: center;
    justify-content: center;
    /* Ваши остальные стили (бордюры, шрифты и т.д.) остаются без изменений */
}

/* 2. Убираем синий цвет у ссылки "Політика конфіденційності" */
.form-check-label a.modal-link,
.form-check-label a {
    color: var(--brand-gold) !important;
    text-decoration: none !important;
    transition: opacity 0.3s ease;
}

.form-check-label a:hover {
    opacity: 0.7;
}

/* 3. Выравниваем текст лейблов с самими переключателями */
.form-check.form-switch {
    display: flex;
    align-items: center;
    gap: 10px;
    padding-left: 0; /* Сбрасываем дефолтный отступ Bootstrap */
}

.form-check-input[role="switch"] {
    margin-left: 0 !important;
    margin-top: 0 !important;
    cursor: pointer;
}

.form-check-label {
    cursor: pointer;
}

/* ==========================================================================
   СИСТЕМНЫЕ ВСПЛЫВАЮЩИЕ УВЕДОМЛЕНИЯ (ТОСТЫ / АЛЕРТЫ) - ИДЕАЛ
   ========================================================================== */

/* 1. КОНТЕЙНЕР */
#alert.toast-container {
    left: 0 !important;
    right: 0 !important;
    transform: none !important;
    width: 100% !important;
    max-width: 100% !important;
    display: flex !important;
    flex-direction: column;
    align-items: center;
    padding: 15px !important;
    pointer-events: none;
    z-index: 9999; 
}

/* 2. БАЗА ПЛАШКИ: Задаем прозрачную базовую рамку в 1px */
#alert.toast-container .alert {
    pointer-events: auto;
    width: 100% !important;
    max-width: 320px !important;
    margin: 0 auto 10px auto !important;
    background-color: #ffffff !important;
    border-radius: 8px !important;
    font-family: 'Montserrat', sans-serif !important;
    font-size: 13px !important;
    color: var(--brand-black) !important;
    padding: 15px 40px 15px 20px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: flex-start !important;
    gap: 15px !important;
    line-height: 1.5 !important;
    border: 1px solid transparent !important; /* Подготовка под цветную рамку 1px */
}

/* Иконка */
#alert.toast-container .alert i {
    font-size: 20px !important;
    margin: 0 !important;
    flex-shrink: 0 !important;
}

/* ==========================================================================
   3. ОШИБКА: Изящная красная рамка 1px по всему контуру + легкое свечение
   ========================================================================== */
#alert.toast-container .alert-danger {
    border-color: rgba(230, 57, 70, 0.4) !important; /* Тонкая рамка с красным оттенком */
    box-shadow: 0 10px 30px rgba(230, 57, 70, 0.1) !important; /* Мягкая красная тень */
}
#alert.toast-container .alert-danger i {
    color: #e63946 !important;
}

/* ==========================================================================
   4. УСПЕХ: Изящная золотая рамка 1px по всему контуру
   ========================================================================== */
#alert.toast-container .alert-success {
    border-color: rgba(197, 160, 33, 0.4) !important; /* Тонкая золотая рамка */
    box-shadow: 0 10px 30px rgba(197, 160, 33, 0.1) !important;
}
#alert.toast-container .alert-success i {
    color: var(--brand-gold) !important;
}

/* 5. КРЕСТИК ЗАКРЫТИЯ */
#alert.toast-container .alert .btn-close {
    position: absolute;
    right: 15px;
    top: 50%;
    transform: translateY(-50%);
    padding: 0;
    margin: 0;
    opacity: 0.4;
    background-size: 10px;
    transition: opacity 0.3s ease;
}
#alert.toast-container .alert .btn-close:hover {
    opacity: 0.9;
}

/* ==========================================================================
   МИНИМАЛИЗМ ФОРМЫ: Скрываем текстовые ошибки под полями ввода
   ========================================================================== */
.desktop-auth-field .invalid-feedback {
    display: none !important;
}

/* Убираем сдвиг глазика пароля, если появляется иконка ошибки */
.desktop-auth-field.position-relative .password-toggle {
    position: absolute;
    right: 15px; /* Исходное положение (поменяйте на 10px, если хотите еще ближе к краю) */
    top: 50%;
    transform: translateY(-50%);
    z-index: 10;
    transition: right 0.3s ease, color 0.3s ease; /* Добавили плавную анимацию для сдвига! */
}

/* 2. МАГИЯ: Если поле получило ошибку (is-invalid) - сдвигаем глазик левее */
.desktop-auth-field .form-control.is-invalid + .password-toggle {
    right: 40px !important; /* Уступает место восклицательному знаку */
}

/* ==========================================================================
   ЕДИНЫЙ ПРЕМИАЛЬНЫЙ СТИЛЬ ДЛЯ КАЛЕНДАРЯ (iOS, Android, Desktop)
   ========================================================================== */

/* 1. Прячем дефолтную иконку браузера, но оставляем невидимую зону для клика */
input[type="date"]::-webkit-calendar-picker-indicator {
    opacity: 0; 
    cursor: pointer;
    position: absolute;
    right: 12px;
    width: 24px;
    height: 24px;
}

/* 2. Общие стили поля и наша кастомная иконка */
input[type="date"] {
    position: relative;
    -webkit-appearance: listbox;
    appearance: auto;
    
    /* Базовый цвет для уже заполненной даты */
    color: var(--brand-black) !important; 
    
    /* Наша SVG-иконка в цвете --brand-gold (#c5a021) */
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='%23c5a021' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Crect x='3' y='4' width='18' height='18' rx='2' ry='2'%3E%3C/rect%3E%3Cline x1='16' y1='2' x2='16' y2='6'%3E%3C/line%3E%3Cline x1='8' y1='2' x2='8' y2='6'%3E%3C/line%3E%3Cline x1='3' y1='10' x2='21' y2='10'%3E%3C/line%3E%3C/svg%3E") !important;
    background-repeat: no-repeat !important;
    background-position: right 10px center !important;
    background-size: 18px !important;
    padding-right: 40px !important;
}

/* 3. Цвет самой маски "дд.мм.рррр" (Имитируем стандартный ::placeholder через прозрачность) */
input[type="date"]::-webkit-datetime-edit-text,
input[type="date"]::-webkit-datetime-edit-day-field,
input[type="date"]::-webkit-datetime-edit-month-field,
input[type="date"]::-webkit-datetime-edit-year-field {
    color: var(--brand-black) !important; /* Берем основной черный цвет... */
    opacity: 0.4 !important;              /* ...и делаем его полупрозрачным, как у остальных подсказок */
}

/* 4. При клике и заполнении убираем прозрачность, чтобы введенные цифры стали четко черными */
input[type="date"]:focus::-webkit-datetime-edit-text,
input[type="date"]:focus::-webkit-datetime-edit-day-field,
input[type="date"]:focus::-webkit-datetime-edit-month-field,
input[type="date"]:focus::-webkit-datetime-edit-year-field,
input[type="date"]:active::-webkit-datetime-edit-text,
input[type="date"]:active::-webkit-datetime-edit-day-field,
input[type="date"]:active::-webkit-datetime-edit-month-field,
input[type="date"]:active::-webkit-datetime-edit-year-field {
    opacity: 1 !important;
}

/* ==========================================================================
   15. ФИРМЕННЫЕ ПЕРЕКЛЮЧАТЕЛИ (TOGGLE SWITCHERS) ДЛЯ ТЕМЫ RAFFIA
   ========================================================================== */

/* Контейнер для выравнивания свитча и текста в одну строку */
.raffia-switch-row {
    display: flex;
    align-items: center;
    gap: 12px; /* Отступ между овалом и текстом */
}

/* Превращаем чекбокс в овальный тумблер (выключенное состояние) */
.raffia-oval-switch {
    position: relative;
    width: 36px;
    height: 20px;
    -webkit-appearance: none;
    appearance: none;
    background-color: rgba(26, 26, 26, 0.1); /* База на основе вашего --brand-black */
    border: 1px solid rgba(26, 26, 26, 0.15);
    border-radius: 20px; /* Идеальный овал */
    outline: none;
    cursor: pointer;
    transition: background-color 0.25s ease, border-color 0.25s ease;
}

/* Маленький круглый ползунок внутри овала */
.raffia-oval-switch::before {
    content: '';
    position: absolute;
    top: 2px;
    left: 2px;
    width: 14px;
    height: 14px;
    background-color: #ffffff;
    border-radius: 50%;
    transition: transform 0.25s cubic-bezier(0.25, 0.8, 0.25, 1);
}

/* Эффект при наведении на выключенный тумблер */
.raffia-oval-switch:hover {
    border-color: rgba(26, 26, 26, 0.3);
}

/* Включенное состояние — строго наше рутовское золото */
.raffia-oval-switch:checked {
    background-color: var(--brand-gold) !important; /* #c5a021 */
    border-color: var(--brand-gold) !important;
}

/* Смещение белого кружка вправо при активации */
.raffia-oval-switch:checked::before {
    transform: translateX(16px);
}

/* Мягкая золотая дымка вокруг свитча при клике/фокусе */
.raffia-oval-switch:focus {
    box-shadow: 0 0 0 3px rgba(197, 160, 33, 0.15);
}

/* Текст подсказки, который стоит справа от овала */
.raffia-switch-label {
    font-family: 'Montserrat', sans-serif;
    color: var(--brand-black);
    opacity: 0.85;
    font-size: 14px;
    font-weight: 400;
    cursor: pointer;
    user-select: none;
    margin: 0;
}

/* ==========================================================================
   ИНТЕГРАЦИЯ SELECT2 С ГЛОБАЛЬНЫМИ ФОРМАМИ RAFFIA
   ========================================================================== */

/* 1. Закрытое состояние: полностью копируем стили ваших .form-control */
.select2-container--bootstrap-5 .select2-selection {
    background-color: rgba(197, 160, 33, 0.03) !important;
    border: none !important;
    border-bottom: 1px solid rgba(197, 160, 33, 0.3) !important;
    border-radius: 4px 4px 0 0 !important;
    min-height: 46px !important; 
    padding: 0 15px !important; /* Оставляем только боковые отступы */
    box-shadow: none !important;
    font-family: 'Montserrat', sans-serif !important;
    font-size: 14px !important;
    transition: background-color 0.3s ease, border-color 0.3s ease !important;
    display: flex !important;
    align-items: center !important; 
}

/* Центрируем текст внутри закрытого поля */
.select2-container--bootstrap-5 .select2-selection__rendered {
    color: var(--brand-black) !important;
    padding: 0 !important; /* Убиваем системные отступы */
    margin: 0 !important;
    line-height: 1 !important; /* Сбрасываем высоту строки */
    width: 100%;
}

/* Цвет плейсхолдера по вашему брендбуку */
.select2-container--bootstrap-5 .select2-selection__placeholder {
    color: var(--text-muted) !important;
    opacity: 0.8 !important;
    font-weight: 300 !important;
}

/* 2. Состояние при фокусе / открытии (Золотая линия и смена фона) */
.select2-container--bootstrap-5.select2-container--focus .select2-selection,
.select2-container--bootstrap-5.select2-container--open .select2-selection {
    background-color: rgba(197, 160, 33, 0.06) !important;
    border-bottom-color: var(--brand-gold) !important;
    box-shadow: none !important;
}

/* Сдвигаем стрелочку */
.select2-container--bootstrap-5 .select2-selection__arrow {
    right: 5px !important;
    top: 50% !important;
    transform: translateY(-50%) !important;
}

.select2-container--bootstrap-5 .select2-dropdown .select2-results__option--highlighted,
.select2-container--bootstrap-5 .select2-dropdown .select2-results__option--highlighted[aria-selected],
.select2-container--bootstrap-5 .select2-dropdown .select2-results__option[aria-selected="true"] {
    background-color: var(--brand-gold) !important;
    color: var(--bg-ivory) !important;
}

/* ==========================================================================
   ВЫПАДАЮЩИЙ СПИСОК (Открытый барабан с регионами)
   ========================================================================== */

/* Окно самого списка */
.select2-dropdown {
    border: none !important;
    box-shadow: 0 15px 35px rgba(0, 0, 0, 0.08) !important; /* Тень как у ваших дропдаунов */
    border-radius: 0 0 8px 8px !important;
    background-color: var(--bg-ivory) !important;
    font-family: 'Montserrat', sans-serif !important;
    overflow: hidden;
    z-index: 9999 !important; /* Чтобы список перекрывал соседние элементы */
}

/* ==========================================================================
   ПОЛЕ ПОИСКА ВНУТРИ ВЫПАДАЮЩЕГО СПИСКА (Raffia Premium: 100% + Воздух + Лупа)
   ========================================================================== */

/* 1. Убираем внутренние отступы у обертки, чтобы поле прилегло к краям от края до края */
.select2-search--dropdown {
    padding: 0 !important;
}

/* 2. Стилизуем само поле: 100% ширины, прозрачный фон и золотая лупа */
.select2-container--bootstrap-5 .select2-search .select2-search__field {
    background-color: transparent !important; /* Сливается с общим фоном меню */
    border: none !important;
    border-bottom: 1px solid rgba(197, 160, 33, 0.3) !important;
    border-radius: 0 !important; /* Убираем скругления */
    
    /* Отступы: сверху/снизу 12px, справа 20px, а слева 45px, чтобы освободить место для лупы */
    padding: 12px 20px 12px 45px !important; 
    
    font-size: 14px !important;
    color: var(--brand-black) !important;
    outline: none !important;
    box-shadow: none !important;

    /* 3. Добавляем аккуратную SVG-лупу цвета --brand-gold (#c5a021) */
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23c5a021' stroke-width='1.7' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='11' cy='11' r='8'%3E%3C/circle%3E%3Cline x1='21' y1='21' x2='16.65' y2='16.65'%3E%3C/line%3E%3C/svg%3E") !important;
    background-repeat: no-repeat !important;
    background-position: 15px center !important;
    background-size: 18px !important;
}

/* 4. Эффект при наборе текста (Фокус) */
.select2-container--bootstrap-5 .select2-search .select2-search__field:focus {
    border-bottom-color: var(--brand-gold) !important;
    background-color: transparent !important;
    box-shadow: none !important;
}

/* ==========================================================================
   КВАДРАТНЫЕ КНОПКИ-ИКОНКИ (Списки товаров, Корзина, Wishlist)
   ========================================================================== */
.btn-square-action {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 40px;
    height: 40px;
    padding: 0;
    border-radius: 4px;
    transition: all 0.3s ease;
    background: transparent;
    cursor: pointer;
    font-size: 14px;
}

/* Золотая кнопка (Купить) */
.btn-square-cart {
    border: 1px solid var(--brand-gold);
    color: var(--brand-gold);
}

.btn-square-cart:hover {
    background-color: var(--brand-gold);
    color: var(--bg-ivory);
}

/* Нейтральная кнопка (Удалить) */
.btn-square-remove {
    border: 1px solid rgba(26, 26, 26, 0.15); /* Мягкая серая рамка */
    color: var(--text-muted);
}

.btn-square-remove:hover {
    border-color: #e63946; /* Красный цвет при наведении для акцента удаления */
    color: #e63946;
}

/* Изящная рамка для фото товаров вместо стандартного img-thumbnail */
.raffia-product-img {
    border: 1px solid rgba(197, 160, 33, 0.15);
    border-radius: 4px;
    padding: 4px;
    background-color: #fff;
    transition: border-color 0.3s ease;
}

.raffia-product-img:hover {
    border-color: var(--brand-gold);
}

/* Кнопка Редактировать (Золотая) */
.btn-square-edit {
    border: 1px solid var(--brand-gold);
    color: var(--brand-gold);
}

.btn-square-edit:hover {
    background-color: var(--brand-gold);
    color: var(--bg-ivory);
}
