/* ═══════════════════════════════════════════════════════════
   FONTS — self-hosted (offline-ready)
   Menggantikan Google Fonts CDN link di index.html
   ═══════════════════════════════════════════════════════════ */

/* ── CINZEL ── */
@font-face {
  font-family: 'Cinzel';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url('fonts/cinzel-latin-400-normal.woff2') format('woff2'),
       url('fonts/cinzel-latin-400-normal.woff') format('woff');
}
@font-face {
  font-family: 'Cinzel';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url('fonts/cinzel-latin-600-normal.woff2') format('woff2'),
       url('fonts/cinzel-latin-600-normal.woff') format('woff');
}
@font-face {
  font-family: 'Cinzel';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url('fonts/cinzel-latin-700-normal.woff2') format('woff2'),
       url('fonts/cinzel-latin-700-normal.woff') format('woff');
}
@font-face {
  font-family: 'Cinzel';
  font-style: normal;
  font-weight: 900;
  font-display: swap;
  src: url('fonts/cinzel-latin-900-normal.woff2') format('woff2'),
       url('fonts/cinzel-latin-900-normal.woff') format('woff');
}

/* ── CORMORANT GARAMOND ── */
@font-face {
  font-family: 'Cormorant Garamond';
  font-style: normal;
  font-weight: 300;
  font-display: swap;
  src: url('fonts/cormorant-garamond-latin-300-normal.woff2') format('woff2'),
       url('fonts/cormorant-garamond-latin-300-normal.woff') format('woff');
}
@font-face {
  font-family: 'Cormorant Garamond';
  font-style: italic;
  font-weight: 300;
  font-display: swap;
  src: url('fonts/cormorant-garamond-latin-300-italic.woff2') format('woff2'),
       url('fonts/cormorant-garamond-latin-300-italic.woff') format('woff');
}
@font-face {
  font-family: 'Cormorant Garamond';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url('fonts/cormorant-garamond-latin-400-normal.woff2') format('woff2'),
       url('fonts/cormorant-garamond-latin-400-normal.woff') format('woff');
}
@font-face {
  font-family: 'Cormorant Garamond';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url('fonts/cormorant-garamond-latin-600-normal.woff2') format('woff2'),
       url('fonts/cormorant-garamond-latin-600-normal.woff') format('woff');
}

/* ── RALEWAY ── */
@font-face {
  font-family: 'Raleway';
  font-style: normal;
  font-weight: 300;
  font-display: swap;
  src: url('fonts/raleway-latin-300-normal.woff2') format('woff2'),
       url('fonts/raleway-latin-300-normal.woff') format('woff');
}
@font-face {
  font-family: 'Raleway';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url('fonts/raleway-latin-400-normal.woff2') format('woff2'),
       url('fonts/raleway-latin-400-normal.woff') format('woff');
}
@font-face {
  font-family: 'Raleway';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url('fonts/raleway-latin-500-normal.woff2') format('woff2'),
       url('fonts/raleway-latin-500-normal.woff') format('woff');
}
@font-face {
  font-family: 'Raleway';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url('fonts/raleway-latin-600-normal.woff2') format('woff2'),
       url('fonts/raleway-latin-600-normal.woff') format('woff');
}
@font-face {
  font-family: 'Raleway';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url('fonts/raleway-latin-700-normal.woff2') format('woff2'),
       url('fonts/raleway-latin-700-normal.woff') format('woff');
}

:root{
  --bg:#080808;--bg2:#0e0e0e;--bg3:#161616;--bg4:#1e1e1e;
  --gold:#c9a84c;--gold2:#f0d080;--gold3:#8b6914;--gold4:#6b4f0e;
  --gold-glow:rgba(201,168,76,0.2);--gold-glow2:rgba(201,168,76,0.08);
  --text:#e8dcc8;--text2:#c8bca8;--muted:#666;--muted2:#444;
  --red:#c0392b;--red2:#e74c3c;--red-bg:rgba(192,57,43,0.18);
  --blue:#1565c0;--green:#2e7d32;
  --border:1px solid rgba(201,168,76,0.18);--hdr:62px;--r:8px;
}
*{margin:0;padding:0;box-sizing:border-box;-webkit-tap-highlight-color:transparent}
html,body{height:100%;overflow-x:hidden}
body{background:var(--bg);color:var(--text);font-family:'Raleway',sans-serif;font-size:14px}
::-webkit-scrollbar{width:5px;height:5px}
::-webkit-scrollbar-track{background:var(--bg2)}
::-webkit-scrollbar-thumb{background:var(--gold4);border-radius:3px}
a{color:inherit;text-decoration:none}

/* ===== UTILITIES ===== */
.hidden{display:none!important}
.flex{display:flex}
.center{justify-content:center;align-items:center}
.ml-auto{margin-left:auto}
input[type="date"]{position:relative;cursor:pointer}
input[type="date"]::-webkit-calendar-picker-indicator{
  position:absolute;inset:0;width:100%;height:100%;
  margin:0;padding:0;cursor:pointer;opacity:0;
  filter:invert(0.7) sepia(1) saturate(2) hue-rotate(10deg);
}

/* ===== LOGIN PAGE ===== */
#loginPage{
  min-height:100vh;display:flex;flex-direction:column;
  align-items:center;justify-content:center;
  background:radial-gradient(ellipse at 50% 35%,#1c1400 0%,#0a0800 45%,#080808 75%);
  position:relative;overflow:hidden;
}
#loginPage::before{
  content:'';position:absolute;inset:0;
  background:repeating-linear-gradient(
    -45deg,transparent,transparent 60px,
    rgba(201,168,76,0.012) 60px,rgba(201,168,76,0.012) 61px
  );pointer-events:none;
}
#loginPage::after{
  content:'';position:absolute;
  width:600px;height:600px;border-radius:50%;
  background:radial-gradient(circle,rgba(201,168,76,0.04) 0%,transparent 70%);
  top:50%;left:50%;transform:translate(-50%,-60%);pointer-events:none;
}
.lbox{
  background:rgba(8,7,4,0.98);
  border:1px solid var(--gold);border-radius:14px;
  padding:30px;width:min(400px,92vw);
  box-shadow:0 0 100px rgba(201,168,76,0.1),0 0 30px rgba(0,0,0,0.9),inset 0 1px 0 rgba(201,168,76,0.15);
  position:relative;z-index:1;
}
.lbox::before{
  content:'';position:absolute;top:-1px;left:50%;transform:translateX(-50%);
  width:50%;height:2px;background:linear-gradient(90deg,transparent,var(--gold),transparent);
  border-radius:2px;
}
.llogo{text-align:center;margin-bottom:10px}
.llogo h1{
  font-family:'Cinzel',serif;font-size:clamp(22px,6vw,36px);font-weight:900;color:var(--gold);
  letter-spacing:6px;text-shadow:0 0 40px rgba(201,168,76,0.4);
  animation:glow 3s ease-in-out infinite alternate;
}
@keyframes glow{
  from{text-shadow:0 0 20px rgba(201,168,76,0.3)}
  to{text-shadow:0 0 50px rgba(201,168,76,0.6),0 0 80px rgba(201,168,76,0.2)}
}
.llogo .lsub{
  font-family:'Cormorant Garamond',serif;font-size:12px;
  color:var(--muted);letter-spacing:4px;margin-top:4px;text-transform:uppercase;
}
.lsep-line{
  width:100%;height:1px;margin:20px 0;
  background:linear-gradient(90deg,transparent,rgba(201,168,76,0.3),transparent);
}
.linput{margin-bottom:18px}
.linput label{
  display:block;font-size:10px;color:var(--gold);letter-spacing:2.5px;
  text-transform:uppercase;margin-bottom:8px;font-weight:600;
}
.linput input{
  width:100%;background:rgba(255,255,255,0.03);
  border:1px solid rgba(201,168,76,0.25);border-radius:6px;
  padding:12px 16px;color:var(--text);font-size:14px;font-family:'Raleway',sans-serif;
  outline:none;transition:all .25s;
}
.linput input:focus{border-color:var(--gold);box-shadow:0 0 0 3px var(--gold-glow);background:rgba(201,168,76,0.03)}
.linput input::placeholder{color:var(--muted2)}
.btnPrimary{
  width:100%;padding:14px;margin-top:6px;
  background:linear-gradient(135deg,#7a5810,var(--gold));
  border:none;border-radius:6px;color:#06050a;
  font-family:'Cinzel',serif;font-size:13px;font-weight:700;
  letter-spacing:2.5px;cursor:pointer;transition:all .25s;text-transform:uppercase;
}
.btnPrimary:hover{background:linear-gradient(135deg,var(--gold),var(--gold2));transform:translateY(-1px);box-shadow:0 6px 24px var(--gold-glow)}
.btnPrimary:active{transform:translateY(0);box-shadow:none}
.ldivider{display:flex;align-items:center;gap:12px;margin:18px 0;color:var(--muted);font-size:11px}
.ldivider::before,.ldivider::after{content:'';flex:1;height:1px;background:rgba(201,168,76,0.15)}
.btnSecondary{
  width:100%;padding:11px;background:transparent;
  border:1px solid rgba(201,168,76,0.3);border-radius:6px;
  color:var(--gold);font-family:'Raleway',sans-serif;font-size:13px;
  cursor:pointer;transition:all .2s;letter-spacing:1px;
}
.btnSecondary:hover{background:rgba(201,168,76,0.08);border-color:var(--gold)}
.lerr{
  color:var(--red2);font-size:12px;margin-top:8px;
  padding:8px 12px;background:rgba(192,57,43,0.1);border-radius:4px;
  border-left:2px solid var(--red2);display:none;
}
.lcopy{
  margin-top:24px;text-align:center;font-size:10px;
  color:var(--muted2);letter-spacing:1px;position:relative;z-index:1;
}

/* ===== APP SHELL ===== */
#app{display:none;min-height:100vh;flex-direction:column}

/* ===== SIDEBAR ===== */

/* ===== HEADER ===== */
#hdr{
  height:50px;position:sticky;top:0;z-index:100;
  background:rgba(8,8,8,0.98);backdrop-filter:blur(12px);
  border-bottom:1px solid rgba(201,168,76,0.12);
  display:flex;align-items:center;gap:14px;padding:0 18px;
  flex-shrink:0;
}
.hTitle h2{font-family:'Cinzel',serif;font-size:16px;color:var(--gold);letter-spacing:4px;font-weight:700}
.hTitle p{font-size:10px;color:var(--muted);margin-top:2px;letter-spacing:0.5px}

/* ===== TOP NAVIGATION BAR ===== */
#topNav{
  position:sticky;top:50px;z-index:99;
  background:rgba(10,10,10,0.96);backdrop-filter:blur(10px);
  border-bottom:1px solid rgba(201,168,76,0.1);
  padding:5px 10px;flex-shrink:0;
  overflow-x:auto;
  -webkit-overflow-scrolling:touch;
  scrollbar-width:none;
}
#topNav::-webkit-scrollbar{display:none}
#topNavBtns{
  display:flex;
  flex-wrap:nowrap;
  gap:4px;
  width:max-content;
  min-width:100%;
}
.topNavBtn{
  display:flex;flex-direction:row;align-items:center;justify-content:center;
  gap:5px;padding:8px 12px;border-radius:7px;
  font-family:'Raleway',sans-serif;font-weight:600;font-size:11px;
  letter-spacing:0.5px;cursor:pointer;transition:all .18s;text-transform:uppercase;
  background:rgba(255,255,255,0.03);border:1px solid rgba(255,255,255,0.07);
  color:var(--muted);white-space:nowrap;flex-shrink:0;
}
.topNavBtn svg{display:none}
.topNavBtn:hover{background:rgba(201,168,76,0.07);color:var(--text2);border-color:rgba(201,168,76,0.2)}
.topNavBtn.active{
  background:rgba(201,168,76,0.12);border-color:rgba(201,168,76,0.4);
  color:var(--gold);
}
.topNavBtn.topNavLogout{
  background:rgba(192,57,43,0.08);border-color:rgba(192,57,43,0.25);color:#ef9a9a;
}
.topNavBtn.topNavLogout:hover{background:rgba(192,57,43,0.2);border-color:var(--red2);color:#ffcdd2}
@media(min-width:641px){
  #topNavBtns{gap:6px}
  .topNavBtn{padding:10px 16px;font-size:12px;letter-spacing:0.8px;border-radius:8px}
}
@media(max-width:640px){
  #topNav{padding:4px 8px}
  #topNavBtns{gap:3px}
  .topNavBtn{padding:7px 10px;font-size:10px}
  #hdrClock span:last-child{display:none}
  #hClkTimeEl{font-size:15px !important;letter-spacing:1px !important}
}

/* ===== CONTENT AREA ===== */
#content{
  flex:1;padding:20px;overflow-y:auto;
  max-width:1800px;width:100%;margin:0 auto;
}

/* ===== HOME ===== */
.homeTop{
  display:grid;grid-template-columns:1fr auto;gap:16px;
  margin-bottom:20px;align-items:start;flex-wrap:wrap;
}
.homeTop.noEvent{
  display:none !important;
}

/* ===== SPLASH SCREEN ===== */
#splashScreen{
  position:fixed;inset:0;z-index:99999;
  background:#080808;
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  overflow:hidden;
}
#splashScreen.fade-out{
  animation:splashFadeOut 0.4s ease forwards;
}
@keyframes splashFadeOut{
  from{opacity:1;transform:scale(1)}
  to{opacity:0;transform:scale(1.04)}
}
.splash-bg{
  position:absolute;inset:0;
  background:radial-gradient(ellipse at 50% 40%,#1c1200 0%,#0a0800 40%,#080808 75%);
}
.splash-logo-wrap{
  position:relative;z-index:2;text-align:center;
}
.splash-logo-text{
  opacity:0;
  text-align:center;
  animation:splashLogoIn 0.6s cubic-bezier(0.2,0.8,0.3,1) 0.1s forwards;
}
.splash-brand-top{
  font-family:'Cormorant Garamond',serif;font-size:clamp(10px,2vw,13px);
  color:var(--gold3);letter-spacing:clamp(4px,1.5vw,8px);
  text-transform:uppercase;margin-bottom:14px;
  animation:splashFadeSlideUp 0.45s ease 0.3s both;
}

.splash-brand-line{
  width:clamp(120px,30vw,240px);margin:20px auto;height:1px;
  background:linear-gradient(90deg,transparent,var(--gold),transparent);
  animation:splashLineExpand 0.5s ease 0.5s both;
}
.splash-brand-tagline{
  font-family:'Cormorant Garamond',serif;
  font-size:clamp(9px,1.8vw,12px);
  color:var(--muted);letter-spacing:clamp(3px,1.2vw,6px);
  text-transform:uppercase;
  animation:splashFadeSlideUp 0.5s ease 0.6s both;
}
@keyframes splashLogoIn{
  from{opacity:0;transform:scale(0.88) translateY(20px)}
  to{opacity:1;transform:scale(1) translateY(0)}
}
@keyframes splashNameIn{
  from{opacity:0;transform:scaleX(0.85) translateY(30px);letter-spacing:clamp(20px,5vw,40px)}
  to{opacity:1;transform:scaleX(1) translateY(0);letter-spacing:clamp(8px,3vw,24px)}
}
@keyframes splashNameGlow{
  from{text-shadow:0 0 30px rgba(201,168,76,0.35),0 0 60px rgba(201,168,76,0.15)}
  to{text-shadow:0 0 60px rgba(201,168,76,0.7),0 0 100px rgba(201,168,76,0.35),0 0 140px rgba(201,168,76,0.15)}
}
@keyframes splashFadeSlideUp{
  from{opacity:0;transform:translateY(12px)}
  to{opacity:1;transform:translateY(0)}
}
@keyframes splashLineExpand{
  from{width:0;opacity:0}
  to{width:clamp(120px,30vw,240px);opacity:1}
}
.splash-ornament{
  position:absolute;z-index:2;
  border:1px solid rgba(201,168,76,0.1);border-radius:50%;
  animation:splashOrbit 3s ease-in-out infinite alternate;
}
.splash-ornament.o1{width:300px;height:300px;top:50%;left:50%;margin:-150px 0 0 -150px;animation-delay:0s}
.splash-ornament.o2{width:500px;height:500px;top:50%;left:50%;margin:-250px 0 0 -250px;animation-delay:0.4s;border-color:rgba(201,168,76,0.05)}
@keyframes splashOrbit{
  from{transform:scale(0.92);opacity:0.3}
  to{transform:scale(1.05);opacity:0.7}
}
/* ===== SPLASH TWITCH (elegant glitch) ===== */
@keyframes splashTwitch{
  0%,60%,100%{
    transform:translate(0,0) scale(1) skewX(0deg);
    filter:drop-shadow(0 0 24px rgba(201,168,76,0.5));
  }
  61%{
    transform:translate(-5px,0) scale(1.004) skewX(-1.5deg);
    filter:drop-shadow(-4px 0 10px rgba(255,70,70,0.45)) drop-shadow(4px 0 10px rgba(70,220,255,0.45)) drop-shadow(0 0 18px rgba(201,168,76,0.4));
  }
  62%{
    transform:translate(5px,0) scale(0.997) skewX(1.5deg);
    filter:drop-shadow(4px 0 10px rgba(255,70,70,0.45)) drop-shadow(-4px 0 10px rgba(70,220,255,0.45)) drop-shadow(0 0 18px rgba(201,168,76,0.4));
  }
  63%{
    transform:translate(-2px,1px) scale(1.002) skewX(-0.5deg);
    filter:drop-shadow(0 0 36px rgba(201,168,76,0.85));
  }
  64%{
    transform:translate(0,0) scale(1) skewX(0deg);
    filter:drop-shadow(0 0 24px rgba(201,168,76,0.5));
  }
  72%{
    transform:translate(-3px,0) scale(1) skewX(-1deg);
    filter:drop-shadow(-3px 0 7px rgba(255,70,70,0.3)) drop-shadow(0 0 22px rgba(201,168,76,0.5));
  }
  73%{
    transform:translate(3px,0) scale(1) skewX(1deg);
    filter:drop-shadow(3px 0 7px rgba(70,220,255,0.3)) drop-shadow(0 0 22px rgba(201,168,76,0.5));
  }
  74%{
    transform:translate(0,0) scale(1) skewX(0deg);
    filter:drop-shadow(0 0 24px rgba(201,168,76,0.5));
  }
}
/* ===== LOGIN MOBILE FIX ===== */
@media(max-width:480px){
  .lbox{padding:28px 20px 24px}
  .llogo h1{font-size:26px;letter-spacing:3px}
  .llogo .lsub{font-size:10px;letter-spacing:2.5px}
}
.homeInfo .eventNameDisp{
  font-family:'Cinzel',serif;font-size:20px;color:var(--gold2);
  margin-top:14px;letter-spacing:3px;text-shadow:0 0 20px rgba(240,208,128,0.3);
  min-height:28px;
}
.homeInfo .eventTimeDisp{
  font-size:11px;color:var(--muted);margin-top:4px;letter-spacing:1px;
}
.eventImgWrap img{
  width:220px;height:148px;border-radius:8px;object-fit:cover;
  border:1px solid rgba(201,168,76,0.3);display:block;
  cursor:pointer;
}

/* Stats */
.statsBar{display:flex;gap:12px;margin-bottom:18px;flex-wrap:wrap}
.statCard{
  flex:1;min-width:130px;background:var(--bg2);
  border:var(--border);border-radius:var(--r);
  padding:16px 18px;text-align:center;
  background:linear-gradient(135deg,var(--bg2) 0%,var(--bg3) 100%);
}
.statCard .sv{font-family:'Cinzel',serif;font-size:34px;color:var(--gold);font-weight:700;line-height:1}
.statCard .sl{font-size:9px;color:var(--muted);margin-top:6px;letter-spacing:2px;text-transform:uppercase;font-weight:600}

/* Controls */
.ctrlBar{display:flex;gap:10px;margin-bottom:18px;flex-wrap:wrap;align-items:center}
.srchInp{
  flex:1;min-width:160px;background:var(--bg2);
  border:var(--border);border-radius:6px;
  padding:9px 14px;color:var(--text);font-size:13px;font-family:'Raleway',sans-serif;outline:none;
}
.srchInp:focus,.dateInp:focus{border-color:var(--gold)}
.dateInp{
  background:rgba(201,168,76,0.07);
  border:1px solid rgba(201,168,76,0.45);
  border-radius:6px;
  padding:9px 12px;
  color:var(--gold2);
  font-size:13px;
  font-family:'Raleway',sans-serif;
  font-weight:600;
  outline:none;
  cursor:pointer;
  position:relative;
  letter-spacing:0.5px;
}

/* Buttons */
.btn{
  padding:9px 18px;border-radius:6px;font-size:12px;font-family:'Raleway',sans-serif;
  cursor:pointer;transition:all .2s;font-weight:600;letter-spacing:0.8px;border:none;
  text-transform:uppercase;display:inline-flex;align-items:center;gap:7px;
}
.btnGold{background:linear-gradient(135deg,var(--gold4),var(--gold));color:#06050a}
.btnGold:hover{background:linear-gradient(135deg,var(--gold),var(--gold2));transform:translateY(-1px);box-shadow:0 4px 16px var(--gold-glow)}
.btnRed{background:rgba(192,57,43,0.18);border:1px solid rgba(192,57,43,0.4);color:#ef9a9a}
.btnRed:hover{background:rgba(192,57,43,0.3)}
.btnGray{background:rgba(255,255,255,0.05);border:1px solid rgba(255,255,255,0.1);color:var(--muted)}
.btnGray:hover{background:rgba(255,255,255,0.09);color:var(--text)}
.btnGreen{background:rgba(46,125,50,0.18);border:1px solid rgba(76,175,80,0.35);color:#a5d6a7}
.btnGreen:hover{background:rgba(46,125,50,0.3)}
.btnFDC{
  padding:9px 18px;background:linear-gradient(135deg,#1a4020,var(--green));
  border:1px solid rgba(76,175,80,0.4);border-radius:6px;
  color:#a5d6a7;font-size:12px;font-family:'Raleway',sans-serif;
  cursor:pointer;font-weight:700;letter-spacing:1px;transition:all .2s;text-transform:uppercase;
}
.btnFDC:hover{filter:brightness(1.2);box-shadow:0 0 12px rgba(76,175,80,0.25)}
.btnEvent{
  padding:9px 18px;background:rgba(201,168,76,0.1);
  border:1px solid rgba(201,168,76,0.3);border-radius:6px;
  color:var(--gold);font-size:12px;font-family:'Raleway',sans-serif;
  cursor:pointer;font-weight:600;letter-spacing:1px;transition:all .2s;text-transform:uppercase;
}
.btnEvent:hover{background:rgba(201,168,76,0.18)}

/* ===== FLOOR SECTIONS ===== */
.floorSection{margin-bottom:28px}
.floorTitle{
  font-family:'Cinzel',serif;font-size:12px;letter-spacing:4px;color:var(--gold);
  padding:9px 16px;border-left:3px solid var(--gold);margin-bottom:16px;
  background:rgba(201,168,76,0.04);border-radius:0 6px 6px 0;text-transform:uppercase;
}
.areaBlock{margin-bottom:18px}
.areaLabel{
  font-size:10px;font-weight:700;letter-spacing:2.5px;text-transform:uppercase;
  padding:5px 12px;border-radius:20px;display:inline-block;margin-bottom:10px;opacity:0.9;
}
.tableGrid{display:flex;flex-wrap:wrap;gap:9px}

/* ===== TABLE BOXES ===== */
.tbox{
  width:128px;min-height:108px;border-radius:8px;cursor:pointer;padding:10px 8px;
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  text-align:center;transition:transform .12s ease,filter .12s ease,border-color .12s ease,background .12s ease;
  border:2px solid transparent;position:relative;flex-shrink:0;
  will-change:transform;
}
.tbox:hover{transform:translateY(-2px);filter:brightness(1.12)}
.tbox:active{transform:translateY(0) scale(0.97);transition:transform .06s ease}
.tbox.empty{background:rgba(255,255,255,0.04);border-color:rgba(255,255,255,0.12)}
.tbox.occupied{background:rgba(192,57,43,0.22);border-color:#e74c3c}
.tbox .tn{font-family:'Cinzel',serif;font-size:15px;font-weight:700;letter-spacing:1px;margin-bottom:4px;line-height:1.2}
.tbox .tmc{font-size:12px;color:var(--muted);margin-bottom:4px}
.tbox .tguest{font-size:15px;font-weight:700;color:var(--gold2);margin-bottom:3px;line-height:1.2;word-break:break-word;max-width:100%}
.tbox .tpax{font-size:13px;color:#ef9a9a}
.tbox .tavail{font-size:13px;color:var(--muted);margin-top:4px}
.tbox .tremarks{font-size:11px;color:var(--muted);margin-top:3px;opacity:0.8;max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.tbox .tdep{font-size:12px;color:#90caf9;margin-top:2px}
.tbox .tsisa{font-size:12px;color:#1e88e5;font-weight:700;margin-top:2px}

/* ===== GUEST MODE ===== */
body.guestMode .appFoot{display:none}
body.guestMode #content{padding-top:16px}
/* Sembunyikan header & navigasi untuk guest */
body.guestMode #hdr{display:none!important}
body.guestMode #topNav{display:none!important}
body.guestMode #topNavBtns{display:none!important}
.guestBanner{
  background:linear-gradient(135deg,rgba(201,168,76,0.08),rgba(201,168,76,0.04));
  border:1px solid rgba(201,168,76,0.2);border-radius:8px;
  padding:12px 18px;margin-bottom:16px;
  display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:8px;
}
.guestBanner .gbTitle{font-family:'Cinzel',serif;font-size:14px;color:var(--gold);letter-spacing:2px}
.guestBanner .gbUser{font-size:11px;color:var(--muted)}

/* Deposit + sisa */
.detDepositRow{
  background:rgba(21,101,192,0.1);border:1px solid rgba(21,101,192,0.25);
  border-radius:6px;padding:10px 14px;margin-top:10px;
}
.detDepositRow .dl{color:#90caf9}
.detDepositRow .dv{color:#90caf9;font-weight:700}
.sisaRow{
  background:rgba(21,101,192,0.15);border:1px solid rgba(21,101,192,0.4);
  border-radius:6px;padding:10px 14px;margin-top:6px;
}
.sisaRow .dl{color:#64b5f6}
.sisaRow .dv{color:#1e88e5;font-weight:800;font-size:15px}
.lunasBadge{
  background:rgba(21,101,192,0.2);border:1px solid rgba(21,101,192,0.5);
  border-radius:6px;padding:10px 14px;margin-top:6px;
  text-align:center;color:#42a5f5;font-family:'Cinzel',serif;font-size:13px;
  letter-spacing:1.5px;font-weight:700;
}

/* ===== VIEW HEADER ===== */
.viewHdr{
  display:flex;align-items:center;justify-content:space-between;
  margin-bottom:20px;flex-wrap:wrap;gap:12px;
}
.viewHdr h2{font-family:'Cinzel',serif;font-size:16px;color:var(--gold);letter-spacing:3px;text-transform:uppercase}

/* ===== TABLES (data) ===== */
.tblWrap{overflow-x:auto;border-radius:var(--r);border:var(--border)}
table{width:100%;border-collapse:collapse;font-size:12px}
th{
  background:rgba(201,168,76,0.08);color:var(--gold);
  font-size:9px;letter-spacing:2px;text-transform:uppercase;
  padding:12px 14px;text-align:left;font-weight:700;white-space:nowrap;
  border-bottom:1px solid rgba(201,168,76,0.15);
}
td{padding:11px 14px;border-bottom:1px solid rgba(255,255,255,0.04);color:var(--text2);vertical-align:middle}
tr:last-child td{border:none}
tbody tr:hover td{background:rgba(201,168,76,0.03)}
tfoot td{padding:11px 14px;border-top:1px solid rgba(201,168,76,0.2);color:var(--text2);vertical-align:middle;font-size:12px}
.badge{display:inline-block;padding:3px 9px;border-radius:20px;font-size:9px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase}
.bActive{background:rgba(76,175,80,0.15);color:#a5d6a7}
.bGone{background:rgba(192,57,43,0.15);color:#ef9a9a}

/* ===== MODALS ===== */
.mBg{
  position:fixed;inset:0;background:rgba(0,0,0,0.88);z-index:500;
  display:none;align-items:center;justify-content:center;padding:16px;
  backdrop-filter:blur(4px);
}
.mBg.open{display:flex}
.modal{
  background:var(--bg2);border:1px solid rgba(201,168,76,0.25);border-radius:12px;
  width:100%;max-width:500px;max-height:92vh;overflow-y:auto;
  box-shadow:0 0 60px rgba(0,0,0,0.9);position:relative;
  animation:slideUp .22s ease;
}
.modalWide{max-width:680px}
@keyframes slideUp{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}
.mhdr{
  padding:22px 22px 16px;border-bottom:1px solid rgba(201,168,76,0.1);
  display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;
  background:var(--bg2);z-index:1;
}
.mhdr h3{font-family:'Cinzel',serif;font-size:14px;color:var(--gold);letter-spacing:2.5px;text-transform:uppercase}
.mclose{
  background:none;border:none;color:var(--muted);cursor:pointer;
  font-size:22px;line-height:1;padding:4px;transition:color .2s;margin-left:8px;flex-shrink:0;
}
.mclose:hover{color:var(--text)}
.mbody{padding:20px 22px}
.mfooter{
  padding:14px 22px;border-top:1px solid rgba(201,168,76,0.1);
  display:flex;gap:10px;justify-content:flex-end;flex-wrap:wrap;
  position:sticky;bottom:0;background:var(--bg2);
}

/* Form inputs inside modals */
.finp{margin-bottom:15px}
.finp label{display:block;font-size:9px;color:var(--gold);letter-spacing:2px;text-transform:uppercase;margin-bottom:7px;font-weight:700}
.finp input,.finp select,.finp textarea{
  width:100%;background:rgba(255,255,255,0.03);
  border:1px solid rgba(201,168,76,0.18);border-radius:6px;
  padding:10px 13px;color:var(--text);font-size:13px;
  font-family:'Raleway',sans-serif;outline:none;transition:border-color .2s;
}
.finp input:focus,.finp select:focus,.finp textarea:focus{border-color:var(--gold);background:rgba(201,168,76,0.02)}
.finp input::placeholder,.finp textarea::placeholder{color:var(--muted2)}
.finp select option{background:var(--bg2);color:var(--text)}
.finp textarea{resize:vertical;min-height:65px;line-height:1.5}
.fgrid{display:grid;grid-template-columns:1fr 1fr;gap:12px}

/* Table detail popup */
.detStatus{
  padding:12px 16px;border-radius:6px;margin-bottom:16px;text-align:center;
  font-weight:700;font-size:13px;letter-spacing:1px;
}
.stLunas{background:rgba(21,101,192,0.18);border:1px solid rgba(21,101,192,0.35);color:#90caf9}
.stBelum{background:rgba(192,57,43,0.18);border:1px solid rgba(192,57,43,0.35);color:#ef9a9a}
.detRow{display:flex;justify-content:space-between;align-items:flex-start;padding:9px 0;border-bottom:1px solid rgba(255,255,255,0.04);gap:12px;font-size:13px}
.detRow:last-child{border:none}
.detRow .dl{color:var(--muted);font-size:11px;letter-spacing:0.5px;flex-shrink:0}
.detRow .dv{color:var(--text);font-weight:500;text-align:right}

/* ===== FILTER BAR ===== */
.filterBar{display:flex;gap:9px;margin-bottom:14px;flex-wrap:wrap;align-items:center}
.filterBar input,.filterBar select{
  background:var(--bg2);border:var(--border);border-radius:6px;
  padding:7px 11px;color:var(--text);font-size:12px;
  font-family:'Raleway',sans-serif;outline:none;
}
.filterBar input[type="date"]{position:relative;cursor:pointer}
.filterBar input:focus,.filterBar select:focus{border-color:var(--gold)}
.filterBar label{font-size:11px;color:var(--muted);flex-shrink:0}

/* ===== GUEST FILTER CHIPS ===== */
.gfChip{
  padding:6px 14px;border-radius:20px;font-size:11px;font-family:'Raleway',sans-serif;
  font-weight:600;letter-spacing:0.5px;cursor:pointer;transition:all .18s;
  background:rgba(255,255,255,0.04);border:1px solid rgba(255,255,255,0.1);
  color:var(--muted);white-space:nowrap;
}
.gfChip:hover{background:rgba(201,168,76,0.08);color:var(--text2);border-color:rgba(201,168,76,0.25)}
.gfChip.active{background:rgba(201,168,76,0.15);border-color:var(--gold);color:var(--gold);font-weight:700}

/* ===== SETTINGS ===== */
.setSection{margin-bottom:28px}
.setSection h3{
  font-family:'Cinzel',serif;font-size:12px;color:var(--gold);letter-spacing:3px;
  margin-bottom:14px;padding-bottom:9px;border-bottom:var(--border);text-transform:uppercase;
}
.mcAreaBlock{margin-bottom:20px}
.mcAreaLabel{
  font-size:10px;font-weight:700;letter-spacing:2.5px;text-transform:uppercase;
  padding:5px 12px;border-radius:20px;display:inline-block;margin-bottom:10px;opacity:0.9;
}
.mcGrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(130px,1fr));gap:7px}
.mcItem{background:var(--bg3);border:var(--border);border-radius:6px;padding:9px 10px}
.mcItem label{font-size:9px;color:var(--muted);display:block;margin-bottom:5px;letter-spacing:0.5px;font-weight:600;text-transform:uppercase}
.mcItem input{
  width:100%;background:rgba(255,255,255,0.03);
  border:1px solid rgba(201,168,76,0.15);border-radius:4px;
  padding:6px 8px;color:var(--text);font-size:12px;font-family:'Raleway',sans-serif;outline:none;
}
.mcItem input:focus{border-color:var(--gold)}
.mcFloorTitle{
  font-family:'Cinzel',serif;font-size:11px;letter-spacing:3px;color:var(--gold);
  padding:7px 14px;border-left:3px solid var(--gold);margin-bottom:12px;margin-top:4px;
  background:rgba(201,168,76,0.04);border-radius:0 5px 5px 0;text-transform:uppercase;
}

/* ===== AD POPUP — FADE IN/OUT ===== */
#adMod{
  z-index:600;
  display:flex!important;
  visibility:hidden;
  opacity:0;
  pointer-events:none;
  transition:opacity 0.9s ease, visibility 0.9s ease;
}
#adMod.open{
  visibility:visible;
  opacity:1;
  pointer-events:auto;
}
.adInner{
  background:var(--bg2);border:1px solid var(--gold);border-radius:10px;
  max-width:min(92vw,760px);width:auto;overflow:hidden;position:relative;
  box-shadow:0 0 40px rgba(201,168,76,0.15);
  animation:adPopIn 0.9s cubic-bezier(.22,1,.36,1);
  cursor:pointer;display:inline-flex;flex-direction:column;
}
@keyframes adPopIn{
  from{opacity:0;transform:scale(0.88) translateY(24px)}
  to{opacity:1;transform:scale(1) translateY(0)}
}
.adImg{display:block;width:auto;height:auto;max-width:min(92vw,760px);max-height:82vh;object-fit:contain;cursor:pointer}
.adCaption{padding:8px 14px;font-family:'Cinzel',serif;font-size:11px;color:var(--gold);text-align:center;letter-spacing:2px}

/* ===== MULTI-TABLE SELECT ===== */
.mtsGrid{display:flex;flex-wrap:wrap;gap:5px;max-height:200px;overflow-y:auto;padding:4px}
.mtsBox{
  padding:5px 9px;border-radius:4px;cursor:pointer;font-size:10px;font-weight:600;
  border:1px solid rgba(255,255,255,0.12);background:rgba(255,255,255,0.04);
  color:var(--muted);transition:all .15s;letter-spacing:0.3px;
}
.mtsBox:hover{border-color:var(--gold);color:var(--text2)}
.mtsBox.sel{background:rgba(201,168,76,0.18);border-color:var(--gold);color:var(--gold)}
.mtsBox.occupied-target{background:rgba(201,168,76,0.1);border-color:rgba(201,168,76,0.4);color:var(--gold);cursor:pointer}
.mtsBox.occupied-target:hover{background:rgba(201,168,76,0.2);border-color:var(--gold)}
.mtsBox.occupied-target.sel{background:rgba(201,168,76,0.3);border-color:var(--gold2);color:var(--gold2)}

/* ===== RANKING ===== */
.rankItem{display:flex;align-items:center;gap:12px;padding:10px 0;border-bottom:1px solid rgba(255,255,255,0.04)}
.rankItem:last-child{border:none}
.rankBadge{
  font-family:'Cinzel',serif;font-size:14px;font-weight:700;
  width:30px;height:30px;display:flex;align-items:center;justify-content:center;
  border-radius:50%;flex-shrink:0;
}
.rk1{background:linear-gradient(135deg,var(--gold3),var(--gold2));color:#06050a}
.rk2{background:linear-gradient(135deg,#757575,#bdbdbd);color:#fff}
.rk3{background:linear-gradient(135deg,#6d4c41,#a1887f);color:#fff}
.rkN{background:rgba(255,255,255,0.06);color:var(--muted)}

/* ===== WA MODAL ===== */
.waBody{text-align:center;padding:16px 10px 6px}
.waBody h4{font-family:'Cinzel',serif;font-size:17px;color:var(--gold);margin-bottom:10px;letter-spacing:2px}
.waBody p{color:var(--text2);font-size:13px;margin-bottom:26px;line-height:1.8;max-width:320px;margin-left:auto;margin-right:auto}
.btnWA{
  display:inline-flex;align-items:center;gap:11px;padding:14px 30px;
  background:linear-gradient(135deg,#1b5e20,#2e7d32,#388e3c);
  border:1px solid rgba(76,175,80,0.55);border-radius:10px;
  color:#c8e6c9;font-size:15px;font-weight:700;cursor:pointer;
  text-decoration:none;transition:all .25s;font-family:'Raleway',sans-serif;
  letter-spacing:0.5px;box-shadow:0 4px 18px rgba(37,211,102,0.18);
}
.btnWA:hover{filter:brightness(1.15);box-shadow:0 6px 28px rgba(37,211,102,0.35);transform:translateY(-2px)}
.btnWA:active{transform:translateY(0)}

/* ===== CHECKIN ===== */
.ciItem{
  background:rgba(201,168,76,0.06);border:1px solid rgba(201,168,76,0.18);
  border-radius:8px;padding:14px;margin-bottom:10px;
}
.ciItem h4{font-family:'Cinzel',serif;color:var(--gold);font-size:13px;margin-bottom:6px}
.ciItem p{font-size:11px;color:var(--muted);line-height:1.6}

/* ===== APP FOOTER ===== */
.appFoot{
  text-align:center;padding:11px 20px;font-size:9px;color:var(--muted2);
  border-top:1px solid rgba(201,168,76,0.08);letter-spacing:0.5px;line-height:1.7;
  font-style:italic;flex-shrink:0;
}

/* ===== NOTICE ===== */
.emptyState{
  text-align:center;padding:50px 20px;color:var(--muted);
}
.emptyState p{font-size:13px;margin-top:8px}

/* ===== EVENT IMAGE POPUP ===== */
#evImgPopupBg{
  position:fixed;inset:0;background:rgba(0,0,0,0.92);z-index:700;
  display:none;align-items:center;justify-content:center;padding:20px;
  backdrop-filter:blur(8px);
}
#evImgPopupBg.open{display:flex}
#evImgPopupBg img{
  max-width:min(480px,90vw);max-height:80vh;
  border-radius:12px;border:1px solid var(--gold);
  object-fit:contain;
}
#evImgPopupBg 

/* ===== SYNC STATUS ===== */
.syncBadge{
  font-size:9px;padding:2px 7px;border-radius:10px;
  letter-spacing:1px;font-weight:600;text-transform:uppercase;
  margin-left:6px;
}
.syncOk{background:rgba(46,125,50,0.2);color:#a5d6a7;border:1px solid rgba(76,175,80,0.3)}
.syncWarn{background:rgba(255,152,0,0.18);color:#ffcc80;border:1px solid rgba(255,152,0,0.35)}
.syncOff{background:rgba(100,100,100,0.2);color:var(--muted);border:1px solid rgba(100,100,100,0.3)}

/* ===== RESPONSIVE ===== */
@media(max-width:640px){
  .fgrid{grid-template-columns:1fr}
  .homeTop{grid-template-columns:1fr}
  .homeInfo{text-align:center}
  /* Event image full centered modal on mobile - handled by evImgPopupBg */
  .tbox{width:calc(33.333% - 7px);min-height:100px}
  .tbox .tn{font-size:13px}
  .tbox .tguest{font-size:13px}
  .tbox .tpax{font-size:11px}
  .tbox .tdep,.tbox .tsisa{font-size:11px}
  
  .statsBar{gap:8px}
  .statCard{min-width:100px}
  .lbox{padding:36px 24px 28px}
  .llogo h1{font-size:32px}
  .ctrlBar{flex-direction:row;flex-wrap:wrap;gap:8px}
  .srchInp{min-width:120px}
  #content{padding:12px}
  .tableGrid{gap:6px}
  .statsBar{flex-wrap:wrap}
  .statCard .sv{font-size:26px}
  th{padding:9px 10px;font-size:8px}
  td{padding:9px 10px;font-size:11px}
  /* CENTERED MODALS ON MOBILE */
  .modal{max-width:96vw;border-radius:12px;margin-top:0}
  .mBg{align-items:center;padding:12px}
}
/* ===== PENDING MOVES MODAL ===== */
.pendMoveItem{
  background:rgba(255,255,255,0.03);border:1px solid rgba(255,255,255,0.08);
  border-radius:10px;padding:14px 16px;margin-bottom:10px;
  transition:all 0.2s;
}
.pendMoveItem:hover{border-color:rgba(201,168,76,0.25)}
.pendMoveItem .pmHeader{
  display:flex;align-items:center;gap:10px;margin-bottom:10px;
  flex-wrap:wrap;
}
.pendMoveItem .pmGuest{
  font-size:14px;font-weight:700;color:var(--gold2);flex:1;
}
.pendMoveItem .pmBy{
  font-size:10px;color:var(--muted);letter-spacing:0.5px;
}
.pendMoveItem .pmRoute{
  display:flex;align-items:center;gap:8px;
  margin-bottom:10px;font-size:12px;
}
.pendMoveItem .pmFrom{
  padding:5px 10px;border-radius:6px;
  background:rgba(192,57,43,0.12);border:1px solid rgba(192,57,43,0.3);color:#ef9a9a;
  font-weight:600;
}
.pendMoveItem .pmTo{
  padding:5px 10px;border-radius:6px;
  background:rgba(46,125,50,0.12);border:1px solid rgba(76,175,80,0.3);color:#a5d6a7;
  font-weight:600;
}
.pendMoveItem .pmArrow{color:var(--gold);font-size:14px}
.pendMoveItem .pmMC{
  font-size:11px;color:var(--muted);margin-bottom:10px;
  padding:6px 10px;background:rgba(201,168,76,0.04);border-radius:6px;
}
.pendMoveItem .pmActions{display:flex;gap:8px}
.pmBadgeCount{
  display:inline-flex;align-items:center;justify-content:center;
  background:var(--red2);color:#fff;border-radius:50%;
  width:18px;height:18px;font-size:10px;font-weight:700;
  margin-left:6px;
}

/* ===== MOVE TABLE ENHANCED ===== */
.moveInfoCard{
  background:linear-gradient(135deg,rgba(201,168,76,0.07) 0%,rgba(201,168,76,0.03) 100%);
  border:1px solid rgba(201,168,76,0.25);border-radius:10px;
  padding:14px 16px;margin-bottom:16px;position:relative;overflow:hidden;
}
.moveInfoCard::before{
  content:'';position:absolute;top:0;left:0;right:0;height:2px;
  background:linear-gradient(90deg,transparent,var(--gold),transparent);
}
.moveInfoCard .micTitle{
  font-family:'Cinzel',serif;font-size:9px;letter-spacing:3px;color:var(--gold);
  text-transform:uppercase;margin-bottom:10px;opacity:0.8;
}
.moveInfoGrid{
  display:grid;grid-template-columns:1fr 1fr;gap:8px;
}
.moveInfoItem{display:flex;flex-direction:column;gap:2px}
.moveInfoItem .mil{font-size:9px;color:var(--muted);letter-spacing:1.5px;text-transform:uppercase}
.moveInfoItem .miv{font-size:13px;color:var(--text);font-weight:600}
.moveInfoItem .miv.gold{color:var(--gold2)}
.moveInfoItem .miv.red{color:#ef9a9a}
.moveInfoItem .miv.green{color:#a5d6a7}
.moveArrow{
  display:flex;align-items:center;justify-content:center;gap:10px;
  margin:12px 0;padding:8px;
  background:rgba(255,255,255,0.03);border-radius:8px;
}
.moveArrow .maFrom,.moveArrow .maTo{
  flex:1;text-align:center;
  padding:8px 12px;border-radius:6px;font-size:12px;font-weight:600;
}
.moveArrow .maFrom{
  background:rgba(192,57,43,0.12);border:1px solid rgba(192,57,43,0.3);color:#ef9a9a;
}
.moveArrow .maTo{
  background:rgba(46,125,50,0.12);border:1px solid rgba(76,175,80,0.3);color:#a5d6a7;
  transition:all 0.2s;
}
.moveArrow .maTo.selected{
  background:rgba(201,168,76,0.18);border-color:var(--gold);color:var(--gold2);
}
.moveArrow .arrowIcon{color:var(--gold);font-size:18px;flex-shrink:0}
.moveDestPreview{
  background:rgba(255,255,255,0.03);border:1px dashed rgba(201,168,76,0.2);
  border-radius:8px;padding:10px 14px;margin-bottom:14px;
  font-size:11px;color:var(--muted);transition:all 0.2s;min-height:42px;
  display:flex;align-items:center;
}
.moveDestPreview.active{
  background:rgba(201,168,76,0.06);border-color:rgba(201,168,76,0.4);color:var(--text2);
}
.moveDestPreview .mdpGrid{display:grid;grid-template-columns:repeat(3,1fr);gap:6px;width:100%}
.moveDestPreview .mdpItem{display:flex;flex-direction:column;gap:1px}
.moveDestPreview .mdpL{font-size:8px;color:var(--muted);letter-spacing:1px;text-transform:uppercase}
.moveDestPreview .mdpV{font-size:12px;color:var(--gold2);font-weight:600}
.moveGridTitle{
  font-size:10px;color:var(--muted);letter-spacing:1.5px;text-transform:uppercase;
  margin-bottom:8px;padding-bottom:6px;border-bottom:1px solid rgba(255,255,255,0.06);
}
/* Host pax edit inline */
.paxEditInline{
  display:flex;align-items:center;gap:8px;
  background:rgba(201,168,76,0.06);border:1px solid rgba(201,168,76,0.2);
  border-radius:8px;padding:10px 14px;margin-top:10px;
}
.paxEditInline label{font-size:11px;color:var(--gold);flex-shrink:0;letter-spacing:0.5px}
.paxEditInline input{
  width:70px;background:rgba(255,255,255,0.05);border:1px solid rgba(201,168,76,0.3);
  border-radius:6px;padding:7px 10px;color:var(--text);font-size:13px;
  font-family:'Raleway',sans-serif;outline:none;text-align:center;
}
.paxEditInline input:focus{border-color:var(--gold);box-shadow:0 0 0 2px var(--gold-glow)}
/* Move history badge in guest table */
/* ===== CHECK-IN & EDIT NAME ===== */
.badgeCheckin{
  display:inline-block;padding:3px 9px;border-radius:20px;font-size:10px;font-weight:700;
  letter-spacing:1px;text-transform:uppercase;
}
.badgeCheckin.in{background:rgba(46,125,50,0.25);color:#a5d6a7;border:1px solid rgba(76,175,80,0.4)}
.badgeCheckin.out{background:rgba(255,255,255,0.05);color:var(--muted);border:1px solid rgba(255,255,255,0.1)}
.btnCI{
  padding:4px 10px;border-radius:5px;font-size:10px;font-family:'Raleway',sans-serif;
  cursor:pointer;font-weight:700;letter-spacing:0.8px;border:none;transition:all .18s;
  text-transform:uppercase;
}
.btnCI.doIn{background:rgba(46,125,50,0.2);border:1px solid rgba(76,175,80,0.4);color:#a5d6a7}
.btnCI.doIn:hover{background:rgba(46,125,50,0.4)}
.btnCI.doOut{background:rgba(192,57,43,0.15);border:1px solid rgba(192,57,43,0.35);color:#ef9a9a}
.btnCI.doOut:hover{background:rgba(192,57,43,0.3)}
.btnEditName{
  padding:4px 9px;border-radius:5px;font-size:10px;font-family:'Raleway',sans-serif;
  cursor:pointer;font-weight:600;letter-spacing:0.5px;
  background:rgba(201,168,76,0.1);border:1px solid rgba(201,168,76,0.3);color:var(--gold);
  transition:all .18s;
}
.btnEditName:hover{background:rgba(201,168,76,0.22)}
/* Edit name inline modal */
#editNameModal{
  display:none;position:fixed;inset:0;z-index:9000;
  background:rgba(0,0,0,0.75);backdrop-filter:blur(4px);
  align-items:center;justify-content:center;
}
#editNameModal.open{display:flex}
.editNameBox{
  background:var(--bg2);border:1px solid rgba(201,168,76,0.35);
  border-radius:12px;padding:28px 28px 24px;width:min(400px,92vw);
  box-shadow:0 0 60px rgba(0,0,0,0.8);
}
.editNameBox h3{
  font-family:'Cinzel',serif;font-size:14px;color:var(--gold);
  letter-spacing:2px;margin-bottom:18px;text-transform:uppercase;
}
.editNameBox input{
  width:100%;background:rgba(255,255,255,0.04);
  border:1px solid rgba(201,168,76,0.3);border-radius:6px;
  padding:11px 14px;color:var(--text);font-size:14px;
  font-family:'Raleway',sans-serif;outline:none;transition:all .2s;
}
.editNameBox input:focus{border-color:var(--gold);box-shadow:0 0 0 3px var(--gold-glow)}
.editNameBox .errMsg{color:var(--red2);font-size:12px;margin-top:6px;display:none}
.editNameBox .btnRow{display:flex;gap:10px;margin-top:18px}
.moveHistBadge{
  display:inline-flex;align-items:center;gap:4px;
  font-size:9px;padding:2px 7px;border-radius:10px;
  background:rgba(201,168,76,0.12);color:var(--gold);border:1px solid rgba(201,168,76,0.25);
  cursor:pointer;white-space:nowrap;
}
.moveHistBadge:hover{background:rgba(201,168,76,0.22)}
/* Move history popup */
.moveHistPopup{
  position:fixed;inset:0;background:rgba(0,0,0,0.7);z-index:800;
  display:none;align-items:center;justify-content:center;padding:20px;
  backdrop-filter:blur(4px);
}
.moveHistPopup.open{display:flex}
.moveHistBox{
  background:var(--bg2);border:1px solid rgba(201,168,76,0.3);border-radius:12px;
  padding:20px;max-width:480px;width:100%;max-height:80vh;overflow-y:auto;
}
.moveHistBox h4{font-family:'Cinzel',serif;font-size:13px;color:var(--gold);letter-spacing:2px;margin-bottom:14px}
.moveHistItem{
  padding:10px 12px;border-radius:8px;margin-bottom:8px;
  background:rgba(255,255,255,0.03);border:1px solid rgba(255,255,255,0.07);
  font-size:11px;line-height:1.7;
}
.moveHistItem .mhTime{font-size:9px;color:var(--muted);margin-top:4px}

/* ===== ANTRIAN NOTIF REQUEST ===== */
@keyframes fadeIn{from{opacity:0;transform:scale(0.96)}to{opacity:1;transform:scale(1)}}
@keyframes spamShake{0%,100%{transform:rotate(0deg)}20%{transform:rotate(-12deg)}40%{transform:rotate(12deg)}60%{transform:rotate(-8deg)}80%{transform:rotate(8deg)}}

/* ===== GUEST MODE — sembunyikan stats & kontrol yang tidak perlu ===== */
body.guestMode #statsBar{ display:none !important; }
body.guestMode #preOpenBanner{ display:none !important; }
/* Rapatkan ctrlBar ke atas saat tidak ada event (homeTop hidden) */
body:not(.guestMode) #view-home .homeTop[style*="display: none"] ~ .statsBar,
body:not(.guestMode) #view-home .homeTop[style*="display:none"] ~ .statsBar{ margin-top:0 }
/* Rapatkan ctrlBar saat tidak ada event */
#view-home .homeTop[style*="display: none"] ~ .ctrlBar,
#view-home .homeTop[style*="display:none"] ~ .ctrlBar{ margin-top:0 }

/* ===== DENAH LAYOUT TAMU ===== */
#guestLayoutView{padding:10px 0}
.glv-tabs{display:flex;gap:6px;margin-bottom:14px;flex-wrap:wrap}
.glv-tab{
  padding:7px 16px;border-radius:20px;font-size:11px;font-family:'Raleway',sans-serif;
  font-weight:700;letter-spacing:1px;cursor:pointer;transition:all .18s;
  background:rgba(255,255,255,0.04);border:1px solid rgba(255,255,255,0.1);
  color:var(--muted);text-transform:uppercase;
}
.glv-tab.active{background:rgba(201,168,76,0.15);border-color:var(--gold);color:var(--gold)}
.glv-canvas-wrap{
  position:relative;width:100%;overflow:hidden;
  background:rgba(255,255,255,0.015);
  border:1px solid rgba(201,168,76,0.1);border-radius:10px;
}
.glv-canvas{position:relative;min-width:320px;}
.glv-tbl{
  position:absolute;
  border-radius:8px;
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  font-family:'Raleway',sans-serif;
  border:2px solid;
  box-sizing:border-box;
  transition:box-shadow .15s;
  overflow:hidden;
  user-select:none;-webkit-user-select:none;
}
.glv-tbl .gt-name{font-size:10px;font-weight:800;letter-spacing:1px;text-align:center;line-height:1.2}
.glv-tbl .gt-num{font-size:16px;font-weight:900;letter-spacing:0;text-align:center;line-height:1;font-family:'Cinzel',serif}
.glv-tbl .gt-status{font-size:9px;letter-spacing:0.5px;margin-top:3px;text-align:center;line-height:1.2}
.glv-tbl.gt-occupied{box-shadow:0 0 12px rgba(255,80,80,0.2)}
.glv-tbl.gt-available{opacity:0.8}
/* Legend */
.glv-legend{display:flex;gap:12px;flex-wrap:wrap;margin-top:10px;font-size:10px;color:var(--muted)}
.glv-legend-item{display:flex;align-items:center;gap:5px}
.glv-legend-dot{width:10px;height:10px;border-radius:3px;flex-shrink:0}
/* Guest layout floor decor */
.glv-floor-section{margin-bottom:32px}
.glv-floor-decor{display:flex;gap:8px;margin-bottom:12px;flex-wrap:wrap}
.glv-decor-badge{display:flex;align-items:center;gap:6px;padding:6px 12px;background:rgba(201,168,76,0.07);border:1px solid rgba(201,168,76,0.2);border-radius:8px}
.glv-decor-badge span{font-family:'Cinzel',serif;font-size:10px;color:var(--gold);letter-spacing:2px;text-transform:uppercase}
/* Area legend table */
.glv-area-legend{margin-top:14px}
.glv-area-legend-title{font-size:10px;color:var(--muted);letter-spacing:2px;text-transform:uppercase;margin-bottom:8px}
.glv-area-table{border-collapse:collapse;background:rgba(255,255,255,0.02);border:1px solid rgba(201,168,76,0.12);border-radius:8px;overflow:hidden;min-width:260px;width:100%;max-width:420px}
.glv-area-table th{background:rgba(201,168,76,0.06);padding:7px 10px;font-size:9px;color:var(--gold);letter-spacing:2px;text-align:left;font-weight:700;text-transform:uppercase;white-space:nowrap;border-bottom:1px solid rgba(201,168,76,0.1)}
.glv-area-table td{padding:7px 10px;border-bottom:1px solid rgba(255,255,255,0.04);vertical-align:middle}
.glv-area-table tr:last-child td{border:none}
.glv-area-swatch{width:14px;height:14px;border-radius:3px;display:inline-block;flex-shrink:0}
/* Canvas scaling — berlaku di semua ukuran layar */
.glv-canvas-scaler{transform-origin:top left;display:block}
/* Mobile canvas scaling */
@media(max-width:640px){
  .glv-canvas-wrap{overflow:hidden !important}
  .glv-floor-decor{gap:6px}
  .glv-decor-badge{padding:5px 10px}
}

/* ===== LAYOUT EDITOR (admin/resepsionis) ===== */
#layoutEditorWrap{margin-top:8px}
.le-toolbar{
  display:flex;gap:8px;flex-wrap:wrap;align-items:center;
  margin-bottom:10px;padding:10px 12px;
  background:rgba(255,255,255,0.03);border:1px solid rgba(201,168,76,0.12);border-radius:8px;
}
.le-toolbar label{font-size:10px;color:var(--muted);letter-spacing:1px;text-transform:uppercase;flex-shrink:0}
.le-toolbar select{
  background:var(--bg2);border:1px solid rgba(201,168,76,0.2);border-radius:5px;
  padding:5px 8px;color:var(--text);font-size:11px;font-family:'Raleway',sans-serif;outline:none;
}
.le-grid-canvas{
  position:relative;min-height:340px;
  background:
    repeating-linear-gradient(0deg,rgba(255,255,255,0.03) 0,rgba(255,255,255,0.03) 1px,transparent 1px,transparent 40px),
    repeating-linear-gradient(90deg,rgba(255,255,255,0.03) 0,rgba(255,255,255,0.03) 1px,transparent 1px,transparent 40px);
  border:1px solid rgba(201,168,76,0.15);border-radius:8px;overflow:hidden;
}
.le-item{
  position:absolute;cursor:grab;
  border-radius:6px;border:2px solid;
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  font-family:'Raleway',sans-serif;
  box-sizing:border-box;transition:box-shadow .12s;
  user-select:none;-webkit-user-select:none;
  touch-action:none;
}
.le-item:active{cursor:grabbing;box-shadow:0 6px 20px rgba(0,0,0,0.5);z-index:100}
.le-item.selected{outline:2px solid var(--gold2);outline-offset:2px}
.le-stage-item{
  background:rgba(201,168,76,0.14)!important;
  border-color:rgba(201,168,76,0.6)!important;
  border-style:dashed!important;
  border-width:2px!important;
}
.le-item .li-name{font-size:9px;font-weight:800;letter-spacing:0.8px;text-align:center;pointer-events:none}
.le-size-row{display:flex;gap:6px;align-items:center;flex-wrap:wrap;margin-bottom:10px}
.le-size-row label{font-size:10px;color:var(--muted)}
.le-size-row input{
  width:60px;background:var(--bg2);border:1px solid rgba(201,168,76,0.2);
  border-radius:5px;padding:5px 7px;color:var(--text);font-size:11px;
  font-family:'Raleway',sans-serif;outline:none;text-align:center;
}
.le-hint{font-size:10px;color:var(--muted);margin-top:6px;letter-spacing:0.3px}

/* ===== TOAST NOTIFICATION ===== */
.notif-toast{
  position:fixed;bottom:24px;right:20px;
  background:rgba(14,14,14,0.97);
  border:1px solid rgba(201,168,76,0.55);
  color:var(--gold2);padding:12px 18px;border-radius:8px;
  font-size:12px;font-family:'Raleway',sans-serif;font-weight:600;
  z-index:99999;opacity:0;transform:translateY(20px);
  transition:opacity 0.3s ease, transform 0.3s ease;
  box-shadow:0 6px 28px rgba(0,0,0,0.9),0 0 0 1px rgba(201,168,76,0.1);
  max-width:320px;letter-spacing:0.3px;line-height:1.5;
  pointer-events:none;
  display:flex;align-items:center;gap:4px;
}
.notif-toast.show{opacity:1;transform:translateY(0)}
@media(max-width:640px){.notif-toast{bottom:16px;right:12px;left:12px;max-width:none}}
