/* DeskPulse — single stylesheet. No build step. */
:root{
  --bg:#e9eef8; --ink:#1b2436; --muted:#697089; --line:#d6dcec;
  --brand:#2f5bd6; --brand-dk:#244aad; --brand-lt:#5b82e8; --brand-50:#eef3ff; --brand-100:#dfe8ff;
  --good:#1f9d6b; --bad:#e04f5f;
  --card:#ffffff; --radius:12px; --ring:rgba(47,91,214,.22);
  --shadow:0 1px 2px rgba(20,30,60,.06),0 8px 22px rgba(20,30,60,.08);
  --shadow-raised:inset 0 1px 0 rgba(255,255,255,.9),0 1px 3px rgba(20,30,60,.10),0 12px 26px rgba(20,30,60,.09);
  --inset:inset 0 2px 5px rgba(20,30,60,.12),inset 0 1px 0 rgba(20,30,60,.03);
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{font-family:"Inter",-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  color:var(--ink);background:var(--bg);line-height:1.55;font-size:15px;-webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility}
a{color:var(--brand);text-decoration:none}
a:hover{text-decoration:underline}
h1,h2,h3,h4{margin:0 0 .5rem;font-family:"Plus Jakarta Sans","Inter",-apple-system,"Segoe UI",sans-serif;letter-spacing:-.012em}
code{background:#eef1f8;padding:.15em .4em;border-radius:6px;font-size:.9em}
.muted{color:var(--muted)}
.right{margin-left:auto}

/* Buttons — tactile, gradient + soft depth */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.4rem;
  background:linear-gradient(180deg,var(--brand-lt),var(--brand));color:#fff;border:1px solid var(--brand-dk);
  border-radius:9px;padding:.55rem 1.05rem;font-size:.95rem;cursor:pointer;font-weight:600;
  text-shadow:0 -1px 0 rgba(0,0,0,.18);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.45),0 2px 4px rgba(36,74,173,.30),0 1px 1px rgba(20,30,60,.10)}
.btn:hover{background:linear-gradient(180deg,#4f78e6,var(--brand-dk));text-decoration:none;color:#fff}
.btn:active{box-shadow:var(--inset);transform:translateY(1px)}
.btn.ghost{background:linear-gradient(180deg,#ffffff,#eef2fb);color:var(--brand);border:1px solid var(--line);
  text-shadow:none;box-shadow:inset 0 1px 0 rgba(255,255,255,.9),0 1px 2px rgba(20,30,60,.10)}
.btn.ghost:hover{background:linear-gradient(180deg,#ffffff,#e6ecff);color:var(--brand-dk)}
.btn.danger{background:linear-gradient(180deg,#ec6c79,var(--bad));border-color:#bf3645;color:#fff}
.btn.danger:hover{background:linear-gradient(180deg,#e85563,#c73d4b)}
.btn.lg{padding:.8rem 1.5rem;font-size:1.05rem}
.btn.block{width:100%}
.ghost{color:var(--muted)}
.lnk{cursor:pointer;background:none;border:0;font-size:.9rem;padding:0;color:var(--brand)}
.lnk:hover{text-decoration:underline}
.lnk.danger{color:var(--bad)}

/* Accessibility: always-visible keyboard focus ring */
a:focus-visible,button:focus-visible,.btn:focus-visible,summary:focus-visible,
[tabindex]:focus-visible{outline:2px solid var(--brand);outline-offset:2px;border-radius:6px}

/* Flash */
.flash{padding:.7rem 1rem;border-radius:8px;margin:1rem 0;background:#eaf0ff;border:1px solid #cdd9ff}
.flash.error{background:#fdeaec;border-color:#f4c4cb;color:#a3283a}
.flash.success{background:#e8f7f0;border-color:#bfe6d4;color:#157a4f}
.flash.center{max-width:420px;margin:1rem auto}

/* ── App shell ── */
body.app{display:flex;min-height:100vh}
.sidebar{width:250px;flex:none;background:linear-gradient(180deg,#ffffff,#eef2fb);
  border-right:1px solid var(--line);color:var(--ink);display:flex;flex-direction:column;
  padding:.9rem .7rem;position:sticky;top:0;height:100vh;
  box-shadow:inset -1px 0 0 rgba(255,255,255,.6),2px 0 10px rgba(20,30,60,.04)}
.sidebar .brand{color:var(--ink);font-weight:800;font-size:1.18rem;display:flex;align-items:center;gap:.55rem;
  padding:.45rem .55rem 1rem;text-shadow:0 1px 0 rgba(255,255,255,.8)}
/* Company logo sits below the DeskPulse brand, spanning 90% of the sidebar width. */
.sidebar .org-brand{width:90%;margin:0 auto .9rem;padding-bottom:.9rem;border-bottom:1px solid var(--line)}
.sidebar .org-brand img{display:block;width:100%;height:auto;object-fit:contain}
.logo-preview{display:inline-flex;align-items:center;justify-content:center;padding:.6rem .8rem;margin-bottom:.6rem;
  background:#fff;border:1px solid var(--line);border-radius:10px}
.logo-preview img{max-height:64px;max-width:280px;width:auto;height:auto;object-fit:contain;display:block}
.sidebar nav{display:flex;flex-direction:column;gap:.06rem;flex:1;overflow-y:auto;min-height:0}
.nav-group{margin-top:.85rem}
.nav-group:first-of-type{margin-top:.1rem}
.nav-group-label{font-size:.67rem;font-weight:700;letter-spacing:.07em;text-transform:uppercase;
  color:var(--muted);padding:.25rem .75rem .3rem}
.sidebar nav a{color:#46506b;padding:.5rem .7rem;border-radius:9px;display:flex;align-items:center;
  gap:.6rem;font-size:.92rem;font-weight:500;border:1px solid transparent}
.sidebar nav a svg{width:18px;height:18px;flex:none;color:#8b93ac}
.sidebar nav a .lbl{flex:1;min-width:0}
.sidebar nav a:hover{background:linear-gradient(180deg,#ffffff,#eaf0fc);color:var(--brand);text-decoration:none;
  border-color:var(--line);box-shadow:inset 0 1px 0 rgba(255,255,255,.9),0 1px 2px rgba(20,30,60,.08)}
.sidebar nav a:hover svg{color:var(--brand)}
.sidebar nav a.on{background:linear-gradient(180deg,#dbe6ff,#e9f0ff);color:var(--brand-dk);font-weight:600;
  border-color:#c2d3f5;box-shadow:var(--inset)}
.sidebar nav a.on svg{color:var(--brand)}
.dot{width:10px;height:10px;border-radius:50%;background:radial-gradient(circle at 30% 30%,#7aa0ff,var(--brand));
  box-shadow:0 0 0 4px rgba(47,91,214,.18),inset 0 1px 1px rgba(255,255,255,.6);display:inline-block}
.badge{background:linear-gradient(180deg,#ef6b78,var(--bad));color:#fff;border-radius:20px;font-size:.7rem;
  font-weight:700;padding:.05rem .45rem;margin-left:auto;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.3),0 1px 2px rgba(160,40,55,.4)}
.side-foot{border-top:1px solid var(--line);padding-top:.7rem;margin-top:.5rem;display:flex;align-items:center;gap:.6rem}
.side-foot .who{font-size:.82rem;color:var(--ink);flex:1;line-height:1.25}
.side-foot .who small{color:var(--muted)}
.main{flex:1;min-width:0;padding:1.2rem 1.8rem 3rem}
.topbar{display:flex;align-items:center;gap:.7rem;margin:.1rem 0 1.15rem;min-height:42px}
.topbar h1{font-size:1.4rem;margin:0;flex:1;min-width:0}
.nav-toggle{display:none;align-items:center;justify-content:center;width:42px;height:42px;flex:none;
  border:1px solid var(--line);border-radius:9px;background:linear-gradient(180deg,#ffffff,#eef2fb);
  color:var(--ink);cursor:pointer;box-shadow:inset 0 1px 0 rgba(255,255,255,.9),0 1px 2px rgba(20,30,60,.10)}
.nav-toggle:active{box-shadow:var(--inset)}
.nav-toggle svg{width:20px;height:20px}
.nav-backdrop{display:none;position:fixed;inset:0;background:rgba(20,30,60,.45);z-index:90}
.content{max-width:1100px}

/* Panels & stats — raised tactile surfaces */
.panel{background:linear-gradient(180deg,#ffffff,#f7f9fe);border:1px solid var(--line);border-radius:var(--radius);
  padding:1.1rem 1.2rem;margin-bottom:1.2rem;box-shadow:var(--shadow-raised)}
.panel h3{font-size:1.05rem}
.two-col{display:grid;grid-template-columns:1fr 1fr;gap:1.2rem}
.stat-row{display:flex;gap:1rem;flex-wrap:wrap;margin-bottom:1.2rem}
.stat{background:linear-gradient(180deg,#ffffff,#f4f7fe);border:1px solid var(--line);border-radius:var(--radius);
  padding:.85rem 1.1rem;flex:1;min-width:130px;box-shadow:var(--shadow-raised)}
.stat .lbl{display:block;color:var(--muted);font-size:.8rem;text-transform:uppercase;letter-spacing:.03em}
.stat b{font-size:1.5rem}

/* Period switch */
.period-switch{display:flex;gap:.4rem;align-items:center;margin-bottom:1rem}
.period-switch a{padding:.35rem .85rem;border-radius:20px;background:linear-gradient(180deg,#ffffff,#eef1f8);
  color:var(--muted);border:1px solid var(--line);box-shadow:inset 0 1px 0 rgba(255,255,255,.8)}
.period-switch a.on{background:linear-gradient(180deg,var(--brand-lt),var(--brand));color:#fff;border-color:var(--brand-dk);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.35),0 1px 2px rgba(36,74,173,.3)}
.period-switch a:hover{text-decoration:none}

/* Tables */
table.data{width:100%;border-collapse:collapse;font-size:.9rem}
table.data th,table.data td{text-align:left;padding:.55rem .5rem;border-bottom:1px solid var(--line);vertical-align:top}
table.data th{color:var(--muted);font-weight:600;font-size:.78rem;text-transform:uppercase;letter-spacing:.03em}
.trunc{max-width:340px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.tag{background:#eef1f8;border-radius:6px;padding:.1rem .45rem;font-size:.78rem;color:var(--muted)}
.status{border-radius:6px;padding:.1rem .5rem;font-size:.78rem;text-transform:capitalize}
.status.approved{background:#e8f7f0;color:var(--good)}
.status.pending{background:#fff4e0;color:#b5781a}
.status.rejected{background:#fdeaec;color:var(--bad)}

/* Forms */
label{display:block;font-size:.85rem;color:var(--muted);margin-bottom:.7rem}
input,select,textarea{display:block;width:100%;padding:.5rem .65rem;border:1px solid var(--line);border-radius:8px;
  font-size:.95rem;background:linear-gradient(180deg,#f3f5fc,#ffffff);color:var(--ink);margin-top:.2rem;
  box-shadow:var(--inset)}
input:focus,select:focus,textarea:focus{outline:none;border-color:var(--brand);box-shadow:var(--inset),0 0 0 3px var(--ring)}
.stack label{margin-bottom:.8rem}
.inline{display:flex;gap:.8rem}
.inline label{flex:1}
.row-form{display:flex;gap:.8rem;align-items:flex-end;flex-wrap:wrap}
.row-form label{margin-bottom:0}
.row-form .grow{flex:1;min-width:180px}
label.check{display:flex;align-items:center;gap:.4rem}
label.check input{width:auto;margin:0}

/* Approvals */
.approval{display:flex;justify-content:space-between;gap:1rem;border:1px solid var(--line);border-radius:10px;padding:.9rem;margin-bottom:.7rem;flex-wrap:wrap}
.ap-info .note{font-style:italic;color:var(--muted);margin-top:.3rem}
.ap-actions{display:flex;gap:.5rem;align-items:flex-start}
.ap-actions input{margin:0}

/* Chips / lists */
.chips{list-style:none;padding:0;display:flex;flex-wrap:wrap;gap:.4rem}
.chips li{background:#eef1f8;border-radius:6px;padding:.2rem .55rem;font-size:.82rem}
ul.plain{list-style:none;padding:0;margin:0 0 .8rem}
ul.plain li{padding:.25rem 0;border-bottom:1px solid var(--line)}
ol.steps{margin:.3rem 0 .8rem;padding-left:1.2rem}
ol.steps li{margin:.45rem 0}

/* Screenshot grids */
.shot-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(170px,1fr));gap:.7rem}
.shot-grid.sm{grid-template-columns:repeat(auto-fill,minmax(110px,1fr))}
.shot-grid a{display:block;border:1px solid var(--line);border-radius:8px;overflow:hidden;background:#fff;position:relative}
.shot-grid img{width:100%;height:110px;object-fit:cover;display:block}
.shot-grid span{position:absolute;bottom:0;left:0;right:0;background:rgba(15,22,51,.7);color:#fff;font-size:.7rem;padding:.15rem .4rem}

/* Live */
.live-head{display:flex;justify-content:space-between;align-items:center}
.live-dot,.dot.live{width:10px;height:10px;border-radius:50%;background:var(--good);display:inline-block;margin-right:.3rem;animation:pulse 1.6s infinite}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(31,157,107,.5)}70%{box-shadow:0 0 0 8px rgba(31,157,107,0)}100%{box-shadow:0 0 0 0 rgba(31,157,107,0)}}
.live-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:.9rem;margin-top:1rem}
.live-card{border:1px solid var(--line);border-radius:10px;padding:.9rem;background:#fff}
.live-card.idleoff{opacity:.6}
.live-card h4{display:flex;justify-content:space-between;align-items:center;margin-bottom:.3rem}
.live-card .pill{font-size:.72rem;border-radius:20px;padding:.1rem .5rem}
.live-card .pill.on{background:#e8f7f0;color:var(--good)}
.live-card .pill.off{background:#eef1f8;color:var(--muted)}
.live-card .cur{font-size:.85rem;color:var(--muted);min-height:2.4em}
.live-card .bar{height:6px;background:#eef1f8;border-radius:6px;margin:.4rem 0;overflow:hidden}
.live-card .bar i{display:block;height:100%;background:var(--brand)}
.live-card img{width:100%;height:120px;object-fit:cover;border-radius:6px;margin-top:.5rem;border:1px solid var(--line)}
.live-client{margin-top:1.4rem}
.live-client-head{display:flex;align-items:center;gap:.6rem;padding-bottom:.4rem;border-bottom:2px solid var(--line)}
.live-client-head h3{margin:0;font-size:1.05rem}
.live-team{margin-top:.9rem}
.live-team-head{font-size:.78rem;font-weight:600;text-transform:uppercase;letter-spacing:.03em;color:var(--muted)}
.live-team .live-grid{margin-top:.5rem}
.live-client-sub{margin:.4rem 0 .4rem .9rem;padding-left:.6rem;border-left:2px solid var(--line)}
.live-client-subhead{font-size:.72rem;font-weight:600;color:var(--brand);letter-spacing:.02em}
.live-client-sub .live-grid{margin-top:.4rem}

/* ── Public / auth / landing ── */
body.public{display:block}
.pub-top{display:flex;justify-content:space-between;align-items:center;padding:1rem 2rem;max-width:1100px;margin:0 auto}
.pub-top .brand{font-weight:800;font-size:1.25rem;display:flex;align-items:center;gap:.5rem;color:var(--ink)}
.pub-top nav{display:flex;gap:1.2rem;align-items:center}
.pub-main{max-width:1100px;margin:0 auto;padding:1rem 2rem 3rem}
.pub-foot{text-align:center;color:var(--muted);padding:2rem;font-size:.85rem;border-top:1px solid var(--line);margin-top:2rem}

.auth-card{max-width:420px;margin:3rem auto;background:linear-gradient(180deg,#ffffff,#f6f8fe);border:1px solid var(--line);border-radius:var(--radius);padding:2rem;box-shadow:var(--shadow-raised)}
.auth-card h2{font-size:1.4rem}

/* Landing */
.landing .hero{text-align:center;padding:4rem 1rem 3rem;background:radial-gradient(1200px 400px at 50% -10%,#e6edff,transparent)}
.hero-in{max-width:760px;margin:0 auto}
.hero h1{font-size:2.8rem;line-height:1.1;letter-spacing:-.02em}
.lead{font-size:1.2rem;color:var(--muted);margin:1rem 0 1.6rem}
.cta-row{display:flex;gap:.8rem;justify-content:center;flex-wrap:wrap}
.micro{color:var(--muted);font-size:.85rem;margin-top:1rem}
.features{max-width:1100px;margin:0 auto;padding:2rem}
.features h2{text-align:center;font-size:1.8rem;margin-bottom:1.5rem}
.features .grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.2rem}
.features .card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:1.4rem;box-shadow:var(--shadow)}
.features .card h3{font-size:1.1rem}
.split{max-width:1100px;margin:1rem auto;padding:2rem;display:grid;grid-template-columns:1fr 1fr;gap:2rem}
.split .col{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:1.5rem;box-shadow:var(--shadow)}
.split ul{margin:.5rem 0 0;padding-left:1.1rem}
.split li{margin:.4rem 0}
.cta{text-align:center;padding:3rem 1rem}
.cta h2{font-size:1.8rem;margin-bottom:1rem}

/* Share */
.share-wrap{max-width:1000px;margin:0 auto}
.share-head{display:flex;justify-content:space-between;align-items:flex-end;flex-wrap:wrap;gap:1rem;margin-bottom:1rem}
.share-filters{display:flex;gap:1.2rem;align-items:flex-end;flex-wrap:wrap;margin-bottom:1rem;padding:.8rem 1rem;background:#fff;border:1px solid var(--line);border-radius:10px}
.share-filters .row-form{gap:.5rem}

/* Super-admin acting banner + platform */
.acting-banner{background:#fff4e0;border:1px solid #f0d199;color:#8a5a12;padding:.5rem 1rem;border-radius:8px;margin-bottom:1rem;font-size:.9rem}
.acting-banner a{font-weight:600}
.btn.sm{padding:.3rem .6rem;font-size:.82rem}
.actions-row{display:flex;gap:.4rem;align-items:center;flex-wrap:wrap;margin-bottom:.4rem}
.actions-row form{display:inline}
.bill-form{display:flex;gap:.3rem;align-items:center;flex-wrap:wrap;margin-top:.3rem}
.bill-form input{margin:0}
.inline-form{display:inline}
.inline-form select{display:inline-block;width:auto;padding:.25rem .4rem;margin:0}
.sidebar nav a[href$="platform"]{color:var(--brand-dk);font-weight:600}

.share-url{font-size:.8rem;color:var(--muted);word-break:break-all;background:#eef1f8;padding:.2rem .45rem;border-radius:6px}

/* Agent detail page header */
.detail-head{display:flex;justify-content:space-between;align-items:flex-end;gap:1rem;flex-wrap:wrap;margin-bottom:1rem}
.detail-head h2{margin:0;display:flex;align-items:center;gap:.5rem}
.detail-head .period-switch{margin:0}

/* Agent dashboard: activity/inactivity breakdown + workspace */
.split-bar{height:14px;border-radius:8px;background:#d9def0;overflow:hidden;box-shadow:var(--inset);margin:.4rem 0 .55rem}
.split-bar i{display:block;height:100%}
.split-bar i.act{background:linear-gradient(180deg,#5b82e8,#2f5bd6)}
.split-legend{display:flex;gap:1.3rem;font-size:.85rem;color:var(--muted);margin-bottom:.7rem}
.split-legend .sw{display:inline-block;width:11px;height:11px;border-radius:3px;vertical-align:middle;margin-right:.35rem}
.split-legend .sw.act{background:#2f5bd6}.split-legend .sw.inact{background:#d9def0}
.mini-stats li{display:flex;justify-content:space-between;gap:1rem}
.mini-stats b{font-variant-numeric:tabular-nums;color:#1c3a86}
.agent-workspace .ws-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:1rem}
.ws-item{display:flex;flex-direction:column;gap:.18rem}
.ws-item .lbl{color:var(--muted);font-size:.74rem;text-transform:uppercase;letter-spacing:.04em}
.ws-item b{font-size:1.02rem}
.ws-linkrow{display:flex;gap:.4rem;flex-wrap:wrap;margin-top:.15rem}
.pill.on{background:#e8f7f0;color:var(--good)}
.pill.off{background:#eef1f8;color:var(--muted)}
.panel-head .pill.on,.panel-head .pill.off{border-radius:20px;padding:.15rem .6rem;font-size:.78rem;font-weight:600}

/* Agents management page */
.agent-meta{display:flex;justify-content:space-between;align-items:center;gap:1rem;flex-wrap:wrap;margin-bottom:.4rem}
.op-body h4{margin:.95rem 0 .35rem;font-size:.74rem;text-transform:uppercase;letter-spacing:.05em;color:var(--brand-dk)}
.assign-form select[multiple]{min-width:240px;padding:.3rem .4rem}
.task-list{display:flex;flex-direction:column;gap:.5rem;margin:.35rem 0 .8rem}
.task-row{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap;border:1px solid var(--line);
  border-radius:10px;padding:.5rem .6rem;background:linear-gradient(180deg,#ffffff,#f6f8fe)}
.task-edit{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap;flex:1;margin:0}
.task-edit input[type=text]{flex:1;min-width:180px}
.task-edit select{width:auto;min-width:120px}
.task-edit input,.task-edit select{margin:0}
.task-del{margin:0}
.nowrap{white-space:nowrap}
.dlabel{display:flex;align-items:center;gap:.3rem;margin:0;font-size:.8rem;color:var(--muted)}
.dlabel input{width:auto;margin:0}
.dev-row{display:flex;justify-content:space-between;align-items:center;gap:1rem}
.sched-h{font-size:.78rem;text-transform:uppercase;letter-spacing:.04em;color:var(--brand-dk);margin:.6rem 0 .2rem}
.sched-days{display:flex;flex-wrap:wrap;gap:.2rem .8rem;align-items:center;margin-top:.2rem}
.sched-days .check{margin:0;font-weight:400}

.team-block{border:1px solid var(--line);border-radius:10px;padding:.8rem;margin-bottom:.7rem}
.team-block .chips{margin:.4rem 0}
.team-block .chips form{display:inline}

/* Interactive chart tooltip (timeline screenshot preview) */
#dp-tip{position:fixed;z-index:9999;display:none;width:236px;background:#fff;border:1px solid var(--line);
  border-radius:10px;box-shadow:0 6px 24px rgba(20,30,60,.18);padding:.5rem;pointer-events:none;font-size:.8rem}
#dp-tip .dp-tip-h{font-weight:700;color:#16224a}
#dp-tip .dp-tip-app{color:#6b7390;margin:.15rem 0 .4rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
#dp-tip img{width:100%;border-radius:6px;border:1px solid var(--line);display:block}

/* Manual-entry rows */
.adj-row{align-items:flex-end;border-bottom:1px dashed var(--line);padding-bottom:.6rem;margin-bottom:.6rem}
.adj-row .remove-row{font-size:1rem;align-self:center}
/* Reserve a stable drawing area so charts don't squash/distort when the page is
   zoomed or the column is compressed. JS pins the exact min-height per canvas to its
   own drawing height; this 160px floor reserves space before JS runs. */
canvas.dp-chart{display:block;width:100%;max-width:100%;min-height:160px}

/* ── Backend branding: marketing-matched color accents ── */
.topbar{border-bottom:1px solid var(--line);padding-bottom:.55rem}
.topbar h1{display:flex;align-items:center;gap:.55rem}
.topbar h1::before{content:"";width:5px;height:1.15em;border-radius:4px;
  background:linear-gradient(180deg,var(--brand-lt),var(--brand-dk));box-shadow:0 1px 2px rgba(36,74,173,.4)}
.panel h3,.two-col h3{color:#1c3a86}
.stat b{background:linear-gradient(180deg,#2f5bd6,#16307e);-webkit-background-clip:text;background-clip:text;color:transparent}
.stat .lbl{color:var(--brand-dk);opacity:.75}
table.data thead th{background:linear-gradient(180deg,#f3f6ff,#eaf0fc)}
table.data thead th:first-child{border-top-left-radius:8px}
table.data thead th:last-child{border-top-right-radius:8px}
.acting-banner{background:linear-gradient(180deg,#fff6e3,#ffefcf)}

/* ════════════ Marketing — skeuomorphic, deep→light blue ════════════ */
.landing{background:linear-gradient(180deg,#e7eefb 0%,#f4f7ff 30%,#f4f7ff 100%)}
.pub-top .logo,.site-foot .logo{height:32px;display:block}
.btn svg{width:18px;height:18px;flex:none}

/* Sticky frosted-glass top bar */
.landing .pub-top{position:sticky;top:0;z-index:50;max-width:none;padding:.7rem 2rem;
  background:rgba(244,247,255,.78);backdrop-filter:saturate(180%) blur(12px);
  -webkit-backdrop-filter:saturate(180%) blur(12px);border-bottom:1px solid rgba(20,40,120,.08)}
.landing .pub-top nav{gap:1.5rem}
.landing .pub-top nav a{color:#27324f;font-weight:600;font-size:.92rem}
.landing .pub-top nav a.btn{color:#fff}

/* ── Hero: asymmetric split, deep→light blue, glossy mockup ── */
.landing .hero{position:relative;overflow:hidden;color:#fff;padding:5.5rem 2rem 6rem;
  background:
    radial-gradient(900px 380px at 18% -6%, rgba(255,255,255,.28), transparent 60%),
    linear-gradient(180deg,#071744 0%,#0f2f7e 34%,#2454c4 66%,#4f86f5 100%)}
.landing .hero .hero-photo{position:absolute;inset:0;background-size:cover;background-position:center;
  opacity:.12;mix-blend-mode:luminosity;filter:saturate(.6)}
.landing .hero::after{content:"";position:absolute;left:0;right:0;bottom:-1px;height:90px;
  background:linear-gradient(180deg,transparent,#f4f7ff);pointer-events:none}
.hero-grid{position:relative;z-index:2;max-width:1180px;margin:0 auto;display:grid;
  grid-template-columns:1.05fr .95fr;gap:2.6rem;align-items:center}
.hero-copy h1{font-size:3.2rem;line-height:1.05;letter-spacing:-.025em;color:#fff;
  text-shadow:0 2px 22px rgba(4,12,40,.45)}
.hero-copy .lead{color:#d8e4ff;font-size:1.18rem;max-width:560px;margin:1.1rem 0 1.6rem}
.hero-copy .lead strong{color:#fff}
.kicker{display:inline-flex;align-items:center;gap:.4rem;background:linear-gradient(180deg,rgba(255,255,255,.22),rgba(255,255,255,.10));
  border:1px solid rgba(255,255,255,.32);color:#eef4ff;border-radius:30px;padding:.34rem .9rem;font-size:.76rem;
  font-weight:700;letter-spacing:.05em;text-transform:uppercase;margin-bottom:1.1rem;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.35),0 4px 12px rgba(4,16,60,.3)}
.kicker svg{width:14px;height:14px;color:#ffd98a}
.landing .hero .btn.lg:not(.ghost){background:linear-gradient(180deg,#ffffff,#e8eeff);color:#1c3aa0;border-color:#cdd9ff}
.landing .hero .btn.lg:not(.ghost):hover{background:linear-gradient(180deg,#ffffff,#dbe6ff)}
.landing .hero .btn.ghost{background:rgba(255,255,255,.12);color:#fff;border-color:rgba(255,255,255,.5)}
.landing .hero .btn.ghost:hover{background:rgba(255,255,255,.2);color:#fff}
.hero-trust{list-style:none;display:flex;flex-wrap:wrap;gap:.5rem 1.4rem;margin:1.5rem 0 0;padding:0;
  color:#cfe0ff;font-size:.9rem}
.hero-trust li{display:flex;align-items:center;gap:.4rem}
.hero-trust svg{width:16px;height:16px;color:#8fe0a3}

/* Hero dashboard mockup (pure CSS, skeuomorphic) */
.hero-mock{background:linear-gradient(180deg,#ffffff,#eaeffb);border:1px solid rgba(255,255,255,.7);
  border-radius:16px;padding:.55rem;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.8),0 30px 60px rgba(4,16,60,.48),0 12px 26px rgba(4,16,60,.3)}
.mock-bar{display:flex;align-items:center;gap:.45rem;padding:.35rem .55rem .6rem}
.mock-bar i{width:11px;height:11px;border-radius:50%;box-shadow:inset 0 1px 1px rgba(0,0,0,.18)}
.mock-bar i:nth-child(1){background:#ec6c79}.mock-bar i:nth-child(2){background:#f3c14b}.mock-bar i:nth-child(3){background:#5bbf6a}
.mock-bar .mock-url{margin-left:.4rem;font-size:.72rem;color:#8b93ac;font-weight:600}
.mock-screen{background:linear-gradient(180deg,#f6f8ff,#eef2fb);border:1px solid var(--line);border-radius:11px;
  padding:.9rem;display:grid;grid-template-columns:repeat(4,1fr);gap:.6rem}
.mock-stat{background:linear-gradient(180deg,#ffffff,#f1f5ff);border:1px solid var(--line);border-radius:10px;
  padding:.6rem .65rem;box-shadow:var(--shadow-raised)}
.mock-stat .k{display:block;font-size:.6rem;text-transform:uppercase;letter-spacing:.04em;color:var(--muted)}
.mock-stat .v{font-size:1.15rem;font-weight:800;color:#16224a;font-variant-numeric:tabular-nums}
.mock-chart{grid-column:1/-1;height:128px;border:1px solid var(--line);border-radius:10px;
  background:linear-gradient(180deg,#ffffff,#f3f7ff);display:flex;align-items:flex-end;gap:.45rem;padding:.8rem;
  box-shadow:var(--shadow-raised)}
.mock-chart b{flex:1;border-radius:5px 5px 2px 2px;background:linear-gradient(180deg,#5b82e8,#2f5bd6);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.45)}

/* ── Metrics band (overlaps hero) ── */
.metrics{position:relative;z-index:5;max-width:1180px;margin:-3.5rem auto 0;padding:0 2rem}
.metrics-in{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem}
.metric{background:linear-gradient(180deg,#ffffff,#eef3ff);border:1px solid var(--line);border-radius:16px;
  padding:1.4rem 1rem;text-align:center;box-shadow:var(--shadow-raised)}
.metric .n{display:block;font-size:2.2rem;font-weight:800;font-variant-numeric:tabular-nums;line-height:1;
  font-family:"Plus Jakarta Sans","Inter",sans-serif;
  background:linear-gradient(180deg,#2f5bd6,#16307e);-webkit-background-clip:text;background-clip:text;color:transparent}
.metric .l{display:block;color:var(--muted);font-size:.82rem;margin-top:.45rem}

/* ── Section heads ── */
.section-head{max-width:720px;margin:0 auto 1.8rem;text-align:center}
.section-head .eyebrow,.eyebrow{display:inline-block;font-size:.72rem;font-weight:800;letter-spacing:.12em;
  text-transform:uppercase;color:var(--brand);margin-bottom:.5rem}
.section-head h2{font-size:2rem;color:#15224a;letter-spacing:-.02em}
.section-head .sub{color:var(--muted);font-size:1.05rem;margin:.4rem 0 0}
.section-head.light .eyebrow{color:#9fc0ff}
.section-head.light h2{color:#fff;text-shadow:0 1px 14px rgba(4,12,40,.4)}
.section-head.light .sub{color:#cdd9f7}

/* ── Features ── */
.features{max-width:1180px;margin:0 auto;padding:4.5rem 2rem}
.features.alt{position:relative}
.feat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.1rem}
.features .card,.role-grid .card{position:relative;background:linear-gradient(180deg,#ffffff,#f3f7ff);
  border:1px solid #dde5fb;border-radius:16px;padding:1.4rem;box-shadow:var(--shadow-raised);
  transition:transform .18s ease,box-shadow .18s ease}
.features .card:hover,.role-grid .card:hover{transform:translateY(-3px);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.9),0 18px 38px rgba(20,40,120,.16)}
.features .card h3{font-size:1.04rem;color:#1a2a63;margin-bottom:.3rem}
.features .card p{color:#4a5478;font-size:.93rem;margin:0}
.feat-ico{width:46px;height:46px;border-radius:13px;display:flex;align-items:center;justify-content:center;
  margin-bottom:.8rem;color:#fff;background:linear-gradient(180deg,#5b82e8,#2f5bd6);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.5),0 6px 14px rgba(36,74,173,.4),0 1px 2px rgba(20,30,60,.2)}
.feat-ico svg{width:23px;height:23px}
/* Highlighted hero feature (spans 2 cols, image-led) */
.feat-hero{grid-column:span 2;grid-row:span 2;display:flex;flex-direction:column;overflow:hidden;padding:0}
.feat-hero .card-media{height:210px;background-size:cover;background-position:center top;position:relative;
  background-color:#0a1a47}
/* Dark spotlight overlay so the product screenshot stands out from the page. */
.feat-hero .card-media::after{content:"";position:absolute;inset:0;
  background:radial-gradient(125% 100% at 50% 38%, rgba(8,20,60,.20), rgba(6,15,46,.74))}
.feat-hero .card-body{padding:1.4rem;position:relative}
.feat-hero h3{font-size:1.3rem}
.feat-hero p{font-size:1rem}

/* ── Product-tour carousel ── */
.showcase-carousel{max-width:1180px;margin:0 auto;padding:3.5rem 2rem}
.carousel{position:relative}
.carousel-track{border-radius:18px;overflow:hidden;border:1px solid #dde5fb;box-shadow:var(--shadow-raised);background:#fff}
.slide{margin:0;display:none}
.slide.on{display:block;animation:slidefade .45s ease}
@keyframes slidefade{from{opacity:.35}to{opacity:1}}
.slide-img{height:430px;background-size:cover;background-position:top center;background-color:#0a1a47}
.slide figcaption{padding:1.1rem 1.4rem;background:linear-gradient(180deg,#10307f,#0f2766);color:#fff}
.slide figcaption h3{color:#fff;margin:0 0 .2rem;font-size:1.2rem}
.slide figcaption p{color:#cfe0ff;margin:0;font-size:.95rem}
.carousel-nav{position:absolute;top:215px;transform:translateY(-50%);width:44px;height:44px;border-radius:50%;
  border:0;background:rgba(255,255,255,.92);color:#16224a;font-size:1.7rem;line-height:1;cursor:pointer;
  display:flex;align-items:center;justify-content:center;box-shadow:0 4px 16px rgba(8,20,60,.32)}
.carousel-nav:hover{background:#fff}
.carousel-nav.prev{left:14px}.carousel-nav.next{right:14px}
.carousel-dots{display:flex;justify-content:center;gap:.5rem;margin-top:1rem}
.carousel-dots .dot{width:9px;height:9px;border-radius:50%;border:0;background:#c7d2ee;cursor:pointer;padding:0}
.carousel-dots .dot.on{background:var(--brand);transform:scale(1.2)}
@media (max-width:700px){.slide-img{height:230px}.carousel-nav{top:115px}}

/* ── How it works (over faint office image) ── */
.how{position:relative;overflow:hidden;color:#fff;padding:4.5rem 2rem;
  background:linear-gradient(180deg,#10307f,#244fb8)}
.how-photo{position:absolute;inset:0;background-size:cover;background-position:center;opacity:.14;mix-blend-mode:luminosity}
.how-in{position:relative;z-index:2;max-width:1180px;margin:0 auto}
.step-track{display:grid;grid-template-columns:repeat(4,1fr);gap:1.1rem}
.step{background:linear-gradient(180deg,rgba(255,255,255,.96),rgba(238,243,255,.92));border:1px solid rgba(255,255,255,.6);
  border-radius:16px;padding:1.4rem;box-shadow:0 14px 30px rgba(4,16,60,.28),inset 0 1px 0 rgba(255,255,255,.7)}
.step .num{width:42px;height:42px;border-radius:50%;display:flex;align-items:center;justify-content:center;
  font-weight:800;font-size:1.1rem;color:#fff;margin-bottom:.8rem;background:linear-gradient(180deg,#5b82e8,#2454c4);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.5),0 6px 14px rgba(36,74,173,.4)}
.step h3{font-size:1.02rem;color:#1a2a63}
.step p{color:#4a5478;font-size:.92rem;margin:0}

/* ── Role / glass grids ── */
.role-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.1rem;max-width:1180px;margin:0 auto}
.role-grid.three{grid-template-columns:repeat(3,1fr)}
.role-grid .card.role{display:flex;gap:.9rem;align-items:flex-start}
.role-ico{width:40px;height:40px;flex:none;border-radius:11px;display:flex;align-items:center;justify-content:center;
  color:var(--brand);background:linear-gradient(180deg,#eef3ff,#dde7ff);border:1px solid #cdd9f5;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.8)}
.role-ico svg{width:20px;height:20px}
.role-grid .card.role h3{margin-bottom:.2rem}
#roles .card{border-top:3px solid #3a63e0}
.card.glass{background:linear-gradient(180deg,rgba(255,255,255,.97),rgba(240,245,255,.93));
  border-color:rgba(255,255,255,.6);box-shadow:0 14px 30px rgba(4,16,60,.26),inset 0 1px 0 rgba(255,255,255,.7)}
.card.glass h3{color:#15224a}
.card.glass p{color:#41496b}

/* ── Showcase (teams vs individuals) ── */
.showcase{max-width:1180px;margin:0 auto;padding:1rem 2rem 4rem;display:grid;grid-template-columns:1fr 1fr;gap:1.5rem}
.show-col{background:linear-gradient(180deg,#ffffff,#f3f7ff);border:1px solid #dde5fb;border-radius:18px;
  overflow:hidden;box-shadow:var(--shadow-raised)}
.show-media{height:200px;background-size:cover;background-position:center;position:relative}
.show-media::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(8,23,68,.30),rgba(8,23,68,.05))}
.show-body{padding:1.6rem}
.show-body h3{font-size:1.35rem;color:#15224a}
.ticks{list-style:none;padding:0;margin:.6rem 0 1.2rem;display:flex;flex-direction:column;gap:.5rem}
.ticks li{display:flex;align-items:center;gap:.55rem;color:#41496b;font-size:.95rem}
.ticks svg{width:18px;height:18px;flex:none;color:var(--good)}

/* ── Privacy (over faint tech image) ── */
.privacy{position:relative;overflow:hidden;padding:4.5rem 2rem;color:#fff;
  background:linear-gradient(180deg,#0c1f57,#1d3f9c)}
.privacy-photo{position:absolute;inset:0;background-size:cover;background-position:center;opacity:.16;mix-blend-mode:luminosity}
.privacy-in{position:relative;z-index:2;max-width:1180px;margin:0 auto}

/* ── CTA band ── */
.cta-band{position:relative;overflow:hidden;text-align:center;color:#fff;padding:4.5rem 1.5rem;
  background:linear-gradient(180deg,#0f2f7e,#2f5bd6)}
.cta-photo{position:absolute;inset:0;background-size:cover;background-position:center;opacity:.16;mix-blend-mode:luminosity}
.cta-in{position:relative;z-index:2;max-width:760px;margin:0 auto}
.cta-band h2{font-size:2.3rem;color:#fff;letter-spacing:-.02em;text-shadow:0 2px 16px rgba(4,12,40,.4)}
.cta-band p{color:#dbe6ff;margin:.5rem 0 1.5rem;font-size:1.1rem}
.cta-band .btn.lg:not(.ghost){background:linear-gradient(180deg,#ffffff,#e8eeff);color:#1c3aa0;border-color:#cdd9ff}
.cta-band .btn.lg.ghost{background:rgba(255,255,255,.12);color:#fff;border-color:rgba(255,255,255,.55)}
.cta-row{display:flex;gap:.8rem;justify-content:center;flex-wrap:wrap}

/* ── Footer ── */
.site-foot{background:linear-gradient(180deg,#0d1a3d,#0a1430);color:#aeb6da;padding:2.8rem 2rem 1.5rem;margin-top:0}
.foot-grid{max-width:1180px;margin:0 auto;display:grid;grid-template-columns:2fr 1fr 1fr;gap:2rem}
.foot-grid h4{color:#fff;font-size:.95rem;margin-bottom:.6rem}
.foot-grid a{display:block;color:#aeb6da;padding:.2rem 0}
.foot-grid a:hover{color:#fff}
.site-foot .copy{text-align:center;color:#6b76a8;margin-top:2rem;font-size:.85rem}
.site-foot .copy a{color:#aeb6da}

/* ── Scroll reveal ── */
[data-reveal]{opacity:0;transform:translateY(18px);transition:opacity .6s ease,transform .6s ease}
[data-reveal].in{opacity:1;transform:none}

/* ── Marketing responsive ── */
@media (max-width:1040px){
  .feat-grid{grid-template-columns:repeat(2,1fr)}
  .feat-hero{grid-column:span 2;grid-row:auto}
}
@media (max-width:900px){
  .hero-grid{grid-template-columns:1fr;gap:2rem}
  .hero-mock{order:2;max-width:560px}
  .landing .hero{padding:4.5rem 1.25rem 5rem}
  .hero-copy h1{font-size:2.4rem}
  .metrics-in,.step-track,.role-grid,.role-grid.three{grid-template-columns:repeat(2,1fr)}
  .showcase{grid-template-columns:1fr}
}
@media (max-width:560px){
  .feat-grid,.metrics-in,.step-track,.role-grid,.role-grid.three{grid-template-columns:1fr}
  .feat-hero{grid-column:auto}
  .mock-screen{grid-template-columns:repeat(2,1fr)}
}
@media (prefers-reduced-motion:reduce){
  [data-reveal]{opacity:1;transform:none;transition:none}
  .features .card,.role-grid .card{transition:none}
}

@media (max-width:980px){
  .features .grid,.features .grid.three{grid-template-columns:repeat(2,1fr)}
  .foot-grid{grid-template-columns:1fr 1fr}
}
@media (max-width:880px){
  .two-col,.split,.landing .split{grid-template-columns:1fr}
  body.app{display:block}
  .nav-toggle{display:inline-flex}
  .sidebar{position:fixed;left:0;top:0;z-index:100;width:264px;height:100dvh;transform:translateX(-100%);
    transition:transform .22s ease;box-shadow:0 12px 40px rgba(20,30,60,.28)}
  body.nav-open .sidebar{transform:none}
  body.nav-open .nav-backdrop{display:block}
  .main{padding:1rem 1.1rem 3rem}
  table.data{display:block;overflow-x:auto;white-space:nowrap}
  .hero h1,.landing .hero h1{font-size:2rem}
  .features .grid,.features .grid.three{grid-template-columns:1fr}
}
@media (prefers-reduced-motion:reduce){
  .sidebar{transition:none}
}

/* ── Platform console ── */
.small{font-size:.78rem}
.page-actions{display:flex;gap:.6rem;margin-bottom:1rem;flex-wrap:wrap}
.stat b{font-variant-numeric:tabular-nums}
.stat .sub{display:block;color:var(--muted);font-size:.72rem;margin-top:.15rem}
.stat.alert{border-color:#f3d28a;background:#fffaf0}
.stat.alert b{color:#b5781a}
.panel-head{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin-bottom:.6rem}
.panel-head h3{margin:0}
.signup-list{display:flex;flex-direction:column;gap:.6rem}
.signup-item{display:flex;align-items:center;justify-content:space-between;gap:1rem;
  border:1px solid var(--line);border-radius:10px;padding:.7rem .9rem;background:#fbfcff}
.signup-item .who{font-size:.82rem;margin-top:.15rem}
.signup-actions{display:flex;gap:.4rem;align-items:center;flex-wrap:wrap}
.signup-actions form{margin:0}
.empty-state{text-align:center;color:var(--muted);padding:1.6rem 1rem}
.empty-state svg{width:30px;height:30px;color:var(--good);margin-bottom:.4rem}
.org-group{border:1px solid var(--line);border-radius:10px;margin-top:.6rem;background:#fbfcff}
.org-group>summary{cursor:pointer;padding:.6rem .9rem;list-style:none;display:flex;align-items:center;gap:.5rem}
.org-group>summary::-webkit-details-marker{display:none}
.org-group>summary::before{content:"▸";color:var(--muted);font-size:.8rem;transition:transform .15s}
.org-group[open]>summary::before{transform:rotate(90deg)}
.org-group[open]>summary{border-bottom:1px solid var(--line)}
.org-group .agent-list{margin:0}
.org-group .agent-list td{padding:.45rem .9rem}
.org-group>p{padding:.6rem .9rem;margin:0}

/* Platform horizontal sub-menu (tabs) */
.subnav{display:flex;gap:.2rem;border-bottom:1px solid var(--line);margin-bottom:1.1rem;flex-wrap:wrap}
.subnav a{padding:.5rem .9rem;color:var(--muted);font-weight:600;font-size:.92rem;border-bottom:2px solid transparent;margin-bottom:-1px}
.subnav a:hover{color:var(--ink);text-decoration:none}
.subnav a.on{color:var(--brand);border-bottom-color:var(--brand)}

/* Organizations tree (collapsible org panels + clickable agents) */
.org-panel{border:1px solid var(--line);border-radius:12px;background:var(--card);box-shadow:var(--shadow);margin-bottom:.8rem}
.org-panel>summary{cursor:pointer;list-style:none;display:flex;justify-content:space-between;align-items:center;gap:1rem;padding:.9rem 1.1rem}
.org-panel>summary::-webkit-details-marker{display:none}
.org-panel>summary::before{content:"▸";color:var(--muted);transition:transform .15s}
.org-panel[open]>summary::before{transform:rotate(90deg)}
.org-panel[open]>summary{border-bottom:1px solid var(--line)}
.op-name{display:flex;align-items:center;gap:.5rem}
.op-body{padding:1rem 1.1rem}
.op-manage{display:flex;flex-wrap:wrap;gap:.8rem 1.2rem;align-items:center;justify-content:space-between;
  padding-bottom:.9rem;border-bottom:1px dashed var(--line);margin-bottom:.6rem}
.op-manage .bill-form{display:flex;align-items:center;gap:.4rem;flex-wrap:wrap}
.op-tree h4{margin:.7rem 0 .2rem;font-size:.75rem;text-transform:uppercase;letter-spacing:.04em;color:var(--muted)}
.agent-rows{display:flex;flex-wrap:wrap;gap:.5rem;padding:.5rem .2rem}
.agent-link{background:#fff;border:1px solid var(--line);border-radius:20px;padding:.32rem .8rem;cursor:pointer;font:inherit;color:var(--ink)}
.agent-link:hover{border-color:var(--brand);color:var(--brand)}

/* Modal */
.modal-backdrop{position:fixed;inset:0;background:rgba(15,22,51,.55);display:flex;align-items:center;justify-content:center;padding:1rem;z-index:1000}
.modal-backdrop[hidden]{display:none}
.modal-box{background:#fff;border-radius:14px;max-width:560px;width:100%;max-height:85vh;overflow:auto;box-shadow:0 20px 60px rgba(15,22,51,.35)}
.modal-head{position:sticky;top:0;background:#fff;display:flex;justify-content:space-between;align-items:center;padding:1rem 1.2rem;border-bottom:1px solid var(--line)}
.modal-head h3{margin:0}
.modal-close{border:0;background:none;font-size:1.6rem;line-height:1;cursor:pointer;color:var(--muted)}
.modal-body{padding:1.1rem 1.2rem}
.um-sub{color:var(--muted);margin-bottom:.9rem;display:flex;align-items:center;gap:.5rem}
.um-sub .pill.on{background:#e8f7f0;color:var(--good);border-radius:20px;padding:.1rem .5rem;font-size:.72rem}
dl.kv{display:grid;grid-template-columns:130px 1fr;gap:.45rem .8rem;margin:0}
dl.kv dt{color:var(--muted);font-size:.85rem}
dl.kv dd{margin:0;font-size:.9rem}

/* Onboarding wizard */
.onb-intro{margin-bottom:1rem}
.onb-intro h2{font-size:1.5rem}
.onb-steps{display:flex;flex-wrap:wrap;gap:.3rem;list-style:none;padding:0;margin:0 0 1.2rem;counter-reset:step}
.onb-steps li{flex:1;min-width:120px}
.onb-steps li a{display:flex;align-items:center;gap:.45rem;padding:.55rem .7rem;border:1px solid var(--line);
  border-radius:8px;color:var(--muted);font-weight:600;font-size:.9rem;background:var(--card)}
.onb-steps li a:hover{text-decoration:none;border-color:var(--brand)}
.onb-steps li .n{display:inline-flex;align-items:center;justify-content:center;width:22px;height:22px;
  border-radius:50%;background:#eef1f8;color:var(--muted);font-size:.8rem}
.onb-steps li.on a{border-color:var(--brand);color:var(--brand)}
.onb-steps li.on .n{background:var(--brand);color:#fff}
.onb-steps li.done a{color:var(--good)}
.onb-steps li.done .n{background:#e8f7f0;color:var(--good)}
.onb-row{display:flex;flex-wrap:wrap;gap:.5rem;align-items:center;margin-bottom:.6rem}
.onb-row input[type=text],.onb-row input[type=email]{flex:1;min-width:160px}
.onb-list{list-style:none;padding:0;margin:.4rem 0 0;display:flex;flex-direction:column;gap:.35rem}
.onb-list li{padding:.5rem .7rem;border:1px solid var(--line);border-radius:8px;background:#fbfcff;font-size:.9rem}
.onb-nav{display:flex;justify-content:space-between;gap:.6rem;margin-top:1rem}
.onb-nav .btn:only-child{margin-left:auto}
.onb-done .stat-row{margin:.8rem 0}
.stack label.check{display:flex;align-items:center;gap:.5rem;font-weight:400}
.stack label.check input{width:auto}
.tutorial{background:#eef3ff;border:1px solid #d6e0ff;border-radius:10px;padding:.8rem 1rem;margin-bottom:.9rem;font-size:.9rem;color:#33417a}
.tutorial b{color:#23347a}
.tutorial ul{margin:.4rem 0 .2rem;padding-left:1.1rem}
.tutorial li{margin:.15rem 0}
/* Help bubble + hover tooltips ([data-tip] on any element) */
.dp-help{display:inline-flex;align-items:center;justify-content:center;width:16px;height:16px;
  margin-left:.35rem;border-radius:50%;background:#dbe4ff;color:#3550c8;font-size:.7rem;
  font-weight:700;cursor:help;vertical-align:middle;line-height:1;user-select:none}
.dp-help:hover,.dp-help:focus{background:var(--brand);color:#fff;outline:none}
[data-tip]{position:relative}
[data-tip]::after{content:attr(data-tip);position:absolute;left:50%;bottom:calc(100% + 8px);
  transform:translateX(-50%) translateY(4px);min-width:140px;max-width:260px;width:max-content;
  padding:.45rem .6rem;border-radius:8px;background:#1f2540;color:#fff;font-size:.78rem;
  font-weight:500;line-height:1.35;text-align:left;white-space:normal;box-shadow:0 8px 24px rgba(15,23,42,.28);
  opacity:0;visibility:hidden;pointer-events:none;transition:opacity .14s,transform .14s;z-index:60}
[data-tip]::before{content:"";position:absolute;left:50%;bottom:calc(100% + 2px);
  transform:translateX(-50%) translateY(4px);border:6px solid transparent;border-top-color:#1f2540;
  opacity:0;visibility:hidden;pointer-events:none;transition:opacity .14s,transform .14s;z-index:60}
[data-tip]:hover::after,[data-tip]:focus::after,[data-tip]:focus-within::after,
[data-tip]:hover::before,[data-tip]:focus::before,[data-tip]:focus-within::before{
  opacity:1;visibility:visible;transform:translateX(-50%) translateY(0)}
/* Tooltips anchored near the left edge (e.g. sidebar nav) flip to the right */
[data-tip].tip-right::after{left:0;transform:translateX(0) translateY(4px)}
[data-tip].tip-right::before{left:14px}
[data-tip].tip-right:hover::after,[data-tip].tip-right:focus::after,[data-tip].tip-right:focus-within::after{
  transform:translateX(0) translateY(0)}
/* Sidebar nav: the nav is a vertical scroll container, so absolutely-positioned
   tooltip bubbles would extend its scroll area and overflow the bar's width.
   Suppress the custom bubble here and fall back to the native `title` tooltip
   (still set on every nav link). Custom bubbles remain on main-content elements. */
.sidebar [data-tip]::after,.sidebar [data-tip]::before{content:none !important}

/* Welcome / role guide (first run for employees, HR, IT, client viewers) */
.welcome-hero{display:flex;align-items:flex-start;gap:.9rem;margin-bottom:1.1rem}
.welcome-hero .wh-badge{flex:0 0 auto;width:48px;height:48px;border-radius:12px;background:var(--brand);
  color:#fff;display:flex;align-items:center;justify-content:center;font-size:1.5rem}
.welcome-hero h2{font-size:1.5rem;margin:0}
.guide-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:.8rem;margin:.2rem 0 1rem}
.guide-card{border:1px solid var(--line);border-radius:12px;padding:.9rem 1rem;background:var(--card)}
.guide-card .gc-step{display:inline-flex;align-items:center;justify-content:center;width:26px;height:26px;
  border-radius:50%;background:#eef3ff;color:var(--brand);font-weight:700;font-size:.85rem;margin-bottom:.5rem}
.guide-card h4{margin:.1rem 0 .35rem;font-size:1rem}
.guide-card p{margin:0;color:var(--muted);font-size:.88rem;line-height:1.45}
.guide-card .gc-link{display:inline-block;margin-top:.5rem;font-size:.85rem;font-weight:600}
.guide-actions{display:flex;gap:.6rem;align-items:center;margin-top:.4rem}

@media (max-width:720px){
  .signup-item{flex-direction:column;align-items:flex-start}
}
