*{box-sizing:border-box;margin:0;padding:0}
body{font-family:'Segoe UI',system-ui,sans-serif;background:#f0f4f8;color:#1a2332;min-height:100vh;font-size:14px}
:root{--g:#0d6e42;--g2:#1a9e63;--gd:#0a5533;--gl:#e8f7f0;--b:#1d6fa4;--bl:#e0f0fb;--gr:#6b7280;--bd:#d1d5db;--card:#fff;--nav-start:#0a4a2e;--nav-end:#0d6e42;--login-start:#0a3d25;--login-mid:#0d6e42;--login-end:#1a9e63}
.hidden{display:none!important}

/* LOGIN */
#loginScreen{position:fixed;inset:0;background:linear-gradient(135deg,var(--login-start),var(--login-mid) 60%,var(--login-end));display:flex;align-items:center;justify-content:center;z-index:9000;padding:20px}
.login-card{background:#fff;border-radius:20px;padding:36px 32px;width:100%;max-width:380px;box-shadow:0 24px 64px rgba(0,0,0,.3)}
.login-logo{text-align:center;margin-bottom:24px}
.login-logo .licon{width:60px;height:60px;background:var(--gl);border-radius:16px;display:inline-flex;align-items:center;justify-content:center;font-size:30px;margin-bottom:10px;box-shadow:0 4px 12px rgba(13,110,66,.2)}
.login-logo h1{font-size:20px;font-weight:700;color:#111827}
.login-logo p{font-size:12px;color:var(--gr);margin-top:3px}
.lfield{margin-bottom:14px}
.lfield label{display:block;font-size:11px;font-weight:600;color:var(--gr);text-transform:uppercase;letter-spacing:.5px;margin-bottom:5px}
.lfield input{width:100%;padding:11px 14px;border:1.5px solid var(--bd);border-radius:10px;font-size:14px;outline:none;transition:border-color .2s}
.lfield input:focus{border-color:var(--g2);box-shadow:0 0 0 3px rgba(26,158,99,.1)}
.lfield-pw-wrap{position:relative}
.lfield .lfield-pw-wrap input{padding-right:44px}
.lfield-pw-toggle{position:absolute;right:4px;top:50%;transform:translateY(-50%);width:36px;height:36px;padding:0;border:none;background:transparent;border-radius:8px;color:var(--gr);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:color .15s,background .15s}
.lfield-pw-toggle:hover{background:#f3f4f6;color:#374151}
.lfield-pw-toggle:focus-visible{outline:2px solid var(--g2);outline-offset:1px}
.lfield-pw-toggle svg{width:20px;height:20px;display:block;flex-shrink:0}
.lfield-pw-toggle .pw-icon-eye-off{display:none}
.lfield-pw-toggle.is-visible .pw-icon-eye{display:none}
.lfield-pw-toggle.is-visible .pw-icon-eye-off{display:block}
.login-btn{width:100%;padding:13px;background:var(--g);color:#fff;border:none;border-radius:10px;font-size:14px;font-weight:700;cursor:pointer;transition:all .15s;margin-top:4px;letter-spacing:.3px}
.login-btn:hover{background:var(--gd);transform:translateY(-1px)}
.lerr{background:#fee2e2;color:#991b1b;border-radius:8px;padding:9px 12px;font-size:12px;margin-bottom:12px;display:none}
.login-ver{text-align:center;margin-top:16px;font-size:10px;color:#d1d5db}

/* NAV */
.nav{background:linear-gradient(135deg,var(--nav-start),var(--nav-end));display:flex;align-items:stretch;box-shadow:0 2px 8px rgba(0,0,0,.15)}
.nav-brand{color:#fff;padding:10px 14px;display:flex;align-items:center;gap:8px;font-weight:700;font-size:15px;flex-shrink:0}
.nav-brand .logo{background:#fff;border-radius:7px;width:28px;height:28px;display:flex;align-items:center;justify-content:center;font-size:15px}
.nav-tabs{display:flex;flex:1;overflow-x:auto}
.ntab{padding:10px 16px;color:rgba(255,255,255,.7);font-size:13px;font-weight:500;cursor:pointer;border-bottom:3px solid transparent;transition:all .15s;white-space:nowrap;background:none;border-top:none;border-left:none;border-right:none;text-decoration:none;display:inline-block}
.ntab-today{display:inline-flex;align-items:baseline;flex-wrap:wrap;gap:2px 5px;white-space:normal}
.ntab-today-main{white-space:nowrap}
.ntab-stay-date{font-size:10px;font-weight:700;opacity:.88;font-variant-numeric:tabular-nums;letter-spacing:.03em;color:rgba(255,255,255,.92)}
.ntab:not(.active) .ntab-stay-date{color:rgba(255,255,255,.65)}
.ntab-stay-date.hidden{display:none!important}
.ntab:hover{color:#fff;background:rgba(255,255,255,.1)}
.ntab.active{color:#fff;border-bottom-color:#fff;background:rgba(255,255,255,.12)}
.nav-right{display:flex;align-items:center;gap:8px;padding:0 10px;flex-shrink:0}
.nav-time{color:rgba(255,255,255,.9);font-size:12px;font-variant-numeric:tabular-nums}
.notif-wrap{position:relative;cursor:pointer;width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:rgba(255,255,255,.12);border-radius:7px;transition:background .15s}
.notif-wrap:hover{background:rgba(255,255,255,.22)}
.notif-dot{position:absolute;top:4px;right:4px;width:8px;height:8px;background:#f59e0b;border-radius:50%;border:2px solid var(--g);display:none}
.notif-dot.show{display:block}
.nav-user{display:flex;align-items:center;gap:5px;background:rgba(255,255,255,.15);border-radius:8px;padding:5px 10px;cursor:pointer;border:1px solid rgba(255,255,255,.2);transition:all .15s}
.nav-user:hover{background:rgba(255,255,255,.25)}
.nav-user-name{color:#fff;font-size:11px;font-weight:600;max-width:80px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.lang-btn{background:rgba(255,255,255,.2);border:1px solid rgba(255,255,255,.3);color:#fff;border-radius:6px;padding:4px 8px;cursor:pointer;font-size:11px;font-weight:600}

/* PAGES */
.page{display:none;padding:14px 16px}
.page.active{display:block}

/* DASHBOARD */
.dash-filter-hint{
  display:block;
  width:100%;
  max-width:100%;
  box-sizing:border-box;
  font-size:12px;
  line-height:1.5;
  color:#374151;
  margin:0 0 12px;
  padding:8px 14px;
  background:var(--gl);
  border-radius:12px;
  border:1px solid rgba(13,110,66,.2);
  border-left:4px solid var(--g);
  box-shadow:0 1px 3px rgba(13,110,66,.08);
}
.dash-filter-hint strong{font-weight:700;color:var(--gd)}
.dash{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:8px;margin-bottom:6px;width:100%;max-width:100%}
.dash-today{grid-template-columns:repeat(5,minmax(0,1fr))}
.dash-today .sc-dash-rooms{grid-column:span 1}
.dash-today .sc-dash-pax{grid-column:span 2}
.dash-today .sc-dash-comp{grid-column:span 2}
.tb-history{margin-bottom:10px}
.sc{background:var(--card);border-radius:10px;padding:11px 13px;box-shadow:0 1px 3px rgba(0,0,0,.07);border-left:4px solid transparent}
.sc-lbl{font-size:10px;color:var(--gr);font-weight:600;text-transform:uppercase;letter-spacing:.4px}
.sc-val{font-size:22px;font-weight:700;margin:3px 0 1px;line-height:1}
.sc-sub{font-size:10px;color:var(--gr)}
/* Merged dash cards — compact height */
.sc-dash-rooms,.sc-dash-pax,.sc-dash-resort,.sc-dash-villa{padding:0;overflow:hidden;border-radius:10px}
.sc-dash-rooms > .sc-lbl,.sc-dash-pax > .sc-lbl,.sc-dash-resort > .sc-lbl,.sc-dash-villa > .sc-lbl{display:block;text-align:center;font-weight:700;font-size:11px;letter-spacing:.42px;padding:7px 10px 6px;margin:0;border-bottom:1px solid rgba(0,0,0,.07);background:rgba(255,255,255,.5)}
.sc-dash-rooms > .sc-lbl{color:#0a5c38}
.sc-dash-pax > .sc-lbl{color:#1d4ed8;background:#dbeafe;border-bottom-color:rgba(29,78,216,.15)}
.sc-dash-resort > .sc-lbl{color:#14532d;background:rgba(255,255,255,.35);border-bottom-color:rgba(22,101,52,.12)}
.sc-dash-villa > .sc-lbl{color:#713f12;background:rgba(255,255,255,.4);border-bottom-color:rgba(146,64,14,.12)}
.sc-merge-2{display:grid;grid-template-columns:1fr 1fr;gap:0;margin:0;align-items:stretch}
.sc-merge-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:0;margin:0;align-items:stretch}
.sc-merge-4{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:0;margin:0;align-items:stretch}
.sc-merge-cell{min-width:0;padding:7px 10px}
.sc-merge-cell:not(:last-child){border-right:1px solid var(--bd)}
.sc-dash-resort .sc-merge-cell:not(:last-child){border-right-color:rgba(22,101,52,.18)}
.sc-dash-villa .sc-merge-cell:not(:last-child){border-right-color:rgba(180,130,70,.28)}
.sc-dash-rooms .sc-merge-cell:not(:last-child){border-right-color:rgba(13,110,66,.15)}
.sc-dash-pax .sc-merge-cell:not(:last-child){border-right-color:rgba(29,78,216,.2)}
.sc-merge-lbl{font-size:9px;color:var(--gr);font-weight:700;text-transform:uppercase;letter-spacing:.28px;margin-bottom:2px;text-align:center}
.sc-merge-val{font-size:20px;font-weight:700;line-height:1.1;margin:0 0 2px;text-align:center}
.sc-merge-cell .sc-sub{text-align:center;margin:0;line-height:1.3;font-size:10px;font-weight:600}
.sc-dash-rooms > .sc-sub{margin:0;padding:6px 10px;border-top:1px solid var(--bd);text-align:center;background:rgba(249,250,251,.85);font-size:10px;font-weight:600}
.sc-dash-pax > .sc-sub{margin:0;padding:6px 10px;border-top:1px solid rgba(29,78,216,.2);text-align:center;background:#dbeafe;font-size:10px;font-weight:600;color:#1e40af}
.sc-dash-rooms{border:1px solid rgba(13,110,66,.22);border-left:3px solid var(--g);box-shadow:0 1px 3px rgba(13,110,66,.08)}
.sc-dash-rooms .sc-merge-val{color:var(--g)}
.sc-dash-pax{background:#eff6ff;border:1px solid rgba(59,130,246,.35);border-left:3px solid #1d4ed8;box-shadow:0 1px 3px rgba(29,78,216,.1)}
.sc-dash-pax .sc-merge-val{color:#1d4ed8}
.sc-dash-rooms-val{font-size:28px;font-weight:700;padding:6px 10px;text-align:center;line-height:1.1;color:var(--g)}
#page-today > .svc-stats-today{margin-bottom:10px}
.sc-dash-resort{background:#ecfdf5;border:1px solid rgba(74,222,128,.4);border-left:3px solid #4ade80;box-shadow:0 1px 3px rgba(34,197,94,.1)}
.sc-dash-resort .sc-merge-val{color:#166534}
.sc-dash-resort .sc-sub{color:#15803d}
.sc-dash-villa{background:#faf6f1;border:1px solid rgba(196,165,116,.45);border-left:3px solid #b8956a;box-shadow:0 1px 3px rgba(180,130,70,.1)}
.sc-dash-villa .sc-merge-val{color:#92400e}
.sc-dash-villa .sc-sub{color:#a16207}
.sc-dash-comp{background:#fdf4ff;border:1px solid rgba(168,85,247,.3);border-left:3px solid #a855f7;box-shadow:0 1px 3px rgba(168,85,247,.1);padding:0;overflow:hidden;border-radius:10px}
.sc-dash-comp > .sc-lbl{display:block;text-align:center;font-weight:700;font-size:11px;letter-spacing:.42px;padding:7px 10px 6px;margin:0;border-bottom:1px solid rgba(168,85,247,.15);background:rgba(250,245,255,.7);color:#7c3aed}
.sc-dash-comp .sc-merge-val{color:#6d28d9}
.sc-dash-comp .sc-sub{color:#7c3aed}
.sc-dash-comp .sc-merge-cell:first-child{border-right-color:rgba(168,85,247,.2)}
.svc-stats{display:flex;gap:6px;flex-wrap:wrap;padding:0 0 7px;align-items:center}
.svc-stat{display:inline-flex;align-items:center;gap:3px;background:var(--card);border:1px solid var(--bd);border-radius:8px;padding:2px 8px;font-size:11px;font-weight:600;color:var(--gr)}
.svc-stat .sn{color:#111827;font-weight:700}
.svc-stats-today{
  flex-direction:row;
  align-items:center;
  flex-wrap:wrap;
  gap:6px;
  padding:0;
  margin:0;
}
.svc-stats-flow{display:flex;flex-wrap:wrap;align-items:center;gap:6px}
.svc-stats-today .svc-stat{
  gap:3px;
  padding:3px 9px;
  border-radius:999px;
  font-size:11px;
  border-color:rgba(0,0,0,.08);
  background:#f9fafb;
  transition:border-color .15s,background .15s;
}
.svc-stats-today .svc-stat .sn{font-size:12px;font-weight:800;color:var(--g)}
.prog-wrap{margin-bottom:8px}
.prog-bar{height:5px;background:#e5e7eb;border-radius:3px;overflow:hidden}
.prog-fill{height:100%;background:linear-gradient(90deg,var(--g),var(--g2));border-radius:3px;transition:width .4s}
.prog-label{font-size:10px;color:var(--gr);margin-top:3px;text-align:right}

/* AUTO-IMPORT BANNER */
.aib{border-radius:10px;padding:11px 14px;margin-bottom:10px;display:flex;align-items:center;gap:10px;font-size:12px;border:1.5px solid;transition:all .3s}
.aib.idle{background:#f9fafb;border-color:#e5e7eb;color:var(--gr)}
.aib.running{background:#eff6ff;border-color:#bfdbfe;color:#1e40af}
.aib.success{background:#f0fdf4;border-color:#bbf7d0;color:#065f46}
.aib.error{background:#fef2f2;border-color:#fecaca;color:#991b1b}
.aib-icon{font-size:20px;flex-shrink:0}
.aib-text{flex:1}
.aib-title{font-weight:600;margin-bottom:2px}
.aib-sub{font-size:10px;opacity:.8}
.aib-time{font-size:10px;opacity:.7;white-space:nowrap;flex-shrink:0}
@keyframes spin{to{transform:rotate(360deg)}}
.spin{display:inline-block;animation:spin .8s linear infinite}

/* IMPORT ZONE */
.imp-zone{border:2px dashed var(--bd);border-radius:10px;padding:12px;text-align:center;cursor:pointer;background:#fafafa;margin-bottom:10px;transition:all .2s}
.imp-zone:hover{border-color:var(--g2);background:var(--gl)}

/* TOOLBAR */
.tb{display:flex;align-items:center;gap:7px;margin-bottom:9px;flex-wrap:wrap}
.tb-today{
  align-items:flex-end;
  gap:8px 10px;
  row-gap:10px;
  padding:9px 12px;
  background:var(--card);
  border-radius:12px;
  border:1px solid rgba(0,0,0,.06);
  box-shadow:0 1px 3px rgba(0,0,0,.07);
  margin-bottom:10px;
}
.tb-field{display:flex;flex-direction:column;gap:3px;min-width:0}
.tb-lbl{font-size:10px;font-weight:600;color:var(--gr);text-transform:uppercase;letter-spacing:.35px;line-height:1.2}
.tb-inline{display:flex;align-items:stretch;gap:6px}
.tb-field-grow{flex:1;min-width:min(100%,140px)}
.tb-sinput-name{width:100%;min-width:0;max-width:min(100%,240px)}
.tb-today .sinput{padding:6px 9px}
.tb-today .tb-btn-action{padding:6px 10px;font-size:11px}
.tb-date{width:100%;min-width:132px;max-width:155px;font-size:12px;padding:6px 9px}
.tb-fsel{min-width:0;max-width:160px;padding:6px 9px}
.tb-sep{align-self:stretch;width:1px;min-height:34px;background:var(--bd);flex-shrink:0;margin:0 2px;display:none}
@media (min-width:960px){
  .tb-sep{display:block}
}
.tb-actions{display:flex;flex-wrap:wrap;align-items:center;gap:8px;margin-left:auto}
@media (max-width:640px){
  .tb-actions{width:100%;margin-left:0;justify-content:flex-start;border-top:1px solid rgba(0,0,0,.06);margin-top:2px;padding-top:10px}
}
.tb-btn-icon{padding:6px 9px;min-width:36px;justify-content:center}
.tb-btn-action svg{flex-shrink:0;opacity:.9}
.room-wrap{position:relative}
.room-wrap input{width:140px;padding:8px 10px 8px 32px;border:1.5px solid var(--bd);border-radius:8px;font-size:14px;font-weight:600;outline:none;background:#fff;transition:border-color .2s}
.room-wrap-tb input{min-width:0;width:240px;padding:6px 9px 6px 32px;font-size:13px}
.room-wrap input:focus{border-color:var(--g2)}
.room-wrap .ri{position:absolute;left:9px;top:50%;transform:translateY(-50%);font-size:13px;color:var(--gr);pointer-events:none}
.tb-ri-svg{display:flex;align-items:center;justify-content:center;left:8px}
.tb-ri-svg svg{width:16px;height:16px;color:var(--gr)}
.btn{padding:7px 11px;border-radius:8px;border:none;font-size:12px;font-weight:600;cursor:pointer;transition:all .15s;display:flex;align-items:center;gap:4px;white-space:nowrap}
.btn-g{background:var(--g);color:#fff}.btn-g:hover{background:var(--gd)}
.btn-out{background:#fff;border:1.5px solid var(--bd);color:#374151}.btn-out:hover{border-color:var(--g2)}
.btn-blue{background:var(--bl);color:var(--b);border:1.5px solid #93c5fd}
.btn-red{background:#fee2e2;color:#dc2626;border:1.5px solid #fca5a5}
.btn-amber{background:#fffbeb;color:#92400e;border:1.5px solid #fde68a}
.fsel{padding:7px 9px;border:1.5px solid var(--bd);border-radius:8px;font-size:12px;background:#fff;color:#374151;outline:none;cursor:pointer}
.sinput{padding:7px 10px;border:1.5px solid var(--bd);border-radius:8px;font-size:12px;background:#fff;outline:none;width:130px}

/* MODAL */
.ov{position:fixed;inset:0;background:rgba(0,0,0,.52);z-index:1000;display:flex;align-items:center;justify-content:center;padding:10px}
.modal{background:#fff;border-radius:16px;width:100%;max-width:500px;box-shadow:0 20px 60px rgba(0,0,0,.25);overflow:hidden;max-height:96vh;overflow-y:auto}
.mhdr{background:linear-gradient(135deg,var(--nav-start),var(--nav-end));color:#fff;padding:14px 18px;display:flex;justify-content:space-between;align-items:center;position:sticky;top:0;z-index:10}
.mhdr h2{font-size:15px;font-weight:600}
.mclose{background:rgba(255,255,255,.22);border:none;color:#fff;width:26px;height:26px;border-radius:50%;cursor:pointer;font-size:14px;display:flex;align-items:center;justify-content:center}
.mbody{padding:16px 18px}
.gi{background:var(--gl);border:1.5px solid #a7f3d0;border-radius:11px;padding:12px 14px;margin-bottom:12px}
.gi-top{display:flex;align-items:center;gap:8px;margin-bottom:4px}
.gi-rm{font-size:26px;font-weight:800;color:var(--g)}
.gi-name{font-size:14px;font-weight:700;color:#111827;margin-bottom:2px}
.gi-meta{font-size:11px;color:var(--gr)}
.incl-row{display:flex;justify-content:space-between;align-items:center;background:#f0fdf4;border:1.5px solid #bbf7d0;border-radius:8px;padding:8px 12px;margin-bottom:12px}
.incl-lbl{font-size:11px;font-weight:600;color:#166534}
.incl-val{font-size:17px;font-weight:800;color:var(--g)}
.ben-grid{display:grid;grid-template-columns:1fr 1fr;gap:7px;margin-bottom:12px}
.bc{border-radius:9px;padding:9px 11px;display:flex;align-items:center;gap:8px;border:1.5px solid transparent}
.bc-icon{font-size:18px;flex-shrink:0}
.bc-lbl{font-size:9px;font-weight:600;text-transform:uppercase;letter-spacing:.3px;opacity:.7}
.bc-val{font-size:13px;font-weight:800;line-height:1.2}
.bc-abf{background:#f0fdf4;border-color:#bbf7d0}.bc-abf .bc-val,.bc-abf .bc-lbl{color:#065f46}
.bc-spa{background:#fdf4ff;border-color:#e9d5ff}.bc-spa .bc-val,.bc-spa .bc-lbl{color:#6b21a8}
.bc-pick{background:#eff6ff;border-color:#bfdbfe}.bc-pick .bc-val,.bc-pick .bc-lbl{color:#1e40af}
.bc-tea{background:#fffbeb;border-color:#fde68a}.bc-tea .bc-val,.bc-tea .bc-lbl{color:#92400e}
.bc-fb{background:#f0fdf4;border-color:#a7f3d0}.bc-fb .bc-val,.bc-fb .bc-lbl{color:#065f46}
.bc-msg{background:#f5f3ff;border-color:#ddd6fe}.bc-msg .bc-val,.bc-msg .bc-lbl{color:#4c1d95}
.bc-hon{background:#fff1f2;border-color:#fecdd3}.bc-hon .bc-val,.bc-hon .bc-lbl{color:#9f1239}
.cnt-row{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:12px}
.cnt-grp label{font-size:10px;font-weight:600;color:var(--gr);text-transform:uppercase;letter-spacing:.4px;display:block;margin-bottom:5px}
.cnt-ctrl{display:flex;align-items:center;gap:7px;background:#f9fafb;border-radius:9px;padding:5px 9px;border:1.5px solid var(--bd)}
.cnt-ctrl button{width:28px;height:28px;border-radius:7px;border:none;font-size:16px;font-weight:700;cursor:pointer}
.bminus{background:#fee2e2;color:#dc2626}.bplus{background:#dcfce7;color:#16a34a}
.cnt-num{font-size:20px;font-weight:800;min-width:32px;text-align:center;color:#111827}
.svc-section{margin-bottom:12px}
.svc-title{font-size:10px;font-weight:700;color:var(--gr);text-transform:uppercase;letter-spacing:.5px;margin-bottom:7px}
.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:6px}
.svc-check{display:flex;align-items:center;gap:6px;padding:7px 10px;border-radius:8px;border:1.5px solid var(--bd);cursor:pointer;transition:all .15s;background:#fff;user-select:none}
.svc-check:hover{border-color:var(--g2)}
.svc-check.checked{background:var(--gl);border-color:#10b981}
.svc-check input{display:none}
.svc-check .svc-ico{font-size:14px}
.svc-check .svc-nm{font-size:11px;font-weight:500;color:#374151}
.svc-check.checked .svc-nm{color:#065f46;font-weight:600}
.note-sec{margin-bottom:12px}
.note-toggle{display:flex;align-items:center;gap:6px;font-size:10px;font-weight:600;color:var(--gr);text-transform:uppercase;cursor:pointer;padding:7px 10px;background:#f9fafb;border-radius:8px;border:1.5px solid var(--bd);transition:all .15s}
.note-toggle:hover{border-color:var(--g2)}
.note-arrow{margin-left:auto;transition:transform .2s}.note-arrow.open{transform:rotate(180deg)}
.note-box{background:#f9fafb;border:1px solid var(--bd);border-radius:8px;padding:10px 12px;font-size:11px;color:#374151;line-height:1.75;max-height:160px;overflow-y:auto;margin-top:5px;white-space:pre-wrap;word-break:break-word}
.mftr{padding:0 18px 16px;display:flex;gap:8px}
.bconfirm{flex:1;padding:11px;background:var(--g);color:#fff;border:none;border-radius:10px;font-size:13px;font-weight:700;cursor:pointer}
.bconfirm:hover{background:var(--gd)}
.bcancel{padding:11px 16px;background:#f3f4f6;color:#374151;border:none;border-radius:10px;font-size:13px;font-weight:600;cursor:pointer}
.bundo{padding:11px;background:#fee2e2;color:#dc2626;border:none;border-radius:10px;font-size:13px;font-weight:700;cursor:pointer;flex:1}
.rc-badge{font-size:9px;font-weight:700;padding:2px 6px;border-radius:10px;display:inline-block}
.rc-fr{background:#dbeafe;color:#1e40af}.rc-fv{background:#ede9fe;color:#6d28d9}

/* TABLE */
.tbl-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch;width:100%;max-width:100%}
.tbl-card{background:var(--card);border-radius:10px;box-shadow:0 1px 3px rgba(0,0,0,.07);overflow-x:auto;-webkit-overflow-scrolling:touch}
table{width:100%;border-collapse:collapse;font-size:14px}
.guest-list th:not(:last-child),
.guest-list td:not(:last-child){border-right:1px solid #e2e8e0}
.guest-list th.col-num,
.guest-list td.col-num{
  width:1%;
  max-width:34px;
  min-width:26px;
  padding-left:3px;
  padding-right:3px;
  text-align:center;
  vertical-align:middle;
  white-space:nowrap;
  font-variant-numeric:tabular-nums;
}
.guest-list th.col-num{font-size:10px;line-height:1.2;letter-spacing:.02em;padding-top:8px;padding-bottom:8px}
.guest-list td.col-num{color:#9ca3af;font-size:10px}
.guest-list th.col-guest,
.guest-list td.col-guest{width:1%;min-width:79px;max-width:176px}
.guest-list td.col-guest{word-break:break-word}
.guest-list th.col-benefits,
.guest-list td.col-benefits{min-width:445px;max-width:603px;width:33.6%}
.guest-list td.col-benefits .pill-row{max-width:none}
.guest-list td.col-benefits .ben-udfc{
  margin-bottom:4px;
  display:flex;
  align-items:baseline;
  gap:5px;
  min-width:0;
  max-width:100%;
  cursor:default;
}
.guest-list td.col-benefits .ben-udfc-lbl{
  flex-shrink:0;
  font-size:10px;
  font-weight:700;
  color:#64748b;
  text-transform:uppercase;
  letter-spacing:.04em;
}
.guest-list td.col-benefits .ben-udfc-txt{
  flex:1;
  min-width:0;
  font-size:11px;
  line-height:1.2;
  color:#374151;
  word-break:break-word;
  overflow:hidden;
  display:-webkit-box;
  -webkit-box-orient:vertical;
  -webkit-line-clamp:2;
}
.guest-list th.col-abf,
.guest-list td.col-abf{
  width:1%;
  max-width:40px;
  min-width:34px;
  padding-left:4px;
  padding-right:4px;
  text-align:center;
  vertical-align:middle;
  white-space:nowrap;
}
.guest-list th.col-abf{font-size:10px;line-height:1.2;letter-spacing:.02em;padding-top:8px;padding-bottom:8px}
.udfc-tag{display:inline-block;font-size:10px;font-weight:700;padding:1px 5px;border-radius:4px;vertical-align:baseline;line-height:1.4;white-space:nowrap}
.udfc-tag-comp{background:#fce7f3;color:#9d174d;border:1px solid #fbcfe8}
.udfc-tag-voucher{background:#ede9fe;color:#5b21b6;border:1px solid #ddd6fe}
.guest-list th.col-room,
.guest-list td.col-room{width:1%;max-width:68px;min-width:48px;padding-left:5px;padding-right:5px;text-align:center;vertical-align:middle}
.guest-list th.col-room{font-size:11px;letter-spacing:.02em;padding:8px 4px}
.guest-list td.col-room .rm-badge{max-width:100%;overflow:hidden;text-overflow:ellipsis;vertical-align:middle}
.guest-list th.col-class,
.guest-list td.col-class{width:1%;max-width:66px;min-width:52px;padding-left:4px;padding-right:4px;text-align:center;white-space:nowrap}
.guest-list th.col-class{font-size:11px;letter-spacing:.02em;padding:8px 4px}
.guest-list th.col-adult,
.guest-list td.col-adult{width:1%;max-width:61px;min-width:49px;padding-left:4px;padding-right:4px;text-align:center;white-space:nowrap}
.guest-list th.col-adult{font-size:11px;letter-spacing:.02em;padding:8px 4px}
.guest-list th.col-children,
.guest-list td.col-children{width:1%;max-width:61px;min-width:49px;padding-left:4px;padding-right:4px;text-align:center;white-space:nowrap}
.guest-list th.col-children{font-size:11px;letter-spacing:.02em;padding:8px 4px}
.guest-list th.col-infant,
.guest-list td.col-infant{width:1%;max-width:56px;min-width:44px;padding-left:4px;padding-right:4px;text-align:center;white-space:nowrap}
.guest-list th.col-infant{font-size:11px;letter-spacing:.02em;padding:8px 4px}
.guest-list th.col-stay-dates,
.guest-list td.col-stay-dates{width:1%;min-width:100px;max-width:124px;padding-left:6px;padding-right:6px;vertical-align:middle}
.guest-list th.col-stay-dates{
  font-size:9px;
  line-height:1.25;
  padding:8px 5px;
  letter-spacing:.02em;
  white-space:normal;
  text-align:left;
  text-transform:uppercase;
}
.guest-list td.col-stay-dates{color:#6b7280}
.guest-list .stay-dates-stack{display:flex;flex-direction:column;gap:4px;line-height:1.35}
.guest-list .stay-dates-stack .sd-row{font-size:14px;font-variant-numeric:tabular-nums}
.guest-list .stay-dates-stack .sd-arr{color:#374151;font-weight:600}
.guest-list .stay-dates-stack .sd-dep{color:#4b5563;font-size:13px;font-weight:500}
.guest-list .stay-dates-stack .sd-ci{font-size:12px;font-weight:600;color:#15803d;white-space:nowrap}
thead{background:#f8faf9;border-bottom:2px solid #d1fae5}
th{padding:8px 9px;text-align:left;font-weight:600;font-size:12px;text-transform:uppercase;letter-spacing:.4px;color:#374151;white-space:nowrap}
td{padding:7px 9px;border-bottom:1px solid #f3f4f6;vertical-align:middle}
tr:last-child td{border-bottom:none}
tr:hover td{background:#fafffe}
tr.ci-row td{background:#f0fdf4}
tr.ci-row:hover td{background:#dcfce7}
.rm-badge{display:inline-block;font-weight:700;font-size:13px;padding:2px 8px;border-radius:5px}
.rm-fr{background:#dbeafe;color:#1e40af}.rm-fv{background:#ede9fe;color:#5b21b6}
.rc-badge{font-size:11px;font-weight:700;padding:2px 6px;border-radius:10px;display:inline-block}
.rc-fr{background:#dbeafe;color:#1e40af}.rc-fv{background:#ede9fe;color:#6d28d9}
.nb{display:inline-flex;align-items:center;justify-content:center;width:20px;height:20px;border-radius:4px;font-size:12px;font-weight:700}
.nb-a{background:#dbeafe;color:#1d4ed8}.nb-c{background:#fef3c7;color:#92400e}
.pill{display:inline-flex;align-items:center;gap:2px;font-size:11px;font-weight:600;padding:1px 5px;border-radius:8px;white-space:nowrap}
.p-abf{background:#dcfce7;color:#166534}.p-spa{background:#fdf4ff;color:#6b21a8}
.p-pick{background:#eff6ff;color:#1e40af}.p-tea{background:#fffbeb;color:#92400e}
.p-fb{background:#f0fdf4;color:#065f46}.p-msg{background:#f5f3ff;color:#4c1d95}
.pill-row{display:flex;flex-wrap:wrap;gap:2px;max-width:180px}
.nm{font-weight:600;font-size:14px;color:#111827}.nm-sub{font-size:12px;color:var(--gr)}
.guest-list th.col-identity,
.guest-list td.col-identity{display:none}
.cell-identity{display:flex;flex-direction:column;gap:1px;font-size:11px;line-height:1.35;color:#374151}
.cell-identity .id-line{display:flex;align-items:baseline;gap:5px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.cell-identity .id-lbl{flex-shrink:0;font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:.04em;color:#9ca3af;min-width:32px}
.id-dash{color:#d1d5db}
.guest-list th.col-bnote,
.guest-list td.col-bnote{min-width:180px;max-width:280px;width:1%;vertical-align:top;padding:6px 8px}
.cell-bnote{font-size:11px;line-height:1.35;color:#4b5563;max-height:54px;overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;padding:3px 6px;background:rgba(99,102,241,.06);border-left:2px solid #818cf8;border-radius:3px;cursor:help}
.sd{display:inline-flex;align-items:center;gap:3px;font-size:12px;font-weight:600;padding:2px 7px;border-radius:10px}
.sd-w{background:#f1f5f9;color:#475569}.sd-i{background:#dcfce7;color:#166534}
.ci-btn{padding:4px 9px;border-radius:6px;font-size:12px;font-weight:600;border:none;cursor:pointer;transition:all .15s}
.ci-w{background:var(--g);color:#fff}.ci-d{background:#dcfce7;color:#166534}.ci-view{background:#e0e7ff;color:#3730a3}
.svc-used{display:inline-flex;align-items:center;gap:3px;font-size:9px;font-weight:600;padding:2px 6px;border-radius:8px}
.svc-spa{background:#fdf4ff;color:#6b21a8;border:1px solid #e9d5ff}
.svc-tea{background:#fffbeb;color:#92400e;border:1px solid #fde68a}
.svc-msg{background:#f5f3ff;color:#4c1d95;border:1px solid #ddd6fe}
.svc-fb{background:#ecfdf5;color:#065f46;border:1px solid #a7f3d0}
.svc-other{background:#f9fafb;color:#374151;border:1px solid #e5e7eb}
.svc-row{display:flex;flex-wrap:wrap;gap:2px}

/* MODAL */
.ov{position:fixed;inset:0;background:rgba(0,0,0,.52);z-index:1000;display:flex;align-items:center;justify-content:center;padding:10px}
.modal{background:#fff;border-radius:16px;width:100%;max-width:500px;box-shadow:0 20px 60px rgba(0,0,0,.25);overflow:hidden;max-height:96vh;overflow-y:auto}
.mhdr{background:linear-gradient(135deg,var(--nav-start),var(--nav-end));color:#fff;padding:14px 18px;display:flex;justify-content:space-between;align-items:center;position:sticky;top:0;z-index:10}
.mhdr h2{font-size:15px;font-weight:600}
.mclose{background:rgba(255,255,255,.22);border:none;color:#fff;width:26px;height:26px;border-radius:50%;cursor:pointer;font-size:14px;display:flex;align-items:center;justify-content:center}
.mbody{padding:16px 18px}
.gi{background:var(--gl);border:1.5px solid #a7f3d0;border-radius:11px;padding:12px 14px;margin-bottom:12px}
.gi-top{display:flex;align-items:center;gap:8px;margin-bottom:4px}
.gi-rm{font-size:26px;font-weight:800;color:var(--g)}
.gi-name{font-size:14px;font-weight:700;color:#111827;margin-bottom:2px}
.gi-meta{font-size:11px;color:var(--gr)}
.incl-row{display:flex;justify-content:space-between;align-items:center;background:#f0fdf4;border:1.5px solid #bbf7d0;border-radius:8px;padding:8px 12px;margin-bottom:12px}
.incl-lbl{font-size:11px;font-weight:600;color:#166534}
.incl-val{font-size:17px;font-weight:800;color:var(--g)}
.ben-grid{display:grid;grid-template-columns:1fr 1fr;gap:7px;margin-bottom:12px}
.bc{border-radius:9px;padding:9px 11px;display:flex;align-items:center;gap:8px;border:1.5px solid transparent}
.bc-icon{font-size:18px;flex-shrink:0}
.bc-lbl{font-size:9px;font-weight:600;text-transform:uppercase;letter-spacing:.3px;opacity:.7}
.bc-val{font-size:13px;font-weight:800;line-height:1.2}
.bc-abf{background:#f0fdf4;border-color:#bbf7d0}.bc-abf .bc-val,.bc-abf .bc-lbl{color:#065f46}
.bc-spa{background:#fdf4ff;border-color:#e9d5ff}.bc-spa .bc-val,.bc-spa .bc-lbl{color:#6b21a8}
.bc-pick{background:#eff6ff;border-color:#bfdbfe}.bc-pick .bc-val,.bc-pick .bc-lbl{color:#1e40af}
.bc-tea{background:#fffbeb;border-color:#fde68a}.bc-tea .bc-val,.bc-tea .bc-lbl{color:#92400e}
.bc-fb{background:#f0fdf4;border-color:#a7f3d0}.bc-fb .bc-val,.bc-fb .bc-lbl{color:#065f46}
.bc-msg{background:#f5f3ff;border-color:#ddd6fe}.bc-msg .bc-val,.bc-msg .bc-lbl{color:#4c1d95}
.bc-hon{background:#fff1f2;border-color:#fecdd3}.bc-hon .bc-val,.bc-hon .bc-lbl{color:#9f1239}
.cnt-row{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:12px}
.cnt-grp label{font-size:10px;font-weight:600;color:var(--gr);text-transform:uppercase;letter-spacing:.4px;display:block;margin-bottom:5px}
.cnt-ctrl{display:flex;align-items:center;gap:7px;background:#f9fafb;border-radius:9px;padding:5px 9px;border:1.5px solid var(--bd)}
.cnt-ctrl button{width:28px;height:28px;border-radius:7px;border:none;font-size:16px;font-weight:700;cursor:pointer}
.bminus{background:#fee2e2;color:#dc2626}.bplus{background:#dcfce7;color:#16a34a}
.cnt-num{font-size:20px;font-weight:800;min-width:32px;text-align:center;color:#111827}
.svc-section{margin-bottom:12px}
.svc-title{font-size:10px;font-weight:700;color:var(--gr);text-transform:uppercase;letter-spacing:.5px;margin-bottom:7px}
.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:6px}
.svc-check{display:flex;align-items:center;gap:6px;padding:7px 10px;border-radius:8px;border:1.5px solid var(--bd);cursor:pointer;transition:all .15s;background:#fff;user-select:none}
.svc-check:hover{border-color:var(--g2)}
.svc-check.checked{background:var(--gl);border-color:#10b981}
.svc-check input{display:none}
.svc-check .svc-ico{font-size:14px}
.svc-check .svc-nm{font-size:11px;font-weight:500;color:#374151}
.svc-check.checked .svc-nm{color:#065f46;font-weight:600}
.note-sec{margin-bottom:12px}
.note-toggle{display:flex;align-items:center;gap:6px;font-size:10px;font-weight:600;color:var(--gr);text-transform:uppercase;cursor:pointer;padding:7px 10px;background:#f9fafb;border-radius:8px;border:1.5px solid var(--bd);transition:all .15s}
.note-toggle:hover{border-color:var(--g2)}
.note-arrow{margin-left:auto;transition:transform .2s}.note-arrow.open{transform:rotate(180deg)}
.note-box{background:#f9fafb;border:1px solid var(--bd);border-radius:8px;padding:10px 12px;font-size:11px;color:#374151;line-height:1.75;max-height:160px;overflow-y:auto;margin-top:5px;white-space:pre-wrap;word-break:break-word}
.mftr{padding:0 18px 16px;display:flex;gap:8px}
.bconfirm{flex:1;padding:11px;background:var(--g);color:#fff;border:none;border-radius:10px;font-size:13px;font-weight:700;cursor:pointer}
.bconfirm:hover{background:var(--gd)}
.bcancel{padding:11px 16px;background:#f3f4f6;color:#374151;border:none;border-radius:10px;font-size:13px;font-weight:600;cursor:pointer}
.bundo{padding:11px;background:#fee2e2;color:#dc2626;border:none;border-radius:10px;font-size:13px;font-weight:700;cursor:pointer;flex:1}

/* SETTINGS */
.settings-wrap{max-width:none}
.settings-tabs{display:flex;gap:4px;margin-bottom:16px;background:var(--card);border-radius:10px;padding:4px;border:1px solid var(--bd);overflow-x:auto;-webkit-overflow-scrolling:touch}
.settings-tab{padding:8px 16px;border:none;background:transparent;border-radius:7px;font-size:12px;font-weight:600;color:#6b7280;cursor:pointer;white-space:nowrap;transition:all .2s}
.settings-tab:hover{background:#f3f4f6;color:#374151}
.settings-tab.active{background:var(--g,#0d6e42);color:#fff;box-shadow:0 1px 3px rgba(0,0,0,.15)}
.settings-panel{display:none}
.settings-panel.active{display:block}
.scard{background:var(--card);border-radius:12px;padding:16px 18px;margin-bottom:12px;border:1px solid var(--bd);box-shadow:0 1px 3px rgba(0,0,0,.06)}
.scard h3{font-size:14px;font-weight:600;color:#111827;margin-bottom:12px;display:flex;align-items:center;gap:7px}
.srow{display:flex;align-items:center;justify-content:space-between;padding:9px 0;border-bottom:1px solid #f3f4f6}
.srow:last-child{border-bottom:none;padding-bottom:0}
.srow-lbl{font-size:13px;color:#374151;font-weight:500}
.srow-sub{font-size:11px;color:var(--gr);margin-top:2px}
.toggle-wrap{position:relative;width:38px;height:22px;flex-shrink:0}
.toggle-wrap input{opacity:0;width:0;height:0;position:absolute}
.toggle-slider{position:absolute;inset:0;background:#d1d5db;border-radius:11px;transition:background .2s;cursor:pointer}
.toggle-slider:before{content:'';position:absolute;width:16px;height:16px;background:#fff;border-radius:50%;top:3px;left:3px;transition:transform .2s}
.toggle-wrap input:checked+.toggle-slider{background:var(--g)}
.toggle-wrap input:checked+.toggle-slider:before{transform:translateX(16px)}
.sinp{padding:7px 10px;border:1.5px solid var(--bd);border-radius:8px;font-size:12px;background:#fff;outline:none}
.sinp:focus{border-color:var(--g2)}

/* USER TABLE */
.utbl{width:100%;border-collapse:collapse;font-size:14px;margin-top:8px}
.utbl th{background:#f8faf9;padding:7px 10px;text-align:left;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.4px;color:var(--gr);border-bottom:1px solid #e5e7eb}
.utbl td{padding:8px 10px;border-bottom:1px solid #f3f4f6}
.utbl tr:last-child td{border-bottom:none}

/* Badges */
.badge{padding:2px 8px;border-radius:12px;font-size:10px;font-weight:600;text-transform:uppercase}
.badge-excel{background:#e0f0fb;color:#1d6fa4}
.badge-gmail{background:#fee2e2;color:#dc2626}
.rpill{display:inline-block;font-size:10px;font-weight:700;padding:2px 8px;border-radius:10px}
.radmin{background:#dcfce7;color:#065f46}.rstaff{background:#dbeafe;color:#1e40af}

/* GMAIL STATUS */
.gmail-box{border-radius:10px;padding:12px 14px;margin-bottom:12px;border:1.5px solid;display:flex;align-items:center;gap:10px}
.gmail-connected{background:#f0fdf4;border-color:#bbf7d0}
.gmail-disconnected{background:#f9fafb;border-color:#e5e7eb}
.gmail-btn{width:100%;display:flex;align-items:center;justify-content:center;gap:8px;padding:10px 14px;border:1.5px solid var(--bd);border-radius:9px;background:#fff;cursor:pointer;font-size:13px;font-weight:500;color:#374151;transition:all .15s}
.gmail-btn:hover{border-color:#4285f4;color:#4285f4;box-shadow:0 2px 8px rgba(66,133,244,.15)}
.glog{background:#1e293b;border-radius:8px;padding:10px 12px;font-family:monospace;font-size:10px;color:#6ee7b7;margin-top:8px;max-height:100px;overflow-y:auto;line-height:1.8}

/* NFC API */
.api-endpoint{background:#1e293b;border-radius:8px;padding:10px 14px;font-family:monospace;font-size:11px;color:#6ee7b7;margin:8px 0;overflow-x:auto;white-space:nowrap}
.api-key-row{display:flex;gap:7px;align-items:center;margin-top:8px}
.api-key-input{flex:1;padding:7px 10px;border:1.5px solid var(--bd);border-radius:8px;font-size:11px;font-family:monospace;background:#f9fafb;outline:none;color:#374151}
.cbtn{padding:6px 12px;border:1.5px solid var(--bd);border-radius:7px;background:#fff;font-size:11px;font-weight:600;cursor:pointer;color:#374151;white-space:nowrap;transition:all .15s}
.cbtn:hover{border-color:var(--g2);color:var(--g)}
.nfc-test{width:100%;padding:10px;background:linear-gradient(135deg,#1e293b,#334155);color:#6ee7b7;border:none;border-radius:9px;font-size:12px;font-weight:600;cursor:pointer;margin-top:8px;font-family:monospace;transition:opacity .15s}
.nfc-test:hover{opacity:.85}

/* HIST */
.hcard{background:var(--card);border-radius:10px;padding:14px 16px;margin-bottom:10px;border:1px solid var(--bd);box-shadow:0 1px 3px rgba(0,0,0,.06)}
.hstats{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:8px;font-size:12px;color:var(--gr)}
.hstats strong{color:#111827}

/* ROOM MAP */
.room-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(78px,1fr));gap:5px}
.room-cell{background:var(--card);border-radius:7px;padding:6px 8px;text-align:center;border:1.5px solid var(--bd);font-size:11px;font-weight:600;cursor:pointer;transition:all .15s}
.room-cell:hover{border-color:var(--g2);background:var(--gl)}
.room-cell.occupied{border-color:#bbf7d0;background:#f0fdf4;color:#065f46}
.room-cell.occupied.ci{border-color:#10b981;background:#dcfce7}
.room-cell .rcm{font-size:9px;font-weight:400;color:var(--gr);display:block;margin-top:1px}
.sec-hdr{display:flex;align-items:center;justify-content:space-between;margin:14px 0 8px}
.sec-title{font-size:13px;font-weight:600;color:#374151}
.sec-cnt{font-size:11px;color:var(--gr);background:#f3f4f6;padding:2px 8px;border-radius:10px}

/* TOAST */
.toast{position:fixed;bottom:18px;right:18px;color:#fff;padding:10px 16px;border-radius:9px;font-size:12px;font-weight:600;box-shadow:0 4px 16px rgba(0,0,0,.2);transform:translateY(80px);opacity:0;transition:all .3s;z-index:2000;max-width:340px;display:flex;align-items:center;gap:8px;line-height:1.5}
.toast.show{transform:translateY(0);opacity:1}
.info-box{background:#eff6ff;border-left:3px solid #93c5fd;border-radius:0 7px 7px 0;padding:8px 12px;font-size:12px;color:#1e40af;line-height:1.6;margin-bottom:10px}

/* Guest Modal — compact height: scroll body only, header/footer pinned */
#guestModal {
    animation: modalFadeIn 0.2s ease-out;
}
#guestModal .modal {
    display: flex;
    flex-direction: column;
    max-height: min(78vh, 460px);
    overflow: hidden;
    border-radius: 14px;
    box-shadow: 0 16px 48px rgba(0, 0, 0, 0.22);
}
@media (min-width: 768px) {
    #guestModal .modal {
        max-width: 840px;
    }
}
#guestModal .mhdr {
    flex-shrink: 0;
    padding: 8px 12px;
    box-shadow: 0 1px 0 rgba(255, 255, 255, 0.12);
}
#guestModal .mhdr h2 {
    font-size: 13px;
    font-weight: 700;
    letter-spacing: 0.02em;
}
#guestModal .mclose{width:24px;height:24px;font-size:13px}
#guestModal .mbody {
    flex: 1;
    min-height: 0;
    overflow-y: auto;
    overflow-x: hidden;
    -webkit-overflow-scrolling: touch;
    overscroll-behavior: contain;
    padding: 8px 12px 8px;
    background: #fafbfc;
    scrollbar-gutter: stable;
    display: flex;
    flex-direction: column;
    gap: 6px;
}
#guestModal .mbody .gm-cell {
    min-width: 0;
}
@media (min-width: 768px) {
    #guestModal .mbody {
        display: grid;
        grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
        grid-template-areas:
            "hero actions"
            "notes actions";
        column-gap: 12px;
        row-gap: 10px;
        align-items: start;
    }
    #guestModal .mbody .gm-cell--hero {
        grid-area: hero;
        margin-bottom: 0;
    }
    #guestModal .mbody .gm-cell--actions {
        grid-area: actions;
        align-self: start;
        margin-bottom: 0;
        height: auto;
        display: flex;
        flex-direction: column;
    }
    #guestModal .mbody .gm-cell--actions .svc-grid.svc-grid--modal-tight {
        flex: 0 0 auto;
        align-content: start;
    }
    #guestModal .mbody .gm-cell--notes {
        grid-area: notes;
    }
}
#guestModal .gi.gi-compact {
    padding: 6px 8px;
    margin-bottom: 0;
    border-width: 1px;
    background: #fff;
    border-color: #e2e8f0;
    box-shadow: 0 1px 2px rgba(15, 23, 42, 0.06);
}
#guestModal .gi-compact .gi-top {
    margin-bottom: 0;
    gap: 6px;
    align-items: center;
}
#guestModal .gi-compact .gi-rm {
    font-size: 16px;
    font-weight: 800;
    line-height: 1.05;
}
#guestModal .gi-compact .gi-stay {
    margin-left: auto;
    font-size: 9px;
    font-weight: 600;
    color: var(--gr);
    white-space: nowrap;
}
#guestModal .gi-compact .rc-badge {
    font-size: 8px;
    padding: 1px 5px;
}
#guestModal .gi-mid {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: 2px;
    margin-top: 2px;
    line-height: 1.2;
}
#guestModal .gi-mid .gi-name {
    font-size: 13px;
    font-weight: 700;
    color: #111827;
    margin: 0;
    line-height: 1.15;
}
#guestModal .gi-mid .gi-meta {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 3px 6px;
    font-size: 10px;
    margin: 0;
}
#guestModal .gi-meta-dates {
    font-variant-numeric: tabular-nums;
    color: #64748b;
}
#guestModal .gi-meta-sep {
    color: #cbd5e1;
    font-weight: 400;
}
#guestModal .gi-meta-pax {
    color: #334155;
    font-weight: 600;
}
#guestModal .gi-meta-pax-lbl {
    font-weight: 500;
    color: #94a3b8;
    font-size: 9px;
    letter-spacing: 0.02em;
    margin-left: 4px;
}
#guestModal .gi-stay strong {
    color: var(--g);
    font-weight: 700;
    font-variant-numeric: tabular-nums;
}
#guestModal .gi-udfc {
    margin-top: 3px;
    padding-top: 3px;
    border-top: 1px solid rgba(16, 185, 129, 0.18);
    display: flex;
    flex-wrap: wrap;
    align-items: baseline;
    gap: 4px 6px;
}
#guestModal .gi-udfc-lbl {
    font-size: 8px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: var(--gr);
    flex-shrink: 0;
}
#guestModal .gi-udfc-val {
    font-size: 9px;
    font-weight: 600;
    color: #111827;
    line-height: 1.2;
    word-break: break-word;
    flex: 1;
    min-width: 0;
}
#guestModal .gi-identity {
    margin-top: 3px;
    padding-top: 3px;
    border-top: 1px solid rgba(99, 102, 241, 0.18);
    display: flex;
    flex-wrap: wrap;
    gap: 4px 10px;
    align-items: baseline;
}
#guestModal .gi-id-pair {
    display: inline-flex;
    align-items: baseline;
    gap: 4px;
}
#guestModal .gi-id-lbl {
    font-size: 8px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: var(--gr);
}
#guestModal .gi-id-val {
    font-size: 10px;
    font-weight: 600;
    color: #111827;
    font-variant-numeric: tabular-nums;
}
#guestModal .mftr {
    flex-shrink: 0;
    padding: 8px 12px 10px;
    margin: 0;
    border-top: 1px solid #e5e7eb;
    background: #fff;
    box-shadow: 0 -2px 8px rgba(15, 23, 42, 0.05);
    gap: 6px;
    flex-wrap: wrap;
}
#guestModal .mftr .bconfirm,
#guestModal .mftr .bcancel,
#guestModal .mftr .bundo {
    min-height: 36px;
    border-radius: 9px;
    font-size: 11px;
    padding: 8px 10px;
}

/* Grouped sections — clearer hierarchy inside long modal */
#guestModal .gm-section {
    background: #fff;
    border: 1px solid #e8ecf0;
    border-radius: 10px;
    padding: 6px 8px 7px;
    margin-bottom: 0;
    box-shadow: 0 1px 2px rgba(15, 23, 42, 0.04);
}
#guestModal .gm-section-title {
    font-size: 9px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: #64748b;
    margin: 0 0 5px;
    padding-bottom: 4px;
    border-bottom: 1px solid #f1f5f9;
}
#guestModal .gm-incl-pair {
    border-radius: 10px;
    overflow: hidden;
    margin-bottom: 6px;
    border: 1px solid rgba(15, 23, 42, 0.08);
}
#guestModal .gm-incl-pair .incl-row {
    margin-bottom: 0;
    border-radius: 0;
    border: none;
    border-bottom: 1px solid rgba(15, 23, 42, 0.06);
    padding: 6px 9px;
}
#guestModal .gm-incl-pair .incl-row:last-child {
    border-bottom: none;
}
#guestModal .incl-row--voucher {
    background: #fff7ed;
}
#guestModal .incl-row--voucher .incl-lbl {
    color: #9a3412;
}
#guestModal .incl-row--voucher .incl-val {
    color: #c2410c;
}
#guestModal .gm-section .ben-grid {
    gap: 6px;
    margin-bottom: 0;
}
#guestModal .gm-section .bc {
    padding: 7px 9px;
    border-radius: 8px;
}
#guestModal .gm-section .bc-icon {
    font-size: 16px;
}
#guestModal .gm-section .bc-val {
    font-size: 12px;
}
#guestModal .gm-section .cnt-row {
    margin-bottom: 8px;
}
#guestModal .gm-section .gm-svc-wrap {
    margin-bottom: 0;
}
#guestModal .gm-section .gm-svc-wrap .svc-title {
    margin-bottom: 6px;
    color: #64748b;
}
#guestModal .gm-section .svc-grid:not(.svc-grid--modal-tight) {
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 5px;
}
/* Unified modal: 3-col add-ons with +/- quantity controls */
#guestModal .svc-grid.svc-grid--modal-tight {
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 8px;
    margin-bottom: 0;
}
@media (max-width: 380px) {
    #guestModal .svc-grid.svc-grid--modal-tight {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}
/* Service item with quantity controls (guest modal add-ons) */
.svc-item {
    display: flex;
    flex-direction: column;
    align-items: stretch;
    gap: 8px;
    padding: 8px 8px 7px;
    border-radius: 14px;
    border: 1px solid rgba(15, 23, 42, 0.08);
    background: #fafafa;
    box-shadow: 0 1px 2px rgba(15, 23, 42, 0.05);
    transition: border-color 0.2s ease, background 0.2s ease, box-shadow 0.2s ease;
    user-select: none;
    min-width: 0;
}
.svc-item:hover {
    border-color: rgba(186, 117, 23, 0.35);
    background: #fff;
}
.svc-item.active {
    background: #fffbeb;
    border-color: rgba(186, 117, 23, 0.45);
    box-shadow: 0 1px 2px rgba(186, 117, 23, 0.12);
}
.svc-item-top {
    display: flex;
    align-items: center;
    gap: 8px;
    min-width: 0;
}
.svc-item .svc-ico-wrap {
    flex-shrink: 0;
    width: 32px;
    height: 32px;
    border-radius: 10px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: rgba(255, 255, 255, 0.85);
    border: 1px solid rgba(15, 23, 42, 0.06);
}
.svc-item.active .svc-ico-wrap {
    background: rgba(255, 247, 237, 0.95);
    border-color: rgba(186, 117, 23, 0.2);
}
.svc-item .svc-ico {
    font-size: 15px;
    line-height: 1;
}
.svc-item .svc-nm {
    font-size: 11px;
    font-weight: 700;
    color: #334155;
    line-height: 1.2;
    letter-spacing: 0.01em;
    min-width: 0;
}
.svc-item.active .svc-nm {
    color: #78350f;
}
.svc-item .svc-ctrl {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 6px;
    padding: 4px 5px;
    border-radius: 10px;
    background: rgba(255, 255, 255, 0.9);
    border: 1px solid rgba(15, 23, 42, 0.06);
}
.svc-item.active .svc-ctrl {
    background: #fff;
    border-color: rgba(186, 117, 23, 0.18);
}
.svc-item .svc-btn {
    width: 28px;
    height: 28px;
    min-width: 28px;
    min-height: 28px;
    border-radius: 8px;
    border: none;
    font-size: 16px;
    font-weight: 700;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    line-height: 1;
    padding: 0;
    transition: transform 0.15s ease, opacity 0.15s ease, background 0.15s ease;
}
.svc-item .svc-btn:focus-visible {
    outline: 2px solid #ba7517;
    outline-offset: 1px;
}
.svc-item .svc-btn:active:not(:disabled) {
    transform: scale(0.96);
}
.svc-item .svc-minus {
    background: #fef2f2;
    color: #b91c1c;
}
.svc-item .svc-minus:hover:not(:disabled) {
    background: #fee2e2;
}
.svc-item .svc-plus {
    background: #ecfdf5;
    color: #047857;
}
.svc-item .svc-plus:hover {
    background: #d1fae5;
}
.svc-item .svc-btn:disabled {
    opacity: 0.38;
    cursor: not-allowed;
    transform: none;
}
.svc-item .svc-qty {
    font-size: 16px;
    font-weight: 800;
    min-width: 28px;
    text-align: center;
    color: #0f172a;
    font-variant-numeric: tabular-nums;
}
.svc-item.active .svc-qty {
    color: #78350f;
}
/* Single “Booking summary” block: pills + chips + counters */
#guestModal .gm-section--unified .gm-section-title {
    margin-bottom: 5px;
}
#guestModal .gm-summary-pills {
    display: flex;
    flex-wrap: wrap;
    gap: 4px;
    align-items: center;
}
#guestModal .gm-sum-pill {
    display: inline-flex;
    align-items: baseline;
    gap: 3px;
    font-size: 11px;
    padding: 3px 9px;
    border-radius: 999px;
    font-weight: 600;
    border: 1px solid transparent;
    line-height: 1.15;
}
#guestModal .gm-sum-pill strong {
    font-size: 13px;
    font-weight: 800;
    font-variant-numeric: tabular-nums;
}
#guestModal .gm-sum-abf {
    background: #ecfdf5;
    border-color: #a7f3d0;
    color: #065f46;
}
#guestModal .gm-sum-v {
    background: #fff7ed;
    border-color: #fed7aa;
    color: #9a3412;
}
#guestModal .gm-sum-hint {
    font-size: 9px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    opacity: 0.9;
}
#guestModal .gm-perk-chips {
    display: flex;
    flex-wrap: wrap;
    gap: 3px;
    margin-top: 5px;
}
#guestModal .gm-chip {
    display: inline-block;
    font-size: 9px;
    font-weight: 600;
    padding: 2px 6px;
    border-radius: 6px;
    background: #f1f5f9;
    color: #475569;
    border: 1px solid #e2e8f0;
    line-height: 1.25;
}
#guestModal .gm-chip-spa{background:#faf5ff;border-color:#e9d5ff;color:#5b21b6}
#guestModal .gm-chip-pick{background:#eff6ff;border-color:#bfdbfe;color:#1e40af}
#guestModal .gm-chip-tea{background:#fffbeb;border-color:#fde68a;color:#92400e}
#guestModal .gm-chip-msg{background:#f5f3ff;border-color:#ddd6fe;color:#4c1d95}
#guestModal .gm-chip-fb{background:#ecfdf5;border-color:#bbf7d0;color:#065f46}
#guestModal .gm-chip-hon{background:#fff1f2;border-color:#fecdd3;color:#9f1239}
#guestModal .gm-divider{
    height:1px;
    margin:8px 0 6px;
    border:0;
    background:linear-gradient(90deg,transparent,#e2e8f0 10%,#e2e8f0 90%,transparent);
}
#guestModal .gm-subtitle{
    font-size:9px;
    font-weight:700;
    text-transform:uppercase;
    letter-spacing:0.07em;
    color:#64748b;
    margin:0 0 4px;
}
#guestModal .gm-subtitle--addons{margin-top:6px}
#guestModal .gm-subtitle-hint{
    font-weight:600;
    text-transform:none;
    letter-spacing:0.02em;
    color:#94a3b8;
}
#guestModal .gm-cnt-modal{margin-bottom:0;gap:6px}
#guestModal .gm-cnt-modal--3{grid-template-columns:repeat(3,minmax(0,1fr))}
#guestModal .gm-cnt-modal .cnt-grp label{font-size:9px;margin-bottom:3px}
#guestModal .gm-cnt-modal .cnt-ctrl{padding:4px 6px}
#guestModal .gm-cnt-modal .cnt-ctrl button{width:26px;height:26px;font-size:14px}
#guestModal .gm-cnt-modal .cnt-num{font-size:17px;min-width:28px}
#guestModal .gm-notes-wrap {
    margin-top: 0;
    padding-top: 0;
    border-top: none;
    background: #fff;
    border: 1px solid #e8ecf0;
    border-radius: 10px;
    padding: 6px 8px 7px;
    margin-bottom: 0;
    box-shadow: 0 1px 2px rgba(15, 23, 42, 0.04);
}
#guestModal .gm-notes-heading {
    font-size: 9px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: #64748b;
    margin: 0 0 4px;
    padding-bottom: 4px;
    border-bottom: 1px solid #f1f5f9;
}
#guestModal .gm-notes-wrap > .note-sec {
    margin-bottom: 6px;
}
#guestModal .gm-notes-wrap .note-toggle{
    padding:5px 8px;
    font-size:9px;
    gap:4px;
    border-radius:6px;
}
#guestModal .gm-notes-wrap > .note-sec:last-child {
    margin-bottom: 0;
}
#guestModal .gm-note-ta {
    width: 100%;
    min-height: 40px;
    max-height: 72px;
    resize: vertical;
    margin-top: 4px;
    padding: 6px 8px;
    border: 1px solid var(--bd);
    border-radius: 6px;
    font-size: 11px;
    font-family: inherit;
    line-height: 1.35;
    box-sizing: border-box;
}
#guestModal .gm-note-ta:focus {
    outline: none;
    border-color: var(--g2);
    box-shadow: 0 0 0 2px rgba(26, 158, 99, 0.2);
}
#guestModal .gm-note-save {
    text-align: right;
    margin-top: 5px;
}
#guestModal .btn-save-note {
    font-size: 10px;
    padding: 5px 10px;
    border: 1.5px solid var(--g);
    border-radius: 8px;
    background: var(--gl);
    color: var(--g);
    cursor: pointer;
    font-family: inherit;
    font-weight: 600;
    transition: background 0.15s, border-color 0.15s;
}
#guestModal .btn-save-note:hover {
    background: #d1fae5;
    border-color: var(--gd);
}
#guestModal .gm-booking-comment {
    margin-top: 4px;
    max-height: 56px;
    overflow-y: auto;
    white-space: pre-wrap;
    word-break: break-word;
    background: #f8fafc;
    border: 1px solid #e2e8f0;
    border-radius: 6px;
    padding: 6px 8px;
    font-size: 10px;
    line-height: 1.35;
    color: #374151;
}

#guestModal .modal-content {
    animation: modalSlideIn 0.3s ease-out;
}

@keyframes modalFadeIn {
    from { opacity: 0; }
    to { opacity: 1; }
}

@keyframes modalSlideIn {
    from { 
        opacity: 0; 
        transform: scale(0.95) translateY(-10px); 
    }
    to { 
        opacity: 1; 
        transform: scale(1) translateY(0); 
    }
}
/* Benefits Popup Styles */
.benefits-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
    gap: 12px;
}

.benefit-item {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 12px;
    background: #f8fafc;
    border-radius: 8px;
    border: 1px solid #e2e8f0;
}

.benefit-icon {
    font-size: 20px;
    width: 32px;
    height: 32px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: white;
    border-radius: 6px;
    border: 1px solid #e2e8f0;
}

.benefit-text {
    flex: 1;
}

.benefit-label {
    font-size: 12px;
    font-weight: 600;
    color: #374151;
    margin-bottom: 2px;
}

.benefit-value {
    font-size: 11px;
    color: #6b7280;
    font-weight: 500;
}

/* User Menu Dropdown */
.user-menu {
    background: white;
    border-radius: 8px;
    box-shadow: 0 8px 24px rgba(0, 0, 0, 0.15);
    border: 1px solid #e2e8f0;
    min-width: 160px;
    overflow: hidden;
    animation: dropdownFadeIn 0.15s ease-out;
}

.user-menu-item {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 10px 14px;
    font-size: 13px;
    color: #374151;
    cursor: pointer;
    transition: background-color 0.1s;
}

.user-menu-item:hover {
    background: #f8fafc;
}

.user-menu-divider {
    height: 1px;
    background: #e2e8f0;
    margin: 4px 0;
}

@keyframes dropdownFadeIn {
    from { 
        opacity: 0; 
        transform: translateY(-8px); 
    }
    to { 
        opacity: 1; 
        transform: translateY(0); 
    }
}

@media(max-width:800px){
  .dash{grid-template-columns:1fr}
  .dash-today .sc-dash-rooms,.dash-today .sc-dash-pax,.dash-today .sc-dash-comp{grid-column:span 1}
}
@media(max-width:500px){.svc-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:1024px){.guest-list{width:max-content}}
