:root{
  --bg:#0b1030; --bg-2:#141048; --panel:#1a1a55; --ink:#eef1ff; --muted:#b3b8e0;
  --gold:#f5c542; --gold-2:#ffd873; --line:rgba(255,255,255,.12); --radius:18px; --maxw:1120px;
  --coral:#ff5d73; --sky:#5db4ff; --violet:#b06cff; --mint:#38e0b0;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth;background:var(--bg)}
body{margin:0;background:var(--bg);color:var(--ink);
  font-family:"Inter","Segoe UI",system-ui,-apple-system,Roboto,Arial,sans-serif;
  line-height:1.6;-webkit-font-smoothing:antialiased}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
h1,h2,h3{line-height:1.15;margin:0 0 .5em;font-weight:800;letter-spacing:-.01em}
h2{font-size:clamp(1.6rem,3.4vw,2.5rem)}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 20px}
.section{padding:clamp(52px,7vw,96px) 0}
.eyebrow{color:var(--gold);font-weight:700;letter-spacing:.14em;text-transform:uppercase;font-size:.8rem;margin-bottom:14px}
.muted{color:var(--muted)}
.center{text-align:center}
.btn{display:inline-flex;align-items:center;gap:10px;font-weight:700;padding:14px 26px;border-radius:999px;transition:.2s;cursor:pointer;border:0;font-size:1rem}
.btn-gold{background:linear-gradient(180deg,var(--gold-2),var(--gold));color:#2a2003;box-shadow:0 8px 24px rgba(245,197,66,.28)}
.btn-gold:hover{transform:translateY(-2px);box-shadow:0 12px 30px rgba(245,197,66,.4)}
.btn-ghost{background:transparent;border:1.5px solid var(--line);color:var(--ink)}
.btn-ghost:hover{border-color:var(--gold);color:var(--gold)}

/* Header */
header{position:sticky;top:0;z-index:50;backdrop-filter:blur(12px);background:rgba(11,16,48,.72);border-bottom:1px solid var(--line)}
.nav{display:flex;align-items:center;justify-content:space-between;height:68px}
.logo{font-weight:800;font-size:1.15rem;letter-spacing:-.02em;display:flex;align-items:center;gap:9px}
.logo .star{color:var(--gold)}
.nav-links{display:flex;gap:26px;align-items:center}
.nav-links a{color:var(--muted);font-weight:500;font-size:.95rem;transition:.2s}
.nav-links a:hover,.nav-links a.active{color:var(--ink)}
.nav-links a.active{border-bottom:2px solid var(--gold);padding-bottom:4px}
.nav .btn{padding:10px 20px}
.burger{display:none;background:none;border:0;color:var(--ink);font-size:1.6rem;cursor:pointer}

/* Page hero (subpages) */
.page-hero{padding:clamp(50px,7vw,90px) 0 clamp(30px,4vw,50px);
  background:radial-gradient(1000px 420px at 80% -20%,rgba(245,197,66,.14),transparent 60%),linear-gradient(180deg,var(--bg),var(--bg-2))}
.page-hero h1{font-size:clamp(2rem,4.6vw,3.2rem);max-width:20ch}
.page-hero p{color:var(--muted);max-width:60ch;font-size:1.1rem}
.crumbs{color:var(--muted);font-size:.85rem;margin-bottom:16px}
.crumbs a:hover{color:var(--gold)}

/* Hero (home) */
.hero{position:relative;overflow:hidden;padding:clamp(70px,11vw,150px) 0 clamp(56px,8vw,110px);
  background:radial-gradient(1200px 500px at 80% -10%,rgba(245,197,66,.16),transparent 60%),
    radial-gradient(900px 600px at 0% 20%,rgba(79,110,247,.20),transparent 55%),
    linear-gradient(180deg,var(--bg),var(--bg-2))}
.hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:48px;align-items:center}
.hero h1{font-size:clamp(2.2rem,5.4vw,4rem)}
.hero p.lead{font-size:clamp(1.05rem,1.6vw,1.25rem);color:var(--muted);max-width:38ch}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap;margin-top:28px}
.hero-meta{display:flex;gap:26px;margin-top:34px;flex-wrap:wrap}
.hero-meta .m{border-left:2px solid var(--gold);padding-left:14px}
.hero-meta .m b{display:block;font-size:1.25rem}
.hero-meta .m span{color:var(--muted);font-size:.85rem}
.hero-art{position:relative}
.hero-art img{border-radius:24px;box-shadow:0 30px 70px rgba(0,0,0,.5);aspect-ratio:4/5;object-fit:cover}
.hero-badge{position:absolute;left:-16px;bottom:24px;background:var(--gold);color:#2a2003;font-weight:800;padding:14px 20px;border-radius:16px;box-shadow:0 12px 30px rgba(0,0,0,.35);line-height:1.1}
.hero-badge span{display:block;font-size:.72rem;font-weight:700;opacity:.8}

/* Cards / grid */
.grid{display:grid;gap:22px}
.cols-2{grid-template-columns:repeat(2,1fr)}
.cols-3{grid-template-columns:repeat(3,1fr)}
.card{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:26px}
.card h3{font-size:1.15rem}
.card .ic{width:48px;height:48px;border-radius:12px;display:grid;place-items:center;background:transparent;border:1px solid var(--line);margin-bottom:18px;color:var(--gold)}
.card .ic svg{width:23px;height:23px;display:block;stroke-width:1.5}
.logo .star{color:var(--gold);display:inline-flex}
.logo .star svg{width:20px;height:20px;display:block}
.burger svg{display:block}
.chip .dot{display:inline-block;width:6px;height:6px;border-radius:50%;background:var(--gold);margin-right:9px;vertical-align:middle}

.chips{display:flex;flex-wrap:wrap;gap:12px;margin-top:26px}
.chip{background:var(--panel);border:1px solid var(--line);border-radius:999px;padding:10px 18px;font-weight:600}

/* Gallery */
.gallery{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.gallery img{border-radius:14px;aspect-ratio:1;object-fit:cover;transition:.3s;filter:saturate(1.05)}
.gallery a:hover img{transform:scale(1.03)}

/* Lightbox */
.lb{position:fixed;inset:0;z-index:100;background:rgba(6,9,26,.92);backdrop-filter:blur(6px);
  display:none;align-items:center;justify-content:center;padding:24px}
.lb.open{display:flex}
.lb img{max-width:92vw;max-height:86vh;border-radius:12px;box-shadow:0 30px 80px rgba(0,0,0,.6)}
.lb-btn{position:absolute;background:rgba(255,255,255,.08);border:1px solid var(--line);color:#fff;
  width:52px;height:52px;border-radius:50%;font-size:1.6rem;cursor:pointer;display:grid;place-items:center;transition:.2s}
.lb-btn:hover{background:var(--gold);color:#2a2003;border-color:var(--gold)}
.lb-close{top:22px;right:22px;font-size:1.4rem}
.lb-prev{left:22px}.lb-next{right:22px}
.lb-count{position:absolute;bottom:22px;left:50%;transform:translateX(-50%);color:var(--muted);font-size:.9rem}
@media(max-width:520px){.lb-prev{left:10px}.lb-next{right:10px}.lb-btn{width:44px;height:44px}}

/* Reviews */
.review{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:26px}
.stars{color:var(--gold);letter-spacing:2px;margin-bottom:12px}
.review .who{margin-top:16px;font-weight:700}
.review .who span{color:var(--muted);font-weight:400;font-size:.9rem}

/* FAQ */
details{background:var(--panel);border:1px solid var(--line);border-radius:14px;padding:0 24px;margin-bottom:12px}
details summary{cursor:pointer;list-style:none;padding:20px 0;font-weight:700;display:flex;justify-content:space-between;gap:16px}
details summary::-webkit-details-marker{display:none}
details summary::after{content:"+";color:var(--gold);font-size:1.5rem;line-height:1}
details[open] summary::after{content:"–"}
details .a{padding:0 0 20px;color:var(--muted)}

/* Rules list */
.rules li{margin-bottom:14px;padding-left:6px}
.rules li::marker{color:var(--gold);font-weight:700}

/* Contacts */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:22px}
.contact-card{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:30px}
.contact-card a.big{font-size:1.5rem;font-weight:800;color:var(--gold)}

.cta{background:linear-gradient(120deg,#1a2560,#2a184f);border:1px solid var(--line);border-radius:26px;padding:clamp(34px,5vw,60px);text-align:center}

footer{border-top:1px solid var(--line);padding:44px 0;color:var(--muted);font-size:.9rem;background:var(--bg);position:relative;z-index:1}
.foot-grid{display:flex;justify-content:space-between;gap:24px;flex-wrap:wrap}
.foot-bottom{border-top:1px solid var(--line);margin-top:36px;padding-top:22px;text-align:center;font-size:.82rem;color:var(--muted);line-height:1.5}
.foot-links{margin-bottom:12px;font-size:.9rem}
.foot-links a{color:var(--muted);transition:.2s}
.foot-links a:hover{color:var(--gold)}
.socials{display:flex;gap:14px}
.socials a{width:40px;height:40px;border-radius:10px;background:var(--panel);border:1px solid var(--line);display:grid;place-items:center;transition:.2s}
.socials a:hover{border-color:var(--gold);color:var(--gold)}

@media(max-width:860px){
  .hero-grid,.contact-grid{grid-template-columns:1fr}
  .hero-art{order:-1}
  .cols-2,.cols-3{grid-template-columns:1fr 1fr}
  .gallery{grid-template-columns:1fr 1fr}
  .nav-links{display:none}
  .burger{display:block}
  .foot-grid{flex-direction:column}
}
@media(max-width:520px){
  .cols-2,.cols-3,.gallery{grid-template-columns:1fr}
  .nav{gap:10px}
  .logo{font-size:1rem;white-space:nowrap;gap:6px}
  .logo .muted{display:none}            /* прячем «на Мосфильме» */
  .logo .star svg{width:17px;height:17px}
  .nav .btn{padding:8px 14px;font-size:.82rem;white-space:nowrap}
}

/* ============ Праздничная палитра (colorful) ============ */
body{
  background:
    radial-gradient(900px 600px at 90% -5%, rgba(176,108,255,.16), transparent 55%),
    radial-gradient(800px 600px at -5% 15%, rgba(93,180,255,.14), transparent 55%),
    var(--bg);
}
/* многоцветное свечение в hero */
.hero{
  background:
    radial-gradient(760px 420px at 82% -8%, rgba(245,197,66,.22), transparent 60%),
    radial-gradient(700px 520px at 12% 6%, rgba(176,108,255,.28), transparent 58%),
    radial-gradient(680px 520px at 60% 100%, rgba(255,93,115,.20), transparent 60%),
    radial-gradient(700px 600px at 0% 90%, rgba(93,180,255,.20), transparent 55%),
    linear-gradient(180deg,var(--bg),var(--bg-2));
}
.page-hero{
  background:
    radial-gradient(820px 380px at 85% -20%, rgba(176,108,255,.20), transparent 60%),
    radial-gradient(680px 400px at 5% 0%, rgba(93,180,255,.16), transparent 60%),
    linear-gradient(180deg,var(--bg),var(--bg-2));
}
/* градиентные заголовки */
.hero h1{
  background:linear-gradient(100deg,#fff 10%,var(--gold-2) 45%,var(--coral) 80%);
  -webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;
}
.page-hero h1{
  background:linear-gradient(100deg,#fff 20%,var(--gold-2) 70%,var(--violet) 100%);
  -webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;
}
.eyebrow{background:linear-gradient(90deg,var(--gold),var(--coral));-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}

/* кнопка-праздник */
.btn-gold{background:linear-gradient(120deg,var(--gold-2),var(--gold) 55%,#ff9f43);color:#2a1c03;
  box-shadow:0 10px 26px rgba(245,197,66,.35)}
.btn-gold:hover{box-shadow:0 14px 34px rgba(255,159,67,.5)}

/* карточки: сдержанно, единый акцент, мягкий hover */
.grid.cols-3 .card,.grid.cols-2 .card{transition:transform .25s,border-color .25s,background .25s}
.grid.cols-3 .card:hover,.grid.cols-2 .card:hover{transform:translateY(-4px);border-color:rgba(245,197,66,.35);background:#1e1f60}
.card .ic{color:var(--gold)}

/* разноцветные чипы героев */
.chips .chip:nth-child(4n+1) .dot{background:var(--gold)}
.chips .chip:nth-child(4n+2) .dot{background:var(--coral)}
.chips .chip:nth-child(4n+3) .dot{background:var(--sky)}
.chips .chip:nth-child(4n+4) .dot{background:var(--mint)}
.chips .chip{transition:.2s}
.chips .chip:hover{border-color:var(--violet);transform:translateY(-2px)}

/* CTA — насыщенный градиент */
.cta{background:
  radial-gradient(600px 300px at 100% 0%, rgba(255,93,115,.30), transparent 60%),
  radial-gradient(500px 320px at 0% 100%, rgba(93,180,255,.28), transparent 60%),
  linear-gradient(120deg,#231a63,#3a1550);border-color:rgba(255,255,255,.16)}

/* бейдж на hero — коралловый */
.hero-badge{background:linear-gradient(120deg,var(--coral),#ff9f43);color:#3a0f16}

/* звёзды рейтинга чуть ярче + акцент у отзывов */
.review{transition:.2s}
.review:hover{border-color:var(--violet);transform:translateY(-3px)}

/* ============ Доп. блоки контента ============ */
/* видео-баннер */
.hero{isolation:isolate}
.hero-video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:-2;opacity:.28}
.hero::after{content:"";position:absolute;inset:0;z-index:-1;
  background:linear-gradient(180deg,rgba(11,16,48,.55),rgba(11,16,48,.85))}

/* афиша / сеансы */
.sessions{display:grid;gap:16px;margin-top:34px}
.session{display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:20px;
  background:var(--panel);border:1px solid var(--line);border-radius:16px;padding:18px 24px;transition:.2s}
.session:hover{border-color:var(--gold);transform:translateX(4px)}
.session .date{text-align:center;min-width:64px}
.session .date .d{font-size:1.7rem;font-weight:800;line-height:1;color:var(--gold)}
.session .date .m{font-size:.78rem;text-transform:uppercase;color:var(--muted);letter-spacing:.08em}
.session .info b{font-size:1.05rem}
.session .info span{display:block;color:var(--muted);font-size:.9rem}
.session .time{font-weight:700;color:var(--sky)}
@media(max-width:640px){.session{grid-template-columns:auto 1fr;gap:14px}.session .btn{grid-column:1/-1}}

/* программа-таймлайн */
.timeline{margin-top:34px;border-left:2px solid var(--line);padding-left:26px;display:grid;gap:26px}
.tl{position:relative}
.tl::before{content:"";position:absolute;left:-33px;top:4px;width:12px;height:12px;border-radius:50%;
  background:var(--gold);box-shadow:0 0 0 4px rgba(245,197,66,.18)}
.tl b{display:block;font-size:1.05rem;margin-bottom:3px}
.tl span{display:block;color:var(--muted)}

/* партнёры */
.partners{display:grid;grid-template-columns:repeat(6,1fr);gap:18px;align-items:center;margin-top:30px}
.partners a{background:#fff;border-radius:12px;padding:16px;display:grid;place-items:center;transition:.2s;opacity:.9}
.partners a:hover{opacity:1;transform:translateY(-3px)}
.partners img{max-height:44px;width:auto;filter:none}
@media(max-width:860px){.partners{grid-template-columns:repeat(3,1fr)}}
@media(max-width:480px){.partners{grid-template-columns:repeat(2,1fr)}}

/* подписка */
.subscribe{display:flex;gap:12px;flex-wrap:wrap;margin-top:14px;max-width:420px}
.subscribe input{flex:1;min-width:180px;background:var(--panel);border:1px solid var(--line);
  border-radius:999px;padding:12px 18px;color:var(--ink);font-size:.95rem}
.subscribe input::placeholder{color:var(--muted)}
.subscribe input:focus{outline:none;border-color:var(--gold)}

/* карта */
.map{margin-top:22px;border-radius:18px;overflow:hidden;border:1px solid var(--line);line-height:0}
.map iframe{width:100%;height:440px;border:0;display:block;filter:grayscale(.15)}
@media(max-width:600px){.map iframe{height:340px}}

/* артисты */
.people{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:30px}
.person{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;transition:.2s}
.person:hover{transform:translateY(-4px);border-color:var(--gold)}
.person img{width:100%;aspect-ratio:3/4;object-fit:cover}
.person .cap{padding:16px 18px}
.person .cap b{display:block}
.person .cap span{color:var(--muted);font-size:.9rem}
@media(max-width:600px){.people{grid-template-columns:1fr 1fr;gap:14px}}

/* ============ Контент-блоки из исходника ============ */
/* фиче-тайлы с фото (Cirque-style) */
.tiles{display:grid;grid-template-columns:repeat(2,1fr);gap:18px;margin-top:34px}
.tile{position:relative;border-radius:20px;overflow:hidden;min-height:280px;display:flex;align-items:flex-end;border:1px solid var(--line)}
.tile img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:.4s}
.tile:hover img{transform:scale(1.04)}
.tile .tx{position:relative;padding:24px;background:linear-gradient(180deg,transparent,rgba(6,9,26,.88) 55%);width:100%}
.tile h3{margin:0 0 6px;font-size:1.25rem}
.tile p{margin:0;color:#cdd3f2;font-size:.95rem;line-height:1.5}
@media(max-width:720px){.tiles{grid-template-columns:1fr}.tile{min-height:220px}}

/* звёзды */
.cast{display:grid;grid-template-columns:repeat(2,1fr);gap:22px;margin-top:30px;max-width:760px}
.cast .person img{aspect-ratio:4/5}
@media(max-width:600px){.cast{grid-template-columns:1fr 1fr;gap:14px}}

/* видео СМИ */
.videos{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:32px}
.videos .v{border-radius:16px;overflow:hidden;border:1px solid var(--line);aspect-ratio:16/9;background:#000}
.videos iframe{width:100%;height:100%;border:0;display:block}
@media(max-width:860px){.videos{grid-template-columns:1fr}}

/* подарок */
.gift{display:grid;grid-template-columns:.9fr 1.1fr;gap:40px;align-items:center}
.gift img{border-radius:20px;box-shadow:0 20px 50px rgba(0,0,0,.4)}
@media(max-width:760px){.gift{grid-template-columns:1fr}}

/* ============ Паттерны конкурентов ============ */
/* липкая кнопка покупки (мобайл, Cirque-style) */
.buybar{display:none;position:fixed;left:0;right:0;bottom:0;z-index:60;
  padding:10px 14px calc(10px + env(safe-area-inset-bottom));
  background:rgba(11,16,48,.94);backdrop-filter:blur(10px);border-top:1px solid var(--line)}
.buybar .btn{width:100%;justify-content:center;padding:13px 20px}
@media(max-width:860px){.buybar{display:block}body{padding-bottom:76px}}

/* видео-модалка (трейлер) */
.vlb{position:fixed;inset:0;z-index:110;background:rgba(6,9,26,.94);backdrop-filter:blur(6px);
  display:none;align-items:center;justify-content:center;padding:20px}
.vlb.open{display:flex}
.vlb .vwrap{width:min(94vw,960px);aspect-ratio:16/9;background:#000;border-radius:14px;overflow:hidden;box-shadow:0 30px 80px rgba(0,0,0,.6)}
.vlb iframe{width:100%;height:100%;border:0;display:block}
.vlb .lb-close{top:18px;right:18px}

/* бегущая фото-лента */
.marquee{overflow:hidden;padding:24px 0;background:var(--bg-2);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.marquee .track{display:flex;gap:14px;width:max-content;animation:mq 45s linear infinite}
.marquee:hover .track{animation-play-state:paused}
.marquee img{height:150px;width:auto;border-radius:12px;display:block}
@keyframes mq{to{transform:translateX(-50%)}}
@media(max-width:600px){.marquee img{height:108px}}
@media(prefers-reduced-motion:reduce){.marquee .track{animation:none}}
