/* India Hotel PMS — Saffron & Gold Dark Theme */
@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:wght@400;700&family=DM+Sans:wght@300;400;500;600&display=swap');

:root {
  --bg-deep:    #0a0c12;
  --bg-card:    #13161f;
  --bg-el:      #1e2333;
  --bg-hover:   #252a3a;
  --border:     rgba(255,255,255,0.07);
  --bdr-saf:    rgba(255,153,51,0.35);
  --saffron:    #ff9933;
  --saf-dim:    rgba(255,153,51,0.12);
  --gold:       #d4a843;
  --gold-dim:   rgba(212,168,67,0.12);
  --green-in:   #138808;
  --text-1:     #f2ede6;
  --text-2:     #8d93a8;
  --text-3:     #545c75;
  --blue:       #4a9eff;
  --teal:       #2ec4b6;
  --red:        #e55353;
  --orange:     #ff9a3c;
  --purple:     #9b6dff;
  --av: #2ec4b6; --oc: #e55353; --rs: #ff9933; --mt: #9b6dff; --cl: #4a9eff;
  --sw: 230px;
  --hh: 62px;
  --r:  12px;
  --rs2: 8px;
  --sh: 0 4px 24px rgba(0,0,0,.5);
  --tr: all .2s ease;
}
*{margin:0;padding:0;box-sizing:border-box;-webkit-tap-highlight-color:transparent}
html{font-size:16px}
body{font-family:'DM Sans',sans-serif;background:var(--bg-deep);color:var(--text-1);min-height:100vh;overflow-x:hidden}

/* ── App Shell ── */
.app{display:grid;grid-template-columns:var(--sw) 1fr;min-height:100vh}

/* ── Sidebar ── */
.sidebar{background:var(--bg-card);border-right:1px solid var(--border);display:flex;flex-direction:column;position:sticky;top:0;height:100vh;overflow-y:auto}
.s-logo{padding:18px 16px 10px;border-bottom:1px solid var(--border)}
.s-logo-name{font-family:'Playfair Display',serif;font-size:1rem;font-weight:700;color:var(--saffron);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.s-logo-sub{font-size:0.62rem;color:var(--text-3);margin-top:2px;display:flex;align-items:center;gap:4px}
.s-badge{margin:8px 12px;background:var(--saf-dim);border:1px solid var(--bdr-saf);border-radius:6px;padding:6px 10px;font-size:0.72rem;color:var(--saffron);cursor:pointer;text-align:center}
.s-occ{padding:8px 14px;border-bottom:1px solid var(--border)}
.occ-row{display:flex;justify-content:space-between;font-size:0.68rem;color:var(--text-3);margin-bottom:4px}
.occ-val{font-weight:700;color:var(--saffron)}
.occ-bar{height:4px;background:var(--bg-el);border-radius:2px;overflow:hidden}
.occ-fill{height:100%;background:var(--saffron);border-radius:2px;transition:width .5s}
nav{flex:1;overflow-y:auto;padding:6px 0}
.nav-sec{padding:6px 0}
.nav-lbl{font-size:0.58rem;text-transform:uppercase;letter-spacing:1.5px;color:var(--text-3);padding:6px 16px 3px;font-weight:600}
.nav-a{display:flex;align-items:center;gap:9px;padding:8px 16px;font-size:0.845rem;color:var(--text-2);text-decoration:none;transition:var(--tr);position:relative}
.nav-a:hover{background:var(--bg-el);color:var(--text-1)}
.nav-a.active{color:var(--saffron);background:var(--saf-dim);border-right:2px solid var(--saffron)}
.nav-ic{width:18px;text-align:center;font-size:0.9rem;flex-shrink:0}
.nav-badge{margin-left:auto;background:var(--red);color:#fff;font-size:0.58rem;font-weight:700;padding:1px 5px;border-radius:8px;min-width:16px;text-align:center}
.s-user{padding:12px 14px;border-top:1px solid var(--border);display:flex;align-items:center;gap:9px}
.u-av{width:32px;height:32px;border-radius:50%;background:var(--saf-dim);border:1px solid var(--bdr-saf);display:flex;align-items:center;justify-content:center;font-size:0.72rem;font-weight:700;color:var(--saffron);flex-shrink:0}
.u-name{font-size:0.8rem;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.u-role{font-size:0.62rem;color:var(--text-3)}
.s-logout{margin-left:auto;font-size:0.72rem;color:var(--text-3);text-decoration:none;padding:4px 8px;border:1px solid var(--border);border-radius:4px;white-space:nowrap}
.s-logout:hover{color:var(--red);border-color:var(--red)}

/* ── Main ── */
.main{display:flex;flex-direction:column;min-height:100vh;overflow:hidden}
.topbar{height:var(--hh);padding:0 22px;display:flex;align-items:center;gap:12px;border-bottom:1px solid var(--border);background:var(--bg-card);position:sticky;top:0;z-index:10}
.topbar-title{font-family:'Playfair Display',serif;font-size:1.15rem;font-weight:700;flex:1}
.topbar-stat{background:var(--bg-el);border:1px solid var(--border);border-radius:6px;padding:4px 12px;font-size:0.72rem;color:var(--text-2);display:flex;align-items:center;gap:5px;white-space:nowrap}
.topbar-stat .v{font-weight:700;color:var(--text-1)}
.page-body{flex:1;padding:20px 22px;overflow-y:auto}

/* ── Cards ── */
.card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--r);padding:18px;margin-bottom:0}
.card-hd{display:flex;justify-content:space-between;align-items:center;margin-bottom:14px;flex-wrap:wrap;gap:8px}
.card-title{font-family:'Playfair Display',serif;font-size:1rem;font-weight:700}
.card-sub{font-size:0.72rem;color:var(--text-3)}

/* ── Stats Grid ── */
.stats{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:12px;margin-bottom:18px}
.stat{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--r);padding:16px;position:relative;overflow:hidden}
.stat::before{content:'';position:absolute;top:0;left:0;right:0;height:2px}
.stat.saf::before{background:var(--saffron)}.stat.bl::before{background:var(--blue)}
.stat.gr::before{background:var(--teal)}.stat.re::before{background:var(--red)}
.stat.or::before{background:var(--orange)}.stat.pu::before{background:var(--purple)}
.stat.go::before{background:var(--gold)}.stat.gi::before{background:var(--green-in)}
.stat-lbl{font-size:0.68rem;text-transform:uppercase;letter-spacing:1px;color:var(--text-3);margin-bottom:6px}
.stat-val{font-size:1.6rem;font-weight:700;line-height:1}
.stat-sub{font-size:0.68rem;color:var(--text-3);margin-top:4px}
.stat-ic{position:absolute;right:14px;top:50%;transform:translateY(-50%);font-size:1.5rem;opacity:.2}

/* ── Buttons ── */
.btn{display:inline-flex;align-items:center;gap:6px;padding:9px 16px;border-radius:var(--rs2);font-size:0.845rem;font-weight:500;cursor:pointer;border:1px solid transparent;transition:var(--tr);text-decoration:none;font-family:inherit;white-space:nowrap;vertical-align:middle}
.btn-saf{background:var(--saffron);color:#0a0c12;border-color:var(--saffron)}.btn-saf:hover{background:#ffb366;border-color:#ffb366}
.btn-out{background:transparent;color:var(--text-2);border-color:var(--border)}.btn-out:hover{border-color:var(--saffron);color:var(--saffron)}
.btn-ghost{background:transparent;color:var(--text-2);border-color:transparent}.btn-ghost:hover{background:var(--bg-el);color:var(--text-1)}
.btn-blue{background:rgba(74,158,255,.15);color:var(--blue);border-color:rgba(74,158,255,.3)}.btn-blue:hover{background:rgba(74,158,255,.25)}
.btn-grn{background:rgba(46,196,182,.15);color:var(--teal);border-color:rgba(46,196,182,.3)}.btn-grn:hover{background:rgba(46,196,182,.25)}
.btn-red{background:rgba(229,83,83,.15);color:var(--red);border-color:rgba(229,83,83,.3)}.btn-red:hover{background:rgba(229,83,83,.25)}
.btn-sm{padding:5px 11px;font-size:0.78rem}.btn-xs{padding:3px 8px;font-size:0.7rem}
.btn-lg{padding:12px 22px;font-size:0.9rem}
.btn:disabled{opacity:.5;cursor:not-allowed}
.w100{width:100%}

/* ── Forms ── */
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.form-row.c3{grid-template-columns:1fr 1fr 1fr}
.form-row.c4{grid-template-columns:repeat(4,1fr)}
.form-grp{display:flex;flex-direction:column;gap:5px}
.form-lbl{font-size:0.72rem;font-weight:600;color:var(--text-2);text-transform:uppercase;letter-spacing:.5px}
.form-ctrl{width:100%;background:var(--bg-deep);border:1px solid var(--border);border-radius:var(--rs2);padding:10px 13px;color:var(--text-1);font-size:0.875rem;font-family:inherit;transition:var(--tr)}
.form-ctrl:focus{outline:none;border-color:var(--saffron);box-shadow:0 0 0 3px var(--saf-dim)}
.form-ctrl::placeholder{color:var(--text-3)}
.form-hint{font-size:0.68rem;color:var(--text-3)}
.form-divider{height:1px;background:var(--border);margin:16px 0}
.sec-hd{font-size:0.7rem;font-weight:700;text-transform:uppercase;letter-spacing:1.5px;color:var(--saffron);padding-bottom:8px;border-bottom:1px solid var(--bdr-saf);margin-bottom:12px}

/* ── Tables ── */
.tbl-wrap{overflow-x:auto}
table{width:100%;border-collapse:collapse}
th{padding:9px 12px;text-align:left;font-size:0.68rem;text-transform:uppercase;letter-spacing:.8px;color:var(--text-3);background:var(--bg-deep);font-weight:600;white-space:nowrap}
td{padding:10px 12px;font-size:0.845rem;border-bottom:1px solid rgba(255,255,255,.03);vertical-align:middle}
tr:hover td{background:rgba(255,255,255,.015)}
.text-c{text-align:center}.text-r{text-align:right}
.font-b{font-weight:700}

/* ── Badges ── */
.badge{display:inline-block;padding:2px 8px;border-radius:10px;font-size:0.68rem;font-weight:600;text-transform:uppercase;letter-spacing:.3px}
.b-av{background:rgba(46,196,182,.15);color:var(--teal)}
.b-oc{background:rgba(229,83,83,.15);color:var(--red)}
.b-rs{background:rgba(255,153,51,.15);color:var(--saffron)}
.b-cl{background:rgba(74,158,255,.15);color:var(--blue)}
.b-mt{background:rgba(155,109,255,.15);color:var(--purple)}
.b-cf{background:rgba(74,158,255,.15);color:var(--blue)}
.b-ci{background:rgba(229,83,83,.15);color:var(--red)}
.b-co{background:rgba(46,196,182,.15);color:var(--teal)}
.b-cn{background:rgba(84,92,117,.15);color:var(--text-3)}
.b-no{background:rgba(255,154,60,.15);color:var(--orange)}
.b-saf{background:var(--saf-dim);color:var(--saffron)}
.b-gold{background:var(--gold-dim);color:var(--gold)}
.b-grn{background:rgba(19,136,8,.12);color:#2ec050}
.b-veg{background:rgba(19,136,8,.15);border:1px solid rgba(19,136,8,.35);color:#2ec050;font-size:.55rem;padding:1px 5px;border-radius:3px}
.b-nv{background:rgba(229,83,83,.1);border:1px solid rgba(229,83,83,.35);color:#ff7070;font-size:.55rem;padding:1px 5px;border-radius:3px}

/* ── Alerts ── */
.alert{padding:10px 14px;border-radius:var(--rs2);font-size:0.845rem;margin-bottom:14px}
.alert-ok{background:rgba(46,196,182,.1);border:1px solid rgba(46,196,182,.3);color:var(--teal)}
.alert-err{background:rgba(229,83,83,.1);border:1px solid rgba(229,83,83,.3);color:var(--red)}
.alert-warn{background:rgba(255,153,51,.1);border:1px solid rgba(255,153,51,.3);color:var(--saffron)}

/* ── Modals ── */
.modal-ov{position:fixed;inset:0;background:rgba(0,0,0,.7);display:none;align-items:center;justify-content:center;z-index:1000;padding:16px;backdrop-filter:blur(3px)}
.modal-ov.open{display:flex}
.modal{background:var(--bg-card);border:1px solid var(--bdr-saf);border-radius:var(--r);width:100%;max-width:640px;max-height:92vh;display:flex;flex-direction:column;box-shadow:0 20px 60px rgba(0,0,0,.7)}
.modal-lg{max-width:800px}.modal-xl{max-width:960px}.modal-sm{max-width:440px}
.modal-hd{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;border-bottom:1px solid var(--border)}
.modal-title{font-family:'Playfair Display',serif;font-size:1rem;font-weight:700}
.modal-close{background:none;border:none;color:var(--text-3);font-size:1.2rem;cursor:pointer;line-height:1;padding:0 4px}
.modal-close:hover{color:var(--red)}
.modal-body{flex:1;overflow-y:auto;padding:20px}
.modal-ft{display:flex;justify-content:flex-end;gap:8px;padding:14px 20px;border-top:1px solid var(--border)}

/* ── Tabs ── */
.tabs{display:flex;gap:0;border-bottom:1px solid var(--border);margin-bottom:18px;overflow-x:auto}
.tab{padding:9px 18px;font-size:0.82rem;font-weight:500;color:var(--text-3);cursor:pointer;border-bottom:2px solid transparent;transition:var(--tr);white-space:nowrap;background:none;border-top:none;border-left:none;border-right:none;font-family:inherit}
.tab:hover{color:var(--text-1)}
.tab.active{color:var(--saffron);border-bottom-color:var(--saffron)}

/* ── Room Grid ── */
.room-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(90px,1fr));gap:8px}
.room-card{background:var(--bg-el);border:1px solid var(--border);border-radius:var(--rs2);padding:10px 6px;text-align:center;cursor:pointer;transition:var(--tr);position:relative}
.room-card:hover{transform:translateY(-2px);box-shadow:0 4px 16px rgba(0,0,0,.4)}
.room-card.st-available{border-color:rgba(46,196,182,.3)}.room-card.st-available:hover{border-color:var(--teal)}
.room-card.st-occupied{border-color:rgba(229,83,83,.3)}.room-card.st-occupied:hover{border-color:var(--red)}
.room-card.st-reserved{border-color:rgba(255,153,51,.3)}.room-card.st-reserved:hover{border-color:var(--saffron)}
.room-card.st-cleaning{border-color:rgba(74,158,255,.3)}.room-card.st-cleaning:hover{border-color:var(--blue)}
.room-card.st-maintenance{border-color:rgba(155,109,255,.3)}.room-card.st-maintenance:hover{border-color:var(--purple)}
.rm-num{font-size:1.1rem;font-weight:700}
.rm-type{font-size:0.6rem;color:var(--text-3);margin-top:2px}
.rm-dot{width:7px;height:7px;border-radius:50%;margin:4px auto 0}

/* ── HK Kanban ── */
.hk-board{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}
.hk-col{background:var(--bg-el);border:1px solid var(--border);border-radius:var(--r);padding:10px;min-height:160px}
.hk-col-hd{font-size:0.68rem;text-transform:uppercase;letter-spacing:1px;color:var(--text-3);font-weight:700;margin-bottom:9px;display:flex;justify-content:space-between;align-items:center}
.hk-ct{background:var(--saf-dim);padding:1px 7px;border-radius:10px;font-size:0.68rem;color:var(--saffron)}
.hk-task{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--rs2);padding:9px;margin-bottom:7px;cursor:pointer;transition:var(--tr)}
.hk-task:hover{border-color:var(--saffron)}
.hk-task.pri-urgent{border-left:3px solid var(--red)}
.hk-task.pri-high{border-left:3px solid var(--orange)}
.hk-task.pri-normal{border-left:3px solid var(--blue)}
.hk-task.pri-low{border-left:3px solid var(--text-3)}

/* ── Empty State ── */
.empty{text-align:center;padding:40px 20px;color:var(--text-3)}
.empty-ic{font-size:3rem;opacity:.2;margin-bottom:12px}
.empty-txt{font-size:0.875rem}

/* ── Toast ── */
#toasts{position:fixed;bottom:24px;right:24px;z-index:9999;display:flex;flex-direction:column;gap:8px}
.toast{padding:12px 18px;border-radius:var(--rs2);font-size:0.845rem;font-weight:500;box-shadow:var(--sh);animation:slideIn .25s;max-width:340px}
.toast-ok{background:#1a3a2e;border:1px solid var(--teal);color:var(--teal)}
.toast-err{background:#3a1a1a;border:1px solid var(--red);color:var(--red)}
.toast-info{background:#1a2a3a;border:1px solid var(--blue);color:var(--blue)}
@keyframes slideIn{from{transform:translateX(100%);opacity:0}to{transform:translateX(0);opacity:1}}

/* ── India flag top bar ── */
body::after{content:'';position:fixed;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,#ff9933 33.3%,#fff 33.3% 66.6%,#138808 66.6%);z-index:9999;pointer-events:none}

/* ── Misc ── */
.divider{height:1px;background:var(--border);margin:14px 0}
.text-saf{color:var(--saffron)}.text-gold{color:var(--gold)}.text-muted{color:var(--text-3)}
.text-red{color:var(--red)}.text-grn{color:var(--teal)}.text-blue{color:var(--blue)}
.gap8{display:flex;gap:8px;flex-wrap:wrap;align-items:center}
.mt-12{margin-top:12px}
.pr-tag{background:var(--bg-deep);border:1px solid var(--border);border-radius:var(--rs2);padding:4px 10px;font-size:0.72rem;color:var(--text-2)}

/* ── Scroll ── */
::-webkit-scrollbar{width:5px;height:5px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:var(--bg-el);border-radius:3px}
::-webkit-scrollbar-thumb:hover{background:var(--bdr-saf)}

/* ── Responsive ── */
@media(max-width:900px){
  .app{grid-template-columns:1fr}
  .sidebar{display:none}
  .hk-board{grid-template-columns:1fr 1fr}
  .form-row{grid-template-columns:1fr}
  .form-row.c3,.form-row.c4{grid-template-columns:1fr 1fr}
}
@media(max-width:540px){
  .hk-board{grid-template-columns:1fr}
  .stats{grid-template-columns:1fr 1fr}
  .page-body{padding:12px}
}
