/* ====================================================================
   ABLAZE TEENS MINISTRY OS — stylesheet
   Glassmorphism SaaS shell · fire identity · dynamic squad theming.
   The --accent* group is rewritten by JS whenever the squad changes,
   so every accent-driven surface recolours automatically.
   ==================================================================== */

:root{
  /* base ember surfaces */
  --ember:#0a0604;
  --ember-2:#0d0908;
  --surface:rgba(28,18,14,.55);
  --surface-2:rgba(42,27,21,.62);
  --surface-3:rgba(58,38,29,.72);
  --glass-border:rgba(255,255,255,.08);
  --line:rgba(255,150,90,.15);
  --line-2:rgba(255,150,90,.30);
  --ink:#ffffff;
  --ink-dim:#e7d8cb;
  --muted:#b29684;
  --muted-2:#8a715f;

  /* fire */
  --fire-1:#ff3d00; --fire-2:#ff7a00; --fire-3:#ffb200;
  --fire-grad:linear-gradient(135deg,#ff3d00 0%,#ff7a00 52%,#ffc400 100%);

  /* squad palettes (solid + gradient) */
  --dunamis:#22c55e;  --dunamis-grad:linear-gradient(135deg,#0ba360 0%,#3cba92 100%);
  --koinonia:#4facfe; --koinonia-grad:linear-gradient(135deg,#2563eb 0%,#00f2fe 100%);
  --rhema:#ff3b5c;    --rhema-grad:linear-gradient(135deg,#ff3d00 0%,#ff2e6a 100%);
  --agape:#ffc400;    --agape-grad:linear-gradient(135deg,#f59e0b 0%,#ffd000 100%);
  --phos:#b06bff;     --phos-grad:linear-gradient(135deg,#a855f7 0%,#fe5196 100%);

  /* DYNAMIC accent — overwritten on squad switch */
  --accent:#ff7a00;
  --accent-2:#ffc400;
  --accent-grad:var(--fire-grad);
  --accent-soft:rgba(255,122,0,.14);
  --accent-glow:rgba(255,122,0,.5);

  /* status */
  --ok:#22c55e;   --ok-soft:rgba(34,197,94,.14);
  --warn:#f5a623; --warn-soft:rgba(245,166,35,.14);
  --bad:#ff3b5c;  --bad-soft:rgba(255,59,92,.14);
  --info:#4facfe; --info-soft:rgba(79,172,254,.14);

  --r-sm:10px; --r:14px; --r-lg:18px; --r-xl:24px;
  --sidebar-w:252px;
  --display:'Anton',sans-serif;
  --body:'Sora',system-ui,-apple-system,sans-serif;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:var(--body);color:var(--ink);background:var(--ember);
  -webkit-font-smoothing:antialiased;line-height:1.55;min-height:100vh;
}
button{font-family:inherit}
::selection{background:var(--accent);color:#160b04}
::-webkit-scrollbar{width:10px;height:10px}
::-webkit-scrollbar-thumb{background:rgba(255,150,90,.18);border-radius:8px}
::-webkit-scrollbar-thumb:hover{background:rgba(255,150,90,.3)}

/* ---------------- ambient background ---------------- */
.bg-wrap{position:fixed;inset:0;z-index:-2;overflow:hidden;background:
  radial-gradient(1200px 820px at 82% -12%, rgba(255,90,0,.10), transparent 60%),
  radial-gradient(1000px 720px at -8% 112%, rgba(255,46,77,.08), transparent 56%),
  var(--ember)}
.bg-orb{position:absolute;border-radius:50%;filter:blur(90px);opacity:.42;transition:background 1.2s ease}
.bg-orb.o1{width:520px;height:520px;left:-120px;top:-80px;background:var(--accent);animation:drift1 26s ease-in-out infinite}
.bg-orb.o2{width:460px;height:460px;right:-100px;top:30%;background:var(--accent-2);opacity:.3;animation:drift2 32s ease-in-out infinite}
.bg-orb.o3{width:560px;height:560px;left:30%;bottom:-200px;background:var(--fire-1);opacity:.24;animation:drift1 30s ease-in-out infinite reverse}
@keyframes drift1{0%,100%{transform:translate(0,0)}50%{transform:translate(60px,40px)}}
@keyframes drift2{0%,100%{transform:translate(0,0)}50%{transform:translate(-50px,30px)}}
.bg-grid{position:absolute;inset:0;background-image:
  linear-gradient(rgba(255,150,90,.05) 1px,transparent 1px),
  linear-gradient(90deg,rgba(255,150,90,.05) 1px,transparent 1px);
  background-size:46px 46px;mask-image:radial-gradient(circle at 50% 30%,#000,transparent 80%);opacity:.5}
#ember-canvas{position:fixed;inset:0;z-index:-1;pointer-events:none}

/* ---------------- app shell ---------------- */
.app{display:grid;grid-template-columns:var(--sidebar-w) 1fr;min-height:100vh}

.sidebar{position:sticky;top:0;height:100vh;border-right:1px solid var(--line);
  background:linear-gradient(180deg,rgba(13,9,8,.92),rgba(10,6,4,.78));
  backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px);
  display:flex;flex-direction:column;padding:20px 14px;z-index:60}
.brand{display:flex;align-items:center;gap:12px;padding:6px 8px 18px}
.brand img{width:46px;height:46px;border-radius:12px;object-fit:cover;
  box-shadow:0 0 0 1px var(--line-2),0 10px 26px -8px var(--accent-glow);background:#000}
.brand .bt{font-family:var(--display);font-size:19px;line-height:.95;letter-spacing:.5px}
.brand .bt b{display:block;background:var(--accent-grad);-webkit-background-clip:text;background-clip:text;color:transparent}
.brand .bs{font-size:9.5px;letter-spacing:2.5px;color:var(--muted);text-transform:uppercase;margin-top:3px}

.nav{display:flex;flex-direction:column;gap:4px;margin-top:4px}
.nav-item{display:flex;align-items:center;gap:12px;padding:12px 13px;border-radius:12px;border:1px solid transparent;
  background:transparent;color:var(--ink-dim);font-weight:600;font-size:13.5px;cursor:pointer;text-align:left;position:relative;transition:.18s}
.nav-item .ni{font-size:17px;width:22px;text-align:center;flex-shrink:0}
.nav-item:hover{background:rgba(255,255,255,.045);color:var(--ink)}
.nav-item.active{background:var(--accent-soft);color:var(--ink);border-color:var(--line-2)}
.nav-item.active::before{content:"";position:absolute;left:-14px;top:11px;bottom:11px;width:3px;border-radius:0 3px 3px 0;background:var(--accent-grad)}
.nav-sec{font-size:10px;letter-spacing:1.6px;text-transform:uppercase;color:var(--muted-2);padding:14px 13px 6px;font-weight:700}
.nav-foot{margin-top:auto;padding:14px 11px 2px;border-top:1px solid var(--line);font-size:11px;color:var(--muted-2);line-height:1.55}
.nav-foot b{color:var(--muted);font-weight:600}

.main{min-width:0;display:flex;flex-direction:column;overflow-x:hidden}
.topbar{position:sticky;top:0;z-index:50;display:flex;align-items:center;gap:14px;padding:13px 26px;
  border-bottom:1px solid var(--line);background:rgba(10,6,4,.72);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px)}
.menu-btn{display:none;background:var(--surface);border:1px solid var(--line);color:var(--ink);width:40px;height:40px;border-radius:11px;font-size:18px;cursor:pointer;flex-shrink:0}
.tb-titles{min-width:0}
.tb-title{font-family:var(--display);font-size:21px;letter-spacing:.5px;line-height:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.tb-sub{font-size:12px;color:var(--muted);margin-top:3px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.tb-spacer{flex:1}
.search{display:flex;align-items:center;gap:8px;background:var(--surface);border:1px solid var(--line);border-radius:12px;padding:9px 13px;min-width:190px;transition:.2s}
.search:focus-within{border-color:var(--accent)}
.search .si{font-size:14px;color:var(--muted)}
.search input{background:none;border:none;outline:none;color:var(--ink);font:inherit;font-size:13px;width:100%}
.search input::placeholder{color:var(--muted-2)}
.squad-pick{position:relative;flex-shrink:0}
.squad-pick select{appearance:none;-webkit-appearance:none;background:var(--surface);border:1px solid var(--line-2);border-radius:12px;
  color:var(--ink);font:inherit;font-weight:700;font-size:13px;padding:10px 34px 10px 14px;cursor:pointer}
.squad-pick select:focus{outline:none;border-color:var(--accent)}
.squad-pick select option{background:#1a0f0b;color:var(--ink)}
.squad-pick .chev{position:absolute;right:13px;top:50%;transform:translateY(-50%);color:var(--accent);pointer-events:none;font-size:11px}
.leader-chip{display:flex;align-items:center;gap:10px;background:var(--surface);border:1px solid var(--line);border-radius:12px;padding:6px 14px 6px 6px;flex-shrink:0}
.leader-chip .av{width:34px;height:34px;border-radius:9px;background:var(--accent-grad);display:grid;place-items:center;font-family:var(--display);color:#160b04;font-size:14px}
.leader-chip .lt .lr{font-size:11px;color:var(--muted);line-height:1.2}
.leader-chip .lt .ln{font-size:13px;font-weight:700;line-height:1.2}

.content{padding:26px;max-width:1380px;width:100%;margin:0 auto}
.module{display:none}
.module.active{display:block;animation:fadeUp .5s cubic-bezier(.16,1,.3,1)}
@keyframes fadeUp{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}

/* anchor chips */
.anchors{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:26px}
.anchor{font-size:12px;font-weight:600;color:var(--muted);background:var(--surface);border:1px solid var(--line);border-radius:999px;padding:7px 14px;cursor:pointer;transition:.16s}
.anchor:hover,.anchor.on{color:var(--ink);border-color:var(--line-2);background:var(--accent-soft)}

/* section */
.sec{margin-bottom:34px;scroll-margin-top:90px}
.sec-h{display:flex;align-items:center;gap:13px;margin-bottom:16px}
.sec-h .ey{font-family:var(--display);font-size:12px;letter-spacing:2px;color:var(--accent);text-transform:uppercase;white-space:nowrap}
.sec-h h2{font-family:var(--display);font-size:clamp(20px,2.6vw,27px);letter-spacing:.5px;white-space:nowrap}
.sec-h .ln2{flex:1;height:1px;background:linear-gradient(90deg,var(--line-2),transparent)}
.sec-note{font-size:13px;color:var(--muted);margin:-6px 0 16px}

/* glass + utility */
.glass{background:var(--surface);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);
  border:1px solid var(--glass-border);border-radius:var(--r-xl);box-shadow:0 16px 42px -14px rgba(0,0,0,.55);position:relative;overflow:hidden}
.glass.glow::after{content:"";position:absolute;inset:0;background:radial-gradient(640px 200px at 50% -50%,var(--accent-soft),transparent 70%);pointer-events:none}
.pad{padding:24px}
.row{display:flex;align-items:center;gap:12px}
.wrap{flex-wrap:wrap}
.spacer{flex:1}
.empty{color:var(--muted-2);font-size:13.5px;font-style:italic;padding:20px;text-align:center}

/* buttons */
.btn{font-weight:700;font-size:13.5px;border-radius:12px;padding:11px 17px;cursor:pointer;border:1px solid transparent;
  display:inline-flex;align-items:center;gap:8px;transition:.18s;white-space:nowrap}
.btn-primary{background:var(--accent-grad);color:#160b04;box-shadow:0 8px 22px -8px var(--accent-glow)}
.btn-primary:hover{transform:translateY(-1px);filter:brightness(1.06)}
.btn-ghost{background:var(--surface);border-color:var(--line-2);color:var(--ink-dim)}
.btn-ghost:hover{border-color:var(--accent);color:var(--ink)}
.btn-sm{padding:8px 13px;font-size:12.5px;border-radius:10px}
.btn[disabled]{opacity:.4;cursor:not-allowed;transform:none!important;filter:none!important;box-shadow:none}

/* metric cards */
.metrics{display:grid;grid-template-columns:repeat(auto-fit,minmax(176px,1fr));gap:15px}
.metric{background:var(--surface);border:1px solid var(--glass-border);border-radius:var(--r-lg);padding:19px;position:relative;overflow:hidden;transition:transform .2s,border-color .2s;backdrop-filter:blur(14px)}
.metric:hover{transform:translateY(-3px);border-color:var(--line-2)}
.metric::before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--accent-grad);opacity:.7}
.metric .mh{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:12px}
.metric .ml{font-size:11px;color:var(--muted);font-weight:700;text-transform:uppercase;letter-spacing:.6px;max-width:120px}
.metric .mi{font-size:16px;width:32px;height:32px;border-radius:9px;background:var(--accent-soft);display:grid;place-items:center;flex-shrink:0}
.metric .mn{font-family:var(--display);font-size:36px;line-height:.95;background:var(--accent-grad);-webkit-background-clip:text;background-clip:text;color:transparent}
.metric .mn.plain{background:none;-webkit-background-clip:initial;color:var(--ink)}
.metric .ms{font-size:11.5px;color:var(--muted-2);margin-top:7px;display:flex;align-items:center;gap:6px}
.trend{font-size:11px;font-weight:700;padding:2px 7px;border-radius:999px}
.trend.up{color:var(--ok);background:var(--ok-soft)}
.trend.down{color:var(--bad);background:var(--bad-soft)}
.trend.flat{color:var(--muted);background:rgba(255,255,255,.06)}

/* ---------------- health intelligence ---------------- */
.health-wrap{display:grid;grid-template-columns:300px 1fr;gap:26px;align-items:center}
.ring-box{display:flex;flex-direction:column;align-items:center;gap:14px}
.ring{position:relative;width:210px;height:210px}
.ring svg{transform:rotate(-90deg);width:100%;height:100%}
.ring .ring-track{fill:none;stroke:rgba(255,255,255,.07);stroke-width:16}
.ring .ring-fill{fill:none;stroke:url(#ringgrad);stroke-width:16;stroke-linecap:round;transition:stroke-dashoffset 1.1s cubic-bezier(.16,1,.3,1)}
.ring .ring-mid{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center}
.ring .ring-pct{font-family:var(--display);font-size:52px;line-height:.9;background:var(--accent-grad);-webkit-background-clip:text;background-clip:text;color:transparent}
.ring .ring-lab{font-size:11px;letter-spacing:1.5px;text-transform:uppercase;color:var(--muted);margin-top:4px}
.hstatus{font-family:var(--display);font-size:18px;letter-spacing:1px;padding:7px 18px;border-radius:999px;text-transform:uppercase}
.hs-excellent{color:var(--ok);background:var(--ok-soft)}
.hs-healthy{color:var(--info);background:var(--info-soft)}
.hs-attention{color:var(--warn);background:var(--warn-soft)}
.hs-critical{color:var(--bad);background:var(--bad-soft)}
.factors{display:flex;flex-direction:column;gap:15px}
.factor .fl{display:flex;justify-content:space-between;font-size:12.5px;margin-bottom:6px}
.factor .fl .fk{color:var(--ink-dim);font-weight:600}
.factor .fl .fv{color:var(--accent-2);font-weight:700}
.fbar{height:9px;border-radius:999px;background:rgba(255,255,255,.06);overflow:hidden}
.fbar i{display:block;height:100%;border-radius:999px;background:var(--accent-grad);transition:width 1s cubic-bezier(.16,1,.3,1)}

/* insights engine */
.insights{display:flex;flex-direction:column;gap:11px}
.insight{display:flex;gap:13px;align-items:flex-start;background:var(--surface-2);border:1px solid var(--glass-border);border-left:3px solid var(--muted);border-radius:13px;padding:14px 16px}
.insight.risk{border-left-color:var(--bad)}
.insight.warn{border-left-color:var(--warn)}
.insight.info{border-left-color:var(--info)}
.insight .ii{font-size:18px;flex-shrink:0;line-height:1.3}
.insight .it{font-weight:700;font-size:13.5px;margin-bottom:2px}
.insight .id{font-size:12.5px;color:var(--muted);line-height:1.5}
.insight .who{display:inline-flex;flex-wrap:wrap;gap:5px;margin-top:7px}
.insight .who span{font-size:11px;font-weight:600;color:var(--ink-dim);background:rgba(255,255,255,.06);border-radius:6px;padding:3px 8px}
.insight-empty{display:flex;align-items:center;gap:10px;color:var(--ok);background:var(--ok-soft);border-radius:13px;padding:16px;font-size:13.5px;font-weight:600}

/* capacity */
.cap-top{display:flex;align-items:baseline;gap:10px;margin-bottom:12px}
.cap-n{font-family:var(--display);font-size:32px;line-height:1}
.cap-n b{background:var(--accent-grad);-webkit-background-clip:text;background-clip:text;color:transparent}
.cap-n .of{color:var(--muted)}
.cap-lab{font-size:12.5px;color:var(--muted);font-weight:600}
.cap-pct{margin-left:auto;font-size:13px;font-weight:700;color:var(--accent-2)}
.cap-bar{height:12px;border-radius:999px;background:rgba(255,255,255,.06);overflow:hidden}
.cap-bar i{display:block;height:100%;border-radius:999px;background:var(--accent-grad);transition:width .9s cubic-bezier(.16,1,.3,1)}
.cap-bar i.full{background:linear-gradient(135deg,#ff3d00,#ff2e4d)}
.cap-msg{display:flex;align-items:center;gap:10px;margin-top:14px;background:var(--bad-soft);border:1px solid rgba(255,59,92,.3);border-radius:12px;padding:13px 15px;font-size:13px;color:#ffd0d8}
.cap-msg b{color:#fff}

/* ---------------- roster ---------------- */
.rtools{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-bottom:16px}
.seg{display:inline-flex;background:var(--surface);border:1px solid var(--line);border-radius:11px;padding:3px;gap:2px}
.seg button{background:transparent;border:none;color:var(--muted);font-weight:600;font-size:12.5px;padding:7px 13px;border-radius:8px;cursor:pointer;transition:.16s}
.seg button:hover{color:var(--ink)}
.seg button.on{background:var(--accent-grad);color:#160b04}
.mini-sel{appearance:none;-webkit-appearance:none;background:var(--surface);border:1px solid var(--line);border-radius:11px;color:var(--ink-dim);font:inherit;font-weight:600;font-size:12.5px;padding:8px 30px 8px 13px;cursor:pointer;position:relative}
.mini-sel option{background:#1a0f0b}
.sel-wrap{position:relative}
.sel-wrap .chev{position:absolute;right:12px;top:50%;transform:translateY(-50%);color:var(--accent);pointer-events:none;font-size:10px}
.rcount{font-size:12.5px;color:var(--muted-2);margin-left:auto}

.roster{display:flex;flex-direction:column;gap:12px}
.rcard{background:var(--surface);border:1px solid var(--glass-border);border-radius:var(--r-lg);overflow:hidden;transition:border-color .2s;backdrop-filter:blur(14px)}
.rcard:hover{border-color:var(--line-2)}
.rcard.open{border-color:var(--line-2)}
.rhead{display:flex;align-items:center;gap:13px;padding:15px 18px;cursor:pointer;width:100%;background:none;border:none;text-align:left;color:inherit}
.r-av{width:42px;height:42px;border-radius:11px;display:grid;place-items:center;font-family:var(--display);font-size:17px;color:#fff;flex-shrink:0}
.r-id{min-width:0;flex:1}
.r-name{font-size:15.5px;font-weight:700;line-height:1.2}
.r-meta{font-size:12px;color:var(--muted);margin-top:2px;display:flex;gap:8px;flex-wrap:wrap;align-items:center}
.r-meta .schip{font-size:10px;font-weight:700;letter-spacing:.4px;text-transform:uppercase;padding:2px 7px;border-radius:5px;color:#fff}
.hpill{font-size:12px;font-weight:700;padding:5px 12px;border-radius:999px;flex-shrink:0;white-space:nowrap}
.hp-excellent{color:var(--ok);background:var(--ok-soft)}
.hp-healthy{color:var(--info);background:var(--info-soft)}
.hp-attention{color:var(--warn);background:var(--warn-soft)}
.hp-critical{color:var(--bad);background:var(--bad-soft)}
.r-chev{font-size:13px;color:var(--muted);transition:transform .3s;flex-shrink:0}
.rcard.open .r-chev{transform:rotate(180deg)}
.rbody{display:grid;grid-template-rows:0fr;transition:grid-template-rows .35s ease}
.rcard.open .rbody{grid-template-rows:1fr}
.rbody-in{overflow:hidden;min-height:0}
.rbody-pad{padding:4px 18px 20px;border-top:1px solid var(--line)}

.block-label{font-size:10.5px;letter-spacing:1.4px;text-transform:uppercase;color:var(--accent);font-weight:700;margin:18px 0 11px}
.info-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:11px}
.info-cell{background:var(--surface-2);border:1px solid var(--glass-border);border-radius:11px;padding:11px 13px}
.info-cell .ic-l{font-size:10.5px;color:var(--muted-2);text-transform:uppercase;letter-spacing:.5px;font-weight:600}
.info-cell .ic-v{font-size:13.5px;color:var(--ink);font-weight:600;margin-top:3px;word-break:break-word}
.badge{display:inline-block;font-size:10.5px;font-weight:700;letter-spacing:.4px;text-transform:uppercase;padding:3px 9px;border-radius:6px}
.b-grad{color:var(--ok);background:var(--ok-soft)}
.b-enr{color:var(--info);background:var(--info-soft)}
.b-pend{color:var(--muted);background:rgba(255,255,255,.06)}
.b-yes{color:var(--ok);background:var(--ok-soft)}
.b-no{color:var(--muted);background:rgba(255,255,255,.06)}

/* discipleship */
.disc-tasks{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:9px}
.dtask{display:flex;align-items:center;gap:10px;background:var(--surface-2);border:1px solid var(--glass-border);border-radius:11px;padding:11px 13px;cursor:pointer;transition:.16s;user-select:none}
.dtask:hover{border-color:var(--line-2)}
.dtask .dbox{width:21px;height:21px;border-radius:6px;border:1.5px solid var(--line-2);display:grid;place-items:center;flex-shrink:0;font-size:12px;color:#160b04;transition:.16s}
.dtask.done .dbox{background:var(--accent-grad);border-color:transparent}
.dtask .dlbl{font-size:13px;font-weight:600;flex:1}
.dtask .dpc{font-size:11px;color:var(--muted-2);font-weight:700}
.dtask.done .dlbl{color:var(--ink)}
.disc-foot{display:flex;align-items:center;gap:12px;margin-top:12px}
.disc-bar{flex:1;height:9px;border-radius:999px;background:rgba(255,255,255,.06);overflow:hidden}
.disc-bar i{display:block;height:100%;border-radius:999px;background:var(--accent-grad);transition:width .5s ease}
.disc-pct{font-size:12.5px;font-weight:700;color:var(--accent-2);font-family:var(--display);letter-spacing:.5px}

/* vital signs */
.vitals{display:grid;grid-template-columns:repeat(auto-fit,minmax(190px,1fr));gap:12px}
.vital label{display:block;font-size:11.5px;color:var(--muted);font-weight:600;margin-bottom:6px}
.vital .sel-wrap{display:block}
.vital select{width:100%;appearance:none;-webkit-appearance:none;background:var(--surface-2);border:1px solid var(--line);border-radius:10px;color:var(--ink);font:inherit;font-size:13px;font-weight:600;padding:10px 30px 10px 12px;cursor:pointer}
.vital select:focus{outline:none;border-color:var(--accent)}
.vital select option{background:#1a0f0b}
.rng{width:100%;height:8px;cursor:pointer;accent-color:var(--accent)}
.notes-area{width:100%;background:var(--surface-2);border:1px solid var(--line);border-radius:12px;color:var(--ink);font:inherit;font-size:13px;padding:12px 14px;resize:vertical;min-height:56px;margin-top:4px}
.notes-area:focus{outline:none;border-color:var(--accent)}
.r-foot{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-top:18px;padding-top:14px;border-top:1px solid var(--line)}
.r-updated{font-size:11.5px;color:var(--muted-2)}
.r-remove{background:transparent;border:1px solid var(--line);color:var(--muted);font-weight:600;font-size:12px;padding:8px 13px;border-radius:10px;cursor:pointer;transition:.16s}
.r-remove:hover{border-color:var(--bad);color:var(--bad)}

/* ---------------- reporting charts ---------------- */
.report-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:16px}
.chart-card{background:var(--surface);border:1px solid var(--glass-border);border-radius:var(--r-lg);padding:20px;backdrop-filter:blur(14px)}
.cc-h{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}
.cc-h .cct{font-weight:700;font-size:14px}
.cc-h .ccs{font-size:11px;color:var(--muted-2)}
.donut-wrap{display:flex;align-items:center;gap:18px}
.donut{width:128px;height:128px;flex-shrink:0;transform:rotate(-90deg)}
.donut-legend{display:flex;flex-direction:column;gap:8px;flex:1}
.dl{display:flex;align-items:center;gap:9px;font-size:12.5px}
.dl .dot{width:11px;height:11px;border-radius:3px;flex-shrink:0}
.dl .dn{color:var(--ink-dim);flex:1}
.dl .dv{color:var(--muted);font-weight:700}
.barrow{display:flex;align-items:center;gap:12px;margin-bottom:11px}
.barrow .brl{width:84px;font-size:12px;color:var(--ink-dim);font-weight:600;flex-shrink:0}
.barrow .brbar{flex:1;height:10px;border-radius:999px;background:rgba(255,255,255,.06);overflow:hidden}
.barrow .brbar i{display:block;height:100%;border-radius:999px;transition:width .8s ease}
.barrow .brv{width:32px;text-align:right;font-size:12px;font-weight:700;color:var(--muted);flex-shrink:0}
.spark{width:100%;height:54px;margin-top:4px}
.sum-line{display:flex;justify-content:space-between;font-size:13px;padding:8px 0;border-bottom:1px solid var(--line)}
.sum-line:last-child{border-bottom:none}
.sum-line .sk{color:var(--muted)}
.sum-line .sv{font-weight:700;color:var(--ink)}
.export-row{display:flex;gap:10px;flex-wrap:wrap;margin-top:18px}

/* ---------------- modal ---------------- */
.overlay{position:fixed;inset:0;z-index:200;background:rgba(5,3,2,.72);backdrop-filter:blur(6px);
  display:flex;align-items:flex-start;justify-content:center;padding:40px 18px;opacity:0;pointer-events:none;transition:opacity .25s;overflow-y:auto}
.overlay.show{opacity:1;pointer-events:auto}
.modal{width:100%;max-width:640px;background:linear-gradient(180deg,rgba(30,19,15,.96),rgba(18,11,9,.98));
  border:1px solid var(--line-2);border-radius:var(--r-xl);box-shadow:0 30px 80px -20px #000;
  transform:translateY(20px) scale(.98);transition:transform .3s cubic-bezier(.16,1,.3,1);margin:auto 0}
.overlay.show .modal{transform:translateY(0) scale(1)}
.modal-h{display:flex;align-items:center;gap:13px;padding:22px 24px;border-bottom:1px solid var(--line)}
.modal-h .mhi{width:42px;height:42px;border-radius:12px;background:var(--accent-grad);display:grid;place-items:center;font-size:20px;flex-shrink:0}
.modal-h .mht{font-family:var(--display);font-size:21px;letter-spacing:.5px;line-height:1}
.modal-h .mhs{font-size:12px;color:var(--muted);margin-top:3px}
.modal-h .mx{margin-left:auto;background:transparent;border:1px solid var(--line);color:var(--muted);width:34px;height:34px;border-radius:9px;font-size:17px;cursor:pointer;flex-shrink:0;transition:.16s}
.modal-h .mx:hover{border-color:var(--bad);color:var(--bad)}
.modal-b{padding:22px 24px;max-height:64vh;overflow-y:auto}
.fsec{margin-bottom:22px}
.fsec:last-child{margin-bottom:0}
.fsec-h{font-size:10.5px;letter-spacing:1.4px;text-transform:uppercase;color:var(--accent);font-weight:700;margin-bottom:13px;display:flex;align-items:center;gap:8px}
.fsec-h::after{content:"";flex:1;height:1px;background:var(--line)}
.fgrid{display:grid;grid-template-columns:1fr 1fr;gap:13px}
.field{display:flex;flex-direction:column;gap:6px}
.field.full{grid-column:1/-1}
.field label{font-size:12px;color:var(--ink-dim);font-weight:600}
.field label .req{color:var(--accent)}
.field input,.field select,.field textarea{background:var(--surface-2);border:1px solid var(--line);border-radius:11px;color:var(--ink);font:inherit;font-size:13.5px;padding:11px 13px;outline:none;transition:.16s;width:100%;appearance:none;-webkit-appearance:none}
.field select{cursor:pointer}
.field select option{background:#1a0f0b}
.field input:focus,.field select:focus,.field textarea:focus{border-color:var(--accent)}
.field input::placeholder,.field textarea::placeholder{color:var(--muted-2)}
.field.err input,.field.err select{border-color:var(--bad)}
.field .msg{font-size:11.5px;color:var(--bad);min-height:0;display:none}
.field.err .msg{display:block}
.seg2{display:inline-flex;background:var(--surface-2);border:1px solid var(--line);border-radius:11px;padding:3px;gap:2px;width:fit-content}
.seg2 button{background:transparent;border:none;color:var(--muted);font-weight:600;font-size:13px;padding:9px 18px;border-radius:8px;cursor:pointer;transition:.16s}
.seg2 button.on{background:var(--accent-grad);color:#160b04}
.modal-f{display:flex;justify-content:flex-end;gap:11px;padding:18px 24px;border-top:1px solid var(--line)}

/* ---------------- toasts + fab ---------------- */
.toasts{position:fixed;right:22px;bottom:22px;z-index:300;display:flex;flex-direction:column;gap:10px;max-width:340px}
.toast{display:flex;align-items:center;gap:11px;background:linear-gradient(180deg,rgba(34,21,16,.97),rgba(20,12,10,.98));
  border:1px solid var(--line-2);border-left:3px solid var(--accent);border-radius:13px;padding:13px 16px;
  box-shadow:0 16px 40px -12px #000;animation:toastIn .35s cubic-bezier(.16,1,.3,1);font-size:13px}
.toast.out{animation:toastOut .3s forwards}
.toast.ok{border-left-color:var(--ok)} .toast.warn{border-left-color:var(--warn)} .toast.info{border-left-color:var(--info)}
.toast .ti{font-size:17px;flex-shrink:0}
@keyframes toastIn{from{opacity:0;transform:translateX(40px)}to{opacity:1;transform:translateX(0)}}
@keyframes toastOut{to{opacity:0;transform:translateX(40px)}}
.fab{position:fixed;right:24px;bottom:24px;z-index:150;width:58px;height:58px;border-radius:18px;border:none;cursor:pointer;
  background:var(--accent-grad);color:#160b04;font-size:26px;display:grid;place-items:center;
  box-shadow:0 14px 34px -8px var(--accent-glow);transition:transform .2s}
.fab:hover{transform:translateY(-3px) rotate(90deg)}
.fab[disabled]{opacity:.4;cursor:not-allowed;transform:none}

/* ---------------- hub / resources / library ---------------- */
.vid-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:16px}
.vid-card{background:var(--surface);border:1px solid var(--glass-border);border-radius:var(--r-lg);overflow:hidden;transition:transform .2s,border-color .2s;backdrop-filter:blur(14px)}
.vid-card:hover{transform:translateY(-4px);border-color:var(--line-2)}
.vid-thumb{height:148px;position:relative;display:grid;place-items:center;background:linear-gradient(135deg,rgba(255,61,0,.25),rgba(40,25,20,.5))}
.vid-thumb.has-thumb::before{content:"";position:absolute;inset:0;background:rgba(0,0,0,.32);transition:background .2s}
.vid-card:hover .vid-thumb.has-thumb::before{background:rgba(0,0,0,.12)}
.vid-thumb .play{position:relative;z-index:1;width:54px;height:54px;border-radius:50%;background:rgba(0,0,0,.45);backdrop-filter:blur(6px);border:1px solid rgba(255,255,255,.5);display:grid;place-items:center;font-size:20px;color:#fff;transition:.2s;padding-left:3px}
.vid-card:hover .play{background:var(--accent-grad);color:#160b04;transform:scale(1.08)}
.vid-thumb .dur{position:absolute;z-index:1;right:10px;bottom:10px;background:rgba(0,0,0,.6);font-size:11px;font-weight:600;padding:3px 8px;border-radius:6px}
.vid-thumb .wk{position:absolute;z-index:1;left:10px;top:10px;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;background:var(--accent-grad);color:#160b04;padding:3px 9px;border-radius:6px}
.vid-b{padding:16px}
.vid-b .vt{font-weight:700;font-size:14.5px;margin-bottom:5px}
.vid-b .vd{font-size:12.5px;color:var(--muted);line-height:1.5;margin-bottom:13px}

.checkin-history{display:flex;flex-direction:column;gap:9px;margin-top:8px}
.ci-row{display:flex;align-items:center;gap:10px;flex-wrap:wrap;background:var(--surface-2);border:1px solid var(--glass-border);border-radius:11px;padding:11px 14px}
.ci-row .ci-date{font-size:12px;font-weight:700;color:var(--accent-2);min-width:96px}
.ci-row .ci-tag{font-size:11px;font-weight:600;padding:3px 9px;border-radius:6px;background:rgba(255,255,255,.06);color:var(--ink-dim)}
.ci-row .ci-note{font-size:12px;color:var(--muted);flex-basis:100%;margin-top:2px}

.res-cat{margin-bottom:26px}
.cat-h{display:flex;align-items:center;gap:10px;font-family:var(--display);font-size:16px;letter-spacing:.5px;margin-bottom:13px}
.cat-h .ci{font-size:18px}
.res-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:13px}
.res-card{background:var(--surface);border:1px solid var(--glass-border);border-radius:var(--r-lg);padding:18px;display:flex;flex-direction:column;transition:transform .2s,border-color .2s;backdrop-filter:blur(14px)}
.res-card:hover{transform:translateY(-3px);border-color:var(--line-2)}
.res-card .rc-tag{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--accent);margin-bottom:9px}
.res-card .rc-t{font-weight:700;font-size:14px;margin-bottom:6px}
.res-card .rc-d{font-size:12.5px;color:var(--muted);line-height:1.5;flex:1;margin-bottom:14px}

.book-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:18px}
.book{background:var(--surface);border:1px solid var(--glass-border);border-radius:var(--r-lg);overflow:hidden;transition:transform .2s,border-color .2s;backdrop-filter:blur(14px)}
.book:hover{transform:translateY(-5px);border-color:var(--line-2)}
.book-cover{height:200px;position:relative;display:flex;align-items:flex-end;padding:16px}
.book-cover::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 30%,rgba(0,0,0,.7))}
.book-cover .bk-icn{position:absolute;top:16px;left:16px;font-size:26px}
.book-cover .bk-ct{position:relative;z-index:1;font-family:var(--display);font-size:18px;line-height:1.05;letter-spacing:.5px}
.book-b{padding:16px}
.book-b .bk-a{font-size:11.5px;color:var(--accent-2);font-weight:600;margin-bottom:7px}
.book-b .bk-d{font-size:12px;color:var(--muted);line-height:1.5;margin-bottom:14px;min-height:54px}

/* scrim for mobile drawer */
.scrim{position:fixed;inset:0;z-index:55;background:rgba(0,0,0,.5);backdrop-filter:blur(2px);opacity:0;pointer-events:none;transition:opacity .25s}
.scrim.show{opacity:1;pointer-events:auto}

/* ---------------- responsive ---------------- */
@media(max-width:1080px){
  .app{grid-template-columns:1fr}
  .sidebar{position:fixed;top:0;left:0;width:280px;transform:translateX(-100%);transition:transform .3s cubic-bezier(.16,1,.3,1)}
  .sidebar.open{transform:translateX(0)}
  .menu-btn{display:grid;place-items:center}
  .health-wrap{grid-template-columns:1fr}
  .ring-box{margin-bottom:8px}
}
@media(max-width:720px){
  .content{padding:18px}
  .topbar{padding:11px 16px;gap:10px}
  .search{display:none}
  .leader-chip .lt{display:none}
  .leader-chip{padding:6px}
  .fgrid{grid-template-columns:1fr}
  .tb-title{font-size:18px}
  .pad{padding:18px}
  .glass{border-radius:var(--r-lg)}
  .ring{width:180px;height:180px}
  .fab{right:16px;bottom:16px}
  .toasts{right:12px;left:12px;bottom:12px;max-width:none}
}
@media(prefers-reduced-motion:reduce){
  *{animation-duration:.001ms!important;transition-duration:.08s!important}
  .bg-orb{animation:none}
}

/* ====================================================================
   MINISTRY OS v2 — role system, reporting & escalation components
   ==================================================================== */

/* ---------------- role sign-in screen ---------------- */
.login{position:fixed;inset:0;z-index:500;display:flex;align-items:center;justify-content:center;padding:28px;overflow-y:auto;
  background:radial-gradient(1100px 700px at 80% -10%,rgba(255,90,0,.14),transparent 60%),
             radial-gradient(900px 650px at -5% 110%,rgba(255,46,77,.10),transparent 55%),var(--ember)}
.login.hide{display:none}
.login-box{max-width:1060px;width:100%;margin:auto}
.login-brand{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;text-align:center}
.login-brand img{width:auto;height:64px;max-width:80%;object-fit:contain;border-radius:0;background:none;box-shadow:none}
.login-title{font-family:var(--display);font-size:clamp(30px,5vw,44px);letter-spacing:.5px;line-height:.95;text-align:center;margin-top:18px}
.login-title em{font-style:normal;background:var(--fire-grad);-webkit-background-clip:text;background-clip:text;color:transparent}
.login-sub{text-align:center;color:var(--muted);font-size:14px;margin-top:10px}
.role-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(186px,1fr));gap:14px;margin-top:30px}
.role-card{background:var(--surface);backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px);
  border:1px solid var(--glass-border);border-radius:18px;padding:20px 18px;cursor:pointer;text-align:left;color:var(--ink);
  transition:.2s;position:relative;overflow:hidden}
.role-card::before{content:"";position:absolute;left:0;top:0;right:0;height:3px;background:var(--fire-grad);opacity:.85}
.role-card:hover{transform:translateY(-4px);border-color:var(--line-2);box-shadow:0 18px 44px -14px rgba(255,100,0,.35)}
.role-card .rl{font-size:9.5px;letter-spacing:1.8px;text-transform:uppercase;color:var(--fire-3);font-weight:700}
.role-card .ri{font-size:25px;margin:9px 0 7px}
.role-card .rt{font-family:var(--display);font-size:17px;letter-spacing:.5px;line-height:1.05}
.role-card .rn{font-size:12px;color:var(--ink-dim);font-weight:600;margin-top:7px}
.role-card .rs{font-size:11px;color:var(--muted-2);margin-top:5px;line-height:1.5}
.login-note{text-align:center;color:var(--muted-2);font-size:11.5px;margin-top:24px}

/* persona / role identity */
.rolebadge{font-size:10px;font-weight:800;letter-spacing:.8px;text-transform:uppercase;padding:4px 10px;border-radius:7px;background:var(--accent-soft);color:var(--accent-2);border:1px solid var(--line)}
.scope-note{display:flex;align-items:center;gap:9px;font-size:12px;color:var(--muted);background:var(--surface);border:1px dashed var(--line-2);border-radius:11px;padding:10px 14px;margin-bottom:20px}
.scope-note .sni{font-size:14px}
.squad-tag{display:inline-block;font-size:9.5px;font-weight:800;letter-spacing:.5px;text-transform:uppercase;padding:3px 8px;border-radius:5px;color:#fff}

/* ---------------- reports & escalation ---------------- */
.stpill{display:inline-flex;align-items:center;gap:6px;font-size:10.5px;font-weight:800;letter-spacing:.4px;text-transform:uppercase;padding:4px 11px;border-radius:999px;border:1px solid;white-space:nowrap}
.sevdot{width:9px;height:9px;border-radius:50%;flex-shrink:0}
.rep-list{display:flex;flex-direction:column;gap:10px}
.rep-row{display:flex;align-items:center;gap:13px;background:var(--surface-2);border:1px solid var(--glass-border);border-radius:13px;padding:13px 16px;cursor:pointer;transition:.16s;text-align:left;width:100%;color:var(--ink)}
.rep-row:hover{border-color:var(--line-2);transform:translateX(3px)}
.rep-main{flex:1;min-width:0}
.rep-t{font-weight:700;font-size:13.5px;display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.rep-m{font-size:11.5px;color:var(--muted);margin-top:3px}
.rep-chev{color:var(--muted-2);font-size:13px;flex-shrink:0}

/* timeline */
.timeline{margin:6px 0 4px;padding-left:9px}
.tl-item{position:relative;padding:0 0 17px 22px;border-left:2px solid var(--line)}
.tl-item:last-child{border-left-color:transparent;padding-bottom:2px}
.tl-dot{position:absolute;left:-7px;top:1px;width:12px;height:12px;border-radius:50%;background:var(--accent-grad);box-shadow:0 0 0 3px rgba(0,0,0,.45)}
.tl-l{font-size:13px;font-weight:700;line-height:1.3}
.tl-m{font-size:11.5px;color:var(--muted);margin-top:2px}

/* report detail header */
.rep-head{display:flex;align-items:flex-start;gap:13px;flex-wrap:wrap;margin-bottom:14px}
.rep-desc{background:var(--surface-2);border:1px solid var(--glass-border);border-radius:12px;padding:13px 15px;font-size:13px;color:var(--ink-dim);line-height:1.6;margin:10px 0}
.rep-actions{display:flex;gap:9px;flex-wrap:wrap;margin-top:16px}

/* ---------------- tables (rankings, users) ---------------- */
.tbl-wrap{overflow-x:auto}
.tbl{width:100%;border-collapse:collapse;font-size:13px;min-width:520px}
.tbl th{font-size:10px;letter-spacing:1.2px;text-transform:uppercase;color:var(--muted-2);font-weight:700;text-align:left;padding:9px 13px;border-bottom:1px solid var(--line-2)}
.tbl td{padding:12px 13px;border-bottom:1px solid var(--line);color:var(--ink-dim)}
.tbl tr:last-child td{border-bottom:none}
.tbl td b{color:var(--ink)}
.tbl .rank{font-family:var(--display);font-size:17px;color:var(--accent-2)}

/* comparison bars */
.cmp-row{display:flex;align-items:center;gap:12px;margin-bottom:12px}
.cmp-row:last-child{margin-bottom:0}
.cmp-n{width:96px;font-size:12.5px;font-weight:700;flex-shrink:0;display:flex;align-items:center;gap:8px}
.cmp-bar{flex:1;height:13px;border-radius:999px;background:rgba(255,255,255,.06);overflow:hidden}
.cmp-bar i{display:block;height:100%;border-radius:999px;transition:width .9s cubic-bezier(.16,1,.3,1)}
.cmp-v{width:44px;text-align:right;font-size:12.5px;font-weight:700;color:var(--muted)}

/* leader performance card */
.lead-card{display:flex;align-items:center;gap:14px;background:var(--surface-2);border:1px solid var(--glass-border);border-radius:14px;padding:15px 17px}
.lead-card .la{width:42px;height:42px;border-radius:11px;display:grid;place-items:center;font-family:var(--display);font-size:16px;color:#fff;flex-shrink:0}
.lead-card .ln2{font-weight:700;font-size:14px}
.lead-card .lm2{font-size:11.5px;color:var(--muted);margin-top:2px}
.lead-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:12px}

/* lite member rows (read-only, higher roles) */
.mlite{display:flex;align-items:center;gap:12px;background:var(--surface-2);border:1px solid var(--glass-border);border-radius:12px;padding:11px 14px}
.mlite .ma{width:34px;height:34px;border-radius:9px;display:grid;place-items:center;font-family:var(--display);font-size:13px;color:#fff;flex-shrink:0}
.mlite .mn2{font-weight:700;font-size:13px;flex:1;min-width:0}
.mlite .ms2{font-size:11px;color:var(--muted)}

/* topbar switch-role */
.switch-role{background:transparent;border:1px solid var(--line);color:var(--muted);font-weight:600;font-size:11.5px;padding:8px 13px;border-radius:10px;cursor:pointer;transition:.16s;white-space:nowrap}
.switch-role:hover{border-color:var(--accent);color:var(--ink)}

@media(max-width:720px){
  .role-grid{grid-template-columns:1fr 1fr}
  .cmp-n{width:74px}
}

/* ============ pilot additions: login card, dropdowns, badges ============ */
.login-card{margin-top:24px;text-align:left}
.login-card .field input{width:100%}
.remember{display:flex;align-items:center;gap:8px;font-size:12.5px;color:var(--muted);cursor:pointer}
.remember input{accent-color:var(--accent);width:15px;height:15px}
.linklike{background:none;border:none;color:var(--accent-2);font:inherit;font-size:12.5px;font-weight:600;cursor:pointer;padding:0}
.linklike:hover{text-decoration:underline}
.login-err{color:var(--bad);font-size:12.5px;font-weight:600;min-height:0;margin-top:10px;display:none}
.login-err.show{display:block}
.demo-box{margin-top:18px;text-align:center;font-size:11.5px;color:var(--muted-2);line-height:2}
.demo-box b{color:var(--muted)}
.demo-box code{color:var(--accent-2);background:rgba(0,0,0,.35);padding:2px 7px;border-radius:6px}
.demo-box span{display:inline-block;background:var(--surface);border:1px solid var(--line);border-radius:7px;padding:2px 9px;margin:0 3px;color:var(--ink-dim)}

.icon-btn{position:relative;width:42px;height:42px;border-radius:12px;border:1px solid var(--line);background:var(--surface);color:var(--ink-dim);font-size:17px;cursor:pointer;flex-shrink:0;transition:.16s}
.icon-btn:hover{border-color:var(--accent);color:var(--ink)}
.nbadge{position:absolute;top:-6px;right:-6px;min-width:19px;height:19px;border-radius:999px;background:var(--accent-grad);color:#160b04;font-size:10.5px;font-weight:800;display:grid;place-items:center;padding:0 5px;box-shadow:0 4px 12px -2px var(--accent-glow)}

.drop{position:absolute;top:64px;right:24px;width:min(380px,92vw);max-height:65vh;overflow-y:auto;background:linear-gradient(180deg,rgba(30,19,15,.98),rgba(18,11,9,.99));border:1px solid var(--line-2);border-radius:16px;box-shadow:0 28px 70px -16px #000;display:none;z-index:90;padding:8px}
.drop.show{display:block;animation:fadeUp .25s cubic-bezier(.16,1,.3,1)}
.drop-h{display:flex;align-items:center;justify-content:space-between;font-size:11px;letter-spacing:1.4px;text-transform:uppercase;color:var(--muted);font-weight:700;padding:10px 12px 8px}
.notif{display:flex;gap:11px;padding:11px 12px;border-radius:11px;font-size:12.5px;color:var(--ink-dim);line-height:1.5}
.notif.unread{background:var(--accent-soft)}
.notif .nt{font-size:15px;flex-shrink:0}
.notif .nm{font-size:10.5px;color:var(--muted-2);margin-top:2px}
#searchPanel{right:auto;left:50%;transform:translateX(-50%);width:min(560px,94vw)}
.sr-h{font-size:10px;letter-spacing:1.4px;text-transform:uppercase;color:var(--accent);font-weight:700;padding:10px 12px 5px}
.sr{display:flex;align-items:center;gap:10px;width:100%;text-align:left;background:none;border:none;color:var(--ink-dim);font:inherit;font-size:13px;padding:9px 12px;border-radius:10px;cursor:pointer}
.sr:hover{background:rgba(255,255,255,.05);color:var(--ink)}
.sr .sri{font-size:14px;width:20px;text-align:center;flex-shrink:0}
.sr .srm{font-size:11px;color:var(--muted-2);margin-left:auto;flex-shrink:0}

.dl-btn{margin-top:auto}
.file-meta{font-size:10.5px;color:var(--muted-2);margin-top:6px}
.views-tag{font-size:10.5px;color:var(--muted-2)}
.watched{color:var(--ok);font-size:10.5px;font-weight:700}
.embed-wrap{position:relative;width:100%;aspect-ratio:16/9;background:#000;border-radius:12px;overflow:hidden}
.embed-wrap iframe{position:absolute;inset:0;width:100%;height:100%;border:0}
.prof-hist{margin-top:8px;display:flex;flex-direction:column;gap:7px}
.prof-hist .ph{display:flex;justify-content:space-between;font-size:12px;color:var(--muted);background:var(--surface-2);border:1px solid var(--glass-border);border-radius:9px;padding:8px 12px}
@media(max-width:720px){ .drop{right:10px} #searchPanel{left:10px;right:10px;transform:none;width:auto} .switch-role span{display:none} }

/* ============ V3: calendar, tabs, messages, missions, FS ============ */
.tabbar{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:18px}
.tabbar button{background:var(--surface);border:1px solid var(--line);color:var(--muted);font:inherit;font-size:12.5px;font-weight:700;padding:9px 16px;border-radius:11px;cursor:pointer;transition:.16s}
.tabbar button.on{background:var(--accent-soft);border-color:var(--accent);color:var(--ink)}
.cal{display:grid;grid-template-columns:repeat(7,1fr);gap:6px}
.cal-h{font-size:10px;letter-spacing:1.2px;text-transform:uppercase;color:var(--muted-2);font-weight:700;text-align:center;padding:4px 0}
.cal-day{min-height:84px;background:var(--surface-2);border:1px solid var(--glass-border);border-radius:11px;padding:7px 8px;font-size:11.5px;color:var(--muted);position:relative}
.cal-day.other{opacity:.35}
.cal-day.today{border-color:var(--accent);box-shadow:0 0 0 1px var(--accent) inset}
.cal-day .dn{font-weight:800;color:var(--ink-dim);font-size:12px}
.cal-ev{display:block;margin-top:4px;font-size:10px;font-weight:700;color:#fff;padding:2px 6px;border-radius:5px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}
.msg-row{background:var(--surface-2);border:1px solid var(--glass-border);border-radius:13px;padding:14px 16px;margin-bottom:10px}
.msg-top{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.msg-sub{font-weight:800;font-size:14px}
.msg-kind{font-size:9.5px;font-weight:800;letter-spacing:.6px;text-transform:uppercase;padding:3px 9px;border-radius:6px;background:var(--accent-soft);color:var(--accent-2)}
.msg-body{font-size:13px;color:var(--ink-dim);line-height:1.6;margin-top:8px}
.msg-meta{font-size:11px;color:var(--muted-2);margin-top:6px}
.msg-acts{display:flex;gap:7px;flex-wrap:wrap;margin-top:11px}
.msg-reply{display:flex;gap:8px;margin-top:10px}
.msg-reply input{flex:1;background:var(--surface);border:1px solid var(--line);border-radius:10px;color:var(--ink);font:inherit;font-size:12.5px;padding:9px 12px}
.reply-line{font-size:12px;color:var(--muted);margin-top:7px;padding-left:12px;border-left:2px solid var(--line)}
.mis-card{background:var(--surface-2);border:1px solid var(--glass-border);border-radius:14px;padding:15px 17px;margin-bottom:11px}
.mis-top{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.mis-name{font-family:var(--display);font-size:17px;letter-spacing:.4px}
.mis-meta{font-size:11.5px;color:var(--muted);margin-top:5px}
.fschip{display:inline-flex;align-items:center;gap:6px;font-size:11px;font-weight:800;padding:4px 11px;border-radius:999px;background:var(--accent-soft);border:1px solid var(--line-2);color:var(--accent-2)}
.wkbadge{font-size:10px;font-weight:800;padding:3px 9px;border-radius:999px;color:#160b04}
.chipsel{display:flex;gap:7px;flex-wrap:wrap}
.chipsel button{background:var(--surface-2);border:1px solid var(--line);color:var(--muted);font:inherit;font-size:11.5px;font-weight:700;padding:7px 13px;border-radius:999px;cursor:pointer}
.chipsel button.on{background:var(--accent-soft);border-color:var(--accent);color:var(--ink)}
.stu-card{background:var(--surface-2);border:1px solid var(--glass-border);border-radius:14px;padding:15px 17px;margin-bottom:11px}
.teevo-card{background:linear-gradient(135deg,rgba(255,122,0,.12),rgba(255,46,77,.07));border:1px solid var(--line-2);border-radius:16px;padding:17px 19px;margin-bottom:16px}
@media(max-width:760px){.cal-day{min-height:58px;padding:5px 6px}.cal-ev{display:none}.cal-day .dots{display:flex;gap:3px;margin-top:4px}.cal-day .dot2{width:6px;height:6px;border-radius:50%}}

.navnum{display:inline-grid;place-items:center;min-width:18px;height:18px;border-radius:999px;background:var(--accent-grad);color:#160b04;font-size:10px;font-weight:800;padding:0 5px;margin-left:6px;vertical-align:1px}

/* ════════════════════════════════════════════════════════════════════
   V3.2 DESIGN SYSTEM — precision pass
   Signature motif: the EMBER HAIRLINE (1px fire-gradient rule) repeated
   at topbar base, section headers, active nav, card hover, login card.
   ════════════════════════════════════════════════════════════════════ */
:root{
  --r-lg:18px; --r-md:14px; --r-sm:11px;
  --ease:cubic-bezier(.2,.8,.2,1);
  --hairline:linear-gradient(90deg,transparent,var(--accent) 18%,var(--accent-2) 50%,var(--accent) 82%,transparent);
  --elev-1:inset 0 1px 0 rgba(255,255,255,.05), 0 1px 2px rgba(0,0,0,.4);
  --elev-2:inset 0 1px 0 rgba(255,255,255,.06), 0 18px 44px -24px rgba(0,0,0,.75);
  --elev-3:inset 0 1px 0 rgba(255,255,255,.07), 0 30px 70px -28px rgba(0,0,0,.85);
}
::selection{background:var(--accent);color:#1a0d04}
*{scrollbar-width:thin;scrollbar-color:rgba(255,255,255,.14) transparent}
*::-webkit-scrollbar{width:9px;height:9px}
*::-webkit-scrollbar-thumb{background:rgba(255,255,255,.12);border-radius:999px;border:2px solid transparent;background-clip:content-box}
*::-webkit-scrollbar-thumb:hover{background:var(--accent);border:2px solid transparent;background-clip:content-box}
:focus{outline:none}
:focus-visible{outline:2px solid var(--accent);outline-offset:2px;border-radius:6px}
input:focus-visible,select:focus-visible,textarea:focus-visible{outline-offset:0}

/* ---------- type rhythm ---------- */
body{font-feature-settings:"ss01";-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
.metric .mn,.ring-pct,.cmp-v,.cap-n b,.tbl td,.disc-pct{font-variant-numeric:tabular-nums}
.sec-h{gap:14px;margin-bottom:14px}
.sec-h h2{letter-spacing:.2px}
.sec-h .ey{background:var(--accent-soft);border:1px solid var(--line-2);color:var(--accent-2);
  font-size:10.5px;font-weight:800;letter-spacing:1.6px;padding:5px 11px;border-radius:999px;min-width:0}
.sec-h .ln2{height:1px;background:var(--hairline);opacity:.5;border:none}
.block-label{letter-spacing:1.8px;color:var(--muted-2)}

/* ---------- elevation language (every card speaks it) ---------- */
.glass,.metric,.chart-card,.rcard,.lead-card,.res-card,.vid-card,.book,.msg-row,.mis-card,.stu-card,.teevo-card,.cal-day,.insight,.mlite,.rep-row{
  box-shadow:var(--elev-1);transition:transform .2s var(--ease),box-shadow .2s var(--ease),border-color .2s var(--ease)}
.glass{box-shadow:var(--elev-2);border-radius:var(--r-lg)}
.metric,.chart-card,.lead-card,.msg-row,.mis-card,.stu-card{border-radius:var(--r-md);position:relative;overflow:hidden}
.metric::before,.chart-card::before,.mis-card::before,.stu-card::before,.teevo-card::before{
  content:"";position:absolute;inset:0 0 auto 0;height:1px;background:var(--hairline);opacity:0;transition:opacity .25s var(--ease)}
.metric:hover,.lead-card:hover,.res-card:hover,.vid-card:hover,.book:hover,.mis-card:hover,.stu-card:hover{
  transform:translateY(-2px);box-shadow:var(--elev-2);border-color:var(--line-2)}
.metric:hover::before,.chart-card:hover::before,.mis-card:hover::before,.stu-card:hover::before,.teevo-card:hover::before{opacity:.8}
.msg-row:hover,.rep-row:hover,.mlite:hover{border-color:var(--line-2);box-shadow:var(--elev-1),0 0 0 1px var(--accent-soft)}
.rep-row{border-radius:var(--r-sm)}
.teevo-card{box-shadow:var(--elev-2)}

/* metric entrance — quiet stagger */
@keyframes rise{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}
.metrics .metric{animation:rise .45s var(--ease) both}
.metrics .metric:nth-child(2){animation-delay:.05s}.metrics .metric:nth-child(3){animation-delay:.1s}
.metrics .metric:nth-child(4){animation-delay:.15s}.metrics .metric:nth-child(5){animation-delay:.2s}
.metrics .metric:nth-child(6){animation-delay:.25s}
.module.active .sec{animation:rise .5s var(--ease) both}
.module.active .sec:nth-of-type(2){animation-delay:.06s}.module.active .sec:nth-of-type(3){animation-delay:.12s}

/* ---------- buttons: press feel + inner light ---------- */
.btn{transition:transform .15s var(--ease),box-shadow .2s var(--ease),background .2s var(--ease),border-color .2s var(--ease)}
.btn:active{transform:scale(.97)}
.btn-primary{box-shadow:inset 0 1px 0 rgba(255,255,255,.35),0 10px 26px -10px var(--accent-glow)}
.btn-primary:hover{transform:translateY(-1px);box-shadow:inset 0 1px 0 rgba(255,255,255,.4),0 14px 30px -10px var(--accent-glow);filter:saturate(1.08)}
.btn-ghost:hover{background:var(--accent-soft);border-color:var(--accent);color:var(--ink)}
.btn[disabled]{opacity:.45;pointer-events:none}
.fab{box-shadow:inset 0 1px 0 rgba(255,255,255,.35),0 18px 40px -12px var(--accent-glow);transition:transform .2s var(--ease),box-shadow .2s var(--ease)}
.fab:hover{transform:translateY(-3px) rotate(90deg)}

/* ---------- chrome: topbar + sidebar carry the hairline ---------- */
.topbar{backdrop-filter:blur(18px) saturate(1.3);-webkit-backdrop-filter:blur(18px) saturate(1.3);position:relative}
.topbar::after{content:"";position:absolute;left:0;right:0;bottom:-1px;height:1px;background:var(--hairline);opacity:.45}
.sidebar{background:linear-gradient(180deg,rgba(26,16,12,.92),rgba(16,10,8,.96))}
.brand{position:relative;padding-bottom:18px}
.brand::after{content:"";position:absolute;left:0;right:14px;bottom:0;height:1px;background:var(--hairline);opacity:.35}
.brand img{box-shadow:0 0 0 1px var(--line-2),0 0 24px -6px var(--accent-glow)}
.nav-item{position:relative;transition:background .18s var(--ease),color .18s var(--ease),padding-left .18s var(--ease)}
.nav-item::before{content:"";position:absolute;left:0;top:18%;bottom:18%;width:3px;border-radius:999px;
  background:var(--accent-grad);opacity:0;transform:scaleY(.3);transition:opacity .2s var(--ease),transform .25s var(--ease)}
.nav-item:hover{padding-left:18px}
.nav-item.active::before{opacity:1;transform:scaleY(1)}
.nav-item.active{box-shadow:inset 0 0 0 1px var(--line-2),inset 0 0 26px -14px var(--accent-glow)}
.navnum{box-shadow:0 4px 12px -3px var(--accent-glow)}
.leader-chip,.icon-btn,.switch-role,.search{transition:border-color .2s var(--ease),box-shadow .2s var(--ease)}
.leader-chip:hover,.icon-btn:hover,.switch-role:hover{box-shadow:0 0 0 1px var(--accent) inset}
.search:focus-within{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}

/* ---------- forms: one height, one focus language ---------- */
.field input,.field select,.sel-wrap select{min-height:44px;border-radius:var(--r-sm);
  transition:border-color .18s var(--ease),box-shadow .18s var(--ease),background .18s var(--ease)}
.field input:hover,.field select:hover,.sel-wrap select:hover,.notes-area:hover{border-color:var(--line-2)}
.field input:focus,.field select:focus,.sel-wrap select:focus,.notes-area:focus,.msg-reply input:focus{
  border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}
.field.err input,.field.err textarea{box-shadow:0 0 0 3px rgba(255,59,92,.15)}
input[type="color"]{cursor:pointer;padding:4px}
.rng{accent-color:var(--accent)}
.seg2 button,.tabbar button,.chipsel button{transition:background .16s var(--ease),color .16s var(--ease),border-color .16s var(--ease),transform .12s var(--ease)}
.seg2 button:active,.tabbar button:active,.chipsel button:active{transform:scale(.96)}
.tabbar button.on{box-shadow:inset 0 -2px 0 var(--accent)}

/* ---------- tables ---------- */
.tbl th{letter-spacing:1.6px;color:var(--muted-2);border-bottom:1px solid var(--line-2)}
.tbl tr{transition:background .15s var(--ease)}
.tbl tr:hover td{background:rgba(255,255,255,.025)}
.tbl td{border-color:var(--glass-border)}

/* ---------- modals: cinematic but quick ---------- */
.overlay{backdrop-filter:blur(16px) saturate(1.2);-webkit-backdrop-filter:blur(16px) saturate(1.2);background:rgba(10,5,3,.7)}
@keyframes modalIn{from{opacity:0;transform:translateY(14px) scale(.975)}to{opacity:1;transform:none}}
.overlay.show .modal{animation:modalIn .3s var(--ease)}
.modal{box-shadow:var(--elev-3);border-radius:20px}
.modal-h{position:relative}
.modal-h::after{content:"";position:absolute;left:18px;right:18px;bottom:0;height:1px;background:var(--hairline);opacity:.4}
.mhi{box-shadow:inset 0 1px 0 rgba(255,255,255,.3),0 8px 20px -8px var(--accent-glow)}
.mx{transition:transform .2s var(--ease),color .2s var(--ease)}
.mx:hover{transform:rotate(90deg);color:var(--ink)}

/* ---------- pills, badges, status language ---------- */
.stpill,.badge,.rolebadge,.squad-tag,.fschip,.wkbadge,.msg-kind,.ci-tag{letter-spacing:.5px}
.stpill{padding:4px 11px;border-radius:999px;font-weight:800}
.hpill{box-shadow:var(--elev-1)}
.squad-tag{box-shadow:0 4px 12px -4px rgba(0,0,0,.5),inset 0 1px 0 rgba(255,255,255,.25)}

/* ---------- specifics ---------- */
.teevo-card{border-radius:var(--r-lg);background:linear-gradient(135deg,rgba(255,122,0,.14),rgba(255,46,77,.06) 60%,rgba(255,196,0,.05))}
.cal-day{transition:border-color .18s var(--ease),box-shadow .18s var(--ease)}
.cal-day:hover{border-color:var(--line-2)}
.cal-day.today{box-shadow:inset 0 0 0 1px var(--accent),0 0 22px -8px var(--accent-glow)}
.cal-ev{box-shadow:inset 0 1px 0 rgba(255,255,255,.22)}
.drop{box-shadow:var(--elev-3);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px)}
.notif{transition:background .15s var(--ease)}
.notif:hover{background:rgba(255,255,255,.04)}
.toast{box-shadow:var(--elev-2);border-radius:var(--r-md)}
.empty{display:flex;align-items:center;justify-content:center;gap:10px;min-height:72px;border-style:dashed;border-radius:var(--r-md);letter-spacing:.2px}
.rhead{transition:background .18s var(--ease)}
.rhead:hover{background:rgba(255,255,255,.03)}
.rcard.open{box-shadow:var(--elev-2),0 0 0 1px var(--line-2)}
.dtask{transition:transform .15s var(--ease),background .2s var(--ease),border-color .2s var(--ease)}
.dtask:hover{transform:translateY(-1px)}
.dtask.done{box-shadow:inset 0 0 18px -10px var(--accent-glow)}
.factor .fbar i,.cmp-bar i,.disc-bar i,.cap-bar i{transition:width .7s var(--ease)}
.ring-fill{transition:stroke-dashoffset 1s var(--ease)}
.insight{border-radius:var(--r-md)}
.scope-note{border-radius:var(--r-md);backdrop-filter:blur(8px)}
.login-card{box-shadow:var(--elev-3);position:relative;border-radius:20px}
.login-card::before{content:"";position:absolute;inset:0 0 auto 0;height:1px;background:var(--hairline);opacity:.7;border-radius:20px 20px 0 0}
.login-brand img{box-shadow:none}
.demo-box span{transition:border-color .18s var(--ease),color .18s var(--ease);cursor:default}
.demo-box span:hover{border-color:var(--accent);color:var(--ink)}
.lead-card .la,.r-av,.ma{box-shadow:inset 0 1px 0 rgba(255,255,255,.3),0 6px 16px -6px rgba(0,0,0,.6)}

/* ---------- quality floor ---------- */
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.01ms !important;animation-iteration-count:1 !important;transition-duration:.01ms !important}
}
@media (max-width:760px){
  .metrics .metric,.module.active .sec{animation:none}
  .nav-item:hover{padding-left:16px}
}

/* ════════════════════════════════════════════════════════════════════
   V3.2 MODERNIZATION — Inter system, calmer surface, SaaS density
   ════════════════════════════════════════════════════════════════════ */
:root{
  --display:'Inter',system-ui,sans-serif; --body:'Inter',system-ui,sans-serif;
  --accent:#f08a1d; --accent-2:#f6b450;
  --accent-grad:linear-gradient(135deg,#e85d11 0%,#f08a1d 55%,#f6b450 100%);
  --fire-grad:linear-gradient(135deg,#e85d11,#f08a1d 55%,#f6b450);
  --accent-soft:rgba(240,138,29,.12); --accent-glow:rgba(240,138,29,.25);
  --ink:#f5efe9; --ink-dim:#d9cfc6; --muted:#9c8d81; --muted-2:#6f6258;
}
body{font-family:var(--body)}
h1,h2,h3,.tb-title,.mn,.mis-name,.ring-pct,.login-title,.mht,.bk-ct,.cap-n{font-family:var(--display)!important;letter-spacing:-.3px!important}
.sec-h h2{font-size:17px;font-weight:800;text-transform:none;letter-spacing:-.2px!important}
.tb-title{font-size:19px;font-weight:800}
.metric .mn{font-size:26px;font-weight:800}
.ring-pct{font-size:34px;font-weight:800}
.mis-name,.msg-sub{font-size:15px;font-weight:700;letter-spacing:-.2px}
.login-title{font-weight:900}
.login-title em{font-style:normal}
.mht{font-size:16px;font-weight:800}
.bt,.bs{display:none}
/* calmer surface: blur −40%, glow −50%, contrast + */
.topbar{backdrop-filter:blur(11px) saturate(1.15);-webkit-backdrop-filter:blur(11px) saturate(1.15)}
.overlay{backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);background:rgba(10,6,4,.72)}
.drop{backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px)}
.bg-orb{filter:blur(55px);opacity:.42}
.glass.glow{box-shadow:var(--elev-2)}
.btn-primary{box-shadow:inset 0 1px 0 rgba(255,255,255,.28),0 8px 20px -10px var(--accent-glow)}
.btn-primary:hover{box-shadow:inset 0 1px 0 rgba(255,255,255,.32),0 10px 24px -10px var(--accent-glow)}
/* density + whitespace */
.content{padding:30px 34px 56px;max-width:1460px}
.sec{margin-bottom:34px}
.metrics{gap:14px}
@media(max-width:760px){.content{padding:20px 16px 46px}}
/* ---------- sidebar 2.0: logo-only home, sections, collapse ---------- */
.brand-btn{background:none;border:none;cursor:pointer;display:flex;justify-content:center;padding:6px 4px 16px;width:100%;transition:transform .2s var(--ease),filter .2s var(--ease)}
.brand-btn img{width:120px;height:auto;border-radius:0;box-shadow:none;background:none;filter:drop-shadow(0 6px 18px var(--accent-glow))}
.brand-btn:hover{transform:scale(1.05)}
.brand-btn:hover img{filter:drop-shadow(0 8px 24px rgba(240,138,29,.45))}
.brand::after{right:6px;left:6px}
.nav-sec{margin:16px 4px 6px;font-size:9.5px;line-height:1.7;letter-spacing:2px;color:var(--muted-2);font-weight:800;text-transform:uppercase;white-space:nowrap;overflow:visible;padding-top:2px}
.nav-item{font-size:13px;white-space:nowrap}
.sb-toggle{margin:10px 12px 4px;background:var(--surface);border:1px solid var(--line);color:var(--muted);border-radius:10px;height:34px;cursor:pointer;font-size:11px;transition:.18s var(--ease)}
.sb-toggle:hover{color:var(--ink);border-color:var(--accent)}
body.sb-min .sidebar{width:78px}
body.sb-min .nav-sec{height:1px;background:var(--glass-border);margin:12px 10px;overflow:hidden;color:transparent}
body.sb-min .nav-item{padding-left:0;justify-content:center}
body.sb-min .nav-item .nlbl,body.sb-min .nav-foot{display:none}
body.sb-min .brand-btn img{width:46px}
body.sb-min .sb-toggle{margin:10px 14px}
.nav-item .ni{width:20px;text-align:center;flex-shrink:0}
/* ---------- breadcrumbs ---------- */
.crumbs{display:flex;align-items:center;gap:7px;padding:11px 34px 0;font-size:12px;color:var(--muted-2);flex-wrap:wrap}
.crumbs:empty{display:none}
.crumbs button{background:none;border:none;color:var(--muted);font:inherit;cursor:pointer;padding:2px 4px;border-radius:6px}
.crumbs button:hover{color:var(--accent-2)}
.crumbs .sep{opacity:.5}
.crumbs .cur{color:var(--ink);font-weight:700}
@media(max-width:760px){.crumbs{padding:10px 16px 0}}
/* ---------- clickable metrics ---------- */
.metric.clk{cursor:pointer}
.metric.clk::after{content:"View details →";position:absolute;right:14px;bottom:11px;font-size:10.5px;font-weight:700;color:var(--accent-2);opacity:0;transform:translateX(-4px);transition:.2s var(--ease)}
.metric.clk:hover::after{opacity:1;transform:none}
.metric.clk:hover{border-color:var(--accent)}
/* ---------- attention panel + activity ---------- */
.attn{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:12px;margin-bottom:22px}
.attn-card{display:flex;align-items:center;gap:12px;background:var(--surface-2);border:1px solid var(--line-2);border-radius:var(--r-md);padding:14px 16px;cursor:pointer;box-shadow:var(--elev-1);transition:.2s var(--ease)}
.attn-card:hover{transform:translateY(-2px);border-color:var(--accent)}
.attn-n{font-family:var(--display);font-size:24px;font-weight:800;min-width:34px}
.attn-l{font-size:11.5px;color:var(--muted);font-weight:600;line-height:1.35}
.greet{font-family:var(--display);font-size:clamp(20px,3vw,27px);font-weight:800;letter-spacing:-.4px;margin-bottom:4px}
.greet-sub{font-size:12.5px;color:var(--muted);margin-bottom:20px}
.feed{display:flex;flex-direction:column;gap:9px}
.feed-row{display:flex;gap:11px;align-items:flex-start;background:var(--surface-2);border:1px solid var(--glass-border);border-radius:var(--r-sm);padding:11px 13px;font-size:12.5px;color:var(--ink-dim);cursor:pointer;transition:.15s var(--ease)}
.feed-row:hover{border-color:var(--line-2);background:rgba(255,255,255,.03)}
.feed-row .ft{flex-shrink:0}.feed-row .fm{font-size:10.5px;color:var(--muted-2);margin-top:2px}
/* ---------- command palette ---------- */
.overlay.pal{align-items:flex-start;padding-top:12vh}
.palette{width:min(620px,94vw);background:linear-gradient(180deg,rgba(32,22,16,.99),rgba(20,13,10,.99));border:1px solid var(--line-2);border-radius:18px;box-shadow:var(--elev-3);overflow:hidden}
.pal-top{display:flex;align-items:center;gap:11px;padding:15px 17px;border-bottom:1px solid var(--glass-border)}
.pal-top input{flex:1;background:none;border:none;color:var(--ink);font:inherit;font-size:15px;outline:none}
.pal-top kbd,.pal-hint kbd{background:var(--surface);border:1px solid var(--line);border-radius:6px;padding:2px 7px;font-size:10.5px;color:var(--muted)}
.pal-res{max-height:52vh;overflow-y:auto;padding:8px}
.pal-hint{padding:22px;text-align:center;font-size:12px;color:var(--muted-2)}
.pal-res .sr{border-radius:9px}
/* ---------- entity links ---------- */
.lnk{background:none;border:none;color:var(--ink);font:inherit;font-weight:700;cursor:pointer;padding:0;border-bottom:1px dashed transparent}
.lnk:hover{color:var(--accent-2);border-bottom-color:var(--accent-2)}
.squad-tag{cursor:pointer}
.squad-tag:hover{filter:brightness(1.15)}
/* ---------- profile pages ---------- */
.ptabs{display:flex;gap:6px;flex-wrap:wrap;border-bottom:1px solid var(--glass-border);margin-bottom:20px}
.ptabs button{background:none;border:none;color:var(--muted);font:inherit;font-size:12.5px;font-weight:700;padding:10px 14px;cursor:pointer;border-bottom:2px solid transparent;transition:.16s var(--ease)}
.ptabs button.on{color:var(--ink);border-bottom-color:var(--accent)}
.phead{display:flex;align-items:center;gap:16px;margin-bottom:18px;flex-wrap:wrap}
.phead .pav{width:58px;height:58px;border-radius:16px;display:grid;place-items:center;font-family:var(--display);font-weight:800;font-size:21px;color:#fff;box-shadow:var(--elev-1)}
.phead h1{font-size:clamp(20px,3vw,26px);font-weight:800;letter-spacing:-.4px;margin:0}
.pmeta{font-size:12px;color:var(--muted);margin-top:3px}
.attbars{display:flex;align-items:flex-end;gap:5px;height:90px;padding:8px 2px}
.attbars i{flex:1;background:var(--accent-grad);border-radius:5px 5px 2px 2px;min-height:4px;opacity:.85}
.tline{position:relative;padding-left:18px}
.tline::before{content:"";position:absolute;left:5px;top:6px;bottom:6px;width:2px;background:var(--glass-border)}
.tline .ti2{position:relative;padding:7px 0 7px 8px;font-size:12.5px;color:var(--ink-dim)}
.tline .ti2::before{content:"";position:absolute;left:-17px;top:13px;width:8px;height:8px;border-radius:50%;background:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}
.tline .tm2{font-size:10.5px;color:var(--muted-2)}
/* ---------- chat ---------- */
.chat{display:grid;grid-template-columns:300px 1fr;gap:0;background:var(--surface);border:1px solid var(--glass-border);border-radius:var(--r-lg);overflow:hidden;min-height:60vh;box-shadow:var(--elev-2)}
.chat-list{border-right:1px solid var(--glass-border);overflow-y:auto;max-height:72vh}
.chat-li{display:flex;gap:11px;align-items:center;width:100%;text-align:left;background:none;border:none;border-bottom:1px solid var(--glass-border);padding:13px 14px;cursor:pointer;color:var(--ink);font:inherit;transition:background .15s var(--ease)}
.chat-li:hover{background:rgba(255,255,255,.03)}
.chat-li.on{background:var(--accent-soft)}
.chat-li .ca{width:38px;height:38px;border-radius:12px;display:grid;place-items:center;font-weight:800;color:#fff;flex-shrink:0;font-size:13px}
.chat-li .cn{font-size:13px;font-weight:700}
.chat-li .cl{font-size:11px;color:var(--muted-2);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:160px}
.chat-li .ct{margin-left:auto;text-align:right;font-size:10px;color:var(--muted-2);flex-shrink:0}
.chat-li .cu{display:inline-grid;place-items:center;min-width:17px;height:17px;border-radius:999px;background:var(--accent-grad);color:#1a0d04;font-size:9.5px;font-weight:800;margin-top:3px}
.chat-main{display:flex;flex-direction:column;max-height:72vh}
.chat-h{display:flex;align-items:center;gap:11px;padding:13px 16px;border-bottom:1px solid var(--glass-border)}
.chat-msgs{flex:1;overflow-y:auto;padding:18px 16px;display:flex;flex-direction:column;gap:9px}
.bub{max-width:72%;padding:9px 13px;border-radius:14px;font-size:13px;line-height:1.5;box-shadow:var(--elev-1)}
.bub.me{align-self:flex-end;background:var(--accent-grad);color:#1d1006;border-bottom-right-radius:4px;font-weight:500}
.bub.them{align-self:flex-start;background:var(--surface-2);border:1px solid var(--glass-border);color:var(--ink-dim);border-bottom-left-radius:4px}
.bub .bm{display:block;font-size:9.5px;opacity:.65;margin-top:4px;text-align:right}
.chat-in{display:flex;gap:9px;padding:12px 14px;border-top:1px solid var(--glass-border)}
.chat-in input{flex:1;background:var(--surface-2);border:1px solid var(--line);border-radius:999px;color:var(--ink);font:inherit;font-size:13px;padding:11px 17px}
.chat-empty{display:grid;place-items:center;color:var(--muted-2);font-size:13px;min-height:300px}
.chat-back{display:none}
@media(max-width:860px){
  .chat{grid-template-columns:1fr;min-height:70vh}
  .chat-list{display:block}.chat-main{display:none}
  .chat.open .chat-list{display:none}.chat.open .chat-main{display:flex;max-height:none}
  .chat-back{display:inline-flex}
}
/* ---------- feed / testimony cards ---------- */
.tcard{background:var(--surface-2);border:1px solid var(--glass-border);border-radius:var(--r-lg);padding:18px 20px;margin-bottom:14px;box-shadow:var(--elev-1)}
.tcard.feat{border-color:var(--accent);box-shadow:var(--elev-1),0 0 0 1px var(--accent-soft)}
.tcard .tt2{font-size:16px;font-weight:800;letter-spacing:-.2px}
.tcard .tb2{font-size:13px;color:var(--ink-dim);line-height:1.65;margin-top:9px;white-space:pre-wrap}
.react{display:flex;gap:8px;margin-top:13px;flex-wrap:wrap}
.react button{background:var(--surface);border:1px solid var(--line);border-radius:999px;color:var(--muted);font:inherit;font-size:12px;font-weight:700;padding:6px 13px;cursor:pointer;transition:.16s var(--ease)}
.react button:hover,.react button.on{border-color:var(--accent);color:var(--ink);background:var(--accent-soft)}
.cmt{font-size:12.5px;color:var(--ink-dim);padding:8px 0 0 12px;border-left:2px solid var(--glass-border);margin-top:8px}
/* ---------- order of service ---------- */
.seg-row{display:grid;grid-template-columns:1.3fr 84px 1.2fr;gap:8px;margin-bottom:8px;align-items:start}
.seg-row input,.seg-row select{min-height:40px}
.seg-sub{grid-column:1/-1;display:grid;grid-template-columns:1fr auto auto;gap:8px}
.seg-del{background:none;border:1px solid var(--line);color:var(--muted);border-radius:9px;width:40px;cursor:pointer}
.seg-del:hover{color:var(--bad);border-color:var(--bad)}
.oos td{padding:10px 12px}
/* week / agenda views */
.cal-week{display:grid;grid-template-columns:repeat(7,1fr);gap:8px}
.cal-week .cal-day{min-height:150px}
.agenda .ag-d{font-size:11px;letter-spacing:1.4px;text-transform:uppercase;color:var(--accent-2);font-weight:800;margin:14px 0 7px}

/* V3.2 sidebar layout fix: scrollable nav, pinned toggle */
.nav{flex:1 1 auto;overflow-y:auto;min-height:0;margin-top:4px}
.sb-toggle{flex-shrink:0;order:99}
.nav-foot{flex-shrink:0;order:100}
.sidebar{padding-bottom:12px}

/* ════════ V3.2.2 design-error fixes ════════ */
/* 1. Tables must scroll WITHIN their wrapper, never stretch the page */
.tbl-wrap{overflow-x:auto;max-width:100%;-webkit-overflow-scrolling:touch}
.glass.pad{min-width:0}
.sec,.module,.content{min-width:0}
/* 2. Background orbs must never create horizontal scroll on small screens */
@media(max-width:760px){
  .bg-orb.o1{width:300px;height:300px;left:-90px;top:-60px}
  .bg-orb.o2{width:260px;height:260px;right:-120px;top:25%}
  .bg-orb.o3{width:320px;height:320px;left:auto;right:-140px;bottom:-160px}
}
/* hard stop: nothing scrolls the page sideways */
/* overflow-x removed from html — it broke position:sticky on the sidebar. Horizontal scroll is contained at the .app/.main level instead. */
html{max-width:100%}

/* ════════ V3.2.2 overflow fix (definitive) ════════ */
/* The off-canvas sidebar is position:fixed and escapes body overflow containment.
   Orbs are decoration — keep them strictly within the viewport on phones. */
@media(max-width:760px){
  .bg-orb.o1{width:240px;height:240px;left:-60px;top:-40px;right:auto}
  .bg-orb.o2{width:200px;height:200px;left:auto;right:-60px;top:22%}
  .bg-orb.o3{width:240px;height:240px;left:auto;right:-70px;bottom:-120px}
  /* sidebar drawer fully off-screen, no sliver of scroll */
  .sidebar{transform:translateX(-100%);transition:transform .28s cubic-bezier(.2,.8,.2,1)}
  .sidebar.open{transform:translateX(0)}
}

/* ════════ V3.2.2 table overflow — definitive ════════ */
/* A scroll container that is a flex/grid child needs min-width:0 or it expands to content. */
.tbl-wrap{min-width:0;width:100%;display:block;overflow-x:auto}
.glass,.glass.pad,.sec{min-width:0}
/* Reduce the table min-width on phones so most fit without scroll; if not, the wrap scrolls. */
@media(max-width:520px){ .tbl{min-width:440px} .tbl th,.tbl td{padding:8px 9px;font-size:12px} }

/* ════════ V3.2.2 table scroll — hard boundary ════════ */
.tbl-wrap{display:block;width:100%;max-width:100%;overflow-x:auto;contain:inline-size}

/* ════════ V3.2.2 accessibility fixes ════════ */
/* 1. Sidebar section labels — lift from 3.0:1 to ~4.7:1 (WCAG AA) */
.nav-sec{color:#9a8a7d}
/* 2. Visible keyboard focus for all interactive elements (was missing entirely) */
:focus-visible{outline:2px solid var(--accent);outline-offset:2px;border-radius:6px}
button:focus-visible,.btn:focus-visible,.nav-item:focus-visible,
input:focus-visible,select:focus-visible,textarea:focus-visible,
[data-nav]:focus-visible,[data-ptab]:focus-visible,[tabindex]:focus-visible{
  outline:2px solid var(--accent);outline-offset:2px}
/* inputs already have a focus border; make it stronger & consistent */
input:focus,select:focus,textarea:focus{border-color:var(--accent)}

/* ════════ Dynamic FAB: icon + hover tooltip ════════ */
.fab .fab-ic{display:grid;place-items:center;font-size:24px;line-height:1;transition:transform .25s var(--ease)}
.fab:hover .fab-ic{transform:rotate(90deg)}
.fab:hover{transform:translateY(-3px)}              /* rotate moved to icon so the tooltip stays upright */
.fab::after{content:attr(data-tip);position:absolute;right:72px;top:50%;transform:translateY(-50%) translateX(6px);
  background:rgba(20,13,10,.97);color:var(--ink);font-size:12.5px;font-weight:600;white-space:nowrap;
  padding:8px 12px;border-radius:10px;border:1px solid var(--line-2);box-shadow:0 10px 30px -8px #000;
  opacity:0;pointer-events:none;transition:opacity .18s,transform .18s}
.fab:hover::after{opacity:1;transform:translateY(-50%) translateX(0)}
@media(max-width:760px){ .fab::after{display:none} }   /* no hover tooltips on touch */

/* ════════ "My Week" action hub ════════ */
.myweek{background:linear-gradient(180deg,rgba(240,138,29,.07),rgba(20,13,10,.4));border:1px solid var(--line-2);
  border-radius:var(--r-xl);padding:18px 18px 14px;margin-bottom:22px;backdrop-filter:blur(14px)}
.mw-head{display:flex;align-items:center;gap:10px;margin-bottom:13px}
.mw-title{font-family:var(--display);font-size:16px;font-weight:800;letter-spacing:.3px;flex:1}
.mw-count{background:var(--accent);color:#1a0f06;font-size:12px;font-weight:800;min-width:24px;height:24px;
  border-radius:999px;display:grid;place-items:center;padding:0 7px}
.mw-list{display:flex;flex-direction:column;gap:8px}
.mw-row{display:flex;align-items:center;gap:13px;padding:12px 13px;background:var(--surface);border:1px solid var(--glass-border);
  border-radius:var(--r-lg);transition:border-color .18s,transform .18s}
.mw-row:hover{border-color:var(--line-2);transform:translateX(2px)}
.mw-ic{font-size:19px;width:34px;height:34px;display:grid;place-items:center;background:var(--accent-soft);border-radius:10px;flex-shrink:0}
.mw-body{flex:1;min-width:0}
.mw-tag{font-size:10px;letter-spacing:1px;text-transform:uppercase;color:var(--accent-2);font-weight:700;margin-bottom:2px}
.mw-text{font-size:13.5px;font-weight:600;color:var(--ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.mw-sub{font-size:11.5px;color:var(--muted);margin-top:1px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.mw-acts{display:flex;gap:7px;flex-shrink:0}
.mw-more{font-size:11.5px;color:var(--muted-2);text-align:center;padding:10px 0 2px;font-style:italic}
.myweek-clear{display:flex;align-items:center;gap:14px;background:linear-gradient(180deg,rgba(34,197,94,.08),rgba(20,13,10,.3));
  border:1px solid rgba(34,197,94,.25);border-radius:var(--r-xl);padding:18px 20px;margin-bottom:22px}
.mwc-ic{font-size:30px}
.mwc-sub{font-size:12.5px;color:var(--muted);margin-top:2px}
@media(max-width:600px){
  .mw-row{flex-wrap:wrap;gap:9px}
  .mw-acts{width:100%;justify-content:flex-end}
  .mw-ic{order:0} .mw-body{order:1;flex:1} .mw-acts{order:2}
}

/* ════════ Batch attendance register ════════ */
.reg-batch{display:flex;align-items:center;gap:7px;padding-bottom:11px;margin-bottom:8px;border-bottom:1px solid var(--glass-border);flex-wrap:wrap}
.reg-batch-l{font-size:12px;color:var(--accent-2);font-weight:700}
.reg-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:2px 16px;max-height:280px;overflow-y:auto;padding-right:4px}
.reg-item{display:flex;align-items:center;gap:9px;padding:7px 8px;border-radius:9px;font-size:13px;cursor:pointer;transition:background .15s}
.reg-item:hover{background:var(--surface-2)}
.reg-item input{flex-shrink:0;width:16px;height:16px;accent-color:var(--accent)}
.reg-name{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}

/* draft-restored notice */
.draft-restored{background:var(--accent-soft);border:1px solid var(--line-2);color:var(--accent-2);
  font-size:12px;font-weight:600;padding:8px 12px;border-radius:9px;margin-bottom:14px}

/* ════════ Unified People view: leader/role chips ════════ */
.people-count{font-size:12.5px;color:var(--muted);font-weight:600;align-self:center}
.leader-tag{display:inline-block;font-size:9.5px;font-weight:800;letter-spacing:.6px;text-transform:uppercase;
  background:var(--accent-soft);color:var(--accent-2);padding:2px 7px;border-radius:999px;border:1px solid var(--line-2);vertical-align:middle;margin-left:3px}
.role-chip{display:inline-block;font-size:11px;font-weight:700;color:var(--muted);background:var(--surface-2);
  padding:4px 10px;border-radius:999px;border:1px solid var(--glass-border);white-space:nowrap}

/* small hint under a form field */
.field-hint{font-size:11px;color:var(--muted);margin-top:5px}

/* ════════ Unified People view (admin) ════════ */
.people-filter{display:flex;gap:12px;align-items:center;margin-bottom:16px;flex-wrap:wrap}
.people-filter #peopleSearch{flex:1;min-width:200px;background:var(--surface);border:1px solid var(--line-2);
  color:var(--ink);padding:10px 14px;border-radius:11px;font-size:13.5px;font-family:inherit}
.people-filter #peopleSearch:focus{outline:2px solid var(--accent);outline-offset:1px;border-color:var(--accent)}
.seg{display:inline-flex;background:var(--surface);border:1px solid var(--glass-border);border-radius:11px;padding:3px;gap:2px}
.seg-b{background:transparent;border:0;color:var(--muted);font-size:12.5px;font-weight:600;padding:7px 14px;border-radius:8px;cursor:pointer;transition:all .15s;font-family:inherit}
.seg-b:hover{color:var(--ink)}
.seg-b.active{background:var(--accent);color:#1a0f06}
.role-badge{font-size:10.5px;letter-spacing:.4px;text-transform:uppercase;font-weight:700;color:var(--accent-2);
  background:var(--accent-soft);border:1px solid var(--line-2);padding:4px 10px;border-radius:999px;white-space:nowrap}
.person-row[data-pkind="leader"] .ma{box-shadow:0 0 0 2px var(--accent-soft)}

/* ════════════════ FINANCES (V3.5 Phase 1) ════════════════ */
.fin-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:16px;margin-bottom:20px}
.fin-stat{background:linear-gradient(180deg,rgba(240,138,29,.08),rgba(20,13,10,.4));border:1px solid var(--line-2);border-radius:var(--r-xl);padding:18px;backdrop-filter:blur(14px)}
.fin-stat-h{display:flex;align-items:center;gap:10px;margin-bottom:14px}
.fin-stat-ic{font-size:22px;width:40px;height:40px;display:grid;place-items:center;background:var(--accent-soft);border-radius:11px}
.fin-stat-t{font-family:var(--display);font-size:15px;font-weight:800;letter-spacing:.2px}
.fin-stat-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.fin-stat-cell{background:var(--surface);border:1px solid var(--glass-border);border-radius:var(--r-lg);padding:11px 12px}
.fsc-l{font-size:10.5px;letter-spacing:.6px;text-transform:uppercase;color:var(--muted);font-weight:700;margin-bottom:3px}
.fsc-v{font-size:18px;font-weight:800;color:var(--ink);font-family:var(--display)}
.fin-cols{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:16px}
@media(max-width:760px){.fin-cols{grid-template-columns:1fr}}
.fin-panel{min-width:0}
.fin-panel-h{font-family:var(--display);font-size:14px;font-weight:800;letter-spacing:.2px;margin-bottom:12px;color:var(--ink)}
.fin-empty-chart,.fin-empty-list{font-size:12.5px;color:var(--muted);padding:20px;text-align:center;background:var(--surface);border-radius:var(--r-lg);border:1px dashed var(--glass-border)}
.fin-buildnote{margin-top:18px;font-size:12.5px;color:var(--muted);background:var(--accent-soft);border:1px solid var(--line-2);border-radius:var(--r-lg);padding:14px 16px;line-height:1.6}
.fin-buildnote b{color:var(--accent-2)}
.fin-stub{text-align:center;padding:60px 24px;background:var(--surface);border:1px dashed var(--line-2);border-radius:var(--r-xl)}
.fin-stub-ic{font-size:46px;margin-bottom:14px}
.fin-stub-t{font-family:var(--display);font-size:22px;font-weight:800;margin-bottom:10px}
.fin-stub-d{font-size:13.5px;color:var(--muted);max-width:520px;margin:0 auto 16px;line-height:1.6}
.fin-stub-tag{display:inline-block;font-size:11px;letter-spacing:.6px;text-transform:uppercase;font-weight:700;color:var(--accent-2);background:var(--accent-soft);border:1px solid var(--line-2);padding:6px 14px;border-radius:999px}

/* ════════ Finance Phase 2: bars, recent activity, loading ════════ */
.fin-loading{padding:40px;text-align:center;color:var(--muted);font-size:13px}
.fin-bars{display:flex;flex-direction:column;gap:10px}
.fin-bar-row{display:grid;grid-template-columns:110px 1fr auto;align-items:center;gap:12px}
.fbr-l{font-size:12.5px;color:var(--ink);font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.fbr-track{height:10px;background:var(--surface-2);border-radius:999px;overflow:hidden}
.fbr-fill{height:100%;background:linear-gradient(90deg,#ff3d00,#ff7a00,#ffb200);border-radius:999px;transition:width .5s var(--ease)}
.fbr-v{font-size:12.5px;font-weight:700;color:var(--accent-2);white-space:nowrap;text-align:right;min-width:70px}
.fin-recent{display:flex;flex-direction:column;gap:4px}
.fin-recent-row{display:flex;align-items:center;gap:11px;padding:9px 6px;border-bottom:1px solid var(--glass-border)}
.fin-recent-row:last-child{border-bottom:0}
.frr-ic{font-size:17px;width:30px;height:30px;display:grid;place-items:center;background:var(--accent-soft);border-radius:9px;flex-shrink:0}
.frr-body{flex:1;min-width:0}
.frr-name{font-size:13px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.frr-sub{font-size:11px;color:var(--muted);margin-top:1px}
.frr-amt{font-size:13.5px;font-weight:800;color:#22c55e;white-space:nowrap}
.frr-amt.neg{color:#ef4444}

/* ════════ Finance Phase 3: deletion governance ════════ */
.badge.b-pend{background:rgba(245,158,11,.15);color:#f59e0b;border:1px solid rgba(245,158,11,.3)}
.delreq-rec{background:var(--surface);border:1px solid var(--line-2);border-radius:var(--r-lg);padding:12px 14px;margin-bottom:14px}
.dr-rec-l{font-size:10.5px;letter-spacing:.6px;text-transform:uppercase;color:var(--muted);font-weight:700;margin-bottom:3px}
.dr-rec-v{font-size:14px;font-weight:700;color:var(--ink)}
.delreq-note{font-size:11.5px;color:var(--muted);margin-top:12px;font-style:italic}
.del-list{display:flex;flex-direction:column;gap:10px}
.del-card{display:flex;align-items:center;gap:14px;background:var(--surface);border:1px solid var(--line-2);border-radius:var(--r-lg);padding:14px 16px}
.del-card-main{flex:1;min-width:0}
.del-sum{font-size:14px;font-weight:700;color:var(--ink);margin-bottom:4px}
.del-meta{font-size:11.5px;color:var(--muted);margin-top:1px}
.del-acts{display:flex;gap:8px;flex-shrink:0}
.fin-pending-banner{display:flex;align-items:center;gap:12px;background:linear-gradient(180deg,rgba(245,158,11,.12),rgba(20,13,10,.3));border:1px solid rgba(245,158,11,.35);border-radius:var(--r-lg);padding:13px 16px;margin-bottom:18px;cursor:pointer;font-size:13px;transition:border-color .18s}
.fin-pending-banner:hover{border-color:rgba(245,158,11,.6)}
.fpb-ic{font-size:18px}
.fpb-go{margin-left:auto;color:var(--accent-2);font-weight:700;font-size:12.5px}

/* ════════ Finance Phase 3.5: POP links + audit log ════════ */
.pop-link{background:var(--accent-soft);border:1px solid var(--line-2);color:var(--accent-2);font-size:11px;font-weight:700;padding:4px 9px;border-radius:7px;cursor:pointer;font-family:inherit;transition:all .15s}
.pop-link:hover{background:var(--accent);color:#1a0f06}
.audit-feed{display:flex;flex-direction:column;gap:2px}
.audit-row{display:flex;align-items:flex-start;gap:11px;padding:11px 6px;border-bottom:1px solid var(--glass-border)}
.audit-row:last-child{border-bottom:0}
.audit-ic{font-size:16px;width:30px;height:30px;display:grid;place-items:center;background:var(--surface-2);border-radius:8px;flex-shrink:0;margin-top:1px}
.audit-body{flex:1;min-width:0}
.audit-act{font-size:13px;font-weight:700;color:var(--ink)}
.audit-detail{font-weight:400;color:var(--muted);margin-left:8px;font-size:12px}
.audit-meta{font-size:11px;color:var(--muted-2);margin-top:2px}

/* ════════ Finance Phase 4: net position ════════ */
.fin-net{display:flex;align-items:stretch;gap:10px;background:linear-gradient(180deg,rgba(240,138,29,.06),rgba(20,13,10,.35));border:1px solid var(--line-2);border-radius:var(--r-xl);padding:16px;margin-bottom:20px;flex-wrap:wrap}
.fin-net-cell{flex:1;min-width:130px;background:var(--surface);border:1px solid var(--glass-border);border-radius:var(--r-lg);padding:12px 14px;text-align:center}
.fnc-l{font-size:10.5px;letter-spacing:.6px;text-transform:uppercase;color:var(--muted);font-weight:700;margin-bottom:5px}
.fnc-v{font-size:20px;font-weight:800;font-family:var(--display)}
.fnc-v.pos{color:#22c55e}
.fnc-v.neg{color:#ef4444}
.fin-net-op{display:grid;place-items:center;font-size:22px;color:var(--muted);font-weight:700}
@media(max-width:640px){.fin-net-op{display:none}.fin-net-cell{min-width:calc(50% - 8px)}}

/* ════════ Finance Phase 5: contributor cards ════════ */
.fin-mem-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:12px;margin-bottom:18px}
.fmc{background:var(--surface);border:1px solid var(--line-2);border-radius:var(--r-lg);padding:14px 16px}
.fmc-l{font-size:10.5px;letter-spacing:.5px;text-transform:uppercase;color:var(--muted);font-weight:700;margin-bottom:6px}
.fmc-v{font-size:21px;font-weight:800;font-family:var(--display);color:var(--ink)}
.finmem-row:hover{background:var(--surface-2)}

/* ════════ Finance Phase 5: analytics rankings + filters ════════ */
.rank-sub{font-weight:400;color:var(--muted);font-size:11px;margin-left:8px}
.rank-list{display:flex;flex-direction:column;gap:2px}
.rank-row{display:flex;align-items:center;gap:11px;padding:9px 6px;border-bottom:1px solid var(--glass-border)}
.rank-row:last-child{border-bottom:0}
.rank-row:hover{background:var(--surface-2)}
.rank-n{width:24px;height:24px;display:grid;place-items:center;background:var(--accent-soft);color:var(--accent-2);border-radius:7px;font-size:12px;font-weight:800;flex-shrink:0}
.rank-name{flex:1;min-width:0;font-size:13.5px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.rank-sq{font-weight:400;color:var(--muted);font-size:11px;margin-left:7px}
.rank-val{font-size:13.5px;font-weight:800;color:var(--accent-2);white-space:nowrap}
.fin-filter-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:12px;margin-bottom:6px}
.fin-filter-grid .field label{font-size:10.5px;letter-spacing:.4px;text-transform:uppercase;color:var(--muted);font-weight:700}
.fin-filter-grid select,.fin-filter-grid input{background:var(--surface);border:1px solid var(--line-2);color:var(--ink);padding:8px 10px;border-radius:9px;font-size:13px;font-family:inherit;width:100%}

/* ════════ Finance Phase 5: categories management ════════ */
.cat-list{display:flex;flex-direction:column;gap:6px}
.cat-row{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:9px 12px;background:var(--surface);border:1px solid var(--glass-border);border-radius:9px}
.cat-row.archived{opacity:.6}
.cat-name{font-size:13px;font-weight:600}

/* ════════ Finance Phase 6: report cards ════════ */
.report-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:14px}
.report-card{background:var(--surface);border:1px solid var(--line-2);border-radius:var(--r-xl);padding:18px;display:flex;flex-direction:column;gap:14px}
.rc-top{display:flex;align-items:flex-start;gap:12px}
.rc-ic{font-size:26px;width:46px;height:46px;display:grid;place-items:center;background:var(--accent-soft);border-radius:12px;flex-shrink:0}
.rc-title{font-family:var(--display);font-size:15px;font-weight:800}
.rc-desc{font-size:12px;color:var(--muted);margin-top:3px;line-height:1.45}
.rc-actions{display:flex;gap:8px;margin-top:auto}
.rc-actions .btn{flex:1}

/* ════════ V3.5.8 §11: collapsible nav sections ════════ */
.nav-group{margin-bottom:2px}
button.nav-sec{display:flex;align-items:center;justify-content:space-between;width:100%;background:none;border:0;cursor:pointer;padding:10px 14px 6px;font-family:inherit}
.nav-sec-label{font-size:10.5px;letter-spacing:.7px;text-transform:uppercase;color:var(--muted-2);font-weight:800}
.nav-sec-caret{font-size:9px;color:var(--muted-2);transition:transform .15s}
button.nav-sec:hover .nav-sec-label,button.nav-sec:hover .nav-sec-caret{color:var(--muted)}
.nav-group .nav-items{overflow:hidden;max-height:1000px;transition:max-height .2s ease}
.nav-group.collapsed .nav-items{max-height:0}

/* ════════ V3.5.9 §9.2: finance menu sub-grouping ════════ */
.nav-subhead{font-size:9px;letter-spacing:.8px;text-transform:uppercase;color:var(--muted-2);opacity:.65;font-weight:700;padding:8px 14px 3px 16px}

/* ════════════════════════════════════════════════════════════════
   MOBILE PERFORMANCE & RENDERING FIX
   Two layers:
   (A) a @media query that works WITHOUT JavaScript — critical because the
       login screen renders before the script runs. backdrop-filter on mobile
       repaints as solid BLACK when the keyboard opens, so we remove it entirely
       on small screens via a universal selector (catches every element).
   (B) body.lite (set by JS) freezes the canvas/orbs on touch devices of any size.
   ════════════════════════════════════════════════════════════════ */

/* (A) NO-JS MOBILE FIX — the important one for the black-out bug */
@media (max-width: 820px){
  /* kill ALL backdrop blur on mobile — every element, even ones not class-named here.
     This is what stops inputs/modals from blacking out on focus. */
  *{
    backdrop-filter: none !important;
    -webkit-backdrop-filter: none !important;
  }
  /* since the blur is gone, give translucent surfaces a SOLID, VISIBLY-LIGHTER
     background plus a clear border — otherwise cards blend into the dark page
     and look invisible (which is what made the login form disappear). */
  .glass, .card, .mlite, .metric, .sum-card, .rcard, .chart-card, .vid-card,
  .res-card, .book, .role-card, .fin-stat, .drop, .scope-note, .login-card,
  [class*="glass"]{
    background: #1f1410 !important;
    border: 1px solid rgba(255,255,255,0.14) !important;
  }
  .topbar{ background: #160d0a !important; }
  .sidebar, .scrim-menu, nav{ background: #130b08 !important; }
  .overlay, .scrim{ background: rgba(6,4,3,0.86) !important; }
  /* inputs need to be lighter than their card so they're clearly tappable fields */
  .field input, .field select, .field textarea{
    background: #2a1c16 !important;
    border: 1px solid rgba(255,255,255,0.18) !important;
  }
  /* freeze the big animated background orbs + ember canvas (battery + jank) */
  .bg-orb{ animation: none !important; opacity: .14 !important; }
  #ember-canvas{ display: none !important; }
  /* lighten heavy multi-layer shadows to one cheap shadow */
  .card, .glass, .metric, .sum-card, .mlite, .rcard{
    box-shadow: 0 1px 3px rgba(0,0,0,0.45) !important;
  }
  /* snappier taps */
  *{ transition-duration: 0.1s !important; }
}

/* (B) JS-set lite mode — covers touch tablets wider than 820px too */
body.lite *{ backdrop-filter: none !important; -webkit-backdrop-filter: none !important; }
body.lite .bg-orb{ animation: none !important; opacity: .14 !important; }
body.lite #ember-canvas{ display: none !important; }
body.lite .glass, body.lite .card, body.lite .metric, body.lite .mlite,
body.lite [class*="glass"]{ background: rgba(26,17,13,0.94) !important; }

/* danger button (delete) */
.btn-danger{ color:#ff6b6b !important; border-color:rgba(255,107,107,0.35) !important; }
.btn-danger:hover{ background:rgba(255,107,107,0.12) !important; border-color:rgba(255,107,107,0.6) !important; }

/* birthdays widget */
.bday-h{font-size:11px;letter-spacing:.5px;text-transform:uppercase;color:var(--muted-2);font-weight:700;margin-bottom:8px}
.bday-row{display:flex;align-items:center;gap:12px;width:100%;text-align:left;background:none;border:none;border-radius:10px;padding:8px;cursor:pointer;transition:background .15s}
.bday-row:hover{background:rgba(255,255,255,.05)}
.bday-row.hot{background:linear-gradient(90deg,rgba(255,138,29,.16),transparent);border:1px solid rgba(255,138,29,.3)}
.bday-row .ma{width:38px;height:38px;border-radius:10px;display:grid;place-items:center;font-weight:700;font-size:13px;color:#160b04;flex-shrink:0}
.bday-row .mn2{font-weight:600;font-size:14px}
.bday-row .ms2{font-size:12px;color:var(--muted);font-weight:400}
.bday-today{margin-bottom:4px}
