/* ══════════════════════════════════════════════════════════════════
   LEAVE MANAGER — leave dashboard. Scoped to .lm-app; teal accent, uses the
   shell tokens (var(--panel/--ink/--line/--muted)) so it inherits dark mode.
   Reuses .pm-modal / .pm-field / .pm-btn from pm.css for the modals.
══════════════════════════════════════════════════════════════════ */
.lm-app{--lm:#0d9488;--lm-d:#0f766e;--lm-soft:#f4f8f8;max-width:none;width:100%;padding:0 26px;display:flex;flex-direction:column;gap:16px}
.lm-app *{box-sizing:border-box}
html.dark .lm-app{--lm-soft:#111a1a}

/* header */
.lm-header{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;flex-wrap:wrap}
.lm-head-l{display:flex;align-items:center;gap:13px;min-width:0}
.lm-head-ico{width:46px;height:46px;flex:none;border-radius:13px;display:grid;place-items:center;color:#fff;font-size:19px;background:linear-gradient(135deg,#14b8a6,#0f766e);box-shadow:0 8px 20px rgba(13,148,136,.3)}
.lm-title{font-size:21px;font-weight:800;letter-spacing:-.02em;line-height:1.1}
.lm-sub{margin-top:3px;color:var(--muted);font-size:13px;font-weight:600}
.lm-head-r{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.lm-role{display:inline-flex;align-items:center;gap:4px;background:var(--lm-soft);border:1px solid var(--line);border-radius:10px;padding:3px;font-size:12px}
.lm-role>span{color:var(--muted);font-weight:700;padding:0 6px;font-size:11px}
.lm-role-btn{border:none;background:transparent;font:inherit;font-size:12px;font-weight:700;color:var(--muted);padding:6px 11px;border-radius:8px;cursor:pointer}
.lm-role-btn.on{background:#fff;color:var(--lm-d);box-shadow:0 1px 3px rgba(0,0,0,.12)}
html.dark .lm-role-btn.on{background:#0b2b28;color:#5eead4}
/* team-mode chip (replaces the demo role toggle when signed in to a real leave team) */
.lm-teamchip{display:inline-flex;align-items:center;gap:7px;background:var(--lm-soft);border:1px solid var(--line);border-radius:10px;padding:6px 11px;font-size:12.5px;font-weight:700;color:var(--ink)}
.lm-teamchip>i{color:var(--lm)}
.lm-role-tag{font-size:10.5px;font-weight:800;text-transform:uppercase;letter-spacing:.03em;padding:2px 7px;border-radius:6px}
.lm-role-mgr{background:#0d9488;color:#fff}
.lm-role-emp{background:var(--line);color:var(--muted)}
html.dark .lm-role-emp{background:#243534;color:#9fb3b1}

/* section nav */
.lm-nav{display:flex;gap:5px;flex-wrap:wrap;background:var(--panel);border:1px solid var(--line);border-radius:14px;padding:6px;box-shadow:0 1px 2px rgba(16,24,40,.04)}
.lm-nav-btn{display:inline-flex;align-items:center;gap:8px;border:none;background:transparent;font:inherit;font-size:13px;font-weight:700;color:#55617a;padding:9px 14px;border-radius:10px;cursor:pointer;transition:.14s;position:relative}
.lm-nav-btn:hover{background:var(--lm-soft);color:var(--lm-d)}
.lm-nav-btn.active{background:linear-gradient(135deg,#14b8a6,#0f766e);color:#fff;box-shadow:0 6px 14px rgba(13,148,136,.28)}
.lm-nav-badge{background:#ef4444;color:#fff;font-size:10px;font-weight:800;border-radius:20px;min-width:16px;height:16px;display:grid;place-items:center;padding:0 4px}
.lm-nav-btn.active .lm-nav-badge{background:#fff;color:#0f766e}

/* KPI cards */
.lm-kpis{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.lm-kpi{display:flex;align-items:center;gap:14px;background:var(--panel);border:1px solid var(--line);border-radius:14px;padding:16px 18px;box-shadow:0 1px 2px rgba(16,24,40,.04),0 6px 20px rgba(16,24,40,.05)}
.lm-kpi-ico{width:46px;height:46px;flex:none;border-radius:13px;display:grid;place-items:center;font-size:18px;color:var(--c);background:color-mix(in srgb,var(--c) 13%,transparent)}
.lm-kpi-k{font-size:12.5px;color:var(--muted);font-weight:700}
.lm-kpi-v{font-size:28px;font-weight:800;letter-spacing:-.02em;line-height:1.15}
.lm-kpi-v span{font-size:13px;font-weight:600;color:var(--muted)}
.lm-kpi-sub{margin-top:3px;font-size:11.5px;color:var(--muted)}

/* grids + cards */
.lm-grid-3{display:grid;grid-template-columns:1.1fr 1fr 1.2fr;gap:16px}
.lm-grid-2{display:grid;grid-template-columns:1.2fr 1fr;gap:16px}
.lm-card{background:var(--panel);border:1px solid var(--line);border-radius:16px;padding:18px 20px;box-shadow:0 1px 2px rgba(16,24,40,.04),0 6px 20px rgba(16,24,40,.05);min-width:0}
.lm-card-h{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:14px}
.lm-card-h h3{font-size:15px;font-weight:800;letter-spacing:-.01em}
.lm-card-h h3 span{color:var(--muted);font-weight:600;font-size:12.5px}
.lm-link{border:none;background:none;color:var(--lm-d);font-weight:700;font-size:12.5px;cursor:pointer;padding:0}
.lm-count,.lm-ot{color:var(--muted);font-size:12.5px;font-weight:600}
.lm-ot b{color:var(--lm-d)}
.lm-empty{color:var(--muted);font-size:13px;text-align:center;padding:26px 0}
.lm-empty i{color:#16a34a;margin-right:6px}

/* donut */
.lm-donut{display:flex;align-items:center;gap:18px;flex-wrap:wrap}
.lm-donut-svg{width:150px;height:150px;flex:none}
.lm-donut-svg path,.lm-donut-svg circle{transition:opacity .12s}
.lm-donut-svg path:hover{opacity:.85}
.lm-donut-num{text-anchor:middle;font-size:24px;font-weight:800;fill:var(--ink)}
.lm-donut-lbl{text-anchor:middle;font-size:9px;font-weight:700;fill:var(--muted);text-transform:uppercase;letter-spacing:.05em}
.lm-donut-legend{flex:1;min-width:150px;display:flex;flex-direction:column;gap:8px}
.lm-leg{display:flex;align-items:center;gap:9px;font-size:12.5px}
.lm-leg-dot{width:9px;height:9px;border-radius:50%;flex:none}
.lm-leg-name{flex:1;min-width:0;color:var(--ink);font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.lm-leg b{color:var(--ink);font-weight:800}
.lm-leg-pct{color:var(--muted);font-weight:700;width:34px;text-align:right}
.lm-donut-empty{color:var(--muted);font-size:13px;padding:24px 0;text-align:center}

/* holidays */
.lm-hol-list{display:flex;flex-direction:column;gap:11px}
.lm-hol{display:flex;align-items:center;gap:12px}
.lm-hol-date{width:44px;height:46px;flex:none;border-radius:11px;background:var(--lm-soft);border:1px solid var(--line);display:flex;flex-direction:column;align-items:center;justify-content:center;line-height:1}
.lm-hol-day{font-size:16px;font-weight:800;color:var(--lm-d)}
.lm-hol-mon{font-size:9px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.04em}
.lm-hol-b{flex:1;min-width:0}
.lm-hol-name{font-size:13.5px;font-weight:700}
.lm-hol-when{font-size:11.5px;color:var(--muted)}
.lm-hol-in{font-size:11px;font-weight:700;color:var(--lm-d);background:var(--lm-soft);border-radius:20px;padding:3px 9px;white-space:nowrap}
.lm-hol-full .lm-hol{padding:6px 0;border-bottom:1px solid var(--line)}

/* calendar */
.lm-cal-card{padding:16px}
.lm-cal-head{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:10px}
.lm-cal-head h3{font-size:14px;font-weight:800}
.lm-cal-nav{display:flex;gap:5px}
.lm-cal-btn{border:1px solid var(--line);background:var(--panel);color:var(--ink);border-radius:8px;padding:5px 9px;font:inherit;font-size:12px;font-weight:700;cursor:pointer}
.lm-cal-btn:hover{background:var(--lm-soft)}
.lm-cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:2px}
.lm-cal-dow{font-size:10px;font-weight:800;color:var(--muted);text-align:center;padding:4px 0;text-transform:uppercase}
.lm-cal-cell{aspect-ratio:1;border-radius:9px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;font-size:12.5px;position:relative;cursor:default}
.lm-cal-cell:not(.lm-cal-pad):hover{background:var(--lm-soft)}
.lm-cal-num{font-weight:600;color:var(--ink)}
.lm-cal-cell.is-today{background:#0d9488}
.lm-cal-cell.is-today .lm-cal-num{color:#fff;font-weight:800}
.lm-cal-cell.is-hol .lm-cal-num{color:#16a34a;font-weight:800}
.lm-cal-dots{display:flex;gap:2px;height:5px}
.lm-cal-dot{width:5px;height:5px;border-radius:50%}
.lm-cal-legend{display:flex;flex-wrap:wrap;gap:12px;margin-top:12px;padding-top:10px;border-top:1px solid var(--line);font-size:11px;color:var(--muted);font-weight:600}
.lm-cal-legend span{display:inline-flex;align-items:center;gap:5px}
.lm-cal-legend i{width:8px;height:8px;border-radius:50%;display:inline-block}
.lm-cal-big{max-width:720px}
.lm-cal-big .lm-cal-cell{aspect-ratio:auto;min-height:54px;align-items:flex-start;padding:6px 8px}

/* request rows */
.lm-reqs{display:flex;flex-direction:column}
.lm-req{display:grid;grid-template-columns:1.6fr 1.1fr 1fr .9fr auto;align-items:center;gap:12px;padding:12px 4px;border-bottom:1px solid var(--line)}
.lm-req:last-child{border-bottom:0}
.lm-req-who{display:flex;align-items:center;gap:10px;min-width:0}
.lm-avatar{width:34px;height:34px;flex:none;border-radius:50%;display:grid;place-items:center;color:#fff;font-size:11px;font-weight:800}
.lm-req-name{font-size:13px;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.lm-you{font-size:9px;font-weight:800;text-transform:uppercase;color:var(--lm-d);background:var(--lm-soft);border-radius:20px;padding:1px 6px}
.lm-req-role{font-size:11.5px;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.lm-req-type{font-size:12.5px;font-weight:600;display:flex;align-items:center;gap:7px;white-space:nowrap}
.lm-dot{width:8px;height:8px;border-radius:50%;flex:none}
.lm-req-dates{font-size:12.5px;font-weight:600}
.lm-req-days{font-size:11px;color:var(--muted)}
.lm-req-status{display:inline-flex;align-items:center;gap:6px;font-size:11.5px;font-weight:800;border-radius:20px;padding:4px 11px;white-space:nowrap}
.lm-st-approved{background:#e7f7ef;color:#0f7a4f}
.lm-st-pending{background:#fef4e2;color:#a5710a}
.lm-st-rejected{background:#fdecec;color:#c53034}
html.dark .lm-st-approved{background:#123726;color:#59c78f}
html.dark .lm-st-pending{background:#3a2c10;color:#e6b45a}
html.dark .lm-st-rejected{background:#3a1618;color:#f28b8e}
.lm-note-flag{cursor:help;opacity:.75}
.lm-decide{display:inline-flex;align-items:center;gap:6px;border:1px solid #bfe0dc;background:var(--lm-soft);color:var(--lm-d);font:inherit;font-size:12px;font-weight:700;border-radius:9px;padding:7px 12px;cursor:pointer;white-space:nowrap}
.lm-decide:hover{background:#e0f2f0}
html.dark .lm-decide{background:#0b2b28;border-color:#1f5a54;color:#5eead4}

/* balance bars */
.lm-bal-list{display:flex;flex-direction:column;gap:16px}
.lm-bal{display:flex;align-items:center;gap:13px}
.lm-bal-ico{width:40px;height:40px;flex:none;border-radius:11px;display:grid;place-items:center;font-size:15px;color:var(--c);background:color-mix(in srgb,var(--c) 13%,transparent)}
.lm-bal-b{flex:1;min-width:0}
.lm-bal-top{display:flex;align-items:baseline;justify-content:space-between;gap:8px}
.lm-bal-name{font-size:13px;font-weight:700}
.lm-bal-num{font-size:15px;font-weight:800}
.lm-bal-num small{font-size:11px;font-weight:600;color:var(--muted)}
.lm-bal-track{height:8px;border-radius:20px;background:var(--lm-soft);overflow:hidden;margin:5px 0 4px}
.lm-bal-fill{height:100%;border-radius:20px;transition:width .3s}
.lm-bal-sub{font-size:11px;color:var(--muted)}

/* apply / decision modal fields */
.lm-lbl{display:block;font-size:12px;font-weight:700;color:var(--muted);margin:2px 0 5px}
.lm-apply-dates{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:2px}
.lm-check{display:inline-flex;align-items:center;gap:7px;font-size:13px;font-weight:600;color:var(--ink);cursor:pointer;margin:8px 0}
.lm-apply-summary{display:flex;justify-content:space-between;gap:10px;background:var(--lm-soft);border:1px solid var(--line);border-radius:10px;padding:9px 12px;font-size:12.5px;color:var(--muted);margin:4px 0 10px}
.lm-apply-summary b{color:var(--lm-d);font-size:14px}
.lm-apply-summary .lm-over{color:#c53034;font-weight:700}
.lm-apply-actions{display:flex;justify-content:flex-end;margin-top:12px}
.lm-est-modal textarea{width:100%}
.lm-apply-card textarea.pm-field,#lmDecisionForm textarea.pm-field{min-height:80px}
.lm-decision-actions{display:flex;justify-content:flex-end;gap:9px;margin-top:12px}
.lm-dec-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.lm-dec-grid>div{display:flex;flex-direction:column;gap:2px}
.lm-dec-grid span{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.03em;color:var(--muted)}
.lm-dec-grid b{font-size:13px;font-weight:700;display:flex;align-items:center;gap:6px}
.lm-dec-reason{grid-column:1/-1}

/* boot loading + signed-in-Pro-without-a-team empty state */
.lm-boot{display:flex;align-items:center;justify-content:center;gap:9px;min-height:220px;color:var(--muted);font-weight:600;font-size:14px}
.lm-empty-pro{text-align:center;padding:40px 26px;max-width:560px;margin:6px auto}
.lm-empty-pro-ico{width:58px;height:58px;border-radius:16px;margin:0 auto 16px;display:grid;place-items:center;color:#fff;font-size:23px;background:linear-gradient(135deg,#14b8a6,#0f766e);box-shadow:0 8px 20px rgba(13,148,136,.3)}
.lm-empty-pro h3{font-size:18px;font-weight:800;margin:0 0 8px}
.lm-empty-pro p{color:var(--muted);font-size:14px;line-height:1.7;margin:0}
.lm-empty-pro a{color:var(--lm);font-weight:700;text-decoration:none}
.lm-empty-pro a:hover{text-decoration:underline}
.lm-create-team{display:flex;gap:8px;justify-content:center;flex-wrap:wrap;margin:6px 0 4px}
.lm-create-team .pm-field{max-width:260px}
.lm-empty-alt{font-size:12.5px;margin-top:14px}

/* import / bulk-update card */
.lm-import-steps{margin:2px 0 14px;padding-left:20px;color:var(--muted);font-size:13px;line-height:1.7}
.lm-import-steps b{color:var(--ink)}
.lm-import-actions{display:flex;gap:10px;flex-wrap:wrap}
.lm-import-up{cursor:pointer;position:relative}
.lm-import-result{margin-top:14px}
.lm-import-ok{display:flex;align-items:center;gap:8px;font-size:13.5px;font-weight:700;color:var(--lm-d);background:var(--lm-soft);border:1px solid var(--line);border-radius:11px;padding:11px 13px}
html.dark .lm-import-ok{color:#5eead4}
.lm-import-bad{display:flex;align-items:center;gap:8px;font-size:13.5px;font-weight:700;color:#b42318;background:#fef3f2;border:1px solid #fecdca;border-radius:11px;padding:11px 13px}
html.dark .lm-import-bad{color:#fda29b;background:#3a1412;border-color:#5b1c18}
.lm-import-errs{margin:8px 0 0;padding-left:20px;font-size:12.5px;color:var(--muted);line-height:1.6}
.lm-seat-full{color:#b45309;font-weight:800}
html.dark .lm-seat-full{color:#fcd34d}
.lm-import-note{margin:2px 0 14px;font-size:13px;line-height:1.6;color:#92400e;background:#fffbeb;border:1px solid #fde68a;border-radius:11px;padding:11px 13px}
.lm-import-note a{color:inherit;font-weight:800;text-decoration:underline}
html.dark .lm-import-note{color:#fcd34d;background:#2e2408;border-color:#4d3b0a}

/* ── manager: team settings + roster + balances (Manage section) ── */
.lm-muted{color:var(--muted);font-weight:600;font-size:12px}
.lm-set-row{display:flex;align-items:center;gap:12px;padding:11px 2px;border-top:1px solid var(--line)}
.lm-set-row:first-of-type{border-top:none}
.lm-set-row>label{width:110px;flex:none;font-size:12.5px;font-weight:700;color:var(--muted)}
.lm-set-inline{display:inline-flex;align-items:center;gap:8px;flex-wrap:wrap}
.lm-set-inline .pm-field{max-width:280px}
.lm-mlist{display:flex;flex-direction:column}
.lm-mrow{display:grid;grid-template-columns:1.4fr .9fr 1.1fr auto;align-items:center;gap:12px;padding:11px 2px;border-top:1px solid var(--line)}
.lm-mrow:first-child{border-top:none}
.lm-mrow-who{display:flex;align-items:center;gap:10px;min-width:0}
.lm-mrow-nb{min-width:0;display:flex;flex-direction:column;gap:1px}
.lm-mrow-name{font-weight:700;font-size:13.5px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.lm-mrow-email{font-size:11.5px;color:#6b7280;line-height:1.3;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
html.dark .lm-mrow-email{color:#94a3b8}
.lm-invited{font-size:11px;color:#94a3b8;font-weight:600}
.lm-mrow-role{display:flex;align-items:center;gap:6px}
.lm-role-sel{max-width:130px;padding:6px 8px;font-size:12.5px}
.lm-mrow-bal{display:flex;gap:12px;font-size:12px;color:var(--muted)}
.lm-mrow-bal b{color:var(--ink);font-size:13px}
.lm-mrow-act{display:flex;align-items:center;gap:6px;justify-content:flex-end;flex-wrap:wrap}
.lm-editbal{padding:6px 11px;font-size:12.5px}
.lm-mini{width:32px;height:32px;flex:none;border:1px solid var(--line);background:var(--panel);color:var(--muted);border-radius:9px;cursor:pointer;display:grid;place-items:center;font-size:13px}
.lm-mini:hover{color:var(--lm);border-color:var(--lm)}
.lm-mini-danger:hover{color:#e5484d;border-color:#e5484d}
/* holiday management */
.lm-hol-add{display:flex;gap:8px;flex-wrap:wrap;align-items:center;margin:2px 0 14px}
.lm-hol-add .pm-field{max-width:200px}
.lm-hol-half{display:inline-flex;align-items:center;gap:6px;font-size:12.5px;font-weight:600;color:var(--muted);white-space:nowrap}
.lm-hol-half input{width:15px;height:15px;accent-color:var(--lm)}
.lm-hol-acts{display:flex;gap:6px;margin-left:auto}
.lm-hol-x,.lm-hol-edit{width:28px;height:28px;font-size:12px}
.lm-hol-halfbadge{display:inline-block;margin-left:8px;font-size:10.5px;font-weight:800;text-transform:uppercase;letter-spacing:.03em;color:#b45309;background:#fef3c7;border-radius:6px;padding:2px 7px;vertical-align:middle}
html.dark .lm-hol-halfbadge{color:#fcd34d;background:#3a2c08}
/* balance-edit modal */
.lm-balance-card{max-width:520px}
.lm-bal-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px 14px}
.lm-balf{display:flex;flex-direction:column;gap:4px}
.lm-balf>span{font-size:11.5px;font-weight:700;color:var(--muted)}
.lm-balf-in{padding:8px 10px}
.lm-bal-derived{margin-top:14px;padding:11px 13px;background:var(--lm-soft);border:1px solid var(--line);border-radius:11px;font-size:13px;line-height:1.7}
.lm-bal-derived b{color:var(--lm-d)}
html.dark .lm-bal-derived b{color:#5eead4}
.lm-balance-actions{display:flex;justify-content:flex-end;margin-top:16px}

@media(max-width:1100px){.lm-kpis{grid-template-columns:repeat(2,1fr)}.lm-grid-3,.lm-grid-2{grid-template-columns:1fr}}
@media(max-width:720px){.lm-mrow{grid-template-columns:1fr auto;row-gap:8px}.lm-mrow-bal{grid-column:1/-1;order:3}.lm-bal-grid{grid-template-columns:1fr}}
@media(max-width:640px){.lm-req{grid-template-columns:1fr auto}.lm-req-type,.lm-req-dates{display:none}}

/* self-serve "Add seats" (owner, Manage/import card) */
.lm-addseats{border:1px solid #cfe0fb;background:#eef3fe;color:#1d4ed8;border-radius:8px;padding:3px 10px;font:inherit;font-size:11.5px;font-weight:800;cursor:pointer}
.lm-addseats:hover{background:#dfeafd}

/* one-by-one invite form (Manage) */
.lm-invite-form{display:flex;gap:8px;flex-wrap:wrap;align-items:center}
.lm-invite-form #lmInviteEmail{flex:1 1 220px;min-width:0}
.lm-invite-form .lm-invite-role{flex:0 0 auto;width:auto}
.lm-invite-note{margin:9px 0 0;font-size:12px;color:var(--muted);line-height:1.5}
