:root{
  --void:#0A0A0F;
  --lure-bg:#0C0A12;
  --flags-bg:#0F0B17;
  --legal-bg:#0A0C0F;
  --ink:#16161f;
  --ink-2:#1c1c28;
  --gold:#E7B64B;
  --gold-hi:#FFDB74;
  --gold-deep:#9c7526;
  --crimson:#FF2E4D;
  --crimson-deep:#CE2138;
  --mint:#37E3A6;
  --bone:#ECE6D8;
  --smoke:#94909f;
  --paper:#F3EDE2;
  --paper-ink:#1A1712;
  --paper-muted:#6f6759;
  --line:rgba(236,230,216,.10);
  --line-2:rgba(236,230,216,.20);
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{background:var(--void);color:var(--bone);font-family:'Inter',system-ui,sans-serif;font-size:17px;line-height:1.6;-webkit-font-smoothing:antialiased;overflow-x:hidden}
a{color:inherit;text-decoration:none}
::selection{background:var(--crimson);color:#fff}
.wrap{max-width:1180px;margin:0 auto;padding:0 24px}
.div-glow{height:1px;background:linear-gradient(90deg,transparent,var(--line-2),transparent)}

/* TOP BAR */
.topbar{position:sticky;top:0;z-index:60;background:rgba(10,10,15,.78);backdrop-filter:blur(14px);border-bottom:1px solid var(--line)}
.topbar .inner{display:flex;align-items:center;justify-content:space-between;height:64px}
.brand-mini{font-family:'Inter',system-ui,sans-serif;font-size:19px;letter-spacing:.04em;text-transform:uppercase;display:inline-flex;align-items:baseline}
.brand-mini b{color:var(--crimson);font-weight:inherit}
.brand-mini .tld{font-family:'Inter',system-ui,sans-serif;font-size:12px;color:var(--gold);margin-left:4px;letter-spacing:.04em;text-transform:lowercase;font-weight:700}
.topnav{display:flex;align-items:center;gap:30px}
.topnav a{font-family:'Inter',sans-serif;font-size:15px;font-weight:700;color:var(--bone);position:relative;padding:4px 0;transition:color .2s}
.topnav a::after{content:"";position:absolute;left:0;bottom:-2px;width:0;height:2px;background:var(--crimson);transition:width .25s}
.topnav a:hover{color:var(--crimson)}
.topnav a:hover::after{width:100%}
@media(max-width:600px){.topnav{gap:18px}.topnav a{font-size:13.5px}.brand-mini{font-size:16px}}

/* HERO */
.hero{position:relative;padding:84px 0 76px;overflow:hidden}
.hero::before{content:"";position:absolute;inset:0;z-index:0;background:radial-gradient(58% 48% at 50% -6%, rgba(231,182,75,.22), transparent 60%),radial-gradient(48% 44% at 86% 112%, rgba(255,46,77,.16), transparent 60%),radial-gradient(44% 38% at 10% 92%, rgba(55,227,166,.07), transparent 60%)}
.hero::after{content:"";position:absolute;z-index:0;width:640px;height:640px;right:-220px;top:-150px;border-radius:50%;border:1px dashed rgba(231,182,75,.14);box-shadow:inset 0 0 0 26px rgba(231,182,75,.035);opacity:.7}
.hero .wrap{position:relative;z-index:2}
.marquee-bulbs{display:flex;gap:14px;margin-bottom:56px}
.marquee-bulbs i{width:8px;height:8px;border-radius:50%;background:var(--gold);box-shadow:0 0 10px var(--gold-hi);animation:bulb 1.6s infinite}
.marquee-bulbs i:nth-child(2n){background:var(--crimson);box-shadow:0 0 10px var(--crimson);animation-delay:.3s}
.marquee-bulbs i:nth-child(3n){animation-delay:.6s}
.marquee-bulbs i:nth-child(4n){animation-delay:.9s}
@keyframes bulb{0%,100%{opacity:1}50%{opacity:.25}}
.wordmark{font-family:'Inter',system-ui,sans-serif;text-transform:uppercase;font-size:clamp(38px,7.4vw,102px);line-height:1.02;letter-spacing:-.005em;white-space:nowrap;color:var(--bone);text-shadow:0 0 60px rgba(231,182,75,.12);max-width:100%}
.wordmark .hl{color:var(--crimson);text-shadow:0 0 26px rgba(255,46,77,.55),0 0 64px rgba(255,46,77,.3);animation:flick 5s infinite}
@keyframes flick{0%,92%,100%{opacity:1}93%{opacity:.45}95%{opacity:1}96%{opacity:.55}}
@media(max-width:620px){.wordmark{white-space:normal;line-height:1.05}}
.hero-sub{margin-top:34px;max-width:640px;font-size:clamp(18px,2.3vw,23px);line-height:1.55;color:#cfc8bb}
.hero-sub b{color:var(--gold-hi);font-weight:600}
.hero-actions{margin-top:38px;display:flex;gap:14px;flex-wrap:wrap;align-items:center}
.btn{font-family:'Inter',system-ui,sans-serif;font-weight:800;letter-spacing:.04em;text-transform:uppercase;font-size:14px;padding:15px 24px;border-radius:10px;cursor:pointer;border:1px solid transparent;transition:transform .15s,box-shadow .2s,border-color .2s}
.btn-primary{background:var(--gold);color:#1a1305}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 14px 34px rgba(231,182,75,.3)}
.btn-ghost{border-color:var(--line-2);color:var(--bone)}
.btn-ghost:hover{border-color:var(--bone);transform:translateY(-2px)}
.scroll-cue{margin-top:56px;display:flex;align-items:center;gap:12px;font-family:'Inter',system-ui,sans-serif;font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:var(--smoke)}
.scroll-cue .bar{width:46px;height:1px;background:var(--line-2);position:relative;overflow:hidden}
.scroll-cue .bar::after{content:"";position:absolute;inset:0;width:18px;background:var(--gold);animation:slide 2s infinite}
@keyframes slide{0%{transform:translateX(-20px)}100%{transform:translateX(46px)}}

/* THESIS = beige accent band */
.thesis{padding:46px 0 70px;background:var(--void)}
.thesis-band{border-radius:26px;background:var(--paper);color:var(--paper-ink);padding:64px 52px;display:grid;grid-template-columns:1.35fr 1fr;gap:48px;align-items:center;box-shadow:0 26px 60px rgba(0,0,0,.5),inset 0 1px 0 rgba(255,255,255,.5)}
@media(max-width:820px){.thesis-band{grid-template-columns:1fr;gap:26px;padding:44px 30px}}
.thesis-band h2{font-family:'Inter',system-ui,sans-serif;text-transform:uppercase;font-size:clamp(28px,4.6vw,52px);line-height:1.28;letter-spacing:.01em;color:var(--paper-ink)}
.thesis-band h2 em{font-style:normal;color:var(--crimson-deep)}
.thesis-band p{color:var(--paper-muted);font-size:clamp(18px,1.9vw,21px);line-height:1.65}

/* SECTION HEAD */
.shead{margin-bottom:48px}
.shead .num{font-family:'Inter',system-ui,sans-serif;font-weight:700;color:var(--crimson);font-size:13px;letter-spacing:.18em;display:block;margin-bottom:16px}
.shead h2{font-family:'Inter',system-ui,sans-serif;text-transform:uppercase;font-size:clamp(34px,6vw,72px);line-height:1.06;letter-spacing:.01em}
.shead h2 b{color:var(--crimson)}
.shead .lead{margin-top:20px;max-width:620px;color:var(--smoke);line-height:1.65}

/* LURE */
.lure{padding:90px 0;background:var(--lure-bg)}
.tickets{display:grid;grid-template-columns:repeat(2,1fr);gap:22px}
@media(max-width:760px){.tickets{grid-template-columns:1fr}}
.ticket{position:relative;height:300px;border-radius:18px;cursor:pointer;perspective:1600px}
@media(max-width:760px){.ticket{height:240px}}
@media(max-width:420px){.ticket{height:230px}}
.ticket-inner{position:absolute;inset:0;transform-style:preserve-3d;transition:transform .7s cubic-bezier(.2,.7,.2,1)}
.ticket.flip .ticket-inner{transform:rotateY(180deg)}
.face{position:absolute;inset:0;border-radius:18px;backface-visibility:hidden;-webkit-backface-visibility:hidden;padding:24px;display:flex;flex-direction:column;overflow:hidden}
.face.front{background:linear-gradient(150deg,#b6852a 0%,#e7c25e 46%,#f0cf73 60%,#c79a35 100%);border:1px solid rgba(255,219,116,.5);color:#221603;box-shadow:0 18px 40px rgba(0,0,0,.35)}
.face.front::after{content:"";position:absolute;inset:0;background:linear-gradient(115deg,transparent 32%,rgba(255,255,255,.5) 48%,transparent 63%);transform:translateX(-35%);transition:transform .9s;mix-blend-mode:screen;pointer-events:none}
.ticket:hover .face.front::after{transform:translateX(45%)}
.ftop{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:18px}
.face.front .tnum{font-family:'Inter',system-ui,sans-serif;font-size:30px;line-height:1;color:#2b1d04}
.face.front .scratch-hint{font-family:'Inter',system-ui,sans-serif;font-size:11.5px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;background:rgba(34,22,3,.16);border:1px solid rgba(34,22,3,.35);padding:6px 10px;border-radius:7px;color:#2b1d04}
.front-body{margin-top:auto}
.face.front h3{font-family:'Inter',system-ui,sans-serif;text-transform:uppercase;font-size:clamp(28px,3.9vw,42px);line-height:1.1;color:#1c1302}
.face.front .rule{height:1px;background:rgba(34,22,3,.28);margin:16px 0}
.face.front .lure-line{font-size:16px;font-weight:700;line-height:1.4;color:#3a2a08}
.face.back{background:radial-gradient(130% 110% at 0% 0%,#27121a,#15111b);border:1px solid rgba(255,46,77,.32);transform:rotateY(180deg);color:var(--bone)}
.face.back .flag{font-family:'Inter',system-ui,sans-serif;font-size:12.5px;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--crimson)}
.face.back h4{font-family:'Inter',system-ui,sans-serif;text-transform:uppercase;font-size:clamp(23px,3.1vw,29px);line-height:1.3;margin-top:14px;color:#fff}
.face.back p{font-size:16.5px;line-height:1.6;color:#ddd6c9;margin-top:16px}
.face.back p b{color:var(--crimson);font-weight:700}
.face.back .back-tip{margin-top:auto;font-family:'Inter',system-ui,sans-serif;font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:#8c8597}

/* FLAGS */
.flags{padding:90px 0;background:var(--flags-bg)}
.stat-band{margin:0 0 58px;border-radius:20px;padding:36px;background:linear-gradient(180deg,#1a140a,#0f0b06);border:1px solid rgba(231,182,75,.22);box-shadow:inset 0 1px 0 rgba(231,182,75,.12)}
.stat-band .band-label{font-family:'Inter',system-ui,sans-serif;font-size:12px;letter-spacing:.2em;text-transform:uppercase;color:var(--gold);margin-bottom:24px}
.stats{display:grid;grid-template-columns:repeat(3,1fr);gap:30px}
@media(max-width:760px){.stats{grid-template-columns:1fr;gap:24px}}
.stat .big{font-family:'Inter',system-ui,sans-serif;font-size:clamp(48px,7vw,72px);line-height:1;color:var(--gold)}
.stat .big.red{color:var(--crimson)}
.stat .lbl{margin-top:14px;font-size:15px;color:#c8c3b7;line-height:1.55}
.stat .lbl b{color:var(--bone)}
.flag-list{display:grid;border-top:1px solid var(--line)}
.fitem{display:grid;grid-template-columns:48px 1fr;gap:22px;padding:30px 6px;border-bottom:1px solid var(--line);align-items:start;transition:background .25s}
.fitem:hover{background:rgba(255,46,77,.045)}
.fitem .mark{width:36px;height:36px;border-radius:9px;border:1.5px solid var(--crimson);color:var(--crimson);font-family:'Inter',system-ui,sans-serif;font-size:22px;display:flex;align-items:center;justify-content:center;line-height:1}
.fitem h3{font-family:'Inter',system-ui,sans-serif;text-transform:uppercase;font-size:clamp(21px,2.6vw,28px);line-height:1.14;letter-spacing:.01em}
.fitem p{margin-top:12px;color:#cbc6ba;font-size:16px;line-height:1.65;max-width:74ch}
.fitem p b{color:var(--gold-hi);font-weight:600}
.fitem.hot p b{color:var(--crimson);font-weight:700}

/* LEGAL */
.legal{padding:90px 0;background:var(--legal-bg)}
.legal .shead h2 b{color:var(--mint)}
.badges{display:flex;flex-wrap:wrap;gap:10px;margin-top:24px}
.badge{font-family:'Inter',system-ui,sans-serif;font-size:13px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--mint);border:1px solid rgba(55,227,166,.45);background:rgba(55,227,166,.06);padding:9px 15px;border-radius:999px;display:inline-flex;align-items:center;gap:8px}
.badge::before{content:"";width:7px;height:7px;border-radius:50%;background:var(--mint);box-shadow:0 0 10px var(--mint)}
.ops-card{margin-top:44px;background:var(--paper);color:var(--paper-ink);border-radius:26px;padding:40px 36px;box-shadow:0 26px 60px rgba(0,0,0,.5),inset 0 1px 0 rgba(255,255,255,.5)}
@media(max-width:640px){.ops-card{padding:30px 22px}}
.ops{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
@media(max-width:980px){.ops{grid-template-columns:repeat(3,1fr)}}
@media(max-width:640px){.ops{grid-template-columns:repeat(2,1fr)}}
.op{position:relative;display:flex;flex-direction:column;justify-content:space-between;min-height:108px;padding:18px;border-radius:13px;background:rgba(26,19,5,.04);border:1px solid rgba(26,19,5,.12);transition:transform .18s,border-color .2s,background .2s}
.op:hover{transform:translateY(-3px);border-color:rgba(11,138,89,.55);background:rgba(26,19,5,.08)}
.op .seal{font-family:'Inter',system-ui,sans-serif;font-size:10px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:#0b8a59;display:flex;align-items:center;gap:6px}
.op .seal::before{content:"";width:6px;height:6px;border-radius:50%;background:#0b8a59}
.op .oname{font-family:'Inter',system-ui,sans-serif;text-transform:uppercase;font-size:clamp(19px,2.4vw,25px);letter-spacing:.01em;line-height:1.04;color:var(--paper-ink);transition:color .2s}
.op:hover .oname{color:#0b8a59}
.op .arrow{position:absolute;top:16px;right:16px;color:var(--paper-muted);font-size:14px;transition:color .2s,transform .2s}
.op:hover .arrow{color:#0b8a59;transform:translate(2px,-2px)}
.op .op-logo{position:absolute;top:14px;right:38px;width:22px;height:22px;border-radius:5px;object-fit:contain;background:#fff;padding:2px;box-shadow:0 1px 3px rgba(26,19,5,.15);opacity:.95;transition:opacity .2s,transform .2s}
.op:hover .op-logo{opacity:1;transform:translateY(-1px)}
.ops-note{margin-top:24px;font-size:13.5px;color:var(--paper-muted);line-height:1.6}

/* FOOTER */
.foot{padding:84px 0 48px;background:linear-gradient(180deg,var(--legal-bg),#070409)}
.foot-top{display:grid;grid-template-columns:1.25fr 1fr;gap:52px;align-items:start}
.foot-top > .foot-left{padding:28px 0 0}
@media(max-width:760px){.foot-top{grid-template-columns:1fr;gap:38px}}
.foot-claim{font-family:'Inter',system-ui,sans-serif;text-transform:uppercase;font-size:clamp(28px,4.4vw,48px);line-height:1.1}
.foot-claim em{font-style:normal;color:var(--gold)}
.foot-claim .red{color:var(--crimson)}
.foot p.note{margin-top:20px;color:var(--smoke);max-width:48ch;font-size:15px;line-height:1.65}
.am-block{align-self:start;display:flex;flex-direction:column;align-items:flex-end;text-align:right;padding-top:12px}
.am-tag{font-family:'Inter',system-ui,sans-serif;font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--smoke);margin-bottom:16px}
.am-logo-link{display:inline-block;line-height:0;transition:opacity .22s ease,transform .22s ease}
.am-logo-link:hover{opacity:.82;transform:translateY(-1px)}
.am-block .am-logo{display:block;height:34px;width:auto;filter:brightness(0) invert(1);opacity:.95}
.am-name{font-family:'Inter',system-ui,sans-serif;text-transform:uppercase;font-size:34px;letter-spacing:.03em;color:#fff;line-height:1}
.am-block p.am-desc{margin-top:18px;color:var(--smoke);font-size:13.5px;line-height:1.65;max-width:42ch}
.foot-bottom{margin-top:56px;padding-top:28px;border-top:1px solid var(--line);display:flex;flex-wrap:wrap;gap:18px;justify-content:space-between;align-items:center}
.foot-bottom .left{display:flex;gap:14px;align-items:center;flex-wrap:wrap}
.pill18{font-family:'Inter',system-ui,sans-serif;font-size:12px;font-weight:700;letter-spacing:.1em;border:1px solid var(--crimson);border-radius:999px;padding:5px 11px;color:var(--crimson)}
.foot-bottom .rg{font-family:'Inter',system-ui,sans-serif;font-size:12px;letter-spacing:.04em;color:var(--smoke)}
.foot-bottom .links{display:flex;gap:22px;flex-wrap:wrap}
.foot-bottom .links a{font-family:'Inter',system-ui,sans-serif;font-size:12px;letter-spacing:.06em;text-transform:uppercase;color:var(--smoke)}
.foot-bottom .links a:hover{color:var(--bone)}
.foot-bottom .copy{font-family:'Inter',system-ui,sans-serif;font-size:11.5px;color:#55505f;width:100%;margin-top:6px;line-height:1.6}

.reveal{opacity:0;transform:translateY(26px);transition:opacity .7s ease,transform .7s ease}
.reveal.in{opacity:1;transform:none}
@media(prefers-reduced-motion:reduce){*{animation:none !important}.reveal{opacity:1;transform:none;transition:none}.ticket-inner{transition:none}html{scroll-behavior:auto}}
:focus-visible{outline:2px solid var(--mint);outline-offset:3px;border-radius:4px}
</style>

/* Sjednoceni vahy pro nadpisy (Inter misto Anton) */
.brand-mini,.face.front .tnum,.face.back h4,.fitem .mark,.fitem h3,.op .oname{font-weight:800}
.wordmark,.thesis-band h2,.shead h2,.face.front h3,.stat .big,.foot-claim,.am-name{font-weight:900}

/* === Cookie banner === */
.cc-banner{position:fixed;left:20px;right:20px;bottom:20px;z-index:200;background:rgba(20,18,30,.96);backdrop-filter:blur(14px);border:1px solid var(--line-2);border-radius:16px;box-shadow:0 24px 60px rgba(0,0,0,.55);max-width:1180px;margin:0 auto}
.cc-banner-inner{display:grid;grid-template-columns:1fr auto;gap:22px;align-items:center;padding:22px 26px}
@media(max-width:760px){.cc-banner-inner{grid-template-columns:1fr;gap:16px}}
.cc-banner-text strong{display:block;font-weight:800;color:var(--bone);font-size:15px;margin-bottom:4px}
.cc-banner-text p{color:#cbc6ba;font-size:13.5px;line-height:1.55;margin:0}
.cc-banner-actions{display:flex;gap:10px;flex-wrap:wrap;align-items:center}
.cc-btn{font-family:'Inter',system-ui,sans-serif;font-weight:700;font-size:13px;letter-spacing:.04em;text-transform:uppercase;padding:11px 18px;border-radius:8px;cursor:pointer;border:1px solid transparent;transition:transform .15s,background .2s,border-color .2s}
.cc-btn-primary{background:var(--gold);color:#1a1305}
.cc-btn-primary:hover{background:var(--gold-hi);transform:translateY(-1px)}
.cc-btn-ghost{background:transparent;border-color:var(--line-2);color:var(--bone)}
.cc-btn-ghost:hover{border-color:var(--bone)}

/* === Modal === */
.modal{position:fixed;inset:0;z-index:300}
.modal-backdrop{position:absolute;inset:0;background:rgba(8,6,12,.78);backdrop-filter:blur(6px)}
.modal-box{position:relative;max-width:680px;width:calc(100% - 32px);max-height:88vh;margin:5vh auto;background:var(--ink-2);border:1px solid var(--line-2);border-radius:18px;padding:38px 36px 30px;color:var(--bone);overflow-y:auto;box-shadow:0 30px 70px rgba(0,0,0,.6)}
@media(max-width:640px){.modal-box{padding:28px 22px 22px}}
.modal-close{position:absolute;top:14px;right:18px;width:34px;height:34px;border-radius:8px;background:transparent;border:1px solid var(--line-2);color:var(--smoke);font-size:22px;cursor:pointer;line-height:1;display:flex;align-items:center;justify-content:center;transition:color .15s,border-color .15s}
.modal-close:hover{color:var(--bone);border-color:var(--bone)}
.modal-box h2{font-family:'Inter',system-ui,sans-serif;font-weight:900;text-transform:uppercase;font-size:26px;line-height:1.15;letter-spacing:.01em;margin-bottom:14px}
.modal-box .modal-lead{color:#cfc8bb;font-size:15px;line-height:1.65;margin-bottom:22px}
.modal-box .modal-lead b{color:var(--gold-hi)}
.modal-box h3{font-family:'Inter',system-ui,sans-serif;font-weight:800;text-transform:uppercase;font-size:15px;letter-spacing:.02em;margin:22px 0 10px;color:var(--bone)}
.modal-box p{color:#cbc6ba;font-size:14.5px;line-height:1.65;margin-bottom:10px}
.modal-box p b{color:var(--bone)}
.modal-box a{color:var(--gold);text-decoration:underline;text-decoration-color:rgba(231,182,75,.4);text-underline-offset:3px}
.modal-box a:hover{text-decoration-color:var(--gold)}

/* Cookie rows + switch */
.cc-rows{margin:8px 0 22px;border:1px solid var(--line);border-radius:12px;overflow:hidden}
.cc-row{display:grid;grid-template-columns:1fr auto;gap:20px;align-items:center;padding:18px 22px;border-bottom:1px solid var(--line)}
.cc-row:last-child{border-bottom:none}
.cc-row strong{font-weight:800;color:var(--bone);font-size:14px;text-transform:uppercase;letter-spacing:.04em;display:block;margin-bottom:4px}
.cc-row p{font-size:13.5px;line-height:1.55;margin:0;color:#a9a499}
.cc-switch{position:relative;width:46px;height:26px;display:inline-block;cursor:pointer}
.cc-switch input{position:absolute;opacity:0;width:0;height:0}
.cc-switch span{position:absolute;inset:0;border-radius:999px;background:#3a3645;transition:background .2s}
.cc-switch span::after{content:"";position:absolute;top:3px;left:3px;width:20px;height:20px;border-radius:50%;background:#fff;transition:transform .2s}
.cc-switch input:checked + span{background:var(--mint)}
.cc-switch input:checked + span::after{transform:translateX(20px)}
.cc-switch.is-locked{cursor:not-allowed}
.cc-switch.is-locked span{background:#0b8a59;opacity:.6}

.modal-actions{display:flex;gap:10px;flex-wrap:wrap;justify-content:flex-end;margin-bottom:18px}

/* === MOBILE OPTIMIZATION === */
@media (max-width: 760px) {
  body { font-size: 16px; }
  .wrap { padding: 0 18px; }
  .topbar .inner { height: 56px; }
  .brand-mini { font-size: 15px; }
  .brand-mini .tld { font-size: 10px; margin-left: 3px; }
  .topnav { gap: 14px; }
  .topnav a { font-size: 12.5px; }

  .hero { padding: 48px 0 56px; }
  .marquee-bulbs { margin-bottom: 32px; gap: 10px; }
  .marquee-bulbs i { width: 6px; height: 6px; }
  .wordmark { font-size: clamp(34px, 11vw, 56px); white-space: normal; line-height: 1.06; letter-spacing: -.01em; }
  .hero-sub { font-size: 17px; margin-top: 22px; }
  .hero-actions { margin-top: 26px; gap: 10px; }
  .hero-actions .btn { padding: 13px 18px; font-size: 13px; flex: 1; min-width: 0; text-align: center; }
  .scroll-cue { margin-top: 36px; font-size: 11px; }
  .hero::after { width: 380px; height: 380px; right: -180px; top: -80px; }

  .thesis { padding: 22px 0 36px; }
  .thesis-band { padding: 32px 24px; gap: 18px; border-radius: 18px; }

  .lure, .flags, .legal { padding: 60px 0; }
  .shead { margin-bottom: 32px; }
  .shead .num { font-size: 12px; margin-bottom: 12px; }

  .stat-band { padding: 26px 22px; margin-bottom: 40px; border-radius: 14px; }
  .stat-band .band-label { font-size: 11px; margin-bottom: 18px; }
  .stat .big { font-size: 56px; }
  .stat .lbl { font-size: 14px; }

  .fitem { padding: 22px 4px; gap: 16px; grid-template-columns: 36px 1fr; }
  .fitem .mark { width: 30px; height: 30px; font-size: 18px; }
  .fitem h3 { font-size: 19px; }
  .fitem p { font-size: 15px; margin-top: 10px; }

  .ops-card { padding: 28px 18px; border-radius: 18px; margin-top: 32px; }
  .ops { gap: 10px; }
  .op { padding: 14px; min-height: 92px; border-radius: 11px; }
  .op .seal { font-size: 9px; }
  .op .oname { font-size: 17px; }
  .op .op-logo { width: 18px; height: 18px; top: 12px; right: 32px; padding: 1px; }
  .op .arrow { font-size: 12px; top: 12px; right: 12px; }

  .foot { padding: 52px 0 28px; }
  .foot-top { gap: 26px; }
  .foot-top > .foot-left { padding: 0; }
  .foot-claim { font-size: 32px; }
  .foot p.note { font-size: 14px; margin-top: 14px; }
  .am-block { align-items: flex-start; text-align: left; padding-top: 4px; }
  .am-block .am-logo { height: 30px; }
  .am-block p.am-desc { font-size: 13px; margin-top: 14px; max-width: none; }
  .foot-bottom { margin-top: 36px; padding-top: 20px; gap: 12px; flex-direction: column; align-items: flex-start; }
  .foot-bottom .links { gap: 14px; }
  .foot-bottom .links a { font-size: 11.5px; }

  /* Cookie banner */
  .cc-banner { left: 12px; right: 12px; bottom: 12px; border-radius: 14px; }
  .cc-banner-inner { padding: 18px 20px; }
  .cc-banner-actions { width: 100%; }
  .cc-banner-actions .cc-btn { flex: 1; min-width: 0; padding: 11px 12px; font-size: 12px; }

  /* Modals */
  .modal-box { padding: 28px 20px 22px; margin: 16px auto; max-height: 92vh; border-radius: 14px; }
  .modal-box h2 { font-size: 22px; }
  .modal-close { top: 10px; right: 12px; width: 30px; height: 30px; font-size: 20px; }
  .cc-row { padding: 16px 18px; grid-template-columns: 1fr auto; gap: 14px; }
}

/* Tablet portrait */
@media (min-width: 761px) and (max-width: 1024px) {
  .wordmark { font-size: clamp(46px, 8.5vw, 84px); }
}

/* Touch-friendly tap targets */
@media (hover: none) {
  .ticket { cursor: default; }
  .op:hover { transform: none; }
}

/* === SCROLL PERFORMANCE OVERRIDES === */
html { scroll-behavior: auto; }

/* Skip rendering of off-screen sections (modern browsers) */
.thesis, .lure, .flags, .legal, .foot {
  content-visibility: auto;
  contain-intrinsic-size: 600px;
}

/* Force GPU compositing on heavy sections */
.hero, .thesis-band, .ops-card, .ticket {
  transform: translateZ(0);
  will-change: auto;
}

/* Lighter topbar — keep backdrop-filter only on hover-capable, drop on touch */
@media (hover: none) {
  .topbar { backdrop-filter: none; background: rgba(10,10,15,.95); }
}

/* Faster reveal — was .7s, now .35s */
.reveal { transition: opacity .35s ease-out, transform .35s ease-out; }

/* Remove expensive decorative dashed-circle on smaller screens */
@media (max-width: 1100px) { .hero::after { display: none; } }

/* Pause bulb pulse animation when off-screen (saves CPU when scrolled past hero) */
.marquee-bulbs { contain: layout style paint; }

/* Prevent overscroll bounce repaint */
body { overscroll-behavior-y: none; }

/* Smooth section transitions */
section { contain: layout style; }

/* === Ticket back face — mobile fine tune === */
@media (max-width: 760px) {
  .ticket { height: 280px; }
  .face { padding: 20px; }
  .face.front h3 { font-size: 24px; line-height: 1.15; }
  .face.front .tnum { font-size: 26px; }
  .face.front .lure-line { font-size: 15px; line-height: 1.4; }
  .face.front .ftop { margin-bottom: 12px; }
  .face.back .flag { font-size: 11px; letter-spacing: .14em; }
  .face.back h4 { font-size: 19px; line-height: 1.25; margin-top: 10px; }
  .face.back p { font-size: 13.5px; line-height: 1.5; margin-top: 10px; }
  .face.back .back-tip { font-size: 10px; }
}

@media (max-width: 420px) {
  .ticket { height: 285px; }
  .face { padding: 18px; }
  .face.front h3 { font-size: 22px; }
  .face.back h4 { font-size: 18px; }
  .face.back p { font-size: 13px; line-height: 1.5; margin-top: 8px; }
}

/* === Mobile topbar: 2-row layout (brand top, nav full-width bottom) === */
@media (max-width: 760px) {
  .topbar { padding: 0; }
  .topbar .inner {
    height: auto;
    flex-direction: column;
    padding: 0;
    gap: 0;
  }
  .topbar .inner .brand-mini {
    width: 100%;
    height: 50px;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 0 16px;
    font-size: 17px;
    border-bottom: 1px solid var(--line);
  }
  .topbar .inner .brand-mini .tld { font-size: 11px; margin-left: 3px; }
  .topnav {
    width: 100%;
    display: flex;
    justify-content: stretch;
    gap: 0;
    padding: 0;
  }
  .topnav a {
    flex: 1 1 0;
    text-align: center;
    padding: 11px 6px;
    font-size: 12px;
    font-weight: 700;
    line-height: 1.2;
    letter-spacing: .02em;
    border-right: 1px solid var(--line);
    transition: background .15s, color .15s;
  }
  .topnav a:last-child { border-right: none; }
  .topnav a:hover { background: rgba(255,46,77,.08); color: var(--crimson); }
  .topnav a::after { display: none; }
}

/* === Footer Affilmaster — vše inline na společné baseline === */
.foot-am {
    border-top: 1px solid var(--line);
    margin-top: 24px;
    padding-top: 18px;
    text-align: center;
    font-family: inherit;
    font-size: 12px;
    line-height: 1.6;
    color: var(--smoke);
    opacity: 0.55;
    transition: opacity .2s;
}
.foot-am:hover { opacity: 0.85; }
.foot-am .am-tag,
.foot-am .am-desc-mini {
    display: inline;
    font-size: inherit;
    font-weight: 400;
    color: inherit;
    text-transform: none;
    letter-spacing: normal;
}
.foot-am a {
    display: inline-block;
    margin: 0 4px;
    line-height: 0;
}
.foot-am .am-logo-mini {
    height: 14px;
    width: auto;
    filter: brightness(0) invert(1);
    display: inline-block;
    vertical-align: middle;
}
@media (max-width: 600px) {
    .foot-am { padding-top: 16px; font-size: 11px; }
    .foot-am .am-logo-mini { height: 12px; }
}

/* === Language switch CZ | SK (footer, decentní) === */
.foot-bottom .lang-switch {
    display: inline-flex;
    align-items: center;
    gap: 2px;
    margin-left: 6px;
    padding-left: 14px;
    border-left: 1px solid var(--line);
}
.foot-bottom .lang-switch a {
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 0.08em;
    padding: 2px 6px;
    border-radius: 3px;
    color: inherit;
    transition: color .15s, background .15s;
}
.foot-bottom .lang-switch a:hover { color: var(--bone); background: rgba(255,255,255,.05); }
.foot-bottom .lang-switch a.active { color: var(--bone); background: rgba(255,255,255,.08); }
@media (max-width: 600px) {
    .foot-bottom .lang-switch { margin-left: 0; padding-left: 0; border-left: none; }
}
