/* Logikum v9 — ESCAPOLOGY-STYLE: premium private escape rooms, full-bleed video hero
   Dark slate #252b38 · cream #FFFEF6 · sky-blue accent #75b4d9 · clean geometric · photographic
   Montserrat (headings) + Golos Text (body) */
:root{
  --bg:#1d2230; --bg2:#161a26; --slate:#252b38; --slate2:#2c3342; --card:#222834;
  --cream:#fffef6; --off:#e8eaee; --muted:#babec5; --dim:#87817b;
  --sky:#75b4d9; --sky2:#9ccbe8; --teal:#5fa6a0; --gold:#d8b15a;
  --line:#363d4d; --line2:#454d60;
  --maxw:1240px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;background:var(--bg);color:var(--cream);font-family:'Golos Text',system-ui,sans-serif;line-height:1.7;-webkit-font-smoothing:antialiased;overflow-x:hidden}
a{color:inherit;text-decoration:none}img{max-width:100%;display:block}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 26px}
h1,h2,h3{font-family:'Montserrat',sans-serif;font-weight:800;line-height:1.08;letter-spacing:-.01em}
.muted{color:var(--muted)}.center{text-align:center}
.eyebrow{font-family:'Montserrat',sans-serif;font-weight:700;text-transform:uppercase;letter-spacing:.22em;font-size:12px;color:var(--sky)}

/* nav */
header.nav{position:sticky;top:0;z-index:60;background:rgba(22,26,38,.86);backdrop-filter:blur(14px);border-bottom:1px solid var(--line)}
.nav .wrap{display:flex;align-items:center;gap:24px;height:74px}
.brand{display:flex;align-items:center;gap:11px;font-family:'Montserrat';font-weight:800;font-size:22px;letter-spacing:.04em;text-transform:uppercase}
.brand .mk{width:30px;height:30px;border:2px solid var(--sky);border-radius:8px;display:grid;place-items:center;color:var(--sky);font-size:15px}
.nav nav{display:flex;gap:4px;margin-left:auto;flex-wrap:wrap;align-items:center}
.nav nav a{padding:9px 15px;font-family:'Montserrat';font-weight:600;font-size:14px;color:var(--off);transition:.18s}
.nav nav a:hover,.nav nav a.active{color:var(--sky)}
.nav .cta{background:var(--sky);color:#0e1b25!important;border-radius:8px;font-weight:700}
.nav .cta:hover{background:var(--sky2)}
.burger{display:none;margin-left:auto;background:none;border:1px solid var(--line2);color:var(--cream);padding:8px 12px;cursor:pointer;border-radius:8px}

/* buttons */
.btn{display:inline-flex;align-items:center;gap:9px;padding:14px 28px;font-family:'Montserrat';font-weight:700;font-size:14px;cursor:pointer;border:2px solid transparent;background:var(--slate2);color:var(--cream);border-radius:10px;transition:.18s;letter-spacing:.01em}
.btn:hover{transform:translateY(-2px)}
.btn-primary{background:var(--sky);color:#0e1b25;box-shadow:0 10px 30px -12px rgba(117,180,217,.8)}
.btn-primary:hover{background:var(--sky2)}
.btn-ghost{background:transparent;border-color:rgba(255,254,246,.35);color:var(--cream)}
.btn-ghost:hover{border-color:var(--cream);background:rgba(255,255,255,.06)}
.btn-sm{padding:9px 16px;font-size:13px;border-radius:8px}

/* ===== VIDEO HERO (escapology-style) ===== */
.vhero{position:relative;min-height:92vh;display:flex;align-items:center;overflow:hidden;border-bottom:1px solid var(--line)}
.vhero video,.vhero .poster{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0}
.vhero .scrim{position:absolute;inset:0;z-index:1;background:linear-gradient(180deg,rgba(22,26,38,.55) 0%,rgba(22,26,38,.35) 40%,rgba(22,26,38,.92) 100%)}
.vhero .scrim2{position:absolute;inset:0;z-index:1;background:radial-gradient(120% 80% at 20% 30%,transparent,rgba(22,26,38,.5))}
.vhero .wrap{position:relative;z-index:2;padding:80px 26px}
.vhero .inner{max-width:720px}
.vhero .eyebrow{margin-bottom:18px;display:inline-flex;align-items:center;gap:10px}
.vhero .eyebrow .live{width:8px;height:8px;border-radius:50%;background:var(--sky);box-shadow:0 0 12px var(--sky);animation:pulse 1.8s infinite}
@keyframes pulse{50%{opacity:.35}}
.vhero h1{font-size:clamp(44px,7.5vw,92px);font-weight:800;margin:0 0 18px;letter-spacing:-.02em;text-shadow:0 4px 30px rgba(0,0,0,.4)}
.vhero p.lead{font-size:clamp(17px,2.4vw,21px);color:var(--off);max-width:600px;margin:0 0 32px}
.vhero .actions{display:flex;gap:14px;flex-wrap:wrap}
.vhero .sound{position:absolute;bottom:22px;right:24px;z-index:3;background:rgba(22,26,38,.6);border:1px solid var(--line2);color:var(--cream);width:44px;height:44px;border-radius:50%;cursor:pointer;font-size:16px;backdrop-filter:blur(6px)}
.vstat{display:flex;gap:34px;margin-top:42px;flex-wrap:wrap}
.vstat .s b{font-family:'Montserrat';font-weight:800;font-size:32px;color:var(--cream);display:block;line-height:1}
.vstat .s span{font-size:13px;color:var(--muted);text-transform:uppercase;letter-spacing:.08em}

/* sections */
section{padding:88px 0;position:relative}
.slate{background:var(--slate)}
.sec-head{max-width:720px;margin:0 auto 50px;text-align:center}
.sec-head .eyebrow{display:block;margin-bottom:14px}
.sec-head h2{font-size:clamp(30px,4.6vw,46px);margin:0 0 12px}
.sec-head p{color:var(--muted);font-size:17px}
.sec-head.left{text-align:left;margin-left:0}

/* room cards */
.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:26px}
.card{background:var(--card);border:1px solid var(--line);border-radius:18px;overflow:hidden;transition:.22s;display:block;position:relative}
.card:hover{transform:translateY(-6px);border-color:var(--line2);box-shadow:0 30px 60px -30px rgba(0,0,0,.7)}
.card .ph{aspect-ratio:3/2;overflow:hidden;position:relative}
.card .ph img{width:100%;height:100%;object-fit:cover;transition:.6s}
.card:hover .ph img{transform:scale(1.06)}
.card .ph::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 55%,rgba(34,40,52,.96))}
.card .tags{position:absolute;top:14px;left:14px;z-index:2;display:flex;gap:7px}
.card .tags span{background:rgba(22,26,38,.78);border:1px solid var(--line2);color:var(--cream);font-family:'Montserrat';font-weight:600;font-size:11px;padding:4px 10px;border-radius:7px;backdrop-filter:blur(6px)}
.card .rating{position:absolute;top:14px;right:14px;z-index:2;background:rgba(22,26,38,.78);color:var(--gold);font-weight:700;font-size:12px;padding:4px 10px;border-radius:7px;border:1px solid var(--line2)}
.card .body{padding:22px}
.card h3{font-size:22px;margin:0 0 6px}
.card .genre{color:var(--muted);font-size:14px;min-height:40px}
.card .meta{display:flex;gap:16px;color:var(--dim);font-size:13px;font-family:'Montserrat';font-weight:600;margin:14px 0;flex-wrap:wrap}
.card .meta b{color:var(--off)}
.card .foot{display:flex;align-items:center;justify-content:space-between;border-top:1px solid var(--line);padding-top:16px}
.card .price{font-family:'Montserrat';font-weight:800;font-size:19px}.card .price span{font-size:12px;color:var(--muted);font-weight:500}

/* difficulty dots */
.dots{display:flex;gap:5px;align-items:center}
.dots i{width:8px;height:8px;border-radius:50%;background:var(--line2)}
.dots i.on{background:var(--sky)}

/* chips */
.chips{display:flex;gap:10px;flex-wrap:wrap;justify-content:center;margin-bottom:42px}
.chip{padding:10px 20px;border:1px solid var(--line2);background:transparent;color:var(--muted);font-family:'Montserrat';font-weight:600;font-size:14px;cursor:pointer;border-radius:999px;transition:.18s}
.chip:hover{color:var(--cream);border-color:var(--sky)}
.chip.active{background:var(--sky);color:#0e1b25;border-color:var(--sky)}

/* "game for every group" */
.groups{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:20px}
.group{position:relative;border-radius:18px;overflow:hidden;aspect-ratio:4/5;border:1px solid var(--line)}
.group img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;filter:saturate(.95)}
.group .ov{position:absolute;inset:0;background:linear-gradient(180deg,transparent 40%,rgba(22,26,38,.92));display:flex;flex-direction:column;justify-content:flex-end;padding:22px}
.group h3{font-size:21px;margin:0 0 4px}
.group p{color:var(--muted);font-size:13px;margin:0}

/* split feature */
.split{display:grid;grid-template-columns:1fr 1fr;gap:50px;align-items:center}
.split .media{border-radius:20px;overflow:hidden;border:1px solid var(--line);aspect-ratio:16/11}
.split .media img{width:100%;height:100%;object-fit:cover}
.split h2{font-size:clamp(28px,4vw,42px);margin:0 0 8px}
.split .em{color:var(--sky);font-family:'Montserrat';font-weight:700;font-size:18px;margin-bottom:14px}
.split p{color:var(--muted)}
.steps{display:grid;gap:14px;margin-top:20px}
.steps .st{display:flex;gap:14px;align-items:flex-start}
.steps .st b{font-family:'Montserrat';font-weight:800;color:var(--sky);font-size:15px;border:2px solid var(--sky);width:36px;height:36px;border-radius:50%;display:grid;place-items:center;flex:none}

/* FAQ accordion */
.faq{max-width:780px;margin:0 auto}
.faq details{border-bottom:1px solid var(--line);padding:6px 0}
.faq summary{list-style:none;cursor:pointer;padding:18px 0;font-family:'Montserrat';font-weight:700;font-size:18px;display:flex;justify-content:space-between;align-items:center;gap:16px}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";color:var(--sky);font-size:24px;font-weight:400;transition:.2s}
.faq details[open] summary::after{transform:rotate(45deg)}
.faq details p{color:var(--muted);padding:0 0 18px;margin:0}

/* quest detail */
.qhero{display:grid;grid-template-columns:1.15fr .85fr;gap:34px;align-items:start;padding-top:36px}
.qhero .gallery .main{border-radius:18px;overflow:hidden;border:1px solid var(--line);aspect-ratio:3/2}
.qhero .gallery .main img{width:100%;height:100%;object-fit:cover}
.qhero .thumbs{display:flex;gap:10px;margin-top:12px;flex-wrap:wrap}
.qhero .thumbs img{width:88px;height:62px;object-fit:cover;border-radius:10px;border:1px solid var(--line);cursor:pointer;opacity:.6;transition:.18s}
.qhero .thumbs img:hover,.qhero .thumbs img.on{opacity:1;border-color:var(--sky)}
.qhero h1{font-size:clamp(30px,4.6vw,46px);margin:8px 0}
.qbadges{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;margin:20px 0}
.qbadge{background:var(--card);border:1px solid var(--line);border-radius:12px;padding:14px 16px}
.qbadge b{display:block;font-family:'Montserrat';font-weight:800;font-size:18px}
.qbadge span{color:var(--muted);font-size:12px;text-transform:uppercase;letter-spacing:.05em}
.meter{height:8px;border-radius:6px;background:var(--slate2);overflow:hidden;margin-top:8px}
.meter i{display:block;height:100%;background:linear-gradient(90deg,var(--sky),var(--gold))}
.pricebox{background:var(--card);border:1px solid var(--line);border-radius:14px;padding:20px;margin-top:18px}
.pricebox .row{display:flex;justify-content:space-between;padding:9px 0;border-bottom:1px solid var(--line)}
.pricebox .row:last-child{border:0}.pricebox b{font-family:'Montserrat';font-weight:800}

/* ===== booking board (shared classes) ===== */
.board-wrap{background:var(--card);border:1px solid var(--line);border-radius:18px;padding:24px}
.board-top{display:flex;align-items:center;justify-content:center;gap:18px;margin-bottom:18px;position:relative}
.board-top .range{font-family:'Montserrat';font-weight:700;font-size:16px}
.board-nav{width:44px;height:44px;border-radius:50%;border:1px solid var(--line2);background:transparent;color:var(--cream);cursor:pointer;font-size:18px;display:flex;align-items:center;justify-content:center;transition:.18s}
.board-nav:hover{border-color:var(--sky);color:var(--sky)}
.board-top .l{position:absolute;left:0}.board-top .r{position:absolute;right:0}
.board{display:grid;grid-template-columns:repeat(7,1fr);gap:9px;min-width:760px}
.board .col-head{text-align:center;padding-bottom:8px}
.board .col-head .d{font-family:'Montserrat';font-weight:800;font-size:15px}
.board .col-head .w{color:var(--muted);font-size:12px;text-transform:uppercase}
.board .col-head.we .d{color:var(--teal)}
.slot{display:block;width:100%;text-align:center;padding:12px 6px;font-family:'Montserrat';font-weight:700;font-size:14px;cursor:pointer;border:1px solid var(--line2);background:var(--slate2);color:var(--cream);border-radius:10px;transition:.14s}
.slot small{display:block;font-weight:600;font-size:10px;opacity:.85;margin-top:2px}
.slot.weekday{border-color:rgba(117,180,217,.5)}.slot.weekday:hover{background:rgba(117,180,217,.16);border-color:var(--sky)}
.slot.weekend{border-color:rgba(95,166,160,.5)}.slot.weekend:hover{background:rgba(95,166,160,.16);border-color:var(--teal)}
.slot.promo{background:rgba(216,177,90,.2);border-color:var(--gold);color:var(--gold)}
.slot.booked{background:var(--bg2);color:var(--dim);cursor:not-allowed;text-decoration:line-through;border-color:var(--line)}
.slot.blocked{background:var(--bg2);color:var(--dim);cursor:not-allowed}
.slot.past{opacity:.32;cursor:not-allowed;pointer-events:none}
.legend{display:flex;gap:22px;justify-content:center;flex-wrap:wrap;margin-top:22px;color:var(--muted);font-size:13px;font-family:'Montserrat';font-weight:600}
.legend span{display:flex;align-items:center;gap:8px}
.legend i{width:14px;height:14px;border-radius:4px;display:inline-block}
.lg-weekday{background:var(--sky)}.lg-weekend{background:var(--teal)}.lg-promo{background:var(--gold)}.lg-booked{background:var(--dim)}
.board-scroll{overflow-x:auto}

/* modal */
.modal-bg{position:fixed;inset:0;background:rgba(14,18,28,.82);backdrop-filter:blur(8px);display:none;align-items:center;justify-content:center;z-index:120;padding:20px}
.modal-bg.on{display:flex}
.modal{background:var(--slate);border:1px solid var(--line2);border-radius:18px;max-width:460px;width:100%;padding:30px}
.modal h3{margin:0 0 4px}
.modal .field{margin:16px 0}
.modal label,.field label{display:block;font-family:'Montserrat';font-weight:600;font-size:12px;text-transform:uppercase;letter-spacing:.05em;color:var(--muted);margin-bottom:7px}
.modal input,.modal select,.field input,.field select,.field textarea{width:100%;padding:13px 15px;border-radius:10px;border:1px solid var(--line2);background:var(--bg2);color:var(--cream);font-size:15px;font-family:inherit}
.modal input:focus,.modal select:focus{outline:none;border-color:var(--sky)}
.modal .summary{background:var(--bg2);border:1px solid var(--line);border-radius:10px;padding:14px;margin:14px 0;font-size:14px}
.modal .summary b{color:var(--sky)}
.modal .x{float:right;background:none;border:1px solid var(--line2);color:var(--muted);width:34px;height:34px;border-radius:8px;font-size:18px;cursor:pointer}
.ok-msg{background:rgba(95,166,160,.16);border:1px solid var(--teal);color:#a7d8d2;padding:15px;border-radius:12px}

/* prose */
.prose{max-width:760px;margin:0 auto}.prose p{color:var(--muted)}
.prose img{border-radius:14px;margin:18px 0}

/* footer */
footer{border-top:1px solid var(--line);background:var(--bg2);padding:60px 0 32px;margin-top:40px}
.fcols{display:grid;grid-template-columns:2fr 1fr 1fr;gap:34px}
footer h4{font-family:'Montserrat';font-weight:800;font-size:15px;text-transform:uppercase;letter-spacing:.04em;margin:0 0 16px}
footer a{color:var(--muted);display:block;padding:5px 0;font-size:14px}footer a:hover{color:var(--sky)}
.copyright{border-top:1px solid var(--line);margin-top:36px;padding-top:22px;color:var(--dim);font-size:13px;text-align:center}

@media(max-width:900px){
  .qhero,.split{grid-template-columns:1fr}.fcols{grid-template-columns:1fr 1fr}
  .nav nav{display:none;position:absolute;top:74px;left:0;right:0;flex-direction:column;background:var(--bg2);border-bottom:1px solid var(--line);padding:12px 26px}
  .nav nav.open{display:flex}.burger{display:block}
}
@media(max-width:560px){.fcols{grid-template-columns:1fr}.qbadges{grid-template-columns:1fr}.vstat{gap:22px}}
