
:root{
  --bg:#f3f6fb;
  --surface:#ffffff;
  --surface2:rgba(255,255,255,.85);
  --text:#0f1b2d;
  --muted:#5b6b84;
  --stroke:rgba(15,27,45,.12);
  --shadow:0 10px 28px rgba(15,27,45,.08);
  --radius:16px;

  --accent:#2563eb;
  --accent2:#60a5fa;

  --ok:#16a34a;
  --warn:#f59e0b;
  --bad:#ef4444;

  --navW: 280px;
  --font: ui-sans-serif, system-ui, -apple-system, "Segoe UI", Roboto, Arial;
}

*{box-sizing:border-box}
html,body{height:100%}
body{margin:0;font-family:var(--font);color:var(--text);background:var(--bg)}
.no-scroll{overflow:hidden}
a{color:inherit}

.app{min-height:100vh;display:grid;grid-template-columns:var(--navW) 1fr;gap:18px;padding:18px}

.overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.45);z-index:40;opacity:0;transition:.18s ease}
.overlay.is-open{opacity:1}

.sidebar{background:var(--surface2);backdrop-filter:blur(10px);border:1px solid var(--stroke);border-radius:var(--radius);box-shadow:var(--shadow);padding:14px;height:calc(100vh - 36px);position:sticky;top:18px;z-index:50;overflow:auto}
.brand{display:flex;align-items:center;gap:12px;padding:10px 10px 14px;border-bottom:1px solid var(--stroke);margin-bottom:12px}
.logo{width:38px;height:38px;border-radius:14px;background:linear-gradient(135deg,var(--accent),color-mix(in srgb,var(--accent) 40%,transparent));box-shadow:0 12px 22px color-mix(in srgb,var(--accent) 28%,transparent)}
.brand-title{font-weight:900;letter-spacing:-.01em;font-size:14px}
.brand-sub{font-size:12px;color:var(--muted);margin-top:2px}

.nav{display:flex;flex-direction:column;gap:6px;padding:8px 6px}
.nav-item{display:flex;align-items:center;gap:10px;padding:10px 10px;border-radius:14px;text-decoration:none;color:var(--text);border:1px solid transparent}
.nav-item:hover{background:color-mix(in srgb,var(--accent) 9%,transparent);border-color:color-mix(in srgb,var(--accent) 16%,transparent)}
.nav-item.active{background:color-mix(in srgb,var(--accent) 12%,transparent);border-color:color-mix(in srgb,var(--accent) 24%,transparent)}
.ico{width:34px;height:34px;border-radius:12px;display:grid;place-items:center;border:1px solid var(--stroke);background:rgba(15,27,45,.04)}
.nav-spacer{flex:1}
.nav-foot{margin-top:10px;padding:10px;border-top:1px solid var(--stroke)}
.hint{font-size:12px;color:var(--muted);line-height:1.35}

.main{min-width:0;display:flex;flex-direction:column;gap:18px}
.topbar{background:var(--surface2);backdrop-filter:blur(10px);border:1px solid var(--stroke);border-radius:var(--radius);box-shadow:var(--shadow);padding:12px 14px;display:flex;align-items:center;gap:12px;
  position:relative; z-index:75; /* ensure dropdowns appear above content cards */
}
.burger{width:42px;height:42px;border-radius:14px;border:1px solid var(--stroke);background:var(--surface);color:var(--text);cursor:pointer;display:none}
.topbar-title{display:flex;flex-direction:column;gap:2px;min-width:160px}
.h1{font-weight:950;letter-spacing:-.02em}
.crumb{font-size:12px;color:var(--muted)}
.topbar-actions{display:flex;align-items:center;gap:10px;margin-left:auto;min-width:0}
.search{min-width:220px;flex:1}
.search input{width:100%;padding:12px 12px;border-radius:14px;border:1px solid var(--stroke);background:rgba(15,27,45,.04);outline:none;color:var(--text)}
.search input::placeholder{color:color-mix(in srgb,var(--muted) 75%,transparent)}
.chip{border:1px solid var(--stroke);background:var(--surface);border-radius:999px;padding:9px 11px;font-size:12px;color:var(--muted);white-space:nowrap}
.chip-btn{cursor:pointer}
.avatar{width:40px;height:40px;border-radius:16px;background:linear-gradient(135deg,rgba(15,27,45,.14),rgba(15,27,45,.04));border:1px solid var(--stroke)}

.content{min-width:0}
.footer{padding:8px 6px;color:var(--muted);font-size:12px}

.grid{display:grid;gap:18px;min-width:0}
.grid.kpis{grid-template-columns:repeat(12,1fr)}
.kpi{grid-column:span 3}
.grid.two{grid-template-columns:repeat(12,1fr)}
/* allow any direct child (not only .card) to occupy intended columns */
.grid.two>*:first-child{grid-column:span 8}
.grid.two>*:last-child{grid-column:span 4}
.grid.one{grid-template-columns:1fr}
.grid.three{grid-template-columns:repeat(12,1fr)}
.grid.three>.card{grid-column:span 4}

.card{background:var(--surface2);backdrop-filter:blur(10px);border:1px solid var(--stroke);border-radius:var(--radius);box-shadow:var(--shadow);padding:14px;min-width:0}
.card-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:12px}
.card-title{font-weight:950;letter-spacing:-.015em}
.card-sub{font-size:12px;color:var(--muted);margin-top:2px}

.kpi-top{display:flex;align-items:center;justify-content:space-between;gap:10px}
.kpi-label{font-size:12px;color:var(--muted)}
.kpi-value{font-size:22px;font-weight:950;letter-spacing:-.03em;margin-top:8px}
.kpi-sub{font-size:12px;color:var(--muted);margin-top:6px}
.pill{display:inline-flex;align-items:center;padding:6px 10px;border-radius:999px;border:1px solid var(--stroke);background:rgba(15,27,45,.03);font-size:12px}
.pill-ok{border-color:color-mix(in srgb,var(--ok) 40%,var(--stroke));background:color-mix(in srgb,var(--ok) 10%,transparent);color:color-mix(in srgb,var(--ok) 85%,var(--text))}
.pill-warn{border-color:color-mix(in srgb,var(--warn) 40%,var(--stroke));background:color-mix(in srgb,var(--warn) 12%,transparent);color:color-mix(in srgb,var(--warn) 80%,var(--text))}
.pill-bad{border-color:color-mix(in srgb,var(--bad) 40%,var(--stroke));background:color-mix(in srgb,var(--bad) 10%,transparent);color:color-mix(in srgb,var(--bad) 85%,var(--text))}

.btn{border:1px solid color-mix(in srgb,var(--accent) 30%,transparent);background:color-mix(in srgb,var(--accent) 12%,transparent);color:var(--accent);padding:10px 12px;border-radius:14px;font-weight:900;cursor:pointer}
.btn:hover{background:color-mix(in srgb,var(--accent) 16%,transparent)}
.btn.ghost{background:transparent;border-color:var(--stroke);color:var(--text)}
.btn.small{padding:8px 10px;border-radius:12px;font-weight:900}
.btn.full{width:100%}

.btn.danger{border:1px solid color-mix(in srgb,var(--bad) 40%,transparent);background:color-mix(in srgb,var(--bad) 10%,transparent);color:color-mix(in srgb,var(--bad) 85%,var(--text))}
.btn.danger:hover{background:color-mix(in srgb,var(--bad) 16%,transparent)}

.actions-inline{display:flex;gap:10px;flex-wrap:wrap}

.chart{display:flex;flex-direction:column;gap:12px}
.bar{display:grid;grid-template-columns:1fr auto;gap:10px;align-items:center;padding:12px;border:1px solid var(--stroke);border-radius:14px;background:rgba(15,27,45,.03);position:relative;overflow:hidden}
.bar span{position:absolute;left:0;top:0;bottom:0;width:60%;background:linear-gradient(90deg,color-mix(in srgb,var(--accent) 26%,transparent),color-mix(in srgb,var(--accent) 8%,transparent))}
.bar.alt span{background:linear-gradient(90deg,rgba(22,163,74,.22),rgba(22,163,74,.06))}
.bar em{position:relative;z-index:1;font-style:normal;color:var(--muted)}
.bar strong{position:relative;z-index:1}
.note{font-size:12px;color:var(--muted)}

.list{display:flex;flex-direction:column;gap:10px}
.list.tight{gap:8px}
.row{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px;border:1px solid var(--stroke);border-radius:14px;background:rgba(15,27,45,.03)}
.row-main{min-width:0}
.row-title{font-weight:950;letter-spacing:-.01em}
.row-meta{font-size:12px;color:var(--muted);margin-top:3px}

.status{display:inline-flex;align-items:center;gap:8px;padding:6px 10px;border-radius:999px;border:1px solid var(--stroke);font-size:12px;white-space:nowrap}
.status i{width:8px;height:8px;border-radius:999px;background:var(--muted)}
.status.ok i{background:var(--ok)}
.status.warn i{background:var(--warn)}
.status.bad i{background:var(--bad)}

.kv{display:flex;flex-direction:column;gap:10px}
.kv div{display:flex;justify-content:space-between;gap:12px;padding:10px 0;border-bottom:1px dashed var(--stroke)}
.kv div:last-child{border-bottom:none}
.kv span{color:var(--muted);font-size:12px}
.kv b{font-weight:950;text-align:right}

.stats{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-top:6px}
.stat{padding:12px;border:1px solid var(--stroke);border-radius:14px;background:rgba(15,27,45,.03)}
.stat b{font-size:18px;display:block;font-weight:950}
.stat span{font-size:12px;color:var(--muted)}

.kanban{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;overflow:auto;padding-bottom:4px}
.col{min-width:240px;border:1px solid var(--stroke);border-radius:14px;background:rgba(15,27,45,.03);padding:10px}
.col-head{font-weight:950;margin:4px 4px 10px}
.task{border:1px solid var(--stroke);border-radius:14px;background:var(--surface);padding:10px;margin-bottom:10px}
.task b{display:block;font-weight:950}
.task span{display:block;margin-top:4px;font-size:12px;color:var(--muted)}

.table{display:flex;flex-direction:column;gap:10px}
.trow{display:grid;grid-template-columns:2.2fr 1fr 1fr 1fr auto;gap:12px;align-items:center;padding:12px;border:1px solid var(--stroke);border-radius:14px;background:rgba(15,27,45,.03)}
.trow.thead{background:transparent;border:none;padding:0 2px;color:var(--muted);font-size:12px}
.muted{color:var(--muted);font-size:12px;display:block;margin-top:4px}

.form{display:flex;flex-direction:column;gap:12px}
label{font-size:12px;color:var(--muted);display:flex;flex-direction:column;gap:6px}
input,select,textarea{padding:12px 12px;border-radius:14px;border:1px solid var(--stroke);background:rgba(15,27,45,.04);color:var(--text);outline:none}
textarea{min-height:140px;resize:vertical}
.two-cols{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.three-cols{display:grid;grid-template-columns:1fr 1fr 1fr;gap:10px}

.hero{margin-bottom:18px;border-radius:var(--radius);border:1px solid var(--stroke);box-shadow:var(--shadow);padding:16px;display:flex;align-items:center;justify-content:space-between;gap:14px;background:linear-gradient(135deg,color-mix(in srgb,var(--accent) 12%,transparent),color-mix(in srgb,var(--accent2) 10%,transparent));min-width:0}
.hero-title{font-weight:950;letter-spacing:-.03em;font-size:18px}
.hero-sub{font-size:12px;color:var(--muted);margin-top:4px}
.hero-actions{display:flex;gap:10px;flex-wrap:wrap}
@media (max-width:860px){.hero{flex-direction:column;align-items:flex-start}}

.badge{display:inline-flex;align-items:center;gap:8px;padding:8px 10px;border-radius:999px;border:1px solid var(--stroke);background:rgba(15,27,45,.03);font-size:12px}
.badge .swatch{width:12px;height:12px;border-radius:999px;background:var(--accent)}

.block{border:1px solid var(--stroke);border-radius:var(--radius);background:rgba(15,27,45,.02);padding:12px}
.block+.block{margin-top:12px}
.block-title{font-weight:950}
.block-sub{font-size:12px;color:var(--muted);margin-top:4px}

.results{display:flex;flex-direction:column;gap:10px;margin-top:10px}
.result{padding:12px;border:1px solid var(--stroke);border-radius:14px;background:rgba(15,27,45,.03);display:flex;justify-content:space-between;gap:12px;align-items:flex-start}
.result b{display:block;font-weight:950}
.result span{display:block;font-size:12px;color:var(--muted);margin-top:4px}

.toast{position:fixed;right:18px;bottom:18px;z-index:99;padding:12px 14px;border-radius:14px;border:1px solid var(--stroke);background:var(--surface2);box-shadow:var(--shadow);opacity:0;transform:translateY(8px);pointer-events:none;transition:.18s ease}
.toast.show{opacity:1;transform:translateY(0)}
.toast b{display:block;font-weight:950}
.toast small{display:block;margin-top:2px;color:var(--muted)}

@media (max-width:1100px){
  .kpi{grid-column:span 6}
  .grid.two>*:first-child{grid-column:span 12}
  .grid.two>*:last-child{grid-column:span 12}
  .grid.three>.card{grid-column:span 12}
  .search{min-width:160px}
}
@media (max-width:860px){
  .app{grid-template-columns:1fr}
  .overlay{display:block;pointer-events:none}
  .overlay.is-open{pointer-events:auto}
  .sidebar{position:fixed;left:18px;right:18px;top:82px;height:auto;max-height:calc(100vh - 110px);transform:translateY(-10px);opacity:0;pointer-events:none;transition:.18s ease}
  .sidebar.is-open{opacity:1;pointer-events:auto;transform:translateY(0)}
  .burger{display:inline-grid;place-items:center}
  .search{display:none}
  .three-cols{grid-template-columns:1fr}
}
/* Theme picker (custom dropdown to avoid native select glitches) */
.theme-picker{position:relative; margin-top:10px}
.tp-btn{
  width:100%;
  display:flex;
  align-items:center;
  gap:10px;
  padding:12px 12px;
  border-radius:14px;
  border:1px solid var(--stroke);
  background:rgba(15,27,45,.04);
  color:var(--text);
  cursor:pointer;
}
.tp-btn:focus{outline:2px solid color-mix(in srgb, var(--accent) 35%, transparent); outline-offset:2px}
.tp-dot{
  width:12px; height:12px; border-radius:999px;
  background:var(--accent);
  box-shadow:0 0 0 3px color-mix(in srgb, var(--accent) 18%, transparent);
}
.tp-label{font-weight:900}
.tp-caret{margin-left:auto; color:var(--muted)}

.tp-menu{
  position:absolute;
  left:0; right:0;
  top:calc(100% + 8px);
  background:var(--surface2);
  backdrop-filter: blur(10px);
  border:1px solid var(--stroke);
  border-radius:14px;
  box-shadow:var(--shadow);
  padding:6px;
  display:none;
  max-height:260px;
  overflow:auto;
  z-index:120;
}
.tp-menu.open{display:block}

.tp-item{
  width:100%;
  display:flex;
  align-items:center;
  gap:10px;
  padding:10px 10px;
  border-radius:12px;
  border:1px solid transparent;
  background:transparent;
  color:var(--text);
  cursor:pointer;
  text-align:left;
}
.tp-item:hover{
  background:color-mix(in srgb, var(--accent) 9%, transparent);
  border-color:color-mix(in srgb, var(--accent) 16%, transparent);
}
.tp-item.active{
  background:color-mix(in srgb, var(--accent) 12%, transparent);
  border-color:color-mix(in srgb, var(--accent) 24%, transparent);
}
.tp-swatch{
  width:14px; height:14px; border-radius:999px;
  background:var(--accent);
}
.tp-name{font-weight:900}
.tp-meta{margin-left:auto; font-size:12px; color:var(--muted)}

/* Theme picker in topbar (compact) */
.topbar .theme-picker{margin-top:0}
.topbar-theme{margin-top:0}
.topbar-theme .tp-btn{width:auto}
.tp-btn.tp-compact{padding:8px 10px;border-radius:999px}
.tp-btn.tp-compact .tp-label{font-size:12px;max-width:150px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.topbar-theme .tp-menu{left:auto;right:0;width:min(320px, calc(100vw - 24px))}


/* Modal */
.modal{display:none;position:fixed;inset:0;z-index:80;align-items:center;justify-content:center;padding:18px}
.modal.is-open{display:flex}
.modal-backdrop{position:absolute;inset:0;background:rgba(0,0,0,.45);backdrop-filter:blur(2px)}
.modal-card{position:relative;max-width:920px;width:100%;background:var(--surface2);backdrop-filter:blur(12px);
  border:1px solid var(--stroke);border-radius:var(--radius);box-shadow:var(--shadow);padding:14px}
.modal-card.sm{max-width:640px}
.modal-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;padding:8px 8px 12px;border-bottom:1px solid var(--stroke)}
.modal-title{font-weight:800;font-size:18px}
.modal-sub{color:var(--muted);font-size:13px;margin-top:2px}
.modal-body{padding:12px 8px}
.modal-foot{display:flex;gap:10px;justify-content:flex-end;align-items:center;padding:12px 8px 6px;border-top:1px solid var(--stroke)}
.iconbtn{display:inline-flex;align-items:center;justify-content:center;width:34px;height:34px;border-radius:10px;border:1px solid var(--stroke);
  background:rgba(255,255,255,.55);cursor:pointer}
.iconbtn:hover{filter:brightness(.98)}
.iconbtn.danger{border-color:rgba(239,68,68,.35);background:rgba(239,68,68,.08)}
@media (max-width: 820px){
  .modal{padding:10px}
  .modal-card{padding:12px}
}

/* Appeals list: show ~6 items then scroll */
.scroll6{max-height:420px;overflow:auto;padding-right:6px}

/* Tabs (simple) */
.tabs{display:flex;gap:8px;flex-wrap:wrap;margin:0 0 12px}
.tab{padding:9px 12px;border-radius:999px;border:1px solid var(--stroke);background:rgba(15,27,45,.03);text-decoration:none;font-size:12px;font-weight:900;color:var(--text)}
.tab:hover{background:color-mix(in srgb,var(--accent) 10%,transparent);border-color:color-mix(in srgb,var(--accent) 20%,var(--stroke))}
.tab.active{background:color-mix(in srgb,var(--accent) 14%,transparent);border-color:color-mix(in srgb,var(--accent) 30%,transparent);color:var(--accent)}

.small-help{font-size:12px;color:var(--muted);margin-top:6px}

/* Notifications (bell dropdown) */
.notif-wrap{position:relative}
.notif-badge{display:inline-flex;align-items:center;justify-content:center;min-width:18px;height:18px;padding:0 5px;
  border-radius:999px;background:var(--accent);color:#fff;font-size:11px;font-weight:900;margin-left:6px}
.notif{position:absolute;right:0;top:46px;width:min(380px, calc(100vw - 24px));
  background:var(--surface2);backdrop-filter:blur(12px);border:1px solid var(--stroke);border-radius:16px;box-shadow:var(--shadow);
  overflow:hidden;z-index:90}
.notif-head{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:10px 12px;border-bottom:1px solid var(--stroke)}
.notif-title{font-weight:900}
.notif-list{max-height:360px;overflow:auto}
.notif-row{display:flex;align-items:stretch;gap:8px;border-bottom:1px solid var(--stroke)}
.notif-item{flex:1;display:block;padding:10px 12px;text-decoration:none;color:inherit;border:0}
.notif-item:hover{background:rgba(15,27,45,.03)}
.notif-item.unread{background:color-mix(in srgb,var(--accent) 9%,transparent)}
.notif-mark{align-self:stretch;display:inline-flex;align-items:center;justify-content:center;
  width:42px;border:0;background:transparent;color:var(--muted);font-weight:900;cursor:pointer}
.notif-mark:hover{background:rgba(15,27,45,.05);color:var(--text)}
.notif-mark:active{transform:translateY(1px)}
.notif-item .t{font-weight:900;font-size:13px;margin-bottom:2px}
.notif-item .m{color:var(--muted);font-size:12px;line-height:1.35;white-space:pre-wrap}
.notif-item .d{color:var(--muted);font-size:11px;margin-top:6px}
.notif-empty{padding:14px 12px;color:var(--muted);font-size:13px}
.notif-foot{padding:10px 12px;border-top:1px solid var(--stroke);font-size:12px}
.notif-foot a{text-decoration:none;color:var(--accent);font-weight:900}

.flash-focus{outline:2px solid color-mix(in srgb,var(--accent) 50%, transparent);outline-offset:2px;
  box-shadow:0 0 0 4px color-mix(in srgb,var(--accent) 14%, transparent)}

/* Approvals accordion (cabinet) */
.row-details{border:1px solid var(--stroke);border-radius:14px;background:rgba(15,27,45,.03);padding:0;overflow:hidden}
.row-details + .row-details{margin-top:10px}
.row-details > summary{list-style:none;display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px;cursor:pointer}
.row-details > summary::-webkit-details-marker{display:none}
.row-details[open] > summary{background:rgba(15,27,45,.02);border-bottom:1px solid var(--stroke)}
.row-detail-body{padding:12px}

/* Collapsible cards (osbb) */
.stack{display:flex;flex-direction:column;gap:14px}
.collapsible{padding:0}
.collapsible > summary{list-style:none;cursor:pointer}
.collapsible > summary::-webkit-details-marker{display:none}
.collapsible[open] > summary{border-bottom:1px solid var(--stroke)}
.card-pad{padding:12px 14px 14px}
.summary-actions{display:flex;gap:8px;align-items:center}

/* Triangle collapse button (bottom) */
.collapse-foot{display:flex;justify-content:center;margin-top:10px}


/* Checks row */
.checks{display:flex;gap:10px;flex-wrap:wrap;margin-top:8px}
.check{display:flex;align-items:center;gap:8px;font-size:12px;color:var(--text);font-weight:900}
.check input{transform:translateY(1px)}
