@charset "utf-8";
/* ═══════════════ RESET & ROOT ═══════════════ */
:root{
  --red:#E8001E;--red-glow:#ff0028;--red-dim:#8b0011;
  --white:#fff;--black:#000;
  --g0:#000;--g1:#080808;--g2:#111;--g3:#181818;--g4:#222;--g5:#888;
  --green:#00c864;--yellow:#f0b429;
  --fd:'Bebas Neue',sans-serif;--fb:'Barlow Condensed',sans-serif;--fm:'JetBrains Mono',monospace;
  --trans:.22s ease;
}
*{margin:0;padding:0;box-sizing:border-box;}
html{scroll-behavior:smooth;font-size:16px;}
body{background:var(--g0);color:var(--white);font-family:var(--fb);overflow-x:hidden;min-height:100vh;}
img{display:block;max-width:100%;}
button{font-family:var(--fb);cursor:pointer;}
a{text-decoration:none;color:inherit;}
input,select,textarea{font-family:var(--fb);color:var(--white);}
:focus-visible{outline:2px solid var(--red);outline-offset:3px;}

/* ═══════════════ NOISE TEXTURE ═══════════════ */
body::after{content:'';position:fixed;inset:0;background:url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.035'/%3E%3C/svg%3E");pointer-events:none;z-index:9990;opacity:.3;}

/* ═══════════════ SKIP LINK ═══════════════ */
.skip{position:absolute;top:-60px;left:16px;background:var(--red);color:#fff;padding:10px 20px;font-weight:700;letter-spacing:2px;text-transform:uppercase;z-index:99999;transition:top .2s;}
.skip:focus{top:12px;}

/* ═══════════════ TOAST ═══════════════ */
#toasts{position:fixed;bottom:20px;right:20px;z-index:9999;display:flex;flex-direction:column;gap:8px;pointer-events:none;}
.toast{display:flex;align-items:center;gap:10px;padding:14px 18px;background:var(--g2);border:1px solid var(--g4);font-family:var(--fm);font-size:11px;letter-spacing:.5px;min-width:260px;max-width:340px;pointer-events:all;box-shadow:0 8px 32px rgba(0,0,0,.7);animation:tin .3s ease;}
.toast.ok{border-color:var(--green);color:var(--green);}
.toast.err{border-color:var(--red);color:var(--red);}
.toast.info{border-color:var(--yellow);color:var(--yellow);}
.toast .tx{cursor:pointer;margin-left:auto;font-size:16px;opacity:.6;background:none;border:none;color:inherit;}
.toast .tx:hover{opacity:1;}
@keyframes tin{from{transform:translateX(110%);opacity:0;}to{transform:translateX(0);opacity:1;}}
@keyframes tout{from{transform:translateX(0);opacity:1;}to{transform:translateX(110%);opacity:0;}}

/* ═══════════════ CONFIRM DIALOG ═══════════════ */
#cfm{position:fixed;inset:0;background:rgba(0,0,0,.96);z-index:8888;display:flex;align-items:center;justify-content:center;padding:20px;opacity:0;pointer-events:none;transition:opacity .2s;}
#cfm.on{opacity:1;pointer-events:all;}
.cfm-box{background:var(--g2);border:1px solid var(--red);padding:40px;max-width:380px;width:100%;text-align:center;}
.cfm-title{font-family:var(--fd);font-size:26px;letter-spacing:2px;margin-bottom:12px;}
.cfm-msg{font-size:13px;color:var(--g5);margin-bottom:28px;line-height:1.6;}
.cfm-btns{display:flex;gap:10px;justify-content:center;}

/* ═══════════════ MODAL ═══════════════ */
.mo{position:fixed;inset:0;background:rgba(0,0,0,.93);z-index:7000;display:flex;align-items:center;justify-content:center;padding:20px;opacity:0;pointer-events:none;transition:opacity .3s;backdrop-filter:blur(6px);}
.mo.on{opacity:1;pointer-events:all;}
.mo-box{background:var(--g2);border:1px solid var(--g4);padding:40px 36px;max-width:460px;width:100%;position:relative;max-height:88vh;overflow-y:auto;transform:translateY(18px);transition:transform .3s;}
.mo.on .mo-box{transform:translateY(0);}
.mo-x{position:absolute;top:12px;right:12px;background:none;border:1px solid var(--g4);color:var(--g5);width:28px;height:28px;display:flex;align-items:center;justify-content:center;font-size:14px;cursor:pointer;transition:all .2s;}
.mo-x:hover{border-color:var(--white);color:var(--white);}
.mo-title{font-family:var(--fd);font-size:28px;letter-spacing:2px;margin-bottom:6px;}
.mo-sub{font-size:13px;color:var(--g5);margin-bottom:24px;line-height:1.6;}

/* ═══════════════ SPINNER ═══════════════ */
.spin{width:16px;height:16px;border:2px solid rgba(255,255,255,.2);border-top-color:#fff;border-radius:50%;animation:sp .7s linear infinite;display:inline-block;}
@keyframes sp{to{transform:rotate(360deg);}}
.loading{opacity:.65!important;cursor:not-allowed!important;pointer-events:none!important;}

/* ═══════════════ NAV ═══════════════ */
#nav{position:fixed;top:0;left:0;right:0;z-index:1000;display:flex;justify-content:space-between;align-items:center;padding:14px 40px;background:rgba(0,0,0,.88);backdrop-filter:blur(20px);border-bottom:1px solid var(--g4);transition:padding .3s;}
#nav.small{padding:10px 40px;box-shadow:0 4px 30px rgba(0,0,0,.7);}
.nav-logo{display:flex;align-items:center;gap:10px;}
.nav-logo img{height:44px;transition:transform .3s;}
.nav-logo:hover img{transform:scale(1.05);}
.nav-links{display:flex;gap:24px;list-style:none;align-items:center;}
.nav-links a{color:var(--g5);font-size:12px;font-weight:700;letter-spacing:2px;text-transform:uppercase;transition:color .2s;position:relative;padding:4px 0;}
.nav-links a::after{content:'';position:absolute;bottom:-2px;left:0;right:0;height:1px;background:var(--red);transform:scaleX(0);transition:transform .2s;}
.nav-links a:hover{color:var(--white);}
.nav-links a:hover::after,.nav-links a.act::after{transform:scaleX(1);}
.nav-links a.act{color:var(--white);}
.btn-nadmin{border:1px solid var(--red);color:var(--red);padding:8px 16px;font-size:11px;font-weight:700;letter-spacing:2px;text-transform:uppercase;background:transparent;cursor:pointer;transition:all .2s;display:inline-flex;align-items:center;gap:6px;}
.btn-nadmin:hover{background:var(--red);color:#fff;box-shadow:0 0 18px rgba(232,0,30,.45);}
.btn-nbook{background:var(--red);color:#fff;padding:10px 22px;font-size:11px;font-weight:700;letter-spacing:2px;text-transform:uppercase;border:none;cursor:pointer;transition:all .2s;}
.btn-nbook:hover{background:var(--red-glow);box-shadow:0 0 24px rgba(232,0,30,.5);transform:translateY(-1px);}
.hbg{display:none;flex-direction:column;gap:5px;background:none;border:none;padding:4px;cursor:pointer;}
.hbg span{display:block;width:24px;height:2px;background:#fff;transition:all .3s;}
.hbg.x span:nth-child(1){transform:rotate(45deg) translate(5px,5px);}
.hbg.x span:nth-child(2){opacity:0;}
.hbg.x span:nth-child(3){transform:rotate(-45deg) translate(5px,-5px);}

/* ═══════════════ MOBILE MENU ═══════════════ */
#mmenu{position:fixed;inset:0;top:72px;background:rgba(0,0,0,.99);z-index:998;flex-direction:column;padding:28px;display:none;overflow-y:auto;}
#mmenu.on{display:flex;}
.mlink{color:#fff;font-family:var(--fd);font-size:42px;letter-spacing:2px;padding:14px 0;border-bottom:1px solid var(--g4);display:block;transition:color .2s;}
.mlink:hover{color:var(--red);}
.mlink.red{color:var(--red);}

/* ═══════════════ BUTTONS ═══════════════ */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;font-family:var(--fb);font-weight:700;letter-spacing:2px;text-transform:uppercase;cursor:pointer;border:none;transition:all var(--trans);}
.btn-red{background:var(--red);color:#fff;padding:14px 36px;font-size:14px;}
.btn-red:hover:not(:disabled){background:var(--red-glow);box-shadow:0 0 32px rgba(232,0,30,.55);transform:translateY(-2px);}
.btn-out{background:transparent;color:#fff;padding:14px 36px;font-size:14px;border:1px solid rgba(255,255,255,.3);}
.btn-out:hover:not(:disabled){border-color:#fff;background:rgba(255,255,255,.06);}
.btn-ghost{background:transparent;border:1px solid var(--g4);color:var(--g5);padding:10px 18px;font-size:11px;}
.btn-ghost:hover{color:#fff;border-color:#fff;}
.btn-danger{background:transparent;color:var(--red);border:1px solid var(--red);padding:7px 14px;font-size:11px;}
.btn-danger:hover{background:var(--red);color:#fff;}
.btn-sm{padding:7px 14px;font-size:11px;}
button:disabled{opacity:.38;cursor:not-allowed!important;pointer-events:none;}

/* ═══════════════ FORMS ═══════════════ */
.fg{margin-bottom:18px;}
.fl{display:block;font-family:var(--fm);font-size:9px;color:var(--g5);letter-spacing:2px;text-transform:uppercase;margin-bottom:7px;}
.fl .req{color:var(--red);}
.fc{width:100%;background:rgba(255,255,255,.04);border:1px solid var(--g4);color:#fff;padding:12px 14px;font-family:var(--fb);font-size:15px;outline:none;transition:border-color .2s;}
.fc:focus{border-color:var(--red);}
.fc.err{border-color:var(--red);animation:shake .3s;}
.fc option{background:var(--g2);}
@keyframes shake{0%,100%{transform:translateX(0);}30%{transform:translateX(-5px);}70%{transform:translateX(5px);}}
.ferr{font-family:var(--fm);font-size:9px;color:var(--red);margin-top:4px;letter-spacing:1px;display:none;}
.ferr.on{display:block;}
.frow{display:grid;grid-template-columns:1fr 1fr;gap:14px;}
.char-c{font-family:var(--fm);font-size:9px;color:var(--g5);text-align:right;margin-top:4px;}

/* ═══════════════ HERO ═══════════════ */
#home{min-height:100vh;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden;padding:120px 40px 80px;}
.hero-bg{position:absolute;inset:0;background:radial-gradient(ellipse 80% 60% at 50% 100%,rgba(232,0,30,.15) 0%,transparent 70%),radial-gradient(ellipse 40% 40% at 15% 50%,rgba(232,0,30,.07) 0%,transparent 60%),linear-gradient(180deg,#000 0%,#050505 100%);}
.hero-grid{position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,.024) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.024) 1px,transparent 1px);background-size:60px 60px;mask-image:radial-gradient(ellipse 80% 80% at 50% 50%,black 30%,transparent 100%);}
.hero-inner{position:relative;text-align:center;max-width:920px;animation:fu .9s ease both;}
@keyframes fu{from{opacity:0;transform:translateY(36px);}to{opacity:1;transform:translateY(0);}}
.hero-logo{width:200px;margin:0 auto 44px;filter:drop-shadow(0 0 44px rgba(232,0,30,.7));animation:fu .9s ease .1s both;}
.hero-ey{font-family:var(--fm);font-size:11px;letter-spacing:6px;color:var(--red);text-transform:uppercase;margin-bottom:16px;animation:fu .9s ease .2s both;}
.hero-h1{font-family:var(--fd);font-size:clamp(58px,10vw,128px);line-height:.9;letter-spacing:2px;color:#fff;animation:fu .9s ease .3s both;}
.hero-h1 em{color:var(--red);text-shadow:0 0 60px rgba(232,0,30,.5);font-style:normal;}
.hero-sub{font-size:18px;font-weight:300;letter-spacing:4px;color:var(--g5);margin-top:20px;text-transform:uppercase;animation:fu .9s ease .4s both;}
.hero-ctas{display:flex;gap:14px;justify-content:center;margin-top:44px;flex-wrap:wrap;animation:fu .9s ease .5s both;}
.hero-stats{display:flex;gap:44px;justify-content:center;margin-top:60px;padding-top:44px;border-top:1px solid var(--g4);animation:fu .9s ease .6s both;flex-wrap:wrap;}
.hstat-n{font-family:var(--fd);font-size:46px;color:var(--red);line-height:1;}
.hstat-l{font-size:10px;letter-spacing:3px;color:var(--g5);text-transform:uppercase;margin-top:4px;}

/* ═══════════════ MARQUEE ═══════════════ */
.mq{overflow:hidden;border-top:1px solid var(--g4);border-bottom:1px solid var(--g4);padding:14px 0;background:var(--g1);}
.mq-t{display:flex;gap:56px;animation:mq 22s linear infinite;white-space:nowrap;width:max-content;}
.mq-t:hover{animation-play-state:paused;}
@keyframes mq{from{transform:translateX(0);}to{transform:translateX(-50%);}}
.mq-i{font-family:var(--fd);font-size:13px;letter-spacing:4px;color:var(--g5);text-transform:uppercase;display:flex;align-items:center;gap:18px;}
.mq-d{width:5px;height:5px;background:var(--red);border-radius:50%;}

/* ═══════════════ SECTIONS ═══════════════ */
.sec{padding:96px 40px;}
.sec-dark{background:var(--g1);}
.wrap{max-width:1200px;margin:0 auto;}
.sec-ey{font-family:var(--fm);font-size:11px;letter-spacing:5px;color:var(--red);text-transform:uppercase;margin-bottom:14px;}
.sec-h2{font-family:var(--fd);font-size:clamp(40px,6vw,76px);line-height:1;margin-bottom:16px;}
.sec-sub{font-size:16px;font-weight:300;color:var(--g5);letter-spacing:1px;max-width:480px;line-height:1.65;}
.sec-hdr{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:52px;flex-wrap:wrap;gap:20px;}

/* ═══════════════ STUDIOS ═══════════════ */
.studios-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(270px,1fr));gap:2px;}
.sc{background:var(--g2);border:1px solid var(--g4);overflow:hidden;transition:transform .3s,border-color .3s;}
.sc:hover{transform:translateY(-4px);border-color:rgba(232,0,30,.45);}
.sc-img{height:190px;display:flex;align-items:center;justify-content:center;font-size:58px;background:linear-gradient(135deg,var(--g3),var(--g2));transition:transform .5s;}
.sc:hover .sc-img{transform:scale(1.05);}
.sc-body{padding:26px;}
.sc-badge{display:inline-block;background:var(--red);color:#fff;font-size:9px;font-weight:700;letter-spacing:2px;padding:3px 9px;text-transform:uppercase;margin-bottom:9px;}
.sc-name{font-family:var(--fd);font-size:24px;letter-spacing:1px;margin-bottom:7px;}
.sc-desc{font-size:12px;color:var(--g5);line-height:1.65;margin-bottom:16px;}
.sc-tags{display:flex;flex-wrap:wrap;gap:5px;margin-bottom:18px;}
.tag{background:rgba(255,255,255,.04);border:1px solid var(--g4);color:var(--g5);font-family:var(--fm);font-size:9px;padding:3px 8px;}
.sc-btn{width:100%;background:transparent;border:1px solid var(--g4);color:var(--g5);padding:11px;font-family:var(--fb);font-size:11px;font-weight:700;letter-spacing:2px;text-transform:uppercase;cursor:pointer;transition:all .2s;}
.sc-btn:hover,.sc-btn:focus-visible{border-color:var(--red);color:#fff;background:rgba(232,0,30,.09);outline:none;}

/* ═══════════════ PACKAGES ═══════════════ */
.pkg-tabs{display:flex;border-bottom:1px solid var(--g4);flex-wrap:wrap;margin-bottom:34px;}
.ptab{padding:12px 24px;font-family:var(--fb);font-size:12px;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:var(--g5);cursor:pointer;border:none;background:none;border-bottom:2px solid transparent;margin-bottom:-1px;transition:all .2s;}
.ptab:hover{color:#fff;}
.ptab.on{color:#fff;border-bottom-color:var(--red);}
.ptab:focus-visible{outline:2px solid var(--red);}
.ppanel{display:none;}
.ppanel.on{display:grid;grid-template-columns:repeat(auto-fit,minmax(270px,1fr));gap:2px;}
.pc{background:var(--g2);border:1px solid var(--g4);padding:32px 28px;position:relative;transition:border-color .3s,transform .3s;}
.pc:hover{border-color:rgba(232,0,30,.5);transform:translateY(-3px);}
.pc.star{border-color:var(--red);background:linear-gradient(135deg,var(--g2) 0%,rgba(232,0,30,.06) 100%);}
.pc-badge{position:absolute;top:14px;right:14px;background:var(--red);color:#fff;font-size:9px;font-weight:700;letter-spacing:2px;padding:3px 9px;text-transform:uppercase;}
.pc-icon{font-size:32px;margin-bottom:16px;}
.pc-name{font-family:var(--fd);font-size:22px;margin-bottom:6px;letter-spacing:1px;}
.pc-desc{font-size:12px;color:var(--g5);line-height:1.65;margin-bottom:20px;}
.pc-price{display:flex;align-items:baseline;gap:4px;margin-bottom:20px;}
.pc-pn{font-family:var(--fd);font-size:46px;color:var(--red);line-height:1;}
.pc-pu{font-size:12px;color:var(--g5);}
.pc-ul{list-style:none;margin-bottom:26px;}
.pc-ul li{font-size:12px;color:var(--g5);padding:6px 0;border-bottom:1px solid rgba(255,255,255,.04);display:flex;align-items:center;gap:8px;}
.pc-ul li::before{content:'';width:5px;height:5px;background:var(--red);border-radius:50%;flex-shrink:0;}
.pc-btn{width:100%;background:transparent;border:1px solid var(--red);color:var(--red);padding:12px;font-family:var(--fb);font-size:11px;font-weight:700;letter-spacing:2px;text-transform:uppercase;cursor:pointer;transition:all .2s;}
.pc-btn:hover,.pc.star .pc-btn,.pc-btn:focus-visible{background:var(--red);color:#fff;box-shadow:0 0 16px rgba(232,0,30,.3);outline:none;}

/* ═══════════════ BOOKING ═══════════════ */
.book-wrap{display:grid;grid-template-columns:1fr 360px;gap:32px;max-width:1060px;margin:0 auto;}
.book-panel{background:var(--g2);border:1px solid var(--g4);padding:38px;}
.step-bar{display:flex;margin-bottom:34px;}
.sd{flex:1;height:3px;background:var(--g4);position:relative;transition:background .3s;}
.sd.done,.sd.act{background:var(--red);}
.sd-lbl{position:absolute;top:9px;left:0;font-family:var(--fm);font-size:9px;color:var(--g5);white-space:nowrap;letter-spacing:1px;}
.sd.act .sd-lbl,.sd.done .sd-lbl{color:#fff;}
.step{display:none;}
.step.on{display:block;}
.st-title{font-family:var(--fd);font-size:22px;letter-spacing:1px;margin-bottom:6px;}
.st-sub{font-size:12px;color:var(--g5);margin-bottom:24px;}
.room-grid{display:grid;grid-template-columns:1fr 1fr;gap:9px;}
.ro{border:1px solid var(--g4);padding:15px;cursor:pointer;transition:all .2s;background:transparent;color:#fff;text-align:left;width:100%;}
.ro:hover{border-color:rgba(232,0,30,.5);}
.ro.on{border-color:var(--red);background:rgba(232,0,30,.09);}
.ro:focus-visible{outline:2px solid var(--red);}
.ro-name{font-family:var(--fd);font-size:16px;letter-spacing:1px;margin-bottom:3px;}
.ro-rate{font-family:var(--fm);font-size:10px;color:var(--red);}
.time-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:6px;margin-top:6px;}
.ts{border:1px solid var(--g4);padding:9px 4px;text-align:center;cursor:pointer;font-family:var(--fm);font-size:9px;color:var(--g5);transition:all .2s;background:transparent;line-height:1.4;}
.ts:hover:not(.bkd){border-color:var(--red);color:#fff;}
.ts.on{border-color:var(--red);background:rgba(232,0,30,.1);color:#fff;}
.ts.bkd{opacity:.28;cursor:not-allowed;text-decoration:line-through;}
.ts:focus-visible:not(.bkd){outline:2px solid var(--red);}
.dur-btns{display:flex;gap:6px;flex-wrap:wrap;}
.db{border:1px solid var(--g4);padding:9px 16px;cursor:pointer;font-family:var(--fb);font-size:12px;font-weight:600;color:var(--g5);background:transparent;transition:all .2s;}
.db:hover{color:#fff;border-color:rgba(255,255,255,.4);}
.db.on{border-color:var(--red);color:#fff;background:rgba(232,0,30,.1);}
.db:focus-visible{outline:2px solid var(--red);}
.step-btns{display:flex;gap:9px;margin-top:26px;}
.snext{flex:1;background:var(--red);color:#fff;border:none;padding:14px;font-family:var(--fb);font-size:12px;font-weight:700;letter-spacing:2px;text-transform:uppercase;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;gap:8px;}
.snext:hover:not(:disabled){background:var(--red-glow);box-shadow:0 0 16px rgba(232,0,30,.4);}
.sback{background:transparent;border:1px solid var(--g4);color:var(--g5);padding:14px 20px;font-family:var(--fb);font-size:12px;font-weight:700;letter-spacing:2px;text-transform:uppercase;cursor:pointer;transition:all .2s;}
.sback:hover{color:#fff;border-color:#fff;}
/* Pay methods */
.pay-opts{display:flex;gap:8px;margin-bottom:18px;}
.popt{border:1px solid var(--g4);padding:13px;cursor:pointer;transition:all .2s;background:transparent;color:var(--g5);font-size:13px;flex:1;display:flex;align-items:center;justify-content:center;gap:7px;}
.popt:hover,.popt.on{border-color:var(--red);color:#fff;background:rgba(232,0,30,.07);}
.popt:focus-visible{outline:2px solid var(--red);}
.card-icons{display:flex;gap:5px;margin-top:6px;}
.ci{width:34px;height:20px;background:var(--g3);border:1px solid var(--g4);border-radius:2px;display:flex;align-items:center;justify-content:center;font-size:7px;color:var(--g5);}
/* Summary sidebar */
.book-sum{background:var(--g2);border:1px solid var(--g4);padding:28px;position:sticky;top:90px;height:fit-content;}
.sum-title{font-family:var(--fd);font-size:18px;letter-spacing:2px;margin-bottom:20px;padding-bottom:14px;border-bottom:1px solid var(--g4);}
.sum-row{display:flex;justify-content:space-between;align-items:center;padding:8px 0;font-size:12px;border-bottom:1px solid rgba(255,255,255,.04);}
.sum-label{color:var(--g5);}
.sum-val{font-family:var(--fm);font-size:11px;font-weight:600;}
.sum-tot{margin-top:16px;padding-top:16px;border-top:1px solid var(--g4);}
.sum-tot-row{display:flex;justify-content:space-between;align-items:baseline;}
.sum-tot-l{font-family:var(--fd);font-size:17px;letter-spacing:1px;}
.sum-tot-v{font-family:var(--fd);font-size:32px;color:var(--red);}
.sum-dep{background:rgba(232,0,30,.09);border:1px solid rgba(232,0,30,.25);padding:11px 14px;margin-top:12px;}
.sum-dep-l{font-family:var(--fm);font-size:9px;color:var(--red);letter-spacing:2px;text-transform:uppercase;margin-bottom:3px;}
.sum-dep-v{font-family:var(--fd);font-size:24px;}
.pay-badges{display:flex;gap:6px;margin-top:18px;flex-wrap:wrap;}
.pay-badge{border:1px solid var(--g4);padding:6px 12px;font-size:10px;color:var(--g5);}
/* Success */
.book-ok{display:none;text-align:center;padding:56px 40px;}
.book-ok.on{display:block;}
.ok-icon{font-size:58px;margin-bottom:20px;animation:sc .5s ease;}
@keyframes sc{from{transform:scale(0);opacity:0;}to{transform:scale(1);opacity:1;}}
.conf-n{font-family:var(--fm);font-size:13px;color:var(--red);letter-spacing:3px;margin:10px 0 24px;padding:10px;background:rgba(232,0,30,.08);border:1px solid rgba(232,0,30,.2);display:inline-block;}
.conf-det{background:var(--g2);border:1px solid var(--g4);padding:22px;text-align:left;margin:22px auto;max-width:400px;}
.cd-row{display:flex;justify-content:space-between;padding:7px 0;border-bottom:1px solid rgba(255,255,255,.05);font-size:12px;}
.cd-l{color:var(--g5);}
.cd-v{font-family:var(--fm);font-size:10px;}

/* ═══════════════ TESTIMONIALS ═══════════════ */
.tgrid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:2px;margin-top:52px;}
.tc{background:var(--g2);border:1px solid var(--g4);padding:32px;transition:border-color .3s;}
.tc:hover{border-color:rgba(232,0,30,.4);}
.tc-stars{color:var(--red);font-size:14px;letter-spacing:2px;margin-bottom:16px;}
.tc-text{font-size:14px;color:var(--g5);line-height:1.75;font-style:italic;margin-bottom:20px;}
.tc-auth{display:flex;align-items:center;gap:11px;}
.tc-av{width:40px;height:40px;background:linear-gradient(135deg,var(--red),var(--red-dim));border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:var(--fd);font-size:16px;flex-shrink:0;}
.tc-name{font-family:var(--fd);font-size:16px;letter-spacing:1px;}
.tc-role{font-family:var(--fm);font-size:9px;color:var(--g5);letter-spacing:1px;}

/* ═══════════════ CONTACT ═══════════════ */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:64px;max-width:960px;margin:0 auto;align-items:start;}
.ci-item{display:flex;gap:16px;margin-bottom:26px;align-items:flex-start;}
.ci-icon{width:40px;height:40px;background:rgba(232,0,30,.1);border:1px solid rgba(232,0,30,.3);display:flex;align-items:center;justify-content:center;font-size:17px;flex-shrink:0;}
.ci-lbl{font-family:var(--fm);font-size:9px;color:var(--red);letter-spacing:2px;text-transform:uppercase;margin-bottom:4px;}
.ci-val{font-size:14px;color:#fff;line-height:1.55;}
.ci-val a{color:var(--red);}
.ci-val a:hover{text-decoration:underline;}

/* ═══════════════ FOOTER ═══════════════ */
footer{background:var(--g2);border-top:1px solid var(--g4);padding:52px 40px 26px;}
.fg-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:40px;max-width:1100px;margin:0 auto 40px;}
.fg-logo{height:46px;margin-bottom:13px;}
.fg-desc{font-size:12px;color:var(--g5);line-height:1.75;margin-bottom:16px;}
.fg-social{display:flex;gap:9px;}
.fg-soc-btn{width:34px;height:34px;border:1px solid var(--g4);display:flex;align-items:center;justify-content:center;color:var(--g5);font-size:14px;cursor:pointer;transition:all .2s;text-decoration:none;}
.fg-soc-btn:hover{border-color:var(--red);color:var(--red);}
.fg-col-h{font-family:var(--fd);font-size:14px;letter-spacing:3px;margin-bottom:16px;}
.fg-links{list-style:none;}
.fg-links li{margin-bottom:8px;}
.fg-links a,.fg-links button{color:var(--g5);font-size:12px;transition:color .2s;background:none;border:none;cursor:pointer;font-family:var(--fb);padding:0;}
.fg-links a:hover,.fg-links button:hover{color:var(--red);}
.fg-bot{max-width:1100px;margin:0 auto;padding-top:20px;border-top:1px solid var(--g4);display:flex;justify-content:space-between;align-items:center;font-size:10px;color:var(--g5);flex-wrap:wrap;gap:8px;}
.fg-bot a{color:var(--g5);}
.fg-bot a:hover{color:#fff;}

/* ═══════════════ ADMIN PORTAL ═══════════════ */
#admin{position:fixed;inset:0;background:var(--g0);z-index:6000;display:none;flex-direction:column;}
#admin.on{display:flex;}
.ah{display:flex;justify-content:space-between;align-items:center;padding:13px 26px;background:var(--g2);border-bottom:1px solid var(--g4);flex-shrink:0;}
.ah-l{display:flex;align-items:center;gap:13px;}
.ah-title{font-family:var(--fd);font-size:19px;letter-spacing:3px;}
.ah-badge{background:var(--red);color:#fff;font-family:var(--fm);font-size:9px;padding:3px 9px;letter-spacing:2px;}
.ah-r{display:flex;gap:9px;align-items:center;}
.ah-user{font-family:var(--fm);font-size:10px;color:var(--g5);letter-spacing:1px;}
.adm-body{display:flex;flex:1;overflow:hidden;}
.adm-sb{width:200px;background:var(--g2);border-right:1px solid var(--g4);padding:18px 0;overflow-y:auto;flex-shrink:0;}
.adm-sb-sec{font-family:var(--fm);font-size:9px;color:var(--g5);letter-spacing:3px;text-transform:uppercase;padding:12px 20px 5px;}
.adm-nav{display:flex;align-items:center;gap:9px;padding:12px 20px;cursor:pointer;font-family:var(--fb);font-size:12px;font-weight:600;letter-spacing:1px;text-transform:uppercase;color:var(--g5);transition:all .2s;border-left:3px solid transparent;border:none;background:none;width:100%;text-align:left;}
.adm-nav:hover{color:#fff;background:rgba(255,255,255,.03);}
.adm-nav.on{color:#fff;border-left:3px solid var(--red);background:rgba(232,0,30,.07);}
.adm-nav:focus-visible{outline:2px solid var(--red);outline-offset:-2px;}
.adm-content{flex:1;overflow-y:auto;padding:26px 30px;}
.ap{display:none;}
.ap.on{display:block;}
.a-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(170px,1fr));gap:13px;margin-bottom:26px;}
.asc{background:var(--g2);border:1px solid var(--g4);padding:20px;}
.asc-l{font-family:var(--fm);font-size:9px;color:var(--g5);letter-spacing:2px;text-transform:uppercase;margin-bottom:6px;}
.asc-v{font-family:var(--fd);font-size:36px;line-height:1;}
.asc.hi .asc-v{color:var(--red);}
.asc-t{font-family:var(--fm);font-size:9px;margin-top:5px;}
.tu{color:var(--green);}
.td{color:var(--red);}
.a-sec-h{font-family:var(--fd);font-size:20px;letter-spacing:2px;margin-bottom:18px;padding-bottom:9px;border-bottom:1px solid var(--g4);display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:8px;}
.a-tw{overflow-x:auto;}
.at{width:100%;border-collapse:collapse;font-size:11px;min-width:580px;}
.at th{text-align:left;font-family:var(--fm);font-size:9px;color:var(--g5);letter-spacing:2px;text-transform:uppercase;padding:9px 13px;border-bottom:1px solid var(--g4);}
.at td{padding:12px 13px;border-bottom:1px solid rgba(255,255,255,.04);color:#fff;}
.at tr:hover td{background:rgba(255,255,255,.02);}
.at .mn{font-family:var(--fm);font-size:9px;color:var(--g5);}
.at .am{color:var(--red);font-family:var(--fm);font-size:10px;font-weight:700;}
.sbadge{display:inline-block;padding:2px 8px;font-size:9px;font-weight:700;letter-spacing:1px;text-transform:uppercase;font-family:var(--fm);}
.s-ok{background:rgba(0,200,100,.13);color:var(--green);border:1px solid rgba(0,200,100,.27);}
.s-pend{background:rgba(240,180,41,.13);color:var(--yellow);border:1px solid rgba(240,180,41,.27);}
.s-can{background:rgba(232,0,30,.13);color:var(--red);border:1px solid rgba(232,0,30,.27);}
.ta{display:flex;gap:5px;flex-wrap:wrap;}
.tb{background:transparent;cursor:pointer;font-family:var(--fm);font-size:9px;letter-spacing:1px;padding:4px 9px;border:1px solid var(--g4);color:var(--g5);transition:all .2s;text-transform:uppercase;}
.tb:hover{color:#fff;border-color:#fff;}
.tb.del:hover{color:var(--red);border-color:var(--red);}
.tb:focus-visible{outline:2px solid var(--red);}
.a-search{display:flex;gap:9px;margin-bottom:16px;flex-wrap:wrap;}
.a-si{flex:1;min-width:180px;background:rgba(255,255,255,.04);border:1px solid var(--g4);color:#fff;padding:9px 13px;font-family:var(--fb);font-size:13px;outline:none;}
.a-si:focus{border-color:var(--red);}
.a-sel{background:rgba(255,255,255,.04);border:1px solid var(--g4);color:#fff;padding:9px 13px;font-family:var(--fb);font-size:12px;outline:none;cursor:pointer;}
.a-sel:focus{border-color:var(--red);}
.a-sel option{background:var(--g2);}
.p-inp{background:rgba(255,255,255,.04);border:1px solid var(--g4);color:#fff;padding:7px 11px;font-family:var(--fm);font-size:13px;width:90px;outline:none;}
.p-inp:focus{border-color:var(--red);}
/* Bar chart */
.bar-c{display:flex;align-items:flex-end;gap:7px;height:100px;padding:14px;background:var(--g2);border:1px solid var(--g4);}
.bw{flex:1;display:flex;flex-direction:column;align-items:center;gap:4px;height:100%;}
.bi{flex:1;width:100%;background:var(--g4);position:relative;}
.bf{width:100%;background:var(--red);transition:height .6s ease;position:absolute;bottom:0;}
.bl{font-family:var(--fm);font-size:8px;color:var(--g5);}
.bv{font-family:var(--fm);font-size:8px;color:var(--g5);}
/* Room status */
.room-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(190px,1fr));gap:13px;margin-bottom:26px;}
.rcard{background:var(--g2);border:1px solid var(--g4);padding:20px;}
.rcard-name{font-family:var(--fd);font-size:17px;letter-spacing:1px;margin-bottom:9px;}
.rdot{display:inline-flex;align-items:center;gap:6px;font-family:var(--fm);font-size:10px;margin-bottom:11px;}
.dot-g{color:var(--green);}
.dot-r{color:var(--red);}
.dot-y{color:var(--yellow);}
.rtoggle{width:100%;border:1px solid var(--g4);background:transparent;color:var(--g5);padding:8px;font-family:var(--fb);font-size:10px;font-weight:700;letter-spacing:1px;text-transform:uppercase;cursor:pointer;transition:all .2s;}
.rtoggle:hover{border-color:#fff;color:#fff;}
/* Service toggles */
.srv-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:12px;}
.srv-card{background:var(--g2);border:1px solid var(--g4);padding:18px;display:flex;justify-content:space-between;align-items:center;}
.srv-name{font-size:13px;}
.srv-tog{border:none;background:transparent;cursor:pointer;font-family:var(--fm);font-size:9px;letter-spacing:1px;padding:5px 10px;border:1px solid var(--g4);color:var(--g5);transition:all .2s;text-transform:uppercase;}
.srv-tog.on{border-color:var(--green);color:var(--green);}
.srv-tog:hover{color:#fff;border-color:#fff;}
/* Messages */
.msg-card{background:var(--g2);border:1px solid var(--g4);padding:20px;margin-bottom:9px;transition:border-color .2s;}
.msg-card.unread{border-color:rgba(232,0,30,.35);}
.msg-top{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:9px;flex-wrap:wrap;gap:6px;}
.msg-from{font-family:var(--fd);font-size:15px;letter-spacing:1px;}
.msg-email{font-family:var(--fm);font-size:10px;color:var(--g5);margin-left:9px;}
.msg-new{background:var(--red);color:#fff;font-size:9px;padding:2px 7px;font-family:var(--fm);}
.msg-time{font-family:var(--fm);font-size:9px;color:var(--g5);}
.msg-subj{font-size:11px;color:var(--red);font-family:var(--fm);letter-spacing:1px;margin-bottom:6px;}
.msg-body{font-size:13px;color:var(--g5);line-height:1.65;margin-bottom:14px;}
/* Admin login */
.adm-login{flex:1;display:flex;align-items:center;justify-content:center;}
.adm-lb{background:var(--g2);border:1px solid var(--g4);padding:48px 42px;width:100%;max-width:380px;text-align:center;}
.adm-li{font-size:42px;margin-bottom:20px;}
.adm-lt{font-family:var(--fd);font-size:28px;letter-spacing:2px;margin-bottom:6px;}
.adm-ls{font-size:12px;color:var(--g5);margin-bottom:26px;}
.adm-hint{font-family:var(--fm);font-size:9px;color:var(--g5);margin-top:16px;letter-spacing:1px;}
/* Privacy/Terms modal content */
.legal-body{font-size:12px;color:var(--g5);line-height:1.85;max-height:360px;overflow-y:auto;padding-right:6px;}
.legal-body strong{color:#fff;}

/* ═══════════════ RESPONSIVE ═══════════════ */
@media(max-width:1024px){
  .book-wrap{grid-template-columns:1fr;}
  .book-sum{position:static;}
  .contact-grid{grid-template-columns:1fr;gap:40px;}
  .fg-grid{grid-template-columns:1fr 1fr;}
}
@media(max-width:768px){
  #nav{padding:12px 18px;}

  .nav-links{display:none;}
  .hbg{display:flex;}
  .sec{padding:64px 18px;}
  .frow{grid-template-columns:1fr;}
  .time-grid{grid-template-columns:repeat(3,1fr);}
  .room-grid{grid-template-columns:1fr;}
  .adm-sb{display:none;}
  .adm-content{padding:16px;}
  .mo-box{padding:28px 20px;}
  footer{padding:40px 18px 20px;}
  #home{padding:100px 20px 60px;}
}
@media(max-width:480px){
  .hero-h1{font-size:52px;}
  .hero-logo{width:150px;}
  .hero-ctas{flex-direction:column;align-items:stretch;}
  .fg-grid{grid-template-columns:1fr;}
  .time-grid{grid-template-columns:repeat(2,1fr);}
  .a-stats{grid-template-columns:1fr 1fr;}
  .pkg-tabs{gap:0;}
  .ptab{padding:10px 13px;font-size:10px;}
  .pay-opts{flex-direction:column;}
}

@keyframes hpulse {
  0%,100%{border-color:var(--red);box-shadow:none;}
  50%{border-color:var(--red);box-shadow:0 0 18px rgba(232,0,30,.55);}
}
.highlight-pulse{animation:hpulse .7s ease 2;}/* CSS Document */

