@import url('https://fonts.googleapis.com/css2?family=Montserrat:wght@400;500;600;700;800;900&display=swap');
@import url('/visiq-tokens.css?v=202606282702');

/* Единый шрифт проекта — Montserrat (редизайн NEON 2026) */
html, body, button, input, textarea, select { font-family: 'Montserrat', system-ui, -apple-system, 'Segoe UI', sans-serif; }
.user-name { font-family: 'Montserrat', sans-serif; }

/* ============================================================
   VisiQ — ЕДИНАЯ ЦВЕТОВАЯ СИСТЕМА (single source of truth).
   Менять палитру тут — каскадно меняется весь UI. Хардкод-цвета
   по проекту переведены на var(--...) и ссылаются сюда.
   Стиль: premium dark neon, glassmorphism, фиолет/синий/мята/розовый.
   Золото (--gold) — ТОЛЬКО V-Coins / награды / премиум / owner badge.
   ============================================================ */
:root {
    /* ============================================================
       VisiQ NEON 2026 — палитра редизайна (фото-эталон страницы user).
       НОВЫЕ переменные, старые ниже не трогаем (постраничный переход).
       Прим.: --bg-card / --glow-pink / --glow-blue уже заняты старым
       дизайном, поэтому здесь они под псевдонимами (-deep / -sh).
       ============================================================ */
    /* фоны → DS-токены (visiq-tokens.css) */
    --bg-black:     #04060C;
    --bg-deep:      var(--bg-app);
    --bg-navy:      #0B071A;
    --bg-panel:     #0B071A;
    --bg-card-deep: var(--bg-card);
    --bg-card-2:    var(--bg-card-active);
    /* неон / акценты → DS */
    --neon-purple:  var(--accent-purple);
    --neon-violet:  var(--accent-purple-active);
    --neon-pink:    var(--accent-pink);
    --neon-magenta: #C840FF;
    --neon-blue:    var(--accent-blue);
    --neon-cyan:    var(--accent-cyan);
    --neon-green:   var(--success);
    --neon-gold:    var(--accent-gold);
    --neon-red:     var(--error);
    /* градиенты → DS */
    --gradient-primary:   var(--grad-primary);
    --gradient-neon-blue: var(--grad-glass-blue);
    --gradient-pink-blue: var(--grad-neon);
    --gradient-gold:      var(--grad-vcoins);
    /* обводки / линии → DS */
    --border-purple: rgba(168, 85, 247, 0.45);
    --border-violet: rgba(168, 85, 247, 0.40);
    --border-soft:   rgba(168, 85, 247, 0.28);
    --border-active: var(--accent-purple);
    --border-blue:   var(--accent-blue);
    /* текст → DS */
    --text-main:      #FFFFFF;
    --text-secondary: #B8B2CC;
    --text-purple:    var(--accent-purple-hover);
    --text-gold:      var(--accent-gold);
    /* свечения (полный box-shadow) → DS-оттенки */
    --glow-purple-sh: 0 0 18px rgba(139, 92, 246, 0.70);
    --glow-pink-sh:   0 0 18px rgba(255, 43, 214, 0.60);
    --glow-blue-sh:   0 0 18px rgba(59, 130, 246, 0.65);
    --glow-cyan-sh:   0 0 18px rgba(0, 212, 255, 0.60);

    /* — сырые брендовые цвета → DS — */
    --vq-violet: var(--accent-purple);
    --vq-blue:   var(--accent-blue);
    --vq-mint:   var(--success);
    --vq-pink:   var(--accent-pink);
    --vq-gold:   var(--accent-gold);
    --vq-dark:   var(--bg-app);

    /* — поверхности → DS — */
    --bg:        var(--bg-app);
    --bg2:       #100720;
    --bg3:       var(--bg-input);
    --bg4:       var(--bg-card-active);
    --card:      #100720;
    --card2:     var(--bg-card-active);
    --bg-card:   #100720;
    --bg-card2:  var(--bg-card-active);

    /* — границы → DS — */
    --border:        rgba(168, 85, 247, 0.28);
    --border2:       rgba(59, 130, 246, 0.24);
    --border-accent: rgba(168, 85, 247, 0.45);
    --border-acc:    rgba(168, 85, 247, 0.45);
    --bacc:          rgba(168, 85, 247, 0.40);

    /* — текст → DS — */
    --text:       #F6F3FF;
    --muted:      #B8B2CC;
    --dim:        #7C7690;
    --text-muted: #7C7690;
    --text-dim:   #7C7690;

    /* — акценты → DS — */
    --acc:       var(--accent-purple);
    --accent:    var(--accent-purple);
    --acc2:      var(--accent-blue);
    --accent2:   var(--accent-blue);
    --acc3:      var(--success);
    --acc-deep:  var(--accent-purple-active);
    --acc-soft:  #C4B5FD;
    --pink:      var(--accent-pink);
    --gold:      var(--accent-gold);

    /* акцентные подложки/свечения → DS (фиолет alpha) */
    --adim:      rgba(168, 85, 247, 0.10);
    --aglow:     rgba(168, 85, 247, 0.30);
    --accent-dim:  rgba(168, 85, 247, 0.10);
    --accent-glow: rgba(168, 85, 247, 0.30);
    --glow:      rgba(168, 85, 247, 0.30);

    /* — семантика → DS — */
    --danger:    var(--error);
    --success:   #35F2A1;
    --warning:   #FFD166;
    --red:       var(--error);
    --green:     #35F2A1;
    --red-dim:   rgba(255, 77, 109, 0.12);
    --rdim:      rgba(255, 77, 109, 0.12);
    --green-dim: rgba(53, 242, 161, 0.12);
    --gdim:      rgba(53, 242, 161, 0.12);

    /* — свечения (rgba-цвет для box-shadow) → DS — */
    --glow-violet: rgba(168, 85, 247, 0.55);
    --glow-blue:   rgba(59, 130, 246, 0.48);
    --glow-mint:   rgba(53, 242, 161, 0.42);
    --glow-pink:   rgba(255, 43, 214, 0.46);
    --glow-gold:   rgba(246, 183, 60, 0.46);

    /* — градиенты → DS — */
    --grad-main: var(--grad-primary);
    --grad-hot:  var(--grad-neon);
    --grad-gold: var(--grad-vcoins);
    --grad-dark: var(--grad-app-bg);

    --shadow: 0 18px 50px rgba(0,0,0,0.35);
    --r: 14px;
}

* {
    margin: 0;
    padding: 0;
    box-sizing: border-box;
}

/* Тёмный фон корня — убирает белую полосу под статус-баром в APK (WebView рисует html-фон в зоне инсета) */
html {
    background-color: var(--bg, #080D16);
}

/* ============================================================
   VisiQ SCROLLBAR — единый скролл по всему проекту.
   Глобально: убирает белый системный scrollbar в модалках/панелях
   (Информация о группе, списки сообщений/чатов/участников, каталог
   подарков и любой scrollable). Кастомные scrollbar отдельных блоков
   (выше по специфичности) при желании остаются, но базово всё — VisiQ.
   Reusable: класс .visiq-scroll-area для явного применения.
   ============================================================ */
* {
    scrollbar-width: thin;                                    /* Firefox */
    scrollbar-color: var(--visiq-scrollbar-thumb, rgba(139,92,246,.65)) transparent;
}
*::-webkit-scrollbar {
    width: var(--visiq-scrollbar-size, 8px);
    height: var(--visiq-scrollbar-size, 8px);
}
*::-webkit-scrollbar-track {
    background: var(--visiq-scrollbar-track, rgba(255,255,255,.04));
    border-radius: var(--visiq-scrollbar-radius, 999px);
}
*::-webkit-scrollbar-thumb {
    background: linear-gradient(180deg, rgba(168,85,247,.95), rgba(59,130,246,.75));
    border-radius: var(--visiq-scrollbar-radius, 999px);
    border: 2px solid rgba(10,5,25,.85);
}
*::-webkit-scrollbar-thumb:hover {
    background: linear-gradient(180deg, rgba(255,43,214,.95), rgba(139,92,246,.95));
}
*::-webkit-scrollbar-corner { background: transparent; }

/* Reusable-класс для явного применения VisiQ-скролла к контейнеру */
.visiq-scroll-area {
    overflow-y: auto;
    scrollbar-width: thin;
    scrollbar-color: var(--visiq-scrollbar-thumb, rgba(139,92,246,.65)) transparent;
}
.visiq-scroll-area::-webkit-scrollbar { width: var(--visiq-scrollbar-size, 8px); height: var(--visiq-scrollbar-size, 8px); }
.visiq-scroll-area::-webkit-scrollbar-track { background: var(--visiq-scrollbar-track, rgba(255,255,255,.04)); border-radius: var(--visiq-scrollbar-radius, 999px); }
.visiq-scroll-area::-webkit-scrollbar-thumb {
    background: linear-gradient(180deg, rgba(168,85,247,.95), rgba(59,130,246,.75));
    border-radius: var(--visiq-scrollbar-radius, 999px);
    border: 2px solid rgba(10,5,25,.85);
}
.visiq-scroll-area::-webkit-scrollbar-thumb:hover { background: linear-gradient(180deg, rgba(255,43,214,.95), rgba(139,92,246,.95)); }

body {
    background:
      radial-gradient(ellipse at 12% -5%, rgba(139, 92, 246,0.13) 0%, transparent 55%),
      radial-gradient(ellipse at 88% 105%, rgba(59, 130, 246,0.11) 0%, transparent 55%),
      var(--bg-black, #000009);
    background-attachment: fixed;
    font-family: 'Montserrat', 'Segoe UI', Tahoma, sans-serif;
    color: #f0f0f0;
    line-height: 1.6;
}

/* Фиксированная шапка */
.fixed-header {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    background-color: rgba(14,14,18,0.97);
    z-index: 1000;
    padding: 15px 20px 10px 20px;
    box-shadow: 0 2px 10px rgba(0, 0, 0, 0.3);
}

/* Контент с прокруткой */
.scrollable-content {
    max-width: 1200px;
    margin: 180px auto 0 auto;
    padding: 0 20px 20px 20px;
}

.top-row {
    max-width: 1200px;
    margin: 0 auto;
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 15px;
}

.header-back-btn {
    background: none; border: none; cursor: pointer;
    width: 34px; height: 34px; flex-shrink: 0;
    display: flex; align-items: center; justify-content: center;
    border-radius: 9px; color: var(--text);
    transition: background .15s;
    -webkit-tap-highlight-color: transparent;
}
.header-back-btn:hover { background: rgba(255,255,255,.07); }
.header-back-btn:active { background: rgba(255,255,255,.12); }

.burger-menu {
    width: 32px;
    height: 24px;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    cursor: pointer;
    z-index: 10;
    order: 0;
    padding: 2px 0;
    -webkit-tap-highlight-color: transparent;
}

.burger-menu span {
    width: 100%;
    height: 2.5px;
    background-color: #aaa;
    border-radius: 3px;
    transition: transform 0.35s cubic-bezier(0.4,0,0.2,1),
                opacity   0.25s ease,
                width     0.3s ease,
                background 0.2s ease;
    transform-origin: center;
    display: block;
}

/* Hover — подсветка */
.burger-menu:hover span { background-color: var(--acc, #8B5CF6); }

/* Анимация в крестик при открытии */
.burger-menu.active span:nth-child(1) {
    transform: translateY(10px) rotate(45deg);
    background-color: var(--acc, #8B5CF6);
}
.burger-menu.active span:nth-child(2) {
    opacity: 0;
    width: 0;
    transform: scaleX(0);
}
.burger-menu.active span:nth-child(3) {
    transform: translateY(-10px) rotate(-45deg);
    background-color: var(--acc, #8B5CF6);
}

.logo-row {
    flex: 1;
    text-align: center;
    order: 1;
}

.logo-img {
    max-width: 200px;
    width: 100%;
    height: auto;
    cursor: pointer;
}

.placeholder {
    width: 30px;
    order: 2;
}

/* Профиль */
.profile-row {
    max-width: 1200px;
    margin: 0 auto 15px auto;
    background-color: #333333;
    padding: 12px 15px;
    border-radius: 12px;
}

.profile-info {
    display: flex;
    align-items: center;
    gap: 12px;
}

.avatar-circle {
    width: 45px;
    height: 45px;
    background: linear-gradient(135deg, var(--acc, #8B5CF6), var(--acc2, #3B82F6));
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 22px;
    color: white;
}

.user-details {
    display: flex;
    flex-direction: column;
}

.user-name {
    font-size: 16px;
    font-weight: bold;
    color: var(--acc, #8B5CF6);
}

.user-bio {
    font-size: 12px;
    color: #aaa;
}

/* Поиск */
.search-row {
    max-width: 1200px;
    margin: 0 auto;
}

.search-input {
    width: 100%;
    padding: 12px 20px;
    border: none;
    border-radius: 25px;
    background-color: #333333;
    color: #fff;
    font-size: 16px;
    outline: none;
    transition: all 0.3s ease;
}

.search-input:focus {
    border: 2px solid var(--acc, #8B5CF6);
    background-color: #3a3a3a;
}

.search-input::placeholder {
    color: #888;
}

/* Стили для карточек */
.services {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 25px;
    margin-bottom: 30px;
}

.service-card {
    background: #333333;
    border-radius: 12px;
    overflow: hidden;
    cursor: pointer;
    transition: transform 0.3s ease, box-shadow 0.3s ease;
    display: flex;
    flex-direction: column;
}

.service-card:hover {
    transform: translateY(-5px);
    box-shadow: 0 10px 30px rgba(0, 0, 0, 0.3);
}

.service-image {
    width: 100%;
    height: 180px;
    background: #555;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 48px;
}

.service-content {
    padding: 15px;
    flex: 1;
    display: flex;
    flex-direction: column;
}

.service-title {
    font-size: 18px;
    font-weight: bold;
    color: var(--acc, #8B5CF6);
    margin-bottom: 8px;
}

.service-description {
    font-size: 13px;
    color: #ccc;
    margin-bottom: 12px;
    line-height: 1.4;
}

.service-price {
    display: inline-block;
    font-size: 18px;
    font-weight: bold;
    color: var(--acc, #8B5CF6);
    padding: 5px 12px;
    background-color: #222222;
    border-radius: 20px;
    align-self: flex-start;
    margin-top: auto;
}

.service-card.hidden {
    display: none;
}

/* Футер */
footer {
    text-align: center;
    padding-top: 30px;
    border-top: 1px solid #555;
    color: #ccc;
    margin-top: 20px;
}

/* Модальное окно бургера */
.burger-modal {
    display: none;
    position: fixed;
    inset: 0;
    background: rgba(0,0,5,0);
    z-index: 11000;
    justify-content: flex-start;
    align-items: stretch;
    padding: 12px;
    box-sizing: border-box;
    transition: background 0.35s ease;
}

.burger-modal.open {
    background: rgba(0,0,9,0.82);
}

.burger-modal-content {
    background:
        linear-gradient(165deg, #0A0820 0%, #03030F 58%, #06021A 100%) padding-box,
        linear-gradient(150deg, #8B5CF6 0%, #6D28D9 42%, #3B82F6 100%) border-box;
    width: 86vw;
    max-width: 380px;
    height: 100%;
    padding: 0;
    border: 1.5px solid transparent;
    border-radius: 28px;
    box-shadow: 0 0 50px rgba(139, 92, 246,0.30), inset 0 0 30px rgba(139, 92, 246,0.06);
    display: flex;
    flex-direction: column;
    transform: translateX(-115%);
    transition: transform 0.35s cubic-bezier(0.4,0,0.2,1);
    overflow: hidden auto;
}

.burger-modal.open .burger-modal-content {
    transform: translateX(0);
}
/* Неон-скроллбар бургера */
.burger-modal-content { scrollbar-width: thin; scrollbar-color: #8B5CF6 transparent; }
.burger-modal-content::-webkit-scrollbar { width: 6px; }
.burger-modal-content::-webkit-scrollbar-track { background: transparent; margin: 14px 0; }
.burger-modal-content::-webkit-scrollbar-thumb {
    background: linear-gradient(180deg, var(--neon-purple,#8B5CF6), var(--neon-blue,#3B82F6));
    border-radius: 3px;
}
.burger-modal-content::-webkit-scrollbar-thumb:hover { background: linear-gradient(180deg, var(--neon-pink,#FF2BD6), var(--neon-purple,#8B5CF6)); }

/* Шапка панели */
.burger-modal-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 22px 20px 18px;
    border-bottom: 1px solid rgba(255,255,255,0.07);
}

.burger-modal-logo {
    font-size: 30px;
    font-weight: 900;
    letter-spacing: 0.5px;
    background: var(--gradient-primary, linear-gradient(90deg,#3B82F6,#8B5CF6 45%,#FF2BD6));
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
    color: transparent;
    filter: drop-shadow(0 0 14px rgba(139, 92, 246,0.45));
}
.burger-modal-logo-img {
    height: 30px;
    width: auto;
    max-width: 180px;
    display: block;
    object-fit: contain;
}

.close-modal {
    width: 44px; height: 44px;
    border-radius: 50%;
    background: rgba(139, 92, 246,0.10);
    border: 1px solid var(--border-active, #8B5CF6);
    color: var(--text-purple, #A855F7);
    font-size: 22px;
    cursor: pointer;
    display: flex; align-items: center; justify-content: center;
    transition: all 0.2s ease;
    line-height: 1;
    flex-shrink: 0;
    box-shadow: 0 0 16px rgba(139, 92, 246,0.30);
}
.close-modal:hover { background: rgba(139, 92, 246,0.22); color: #fff; box-shadow: var(--glow-purple-sh, 0 0 18px rgba(139, 92, 246,0.75)); }
.close-modal:active { transform: scale(0.9); }

/* Навигация */
.burger-nav {
    display: flex;
    flex-direction: column;
    gap: 4px;
    padding: 18px 14px;
    border-bottom: 1px solid rgba(255,255,255,0.07);
}

.nav-btn {
    background: linear-gradient(180deg, rgba(13,9,44,0.55) 0%, rgba(5,6,30,0.55) 100%);
    border: 1px solid var(--border-soft, #4F3E6B);
    color: var(--text-main, #fff);
    font-size: 16px;
    font-weight: 700;
    text-align: left;
    padding: 15px 18px;
    min-height: 72px;
    box-sizing: border-box;
    cursor: pointer;
    border-radius: 20px;
    transition: border-color 0.22s ease, box-shadow 0.22s ease, transform 0.12s ease;
    font-family: inherit;
    display: flex;
    align-items: center;
    gap: 16px;
    position: relative;
    overflow: hidden;
}

/* Левая полоска убрана — единый стиль с выпадающим меню профиля */
.nav-btn::before { display: none; }

/* Шеврон › справа на каждой кнопке навигации (как на эталоне) */
.nav-btn::after {
    content: '';
    width: 9px; height: 9px;
    margin-left: auto;
    flex-shrink: 0;
    border-right: 2.2px solid var(--text-secondary, #8C90A0);
    border-top: 2.2px solid var(--text-secondary, #8C90A0);
    transform: rotate(45deg);
    transition: border-color 0.2s ease;
}
.nav-btn:hover::after { border-color: var(--text-purple, #A855F7); }

.nav-btn:hover {
    background: linear-gradient(180deg, rgba(20,12,60,0.7) 0%, rgba(8,8,38,0.7) 100%);
    border-color: var(--border-active, #8B5CF6);
    color: #fff;
    box-shadow: 0 0 18px rgba(139, 92, 246,0.28);
    transform: none;
}
.nav-btn:hover .nav-btn-icon { background: rgba(139, 92, 246,0.22); border-color: var(--border-active, #8B5CF6); transform: scale(1.04); }

.nav-btn:active { transform: scale(0.98); }

/* Иконки кнопок навигации — контурная неон-иконка в квадрате (как на эталоне) */
.nav-btn-icon {
    width: 48px;
    height: 48px;
    flex-shrink: 0;
    border-radius: 14px;
    background: rgba(139, 92, 246,0.10);
    border: 1px solid var(--border-active, #8B5CF6);
    color: var(--text-purple, #A855F7);
    display: flex;
    align-items: center;
    justify-content: center;
    box-shadow: 0 0 14px rgba(139, 92, 246,0.32), inset 0 0 12px rgba(139, 92, 246,0.10);
    transition: background 0.15s, transform 0.15s, border-color 0.15s, box-shadow 0.15s;
}
/* когда .nav-btn-icon — это сам <svg> (часть кнопок), а не span-обёртка */
svg.nav-btn-icon { padding: 12px; box-sizing: border-box; }
.nav-btn-icon svg { width: 20px; height: 20px; }
.nav-btn:hover .nav-btn-icon { box-shadow: 0 0 20px rgba(139, 92, 246,0.55), inset 0 0 12px rgba(139, 92, 246,0.14); }

/* Строка: основная кнопка + шеврон */
.nav-btn-row {
    display: flex;
    align-items: stretch;
}
.nav-btn-row .nav-btn {
    flex: 1;
}
.nav-btn-expand {
    width: 38px; flex-shrink: 0;
    background: none; border: none;
    color: #666; cursor: pointer;
    border-radius: 12px;
    display: flex; align-items: center; justify-content: center;
    transition: color .2s, background .2s;
    padding: 0; margin-left: 2px;
}
.nav-btn-expand svg { transition: transform .25s ease; }
.nav-btn-expand:hover { color: var(--acc, #8B5CF6); background: rgba(139, 92, 246,.08); }
.nav-btn-expand.open { color: var(--acc, #8B5CF6); }
.nav-btn-expand.open svg { transform: rotate(180deg); }

/* Подменю утилит — карточка с вертикальной неон-линией слева */
.nav-submenu {
    display: none;
    flex-direction: column;
    gap: 2px;
    margin: 4px 0 6px 14px;
    padding: 8px 8px 8px 18px;
    position: relative;
    border-radius: 16px;
    background: rgba(5,6,30,0.5);
    border: 1px solid var(--border-soft, #4F3E6B);
}
.nav-submenu::before {
    content: ''; position: absolute; left: 9px; top: 12px; bottom: 12px; width: 2px;
    background: linear-gradient(180deg, var(--neon-cyan,#00D4FF), var(--neon-purple,#8B5CF6));
    border-radius: 2px; box-shadow: 0 0 8px rgba(139, 92, 246,0.7);
}
.nav-submenu.open { display: flex; }
.nav-submenu-item {
    display: flex; align-items: center; gap: 12px;
    padding: 10px 12px; border-radius: 12px;
    text-decoration: none; color: var(--text-secondary, #8C90A0);
    font-size: 14px; font-weight: 600; font-family: inherit;
    transition: all .18s;
}
.nav-submenu-item:hover { background: rgba(139, 92, 246,0.12); color: #fff; }
.nav-submenu-item svg { flex-shrink: 0; opacity: .85; color: var(--text-purple,#A855F7); }
.nav-submenu-item:hover svg { opacity: 1; }

/* Кнопки авторизации */
.auth-buttons {
    display: flex;
    flex-direction: column;
    gap: 10px;
    padding: 18px 14px;
    margin-top: auto;
}

.auth-label {
    font-size: 11px;
    font-weight: 700;
    color: #555;
    text-transform: uppercase;
    letter-spacing: 1px;
    padding: 0 4px;
    margin-bottom: 2px;
}

.modal-btn-login,
.modal-btn-register,
.modal-btn-logout {
    padding: 16px 18px;
    min-height: 58px;
    box-sizing: border-box;
    border: none;
    border-radius: 16px;
    font-size: 15px;
    font-weight: 800;
    cursor: pointer;
    transition: all 0.22s ease;
    font-family: inherit;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 12px;
    text-decoration: none;
    text-align: center;
}
.modal-btn-login svg,
.modal-btn-register svg,
.modal-btn-logout svg { width: 20px; height: 20px; flex-shrink: 0; }

.modal-btn-login {
    background: var(--gradient-primary, linear-gradient(90deg,#3B82F6,#8B5CF6 45%,#FF2BD6));
    color: #fff;
    box-shadow: 0 0 18px rgba(139, 92, 246,0.35);
}
.modal-btn-login:hover { transform: translateY(-2px); box-shadow: var(--glow-purple-sh, 0 0 18px rgba(139, 92, 246,0.75)); }

/* Центр управления (админ) — градиентная неон-рамка фиолет→синий + свечение (перебиваем инлайн в burger.js) */
#menuAdminLink {
    background:
        linear-gradient(rgba(11,8,34,0.92), rgba(6,3,20,0.92)) padding-box,
        var(--gradient-neon-blue, linear-gradient(135deg,#00D4FF 0%,#3B82F6 50%,#8B5CF6 100%)) border-box !important;
    border: 1.6px solid transparent !important;
    color: #fff !important;
    box-shadow: 0 0 24px rgba(139, 92, 246,0.45) !important;
}
#menuAdminLink svg { color: var(--text-purple, #A855F7); }
#menuAdminLink:hover { box-shadow: 0 0 32px rgba(139, 92, 246,0.7) !important; transform: translateY(-2px); }

.modal-btn-register {
    background: rgba(5,6,30,0.6);
    color: var(--text-main, #fff);
    border: 1px solid var(--border-soft, #4F3E6B);
}
.modal-btn-register:hover { background: rgba(139, 92, 246,0.10); transform: translateY(-2px); border-color: var(--border-active, #8B5CF6); }

/* Выйти — красный неон-outline */
.modal-btn-logout {
    background: rgba(255,59,107,0.07);
    color: var(--neon-red, #FF4D6D);
    border: 1px solid var(--neon-red, #FF4D6D);
    box-shadow: 0 0 16px rgba(255,59,107,0.20);
}
.modal-btn-logout:hover { background: rgba(255,59,107,0.16); transform: translateY(-2px); box-shadow: 0 0 20px rgba(255,59,107,0.40); }

.modal-btn-login:active,
.modal-btn-register:active,
.modal-btn-logout:active { transform: scale(0.96); }

/* Адаптив */
@media (max-width: 1024px) and (min-width: 769px) {
    .services {
        grid-template-columns: repeat(2, 1fr);
        gap: 20px;
    }
}

@media (max-width: 768px) {
    .fixed-header {
        padding: 10px 15px 8px 15px;
    }
    
    .scrollable-content {
        margin-top: 160px;
        padding: 0 15px 15px 15px;
    }
    
    .logo-img {
        max-width: 150px;
    }
    
    .services {
        grid-template-columns: repeat(2, 1fr);
        gap: 12px;
    }
    
    .service-image {
        height: 130px;
        font-size: 36px;
    }
    
    .service-content {
        padding: 10px;
    }
    
    .service-title {
        font-size: 14px;
        margin-bottom: 5px;
    }
    
    .service-description {
        font-size: 11px;
        margin-bottom: 8px;
        display: -webkit-box;
        -webkit-line-clamp: 2;
        -webkit-box-orient: vertical;
        overflow: hidden;
    }
    
    .service-price {
        font-size: 13px;
        padding: 3px 8px;
    }
    
    .avatar-circle {
        width: 40px;
        height: 40px;
        font-size: 18px;
    }
    
    .user-name {
        font-size: 15px;
    }
    
    .user-bio {
        font-size: 11px;
    }
    
    .search-input {
        padding: 10px 15px;
        font-size: 14px;
    }
    
    .burger-modal-content {
        width: 250px;
    }
    
    .nav-btn {
        font-size: 16px;
        padding: 10px 12px;
    }
    
    .modal-btn-login, .modal-btn-register, .modal-btn-logout {
        padding: 12px 16px;
        font-size: 16px;
    }
}

@media (max-width: 480px) {
    .scrollable-content {
        margin-top: 145px;
    }
    
    .logo-img {
        max-width: 120px;
    }
    
    .services {
        gap: 10px;
    }
    
    .service-image {
        height: 100px;
        font-size: 28px;
    }
    
    .service-title {
        font-size: 12px;
    }
    
    .service-description {
        font-size: 10px;
        -webkit-line-clamp: 2;
    }
    
    .service-price {
        font-size: 11px;
        padding: 2px 6px;
    }
    
    .avatar-circle {
        width: 35px;
        height: 35px;
        font-size: 16px;
    }
    
    .user-name {
        font-size: 13px;
    }
    
    .user-bio {
        font-size: 10px;
    }
    
    .burger-menu {
        width: 25px;
        height: 20px;
    }
}

@media (max-width: 768px) and (orientation: landscape) {
    .scrollable-content {
        margin-top: 145px;
    }
    
    .services {
        grid-template-columns: repeat(3, 1fr);
        gap: 12px;
    }
    
    .service-image {
        height: 100px;
        font-size: 32px;
    }
    
    .service-title {
        font-size: 12px;
    }
    
    .service-description {
        font-size: 10px;
        -webkit-line-clamp: 1;
    }
}

@media (min-width: 1025px) {
    .services {
        grid-template-columns: repeat(4, 1fr);
        gap: 25px;
    }
}

/* ===== НИЖНЯЯ НАВИГАЦИЯ (единые стили для всего проекта) ===== */
.bottom-nav {
    position: fixed;
    bottom: 0; left: 0; right: 0;
    height: 62px;
    padding-bottom: env(safe-area-inset-bottom, 0px);
    background: rgba(18, 18, 22, 0.96);
    backdrop-filter: blur(24px) saturate(150%);
    -webkit-backdrop-filter: blur(24px) saturate(150%);
    display: flex;
    justify-content: space-around;
    align-items: center;
    padding-left: 6px;
    padding-right: 6px;
    border-top: 1px solid rgba(255,255,255,0.06);
    z-index: 9999;
    box-shadow: 0 -2px 16px rgba(0,0,0,0.35);
}
.bottom-nav-item {
    position: relative;
    flex: 1;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 3px;
    padding: 0;
    height: 100%;
    cursor: pointer;
    transition: transform 0.15s ease, color 0.2s ease;
    color: #fff;
    -webkit-tap-highlight-color: transparent;
}
.bottom-nav-item:hover { color: var(--acc-soft, #C4B5FD); }
.bottom-nav-item:active { transform: scale(0.82); }
.bottom-nav-icon {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 25px;
    height: 25px;
    color: inherit;
    transition: color 0.2s, transform 0.2s;
    position: relative;
}
.bottom-nav-icon svg { width: 25px; height: 25px; }
.bottom-nav-label {
    font-size: 10px;
    font-weight: 700;
    font-family: inherit;
    color: inherit;
    transition: color 0.2s;
    white-space: nowrap;
    letter-spacing: 0.2px;
}
/* У первой кнопки (профиль) подписи нет */
#navProfileBottom .bottom-nav-label { display: none; }
/* Активный — оранжевый, неактивный — белый */
.bottom-nav-item.active,
.bottom-nav-item.active .bottom-nav-icon,
.bottom-nav-item.active .bottom-nav-label { color: var(--acc, #8B5CF6); }
.bottom-nav-item.active .bottom-nav-icon svg [stroke] { stroke-width: 2.1; }
/* Скользящая подсветка отключена — у Instagram её нет */
.bottom-nav-item { z-index: 1; }
.bottom-nav-indicator { display: none !important; }
/* Кружок-аватар вместо кнопки «Я» */
.bottom-nav-ava {
    width: 28px; height: 28px;
    border-radius: 50%;
    overflow: hidden;
    display: flex; align-items: center; justify-content: center;
    background: linear-gradient(135deg,var(--acc, #8B5CF6),var(--acc2, #3B82F6));
    color: var(--bg, #080D16); font-weight: 800; font-size: 12px;
    border: 2px solid #fff;
    box-sizing: border-box;
    transition: border-color .2s, box-shadow .2s;
}
.bottom-nav-ava img { width: 100%; height: 100%; object-fit: cover; display: block; }
.bottom-nav-item.active .bottom-nav-ava {
    border-color: var(--acc, #8B5CF6);
    box-shadow: 0 0 0 1.5px rgba(139, 92, 246,.55);
}
.messages-badge {
    position: absolute;
    top: 6px; right: calc(50% - 18px);
    background: var(--acc, #8B5CF6);
    color: var(--bg, #080D16);
    font-size: 9px;
    font-weight: 800;
    min-width: 16px;
    height: 16px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 0 3px;
    border: 1.5px solid rgba(28,28,32,0.97);
    z-index: 10;
    pointer-events: none;
    font-family: inherit;
}
@media (min-width: 769px) {
    .bottom-nav { gap: 0; }
    .bottom-nav-item { max-width: 90px; }
    .bottom-nav-icon, .bottom-nav-icon svg { width: 28px; height: 28px; }
    .messages-badge { top: 2px; right: calc(50% - 22px); font-size: 10px; min-width: 17px; height: 17px; }
}

/* ============================================================
   NEON НИЖНЯЯ НАВИГАЦИЯ — плавающая панель + живой микрофон (эталон 2026)
   ============================================================ */
.bottom-nav {
    bottom: calc(env(safe-area-inset-bottom,0px) + 10px) !important;
    left: 12px !important; right: 12px !important;
    max-width: 620px; margin: 0 auto;
    height: 66px !important;
    border-radius: 26px !important;
    background: linear-gradient(180deg, rgba(13,9,44,0.96), rgba(5,6,30,0.97)) !important;
    border: 1px solid var(--border-purple,#522460) !important;
    border-top: 1px solid var(--border-purple,#522460) !important;
    box-shadow: 0 12px 34px rgba(0,0,0,0.55), 0 0 26px rgba(139, 92, 246,0.18) !important;
    overflow: visible !important;
    justify-content: space-around !important;
}
.bottom-nav-item { color: var(--text-secondary,#8C90A0) !important; }
.bottom-nav-icon { color: var(--text-purple,#A855F7); filter: drop-shadow(0 0 6px rgba(139, 92, 246,0.5)); }
.bottom-nav-label { color: var(--text-secondary,#8C90A0); display: block !important; }
#navProfileBottom .bottom-nav-label { display: block !important; }
.bottom-nav-item.active, .bottom-nav-item.active .bottom-nav-icon, .bottom-nav-item.active .bottom-nav-label { color: var(--neon-pink,#FF2BD6) !important; }
.bottom-nav-item.active .bottom-nav-icon { filter: drop-shadow(0 0 11px rgba(255, 43, 214,0.9)); }
/* Аватар «Я» — неон-кольцо со свечением */
.bottom-nav-ava {
    width: 34px !important; height: 34px !important;
    border: 2px solid var(--neon-purple,#8B5CF6) !important;
    box-shadow: 0 0 12px rgba(139, 92, 246,0.7) !important;
    background: var(--bg-card-deep,#0D092C) !important;
}
.bottom-nav-item.active .bottom-nav-ava { box-shadow: 0 0 17px rgba(255, 43, 214,0.95) !important; border-color: var(--neon-pink,#FF2BD6) !important; }
/* Бейдж сообщений — красный неон */
.messages-badge { background: var(--neon-red,#FF4D6D) !important; color: #fff !important; box-shadow: 0 0 8px rgba(255,59,107,0.6); border-color: rgba(5,6,30,0.97) !important; }
/* FAB — микрофон Василисы: большой неон-кружок с живым свечением */
.bottom-nav-fab {
    position: relative; flex-shrink: 0;
    width: 62px; height: 62px; margin-top: -20px;
    border-radius: 50%; border: none; cursor: pointer; padding: 0;
    background: transparent; color: #fff;
    display: flex; align-items: center; justify-content: center;
    z-index: 3;
}
.bottom-nav-fab-ring {
    position: absolute; inset: -3px; border-radius: 50%; z-index: 0;
    background: conic-gradient(from 0deg, #FF2BD6, #A855F7, #8B5CF6, #3B82F6, #00D4FF, #8B5CF6, #FF2BD6);
    animation: fabRingSpin 5s linear infinite;
}
.bottom-nav-fab::before { content:''; position:absolute; inset:3px; border-radius:50%; background: radial-gradient(circle at 50% 38%, #1a1442, var(--bg-card-deep,#0D092C)); z-index:1; }
.bottom-nav-fab::after { content:''; position:absolute; inset:-4px; border-radius:50%; z-index:-1; box-shadow: 0 0 20px 3px rgba(139, 92, 246,0.75), 0 0 38px 6px rgba(0, 212, 255,0.40); animation: fabGlowPulse 2.6s ease-in-out infinite; }
.bottom-nav-fab svg { width: 28px; height: 28px; position: relative; z-index: 2; color: #fff; filter: drop-shadow(0 0 7px rgba(0, 212, 255,0.8)); }
.bottom-nav-fab:active { transform: scale(0.94); }
@keyframes fabRingSpin { to { transform: rotate(360deg); } }
@keyframes fabGlowPulse { 0%,100% { opacity: .55; } 50% { opacity: 1; } }

/* ============================================================
   ГЛОБАЛЬНАЯ СВЕТЛАЯ ТЕМА — «Крем + Янтарь» (Material 3)
   Активируется атрибутом html[data-theme="light"].
   Управляется из админки (id 1/5), применяется у всех.
   Блок переопределяет CSS-переменные (перекрывает :root всех
   файлов по специфичности) + адресно перекрашивает захардкоженные
   общие поверхности (шапка, бургер, нижняя навигация, карточки).
   ============================================================ */

/* Плавная анимация ТОЛЬКО в момент переключения темы
   (класс вешается boot-скриптом на 450мс, в обычной работе transition не висит) */
html.theme-switching,
html.theme-switching * {
    transition: background-color .4s ease, color .4s ease, border-color .4s ease, box-shadow .4s ease, fill .4s ease !important;
}

html[data-theme="light"] {
    /* — поверхности (тёплый off-white) — */
    --bg:          #F5F2EC;
    --bg2:         #FFFFFF;
    --bg3:         #EFEBE3;
    --bg4:         #E7E2D8;
    --bg-card:     #FFFFFF;
    --bg-card2:    #F1ECE4;
    --bg-input:    #FFFFFF;
    /* — текст — */
    --text:        #22201C;
    --text-muted:  #76726B;
    --text-dim:    #A8A39A;
    --muted:       #76726B;
    --dim:         #A8A39A;
    /* — акцент (фирменный янтарь) — */
    --accent:      #8B5CF6;
    --acc:         #8B5CF6;
    --accent2:     #3B82F6;
    --acc2:        #3B82F6;
    --accent-dim:  rgba(139, 92, 246,0.10);
    --adim:        rgba(139, 92, 246,0.10);
    --accent-glow: rgba(139, 92, 246,0.22);
    --aglow:       rgba(139, 92, 246,0.22);
    --glow:        rgba(139, 92, 246,0.22);
    /* — границы — */
    --border:        rgba(0,0,0,0.09);
    --border-accent: rgba(139, 92, 246,0.28);
    --border-acc:    rgba(139, 92, 246,0.28);
    --bacc:          rgba(139, 92, 246,0.28);
    /* — семантика — */
    --red:       #D64545;
    --red-dim:   rgba(214,69,69,0.10);
    --rdim:      rgba(214,69,69,0.10);
    --green:     #1F9D62;
    --green-dim: rgba(31,157,98,0.12);
    --gdim:      rgba(31,157,98,0.12);
    /* — тени (мягкие тёплые вместо чёрных) — */
    --shadow: 0 4px 24px rgba(80,60,30,0.10);
}

/* Глобальный фон страницы (перекрывает и body{...!important} в user1.css и др.) */
html[data-theme="light"] { background-color: #F5F2EC; }
html[data-theme="light"] body { background-color: #F5F2EC !important; color: #22201C; }
/* Декоративная золотая сетка-фон на светлом — почти не нужна, гасим */
html[data-theme="light"] body::after { opacity: .5; }

/* — Фиксированная шапка — */
html[data-theme="light"] .fixed-header {
    background-color: rgba(255,255,255,0.92);
    box-shadow: 0 2px 14px rgba(80,60,30,0.07);
    border-bottom: 1px solid rgba(0,0,0,0.06);
}
html[data-theme="light"] .burger-menu span { background-color: #6b6b70; }

/* — Профиль / поиск / карточки услуг (общие на главной) — */
html[data-theme="light"] .profile-row { background-color: #FFFFFF; box-shadow: 0 2px 12px rgba(80,60,30,0.06); }
html[data-theme="light"] .user-bio { color: #76726B; }
html[data-theme="light"] .search-input { background-color: #FFFFFF; color: #22201C; box-shadow: inset 0 0 0 1px rgba(0,0,0,0.08); }
html[data-theme="light"] .search-input:focus { background-color: #FFFFFF; border-color: var(--acc-deep, #6D28D9); }
html[data-theme="light"] .search-input::placeholder { color: #A8A39A; }
html[data-theme="light"] .service-card { background: #FFFFFF; box-shadow: 0 2px 14px rgba(80,60,30,0.07); }
html[data-theme="light"] .service-card:hover { box-shadow: 0 10px 30px rgba(80,60,30,0.14); }
html[data-theme="light"] .service-description { color: #76726B; }
html[data-theme="light"] .service-price { background-color: #F1ECE4; }
html[data-theme="light"] footer { border-top-color: rgba(0,0,0,0.1); color: #76726B; }

/* — Бургер-меню (боковая шторка) — */
html[data-theme="light"] .burger-modal-content {
    background: linear-gradient(160deg, #FFFFFF 0%, #F5F2EC 100%);
    border-right: 1px solid rgba(0,0,0,0.07);
    box-shadow: 4px 0 32px rgba(80,60,30,0.16);
}
html[data-theme="light"] .burger-modal-header { border-bottom-color: rgba(0,0,0,0.07); }
html[data-theme="light"] .burger-nav { border-bottom-color: rgba(0,0,0,0.07); }
html[data-theme="light"] .nav-btn { color: #3a3a3e; }
html[data-theme="light"] .nav-btn:hover { background: rgba(139, 92, 246,0.10); color: #A9661A; }
html[data-theme="light"] .nav-btn-expand { color: #A8A39A; }
html[data-theme="light"] .nav-btn-expand:hover { color: #A9661A; background: rgba(139, 92, 246,0.08); }
html[data-theme="light"] .nav-submenu { border-left-color: rgba(139, 92, 246,0.28); }
html[data-theme="light"] .nav-submenu-item { color: #76726B; }
html[data-theme="light"] .nav-submenu-item:hover { background: rgba(139, 92, 246,0.08); color: #A9661A; }
html[data-theme="light"] .auth-label { color: #A8A39A; }
html[data-theme="light"] .close-modal { background: rgba(0,0,0,0.04); border-color: rgba(0,0,0,0.08); color: #76726B; }
html[data-theme="light"] .close-modal:hover { background: rgba(139, 92, 246,0.12); color: #A9661A; border-color: rgba(139, 92, 246,0.3); }
html[data-theme="light"] .modal-btn-register { color: #A9661A; border-color: rgba(139, 92, 246,0.5); }
html[data-theme="light"] .modal-btn-register:hover { background: rgba(139, 92, 246,0.1); border-color: var(--acc-deep, #6D28D9); }

/* — Нижняя навигация — */
html[data-theme="light"] .bottom-nav {
    background: rgba(255,255,255,0.92);
    border-top: 1px solid rgba(0,0,0,0.07);
    box-shadow: 0 -4px 24px rgba(80,60,30,0.08);
}
html[data-theme="light"] .bottom-nav-item { color: #9a958c; }
html[data-theme="light"] .bottom-nav-item:hover { color: #A9661A; background: rgba(139, 92, 246,0.08); }
html[data-theme="light"] .bottom-nav-item.active,
html[data-theme="light"] .bottom-nav-item.active .bottom-nav-icon,
html[data-theme="light"] .bottom-nav-item.active .bottom-nav-label { color: #A9661A; }
html[data-theme="light"] .messages-badge { border-color: #FFFFFF; }

/* — Скелетоны загрузки (инлайн в head страниц) — */
html[data-theme="light"] .skel { background: linear-gradient(90deg,#ECE7DE 25%,#F6F2EB 50%,#ECE7DE 75%); background-size:200% 100%; }
html[data-theme="light"] #buildToast { background: #FFFFFF; border-color: rgba(0,0,0,0.1); color: #76726B; box-shadow: 0 4px 20px rgba(80,60,30,0.15); }