*{margin:0;padding:0;box-sizing:border-box}
:root{--bg:#faf9f6;--card:#ffffff;--ink:#17151a;--mut:#6d6a73;--noir:#17151a;--gold:#c9a13b;--gold-d:#a8842c;--red:#8e1f2f;--line:#e7e4dc}
html{scroll-behavior:smooth}
body{font-family:'Instrument Sans',sans-serif;background:var(--bg);color:var(--ink);line-height:1.68;font-size:16.5px;overflow-x:hidden}
h1,h2,h3{font-family:'Cinzel',serif;font-weight:600;line-height:1.2}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
.wrap{max-width:1180px;margin:0 auto;padding:0 24px}

.ribbon{background:#000;color:#a39f96;font-size:13.5px;padding:9px 16px;text-align:center;position:relative;z-index:95}
.ribbon b{color:#faf9f6}
.ribbon a{display:inline-block;margin-left:12px;background:var(--gold);color:#17151a;font-weight:700;padding:3px 14px;border-radius:2px;font-size:13px}
.ribbon a:hover{background:var(--gold-d)}

header{position:sticky;top:0;z-index:60;background:var(--noir);color:#faf9f6;border-bottom:1px solid rgba(201,161,59,.35)}
.nav-in{display:flex;align-items:center;justify-content:space-between;height:72px;max-width:1180px;margin:0 auto;padding:0 24px}
.logo{font-family:'Cinzel',serif;font-weight:700;font-size:24px;letter-spacing:.14em;display:flex;align-items:center;gap:12px}
.logo .mask{color:var(--gold);font-size:26px}
nav.menu{display:flex;gap:26px;align-items:center}
nav.menu a{font-size:14px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:#b9b5ae;transition:.15s}
nav.menu a:hover,nav.menu a.on{color:var(--gold)}
.cta-btn{background:var(--gold);color:#17151a!important;padding:11px 22px;border-radius:2px;font-weight:700!important}
.cta-btn:hover{background:var(--gold-d)}
.kosik-ind{position:relative;font-size:20px}
.kosik-ind i{position:absolute;top:-7px;right:-11px;background:var(--red);color:#fff;font-style:normal;font-size:10.5px;font-weight:700;min-width:17px;height:17px;border-radius:99px;display:flex;align-items:center;justify-content:center;padding:0 4px}
.burger{display:none;background:none;border:0;cursor:pointer;padding:8px}
.burger span{display:block;width:26px;height:2px;background:var(--gold);margin:6px 0}

/* curtain menu (mobile) — slides down like opona */
.curtain{position:fixed;top:0;left:0;right:0;z-index:90;background:linear-gradient(180deg,#5d121f,#8e1f2f);color:#faf9f6;transform:translateY(-101%);transition:transform .35s ease;padding:26px 30px 40px;border-bottom:4px solid var(--gold);box-shadow:0 20px 60px rgba(0,0,0,.5)}
body.copen .curtain{transform:translateY(0)}
.curtain .chead{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}
.curtain .chead b{font-family:'Cinzel',serif;letter-spacing:.14em;font-size:19px}
.curtain .cclose{background:none;border:1.5px solid rgba(255,255,255,.45);color:#fff;width:42px;height:42px;border-radius:50%;font-size:18px;cursor:pointer}
.curtain nav{display:flex;flex-direction:column}
.curtain nav a{padding:14px 2px;font-family:'Cinzel',serif;font-size:20px;letter-spacing:.06em;border-bottom:1px solid rgba(255,255,255,.16);display:flex;justify-content:space-between}
.curtain nav a::after{content:"♦";color:var(--gold);font-size:12px;align-self:center}

/* hero */
.hero{position:relative;overflow:hidden;color:#fff;background:var(--noir)}
.hero .bgimg{position:absolute;inset:0;background:url(../img/hero.jpg) center/cover;opacity:.7}
.hero::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(15,13,17,.45),rgba(15,13,17,.86) 90%)}
.hero .in{position:relative;z-index:2;max-width:1180px;margin:0 auto;padding:96px 24px 90px;text-align:center}
.hero .kicker{display:inline-block;color:var(--gold);font-weight:600;letter-spacing:.3em;text-transform:uppercase;font-size:12.5px;margin-bottom:18px}
.hero h1{font-size:clamp(34px,5.4vw,62px);letter-spacing:.05em}
.hero p{max-width:640px;margin:18px auto 30px;color:#d8d5cd;font-size:18px}
.btn{display:inline-block;background:var(--gold);color:#17151a;padding:15px 32px;border-radius:2px;font-weight:700;font-size:15.5px;transition:.15s;border:0;cursor:pointer;font-family:'Instrument Sans',sans-serif}
.btn:hover{background:var(--gold-d)}
.btn.red{background:var(--red);color:#fff}
.btn.red:hover{background:#6d1522}
.btn.ghost{background:transparent;border:1.5px solid rgba(255,255,255,.55);color:#fff}
.btn.ghost:hover{background:#fff;color:#17151a}

section{padding:82px 0}
.shead{text-align:center;max-width:680px;margin:0 auto 46px}
.shead .eyebrow{color:var(--gold-d);font-weight:600;letter-spacing:.3em;text-transform:uppercase;font-size:12px;display:block;margin-bottom:12px}
.shead h2{font-size:clamp(26px,3.8vw,40px);letter-spacing:.04em}
.shead p{color:var(--mut);margin-top:12px}

/* program rows */
.prog .den{font-family:'Cinzel',serif;font-size:15px;letter-spacing:.1em;color:var(--gold-d);border-bottom:2px solid var(--gold);display:inline-block;padding-bottom:4px;margin:26px 0 10px}
.prow{display:grid;grid-template-columns:110px 1fr auto auto;gap:18px;align-items:center;background:var(--card);border:1px solid var(--line);border-radius:6px;padding:16px 20px;margin-bottom:10px;transition:.14s}
.prow:hover{border-color:var(--gold);box-shadow:0 10px 30px rgba(23,21,26,.08)}
.prow .cas{font-family:'Cinzel',serif;font-size:19px}
.prow .cas small{display:block;font-family:'Instrument Sans',sans-serif;font-size:12px;color:var(--mut);letter-spacing:.04em}
.prow h3{font-size:18px;font-family:'Instrument Sans',sans-serif;font-weight:700}
.prow .zanr{color:var(--mut);font-size:13.5px}
.prow .scena{font-size:12px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;padding:5px 12px;border-radius:99px;white-space:nowrap}
.scena.velka{background:#f3e7c8;color:#7a5c14}
.scena.mala{background:#e8ecf4;color:#3c5074}
.scena.studio{background:#efe3e5;color:#8e1f2f}
.prow .btn{padding:10px 18px;font-size:13.5px}
.prow.vyprodano .btn{background:#d6d3cb;color:#8a877f;pointer-events:none}

/* repertoar cards */
.rep-g{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.rep{background:var(--card);border:1px solid var(--line);border-radius:8px;overflow:hidden;transition:.16s;position:relative}
.rep:hover{transform:translateY(-4px);box-shadow:0 16px 40px rgba(23,21,26,.13)}
.rep img{width:100%;height:200px;object-fit:cover}
.rep .b{padding:16px 18px}
.rep .zanr{color:var(--gold-d);font-size:11.5px;font-weight:700;letter-spacing:.12em;text-transform:uppercase}
.rep h3{font-size:17px;margin:4px 0 6px;font-family:'Instrument Sans',sans-serif;font-weight:700}
.rep p{color:var(--mut);font-size:13.5px}

/* scenes */
.sceny-g{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.scn{background:var(--noir);color:#faf9f6;border-radius:8px;padding:32px 28px;position:relative;overflow:hidden}
.scn::before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:var(--gold)}
.scn h3{font-size:20px;letter-spacing:.08em;margin-bottom:6px}
.scn .mist{color:var(--gold);font-family:'Cinzel',serif;font-size:15px;margin-bottom:10px}
.scn p{color:#b9b5ae;font-size:14.5px}

/* SEAT MAP */
.smap-wrap{display:grid;grid-template-columns:1fr 320px;gap:36px;align-items:start}
.smap{background:var(--card);border:1px solid var(--line);border-radius:10px;padding:28px;overflow-x:auto}
.stage{background:var(--noir);color:var(--gold);text-align:center;font-family:'Cinzel',serif;letter-spacing:.4em;font-size:13px;padding:10px;border-radius:4px 4px 40px 40px/4px 4px 14px 14px;margin-bottom:26px}
.rows{display:flex;flex-direction:column;gap:7px;min-width:560px}
.srow{display:flex;gap:6px;align-items:center;justify-content:center}
.srow .rlab{width:22px;font-size:11px;color:var(--mut);text-align:right;font-weight:700}
.seat{width:24px;height:22px;border-radius:6px 6px 3px 3px;border:0;cursor:pointer;transition:.1s;flex-shrink:0}
.seat.k1{background:#e4c26a}
.seat.k2{background:#ce8f68}
.seat.k3{background:#9db4d0}
.seat:hover{transform:scale(1.2)}
.seat.taken{background:#dad7cf;cursor:default}
.seat.taken:hover{transform:none}
.seat.sel{background:var(--red);box-shadow:0 0 0 2px #fff,0 0 0 4px var(--red)}
.aisle{width:18px}
.legend{display:flex;gap:16px;flex-wrap:wrap;justify-content:center;margin-top:22px;font-size:13px;color:var(--mut)}
.legend span{display:flex;align-items:center;gap:7px}
.legend i{width:16px;height:15px;border-radius:4px 4px 2px 2px;display:inline-block}
.spanel{background:var(--noir);color:#faf9f6;border-radius:10px;padding:26px;position:sticky;top:90px}
.spanel h3{font-size:17px;letter-spacing:.08em;margin-bottom:4px}
.spanel .term{color:var(--gold);font-size:13.5px;margin-bottom:16px}
.spanel .sel-list{min-height:60px;border-top:1px solid rgba(255,255,255,.15);border-bottom:1px solid rgba(255,255,255,.15);padding:12px 0;margin-bottom:14px;font-size:14px}
.spanel .sel-list .it{display:flex;justify-content:space-between;padding:4px 0;color:#d8d5cd}
.spanel .sum{display:flex;justify-content:space-between;font-size:17px;font-weight:700;margin-bottom:16px}
.spanel .sum b{color:var(--gold)}
.spanel .note{font-size:12.5px;color:#8f8b84;margin-top:12px}

/* cart */
.cart-wrap{display:grid;grid-template-columns:1.2fr .8fr;gap:40px;align-items:start}
.citem{display:grid;grid-template-columns:1fr auto auto;gap:16px;align-items:center;background:var(--card);border:1px solid var(--line);border-radius:8px;padding:18px 20px;margin-bottom:12px}
.citem h3{font-size:16.5px;font-family:'Instrument Sans',sans-serif;font-weight:700}
.citem p{color:var(--mut);font-size:13.5px}
.citem .pr{font-family:'Cinzel',serif;font-size:18px}
.citem .rm{background:none;border:1.5px solid var(--line);border-radius:6px;width:34px;height:34px;cursor:pointer;color:var(--mut)}
.citem .rm:hover{border-color:var(--red);color:var(--red)}
.csum{background:var(--noir);color:#faf9f6;border-radius:10px;padding:28px}
.csum .row{display:flex;justify-content:space-between;padding:7px 0;font-size:14.5px;color:#d8d5cd}
.csum .tot{border-top:1px solid rgba(255,255,255,.2);margin-top:10px;padding-top:14px;font-size:18px;font-weight:700;color:#fff}
.csum .tot b{color:var(--gold)}
.fg{margin-bottom:14px}
.fg label{display:block;margin-bottom:6px;font-weight:600;font-size:13.5px;color:#d8d5cd}
.csum input{width:100%;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.25);border-radius:6px;color:#fff;padding:11px 13px;font-family:inherit;font-size:14.5px}
.csum input:focus{outline:none;border-color:var(--gold)}
.ok-msg{display:none;background:rgba(201,161,59,.15);border:1px solid var(--gold);color:#ecd9a4;padding:14px;border-radius:6px;margin-top:12px;font-size:14px}

/* usher/benefit strip */
.strip{background:var(--noir);color:#faf9f6;padding:70px 0}
.strip .g{display:grid;grid-template-columns:repeat(3,1fr);gap:26px;max-width:1180px;margin:0 auto;padding:0 24px}
.strip h3{font-size:17px;letter-spacing:.06em;color:var(--gold);margin-bottom:8px}
.strip p{color:#b9b5ae;font-size:14.5px}

.band{background:var(--red);color:#fff;padding:66px 0;text-align:center}
.band h2{font-size:clamp(25px,3.8vw,40px);letter-spacing:.05em}
.band p{color:#e8cdd1;margin:10px 0 24px}
.band a{background:var(--gold);color:#17151a;display:inline-block;padding:14px 32px;border-radius:2px;font-weight:700}

footer{background:#000;color:#a39f96;padding:52px 0 40px}
.f-g{display:grid;grid-template-columns:2fr 1fr 1fr;gap:38px;max-width:1180px;margin:0 auto;padding:0 24px}
footer h4{font-family:'Cinzel',serif;color:#faf9f6;font-size:16px;letter-spacing:.1em;margin-bottom:12px}
footer a,footer p{color:#a39f96;font-size:14.5px;display:block;margin-bottom:8px}
footer a:hover{color:var(--gold)}
.f-bot{max-width:1180px;margin:32px auto 0;padding:18px 24px 0;border-top:1px solid #2c2a26;font-size:13px;display:flex;justify-content:space-between;gap:14px;flex-wrap:wrap}

.phero{background:var(--noir);color:#faf9f6;text-align:center}
.phero .in{max-width:860px;margin:0 auto;padding:58px 24px 50px}
.phero .kicker{color:var(--gold);font-weight:600;letter-spacing:.3em;text-transform:uppercase;font-size:12px;display:block;margin-bottom:12px}
.phero h1{font-size:clamp(28px,4.4vw,46px);letter-spacing:.05em}
.phero p{color:#b9b5ae;margin-top:14px;font-size:16.5px}
section.hero,section.phero{padding:0}

.filtry{display:flex;gap:10px;flex-wrap:wrap;justify-content:center;margin-bottom:30px}
.filtry button{border:1.5px solid var(--line);background:#fff;padding:9px 18px;border-radius:99px;cursor:pointer;font-family:inherit;font-size:14px;font-weight:600;transition:.12s}
.filtry button.on{background:var(--noir);color:var(--gold);border-color:var(--noir)}

@media(max-width:960px){
 .rep-g{grid-template-columns:1fr 1fr}
 .sceny-g,.strip .g{grid-template-columns:1fr}
 .smap-wrap,.cart-wrap{grid-template-columns:1fr}
 .spanel{position:static}
 .prow{grid-template-columns:80px 1fr;grid-template-rows:auto auto}
 .prow .scena{justify-self:start}
 .f-g{grid-template-columns:1fr 1fr}
}
@media(max-width:640px){
 nav.menu{display:none}
 .burger{display:block}
 .rep-g,.f-g{grid-template-columns:1fr}
 section{padding:56px 0}
 .hero .in{padding:64px 20px 60px}
 .phero .in{padding:40px 20px 36px}
 .smap{padding:16px 10px}
 .citem{grid-template-columns:1fr auto}
}
.logo svg.mask{flex-shrink:0}
.kosik-ind svg{display:block}
