@font-face{font-family:'Ippolit';src:url('assets/fonts/ippolit_regular.ttf') format('truetype') format('truetype')}
    @font-face{font-family:'Montserrat';src:url('assets/fonts/montserrat_regular.ttf') format('truetype') format('truetype')}
    *,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
    :root{--bg:#F8F7F4;--black:#0D0D0D;--white:#fff;--grid:rgba(0,0,0,.07);--mid:#888;--red:#C0392B}
    html{scroll-behavior:smooth}
    body{background:var(--bg);color:var(--black);font-family:'Montserrat',sans-serif;
      background-image:linear-gradient(var(--grid) 1px,transparent 1px),linear-gradient(90deg,var(--grid) 1px,transparent 1px);
      background-size:72px 72px;min-height:100vh}
    .page{display:none;min-height:100vh}.page.active{display:block}
    #hub.active{display:flex}

    /* ── HUB ── */
    #hub{flex-direction:column;align-items:center;justify-content:center;padding:60px 40px}
    .hub-eye{font-size:.7rem;letter-spacing:5px;text-transform:uppercase;color:var(--mid);margin-bottom:16px;text-align:center}
    .hub-title{font-family:'Ippolit',sans-serif;font-size:clamp(2.8rem,9vw,7rem);text-align:center;line-height:.92;margin-bottom:8px}
    .hub-sub{font-size:.72rem;letter-spacing:4px;text-transform:uppercase;color:var(--mid);text-align:center;margin-bottom:64px}
    .vgrid{display:grid;grid-template-columns:repeat(3,1fr);border:1px solid var(--black);width:100%;max-width:1100px}
    @media(max-width:700px){.vgrid{grid-template-columns:1fr}.vc-card{border-right:none!important;border-bottom:1px solid var(--black)}.vc-card:last-child{border-bottom:none}}
    .vc-card{border-right:1px solid var(--black);cursor:pointer;transition:background .18s;
      display:flex;flex-direction:column;align-items:center;padding:48px 28px 28px;min-height:400px;color:var(--black)}
    .vc-card:last-child{border-right:none}
    .vc-card:hover{background:rgba(0,0,0,.04)}
    .vc-card:hover .ci{transform:scale(1.04)}
    .vc-card:hover .vtag{background:var(--black);color:var(--white);border-color:var(--black)}
    .vc-card:hover .varr{opacity:.8;transform:translateX(4px)}
    .logo-wrap{flex:1;display:flex;align-items:center;justify-content:center;width:100%;padding:8px 0}
    .ci{max-width:200px;max-height:180px;width:100%;object-fit:contain;transition:transform .2s}
    .vsub{font-size:.62rem;letter-spacing:3px;text-transform:uppercase;color:var(--mid);margin-top:6px;text-align:center}
    .vbot{width:100%;border-top:1px solid rgba(0,0,0,.1);padding-top:18px;display:flex;justify-content:space-between;align-items:center;margin-top:auto}
    .vtag{font-size:.63rem;letter-spacing:2px;text-transform:uppercase;border:1px solid rgba(0,0,0,.18);padding:4px 10px;transition:all .18s}
    .varr{font-size:1rem;opacity:.22;transition:opacity .18s,transform .18s}

    /* ── MARQUEE ── */
    .marquee{background:var(--black);color:var(--white);padding:12px 0;overflow:hidden}
    .marq-in{display:flex;animation:scroll 22s linear infinite;white-space:nowrap}
    @keyframes scroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}
    .mi{font-family:'Ippolit',sans-serif;font-size:.68rem;letter-spacing:4px;text-transform:uppercase;padding:0 32px;flex-shrink:0}
    .dot{color:var(--red);padding:0 6px}

    /* ── VENUE HEADER ── */
    .vhdr{position:sticky;top:0;z-index:100;background:var(--bg);border-bottom:1px solid var(--black);
      padding:0 40px;display:flex;align-items:center;justify-content:space-between;height:56px}
    @media(max-width:600px){.vhdr{padding:0 16px}.vnav a{padding:0 10px;font-size:.62rem}}
    .back{font-size:.7rem;letter-spacing:2px;text-transform:uppercase;background:none;border:none;cursor:pointer;
      display:flex;align-items:center;gap:6px;transition:opacity .15s;font-family:'Montserrat',sans-serif}
    .back:hover{opacity:.4}
    .vpname{font-family:'Ippolit',sans-serif;font-size:.95rem;letter-spacing:3px}
    .vnav{display:flex}
    .vnav a{display:block;padding:0 16px;height:56px;line-height:56px;font-size:.68rem;letter-spacing:1.5px;
      text-transform:uppercase;color:var(--black);text-decoration:none;border-left:1px solid var(--black);transition:background .15s,color .15s}
    .vnav a:hover{background:var(--black);color:var(--white)}

    /* ── HERO ── */
    .vhero{display:grid;grid-template-columns:1fr 1fr;border-bottom:1px solid var(--black);min-height:60vh}
    @media(max-width:700px){.vhero{grid-template-columns:1fr}.vhero-r{display:none}}
    .vhero-l{border-right:1px solid var(--black);padding:52px 48px;display:flex;flex-direction:column;justify-content:flex-end}
    @media(max-width:700px){.vhero-l{padding:36px 20px}}
    .hero-logo{margin-bottom:28px}
    .hero-logo img{max-height:150px;max-width:280px;object-fit:contain}
    .hero-logo-txt{font-family:'Ippolit',sans-serif;font-size:clamp(2rem,5vw,3.8rem);line-height:.95}
    .hero-sub{font-size:.68rem;letter-spacing:3px;text-transform:uppercase;color:var(--mid);margin-top:6px}
    .hero-desc{font-size:.94rem;line-height:1.78;opacity:.62;max-width:420px}
    .vhero-r{display:flex;flex-direction:column;overflow:hidden}

    /* ── SLIDER ── */
    .slider{flex:1;position:relative;overflow:hidden;background:#111;min-height:200px}
    .slides{display:flex;height:100%;transition:transform .4s cubic-bezier(.4,0,.2,1)}
    .slide{min-width:100%;height:100%;flex-shrink:0;position:relative;overflow:hidden}
    .slide img{width:100%;height:100%;object-fit:cover;display:block}
    .slide-ph{width:100%;height:100%;min-height:220px;display:flex;align-items:center;justify-content:center;
      background:rgba(0,0,0,.04);font-family:'Ippolit',sans-serif;font-size:.62rem;letter-spacing:3px;
      text-transform:uppercase;color:rgba(0,0,0,.18)}
    .sl-btn{position:absolute;top:50%;transform:translateY(-50%);background:rgba(248,247,244,.9);
      border:1px solid var(--black);color:var(--black);width:36px;height:36px;cursor:pointer;
      display:flex;align-items:center;justify-content:center;font-size:1rem;transition:background .15s;z-index:2}
    .sl-btn:hover{background:var(--black);color:var(--white)}
    .sl-prev{left:12px}.sl-next{right:12px}
    .sl-dots{position:absolute;bottom:10px;left:50%;transform:translateX(-50%);display:flex;gap:6px}
    .sl-dot{width:6px;height:6px;border-radius:50%;background:rgba(255,255,255,.4);cursor:pointer;transition:background .2s}
    .sl-dot.on{background:var(--white)}

    .vstripw{border-top:1px solid var(--black);display:grid;grid-template-columns:1fr 1fr}
    .sc{padding:14px 22px;border-right:1px solid var(--black);font-size:.8rem}
    .sc:last-child{border-right:none}
    .sc .lbl{font-family:'Ippolit',sans-serif;font-size:.56rem;letter-spacing:3px;text-transform:uppercase;color:var(--mid);margin-bottom:3px}
    .sc a{color:inherit;text-decoration:none;border-bottom:1px solid rgba(0,0,0,.2)}
    .sc a:hover{border-color:var(--black)}
    .ghost{flex:1;display:flex;align-items:center;justify-content:center;overflow:hidden;padding:40px}
    .ghost-t{font-family:'Ippolit',sans-serif;font-size:clamp(4rem,10vw,9rem);line-height:.88;opacity:.05;text-align:center;user-select:none}

    /* ── CONTENT ── */
    .vc{max-width:1100px;margin:0 auto;padding:0 48px}
    @media(max-width:700px){.vc{padding:0 20px}}
    .isec{padding:52px 0;border-bottom:1px solid var(--black);display:grid;grid-template-columns:1fr 1fr;gap:52px}
    @media(max-width:700px){.isec{grid-template-columns:1fr;gap:28px}}
    .sh{font-family:'Ippolit',sans-serif;font-size:.78rem;letter-spacing:3px;text-transform:uppercase;color:var(--mid);
      padding-bottom:11px;border-bottom:1px solid var(--black);margin-bottom:18px}
    .ir{display:flex;gap:14px;padding:9px 0;border-bottom:1px solid rgba(0,0,0,.07);font-size:.87rem;line-height:1.55}
    .ir:last-child{border-bottom:none}
    .ir .lbl{font-family:'Ippolit',sans-serif;font-size:.56rem;letter-spacing:2px;text-transform:uppercase;
      color:var(--mid);min-width:70px;margin-top:2px;flex-shrink:0}
    .ir a{color:inherit;text-decoration:none;border-bottom:1px solid rgba(0,0,0,.2)}
    .ir a:hover{border-color:var(--black)}
    .inote{margin-top:16px;padding:16px;background:rgba(0,0,0,.03);border-left:2px solid var(--black);
      font-size:.84rem;line-height:1.65;opacity:.72}

    /* PDF */
    .pdfsec{padding:44px 0;border-bottom:1px solid var(--black);display:flex;align-items:center;justify-content:space-between;gap:20px;flex-wrap:wrap}
    .pdfsec h2{font-family:'Ippolit',sans-serif;font-size:1.15rem;letter-spacing:2px}
    .pdfsec p{font-size:.8rem;color:var(--mid);margin-top:3px}
    .btnpdf{display:inline-flex;align-items:center;gap:8px;padding:13px 26px;font-family:'Montserrat',sans-serif;
      font-size:.72rem;letter-spacing:2px;text-transform:uppercase;text-decoration:none;
      background:var(--black);color:var(--white);border:1px solid var(--black);cursor:pointer;transition:all .15s;white-space:nowrap}
    .btnpdf:hover{background:transparent;color:var(--black)}
    .btnsoon{background:transparent;color:rgba(0,0,0,.25);border:1px solid rgba(0,0,0,.15);cursor:default}
    .btnsoon:hover{background:transparent;color:rgba(0,0,0,.25)}

    /* ── FAQ ── */
    .faqsec{padding:52px 0;border-bottom:1px solid var(--black)}
    .faqsec>h2{font-family:'Ippolit',sans-serif;font-size:clamp(1.2rem,2.5vw,1.8rem);margin-bottom:32px;letter-spacing:1px}
    .faq-item{border-bottom:1px solid rgba(0,0,0,.1)}
    .faq-item:first-of-type{border-top:1px solid rgba(0,0,0,.1)}
    .faq-q{width:100%;display:flex;justify-content:space-between;align-items:center;padding:18px 0;
      font-family:'Montserrat',sans-serif;font-size:.9rem;font-weight:700;text-align:left;
      background:none;border:none;cursor:pointer;color:var(--black);gap:16px;transition:opacity .15s}
    .faq-q:hover{opacity:.6}
    .faq-arr{font-size:1.3rem;font-weight:300;flex-shrink:0;transition:transform .2s;color:var(--mid)}
    .faq-item.open .faq-arr{transform:rotate(45deg)}
    .faq-a{max-height:0;overflow:hidden;transition:max-height .3s ease,padding .3s ease;
      font-size:.88rem;line-height:1.7;opacity:.65;padding:0}
    .faq-item.open .faq-a{max-height:200px;padding-bottom:18px}

    /* ── BOOKING ── */
    .booksec{padding:52px 0 80px}
    .booksec>h2{font-family:'Ippolit',sans-serif;font-size:clamp(1.3rem,3vw,2rem);margin-bottom:36px}
    .booklayout{display:grid;grid-template-columns:1fr 1fr;gap:56px}
    @media(max-width:700px){.booklayout{grid-template-columns:1fr;gap:28px}.baside{border-right:none;padding-right:0}}
    .baside{border-right:1px solid var(--black);padding-right:56px}
    .baside p{font-size:.95rem;line-height:1.75;font-style:italic;opacity:.62;margin-bottom:24px}
    .dl{list-style:none}
    .dl li{display:flex;gap:12px;padding:9px 0;border-bottom:1px solid rgba(0,0,0,.08);font-size:.84rem;line-height:1.5}
    .dl li:last-child{border-bottom:none}
    .dl .lbl{font-family:'Ippolit',sans-serif;font-size:.56rem;letter-spacing:2px;text-transform:uppercase;
      color:var(--mid);min-width:72px;margin-top:2px;flex-shrink:0}
    .fg{display:flex;flex-direction:column;gap:4px;margin-bottom:11px}
    .fg label{font-size:.62rem;letter-spacing:2px;text-transform:uppercase;color:var(--mid)}
    .fg input,.fg select,.fg textarea{background:transparent;border:1px solid rgba(0,0,0,.22);color:var(--black);
      padding:9px 13px;font-family:'Montserrat',sans-serif;font-size:.86rem;outline:none;
      transition:border-color .15s;-webkit-appearance:none;appearance:none}
    .fg input:focus,.fg select:focus,.fg textarea:focus{border-color:var(--black)}
    .fg textarea{resize:vertical;min-height:80px}
    .fg select option{background:var(--bg)}
    .fr2{display:grid;grid-template-columns:1fr 1fr;gap:11px}
    .btnsub{width:100%;padding:13px;margin-top:4px;font-family:'Montserrat',sans-serif;font-size:.72rem;
      letter-spacing:2px;text-transform:uppercase;background:var(--black);color:var(--white);
      border:1px solid var(--black);cursor:pointer;transition:all .15s}
    .btnsub:hover{background:transparent;color:var(--black)}
    .fnote{font-size:.67rem;color:var(--mid);margin-top:7px;font-style:italic}
    .book-ok{display:none;padding:28px;background:var(--black);color:var(--white);text-align:center}
    .book-ok h3{font-family:'Ippolit',sans-serif;font-size:.95rem;letter-spacing:3px;margin-bottom:6px}
    .book-ok p{font-size:.8rem;opacity:.58}

    /* FOOTER */
    .vfoot{background:var(--black);color:var(--white);padding:36px 48px;display:flex;
      justify-content:space-between;align-items:center;flex-wrap:wrap;gap:14px}
    .vfoot-n{font-family:'Ippolit',sans-serif;font-size:1.3rem;letter-spacing:2px}
    .vfoot-s{font-size:.63rem;opacity:.3;margin-top:3px}
    .vfoot a{font-size:.7rem;letter-spacing:1px;text-transform:uppercase;color:rgba(255,255,255,.38);text-decoration:none}
    .vfoot a:hover{color:white}
/* ===== JS-календарь и API-меню (S2) ===== */

.cal-display{padding:14px 18px;border:1px solid rgba(0,0,0,.12);border-radius:8px;
  font-size:.95rem;color:#111;margin-bottom:14px;background:#fafafa}
.cal-picker{display:grid;grid-template-columns:1fr 1fr;gap:24px;margin-bottom:10px}
@media (max-width:560px){.cal-picker{grid-template-columns:1fr}}
.cal-month{border:1px solid rgba(0,0,0,.08);border-radius:8px;padding:14px;background:#fff}
.cal-head{font-family:'Ippolit',sans-serif;font-size:1rem;text-align:center;
  letter-spacing:2px;text-transform:uppercase;margin-bottom:10px;color:#111}
.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:4px}
.cal-dow{font-size:.62rem;text-transform:uppercase;letter-spacing:1px;
  color:rgba(0,0,0,.35);text-align:center;padding:4px 0}
.cal-day{aspect-ratio:1/1;display:flex;align-items:center;justify-content:center;
  font-size:.85rem;border-radius:6px;user-select:none}
.cal-day.past{color:rgba(0,0,0,.18)}
.cal-day.booked{background:rgba(0,0,0,.08);color:rgba(0,0,0,.35);text-decoration:line-through}
.cal-day.free{cursor:pointer;color:#111;border:1px solid rgba(0,0,0,.10);transition:all .12s}
.cal-day.free:hover{background:#111;color:#fff;border-color:#111}
.cal-day.selected{background:#111;color:#fff;border-color:#111;font-weight:600}

.api-menu{padding:30px var(--vpad,8vw);background:#fafafa}
.menu-empty{font-size:.85rem;color:rgba(0,0,0,.5);text-align:center;padding:20px}
.menu-cat{margin-bottom:28px}
.menu-cat-name{font-family:'Ippolit',sans-serif;font-size:1.1rem;letter-spacing:2px;
  text-transform:uppercase;margin-bottom:10px;color:#111;border-bottom:1px solid rgba(0,0,0,.12);
  padding-bottom:6px}
.menu-list{list-style:none;padding:0;margin:0}
.menu-item{display:flex;justify-content:space-between;align-items:baseline;
  padding:8px 0;border-bottom:1px dotted rgba(0,0,0,.08);font-size:.92rem}
.menu-item-name{color:#111;flex:1;padding-right:14px}
.menu-item-price{color:rgba(0,0,0,.6);font-variant-numeric:tabular-nums;white-space:nowrap}
