/* ============================================================
   EL CLASICO FOOTBALL ARENA — style.css
   ============================================================ */

*{box-sizing:border-box;margin:0;padding:0}

:root{
  --g:#00c853;--g2:#00e676;--gold:#ffd600;
  --dk:#07090a;--card:#111820;--bdr:rgba(0,200,83,0.15);
  --txt:#e8f5e9;--muted:#78909c;
  --tr:0.3s ease;
  --font-sans:-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,'Helvetica Neue',Arial,'Noto Sans',sans-serif
}

[data-theme="light"]{
  --dk:#f5f7f5;--card:#ffffff;--bdr:rgba(0,150,60,0.15);
  --txt:#1a2e1a;--muted:#4a6a4a
}

html,body{background:var(--dk);color:var(--txt);font-family:var(--font-sans);transition:background var(--tr),color var(--tr)}

.page{display:none;min-height:520px;opacity:0;transform:translateY(8px);transition:opacity .3s ease,transform .3s ease}
.page.show{display:block;opacity:1;transform:translateY(0)}

/* ── NAV ── */
nav{display:flex;align-items:center;justify-content:space-between;padding:12px 18px;background:var(--dk);border-bottom:1px solid var(--bdr);position:sticky;top:0;z-index:200;flex-wrap:wrap;gap:8px;transition:background var(--tr)}
.logo{font-size:15px;font-weight:500;color:var(--txt);cursor:pointer}
.logo b{color:var(--gold)}
.nav-links{display:flex;gap:2px;flex-wrap:wrap}
.nl{padding:6px 11px;border-radius:20px;font-size:12px;color:var(--muted);cursor:pointer;transition:all .15s;border:1px solid transparent}
.nl:hover{color:var(--txt)}
.nl.active{color:var(--g2);border-color:rgba(0,230,118,0.25);background:rgba(0,230,118,0.07)}
.nav-right{display:flex;align-items:center;gap:8px}
.theme-btn{background:transparent;border:1px solid var(--bdr);color:var(--muted);width:32px;height:32px;border-radius:50%;cursor:pointer;font-size:14px;display:flex;align-items:center;justify-content:center;transition:all .15s}
.theme-btn:hover{border-color:var(--g);color:var(--g2)}
.nb{background:var(--g);color:#000;padding:7px 15px;border-radius:18px;font-size:12px;font-weight:500;cursor:pointer;border:none}

/* ── FLOATING WHATSAPP ── */
.wa-float{position:fixed;bottom:20px;right:20px;z-index:999;width:52px;height:52px;border-radius:50%;background:#25d366;display:flex;align-items:center;justify-content:center;cursor:pointer;box-shadow:0 4px 16px rgba(37,211,102,0.4);transition:transform .2s}
.wa-float:hover{transform:scale(1.1)}
.wa-float svg{width:26px;height:26px}
.wa-tooltip{position:absolute;right:60px;top:50%;transform:translateY(-50%);background:var(--card);border:1px solid var(--bdr);color:var(--txt);padding:6px 12px;border-radius:20px;font-size:12px;white-space:nowrap;opacity:0;pointer-events:none;transition:opacity .2s}
.wa-float:hover .wa-tooltip{opacity:1}

/* ── HERO ── */
.hero{background:linear-gradient(135deg,#050d05 0%,#0a1f0a 40%,#060d18 100%);padding:2.5rem 2rem 2rem;text-align:center;border-bottom:1px solid var(--bdr)}
[data-theme="light"] .hero{background:linear-gradient(135deg,#e8f5e9,#f1f8e9,#e3f2fd)}
.hero-badge{display:inline-block;background:rgba(0,200,83,0.12);border:1px solid rgba(0,200,83,0.3);color:var(--g2);font-size:10px;padding:4px 14px;border-radius:20px;margin-bottom:.8rem;letter-spacing:2px;text-transform:uppercase}
.hero h1{font-size:2.4rem;font-weight:500;color:#fff;line-height:1.15;margin-bottom:.5rem}
[data-theme="light"] .hero h1{color:#1a2e1a}
.hero h1 b{color:var(--g2)}
.hero p{font-size:13px;color:rgba(255,255,255,0.6);margin-bottom:1.5rem}
[data-theme="light"] .hero p{color:var(--muted)}
.hbtns{display:flex;gap:10px;justify-content:center;flex-wrap:wrap;margin-bottom:1.8rem}
.btn-g{background:var(--g);color:#000;padding:11px 24px;border-radius:22px;font-size:14px;font-weight:500;border:none;cursor:pointer;transition:all .15s}
.btn-g:hover{background:var(--g2)}
.btn-o{background:transparent;color:var(--g2);border:1.5px solid rgba(0,200,83,0.4);padding:11px 20px;border-radius:22px;font-size:14px;cursor:pointer}
.hstats{display:flex;gap:0;justify-content:center;border:1px solid var(--bdr);border-radius:12px;overflow:hidden;max-width:460px;margin:0 auto}
.hs{flex:1;padding:.85rem;text-align:center;border-right:1px solid var(--bdr);background:rgba(0,0,0,0.2)}
[data-theme="light"] .hs{background:rgba(255,255,255,0.6)}
.hs:last-child{border:none}
.hs-n{font-size:1.2rem;font-weight:500;color:var(--g2)}
.hs-l{font-size:10px;color:var(--muted);margin-top:2px}

/* ── SOCIAL BAR ── */
.social-bar{display:flex;align-items:center;justify-content:center;gap:10px;padding:.9rem;border-bottom:1px solid var(--bdr);background:rgba(0,0,0,0.2);flex-wrap:wrap}
[data-theme="light"] .social-bar{background:rgba(0,0,0,0.03)}
.soc-btn{display:flex;align-items:center;gap:6px;padding:7px 14px;border-radius:18px;font-size:12px;font-weight:500;cursor:pointer;text-decoration:none;transition:all .15s;border:1px solid transparent}
.soc-fb{background:rgba(24,119,242,0.12);border-color:rgba(24,119,242,0.25);color:#90b8f8}
.soc-ig{background:rgba(225,48,108,0.1);border-color:rgba(225,48,108,0.25);color:#f48fb1}
.soc-wa{background:rgba(37,211,102,0.1);border-color:rgba(37,211,102,0.25);color:#69f0ae}

/* ── PRICE BANNER ── */
.price-banner{background:var(--card);border:1px solid var(--bdr);border-radius:12px;margin:1.2rem;overflow:hidden;transition:background var(--tr)}
.pb-title{font-size:11px;color:var(--muted);letter-spacing:.5px;text-transform:uppercase;padding:.7rem 1rem .4rem}
.pb-grid{display:grid;grid-template-columns:repeat(4,1fr)}
.pb-item{padding:.8rem .5rem;text-align:center;border-right:1px solid var(--bdr)}
.pb-item:last-child{border:none}
.pb-time{font-size:10px;color:var(--muted);margin-bottom:3px}
.pb-price{font-size:1rem;font-weight:500;color:var(--g2)}
.pb-tag{font-size:9px;padding:2px 7px;border-radius:10px;margin-top:3px;display:inline-block}
.tag-night{background:rgba(83,66,177,0.2);color:#b39ddb}
.tag-early{background:rgba(21,101,192,0.18);color:#90caf9}
.tag-day{background:rgba(46,125,50,0.15);color:#a5d6a7}
.tag-eve{background:rgba(230,81,0,0.15);color:#ffcc80}

/* ── LIVE SLOTS ── */
.live-slots-block{margin:1rem 1.2rem;border-radius:14px;border:1px solid var(--bdr);overflow:hidden;background:var(--card)}
.live-slots-header{padding:.8rem 1rem;border-bottom:1px solid var(--bdr);display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:6px}
.live-slots-title{font-size:13px;font-weight:600;color:var(--txt)}
.next-game-timer{font-size:11px;color:var(--g2);font-weight:500;letter-spacing:.3px}
.live-date-tabs{display:flex;gap:6px;padding:.7rem 1rem;border-bottom:1px solid var(--bdr)}
.live-date-tab{padding:4px 12px;border-radius:20px;font-size:11px;cursor:pointer;border:1px solid var(--bdr);color:var(--muted);transition:.2s}
.live-date-tab.on{background:var(--g2);color:#000;border-color:var(--g2);font-weight:600}
.live-slots-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(90px,1fr));gap:8px;padding:.8rem 1rem}
.ls{border-radius:10px;padding:8px 6px;text-align:center;cursor:pointer;border:1px solid var(--bdr);transition:.2s;font-size:11px}
.ls.avail{background:rgba(0,200,83,0.08);border-color:rgba(0,200,83,0.3);color:var(--txt)}
.ls.avail:hover{background:rgba(0,200,83,0.18);transform:translateY(-1px)}
.ls.booked{background:rgba(255,255,255,0.03);border-color:var(--bdr);color:var(--muted);cursor:default;opacity:.55}
.ls-time{font-weight:600;font-size:12px;margin-bottom:2px}
.ls-status{font-size:9px;text-transform:uppercase;letter-spacing:.5px}
.ls.avail .ls-status{color:var(--g2)}
.ls.booked .ls-status{color:var(--muted)}

/* ── GALLERY ── */
.gallery{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;padding:1.2rem;padding-top:0}
.gal-item{border-radius:10px;overflow:hidden;aspect-ratio:4/3;cursor:pointer;position:relative;transition:transform .2s}
.gal-item:hover{transform:scale(1.02)}
.gal-img{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:2.5rem;border:1px solid var(--bdr)}
.g1{background:linear-gradient(135deg,#0a2a0a,#1a4a1a)}
.g2{background:linear-gradient(135deg,#0a1a2a,#1a3a4a)}
.g3{background:linear-gradient(135deg,#1a1a0a,#3a3a1a)}
.g4{background:linear-gradient(135deg,#2a0a0a,#4a1a1a)}
.g5{background:linear-gradient(135deg,#0a2a2a,#1a4a4a)}
.g6{background:linear-gradient(135deg,#1a0a2a,#3a1a4a)}
.gal-label{position:absolute;bottom:0;left:0;right:0;background:linear-gradient(transparent,rgba(0,0,0,0.7));padding:.5rem;font-size:11px;color:#fff}

/* ── LIGHTBOX ── */
.lightbox{position:fixed;inset:0;background:rgba(0,0,0,0.9);z-index:999;display:none;align-items:center;justify-content:center;flex-direction:column;gap:12px}
.lightbox.open{display:flex}
.lb-img{width:320px;height:240px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:4rem}
.lb-close{color:#fff;font-size:24px;cursor:pointer;position:absolute;top:16px;right:20px;background:rgba(255,255,255,0.1);width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center}

/* ── FEATURES ── */
.features{display:grid;grid-template-columns:repeat(auto-fit,minmax(170px,1fr));gap:10px;padding:1.2rem}
.feat{background:var(--card);border:1px solid var(--bdr);border-radius:12px;padding:1rem;transition:background var(--tr)}
.feat-icon{font-size:1.2rem;margin-bottom:.4rem}
.feat h3{font-size:13px;font-weight:500;color:var(--txt);margin-bottom:.25rem}
.feat p{font-size:11px;color:var(--muted);line-height:1.5}

/* ── REVIEWS ── */
.reviews-section{padding:1.2rem;padding-top:0}
.reviews-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.8rem}
.reviews-header h3{font-size:14px;font-weight:500;color:var(--txt)}
.overall-rating{display:flex;align-items:center;gap:8px}
.big-star{font-size:1.6rem;font-weight:500;color:var(--gold)}
.stars{color:var(--gold);font-size:14px}
.review-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:10px;margin-bottom:.8rem}
.review-card{background:var(--card);border:1px solid var(--bdr);border-radius:10px;padding:.9rem;transition:background var(--tr)}
.rev-top{display:flex;align-items:center;gap:8px;margin-bottom:.5rem}
.rev-av{width:30px;height:30px;border-radius:50%;background:rgba(0,200,83,0.2);display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:500;color:var(--g2);flex-shrink:0}
.rev-name{font-size:13px;font-weight:500;color:var(--txt)}
.rev-time{font-size:10px;color:var(--muted)}
.rev-text{font-size:12px;color:var(--muted);line-height:1.5}
.add-review-btn{width:100%;padding:10px;border:1.5px dashed var(--bdr);border-radius:10px;background:transparent;color:var(--muted);font-size:13px;cursor:pointer;transition:all .15s}
.add-review-btn:hover{border-color:var(--g);color:var(--g2)}
.review-form{background:var(--card);border:1px solid var(--bdr);border-radius:10px;padding:1rem;margin-top:.8rem;display:none;transition:background var(--tr)}
.star-picker{display:flex;gap:4px;margin-bottom:.6rem}
.sp{font-size:22px;cursor:pointer;opacity:.4;transition:opacity .15s}
.sp.on{opacity:1}

/* ── FOOTER ── */
.footer{background:rgba(0,0,0,0.3);border-top:1px solid var(--bdr);padding:1.2rem;text-align:center}
[data-theme="light"] .footer{background:rgba(0,0,0,0.04)}
.footer-links{display:flex;justify-content:center;gap:16px;margin-bottom:.6rem;flex-wrap:wrap}
.footer-links a{font-size:12px;color:var(--muted);text-decoration:none}
.footer-links a:hover{color:var(--g2)}
.footer p{font-size:11px;color:var(--muted)}

/* ── SHARED / FORM ── */
.pi{padding:1.5rem}
.sec-h{font-size:1.1rem;font-weight:500;color:var(--txt);margin-bottom:1.1rem}
.bwrap{background:var(--card);border:1px solid var(--bdr);border-radius:12px;padding:1.3rem;margin-bottom:1.1rem;transition:background var(--tr)}
.row2{display:grid;grid-template-columns:1fr 1fr;gap:11px;margin-bottom:11px}
.fg{display:flex;flex-direction:column;gap:4px}
.fg label{font-size:11px;color:var(--muted)}
.fg input,.fg select,.fg textarea{background:var(--dk);border:1px solid var(--bdr);color:var(--txt);padding:9px 12px;border-radius:8px;font-size:13px;transition:all .15s}
.fg input:focus,.fg select:focus,.fg textarea:focus{outline:none;border-color:var(--g)}
.wa-badge{background:rgba(37,211,102,0.12);color:#69f0ae;font-size:10px;padding:2px 7px;border-radius:10px;border:1px solid rgba(37,211,102,0.25);margin-left:4px}
.wa-hint{font-size:10px;color:#69f0ae;margin-top:3px}
.dur-row{display:flex;align-items:center;gap:9px;margin-bottom:.9rem;flex-wrap:wrap}
.dur-row span{font-size:12px;color:var(--muted)}
.dbtns{display:flex;gap:6px;flex-wrap:wrap}
.db{padding:5px 12px;border-radius:15px;border:1.5px solid var(--bdr);background:transparent;color:var(--muted);font-size:12px;cursor:pointer;transition:all .15s}
.db.on{border-color:var(--g);color:var(--g2);background:rgba(0,200,83,0.08)}
.stitle{font-size:10px;color:var(--muted);letter-spacing:.5px;margin-bottom:.5rem;text-transform:uppercase}
.sgrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(78px,1fr));gap:6px;margin-bottom:.9rem}
.sl{padding:7px 3px;text-align:center;border-radius:8px;font-size:11px;cursor:pointer;border:1.5px solid var(--bdr);color:var(--muted);transition:all .15s;line-height:1.4}
.sl .slp{font-size:9px;display:block;margin-top:1px}
.sl.ok:hover{border-color:var(--g);color:var(--g2)}
.sl.ok.sel{background:var(--g);color:#000;border-color:var(--g);font-weight:500}
.sl.ok.sel .slp{color:#000}
.sl.no{background:rgba(229,57,53,0.06);border-color:rgba(229,57,53,0.15);color:rgba(229,57,53,0.4);cursor:not-allowed}
.sl.blk{background:rgba(100,100,100,0.08);border-color:rgba(100,100,100,0.15);color:rgba(150,150,150,0.3);cursor:not-allowed}
.total-b{display:flex;justify-content:space-between;align-items:center;padding:12px 15px;background:rgba(0,200,83,0.06);border:1px solid rgba(0,200,83,0.18);border-radius:10px;margin-bottom:.9rem}
.total-b span{font-size:12px;color:var(--muted)}
.total-b strong{font-size:1.2rem;color:var(--g2)}
.cbtn{width:100%;padding:12px;background:var(--g);color:#000;border:none;border-radius:10px;font-size:14px;font-weight:500;cursor:pointer;transition:all .15s}
.cbtn:hover{background:var(--g2)}
.cbtn:disabled{opacity:.5;cursor:not-allowed}
.sbox{background:rgba(0,200,83,0.06);border:1px solid var(--g);border-radius:10px;padding:1.1rem;text-align:center;display:none;margin-top:.9rem}
.sbox h3{color:var(--g2);font-size:14px;font-weight:500}
.sbox p{color:var(--muted);font-size:12px;margin-top:4px;line-height:1.5}
.wa-confirm a{display:inline-flex;align-items:center;gap:6px;background:rgba(37,211,102,0.12);border:1px solid rgba(37,211,102,0.25);color:#69f0ae;padding:7px 14px;border-radius:18px;font-size:12px;text-decoration:none;margin-top:.7rem}

/* ── AUTH MODAL ── */
.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,0.7);z-index:500;display:none;align-items:center;justify-content:center;padding:1rem}
.modal-overlay.open{display:flex}
.modal-box{background:var(--card);border:1px solid var(--bdr);border-radius:16px;padding:1.8rem;width:100%;max-width:360px}
.modal-box h3{font-size:16px;font-weight:500;color:var(--txt);margin-bottom:.3rem}
.modal-box p{font-size:12px;color:var(--muted);margin-bottom:1.2rem}
.modal-tabs{display:flex;gap:6px;margin-bottom:1.2rem}
.mtab{flex:1;padding:8px;border-radius:8px;border:1px solid var(--bdr);background:transparent;color:var(--muted);font-size:13px;cursor:pointer;transition:all .15s}
.mtab.on{background:var(--g);color:#000;border-color:var(--g);font-weight:500}
.auth-err{color:#ef5350;font-size:11px;margin-top:6px;display:none}
.auth-success{color:var(--g2);font-size:11px;margin-top:6px;display:none}
.user-chip{display:flex;align-items:center;gap:6px;background:rgba(0,200,83,0.08);border:1px solid rgba(0,200,83,0.2);border-radius:18px;padding:5px 12px;font-size:12px;color:var(--g2);cursor:pointer;user-select:none;transition:background .2s}
.user-chip:hover{background:rgba(0,200,83,0.16)}
.user-chip span{max-width:120px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.ud-arrow{font-size:10px;color:var(--muted);transition:transform .2s}
#nav-auth-area{position:relative}
.user-dropdown{display:none;position:absolute;right:0;top:calc(100% + 8px);min-width:210px;background:var(--card);border:1px solid var(--bdr);border-radius:14px;box-shadow:0 8px 30px rgba(0,0,0,0.3);z-index:9999;overflow:hidden;animation:ddFadeIn .15s ease}
.user-dropdown.open{display:block}
@keyframes ddFadeIn{from{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}
.ud-header{display:flex;align-items:center;gap:10px;padding:14px 16px 10px}
.ud-avatar{width:36px;height:36px;border-radius:50%;background:var(--g);color:#000;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:16px;flex-shrink:0}
.ud-name{font-size:13px;font-weight:600;color:var(--txt)}
.ud-phone{font-size:11px;color:var(--muted);margin-top:2px}
.ud-divider{height:1px;background:var(--bdr);margin:2px 0}
.ud-item{padding:11px 16px;font-size:13px;color:var(--txt);cursor:pointer;display:flex;align-items:center;gap:8px;transition:background .15s}
.ud-item:hover{background:rgba(255,255,255,0.05)}
[data-theme="light"] .ud-item:hover{background:rgba(0,0,0,0.04)}
.ud-logout{color:#ef5350}
.ud-logout:hover{background:rgba(239,83,80,0.08) !important}

/* ── BOOKING HISTORY ── */
.hist-wrap{background:var(--card);border:1px solid var(--bdr);border-radius:12px;padding:1.3rem;margin-top:1.1rem;transition:background var(--tr)}
.hist-search{display:flex;gap:8px;margin-bottom:.9rem}
.hist-search input{flex:1;background:var(--dk);border:1px solid var(--bdr);color:var(--txt);padding:8px 12px;border-radius:8px;font-size:13px}
.hist-search button{padding:8px 16px;background:var(--g);color:#000;border:none;border-radius:8px;font-size:13px;cursor:pointer}
.hist-item{background:var(--dk);border:1px solid var(--bdr);border-radius:8px;padding:.8rem;margin-bottom:.6rem;transition:background var(--tr)}
.hist-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:.3rem}
.hist-name{font-size:13px;font-weight:500;color:var(--txt)}
.hist-date{font-size:11px;color:var(--muted)}
.hist-detail{font-size:11px;color:var(--muted)}
.hist-empty{text-align:center;color:var(--muted);font-size:13px;padding:1rem}

/* ── FAQ ── */
.faq-item{border-bottom:1px solid var(--bdr);padding:.8rem 0}
.faq-item:last-child{border:none}
.faq-q{display:flex;justify-content:space-between;align-items:center;cursor:pointer;font-size:13px;font-weight:500;color:var(--txt)}
.faq-icon{color:var(--g2);font-size:16px;transition:transform .2s;flex-shrink:0}
.faq-icon.open{transform:rotate(45deg)}
.faq-a{font-size:12px;color:var(--muted);line-height:1.6;max-height:0;overflow:hidden;transition:max-height .3s ease,padding .2s}
.faq-a.open{max-height:200px;padding-top:.5rem}

/* ── CANCEL POLICY ── */
.policy-box{background:var(--card);border:1px solid var(--bdr);border-radius:12px;padding:1.3rem;margin-bottom:1.1rem;transition:background var(--tr)}
.policy-row{display:flex;align-items:flex-start;gap:10px;padding:.6rem 0;border-bottom:.5px solid var(--bdr)}
.policy-row:last-child{border:none}
.policy-icon{width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:13px;flex-shrink:0;margin-top:1px}
.pi-g{background:rgba(0,200,83,0.15);color:var(--g2)}
.pi-r{background:rgba(229,57,53,0.12);color:#ef5350}
.policy-txt h4{font-size:13px;font-weight:500;color:var(--txt);margin-bottom:2px}
.policy-txt p{font-size:11px;color:var(--muted);line-height:1.5}

/* ── PRICING PAGE ── */
.price-sections{display:flex;flex-direction:column;gap:1rem}
.ps{background:var(--card);border:1px solid var(--bdr);border-radius:12px;overflow:hidden;transition:background var(--tr)}
.ps-head{display:flex;align-items:center;justify-content:space-between;padding:.9rem 1.1rem;border-bottom:1px solid var(--bdr)}
.ps-head h3{font-size:14px;font-weight:500;color:var(--txt)}
.ps-time{font-size:11px;color:var(--muted)}
.ps-price{font-size:1.3rem;font-weight:500;color:var(--g2);padding:.9rem 1.1rem;border-bottom:1px solid var(--bdr)}
.ps-price span{font-size:11px;color:var(--muted);font-weight:400}
.ps-features{list-style:none;padding:.65rem 1.1rem}
.ps-features li{font-size:12px;color:var(--muted);padding:3px 0;border-bottom:.5px solid var(--bdr)}
.ps-features li:last-child{border:none}
.ps-features li::before{content:"+ ";color:var(--g)}
.ps-book{width:calc(100% - 2.2rem);margin:0 1.1rem .9rem;padding:8px;border-radius:8px;border:1.5px solid var(--g);background:transparent;color:var(--g2);font-size:12px;cursor:pointer;transition:all .15s}
.ps-book:hover{background:var(--g);color:#000}

/* ── CHAT ── */
.cwrap{background:var(--card);border:1px solid var(--bdr);border-radius:12px;overflow:hidden;transition:background var(--tr)}
.ch{display:flex;align-items:center;gap:9px;padding:12px 14px;background:rgba(0,200,83,0.06);border-bottom:1px solid var(--bdr)}
.av{width:30px;height:30px;border-radius:50%;background:var(--g);display:flex;align-items:center;justify-content:center;font-size:11px;color:#000;font-weight:500;flex-shrink:0}
.cn{font-size:13px;font-weight:500;color:var(--txt)}
.cs{font-size:10px;color:var(--g2)}
.od{width:5px;height:5px;border-radius:50%;background:var(--g2);display:inline-block;margin-right:3px;animation:blink 2s infinite}
@keyframes blink{0%,100%{opacity:1}50%{opacity:.3}}
.cchips{display:flex;gap:5px;flex-wrap:wrap;padding:8px 12px;border-bottom:1px solid var(--bdr)}
.cc{padding:3px 10px;border-radius:13px;border:1px solid var(--bdr);font-size:11px;color:var(--muted);cursor:pointer;transition:all .15s}
.cc:hover{border-color:var(--g);color:var(--g2)}
.msgs{padding:12px;min-height:160px;max-height:220px;overflow-y:auto;display:flex;flex-direction:column;gap:8px}
.msg{padding:8px 12px;border-radius:12px;font-size:12px;max-width:88%;line-height:1.6}
.msg.b{background:rgba(0,200,83,0.06);color:var(--txt);align-self:flex-start;border:1px solid var(--bdr)}
.msg.u{background:var(--g);color:#000;align-self:flex-end}
.cin{display:flex;gap:7px;padding:10px;border-top:1px solid var(--bdr)}
.cin input{flex:1;background:var(--dk);border:1px solid var(--bdr);color:var(--txt);padding:8px 12px;border-radius:17px;font-size:12px}
.cin input:focus{outline:none;border-color:var(--g)}
.sbtn{background:var(--g);color:#000;border:none;border-radius:50%;width:32px;height:32px;cursor:pointer;font-size:12px;flex-shrink:0;display:flex;align-items:center;justify-content:center}
.dot{width:5px;height:5px;border-radius:50%;background:var(--muted);animation:bounce .9s infinite;display:inline-block;margin:0 2px}
.dot:nth-child(2){animation-delay:.15s}
.dot:nth-child(3){animation-delay:.3s}
@keyframes bounce{0%,60%,100%{transform:translateY(0)}30%{transform:translateY(-5px)}}

/* ── ADMIN PANELS ── */
.login-wrap{max-width:340px;margin:0 auto;background:var(--card);border:1px solid var(--bdr);border-radius:12px;padding:1.6rem;transition:background var(--tr)}
.login-wrap h3{font-size:15px;font-weight:500;color:var(--txt);margin-bottom:.3rem;text-align:center}
.login-wrap p{font-size:11px;color:var(--muted);text-align:center;margin-bottom:1rem}
.apanel{display:none}
.apanel.show{display:block}
.role-badge{display:inline-flex;align-items:center;gap:5px;padding:3px 11px;border-radius:18px;font-size:11px;margin-bottom:.9rem}
.role-badge.mgr{background:rgba(21,101,192,0.12);border:1px solid rgba(21,101,192,0.25);color:#90caf9}
.role-badge.sa{background:rgba(213,0,0,0.1);border:1px solid rgba(213,0,0,0.25);color:#ef9a9a}
.scards{display:grid;grid-template-columns:repeat(auto-fit,minmax(95px,1fr));gap:8px;margin-bottom:1.1rem}
.sc{background:var(--card);border:1px solid var(--bdr);border-radius:10px;padding:.75rem;text-align:center;transition:background var(--tr)}
.sc-n{font-size:1.1rem;font-weight:500;color:var(--g2)}
.sc-l{font-size:10px;color:var(--muted);margin-top:2px}
.atabs{display:flex;gap:6px;margin-bottom:1.1rem;flex-wrap:wrap}
.at{padding:5px 12px;border-radius:15px;border:1px solid var(--bdr);font-size:12px;color:var(--muted);cursor:pointer;transition:all .15s}
.at.on{background:var(--g);color:#000;border-color:var(--g);font-weight:500}
.btable{width:100%;border-collapse:collapse;font-size:12px}
.btable th{text-align:left;padding:6px 8px;font-size:10px;color:var(--muted);border-bottom:1px solid var(--bdr);font-weight:500;text-transform:uppercase}
.btable td{padding:8px;border-bottom:.5px solid var(--bdr);color:var(--txt)}
.bdg{display:inline-block;padding:2px 7px;border-radius:10px;font-size:10px}
.bdg.cf{background:rgba(0,200,83,0.1);color:var(--g2)}
.bdg.pd{background:rgba(255,214,0,0.1);color:#ffd600}
.bdg.cx{background:rgba(229,57,53,0.1);color:#ef5350}
.abtn{padding:2px 8px;border-radius:6px;border:1px solid var(--bdr);background:transparent;color:var(--muted);font-size:10px;cursor:pointer;margin:1px;transition:all .15s}
.abtn:hover{border-color:var(--g);color:var(--g2)}
.abtn.del:hover{border-color:#ef5350;color:#ef5350}
.abtn.wa{background:rgba(37,211,102,0.12);border-color:rgba(37,211,102,0.3);color:#69f0ae}
.abtn.wa:hover{background:rgba(37,211,102,0.22);border-color:#25d366;color:#a5f3c1}
.info-box{background:rgba(0,200,83,0.05);border:1px solid rgba(0,200,83,0.15);border-radius:8px;padding:9px 12px;font-size:11px;color:var(--muted);margin-bottom:.9rem;line-height:1.5}
.block-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(76px,1fr));gap:5px;margin-top:.6rem}
.blk-sl{padding:7px 3px;text-align:center;border-radius:8px;font-size:11px;cursor:pointer;border:1.5px solid var(--bdr);color:var(--muted);transition:all .15s;line-height:1.3}
.blk-sl .blkp{font-size:9px;display:block;color:var(--muted)}
.blk-sl.blocked{background:rgba(229,57,53,0.08);border-color:rgba(229,57,53,0.3);color:#ef9a9a}
.blk-sl.bkd{opacity:.45;cursor:not-allowed}
.blk-sl:not(.blocked):not(.bkd):hover{border-color:#ef5350;color:#ef9a9a}
.srow{display:flex;justify-content:space-between;align-items:center;padding:9px 0;border-bottom:.5px solid var(--bdr)}
.srow:last-child{border:none}
.srow label{font-size:12px;color:var(--txt)}
.srow input,.srow select{background:var(--dk);border:1px solid var(--bdr);color:var(--txt);padding:6px 10px;border-radius:7px;font-size:12px;width:110px}
.savebtn{padding:7px 18px;background:var(--g);color:#000;border:none;border-radius:8px;font-size:12px;font-weight:500;cursor:pointer;margin-top:.8rem}
.price-override{background:var(--card);border:1px solid rgba(255,214,0,0.18);border-radius:10px;padding:.9rem;margin-top:.9rem;transition:background var(--tr)}
.price-override h4{font-size:12px;color:#ffd600;font-weight:500;margin-bottom:.7rem}
.ov-item{display:flex;justify-content:space-between;align-items:center;padding:4px 0;border-bottom:.5px solid var(--bdr);font-size:11px}

/* ── REVENUE CHART ── */
.rev-section{background:var(--card);border:1px solid var(--bdr);border-radius:12px;padding:1.1rem;margin-bottom:1.1rem;transition:background var(--tr)}
.rev-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.8rem;flex-wrap:wrap;gap:8px}
.rev-header h4{font-size:13px;font-weight:500;color:var(--txt)}
.rev-filter{display:flex;gap:5px}
.rf{padding:4px 10px;border-radius:13px;border:1px solid var(--bdr);font-size:11px;color:var(--muted);cursor:pointer;transition:all .15s}
.rf.on{background:var(--g);color:#000;border-color:var(--g)}
.chart-wrap{position:relative;height:160px;width:100%;overflow-x:auto}
.bar-chart{display:flex;align-items:flex-end;gap:4px;height:130px;padding-bottom:20px;min-width:280px}
.bar-col{display:flex;flex-direction:column;align-items:center;flex:1;gap:3px;position:relative;min-width:22px}
.bar{width:100%;border-radius:4px 4px 0 0;background:var(--g);transition:height .4s ease;min-height:2px;opacity:.85;cursor:pointer;min-width:14px}
.bar:hover{opacity:1}
.bar-lbl{font-size:9px;color:var(--muted);position:absolute;bottom:0}
.bar-val{font-size:9px;color:var(--g2);position:absolute;top:-14px}

/* ── CALENDAR ── */
.cal-wrap{background:var(--card);border:1px solid var(--bdr);border-radius:12px;padding:1.1rem;transition:background var(--tr)}
.cal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.8rem}
.cal-header h4{font-size:13px;font-weight:500;color:var(--txt)}
.cal-nav{display:flex;gap:6px}
.cn-btn{padding:4px 10px;border-radius:8px;border:1px solid var(--bdr);background:transparent;color:var(--muted);font-size:12px;cursor:pointer;transition:all .15s}
.cn-btn:hover{border-color:var(--g);color:var(--g2)}
.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:3px}
.cal-dh{text-align:center;font-size:10px;color:var(--muted);padding:4px 0}
.cal-d{text-align:center;padding:6px 2px;border-radius:6px;font-size:11px;cursor:pointer;border:1px solid transparent;transition:all .15s;position:relative}
.cal-d.avail{background:rgba(0,200,83,0.1);color:var(--g2);border-color:rgba(0,200,83,0.15)}
.cal-d.busy{background:rgba(229,57,53,0.08);color:#ef9a9a;border-color:rgba(229,57,53,0.12)}
.cal-d.full{background:rgba(229,57,53,0.15);color:#ef5350;border-color:rgba(229,57,53,0.2)}
.cal-d.today{border-color:var(--g)!important;font-weight:500}
.cal-d.empty{background:transparent;cursor:default}
.cal-d:not(.empty):hover{transform:scale(1.08)}
.cal-legend{display:flex;gap:12px;margin-top:.7rem;flex-wrap:wrap}
.cl{display:flex;align-items:center;gap:4px;font-size:10px;color:var(--muted)}
.cl-dot{width:8px;height:8px;border-radius:2px}

/* ── LOADING SPINNER ── */
.spin{display:inline-block;width:14px;height:14px;border:2px solid rgba(0,200,83,0.3);border-top-color:var(--g);border-radius:50%;animation:spin .6s linear infinite;vertical-align:middle;margin-right:6px}
@keyframes spin{to{transform:rotate(360deg)}}

/* ── HAMBURGER / MOBILE NAV ── */
.hamburger{display:none;background:transparent;border:1px solid var(--bdr);color:var(--txt);width:40px;height:40px;border-radius:10px;cursor:pointer;align-items:center;justify-content:center;flex-shrink:0;transition:border-color .15s}
.hamburger:hover{border-color:var(--g);color:var(--g2)}
.hamburger svg{width:20px;height:20px}
.nav-backdrop{display:none;position:fixed;inset:0;background:rgba(0,0,0,0.55);z-index:198}
.nav-backdrop.open{display:block}

/* ── RESPONSIVE DESKTOP ── */
@media(min-width:769px){
  .sgrid{grid-template-columns:repeat(5,1fr)}
  .block-grid{grid-template-columns:repeat(6,1fr)}
}
#mgr-bookings,#sa-bookings{overflow-x:auto;max-width:100%}
#mgr-bookings .btable,#sa-bookings .btable{min-width:640px}

/* ── RESPONSIVE MOBILE ── */
@media(max-width:480px){
  html,body{font-size:14px}
  nav{padding:10px 14px;flex-wrap:nowrap}
  .hamburger{display:flex;order:0}
  .nav-links{position:fixed;top:0;left:-100%;width:78%;max-width:300px;height:100vh;background:var(--card);border-right:1px solid var(--bdr);flex-direction:column;flex-wrap:nowrap;gap:6px;padding:64px 16px 24px;z-index:199;overflow-y:auto;transition:left .25s ease;box-shadow:2px 0 22px rgba(0,0,0,0.4)}
  .nav-links.open{left:0}
  .nl{width:100%;font-size:14px;padding:13px 16px;min-height:48px;border-radius:10px;display:flex;align-items:center;border:1px solid transparent}
  .nav-right{gap:6px;flex-shrink:0;margin-left:auto}
  .nb{min-height:40px;padding:9px 14px;font-size:13px}
  .hero{padding:1.6rem 1.1rem 1.4rem}
  .hero h1{font-size:clamp(1.6rem,7.2vw,1.95rem);line-height:1.18}
  .hstats{max-width:100%}
  .hs{flex:1;padding:.7rem .25rem}
  .hs-n{font-size:clamp(.9rem,3.6vw,1.1rem)}
  .price-banner{margin:1rem .8rem}
  .pb-grid{grid-template-columns:repeat(2,1fr)}
  .gallery{grid-template-columns:repeat(2,1fr);padding:.9rem .8rem}
  .review-grid{grid-template-columns:1fr}
  .features{grid-template-columns:1fr;padding:.9rem .8rem}
  .pi{padding:1.05rem .8rem}
  .row2{grid-template-columns:1fr}
  .sgrid{grid-template-columns:repeat(3,1fr)}
  .sl{font-size:13px;padding:10px 4px;min-height:54px}
  .cbtn,.savebtn{min-height:46px;font-size:14px}
  .block-grid{grid-template-columns:repeat(3,1fr)}
  .scards{grid-template-columns:repeat(2,1fr)}
  .wa-float{width:48px;height:48px;bottom:16px;right:16px}
  .wa-tooltip{display:none}
}
