/* ═══════════════════════════════════════════════════════════════
   DESIGN SYSTEM — merged from globals.css + v2 refinements
   Palette: teal-deep / ivory / charcoal from original app
═══════════════════════════════════════════════════════════════ */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --teal:#0a7c78;
  --teal-deep:#0f5c5a;
  --teal-soft:rgba(10,124,120,.10);
  --teal-mid:rgba(10,124,120,.18);
  --ivory:#fbf7f1;
  --sand:#efe2d1;
  --charcoal:#243230;
  --fog:#6f7b78;
  --line:rgba(36,50,48,.14);
  --line2:rgba(36,50,48,.20);
  --panel:rgba(255,255,255,.92);
  --panel2:rgba(255,255,255,.75);
  --shadow:0 1px 2px rgba(36,50,48,.04),0 8px 24px rgba(36,50,48,.07);
  --shadow-lg:0 22px 60px rgba(36,50,48,.12);
  --r:20px;--rsm:14px;--rxs:10px;--rchip:999px;
  --f:'DM Sans',system-ui,sans-serif;
  --mono:'DM Mono',monospace;
  --nav:272px;
  --red:#b94040;--red-soft:rgba(185,64,64,.10);
  --amber:#ae7f2c;--amber-soft:rgba(174,127,44,.10);
  --green:#2a6b4a;--green-soft:rgba(42,107,74,.10);
  --blue:#2563ab;--blue-soft:rgba(37,99,171,.10);
}
html,body{height:100%;overflow:hidden}
body{background:radial-gradient(circle at 100% 0%,rgba(10,124,120,.06),transparent 38%),#faf6ee;color:var(--charcoal);font-family:var(--f);font-size:14px;line-height:1.55}

/* ─── SHELL ──────────────────────────────────────────────── */
.shell{display:flex;height:100vh;overflow:hidden}

/* ─── SIDEBAR ────────────────────────────────────────────── */
.sidebar{width:var(--nav);height:100vh;background:rgba(255,255,255,.98);border-right:1px solid var(--line);display:flex;flex-direction:column;flex-shrink:0;box-shadow:var(--shadow);position:relative;z-index:40}
.sidebar-top{padding:18px 18px 14px;border-bottom:1px solid var(--line)}
.brand-row{display:flex;align-items:flex-start;gap:11px}
.brand-row>div:last-child{display:flex;flex-direction:column;gap:2px;min-width:0}
.brand-btn{display:flex;align-items:flex-start;gap:11px;background:none;border:none;padding:0;cursor:pointer;font-family:var(--f);text-align:left}
.brand-mark{width:36px;height:36px;border-radius:10px;background:linear-gradient(145deg,var(--teal),var(--teal-deep));display:flex;align-items:center;justify-content:center;flex-shrink:0;box-shadow:inset 0 1px 0 rgba(255,255,255,.2)}
.brand-mark.has-image{background:transparent;box-shadow:none}
.brand-mark svg{width:20px;height:20px}
.brand-mark img{width:100%;height:100%;object-fit:cover;border-radius:inherit;display:block}
.brand-name{font-size:15px;font-weight:700;letter-spacing:-.35px;color:var(--charcoal);line-height:1.15;white-space:nowrap;max-width:180px;overflow:hidden;text-overflow:ellipsis}
.brand-sub{font-size:10px;font-weight:600;color:var(--fog);font-family:var(--f);letter-spacing:.08em;margin-top:2px;text-transform:uppercase}
.mobile-nav-close{display:none;background:none;border:none;color:var(--fog);cursor:pointer;font-size:22px;line-height:1;padding:4px;width:32px;height:32px;border-radius:10px}
.mobile-nav-close:hover{background:var(--teal-soft);color:var(--teal-deep)}
.mobile-logo-toggle{display:none}
.sidebar-nav{padding:12px 12px;flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:18px}
.nav-section-label{font-size:10px;color:var(--fog);font-family:var(--mono);letter-spacing:.08em;text-transform:uppercase;padding:0 10px;margin-bottom:3px;opacity:.8}
.ni{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:var(--rsm);cursor:pointer;color:var(--fog);font-size:13px;font-weight:500;transition:all .12s;border:none;background:none;width:100%;font-family:var(--f);text-align:left;position:relative}
.ni:hover{background:var(--teal-soft);color:var(--teal-deep)}
.ni.on{background:var(--teal-soft);color:var(--teal-deep);font-weight:600}
.ni-icon{width:18px;height:18px;flex-shrink:0;opacity:.6}
.ni.on .ni-icon,.ni:hover .ni-icon{opacity:1}
.ni-badge{margin-left:auto;font-size:10px;padding:2px 7px;border-radius:var(--rchip);font-family:var(--mono);font-weight:600}
.nb-red{background:var(--red-soft);color:var(--red)}
.nb-teal{background:var(--teal-soft);color:var(--teal-deep)}
.sidebar-foot{padding:12px;border-top:1px solid var(--line)}
.user-pill{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:var(--rsm);cursor:pointer}
.user-pill:hover{background:var(--teal-soft)}
.uav{width:30px;height:30px;border-radius:var(--rchip);background:linear-gradient(145deg,var(--teal),var(--teal-deep));display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:700;color:#fff;flex-shrink:0;font-family:var(--mono)}
.uname{font-size:12px;font-weight:600;color:var(--charcoal)}
.urole{font-size:10px;color:var(--fog)}

/* ─── MAIN ───────────────────────────────────────────────── */
.main{flex:1;min-width:0;display:flex;flex-direction:column;overflow:hidden}
.topbar{padding:18px 24px;border-bottom:1px solid var(--line);background:rgba(255,255,255,.97);display:flex;align-items:center;justify-content:space-between;flex-shrink:0;gap:16px}
.topbar-copy{display:flex;flex-direction:column;gap:4px;min-width:0}
.eyebrow{font-size:11px;text-transform:uppercase;letter-spacing:.08em;color:var(--fog);font-weight:500;margin-bottom:0}
.page-title{font-size:26px;font-weight:600;letter-spacing:-.5px;color:var(--charcoal);line-height:1.15}
.topbar-actions{display:flex;gap:10px;align-items:center;flex-shrink:0;padding-top:0}
.content{flex:1;overflow-y:auto;padding:22px 24px}
.mobile-nav-scrim{display:none}

/* ─── BUTTONS ────────────────────────────────────────────── */
.btn{display:inline-flex;align-items:center;gap:6px;padding:10px 16px;border-radius:var(--rchip);font-size:13px;font-weight:500;cursor:pointer;border:none;transition:all .12s;font-family:var(--f);line-height:1.2;white-space:nowrap}
.btn-primary{background:linear-gradient(145deg,var(--teal),var(--teal-deep));color:#fff;box-shadow:0 2px 8px rgba(10,124,120,.25)}
.btn-primary:hover{background:linear-gradient(145deg,#0b8a86,var(--teal-deep));box-shadow:0 3px 12px rgba(10,124,120,.32)}
.btn-secondary{background:var(--panel2);color:var(--charcoal);border:1px solid var(--line)}
.btn-secondary:hover{background:var(--panel);border-color:var(--line2)}
.btn-danger{background:var(--red-soft);color:var(--red);border:1px solid rgba(185,64,64,.18)}
.btn-danger:hover{background:rgba(185,64,64,.16)}
.btn-ok{background:var(--green-soft);color:var(--green);border:1px solid rgba(42,107,74,.18)}
.btn-ok:hover{background:rgba(42,107,74,.16)}
.btn-sm{padding:8px 14px;font-size:12px}
.btn-xs{padding:5px 10px;font-size:11px}

/* ─── PANELS / CARDS ─────────────────────────────────────── */
.panel{background:var(--panel);border:1px solid var(--line);border-radius:var(--r);padding:22px;box-shadow:var(--shadow)}
.panel-sm{padding:16px 18px}
.metric-card{background:var(--panel);border:1px solid var(--line);border-radius:var(--r);padding:22px 24px;box-shadow:var(--shadow)}
.metric-val{font-size:42px;font-weight:600;letter-spacing:-1.5px;line-height:1;margin:10px 0 7px;color:var(--charcoal);display:block;font-family:var(--f)}
.metric-label{font-size:12px;color:var(--fog);display:block;font-family:var(--f)}
.metric-sub{font-size:11px;color:var(--fog);opacity:.8;display:block;margin-top:4px;font-family:var(--f)}

/* ─── GRIDS ──────────────────────────────────────────────── */
.g2{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.g3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:16px}
.g4{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.g3-2{display:grid;grid-template-columns:1.5fr 1fr;gap:16px;align-items:start}
.g2-stack{display:grid;gap:16px}
.off-grid{display:grid;grid-template-columns:1.08fr .92fr;gap:20px;align-items:start}
.section-actions-row{display:flex;justify-content:space-between;align-items:center;gap:10px;flex-wrap:wrap}
.blockout-toolbar{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px;flex-wrap:wrap;gap:10px}
.bo-nav-btn{-webkit-appearance:none;appearance:none;width:44px;height:44px;border-radius:50%;border:1px solid var(--line2);background:rgba(255,255,255,.96);color:var(--charcoal);font-size:20px;display:flex;align-items:center;justify-content:center;cursor:pointer;box-shadow:var(--shadow)}
.bo-nav-btn:hover{background:var(--panel);border-color:rgba(10,124,120,.22);color:var(--teal-deep)}
.bo-view-switch{display:flex;background:rgba(36,50,48,.06);border-radius:999px;padding:4px;gap:3px;box-shadow:inset 0 1px 0 rgba(255,255,255,.3)}
.bo-view-pill{-webkit-appearance:none;appearance:none;padding:8px 18px;border-radius:999px;border:none;font-size:12px;font-weight:600;cursor:pointer;font-family:var(--f);transition:all .12s;background:transparent;color:var(--fog)}
.bo-view-pill.on{background:#fff;color:var(--teal-deep);box-shadow:0 4px 14px rgba(36,50,48,.08)}
.bo-view-pill:hover{color:var(--teal-deep)}
.bo-cal-shell{border:1px solid var(--line);border-radius:var(--r);overflow:hidden;background:rgba(255,255,255,.96);box-shadow:var(--shadow)}
.bo-cal-head{display:grid;grid-template-columns:repeat(7,1fr);background:rgba(36,50,48,.035);border-bottom:1px solid var(--line)}
.bo-cal-head-cell{padding:10px 8px 12px;text-align:center}
.bo-cal-head-day{font-size:10px;font-family:var(--mono);letter-spacing:.06em;color:var(--fog);text-transform:uppercase}
.bo-cal-head-date{font-size:16px;font-weight:600;line-height:1.1;color:var(--charcoal);margin-top:4px}
.bo-cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:0}
.bo-cell{-webkit-appearance:none;appearance:none;width:100%;min-height:80px;padding:8px;border:none;border-right:1px solid rgba(36,50,48,.12);border-bottom:1px solid rgba(36,50,48,.12);background:#fff;cursor:pointer;transition:background .12s,border-color .12s,box-shadow .12s;color:var(--charcoal);text-align:left}
.bo-cell:hover{background:rgba(10,124,120,.05)}
.bo-cell.cal-other{background:rgba(36,50,48,.025)}
.bo-cell.cal-today{background:rgba(10,124,120,.06)}
.bo-cell:focus{outline:none;box-shadow:inset 0 0 0 2px rgba(37,99,171,.2)}
.bo-cell-top{font-size:10px;font-family:var(--mono);color:var(--fog);margin-bottom:8px}
.bo-cell-copy{font-size:11px;color:var(--fog);line-height:1.3}
.scroll-panel{overflow:hidden}
.mobile-card-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px}
.settings-shell{max-width:780px}
.lt-mobile-list{display:grid;gap:12px}
.lt-mobile-card{background:rgba(255,255,255,.9);border:1px solid var(--line);border-radius:16px;padding:14px 15px;box-shadow:var(--shadow)}
.lt-mobile-top{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:12px}
.lt-mobile-meta{display:grid;grid-template-columns:1fr 1fr;gap:10px 12px;margin-bottom:12px}
.lt-mobile-meta div{min-width:0}
.lt-mobile-meta label{display:block;font-size:10px;color:var(--fog);text-transform:uppercase;letter-spacing:.07em;margin-bottom:4px}
.lt-mobile-actions{display:flex;align-items:center;justify-content:space-between;gap:10px;flex-wrap:wrap}
.slim-scroll{scrollbar-width:thin;scrollbar-color:rgba(36,50,48,.22) transparent}
.report-card-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:16px;margin-bottom:28px}
.report-card-grid > .panel:nth-child(n+4){grid-column:auto}
.report-stats-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:16px;margin-bottom:24px}
.mobile-rail-tip{position:fixed;left:0;top:0;display:none;pointer-events:none;z-index:120;background:rgba(36,50,48,.94);color:#fff;font-size:11px;line-height:1.2;padding:7px 10px;border-radius:10px;white-space:nowrap;box-shadow:var(--shadow-lg)}
#role-editor .perm-rule-row{display:flex;align-items:flex-start;gap:16px;padding:16px 0;border-bottom:1px solid var(--line)}
#role-editor .perm-rule-copy{flex:1;min-width:0}
#role-editor .perm-rule-ctrl{flex-shrink:0;min-width:260px}
#role-editor .perm-scope-panel{display:none;margin-left:24px;margin-top:4px}
#role-editor .perm-scope-panel .fi{font-size:12px;padding:7px 10px}
#role-editor .perm-tag-row{display:flex;flex-wrap:wrap;gap:4px;margin-top:5px}

/* ─── SECTION HEADER ─────────────────────────────────────── */
.sh{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:16px;gap:16px}
.sh h2{font-size:18px;font-weight:600;letter-spacing:-.3px;margin:0}
.sh .eyebrow{margin-bottom:4px}

/* ─── CHIPS / BADGES ─────────────────────────────────────── */
.chip{display:inline-flex;align-items:center;padding:5px 10px;border-radius:var(--rchip);font-size:11px;font-weight:500;font-family:var(--mono);white-space:nowrap}
.chip-teal{background:var(--teal-soft);color:var(--teal-deep);border:1px solid rgba(10,124,120,.18)}
.chip-green{background:var(--green-soft);color:var(--green);border:1px solid rgba(42,107,74,.18)}
.chip-red{background:var(--red-soft);color:var(--red);border:1px solid rgba(185,64,64,.18)}
.chip-amber{background:var(--amber-soft);color:var(--amber);border:1px solid rgba(174,127,44,.18)}
.chip-blue{background:var(--blue-soft);color:var(--blue);border:1px solid rgba(37,99,171,.18)}
.chip-muted{background:rgba(36,50,48,.06);color:var(--fog);border:1px solid var(--line)}
.status-chip{padding:8px 14px;background:var(--teal-soft);color:var(--teal-deep);border-radius:var(--rchip);font-weight:500;font-size:12px}

/* ─── TABLE / LIST ───────────────────────────────────────── */
.tbl{width:100%;border-collapse:collapse}
.tbl th{text-align:left;font-size:10px;color:var(--fog);font-family:var(--mono);font-weight:500;letter-spacing:.07em;text-transform:uppercase;padding:0 16px 12px;border-bottom:1px solid var(--line)}
.tbl td{padding:12px 16px;border-bottom:1px solid var(--line);font-size:13px;vertical-align:middle;color:var(--charcoal)}
.tbl tr:last-child td{border-bottom:none}
.tbl tbody tr{transition:background .08s}
.tbl tbody tr:hover td{background:rgba(10,124,120,.04)}

/* ─── EMP ────────────────────────────────────────────────── */
.emp{display:flex;align-items:center;gap:10px}
.av{border-radius:var(--rchip);display:flex;align-items:center;justify-content:center;font-weight:700;flex-shrink:0;font-family:var(--mono);font-size:10px;color:#fff}
.av-sm{width:30px;height:30px}
.av-md{width:38px;height:38px;font-size:13px}
.av-lg{width:48px;height:48px;font-size:16px}
.emp-name{font-size:13px;font-weight:600;color:var(--charcoal)}
.emp-meta{font-size:11px;color:var(--fog)}

/* ─── PROGRESS ───────────────────────────────────────────── */
.prog{height:4px;background:rgba(36,50,48,.08);border-radius:2px;overflow:hidden;margin-top:6px}
.prog-fill{height:100%;border-radius:2px;background:var(--teal)}

/* ─── TABS ───────────────────────────────────────────────── */
.tabs{display:flex;gap:0;border-bottom:1px solid var(--line);margin-bottom:20px}
.tab{padding:9px 14px;font-size:13px;cursor:pointer;color:var(--fog);border:none;background:none;font-family:var(--f);font-weight:500;transition:all .1s;border-bottom:2px solid transparent;margin-bottom:-1px;white-space:nowrap}
.tab:hover{color:var(--teal-deep)}
.tab.on{color:var(--teal-deep);border-bottom-color:var(--teal-deep)}
.tab-count{margin-left:5px;color:var(--fog);font-weight:400;font-size:12px}
.tab.on .tab-count{color:var(--teal-deep)}

/* ─── FORM ───────────────────────────────────────────────── */
.field{margin-bottom:14px}
.field label{display:block;font-size:12px;color:var(--fog);margin-bottom:6px;font-weight:500}
.fi{width:100%;background:rgba(255,255,255,.9);border:1px solid var(--line);border-radius:var(--rsm);padding:11px 14px;color:var(--charcoal);font-size:13px;font-family:var(--f);outline:none;transition:border-color .12s;-webkit-appearance:none}
.fi:focus{border-color:var(--teal)}
.fi[readonly]{background:rgba(36,50,48,.04);color:var(--fog);cursor:not-allowed}
select.fi{cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath d='M2.5 4.5 6 8l3.5-3.5' stroke='%230f5c5a' stroke-width='1.4' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:32px}
.fi[type="date"]{cursor:pointer;background-image:none;padding-right:14px;min-height:44px}
.fi[type="date"]::-webkit-calendar-picker-indicator{opacity:.7;cursor:pointer}
.fi[type="date"]::-webkit-datetime-edit{color:var(--charcoal)}
.field-note{font-size:11px;color:var(--fog);margin-top:5px;line-height:1.4;opacity:.8}
.frow{display:grid;grid-template-columns:1fr 1fr;gap:12px}

/* ─── MODAL ──────────────────────────────────────────────── */
.overlay{display:none;position:fixed;inset:0;background:rgba(36,50,48,.32);z-index:300;align-items:center;justify-content:center;padding:20px}
.overlay.open{display:flex}
.modal{background:rgba(255,255,255,.98);border:1px solid var(--line2);border-radius:var(--r);padding:26px;width:500px;max-width:100%;max-height:92vh;overflow-y:auto;box-shadow:var(--shadow-lg)}
.modal-lg{width:580px}
.modal-hd{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}
.modal-title{font-size:15px;font-weight:600;color:var(--charcoal)}
.mc{background:none;border:none;color:var(--fog);cursor:pointer;font-size:20px;line-height:1;padding:4px;width:28px;height:28px;display:flex;align-items:center;justify-content:center;border-radius:8px}
.mc:hover{background:var(--teal-soft);color:var(--teal-deep)}

/* ─── AUTH ──────────────────────────────────────────────── */
.auth-gate{position:fixed;inset:0;z-index:500;display:none;background:
  radial-gradient(circle at 0% 0%,rgba(10,124,120,.12),transparent 34%),
  radial-gradient(circle at 100% 100%,rgba(174,127,44,.10),transparent 30%),
  #faf6ee;overflow:auto}
.auth-gate.open{display:block}
.auth-wrap{min-height:100vh;display:grid;grid-template-columns:1.05fr .95fr}
.auth-side{padding:48px 44px;display:flex;flex-direction:column;justify-content:space-between;background:linear-gradient(160deg,rgba(10,124,120,.10),rgba(255,255,255,.45))}
.auth-brand{display:flex;align-items:center;gap:14px;margin-bottom:28px}
.auth-brand-copy{display:flex;flex-direction:column;gap:3px}
.auth-kicker{font-size:11px;text-transform:uppercase;letter-spacing:.08em;color:var(--fog);font-weight:600}
.auth-hero{max-width:520px}
.auth-hero h1{font-size:44px;line-height:1.02;letter-spacing:-1.6px;margin-bottom:14px}
.auth-hero p{font-size:15px;color:var(--fog);max-width:460px}
.auth-points{display:grid;gap:12px;margin-top:24px}
.auth-point{display:flex;gap:10px;align-items:flex-start;padding:12px 14px;border:1px solid rgba(36,50,48,.1);border-radius:16px;background:rgba(255,255,255,.58)}
.auth-point strong{display:block;font-size:13px;margin-bottom:2px}
.auth-point span{font-size:12px;color:var(--fog);line-height:1.45}
.auth-card-wrap{padding:34px;display:flex;align-items:center;justify-content:center}
.auth-card{width:min(100%,460px);background:rgba(255,255,255,.96);border:1px solid var(--line);border-radius:28px;box-shadow:var(--shadow-lg);padding:30px 28px}
.auth-tabs{display:flex;gap:6px;padding:4px;background:rgba(36,50,48,.05);border-radius:999px;margin-bottom:18px}
.auth-tab{flex:1;border:none;background:transparent;border-radius:999px;padding:10px 14px;font-family:var(--f);font-size:13px;font-weight:600;color:var(--fog);cursor:pointer;transition:all .12s}
.auth-tab.on{background:#fff;color:var(--teal-deep);box-shadow:var(--shadow)}
.auth-panel{display:none}
.auth-panel.on{display:block}
.auth-title{font-size:26px;letter-spacing:-.7px;margin-bottom:8px}
.auth-sub{font-size:13px;color:var(--fog);margin-bottom:18px}
.auth-form{display:grid;gap:12px}
.auth-actions{display:flex;gap:10px;flex-wrap:wrap;margin-top:6px}
.auth-skip{margin-top:14px;display:flex;justify-content:center}
.auth-skip button{background:none;border:none;color:var(--fog);font:600 12px var(--f);cursor:pointer}
.auth-skip button:hover{color:var(--teal-deep)}
.auth-note{margin-top:14px;padding:11px 12px;border-radius:14px;background:rgba(36,50,48,.04);border:1px solid var(--line);font-size:11px;color:var(--fog);line-height:1.45}
.app-hidden{display:none!important}

/* ─── TIMELINE ───────────────────────────────────────────── */
.tl{padding-left:22px;position:relative}
.tl::before{content:'';position:absolute;left:6px;top:8px;bottom:8px;width:1px;background:var(--line2)}
.tl-item{position:relative;margin-bottom:14px}
.tl-dot{position:absolute;left:-19px;top:4px;width:9px;height:9px;border-radius:50%}
.tl-done{background:var(--green)}
.tl-active{background:var(--teal)}
.tl-pending{background:rgba(36,50,48,.2)}
.tl-title{font-size:13px;font-weight:600;color:var(--charcoal)}
.tl-meta{font-size:11px;color:var(--fog);margin-top:2px;line-height:1.4}

/* ─── AUDIT ──────────────────────────────────────────────── */
.arow{display:flex;gap:10px;padding:10px 0;border-bottom:1px solid var(--line);align-items:flex-start}
.arow:last-child{border-bottom:none}
.atime{font-size:10px;font-family:var(--mono);color:var(--fog);flex-shrink:0;width:84px;padding-top:2px}
.aico{width:20px;height:20px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:9px;font-weight:700;flex-shrink:0;margin-top:1px;font-family:var(--mono)}
.aico-r{background:var(--red-soft);color:var(--red)}
.aico-b{background:var(--blue-soft);color:var(--blue)}
.aico-a{background:var(--amber-soft);color:var(--amber)}
.aico-g{background:var(--green-soft);color:var(--green)}
.aico-n{background:rgba(36,50,48,.06);color:var(--fog)}
.aact{font-size:12px;font-weight:600;color:var(--charcoal)}
.amet{font-size:11px;color:var(--fog);margin-top:1px;line-height:1.4}

/* ─── ALERTS ─────────────────────────────────────────────── */
.alert{display:flex;gap:10px;padding:12px 14px;border-radius:var(--rsm);font-size:12px;align-items:flex-start;line-height:1.5}
.al-warn{background:var(--amber-soft);border:1px solid rgba(174,127,44,.2);color:var(--amber)}
.al-ok{background:var(--green-soft);border:1px solid rgba(42,107,74,.2);color:var(--green)}
.al-info{background:var(--teal-soft);border:1px solid rgba(10,124,120,.2);color:var(--teal-deep)}
.al-danger{background:var(--red-soft);border:1px solid rgba(185,64,64,.2);color:var(--red)}
.al-muted{background:rgba(36,50,48,.05);border:1px solid var(--line);color:var(--fog)}

/* ─── RESULT BOX ─────────────────────────────────────────── */
.rbox{background:rgba(36,50,48,.03);border:1px solid var(--line);border-radius:var(--rsm);padding:16px}
.rline{display:flex;justify-content:space-between;align-items:baseline;padding:6px 0;border-bottom:1px solid var(--line)}
.rline:last-child{border-bottom:none;padding-top:12px}
.rlbl{font-size:12px;color:var(--fog)}
.rval{font-size:13px;font-family:var(--mono);font-weight:500;color:var(--charcoal)}

/* ─── CHART BARS ─────────────────────────────────────────── */
.cbar{display:flex;align-items:center;gap:10px;margin-bottom:9px}
.cbar-lbl{font-size:12px;color:var(--fog);width:72px;text-align:right;flex-shrink:0}
.cbar-track{flex:1;height:18px;background:rgba(36,50,48,.06);border-radius:6px;overflow:hidden}
.cbar-fill{height:100%;border-radius:6px;display:flex;align-items:center;justify-content:flex-end;padding-right:7px}
.cbar-fill span{font-size:10px;font-family:var(--mono);color:#fff;font-weight:600}

/* ─── CALENDAR ───────────────────────────────────────────── */
.cal-shell{border:1px solid var(--line);border-radius:var(--r);overflow:hidden;background:var(--panel);box-shadow:var(--shadow)}
.cal-hd{display:grid;grid-template-columns:repeat(7,1fr);background:rgba(36,50,48,.04);border-bottom:1px solid var(--line)}
.cal-dlbl{text-align:center;font-size:10px;color:var(--fog);font-family:var(--mono);padding:9px;text-transform:uppercase;letter-spacing:.06em}
.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:0}
.ccell{background:rgba(255,255,255,.7);min-height:80px;padding:8px;cursor:pointer;transition:background .08s;border-right:1px solid var(--line);border-bottom:1px solid var(--line)}
.ccell:hover{background:rgba(10,124,120,.05)}
.ccell.cal-today{background:rgba(10,124,120,.07)}
.ccell.cal-today .cdate{color:var(--teal-deep);font-weight:700}
.ccell.cal-other .cdate{color:var(--fog);opacity:.5}
.ccell.blockout{background:rgba(185,64,64,.06);border-color:rgba(185,64,64,.2)}
.cdate{font-size:10px;font-family:var(--mono);color:var(--fog);margin-bottom:3px;display:inline-block}
.cev{font-size:9px;padding:2px 5px;border-radius:5px;margin-bottom:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-weight:500;line-height:1.4}
.ev-a{background:rgba(10,124,120,.14);color:var(--teal-deep)}
.ev-s{background:var(--amber-soft);color:var(--amber)}
.ev-p{background:var(--green-soft);color:var(--green)}
.ev-bo{background:var(--red-soft);color:var(--red)}

/* ─── BALANCE BARS ───────────────────────────────────────── */
.brow{display:flex;align-items:center;gap:10px;margin-bottom:9px}
.blbl{font-size:12px;color:var(--fog);width:120px;flex-shrink:0}
.btrack{flex:1;height:4px;background:rgba(36,50,48,.08);border-radius:2px;overflow:hidden}
.bfill{height:100%;border-radius:2px;background:var(--teal)}
.bval{font-size:11px;font-family:var(--mono);color:var(--fog);width:50px;text-align:right;flex-shrink:0}

/* ─── DEL CARD ───────────────────────────────────────────── */
.delcard{background:rgba(255,255,255,.7);border:1px solid var(--line);border-radius:var(--rsm);padding:12px 14px;display:flex;align-items:center;gap:10px;margin-bottom:9px}
.delarr{color:var(--fog);font-size:13px;flex-shrink:0}
.delcard-main{display:flex;align-items:center;gap:10px;flex:1;min-width:0}
.delcard-copy{display:flex;flex-direction:column;gap:2px;min-width:0}
.delcard-date{margin-left:auto;flex-shrink:0;font-size:10px}

/* ─── TOGGLE ─────────────────────────────────────────────── */
.tw{position:relative;width:34px;height:19px;cursor:pointer;flex-shrink:0}
.tw input{opacity:0;width:0;height:0;position:absolute}
.tslider{position:absolute;inset:0;border-radius:19px;background:rgba(36,50,48,.15);transition:.2s}
.tslider::after{content:'';position:absolute;left:2px;top:2px;width:15px;height:15px;border-radius:50%;background:#fff;transition:.2s;box-shadow:0 1px 3px rgba(0,0,0,.12)}
.tw input:checked+.tslider{background:var(--teal)}
.tw input:checked+.tslider::after{transform:translateX(15px)}

/* ─── BLOCKOUT SPECIFIC ──────────────────────────────────── */
.blockout-blocked{border-left:3px solid var(--red)}
.blockout-limited{border-left:3px solid var(--amber)}
.setup-step{display:flex;align-items:center;gap:12px;padding:14px 16px;border-radius:var(--rsm);background:rgba(255,255,255,.72);border:1px solid var(--line);margin-bottom:10px}
.setup-step-num{width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:12px;flex-shrink:0;font-family:var(--mono)}
.step-done{background:var(--green-soft);color:var(--green)}
.step-active{background:var(--teal-soft);color:var(--teal-deep)}
.step-pending{background:rgba(36,50,48,.06);color:var(--fog)}
.perm-row{display:flex;align-items:center;justify-content:space-between;padding:12px 0;border-bottom:1px solid var(--line)}
.perm-row:last-child{border-bottom:none}

/* ─── PRICING ────────────────────────────────────────────── */
.pricing-card{padding:22px;border-radius:var(--r);border:1px solid var(--line);background:rgba(255,255,255,.72)}
.pricing-card.featured{background:linear-gradient(145deg,rgba(10,124,120,.10),rgba(255,255,255,.92));border-color:rgba(10,124,120,.18)}
.pricing-val{font-size:32px;font-weight:600;letter-spacing:-.8px;color:var(--charcoal);font-family:var(--mono);display:block;margin:10px 0 4px}

/* ─── TOAST ──────────────────────────────────────────────── */
#toast{position:fixed;bottom:24px;left:50%;transform:translateX(-50%);background:var(--charcoal);color:#fff;padding:10px 18px;border-radius:var(--rchip);font-size:12px;font-weight:500;opacity:0;transition:opacity .2s;pointer-events:none;z-index:999;white-space:nowrap;box-shadow:var(--shadow-lg)}

/* ─── PAGE FADE ──────────────────────────────────────────── */
@keyframes fadeIn{from{opacity:.5;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}
.page-in{animation:fadeIn .18s ease}

/* ─── HEADER BAR ──────────────────────────────────────────── */
.hdr-btn{display:flex;align-items:center;gap:5px;padding:6px 10px;border-radius:var(--rsm);background:none;border:1px solid var(--line);cursor:pointer;font-size:12px;font-weight:500;color:var(--fog);font-family:var(--f);transition:all .1s;white-space:nowrap}
.hdr-btn:hover{background:var(--teal-soft);color:var(--teal-deep);border-color:rgba(10,124,120,.2)}
.hdr-icon{padding:6px 8px}
.hdr-avatar-btn{padding:3px;border-radius:50%;border:1px solid var(--line)}
.hdr-dd{position:fixed;background:rgba(255,255,255,.98);border:1px solid var(--line2);border-radius:var(--rsm);box-shadow:0 8px 32px rgba(36,50,48,.16),0 2px 8px rgba(36,50,48,.08);z-index:9000;overflow:hidden;backdrop-filter:blur(12px)}
.hdr-dd-title{font-size:11px;font-weight:600;color:var(--fog);text-transform:uppercase;letter-spacing:.07em;padding:10px 14px 6px;border-bottom:1px solid var(--line)}
.hdr-dd-item{padding:9px 14px;font-size:13px;color:var(--charcoal);cursor:pointer;transition:background .08s}
.hdr-dd-item:hover{background:var(--teal-soft);color:var(--teal-deep)}
.hdr-notif-item{padding:10px 14px;border-bottom:1px solid var(--line);cursor:pointer;transition:background .08s}
.hdr-notif-item:last-child{border-bottom:none}
.hdr-notif-item:hover{background:var(--teal-soft)}
.hdr-notif-item.unread{background:rgba(10,124,120,.04)}
::-webkit-scrollbar{width:3px;height:3px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:rgba(36,50,48,.15);border-radius:999px}
.slim-scroll::-webkit-scrollbar{width:3px;height:3px}
.slim-scroll::-webkit-scrollbar-track{background:transparent}
.slim-scroll::-webkit-scrollbar-thumb{background:rgba(36,50,48,.18);border-radius:999px}

/* ─── DIV ────────────────────────────────────────────────── */
.div{height:1px;background:var(--line);margin:16px 0}

/* ─── SOFT CHIP BUTTON ───────────────────────────────────── */
.soft-chip{display:inline-flex;align-items:center;padding:7px 12px;border-radius:var(--rchip);background:rgba(36,50,48,.06);color:var(--fog);font-weight:500;font-size:12px;border:none;cursor:pointer;font-family:var(--f);transition:all .1s}
.soft-chip:hover,.soft-chip.active{background:var(--teal-soft);color:var(--teal-deep)}

/* ─── INFO TIPS ──────────────────────────────────────────── */
.tip-wrap{position:relative;display:inline-flex;align-items:center;margin-left:5px;vertical-align:middle}
.tip-icon{width:16px;height:16px;border-radius:50%;background:rgba(36,50,48,.08);border:1px solid var(--line2);display:inline-flex;align-items:center;justify-content:center;font-size:9px;font-weight:700;color:var(--fog);cursor:pointer;flex-shrink:0;transition:all .1s;line-height:1}
.tip-icon:hover{background:var(--teal-soft);color:var(--teal-deep);border-color:rgba(10,124,120,.2)}
.tip-balloon{display:none;position:absolute;left:0;top:calc(100% + 8px);width:260px;background:var(--panel);border:1px solid var(--line2);border-radius:var(--rsm);padding:11px 13px;font-size:12px;color:var(--fog);line-height:1.5;box-shadow:var(--shadow-lg);z-index:60;font-family:var(--f)}
.tip-balloon.tip-right{left:auto;right:0}
.tip-balloon.tip-up{top:auto;bottom:calc(100% + 8px)}
.tip-balloon.open{display:block}
.tip-close-btn{float:right;background:none;border:none;cursor:pointer;color:var(--t3);font-size:16px;line-height:1;margin-left:8px;padding:0;transition:color .1s}
.tip-close-btn:hover{color:var(--charcoal)}

/* ─── MULTI-SELECT (unified) ─────────────────────────────── */
.ms-wrap{position:relative}
.ms-box{min-height:38px;background:rgba(255,255,255,.9);border:1px solid var(--line);border-radius:var(--rsm);padding:5px 36px 5px 8px;cursor:text;display:flex;flex-wrap:wrap;gap:5px;align-items:center;transition:border-color .1s;position:relative}
.ms-box:focus-within{border-color:var(--teal)}
.ms-box-arrow{position:absolute;right:10px;top:50%;transform:translateY(-50%);pointer-events:none;color:var(--fog)}
.ms-tag{display:inline-flex;align-items:center;gap:4px;padding:3px 8px;border-radius:var(--rchip);background:var(--teal-soft);color:var(--teal-deep);border:1px solid rgba(10,124,120,.18);font-size:11px;font-weight:500;white-space:nowrap}
.ms-tag button{background:none;border:none;cursor:pointer;color:var(--teal-deep);font-size:13px;line-height:1;padding:0;opacity:.6}
.ms-tag button:hover{opacity:1}
.ms-input{border:none;background:none;outline:none;font-size:12px;color:var(--charcoal);font-family:var(--f);min-width:80px;flex:1;padding:2px 0}
.ms-input::placeholder{color:var(--fog);opacity:.7}
.ms-dropdown{display:none;position:absolute;top:calc(100% + 4px);left:0;right:0;background:var(--panel);border:1px solid var(--line2);border-radius:var(--rsm);box-shadow:var(--shadow-lg);z-index:100;max-height:220px;overflow-y:auto}
.ms-dropdown.open{display:block}
.ms-opt{padding:9px 14px;font-size:13px;color:var(--charcoal);cursor:pointer;transition:background .08s;display:flex;align-items:center;justify-content:space-between;gap:8px}
.ms-opt:hover{background:var(--teal-soft);color:var(--teal-deep)}
.ms-opt.sel{color:var(--teal-deep)}
.ms-opt.sel::after{content:'✓';font-weight:700;font-size:12px}
.ms-hint{font-size:10px;color:var(--fog);margin-top:4px;font-family:var(--mono)}

/* ─── FILTER BAR (unified) ───────────────────────────────── */
.filter-bar{background:var(--panel);border:1px solid var(--line);border-radius:var(--r);padding:14px 18px;box-shadow:var(--shadow);margin-bottom:18px;display:flex;flex-wrap:wrap;gap:12px;align-items:flex-end}
.filter-group{display:flex;flex-direction:column;gap:4px}
.filter-group.fg-grow{flex:1;min-width:140px}
.filter-group.fg-fixed{min-width:160px;max-width:220px}
.flabel{font-size:10px;color:var(--fog);text-transform:uppercase;letter-spacing:.07em;font-weight:500}
.filter-actions{display:flex;gap:6px;align-items:flex-end;flex-shrink:0;padding-bottom:0}
.icon-btn{width:34px;height:34px;display:flex;align-items:center;justify-content:center;border-radius:var(--rsm);border:1px solid var(--line);background:rgba(255,255,255,.8);cursor:pointer;color:var(--fog);transition:all .1s;flex-shrink:0}
.icon-btn:hover{background:var(--teal-soft);color:var(--teal-deep);border-color:rgba(10,124,120,.2)}

/* ─── TABLE CARD SPACING ─────────────────────────────────── */
.tbl thead tr:first-child th{padding-top:18px}
.tbl tbody tr:first-child td{padding-top:12px}

/* ═══ SWEEP 2 — POLISH ═══════════════════════════════════ */
/* FIX-06: Background */
/* (applied to body rule below) */
/* FIX-07: Stronger borders */
/* (applied to :root below) */
/* FIX-08: Section heading */
.sh h2{font-size:20px;font-weight:600;letter-spacing:-.3px;margin:0}
/* FIX-09: DM Mono numeric-only */
.tbl th{font-family:var(--f)}
.chip{font-family:var(--f)}
.flabel{font-family:var(--f)}
/* FIX-10: Segmented control */
.seg{display:inline-flex;background:rgba(36,50,48,.05);padding:3px;border-radius:999px;gap:0}
.seg .seg-btn{background:none;border:none;border-radius:999px;padding:6px 12px;font-size:11px;font-weight:500;cursor:pointer;color:var(--fog);font-family:var(--f);transition:all .1s}
.seg .seg-btn:hover{color:var(--teal-deep)}
.seg .seg-btn.active{background:#fff;color:var(--teal-deep);box-shadow:0 1px 3px rgba(36,50,48,.10)}
/* FIX-12: Focus ring */
.fi:focus{border-color:var(--teal);box-shadow:0 0 0 3px var(--teal-soft);outline:none}
/* FIX-05: No-wrap date/days/balance columns */
.tbl td.col-dates,.tbl td.col-days,.tbl td.col-balance{white-space:nowrap}
/* FIX-14: Calendar overflow chips */
.cev-more{background:rgba(36,50,48,.06);color:var(--fog);font-weight:600;cursor:pointer;font-size:9px;padding:2px 5px;border-radius:5px;margin-bottom:2px}
.cev-more:hover{background:var(--teal-soft);color:var(--teal-deep)}

/* ═══ SWEEPS 4-5 — COLOUR + DENSITY ═══════════════════════ */
/* FIX-17: Green healthier */
:root{--green:#2f7d5b;--green-soft:rgba(47,125,91,.12)}
/* FIX-19: Offboarding = slate */
.chip-slate{background:rgba(36,50,48,.08);color:var(--charcoal);border:1px solid rgba(36,50,48,.12)}
/* FIX-20: Info popover */
.info-icon{display:inline-flex;align-items:center;justify-content:center;width:18px;height:18px;border-radius:50%;background:rgba(36,50,48,.08);color:var(--fog);font-size:11px;font-weight:600;cursor:pointer;margin-left:6px;font-family:var(--f);line-height:1;border:none;vertical-align:middle;flex-shrink:0;transition:all .1s}
.info-icon:hover{background:var(--teal-soft);color:var(--teal-deep)}
.info-pop{position:absolute;background:#fff;border:1px solid var(--line);border-radius:12px;padding:14px 16px;box-shadow:var(--shadow-lg);max-width:320px;z-index:150;font-size:13px;color:var(--charcoal);line-height:1.55;top:calc(100% + 8px);left:0}
.info-pop.hidden{display:none}
.info-pop h4{font-size:13px;font-weight:600;margin:0 0 6px}
.info-pop-wrap{position:relative;display:inline-flex;align-items:center}

/* ═══ SWEEP 6 — FLOW ══════════════════════════════════════ */
/* FIX-21: Row-expand drawer */
.approval-row{cursor:pointer}
.approval-row:hover td{background:rgba(10,124,120,.04)!important}
.row-detail{display:none}
.row-detail.open{display:table-row;background:rgba(10,124,120,.03)}
.row-detail>td{padding:0}
.row-detail-inner{padding:14px 20px 18px;border-top:1px dashed var(--line)}
.row-detail-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;margin-bottom:10px}
.row-detail-grid label{display:block;font-size:10px;text-transform:uppercase;letter-spacing:.07em;color:var(--fog);font-family:var(--f);margin-bottom:4px;font-weight:500}
/* FIX-24: Bulk select */
.bulk-bar{position:sticky;bottom:0;background:rgba(255,255,255,.98);border-top:1px solid var(--line);padding:12px 20px;display:none;align-items:center;gap:14px;box-shadow:0 -4px 20px rgba(36,50,48,.06);border-radius:0 0 var(--r) var(--r)}
.bulk-bar.on{display:flex}
/* FIX-25: Decline modal */
.reason-chip{display:inline-block;padding:6px 12px;border-radius:var(--rchip);border:1px solid var(--line);font-size:12px;cursor:pointer;transition:all .1s;font-family:var(--f);background:none;color:var(--fog)}
.reason-chip:hover,.reason-chip.sel{background:var(--teal-soft);color:var(--teal-deep);border-color:rgba(10,124,120,.2)}
/* FIX-26: Coverage strip */
.cov-strip{display:flex;gap:3px;margin-top:4px}
.cov-day{flex:1;text-align:center;padding:7px 0;border-radius:6px;font-size:11px;font-family:var(--mono)}
.cov-day.cov-ok{background:var(--green-soft);color:var(--green)}
.cov-day.cov-warn{background:var(--amber-soft);color:var(--amber)}
.cov-day.cov-bad{background:var(--red-soft);color:var(--red)}
.cov-day span{display:block;font-size:9px;opacity:.65;margin-top:1px}

/* ═══ SWEEP 7 — DROPDOWNS ═════════════════════════════════ */
/* FIX-32: Active filter chips */
.active-filters{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:12px;align-items:center}
.chip-closable{cursor:pointer;gap:5px}
.chip-closable:hover{background:var(--teal-mid)}
/* FIX-31: Status segmented */
.status-seg{display:inline-flex;background:rgba(36,50,48,.05);border-radius:var(--rchip);padding:3px;gap:0}
.status-seg button{background:none;border:none;padding:6px 12px;border-radius:var(--rchip);font-size:12px;font-weight:500;cursor:pointer;font-family:var(--f);color:var(--fog);transition:all .1s;white-space:nowrap}
.status-seg button.on{background:#fff;color:var(--teal-deep);box-shadow:0 1px 3px rgba(36,50,48,.10)}

/* ═══ SWEEP 8 — PRODUCTIVITY ══════════════════════════════ */
/* FIX-37: Empty states */
.empty-state{text-align:center;padding:60px 20px;color:var(--fog)}
.empty-state-icon{display:inline-flex;width:64px;height:64px;border-radius:16px;background:var(--teal-soft);color:var(--teal-deep);align-items:center;justify-content:center;font-size:28px;margin-bottom:16px}
.empty-state h3{font-size:16px;color:var(--charcoal);margin:0 0 6px;font-weight:600}
.empty-state p{max-width:340px;margin:0 auto 18px;font-size:13px;color:var(--fog);line-height:1.5}
/* FIX-38: New-since-visit banner */
.diff-banner{background:var(--teal-soft);border:1px solid rgba(10,124,120,.15);border-radius:var(--rsm);padding:10px 16px;margin-bottom:14px;font-size:13px;color:var(--teal-deep);display:flex;align-items:center;justify-content:space-between}
/* FIX-35: Keyboard shortcut hint */
.kbd-hint{font-size:10px;font-family:var(--mono);background:rgba(36,50,48,.07);border:1px solid var(--line);border-radius:4px;padding:1px 5px;color:var(--fog);margin-left:6px;vertical-align:middle}
/* Shortcuts modal */
.shortcuts-grid{display:grid;grid-template-columns:auto 1fr;gap:10px 20px;margin-top:8px}
.shortcuts-grid kbd{font-family:var(--mono);font-size:12px;background:rgba(36,50,48,.07);border:1px solid var(--line);border-radius:4px;padding:3px 7px;color:var(--charcoal)}
.shortcuts-grid span{font-size:13px;color:var(--fog);align-self:center}
/* ─── SEARCHABLE SINGLE-SELECT ──────────────────────────── */
.ss-wrap{position:relative}
.ss-box{display:flex;align-items:center;justify-content:space-between;min-height:38px;background:rgba(255,255,255,.9);border:1px solid var(--line);border-radius:var(--rsm);padding:4px 10px;cursor:text;gap:6px;transition:border-color .1s}
.ss-box:focus-within{border-color:var(--teal)}
.ss-input{flex:1;border:none;background:none;outline:none;font-size:13px;color:var(--charcoal);font-family:var(--f);min-width:60px;cursor:pointer}
.ss-input::placeholder{color:var(--fog);opacity:.75}
.ss-dd{display:none;position:absolute;top:calc(100% + 4px);left:0;right:0;background:var(--panel);border:1px solid var(--line2);border-radius:var(--rsm);box-shadow:var(--shadow-lg);z-index:200;max-height:220px;overflow-y:auto}
.ss-dd.open{display:block}
.ss-opt{padding:9px 14px;font-size:13px;color:var(--charcoal);cursor:pointer;transition:background .08s}
.ss-opt:hover{background:var(--teal-soft);color:var(--teal-deep)}
.ss-opt.ss-sel{color:var(--teal-deep);font-weight:500}
.ss-opt.ss-sel::after{content:'  ✓';font-size:11px}
/* ─── COLUMN PICKER ─────────────────────────────────────── */
.col-pick-row{display:flex;align-items:center;padding:6px 8px;border-radius:var(--rsm);background:rgba(36,50,48,.03);border:1px solid transparent;transition:border-color .1s;cursor:grab}
.col-pick-row:hover{border-color:var(--line);background:var(--teal-soft)}
.col-pick-row[draggable=true]:active{opacity:.5}
/* ─── LEAVE TYPE MODAL ───────────────────────────────────── */
.lt-cat-btn{flex:1;min-width:100px;padding:10px 8px;border:1.5px solid var(--line);border-radius:var(--rsm);cursor:pointer;text-align:center;font-size:12px;font-weight:500;font-family:var(--f);background:none;color:var(--fog);transition:all .12s}
.lt-cat-btn:hover{border-color:var(--teal);color:var(--teal-deep);background:var(--teal-soft)}
.lt-cat-btn.active{border-color:var(--teal-deep);color:var(--teal-deep);background:var(--teal-soft);font-weight:600}
.lt-swatch{width:28px;height:28px;border-radius:7px;cursor:pointer;border:2.5px solid transparent;transition:transform .12s,border-color .12s;flex-shrink:0}
.lt-swatch:hover{transform:scale(1.15)}
.lt-swatch.selected{border-color:rgba(0,0,0,.55);transform:scale(1.1);box-shadow:0 0 0 1px rgba(0,0,0,.15)}

@media (max-width: 1024px){
  :root{--nav:220px}
  .g4,.g3,.g3-2,.g2{grid-template-columns:1fr 1fr}
  .g3-2,.off-grid{grid-template-columns:1fr}
  .topbar{padding:16px 18px;flex-wrap:wrap;align-items:flex-start}
  .content{padding:18px}
  .page-title{font-size:22px}
}

@media (max-width: 820px){
  html,body{overflow:hidden}
  .shell{height:100vh;min-height:100vh;flex-direction:row}
  .sidebar{position:fixed;left:0;top:0;bottom:0;width:min(78vw,300px);max-width:300px;border-right:1px solid var(--line);border-bottom:none;transform:none;transition:width .22s ease, box-shadow .22s ease;overflow:hidden}
  body.mobile-nav-open .sidebar{width:min(78vw,300px);box-shadow:var(--shadow-lg)}
  body.mobile-nav-open .brand-row{justify-content:space-between}
  body.mobile-nav-open .brand-btn{justify-content:flex-start}
  .sidebar-top{padding:14px 10px 10px}
  .brand-row{align-items:center;justify-content:center}
  .brand-btn{width:100%;align-items:center;justify-content:center}
  .mobile-nav-close{display:flex;align-items:center;justify-content:center}
  .sidebar-nav{padding:10px 10px 12px;overflow-y:auto;overflow-x:visible;display:flex;white-space:normal}
  .nav-section{display:block;min-width:0;margin-right:0}
  .main{min-width:0;width:100%;padding-left:72px}
  .topbar{padding:14px}
  .topbar-actions{width:100%;justify-content:flex-start;flex-wrap:wrap}
  .content{padding:14px}
  .g4,.g3,.g3-2,.g2,.frow{grid-template-columns:1fr}
  .dash-metrics{grid-template-columns:1fr 1fr}
  .off-grid,.mobile-card-grid{grid-template-columns:1fr}
  .modal,.modal-lg{width:min(100%,680px)}
  .tbl{min-width:720px}
  .scroll-panel{overflow-x:auto}
  .tabs,.blockout-toolbar > div:last-child,.scroll-panel,.sidebar-nav{scrollbar-width:thin;scrollbar-color:rgba(36,50,48,.18) transparent}
  .tabs{overflow-x:auto;overflow-y:hidden;padding-bottom:2px}
  .tab{flex:0 0 auto}
  .sidebar.mobile-collapsed{width:72px;box-shadow:var(--shadow)}
  .sidebar.mobile-collapsed{overflow:visible}
  .sidebar.mobile-collapsed .brand-btn{justify-content:center}
  .sidebar.mobile-collapsed .brand-btn > div:last-child,
  .sidebar.mobile-collapsed .nav-section-label,
  .sidebar.mobile-collapsed .sidebar-foot{display:none}
  .sidebar.mobile-collapsed .brand-row{justify-content:center}
  .sidebar.mobile-collapsed .sidebar-top{padding:14px 10px}
  .sidebar.mobile-collapsed .sidebar-nav{padding:10px 8px 12px;gap:14px}
  .sidebar.mobile-collapsed .ni{justify-content:center;padding:11px 8px;font-size:0;gap:0}
  .sidebar.mobile-collapsed .ni-icon{width:19px;height:19px;opacity:.8}
  .sidebar.mobile-collapsed .ni-badge{position:absolute;top:4px;right:4px;margin-left:0;font-size:9px;padding:1px 5px}
  .sidebar.mobile-collapsed .mobile-nav-close{display:none}
  body.mobile-nav-open .mobile-nav-close{display:flex}
  .mobile-logo-toggle{display:none !important}
  .mobile-nav-scrim{position:fixed;inset:0;background:rgba(36,50,48,.28);z-index:30;opacity:0;pointer-events:none;transition:opacity .2s ease}
  body.mobile-nav-open .mobile-nav-scrim{display:block;opacity:1;pointer-events:auto}
  .section-actions-row,.blockout-toolbar{align-items:stretch}
  .blockout-toolbar > div:last-child{width:100%;overflow-x:auto}
  .bo-view-switch{width:100%;overflow-x:auto}
  .bo-cal-head-cell{padding:10px 6px 12px}
  .bo-cal-head-date{font-size:15px}
  .bo-cell{min-height:72px;padding:8px}
  .settings-shell{max-width:none}
  .delcard{align-items:flex-start;flex-wrap:wrap}
  .delcard-main{width:100%}
  .delcard-date{margin-left:40px}
  .report-card-grid{grid-template-columns:1fr}
  .report-stats-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:10px}
  .report-stats-grid .metric-card{padding:16px 12px}
  .report-stats-grid .metric-val{font-size:24px}
  .report-stats-grid .metric-label,.report-stats-grid .metric-sub{font-size:10px}
  #role-editor .perm-rule-row{flex-direction:column}
  #role-editor .perm-rule-ctrl{min-width:0;width:100%}
  #role-editor .perm-scope-panel{margin-left:0}
}

@media (max-width: 640px){
  .brand-sub{display:none}
  .page-title{font-size:20px}
  .topbar{gap:12px}
  .content{padding:12px}
  .dash-metrics{grid-template-columns:1fr 1fr}
  .metric-card{padding:18px}
  .metric-val{font-size:32px}
  .modal,.modal-lg{padding:18px 16px}
  .btn{padding:9px 12px}
  .hdr-dd{width:min(92vw,320px)!important;left:8px!important;right:8px!important}
  .lt-mobile-meta{grid-template-columns:1fr}
  .delcard-date{margin-left:0}
  .report-stats-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:8px}
  .report-stats-grid .metric-card{padding:14px 10px}
  .report-stats-grid .metric-val{font-size:20px}
}
@media (max-width: 920px){
  .auth-wrap{grid-template-columns:1fr}
  .auth-side{padding:34px 22px 18px}
  .auth-hero h1{font-size:34px}
  .auth-card-wrap{padding:0 16px 28px}
}
