/* Layout: all sections and components */
/* ===== HEADER (topbar + nav unified) ===== */
        .topbar{
            background:var(--bg-warm);color:var(--text-2);
            font-size:.78rem;padding:10px 0;
            border-bottom:1px solid rgba(0,0,0,.06);
        }
        .topbar-inner{
            max-width:1440px;margin:0 auto;padding:0 40px;
            display:flex;justify-content:space-between;align-items:center;
        }
        .topbar-left{display:flex;gap:24px;align-items:center}
        .topbar-left a{display:flex;align-items:center;gap:6px;color:var(--text-2);transition:color .3s;font-weight:600}
        .topbar-left a:hover{color:var(--text)}
        .topbar-left svg{width:14px;height:14px;opacity:.7}
        .topbar-right{display:flex;gap:14px;align-items:center}
        .topbar-right a{color:var(--text-2);transition:color .3s;display:flex}
        .topbar-right a:hover{color:var(--gold)}
        .topbar-right svg{width:16px;height:16px}

        /* ===== NAV ===== */
        .nav{
            position:sticky;top:0;z-index:100;
            background:var(--bg);
            height:72px;transition:all .4s;
            border-bottom:1px solid rgba(0,0,0,.06);
        }
        .nav.scrolled{box-shadow:0 2px 20px rgba(0,0,0,.06);background:rgba(250,248,244,.97);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px)}
        .nav-inner{
            max-width:1440px;margin:0 auto;height:100%;
            display:flex;align-items:center;
            padding:0 40px;position:relative;
        }
        .nav-logo{display:flex;align-items:center;flex-shrink:0;gap:12px}
        .nav-logo img{height:56px;transition:height .4s}
        .nav.scrolled .nav-logo img{height:50px}
        .nav-logo-text{
            font-size:1.15rem;font-weight:800;color:var(--dark);line-height:1.15;
            letter-spacing:.03em;text-transform:uppercase;
        }
        .nav-logo-text span{
            display:block;font-size:.65rem;font-weight:600;
            color:var(--text-2);letter-spacing:.08em;text-transform:uppercase;
        }
        .nav-left{
            position:absolute;left:50%;transform:translateX(-50%);
            display:flex;gap:32px;list-style:none;align-items:center;
        }
        .nav-left a{font-size:.88rem;font-weight:600;color:var(--text-2);transition:color .3s;letter-spacing:.02em}
        .nav-left a:hover{color:var(--text)}
        .nav-right-wrap{margin-left:auto;display:flex;align-items:center;gap:20px}
        .nav-account{
            width:36px;height:36px;border-radius:50%;
            border:1.5px solid rgba(0,0,0,.1);
            display:flex;align-items:center;justify-content:center;
            color:var(--text-2);transition:all .3s;
        }
        .nav-account:hover{border-color:var(--gold);color:var(--gold)}
        .nav-account svg{width:16px;height:16px}
        .nav-cta{
            background:var(--dark);color:#fff;
            padding:10px 26px;border-radius:100px;
            font-size:.74rem;font-weight:700;transition:all .3s;letter-spacing:.02em;
        }
        .nav-cta:hover{background:var(--gold);transform:translateY(-1px)}
        .nav-burger{display:none;width:40px;height:40px;align-items:center;justify-content:center}
        .nav-burger span{display:block;width:20px;height:2px;background:var(--text);position:relative;transition:all .3s}
        .nav-burger span::before,.nav-burger span::after{content:'';position:absolute;left:0;width:20px;height:2px;background:var(--text);transition:all .3s}
        .nav-burger span::before{top:-6px}
        .nav-burger span::after{top:6px}
        .nav-burger.on span{background:transparent}
        .nav-burger.on span::before{top:0;transform:rotate(45deg)}
        .nav-burger.on span::after{top:0;transform:rotate(-45deg)}
        /* ===== ANNOUNCE BAR ===== */
        .announce-bar{
            background:var(--yellow);color:var(--dark);
            font-size:.82rem;font-weight:600;
            overflow:hidden;
            max-height:48px;
            transition:max-height .4s ease, opacity .4s ease;
        }
        .announce-bar.hidden{max-height:0;opacity:0;pointer-events:none}
        .announce-inner{
            max-width:1440px;margin:0 auto;padding:10px 40px;
            display:flex;align-items:center;justify-content:center;gap:16px;
        }
        .announce-inner p{margin:0;text-align:center}
        .announce-inner a{
            color:var(--dark);font-weight:700;text-decoration:underline;
            text-underline-offset:3px;transition:opacity .3s;
        }
        .announce-inner a:hover{opacity:.7}
        .announce-close{
            background:none;border:none;cursor:pointer;
            font-size:1.3rem;line-height:1;color:var(--dark);
            opacity:.6;transition:opacity .3s;flex-shrink:0;
            padding:0 4px;
        }
        .announce-close:hover{opacity:1}

        .mob-menu{
            position:fixed;left:0;right:0;top:0;bottom:0;z-index:99;
            background:var(--dark);
            display:flex;flex-direction:column;
            padding:100px 32px 40px;
            opacity:0;pointer-events:none;
            transition:opacity .3s ease;
            overflow-y:auto;
        }
        .mob-menu.on{opacity:1;pointer-events:all}
        body.menu-open{overflow:hidden}
        .mob-menu-nav{display:flex;flex-direction:column;gap:0;margin-bottom:24px}
        .mob-menu-nav a{
            font-size:1.1rem;font-weight:700;color:#fff;
            padding:12px 0;border-bottom:1px solid rgba(255,255,255,.06);
            transition:color .2s,transform .4s ease,opacity .4s ease;
            transform:translateX(30px);opacity:0;
        }
        .mob-menu-nav a:hover{color:var(--gold)}
        .mob-menu.on .mob-menu-nav a{transform:translateX(0);opacity:1}
        .mob-menu.on .mob-menu-nav a:nth-child(1){transition-delay:.05s}
        .mob-menu.on .mob-menu-nav a:nth-child(2){transition-delay:.08s}
        .mob-menu.on .mob-menu-nav a:nth-child(3){transition-delay:.11s}
        .mob-menu.on .mob-menu-nav a:nth-child(4){transition-delay:.14s}
        .mob-menu.on .mob-menu-nav a:nth-child(5){transition-delay:.17s}
        .mob-menu.on .mob-menu-nav a:nth-child(6){transition-delay:.20s}
        .mob-menu.on .mob-menu-nav a:nth-child(7){transition-delay:.23s}
        .mob-menu.on .mob-menu-contacts{transform:translateX(0);opacity:1;transition-delay:.26s}
        .mob-menu.on .mob-menu-socials{transform:translateX(0);opacity:1;transition-delay:.3s}
        .mob-menu.on .mob-menu-cta{transform:translateY(0);opacity:1;transition-delay:.34s}
        .mob-menu-contacts{display:flex;flex-direction:column;gap:12px;margin-bottom:28px;transform:translateX(20px);opacity:0;transition:transform .4s ease,opacity .4s ease}
        .mob-menu-contacts a{
            display:flex;align-items:center;gap:10px;
            font-size:.85rem;color:rgba(255,255,255,.5);font-weight:500;
            transition:color .2s;
        }
        .mob-menu-contacts a:hover{color:#fff}
        .mob-menu-contacts svg{width:16px;height:16px;flex-shrink:0;opacity:.5}
        .mob-menu-socials{display:flex;gap:12px;margin-bottom:28px;transform:translateX(20px);opacity:0;transition:transform .4s ease,opacity .4s ease}
        .mob-menu-socials a{
            width:42px;height:42px;border-radius:10px;
            background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.08);
            display:flex;align-items:center;justify-content:center;
            color:rgba(255,255,255,.5);transition:all .2s;
        }
        .mob-menu-socials a:hover{background:rgba(184,150,46,.15);border-color:var(--gold);color:var(--gold)}
        .mob-menu-socials svg{width:18px;height:18px}
        .mob-menu-cta{
            display:flex;gap:10px;margin-top:auto;
            transform:translateY(15px);opacity:0;transition:transform .4s ease,opacity .4s ease;
        }
        .mob-menu-cta a{
            flex:1;text-align:center;padding:14px;border-radius:10px;
            font-size:.85rem;font-weight:700;transition:all .2s;
        }
        .mob-menu-cta .mob-btn-primary{background:var(--gold);color:#fff}
        .mob-menu-cta .mob-btn-primary:hover{background:var(--gold-light)}
        .mob-menu-cta .mob-btn-secondary{background:rgba(255,255,255,.06);color:#fff;border:1px solid rgba(255,255,255,.1)}
        .mob-menu-cta .mob-btn-secondary:hover{border-color:rgba(255,255,255,.2)}

        /* ===== FIXED SOCIALS ===== */
        .side-social{
            position:fixed;left:20px;bottom:24px;
            z-index:90;display:flex;flex-direction:column;gap:12px;
        }
        .side-social a{
            width:38px;height:38px;border-radius:50%;
            display:flex;align-items:center;justify-content:center;
            color:#fff;transition:all .3s;
            box-shadow:0 2px 10px rgba(0,0,0,.15);
        }
        .side-social a:hover{transform:scale(1.12)}
        .side-social .ss-tg{background:#2AABEE}
        .side-social .ss-ig{background:linear-gradient(135deg,#f09433,#e6683c,#dc2743,#cc2366,#bc1888)}
        .side-social .ss-fb{background:#1877F2}
        .side-social svg{width:16px;height:16px}

        /* ===== HERO ===== */
        .hero{
            height:clamp(500px,calc(100vh - 112px),680px);
            display:grid;grid-template-columns:1fr 1fr;
            background:var(--dark);position:relative;overflow:hidden;
        }
        /* Шахматный паттерн на весь фон hero — заполняет зону за скосом */
        .hero::before{
            content:'';position:absolute;inset:0;z-index:0;
            opacity:.04;
            background-image:
                linear-gradient(45deg,var(--gold) 25%,transparent 25%),
                linear-gradient(-45deg,var(--gold) 25%,transparent 25%),
                linear-gradient(45deg,transparent 75%,var(--gold) 75%),
                linear-gradient(-45deg,transparent 75%,var(--gold) 75%);
            background-size:60px 60px;
            background-position:0 0,0 30px,30px -30px,-30px 0;
        }
        .hero-content{
            display:flex;flex-direction:column;justify-content:center;
            padding:60px 48px 60px clamp(40px,5vw,80px);
            position:relative;z-index:2;
        }
        .hero-content>*{position:relative;z-index:1}

        .hero-slogan{
            font-size:.68rem;font-weight:700;letter-spacing:.18em;text-transform:uppercase;
            color:var(--gold);margin-bottom:20px;
        }
        .hero h1{
            font-size:clamp(2.6rem,4.8vw,4.2rem);
            font-weight:800;line-height:1;
            color:#fff;margin-bottom:18px;letter-spacing:-.01em;
        }
        .hero h1 i{color:var(--yellow);font-style:italic;font-weight:700}
        .hero-desc{
            font-size:.95rem;color:rgba(255,255,255,.45);
            max-width:440px;margin-bottom:20px;line-height:1.7;font-weight:400;
        }
        .hero-traits{display:flex;gap:16px;margin-bottom:28px;flex-wrap:wrap}
        .hero-trait{font-size:.75rem;font-weight:600;color:rgba(255,255,255,.55);display:flex;align-items:center;gap:5px}
        .hero-trait::before{content:'';width:4px;height:4px;border-radius:50%;background:var(--gold)}
        .hero-btns{display:flex;gap:10px;flex-wrap:wrap}
        .btn-y{
            display:inline-flex;align-items:center;gap:8px;
            background:var(--yellow);color:var(--dark);
            padding:13px 28px;border-radius:100px;
            font-weight:700;font-size:.82rem;transition:all .25s;
        }
        .btn-y:hover{background:#fff;transform:translateY(-2px);box-shadow:0 8px 24px rgba(0,0,0,.2)}
        .btn-y svg{width:15px;height:15px}
        .btn-o{
            display:inline-flex;align-items:center;gap:8px;
            border:1.5px solid rgba(255,255,255,.2);color:#fff;
            padding:13px 28px;border-radius:100px;
            font-weight:600;font-size:.82rem;transition:all .3s;
        }
        .btn-o:hover{border-color:rgba(255,255,255,.5);background:rgba(255,255,255,.05)}

        .hero-video-col{position:relative;overflow:hidden;clip-path:polygon(80px 0,100% 0,100% 100%,0 100%)}
        /* Размытый фон — видео растянутое на всю область */
        .hero-video-bg{position:absolute;inset:-30px;z-index:0}
        .hero-video-bg video{width:100%;height:100%;object-fit:cover;filter:blur(40px) brightness(.35) saturate(.8);transform:scale(1.15)}
        /* Чистое видео — contain */
        .hero-video-main{position:absolute;inset:0;z-index:1}
        .hero-video-main video{width:100%;height:100%;object-fit:contain;display:block}
        /* Золотая линия вдоль диагонали */
        .hero-video-col::after{
            content:'';position:absolute;inset:0;z-index:3;pointer-events:none;
            background:var(--gold);
            clip-path:polygon(80px 0,83px 0,3px 100%,0 100%);
            opacity:.35;
        }
        .hero-badge{
            position:absolute;bottom:24px;right:24px;z-index:4;
            background:var(--yellow);color:var(--dark);
            padding:14px 18px;border-radius:8px;
        }
        .hero-badge h4{font-weight:800;font-size:.78rem;margin-bottom:2px}
        .hero-badge p{font-size:.68rem;font-weight:500;opacity:.6;line-height:1.3}

        /* ===== MARQUEE ===== */
        .marquee{background:var(--yellow);padding:10px 0;overflow:hidden;white-space:nowrap}
        .marquee-inner{display:inline-flex;animation:mq 25s linear infinite}
        .marquee-inner span{font-size:.85rem;font-weight:700;color:var(--dark);padding:0 24px;display:flex;align-items:center;gap:24px}
        .marquee-inner span::after{content:'♟';opacity:.3;font-size:.7rem}
        @keyframes mq{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}

        /* ===== SECTION TAG ===== */
        .stag{font-size:.62rem;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:var(--gold);margin-bottom:12px}

        /* ===== ABOUT ===== */
        .about{padding:72px 0;background:var(--bg)}
        .about-inner{max-width:1440px;margin:0 auto;padding:0 40px;display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:start}
        .about h2{font-size:clamp(1.8rem,3vw,2.6rem);font-weight:800;line-height:1.1;margin-bottom:16px}
        .about h2 i{color:var(--gold);font-style:italic;font-weight:700}
        .about-text{font-size:.88rem;color:var(--text-2);line-height:1.8;margin-bottom:28px}
        .about-nums{display:flex;gap:32px}
        .about-num{border-left:2px solid var(--gold);padding-left:14px}
        .about-num b{display:block;font-size:2rem;font-weight:800;line-height:1}
        .about-num span{font-size:.7rem;color:var(--text-3)}
        .about-features{display:grid;grid-template-columns:1fr 1fr;gap:0}
        .about-f{padding:28px 24px;border:1px solid rgba(0,0,0,.05);transition:background .3s}
        .about-f:hover{background:rgba(184,150,46,.04)}
        .about-f-n{font-size:2.2rem;font-weight:800;color:rgba(0,0,0,.06);line-height:1;margin-bottom:10px}
        .about-f h4{font-size:1.05rem;font-weight:700;margin-bottom:6px}
        .about-f p{font-size:.88rem;color:var(--text-2);line-height:1.7}

        /* ===== SCHEDULE ===== */
        .schedule{background:var(--dark);padding:80px 0}
        .schedule-inner{max-width:1440px;margin:0 auto;padding:0 40px}
        .schedule-top{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:36px;gap:16px;flex-wrap:wrap}
        .schedule .stag{color:var(--gold-light);margin-bottom:8px}
        .schedule h2{font-size:clamp(1.8rem,3.2vw,2.6rem);font-weight:800;color:var(--white);line-height:1.1}
        .sch-warn{display:flex;align-items:center;gap:8px;background:rgba(245,197,24,.06);border:1px solid rgba(245,197,24,.12);padding:10px 18px;font-size:.78rem;color:var(--yellow);font-weight:600;border-radius:8px}
        .sch-warn svg{width:15px;height:15px;flex-shrink:0;opacity:.6}
        .sch{width:100%;border-collapse:collapse;border:1px solid rgba(255,255,255,.1);border-radius:10px;overflow:visible}
        .sch th{font-size:.68rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--gold);padding:16px 14px;text-align:center;background:rgba(255,255,255,.04);border-bottom:1px solid rgba(255,255,255,.1);border-right:1px solid rgba(255,255,255,.06)}
        .sch th:first-child{text-align:left}
        .sch th:last-child{border-right:none}
        .sch td{padding:14px 14px;border-bottom:1px solid rgba(255,255,255,.07);border-right:1px solid rgba(255,255,255,.04);font-size:.8rem;color:rgba(255,255,255,.35);vertical-align:middle;position:relative;text-align:center}
        .sch td:first-child{text-align:left;border-right:1px solid rgba(255,255,255,.08)}
        .sch td:last-child{border-right:none}
        .sch tr:last-child td{border-bottom:none}
        .sch tr{transition:all .3s}
        .sch tr:hover td{background:rgba(245,197,24,.04)}
        .sch .loc{color:var(--white);font-weight:700;white-space:nowrap;font-size:.85rem;min-width:140px}
        .sch .loc .d{display:inline-block;width:6px;height:6px;border-radius:50%;background:var(--gold);margin-right:8px}
        .sch .dc .loc{color:#7289DA}
        .sch .dc .loc .d{background:#7289DA}
        .t{display:inline-block;padding:5px 10px;margin:2px;background:rgba(245,197,24,.08);border:1px solid rgba(245,197,24,.12);font-size:.72rem;font-weight:600;color:var(--yellow);border-radius:4px;font-variant-numeric:tabular-nums;cursor:pointer;transition:all .2s;position:relative}
        .t:hover{background:var(--yellow);color:var(--dark);border-color:var(--yellow);transform:translateY(-2px);box-shadow:0 4px 12px rgba(245,197,24,.25)}
        /* Турнірні слоти */
        .t.tour{background:rgba(34,197,94,.1);border-color:rgba(34,197,94,.2);color:var(--green)}
        .t.tour:hover{background:var(--green);color:#fff;border-color:var(--green);box-shadow:0 4px 12px rgba(34,197,94,.3)}
        /* Тултип */
        .t:hover::after{
            content:attr(data-info);
            position:absolute;bottom:calc(100% + 10px);left:50%;transform:translateX(-50%);
            background:var(--dark-2);color:#fff;
            font-size:.78rem;font-weight:500;line-height:1.6;text-align:left;
            padding:12px 18px;border-radius:8px;white-space:nowrap;
            border:1px solid rgba(255,255,255,.1);
            box-shadow:0 8px 20px rgba(0,0,0,.5);
            z-index:10;pointer-events:none;
        }
        .t:hover::before{
            content:'';position:absolute;bottom:calc(100% + 4px);left:50%;transform:translateX(-50%);
            border:5px solid transparent;border-top-color:var(--dark-2);
            z-index:10;pointer-events:none;
        }
        /* Легенда под таблицей */
        .sch-legend{display:flex;gap:24px;margin-top:16px;align-items:center}
        .sch-legend-item{display:flex;align-items:center;gap:8px;font-size:.72rem;color:rgba(255,255,255,.4)}
        .sch-legend-dot{width:10px;height:10px;border-radius:2px}
        .sch-legend-dot.lg-train{background:rgba(245,197,24,.15);border:1px solid rgba(245,197,24,.2)}
        .sch-legend-dot.lg-tour{background:rgba(34,197,94,.15);border:1px solid rgba(34,197,94,.2)}
        @keyframes ttIn{from{opacity:0;transform:translateX(-50%) translateY(4px)}to{opacity:1;transform:translateX(-50%) translateY(0)}}
        .sch .e{color:rgba(255,255,255,.25);font-size:.75rem;font-style:italic;position:relative}
        .sch .e::before{display:none}
        /* Адрес при ховере на локацию */
        .sch .loc{cursor:default;position:relative !important}

        /* ===== SCHEDULE MOBILE CARDS ===== */
        .sch-mob{display:none;flex-direction:column;gap:12px}
        .sch-mob-card{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);border-radius:12px;overflow:hidden}
        .sch-mob-card.dc-card{border-color:rgba(114,137,218,.2)}
        .sch-mob-head{padding:14px 16px;font-size:.9rem;font-weight:700;color:#fff;display:flex;align-items:center;gap:8px;cursor:pointer;justify-content:space-between}
        .sch-mob-head .d{width:6px;height:6px;border-radius:50%;background:var(--gold);flex-shrink:0}
        .dc-card .sch-mob-head .d{background:#7289DA}
        .dc-card .sch-mob-head{color:#7289DA}
        .sch-mob-head svg{width:16px;height:16px;color:rgba(255,255,255,.3);transition:transform .3s;flex-shrink:0}
        .sch-mob-card.open .sch-mob-head svg{transform:rotate(180deg)}
        .sch-mob-body{max-height:0;overflow:hidden;transition:max-height .35s ease}
        .sch-mob-card.open .sch-mob-body{max-height:500px}
        .sch-mob-days{display:flex;gap:6px;padding:0 16px 10px;flex-wrap:wrap}
        .sch-mob-day{
            padding:6px 12px;border-radius:6px;font-size:.72rem;font-weight:700;
            background:rgba(255,255,255,.06);color:rgba(255,255,255,.4);
            cursor:pointer;transition:all .2s;border:1px solid transparent;
        }
        .sch-mob-day:hover{border-color:rgba(255,255,255,.1)}
        .sch-mob-day.active{background:rgba(184,150,46,.15);color:var(--gold);border-color:rgba(184,150,46,.3)}
        .sch-mob-day.empty{opacity:.25;pointer-events:none;text-decoration:line-through}
        .sch-mob-slots{padding:0 16px 14px;display:flex;flex-wrap:wrap;gap:6px;min-height:32px}
        .sch-mob-slot{
            padding:6px 14px;border-radius:6px;font-size:.8rem;font-weight:600;
            background:rgba(245,197,24,.08);border:1px solid rgba(245,197,24,.15);
            color:var(--gold-light);cursor:pointer;transition:all .2s;
        }
        .sch-mob-slot:hover{background:rgba(245,197,24,.15);transform:scale(1.05)}
        .sch-mob-empty{font-size:.75rem;color:rgba(255,255,255,.2);font-style:italic;padding:4px 0}

        /* ===== BOOK MODAL ===== */
        .book-modal{position:fixed;inset:0;z-index:200;display:flex;align-items:center;justify-content:center;opacity:0;visibility:hidden;transition:all .25s}
        .book-modal.on{opacity:1;visibility:visible}
        .book-modal-bg{position:absolute;inset:0;background:rgba(0,0,0,.55);backdrop-filter:blur(6px)}
        .book-modal-box{
            position:relative;background:var(--bg);border-radius:20px;
            width:100%;max-width:780px;
            box-shadow:0 24px 64px rgba(0,0,0,.25);
            transform:translateY(20px) scale(.97);transition:all .3s cubic-bezier(.16,1,.3,1);
            display:grid;grid-template-columns:1fr 1fr;overflow:hidden;
        }
        .book-modal.on .book-modal-box{transform:none}
        .book-close{position:absolute;top:18px;right:18px;width:34px;height:34px;display:flex;align-items:center;justify-content:center;border-radius:50%;background:rgba(255,255,255,.1);font-size:.85rem;color:rgba(255,255,255,.6);transition:all .2s;z-index:2}
        .book-close:hover{background:rgba(255,255,255,.2);color:#fff}
        /* Левая часть — форма */
        .book-left{padding:40px}
        .book-header{margin-bottom:20px}
        .book-header h3{font-size:1.3rem;font-weight:800;margin-bottom:4px}
        .book-sub{font-size:.8rem;color:var(--text-3);line-height:1.5}
        .book-info{
            background:var(--dark);color:#fff;padding:16px 20px;border-radius:12px;
            margin-bottom:20px;font-size:.85rem;line-height:1.6;
        }
        .book-info span{display:block;color:rgba(255,255,255,.4);font-size:.72rem;margin-top:2px}
        .book-info b{color:var(--yellow);font-weight:700}
        .book-form{display:flex;flex-direction:column;gap:10px}
        .book-row{display:flex;gap:10px}
        .book-row input{flex:1}
        .book-form input,.book-form select,.book-form textarea{
            padding:13px 16px;border:1.5px solid rgba(0,0,0,.07);border-radius:10px;
            font-family:inherit;font-size:.85rem;background:var(--bg-warm);color:var(--text);
            transition:border-color .2s;outline:none;resize:none;
        }
        .book-form input:focus,.book-form select:focus,.book-form textarea:focus{border-color:var(--gold)}
        .book-form select{color:var(--text-2);appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%239E9893' stroke-width='2'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center}
        .book-submit{
            background:var(--dark);color:#fff;padding:15px;border-radius:100px;
            font-weight:700;font-size:.88rem;transition:all .3s;margin-top:6px;
        }
        .book-submit:hover{background:var(--gold);transform:translateY(-1px)}
        .book-note{text-align:center;font-size:.72rem;color:var(--green);font-weight:600;margin-top:6px}
        .book-toggle{display:flex;background:var(--bg-warm);border-radius:10px;padding:3px;gap:2px;margin-bottom:4px}
        .book-tog{flex:1;padding:10px;border-radius:8px;font-size:.82rem;font-weight:600;color:var(--text-3);transition:all .2s;text-align:center}
        .book-tog.active{background:#fff;color:var(--text);box-shadow:0 1px 4px rgba(0,0,0,.08)}
        .book-tog:hover:not(.active){color:var(--text-2)}
        .book-fields-inner{display:flex;flex-direction:column;gap:10px}
        /* Правая часть — мотивация */
        .book-right{
            background:var(--dark);color:#fff;padding:40px;
            display:flex;flex-direction:column;justify-content:center;
            position:relative;overflow:hidden;
        }
        .book-right::before{
            content:'';position:absolute;inset:0;opacity:.04;
            background-image:
                linear-gradient(45deg,var(--gold) 25%,transparent 25%),
                linear-gradient(-45deg,var(--gold) 25%,transparent 25%),
                linear-gradient(45deg,transparent 75%,var(--gold) 75%),
                linear-gradient(-45deg,transparent 75%,var(--gold) 75%);
            background-size:40px 40px;
            background-position:0 0,0 20px,20px -20px,-20px 0;
        }
        .book-right>*{position:relative;z-index:1}
        .book-right h4{font-size:1.6rem;font-weight:800;line-height:1.15;margin-bottom:16px}
        .book-right h4 i{color:var(--yellow);font-style:italic}
        .book-right p{font-size:.85rem;color:rgba(255,255,255,.5);line-height:1.7;margin-bottom:24px}
        .book-perks{list-style:none;display:flex;flex-direction:column;gap:12px}
        .book-perks li{display:flex;align-items:flex-start;gap:10px;font-size:.82rem;color:rgba(255,255,255,.7);line-height:1.5}
        .book-perks li::before{content:'✓';color:var(--yellow);font-weight:800;flex-shrink:0;margin-top:1px}
        @media(max-width:768px){
            .book-modal-box{grid-template-columns:1fr;max-width:400px}
            .book-right{display:none}
            .book-left{padding:28px}
        }

        /* ===== BANNER ===== */
        .banner{background:var(--yellow);padding:40px 0}
        .banner-inner{max-width:1440px;margin:0 auto;padding:0 40px;display:flex;justify-content:space-between;align-items:center;gap:24px;flex-wrap:wrap}
        .banner h3{font-size:clamp(1.4rem,2.5vw,2rem);font-weight:800;color:var(--dark);margin-bottom:4px}
        .banner p{font-size:.85rem;color:rgba(0,0,0,.45);font-weight:500}
        .btn-blk{background:var(--dark);color:#fff;padding:13px 28px;border-radius:100px;font-weight:700;font-size:.82rem;transition:all .3s;white-space:nowrap}
        .btn-blk:hover{background:#333;transform:translateY(-2px)}

        /* ===== EVENTS ===== */
        .events{padding:72px 0;background:var(--bg)}
        .events-inner{max-width:1440px;margin:0 auto;padding:0 40px}
        .events-top{margin-bottom:32px}
        .events h2{font-size:clamp(1.6rem,3vw,2.4rem);font-weight:800;line-height:1.1}
        .ev-grid{display:grid;grid-template-columns:1.5fr 1fr;gap:16px}
        .ev{position:relative;background:var(--dark);border-radius:14px;overflow:hidden;padding:40px;display:flex;flex-direction:column;justify-content:flex-end;min-height:340px;transition:transform .4s cubic-bezier(.16,1,.3,1)}
        .ev:hover{transform:translateY(-4px)}
        .ev::after{content:'';position:absolute;inset:0;background:radial-gradient(circle at 80% 20%,rgba(184,150,46,.08),transparent 60%)}
        .ev h3{font-size:clamp(1.3rem,2.2vw,1.9rem);font-weight:800;color:var(--white);margin-bottom:8px;position:relative;z-index:2}
        .ev>p{color:rgba(255,255,255,.4);font-size:.82rem;line-height:1.6;position:relative;z-index:2;max-width:360px}
        .ev-date{position:absolute;top:20px;left:20px;z-index:2;font-size:.62rem;font-weight:800;letter-spacing:.08em;text-transform:uppercase;color:var(--yellow)}
        .ev-arr{position:absolute;bottom:20px;right:20px;z-index:2;width:40px;height:40px;border-radius:50%;border:1.5px solid rgba(255,255,255,.1);display:flex;align-items:center;justify-content:center;color:#fff;transition:all .3s}
        .ev:hover .ev-arr{background:var(--yellow);color:var(--dark);border-color:var(--yellow)}
        .ev-gold{background:linear-gradient(145deg,#8B6914,#C9A84C);border-radius:14px;overflow:hidden;padding:40px;display:flex;flex-direction:column;justify-content:flex-end;min-height:340px;position:relative;transition:transform .4s cubic-bezier(.16,1,.3,1)}
        .ev-gold:hover{transform:translateY(-4px)}
        .ev-gold h3{font-size:1.5rem;font-weight:800;color:#fff;margin-bottom:6px}
        .ev-gold p{color:rgba(255,255,255,.6);font-size:.82rem}
        .ev-gold .ev-arr{border-color:rgba(255,255,255,.3);color:#fff}
        .ev-gold:hover .ev-arr{background:#fff;color:var(--gold);border-color:#fff}

        /* ===== TODAY ===== */
        .today{background:var(--dark);padding:72px 0}
        .today-inner{max-width:1440px;margin:0 auto;padding:0 40px;display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center}
        .today .stag{color:var(--gold-light)}
        .today h2{font-size:clamp(1.4rem,2.5vw,2rem);font-weight:800;color:var(--white);line-height:1.15;margin-bottom:18px}
        .today-st{display:flex;align-items:center;gap:8px;margin-bottom:10px}
        .today-st .dot{width:8px;height:8px;border-radius:50%;background:var(--green);box-shadow:0 0 10px rgba(34,197,94,.4);animation:pulse 2s infinite}
        @keyframes pulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(.8)}}
        .today-st span{color:var(--green);font-weight:700;font-size:.82rem}
        .today-time{font-size:clamp(2.8rem,5.5vw,4.2rem);font-weight:800;color:var(--white);line-height:.95;margin-bottom:4px}
        .today-label{color:rgba(255,255,255,.2);font-size:.78rem}
        .today-cards{display:grid;grid-template-columns:1fr 1fr;gap:2px}
        .today-c{background:var(--dark-2);padding:20px;border-radius:4px;transition:background .3s}
        .today-c:hover{background:rgba(184,150,46,.06)}
        .today-c small{display:block;font-size:.56rem;font-weight:700;letter-spacing:.15em;text-transform:uppercase;color:var(--gold);margin-bottom:5px}
        .today-c p{font-weight:600;font-size:.85rem;color:var(--white)}

        /* ===== STATS ===== */
        .stats{padding:80px 0;background:var(--dark);overflow:hidden}
        .stats-inner{max-width:1440px;margin:0 auto;padding:0 40px;display:grid;grid-template-columns:repeat(3,1fr);gap:32px}
        .stat{
            text-align:center;padding:44px 28px;
            background:linear-gradient(145deg,var(--dark-2),rgba(23,22,20,.6));
            border:1px solid rgba(255,255,255,.06);
            border-radius:18px;
            position:relative;overflow:hidden;
            transition:all .4s cubic-bezier(.16,1,.3,1);
        }
        .stat:hover{transform:translateY(-6px);border-color:rgba(184,150,46,.2);box-shadow:0 20px 40px rgba(0,0,0,.3)}
        .stat::before{
            content:'';position:absolute;top:0;left:50%;transform:translateX(-50%);
            width:50px;height:3px;background:var(--gold);border-radius:0 0 4px 4px;
            transition:width .3s;
        }
        .stat:hover::before{width:80px}
        .stat b{display:block;font-size:clamp(2.8rem,5.5vw,4.2rem);font-weight:800;line-height:1;color:#fff;margin-bottom:12px}
        .stat b .g{color:var(--gold)}
        .stat>span{display:block;font-size:1rem;color:#fff;font-weight:600;margin-bottom:4px}
        .stat-desc{display:block;font-size:.82rem;color:rgba(255,255,255,.35);font-weight:400}

        /* ===== COACHES ===== */
        .coaches{padding:80px 0;background:var(--bg)}
        .coaches-inner{max-width:1440px;margin:0 auto;padding:0 40px}
        .coaches-top{margin-bottom:40px}
        .coaches h2{font-size:clamp(1.8rem,3.2vw,2.6rem);font-weight:800;line-height:1.1}
        .coaches-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
        .coach{position:relative;border-radius:14px;overflow:hidden;aspect-ratio:3/4;cursor:pointer}
        .coach-img{position:absolute;inset:0;background:var(--bg-warm)}
        .coach-img img{width:100%;height:100%;object-fit:cover;filter:grayscale(100%);transition:filter .5s}
        .coach:hover .coach-img img{filter:grayscale(0%)}
        .coach-info{
            position:absolute;bottom:0;left:0;right:0;z-index:2;
            padding:24px 20px;
            background:linear-gradient(to top,rgba(13,12,10,.9) 0%,rgba(13,12,10,.4) 70%,transparent 100%);
        }
        .coach-info h4{font-size:1rem;font-weight:700;color:#fff;margin-bottom:2px}
        .coach-info span{font-size:.78rem;color:var(--gold);font-weight:600}
        .coach-info p{font-size:.75rem;color:rgba(255,255,255,.45);margin-top:6px;max-height:0;overflow:hidden;transition:max-height .4s}
        .coach:hover .coach-info p{max-height:60px}

        /* ===== REVIEWS ===== */
        .reviews{padding:80px 0;background:var(--dark)}
        .reviews-inner{max-width:1440px;margin:0 auto;padding:0 40px}
        .reviews-top{margin-bottom:40px}
        .reviews .stag{color:var(--gold-light)}
        .reviews h2{font-size:clamp(1.8rem,3.2vw,2.6rem);font-weight:800;color:var(--white);line-height:1.1}
        .reviews-slider{position:relative;overflow:hidden}
        .reviews-slider .swiper-slide{height:auto}
        .reviews-nav{display:flex;gap:8px;margin-top:28px;justify-content:center}
        .reviews-nav button{
            width:42px;height:42px;border-radius:50%;
            border:1.5px solid rgba(255,255,255,.1);
            display:flex;align-items:center;justify-content:center;
            color:rgba(255,255,255,.4);transition:all .3s;background:none;
        }
        .reviews-nav button:hover{border-color:var(--gold);color:var(--gold)}
        .reviews .swiper-pagination{position:relative;margin-top:20px}
        .reviews .swiper-pagination-bullet{background:rgba(255,255,255,.2);opacity:1;width:8px;height:8px}
        .reviews .swiper-pagination-bullet-active{background:var(--gold);width:24px;border-radius:4px}
        .review{
            padding:32px 28px;border-radius:14px;
            background:var(--dark-2);border:1px solid rgba(255,255,255,.04);
            position:relative;transition:border-color .3s;
        }
        .review:hover{border-color:rgba(184,150,46,.15)}
        .review-q{font-size:3rem;line-height:1;color:var(--gold);opacity:.3;font-family:Georgia,serif;position:absolute;top:16px;right:24px}
        .review p{font-size:.9rem;color:rgba(255,255,255,.6);line-height:1.7;font-style:italic;margin-bottom:20px}
        .review-author{display:flex;align-items:center;gap:12px}
        .review-av{width:40px;height:40px;border-radius:50%;background:rgba(184,150,46,.15);display:flex;align-items:center;justify-content:center;font-size:.85rem;font-weight:700;color:var(--gold)}
        .review-name{font-size:.82rem;font-weight:700;color:#fff}
        .review-role{font-size:.7rem;color:rgba(255,255,255,.3)}

        /* ===== PRICING ===== */
        .pricing{padding:80px 0;background:var(--bg)}
        .pricing-inner{max-width:1440px;margin:0 auto;padding:0 40px}
        .pricing-top{text-align:center;margin-bottom:40px}
        .pricing h2{font-size:clamp(1.8rem,3.2vw,2.6rem);font-weight:800;line-height:1.1}
        .pricing-sub{font-size:.9rem;color:var(--text-2);margin-top:8px}
        .pricing-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;max-width:960px;margin:0 auto}
        .price-card{
            padding:36px 28px;border-radius:16px;
            border:1.5px solid rgba(0,0,0,.06);background:#fff;
            text-align:center;transition:all .3s;position:relative;
        }
        .price-card:hover{transform:translateY(-4px);box-shadow:0 12px 32px rgba(0,0,0,.08)}
        .price-card.pop{border-color:var(--gold);box-shadow:0 8px 24px rgba(184,150,46,.12)}
        .price-card.pop::before{
            content:'Популярний';position:absolute;top:-12px;left:50%;transform:translateX(-50%);
            background:var(--gold);color:#fff;font-size:.62rem;font-weight:700;letter-spacing:.05em;
            padding:4px 14px;border-radius:100px;
        }
        .price-name{font-size:.72rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--text-3);margin-bottom:12px}
        .price-val{font-size:2.6rem;font-weight:800;line-height:1;margin-bottom:4px}
        .price-val small{font-size:.85rem;font-weight:500;color:var(--text-3)}
        .price-per{font-size:.75rem;color:var(--text-3);margin-bottom:20px}
        .price-list{list-style:none;text-align:left;margin-bottom:24px}
        .price-list li{font-size:.82rem;color:var(--text-2);padding:7px 0;border-bottom:1px solid rgba(0,0,0,.04);display:flex;align-items:center;gap:8px}
        .price-list li::before{content:'✓';color:var(--gold);font-weight:700;font-size:.7rem}
        .price-btn{
            display:block;width:100%;padding:13px;border-radius:100px;
            font-weight:700;font-size:.82rem;text-align:center;transition:all .3s;
            border:1.5px solid var(--dark);color:var(--dark);background:transparent;
        }
        .price-btn:hover{background:var(--dark);color:#fff}
        .price-card.pop .price-btn{background:var(--dark);color:#fff;border-color:var(--dark)}
        .price-card.pop .price-btn:hover{background:var(--gold);border-color:var(--gold)}

        /* ===== FAQ ===== */
        .faq{padding:80px 0;background:var(--bg-warm)}
        .faq-inner{max-width:800px;margin:0 auto;padding:0 40px}
        .faq-top{text-align:center;margin-bottom:40px}
        .faq h2{font-size:clamp(1.8rem,3.2vw,2.6rem);font-weight:800;line-height:1.1}
        .faq-item{border-bottom:1px solid rgba(0,0,0,.08)}
        .faq-q{
            display:flex;justify-content:space-between;align-items:center;
            padding:20px 0;cursor:pointer;gap:16px;
        }
        .faq-q h4{font-size:.95rem;font-weight:700;line-height:1.4}
        .faq-q span{
            width:28px;height:28px;border-radius:50%;
            border:1.5px solid rgba(0,0,0,.1);
            display:flex;align-items:center;justify-content:center;
            font-size:.85rem;color:var(--text-3);flex-shrink:0;
            transition:all .3s;
        }
        .faq-item.open .faq-q span{transform:rotate(45deg);border-color:var(--gold);color:var(--gold)}
        .faq-a{max-height:0;overflow:hidden;transition:max-height .4s ease}
        .faq-a p{font-size:.88rem;color:var(--text-2);line-height:1.8;padding-bottom:20px}

        /* ===== CONTACTS ===== */
        .contacts{padding:80px 0;background:var(--dark)}
        .contacts-inner{max-width:1440px;margin:0 auto;padding:0 40px;display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:start}
        .contacts .stag{color:var(--gold-light)}
        .contacts h2{font-size:clamp(1.8rem,3.2vw,2.6rem);font-weight:800;color:var(--white);line-height:1.1;margin-bottom:16px}
        .contacts-desc{font-size:.88rem;color:rgba(255,255,255,.4);line-height:1.7;margin-bottom:28px}
        .contacts-list{display:flex;flex-direction:column;gap:16px;margin-bottom:28px}
        .contact-item{display:flex;align-items:center;gap:14px}
        .contact-icon{
            width:42px;height:42px;border-radius:10px;
            background:rgba(184,150,46,.1);
            display:flex;align-items:center;justify-content:center;flex-shrink:0;
        }
        .contact-icon svg{width:18px;height:18px;color:var(--gold)}
        .contact-item span{font-size:.88rem;color:rgba(255,255,255,.7)}
        .contacts-map{border-radius:14px;overflow:hidden;min-height:320px;border:1px solid rgba(255,255,255,.06);position:relative;z-index:1}
        #mapCanvas{width:100%;height:320px}
        .map-locations{display:flex;flex-wrap:wrap;gap:10px;margin-top:16px}
        .map-loc{
            display:flex;align-items:center;gap:10px;
            background:var(--dark-2);border:1px solid rgba(255,255,255,.06);
            border-radius:10px;padding:12px 16px;flex:1;min-width:140px;
            transition:border-color .2s;cursor:pointer;
        }
        .map-loc:hover{border-color:rgba(184,150,46,.2)}
        .map-loc.active{border-color:var(--gold);background:rgba(184,150,46,.08)}
        .map-dot{font-size:1.5rem;flex-shrink:0;line-height:1;color:var(--gold)}
        .map-loc b{display:block;font-size:.8rem;color:#fff;font-weight:600}
        .map-loc small{font-size:.68rem;color:rgba(255,255,255,.35)}

        /* ===== GALLERY ===== */
        .gallery{padding:80px 0;background:var(--bg)}
        .gallery-inner{max-width:1440px;margin:0 auto;padding:0 40px}
        .gallery-top{margin-bottom:36px}
        .gallery h2{font-size:clamp(1.8rem,3.2vw,2.6rem);font-weight:800;line-height:1.1}
        .gallery-grid{display:grid;grid-template-columns:repeat(4,1fr);grid-template-rows:200px 200px;gap:12px}
        .gallery-item{border-radius:10px;overflow:hidden;background:var(--bg-warm);position:relative;cursor:pointer}
        .gallery-item img{width:100%;height:100%;object-fit:cover;transition:transform .5s}
        .gallery-item:hover img{transform:scale(1.06)}
        .gallery-item:nth-child(1){grid-column:span 2;grid-row:span 2}
        .gallery-item::after{
            content:'';position:absolute;inset:0;
            background:linear-gradient(to top,rgba(0,0,0,.3),transparent 50%);
            opacity:0;transition:opacity .3s;
        }
        .gallery-item:hover::after{opacity:1}

        /* ===== NEWS ===== */
        .news{padding:80px 0;background:var(--bg)}
        .news-inner{max-width:1440px;margin:0 auto;padding:0 40px}
        .news-top{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:36px;gap:16px;flex-wrap:wrap}
        .news h2{font-size:clamp(1.8rem,3.2vw,2.6rem);font-weight:800;line-height:1.1}
        .news-all{font-size:.82rem;font-weight:600;color:var(--gold);display:flex;align-items:center;gap:6px;transition:gap .2s}
        .news-all:hover{gap:10px}
        .news-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:20px}
        .news-card{
            background:#fff;border-radius:14px;overflow:hidden;
            border:1px solid rgba(0,0,0,.06);
            transition:all .3s cubic-bezier(.16,1,.3,1);
        }
        .news-card:hover{transform:translateY(-4px);box-shadow:0 12px 32px rgba(0,0,0,.08)}
        .news-img{height:180px;background:var(--bg-warm);overflow:hidden;position:relative}
        .news-img img{width:100%;height:100%;object-fit:cover;transition:transform .4s}
        .news-card:hover .news-img img{transform:scale(1.05)}
        .news-tag{
            position:absolute;top:12px;left:12px;
            background:var(--yellow);color:var(--dark);
            font-size:.62rem;font-weight:700;letter-spacing:.05em;
            padding:4px 10px;border-radius:100px;
        }
        .news-body{padding:20px}
        .news-date{font-size:.7rem;color:var(--text-3);margin-bottom:6px;font-weight:500}
        .news-body h4{font-size:.95rem;font-weight:700;line-height:1.35;margin-bottom:8px}
        .news-body p{font-size:.82rem;color:var(--text-2);line-height:1.6}
        .news-link{
            display:inline-flex;align-items:center;gap:4px;
            font-size:.78rem;font-weight:600;color:var(--gold);
            margin-top:12px;transition:gap .2s;
        }
        .news-link:hover{gap:8px}

        /* ===== FOOTER ===== */
        .footer{background:var(--dark);padding:60px 0 0;border-top:1px solid rgba(255,255,255,.04)}
        .footer-inner{max-width:1440px;margin:0 auto;padding:0 40px}
        .footer-top{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:40px;padding-bottom:40px;border-bottom:1px solid rgba(255,255,255,.06)}
        .footer-brand{}
        .footer-logo{height:40px;filter:brightness(0) invert(1);opacity:.5;margin-bottom:14px}
        .footer-brand p{font-size:.82rem;color:rgba(255,255,255,.35);line-height:1.7;margin-bottom:16px;max-width:280px}
        .footer-socials{display:flex;gap:10px}
        .footer-socials a{width:34px;height:34px;border-radius:50%;border:1px solid rgba(255,255,255,.1);display:flex;align-items:center;justify-content:center;color:rgba(255,255,255,.4);transition:all .3s}
        .footer-socials a:hover{border-color:var(--gold);color:var(--gold)}
        .footer-socials svg{width:15px;height:15px}
        .footer-col h5{font-size:.68rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--gold);margin-bottom:16px}
        .footer-col a{display:block;font-size:.82rem;color:rgba(255,255,255,.4);padding:4px 0;transition:color .2s}
        .footer-col a:hover{color:#fff}
        .footer-bottom{display:flex;justify-content:space-between;align-items:center;padding:20px 0;margin-top:0}
        .footer-bottom span{font-size:.72rem;color:rgba(255,255,255,.15)}
        .footer-bottom-links{display:flex;gap:20px}
        .footer-bottom-links a{font-size:.72rem;color:rgba(255,255,255,.15);transition:color .2s}
        .footer-bottom-links a:hover{color:rgba(255,255,255,.4)}
