/* ===== OpsDesk-style design system ===== */
:root{
  --bg:#F6F7F9; --surface:#FFFFFF; --surface-2:#FAFBFC;
  --ink:#16202C; --ink-2:#5A6573; --ink-3:#8B95A3;
  --line:#E6E9EE; --line-2:#EFF1F5;
  --brand:#0E6F5C; --brand-2:#0B5546; --brand-soft:#E5F2EE; --brand-ink:#0A4A3E;
  --accent:#C7821A;
  --done:#0E9F6E; --done-bg:#E3F6EE; --pending:#D58A12; --pending-bg:#FBF0DD;
  --over:#D9433B; --over-bg:#FBE6E4; --na:#94A0AE; --na-bg:#EEF1F4;
  --sh-sm:0 1px 2px rgba(16,32,44,.06); --sh:0 1px 3px rgba(16,32,44,.07),0 8px 24px -14px rgba(16,32,44,.22);
  --r:12px;
  /* aliases kept for older markup */
  --card:#fff; --edge:#E6E9EE; --line2:#E6E9EE; --soft:#5A6573; --muted:#5A6573;
  --blue:#0E6F5C; --blue-soft:#E5F2EE; --blue-ink:#0A4A3E; --green:#0E9F6E; --green-soft:#E3F6EE;
  --amber:#D58A12; --amber-soft:#FBF0DD; --rose:#D9433B; --r-sm:9px;
}
*{box-sizing:border-box;margin:0;padding:0}
html,body{margin:0}
body{background:var(--bg);color:var(--ink);font-family:"Plus Jakarta Sans",system-ui,sans-serif;-webkit-font-smoothing:antialiased;font-size:14px;line-height:1.5}
h1,h2,h3{margin:0;font-weight:700;letter-spacing:-.2px}
a{color:var(--brand);text-decoration:none}
button{font-family:inherit;cursor:pointer}
::-webkit-scrollbar{height:8px;width:8px}::-webkit-scrollbar-thumb{background:#cfd5dd;border-radius:8px}
svg{display:block}

/* ===== shell ===== */
.layout{display:grid;grid-template-columns:248px 1fr;min-height:100vh}
.sidebar{background:#0C1A1F;color:#C7D2D0;display:flex;flex-direction:column;position:sticky;top:0;height:100vh;border-right:1px solid #07120f;padding:0}
.side-brand{display:flex;align-items:center;gap:11px;padding:20px 20px 16px}
.logo{width:38px;height:38px;border-radius:10px;background:var(--brand);display:grid;place-items:center;color:#fff;
  box-shadow:inset 0 -2px 6px rgba(0,0,0,.25)}
.logo svg{width:20px;height:20px;stroke:#fff}
.wordmark{font-weight:700;font-size:17px;color:#fff;line-height:1;display:flex;flex-direction:column;gap:3px}
.wordmark small{font-weight:500;font-size:10.5px;color:#7e918d;letter-spacing:.4px;text-transform:uppercase}

.side-user{margin:0 16px 14px;padding:12px;background:rgba(255,255,255,.05);border-radius:11px;display:flex;align-items:center;gap:11px}
.avatar{width:36px;height:36px;border-radius:9px;background:var(--brand-2);color:#fff;display:grid;place-items:center;font-weight:700;font-size:13px;flex-shrink:0}
.su-meta{min-width:0}
.su-meta b{display:block;color:#fff;font-weight:700;font-size:13px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.su-meta span{display:block;color:#8aa39d;font-size:11px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}

.side-sect{font-size:10.5px;text-transform:uppercase;letter-spacing:.8px;color:#5f726e;padding:6px 22px 8px;font-weight:700}
.side-nav{padding:0 12px;display:flex;flex-direction:column;gap:2px;flex:1}
.navitem{display:flex;align-items:center;gap:11px;padding:10px 12px;border-radius:9px;color:#aebbb8;font-weight:600;font-size:13.5px;transition:.12s}
.navitem svg{width:18px;height:18px;stroke:#8aa39d;flex-shrink:0}
.navitem:hover{background:rgba(255,255,255,.05);color:#fff}
.navitem:hover svg{stroke:#fff}
.navitem.active{background:var(--brand);color:#fff}
.navitem.active svg{stroke:#fff}
.navitem.out{color:#c98b86;margin-top:6px}
.navitem.out:hover{background:rgba(217,67,59,.15);color:#fff}
.nav-badge{margin-left:auto;background:var(--over);color:#fff;font-size:11px;font-weight:700;border-radius:999px;padding:1px 8px;min-width:22px;text-align:center}

.side-foot{margin:8px 16px 16px;padding:12px;border-radius:11px;background:rgba(255,255,255,.05)}
.sf-label{font-size:10px;text-transform:uppercase;letter-spacing:.8px;color:#5f726e;font-weight:700}
.sf-role{display:block;font-size:14px;margin:3px 0 8px;color:#fff}
.sf-bar{height:5px;border-radius:999px;background:rgba(255,255,255,.12);overflow:hidden}
.sf-bar span{display:block;height:100%;width:70%;background:var(--brand)}
.role-owner,.role-admin,.role-manager,.role-employee{color:#fff}

.main{min-width:0;display:flex;flex-direction:column}
.topbar{position:sticky;top:0;z-index:20;background:rgba(246,247,249,.85);backdrop-filter:blur(8px);
  border-bottom:1px solid var(--line);padding:15px 28px;display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap}
.tb-crumb{font-size:12px;color:var(--ink-3);font-weight:600;letter-spacing:.2px}
.tb-title h1{font-size:19px;margin-top:2px}
.tb-right{display:flex;align-items:center;gap:10px}
.rolepill{font-size:12px;font-weight:700;padding:6px 13px;border-radius:999px}
.r-owner{background:var(--pending-bg);color:#9a6e0f}
.r-admin{background:var(--over-bg);color:var(--over)}
.r-manager{background:var(--brand-soft);color:var(--brand-ink)}
.r-employee{background:var(--done-bg);color:var(--done)}
.tb-bell{position:relative;width:38px;height:38px;border-radius:9px;border:1px solid var(--line);background:var(--surface);
  display:flex;align-items:center;justify-content:center;color:var(--ink-2)}
.tb-bell svg{width:19px;height:19px}
.tb-bell:hover{background:var(--surface-2)}
.bell-badge{position:absolute;top:-6px;right:-6px;background:var(--over);color:#fff;font-size:11px;font-weight:700;
  min-width:18px;height:18px;border-radius:999px;display:flex;align-items:center;justify-content:center;padding:0 5px;border:2px solid var(--bg)}

.content{padding:24px 28px 80px;max-width:1280px;width:100%}
.foot{text-align:center;color:var(--ink-3);font-size:12px;padding:20px}
.section{margin-top:24px}
.section-h,.ow-ttl,.tt-ttl{display:flex;align-items:center;justify-content:space-between;margin:24px 4px 13px;gap:12px;flex-wrap:wrap}
h2.section,.section h2,.ow-ttl,.tt-ttl{font-size:15.5px;font-weight:700;color:var(--ink)}
.muted{color:var(--ink-2)}

/* ===== KPI / stat cards ===== */
.cards,.kpis{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-bottom:8px}
.kpis.four{grid-template-columns:repeat(4,1fr)}
.card,.kpi{background:var(--surface);border:1px solid var(--line);border-radius:var(--r);padding:18px;box-shadow:var(--sh-sm);position:relative}
.card p{font-size:12px;color:var(--ink-2);font-weight:700}
.card b{font-size:30px;font-weight:800;letter-spacing:-1px;display:block;margin-top:10px;line-height:1}
.card::after{content:"";position:absolute;top:18px;right:18px;width:30px;height:30px;border-radius:8px;background:var(--brand-soft)}
.card.c1::after{background:var(--brand-soft)}.card.c2::after{background:var(--done-bg)}.card.c3::after{background:var(--pending-bg)}
@media(max-width:820px){.cards,.kpis,.kpis.four{grid-template-columns:1fr 1fr}}
@media(max-width:520px){.cards,.kpis,.kpis.four{grid-template-columns:1fr}}

/* ===== generic card / panel ===== */
.panel{background:var(--surface);border:1px solid var(--line);border-radius:var(--r);box-shadow:var(--sh-sm);overflow:hidden;margin-bottom:12px}
.panel-head{display:flex;align-items:center;justify-content:space-between;gap:13px;padding:15px 18px;border-bottom:1px solid var(--line-2)}
.panel-head h3{font-size:14.5px}
.prog{display:flex;align-items:center;gap:11px;font-size:12.5px;font-weight:700;color:var(--ink-2)}
.bar{width:120px;height:7px;border-radius:5px;background:var(--line-2);overflow:hidden}
.bar span{display:block;height:100%;background:var(--brand)}
.count{font-weight:800;color:var(--ink)}.pct{color:var(--ink-3);font-style:normal;font-size:12px}
.rows{padding:12px}.pad-x{padding:0 12px 12px}

.task-row{display:flex;align-items:center;gap:12px;padding:11px 14px;border:1px solid var(--line-2);border-radius:9px;margin-bottom:7px;background:var(--surface)}
.task-row.notdue{display:none}.panel.show-all .task-row.notdue{display:flex}
.task-row.done{background:var(--done-bg);border-color:#bfe6d4}
.task-row.done .task-name{color:var(--ink-3);text-decoration:line-through}
.task-check{width:18px;height:18px;accent-color:var(--brand);cursor:pointer;flex-shrink:0}
.task-name{flex:1;font-size:13.5px;font-weight:600}
.muted-tag{font-size:10px;color:var(--ink-3);font-style:italic}
.byname{font-size:10px;color:var(--done)}
.freq{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.3px;padding:2px 7px;border-radius:5px;background:var(--na-bg);color:var(--ink-2)}
.f-daily{background:#E7EFF8;color:#2f5e87}.f-weekly{background:#EFEAF8;color:#5a4a8c}
.f-biweekly{background:#F8EFE6;color:#8a5a2e}.f-monthly{background:#E9F3EA;color:#3f6b45}
.f-ongoing{background:var(--over-bg);color:var(--over)}.f-asneeded{background:var(--na-bg);color:var(--ink-2)}
.link{background:none;border:none;color:var(--brand);font:inherit;font-weight:700;cursor:pointer;padding:0;font-size:13px}
.toggle-all{margin:2px 12px 12px}.danger{color:var(--over)!important}

/* ===== buttons ===== */
.btn{background:var(--brand);color:#fff;border:none;border-radius:9px;padding:10px 16px;font-size:13px;font-weight:700;display:inline-flex;align-items:center;gap:7px;box-shadow:var(--sh-sm)}
.btn:hover{background:var(--brand-2)}
.btn-primary{background:var(--brand);color:#fff}.btn-primary:hover{background:var(--brand-2)}
.btn-ok{background:var(--done);color:#fff}.btn-block{width:100%;justify-content:center}

/* ===== summary list (owner) ===== */
.summary{background:var(--surface);border:1px solid var(--line);border-radius:var(--r);box-shadow:var(--sh-sm);overflow:hidden}
.srow{display:flex;align-items:center;gap:14px;padding:13px 18px;border-bottom:1px solid var(--line-2)}
.srow:last-child{border-bottom:none}.srow:hover{background:var(--surface-2)}
.sname{flex:1;font-size:14px;font-weight:600}
.srow b{font-variant-numeric:tabular-nums}

/* ===== tables ===== */
.tablewrap{background:var(--surface);border:1px solid var(--line);border-radius:var(--r);box-shadow:var(--sh-sm);overflow:auto}
table{width:100%;border-collapse:collapse}
.table,.ad-table,.mtable{width:100%;border-collapse:collapse;font-size:13px}
th{text-align:left;font-size:11px;text-transform:uppercase;letter-spacing:.4px;color:var(--ink-2);font-weight:700;padding:12px 16px;border-bottom:1px solid var(--line);background:var(--surface-2)}
td{padding:12px 16px;border-bottom:1px solid var(--line-2);font-size:13px}
tr:last-child td{border-bottom:none}
tbody tr:hover td{background:var(--surface-2)}
.actions{display:flex;gap:12px;align-items:center}
.mini-prog{display:flex;align-items:center;gap:9px}
.mini-prog .track{width:120px;height:7px;border-radius:5px;background:var(--line-2);overflow:hidden}
.mini-prog .track i{display:block;height:100%;background:var(--brand)}
.pill{font-size:11px;font-weight:700;padding:3px 9px;border-radius:999px;white-space:nowrap}
.pill.done{background:var(--done-bg);color:var(--done)}.pill.pending{background:var(--pending-bg);color:#9a6e0f}
.pill.over{background:var(--over-bg);color:var(--over)}.pill.muted{background:var(--na-bg);color:var(--ink-2)}
.dot{display:inline-block;width:9px;height:9px;border-radius:50%}
.dot.done{background:var(--done)}.dot.pending{background:var(--pending)}.dot.over{background:var(--over)}

/* ring (conic progress) */
.ring{--p:0;width:42px;height:42px;border-radius:50%;background:conic-gradient(var(--brand) calc(var(--p)*1%),var(--line-2) 0);display:grid;place-items:center;flex-shrink:0}
.ring span{width:32px;height:32px;border-radius:50%;background:var(--surface);display:grid;place-items:center;font-size:10.5px;font-weight:800;color:var(--brand-ink)}

/* ===== matrix (employee daily) ===== */
.matrix-wrap{background:var(--surface);border:1px solid var(--line);border-radius:var(--r);box-shadow:var(--sh-sm);overflow:auto}
.matrix{border-collapse:collapse;width:100%;font-size:13.5px}
.matrix th,.matrix td{border-bottom:1px solid var(--line-2);padding:11px 12px}
.matrix thead th{position:sticky;top:0;background:var(--surface-2);color:var(--ink-2);font-size:11px;text-transform:uppercase;letter-spacing:.4px;font-weight:700;text-align:center}
.matrix .task-col{text-align:left;min-width:240px;position:sticky;left:0;background:var(--surface);z-index:1}
.matrix thead .task-col{background:var(--surface-2);z-index:2}
.matrix .tname{display:block;font-weight:600;color:var(--ink)}
.matrix .freq{display:inline-block;margin-top:4px}
.matrix .hotel-col{min-width:92px;max-width:130px}
.matrix .cell{text-align:center}.matrix .task-check{width:20px;height:20px}
.matrix tbody tr:hover,.matrix tbody tr:hover .task-col{background:var(--surface-2)}
.matrix tr.notdue{display:none}.matrix.show-all tr.notdue{display:table-row}
.matrix tr.notdue .tname{color:var(--ink-2)}
.matrix tfoot td{background:var(--surface-2);font-size:13px;text-align:center;border-top:2px solid var(--line)}
.matrix tfoot .task-col{text-align:left;font-weight:700;color:var(--ink-2)}
.matrix tfoot .colcount b{font-size:15px;color:var(--ink)}
.datepill{display:inline-block;font-size:12px;font-weight:700;color:var(--brand-ink);background:var(--brand-soft);padding:4px 10px;border-radius:7px;white-space:nowrap}
.datepill.due{color:#9a6e0f;background:var(--pending-bg)}

.datebar{background:var(--surface);border:1px solid var(--line);border-radius:var(--r);box-shadow:var(--sh-sm);padding:14px 18px;display:flex;align-items:center;gap:14px;margin-bottom:20px;flex-wrap:wrap}
.datebar label{font-weight:700;font-size:13px;display:flex;align-items:center;gap:8px}
.datebar input,.form input,.form select{font:inherit;border:1px solid var(--line);border-radius:9px;padding:9px 11px;background:var(--surface-2)}
.datebar input:focus,.form input:focus,.form select:focus{outline:none;border-color:var(--brand);background:#fff}

.empty{background:var(--surface);border:1px dashed var(--line);border-radius:var(--r);padding:38px;text-align:center;color:var(--ink-2)}
.empty.small{padding:16px;font-size:13px;margin-bottom:12px}
.assigned-banner{display:flex;align-items:center;gap:12px;background:var(--pending-bg);border:1px solid #f0dcae;color:#8a5a0f;border-radius:var(--r);padding:14px 18px;margin-bottom:20px;font-weight:600;font-size:14px}
.ab-dot{background:var(--over);color:#fff;font-weight:700;min-width:24px;height:24px;border-radius:999px;display:flex;align-items:center;justify-content:center;font-size:13px}
.ab-arrow{margin-left:auto;font-size:18px}

/* ===== forms ===== */
.form{display:flex;flex-direction:column;gap:13px}.form.pad{padding:18px}
.form label{font-size:13px;font-weight:700;display:flex;flex-direction:column;gap:6px}
.row-inline{flex-direction:row;align-items:center}.row-inline input{flex:1}
.checkgrid{display:grid;grid-template-columns:repeat(2,1fr);gap:8px}
.chk{flex-direction:row!important;align-items:center;gap:8px;font-weight:500!important;border:1px solid var(--line);border-radius:9px;padding:8px 10px;cursor:pointer}
.chk input{accent-color:var(--brand)}
.iconbtn{background:var(--surface);border:1px solid var(--line);border-radius:8px;width:30px;height:30px;cursor:pointer}

/* ===== auth ===== */
.auth-body{min-height:100vh;display:grid;place-items:center;padding:20px;font-family:"Plus Jakarta Sans",sans-serif;
  background:linear-gradient(150deg,#0C1A1F,#0E6F5C)}
.auth-card{background:var(--surface);border-radius:18px;padding:36px;width:100%;max-width:410px;box-shadow:0 40px 90px -20px rgba(0,0,0,.55)}
.auth-logo{width:50px;height:50px;border-radius:13px;background:var(--brand);color:#fff;display:grid;place-items:center;font-weight:800;font-size:22px;margin-bottom:18px}
.auth-title{font-size:23px;font-weight:800}
.auth-sub{color:var(--ink-2);font-size:14px;margin:6px 0 22px}
.auth-foot{text-align:center;margin-top:18px;font-size:14px;color:var(--ink-2)}
.alert{padding:11px 14px;border-radius:9px;font-size:14px;margin-bottom:16px}
.alert.err{background:var(--over-bg);color:#9a2a23;border:1px solid #f2c7c3}
.alert.ok{background:var(--done-bg);color:#0a6b4c;border:1px solid #b9ddc1}

/* ===== mobile ===== */
@media(max-width:820px){
  .layout{grid-template-columns:1fr}
  .sidebar{flex-direction:row;flex-wrap:wrap;align-items:center;height:auto;position:static;gap:8px;padding:10px 14px}
  .side-brand{padding:0;margin-right:auto}
  .side-user,.side-foot,.side-sect{display:none}
  .side-nav{flex-direction:row;flex-wrap:wrap;flex:1 1 100%;padding:0}
  .navitem.out{margin-top:0;margin-left:auto}
  .content{padding:18px}.topbar{padding:13px 18px}
}