/* ============================================================
   REYAH PLATFORM, app chrome
   Built on top of reyah-web.css tokens (clinical premium, light)
   Sidebar app · data tables · KPI cards · SVG charts
   ============================================================ */

:root{
  --side-w:256px;
  --topbar-h:68px;
  --pos:#1F8A5B;            /* positive / healthy green */
  --pos-wash:#E8F5EE;
  --pos-line:#BFE4CF;
  --warn:#C77B12;          /* warning amber */
  --warn-wash:#FBF1DF;
  --warn-line:#F0DBB0;
  --bad:#D81F23;           /* bounce / error (reuse accent-ink) */
  --bad-wash:#FCE9E8;
  --info:#2A6FDB;          /* email / neutral channel blue */
  --info-wash:#E8F0FC;
}

/* kill the marketing page blooms/grain inside the app for a calmer canvas */
body.app::before,body.app::after{display:none!important;}
body.app{background:var(--bg-soft);}

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

/* ---------- sidebar ---------- */
.side{
  position:sticky;top:0;height:100vh;
  background:var(--bg);border-right:1px solid var(--line);
  display:flex;flex-direction:column;gap:4px;padding:20px 16px;z-index:40;
}
.side__logo{display:flex;align-items:center;justify-content:center;gap:10px;padding:6px 8px 18px;}
.side__logo img{height:24px;width:auto;}
.side__org{
  display:flex;align-items:center;gap:10px;padding:11px 14px;margin-bottom:10px;
  border:1px solid var(--line);border-radius:var(--r-sm);background:var(--bg);cursor:pointer;
  width:100%;text-align:left;font-family:inherit;transition:border-color .15s ease,background .15s ease;
}
.side__org:hover{border-color:var(--line-strong);background:var(--bg-soft);}
.side__org .nm{flex:1;min-width:0;font-size:var(--fs-sm);font-weight:600;color:var(--ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.side__org .chev{color:var(--muted);flex:0 0 auto;display:flex;}
.side__org .chev svg{width:16px;height:16px;}

.side__label{font-size:10.5px;font-weight:600;letter-spacing:0.13em;text-transform:uppercase;color:var(--faint);padding:14px 12px 6px;}
.navitem{
  display:flex;align-items:center;gap:12px;padding:9px 12px;border-radius:10px;
  font-size:var(--fs-sm);font-weight:500;color:var(--ink-2);cursor:pointer;
  transition:background .14s ease,color .14s ease;position:relative;border:none;background:none;width:100%;text-align:left;font-family:inherit;
}
.navitem svg{width:18px;height:18px;flex:0 0 auto;color:var(--muted);transition:color .14s ease;}
.navitem:hover{background:var(--bg-soft-2);color:var(--ink);}
.navitem.active{background:var(--accent-wash);color:var(--accent-ink);font-weight:600;}
.navitem.active svg{color:var(--accent-2);}
.navitem .count{margin-left:auto;font-size:11px;font-weight:700;font-family:var(--f-mono);background:var(--bg-soft-2);color:var(--ink-2);padding:1px 8px;border-radius:999px;}
.navitem.active .count{background:#fff;color:var(--accent-ink);}
.navitem .count.hot{background:var(--grad);color:#fff;}
.side__foot{margin-top:auto;padding-top:14px;border-top:1px solid var(--line-soft);}
.side__user{display:flex;align-items:center;gap:10px;padding:8px 10px;border-radius:10px;cursor:pointer;}
.side__user:hover{background:var(--bg-soft-2);}
.side__user .av{width:32px;height:32px;border-radius:50%;background:var(--bg-soft-2);border:1px solid var(--line);display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;color:var(--ink-2);flex:0 0 auto;}
.side__user .nm{min-width:0;flex:1;}
.side__user .nm b{display:block;font-size:13px;font-weight:600;color:var(--ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.side__user .nm span{display:block;font-size:11px;color:var(--muted);}
.side__logout{width:32px;height:32px;border-radius:9px;border:1px solid transparent;background:none;display:flex;align-items:center;justify-content:center;color:var(--muted);cursor:pointer;flex:0 0 auto;transition:background .14s ease,color .14s ease,border-color .14s ease;}
.side__logout:hover{background:var(--bg-soft-2);color:var(--ink);border-color:var(--line);}
.side__logout svg{width:17px;height:17px;}

/* ---------- main column ---------- */
.main{min-width:0;display:flex;flex-direction:column;}
.topbar{
  position:sticky;top:0;z-index:30;height:var(--topbar-h);
  background:rgba(255,255,255,0.82);backdrop-filter:saturate(180%) blur(16px);-webkit-backdrop-filter:saturate(180%) blur(16px);
  border-bottom:1px solid var(--line);display:flex;align-items:center;gap:18px;padding:0 clamp(20px,3vw,38px);
}
.topbar__title{display:flex;flex-direction:column;gap:1px;min-width:0;}
.topbar__title h1{font-size:1.18rem;font-weight:600;letter-spacing:-0.02em;color:var(--ink);line-height:1.1;}
.topbar__title span{font-size:12px;color:var(--muted);}
.topbar__spacer{flex:1;}
.topbar__search{display:flex;align-items:center;gap:9px;background:var(--bg-soft);border:1px solid var(--line);border-radius:var(--r-pill);padding:9px 16px;width:min(320px,32vw);color:var(--muted);}
.topbar__search svg{width:16px;height:16px;flex:0 0 auto;}
.topbar__search input{border:none;background:none;outline:none;font-family:inherit;font-size:var(--fs-sm);color:var(--ink);width:100%;}
/* global search ----------------------------------------------------------- */
.topbar__search-wrap{position:relative;}
.topbar__search-wrap:focus-within .topbar__search{border-color:var(--line-strong);background:var(--bg);box-shadow:var(--sh-ring);}
.topbar__search-clear{border:none;background:none;cursor:pointer;color:var(--muted);display:flex;padding:0;flex:0 0 auto;}
.topbar__search-clear svg{width:15px;height:15px;}
.topbar__search-clear:hover{color:var(--ink);}
.searchpop{position:absolute;top:calc(100% + 10px);right:0;width:min(440px,86vw);max-height:min(560px,72vh);overflow-y:auto;
  background:var(--bg);border:1px solid var(--line);border-radius:var(--r-lg);box-shadow:var(--sh-pop);padding:7px;z-index:60;}
.searchpop__empty{padding:22px 16px;text-align:center;color:var(--muted);font-size:var(--fs-sm);}
.searchgrp{padding:5px 0;}
.searchgrp+.searchgrp{border-top:1px solid var(--line-soft);}
.searchgrp__h{display:flex;align-items:center;gap:8px;padding:5px 12px 7px;font-size:11px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--muted);}
.searchgrp__n{font-family:var(--f-mono);font-weight:700;background:var(--bg-soft-2);color:var(--ink-2);border-radius:999px;padding:0 7px;font-size:10px;}
.searchgrp__more{padding:4px 12px 2px;font-size:var(--fs-xs);color:var(--muted);}
.searchrow{display:flex;align-items:center;gap:11px;width:100%;text-align:left;border:none;background:none;cursor:pointer;
  padding:8px 12px;border-radius:var(--r-sm);font-family:inherit;transition:background .12s ease;}
.searchrow:hover{background:var(--bg-soft-2);}
.searchrow__av{width:30px;height:30px;border-radius:50%;flex:0 0 auto;display:flex;align-items:center;justify-content:center;
  background:var(--accent-wash);color:var(--accent-ink);font-size:11px;font-weight:700;}
.searchrow__main{display:flex;flex-direction:column;min-width:0;flex:1;}
.searchrow__label{font-size:var(--fs-sm);font-weight:600;color:var(--ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.searchrow__sub{font-size:var(--fs-xs);color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.searchrow .tag{flex:0 0 auto;}
.iconbtn{width:40px;height:40px;border-radius:11px;border:1px solid var(--line);background:var(--bg);display:flex;align-items:center;justify-content:center;color:var(--ink-2);cursor:pointer;position:relative;transition:border-color .15s ease,background .15s ease;}
.iconbtn:hover{border-color:var(--line-strong);background:var(--bg-soft);}
.iconbtn svg{width:18px;height:18px;}
.iconbtn .dot{position:absolute;top:8px;right:9px;width:8px;height:8px;border-radius:50%;background:var(--grad);border:2px solid var(--bg);}

/* ---------- content area ---------- */
.content{padding:clamp(20px,3vw,34px);max-width:1500px;width:100%;margin-inline:auto;flex:1;}
.page-head{display:flex;align-items:flex-end;justify-content:space-between;gap:20px;flex-wrap:wrap;margin-bottom:24px;}
.page-head h2{font-size:1.5rem;font-weight:600;letter-spacing:-0.025em;color:var(--ink);}
.page-head p{font-size:var(--fs-sm);color:var(--muted);margin-top:3px;}
.page-actions{display:flex;align-items:center;gap:10px;flex-wrap:wrap;}

/* segmented control / filter chips */
.seg{display:inline-flex;background:var(--bg-soft);border:1px solid var(--line);border-radius:var(--r-pill);padding:3px;gap:2px;}
.seg button{border:none;background:none;font-family:inherit;font-size:var(--fs-xs);font-weight:600;color:var(--muted);padding:7px 15px;border-radius:var(--r-pill);cursor:pointer;transition:.14s;white-space:nowrap;}
.seg button.active{background:#fff;color:var(--ink);box-shadow:var(--sh-xs);}

/* ---------- KPI grid ---------- */
.kpis{display:grid;grid-template-columns:repeat(auto-fit,minmax(190px,1fr));gap:16px;}
.kpi{background:var(--bg);border:1px solid var(--line);border-radius:var(--r-lg);padding:20px 22px;box-shadow:var(--sh-ring);position:relative;overflow:hidden;}
.kpi.clickable{cursor:pointer;transition:transform .2s var(--ease),box-shadow .25s var(--ease),border-color .2s var(--ease);}
.kpi.clickable:hover{transform:translateY(-3px);box-shadow:var(--sh-pop);border-color:var(--line-strong);}
.kpi.clickable::after{content:"";position:absolute;top:16px;right:16px;width:14px;height:14px;opacity:0;transition:opacity .2s ease;
  background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23697079' stroke-width='2.4' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M7 7h10v10'/%3E%3Cpath d='M7 17L17 7'/%3E%3C/svg%3E") center/contain no-repeat;}
.kpi.clickable:hover::after{opacity:0.7;}
.kpi.feature.clickable:hover::after{opacity:0;}
.kpi__top{display:flex;align-items:center;gap:9px;color:var(--muted);}
.kpi__top .ic{width:30px;height:30px;border-radius:9px;background:var(--bg-soft-2);display:flex;align-items:center;justify-content:center;color:var(--ink-2);flex:0 0 auto;}
.kpi__top .ic svg{width:16px;height:16px;}
.kpi__top .lab{font-size:var(--fs-xs);font-weight:600;letter-spacing:0.01em;}
.kpi__num{font-size:2.1rem;font-weight:700;letter-spacing:-0.04em;line-height:1;color:var(--ink);margin-top:14px;font-variant-numeric:tabular-nums;}
.kpi__num .u{font-size:0.5em;font-weight:600;color:var(--muted);margin-left:2px;letter-spacing:0;}
.kpi__sub{display:flex;align-items:center;gap:7px;margin-top:10px;font-size:var(--fs-xs);color:var(--muted);}
.delta{display:inline-flex;align-items:center;gap:3px;font-weight:700;font-variant-numeric:tabular-nums;}
.delta svg{width:12px;height:12px;}
.delta.up{color:var(--pos);}
.delta.down{color:var(--bad);}
.kpi.feature{background:var(--grad);color:#fff;border:none;box-shadow:var(--accent-glow);}
.kpi.feature .kpi__top,.kpi.feature .kpi__sub{color:rgba(255,255,255,0.88);}
.kpi.feature .kpi__top .ic{background:rgba(255,255,255,0.18);color:#fff;}
.kpi.feature .kpi__num{color:#fff;}
.kpi.feature .kpi__num .u{color:rgba(255,255,255,0.8);}
.kpi.feature .delta.up{color:#fff;}

/* ---------- generic card / panel ---------- */
.pcard{background:var(--bg);border:1px solid var(--line);border-radius:var(--r-lg);box-shadow:var(--sh-ring);}
.pcard__head{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:18px 22px;border-bottom:1px solid var(--line-soft);}
.pcard__head h3{font-size:1.02rem;font-weight:600;letter-spacing:-0.01em;color:var(--ink);}
.pcard__head .sub{font-size:var(--fs-xs);color:var(--muted);margin-top:2px;}
.pcard__body{padding:22px;}
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:18px;}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;}
.grid-32{display:grid;grid-template-columns:1.7fr 1fr;gap:18px;}
.grid-23{display:grid;grid-template-columns:1fr 1.7fr;gap:18px;}
.stack-gap{display:flex;flex-direction:column;gap:18px;}

/* ---------- status badges ---------- */
.tag{display:inline-flex;align-items:center;gap:6px;font-size:11.5px;font-weight:600;padding:3px 10px;border-radius:var(--r-pill);white-space:nowrap;letter-spacing:0.01em;}
.tag .d{width:6px;height:6px;border-radius:50%;background:currentColor;}
.tag--pos{background:var(--pos-wash);color:var(--pos);}
.tag--warn{background:var(--warn-wash);color:var(--warn);}
.tag--bad{background:var(--bad-wash);color:var(--bad);}
.tag--info{background:var(--info-wash);color:var(--info);}
.tag--neutral{background:var(--bg-soft-2);color:var(--ink-2);}
.tag--accent{background:var(--accent-wash);color:var(--accent-ink);}

/* channel chips */
.chan{display:inline-flex;align-items:center;gap:6px;font-family:var(--f-mono);font-size:10.5px;font-weight:500;letter-spacing:0.04em;text-transform:uppercase;padding:3px 9px;border-radius:6px;}
.chan--email{background:var(--info-wash);color:var(--info);}
.chan--sms{background:var(--pos-wash);color:var(--pos);}
.chan--vm{background:var(--accent-wash);color:var(--accent-ink);}

/* ---------- data table ---------- */
.tbl-wrap{overflow-x:auto;}
table.tbl{width:100%;border-collapse:separate;border-spacing:0;font-size:var(--fs-sm);}
.tbl thead th{
  text-align:left;font-size:11px;font-weight:600;letter-spacing:0.06em;text-transform:uppercase;color:var(--muted);
  padding:11px 16px;border-bottom:1px solid var(--line);white-space:nowrap;background:var(--bg-soft);position:sticky;top:0;
}
.tbl thead th.num,.tbl td.num{text-align:right;font-variant-numeric:tabular-nums;}
.tbl tbody td{padding:13px 16px;border-bottom:1px solid var(--line-soft);color:var(--ink-2);vertical-align:middle;}
.tbl tbody tr{transition:background .12s ease;cursor:pointer;}
.tbl tbody tr:hover{background:var(--bg-soft);}
.tbl tbody tr:last-child td{border-bottom:none;}
.tbl .docname{display:flex;align-items:center;gap:11px;}
.tbl .docname .av{width:32px;height:32px;border-radius:50%;background:var(--bg-soft-2);border:1px solid var(--line);display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;color:var(--ink-2);flex:0 0 auto;}
.tbl .docname b{font-weight:600;color:var(--ink);display:block;}
.tbl .docname span{font-size:11.5px;color:var(--muted);}

/* ---------- mini progress / meter ---------- */
.meter{height:7px;border-radius:999px;background:var(--bg-soft-2);overflow:hidden;}
.meter > i{display:block;height:100%;border-radius:999px;background:var(--grad);}
.meter.pos > i{background:var(--pos);}
.meter.warn > i{background:var(--warn);}
.meter.info > i{background:var(--info);}

/* ---------- domain health row ---------- */
.dhrow{display:grid;grid-template-columns:1.6fr 0.7fr 0.7fr 0.8fr 1fr;gap:14px;align-items:center;padding:15px 0;border-bottom:1px solid var(--line-soft);}
.dhrow:last-child{border-bottom:none;}
.dhrow .dom{font-family:var(--f-mono);font-size:13px;color:var(--ink);font-weight:500;}
.dhrow .mini{font-size:11px;color:var(--muted);margin-top:2px;}
.dhrow .auth{display:flex;gap:6px;}
.authpill{font-size:10px;font-weight:700;font-family:var(--f-mono);padding:2px 6px;border-radius:5px;background:var(--pos-wash);color:var(--pos);letter-spacing:0.02em;}
.authpill.off{background:var(--bad-wash);color:var(--bad);}

/* ---------- activity feed / timeline ---------- */
.feed{display:flex;flex-direction:column;}
.feed__item{display:grid;grid-template-columns:34px 1fr auto;gap:13px;padding:13px 0;border-bottom:1px solid var(--line-soft);align-items:start;}
.feed__item:last-child{border-bottom:none;}
.feed__ic{width:34px;height:34px;border-radius:9px;display:flex;align-items:center;justify-content:center;flex:0 0 auto;}
.feed__ic svg{width:16px;height:16px;}
.feed__ic.pos{background:var(--pos-wash);color:var(--pos);}
.feed__ic.info{background:var(--info-wash);color:var(--info);}
.feed__ic.accent{background:var(--accent-wash);color:var(--accent-2);}
.feed__ic.neutral{background:var(--bg-soft-2);color:var(--ink-2);}
.feed__b b{font-size:var(--fs-sm);font-weight:600;color:var(--ink);}
.feed__b p{font-size:13px;color:var(--muted);margin-top:1px;}
.feed__time{font-size:11.5px;color:var(--faint);white-space:nowrap;font-variant-numeric:tabular-nums;}

/* ---------- pipeline columns ---------- */
.kanban{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;align-items:start;}
.kcol{background:var(--bg-soft);border:1px solid var(--line);border-radius:var(--r-lg);padding:0 13px 13px;max-height:calc(100vh - var(--topbar-h) - 252px);min-height:280px;overflow-y:auto;}
.kcol__head{display:flex;align-items:center;justify-content:space-between;margin-bottom:11px;padding:13px 4px 9px;position:sticky;top:0;background:var(--bg-soft);z-index:1;}
.kcol__head b{font-size:var(--fs-xs);font-weight:600;color:var(--ink-2);letter-spacing:0.01em;}
.kcol__head .n{font-size:11px;font-weight:700;font-family:var(--f-mono);color:var(--muted);background:#fff;border:1px solid var(--line);padding:1px 8px;border-radius:999px;}
.kcard{background:#fff;border:1px solid var(--line);border-radius:var(--r-sm);padding:13px;box-shadow:var(--sh-xs);margin-bottom:10px;cursor:pointer;transition:transform .15s ease,box-shadow .2s ease;}
.kcard:last-child{margin-bottom:0;}
.kcard:hover{transform:translateY(-2px);box-shadow:var(--sh-sm);}
.kcard__name{display:flex;align-items:center;gap:9px;}
.kcard__name .av{width:30px;height:30px;border-radius:50%;background:var(--bg-soft-2);border:1px solid var(--line);display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;color:var(--ink-2);flex:0 0 auto;}
.kcard__name b{font-size:13.5px;font-weight:600;color:var(--ink);}
.kcard__name span{font-size:11px;color:var(--muted);display:block;}
.kcard__meta{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-top:11px;}

/* ---------- inbox / message list ---------- */
.inbox{display:grid;grid-template-columns:360px 1fr;height:calc(100vh - var(--topbar-h) - 76px);min-height:480px;}
.inbox__list{border-right:1px solid var(--line-soft);overflow-y:auto;min-height:0;}
.msg{display:grid;grid-template-columns:40px 1fr;gap:12px;padding:15px 18px;border-bottom:1px solid var(--line-soft);cursor:pointer;transition:background .12s ease;}
.msg:hover{background:var(--bg-soft);}
.msg.active{background:var(--accent-wash);}
.msg.unread{background:rgba(255,74,28,0.035);}
.msg .av{width:40px;height:40px;border-radius:50%;background:var(--bg-soft-2);border:1px solid var(--line);display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:700;color:var(--ink-2);}
.msg__top{display:flex;align-items:baseline;justify-content:space-between;gap:10px;}
.msg__top b{font-size:13.5px;font-weight:600;color:var(--ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.msg.unread .msg__top b::before{content:"";display:inline-block;width:7px;height:7px;border-radius:50%;background:var(--grad);margin-right:7px;vertical-align:middle;}
.msg__top time{font-size:11px;color:var(--faint);white-space:nowrap;flex:0 0 auto;}
.msg__pre{font-size:12.5px;color:var(--muted);margin-top:3px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;}
.msg__tags{display:flex;gap:6px;margin-top:8px;}
.thread{display:flex;flex-direction:column;min-height:0;}
.thread__head{padding:18px 24px;border-bottom:1px solid var(--line-soft);}
.thread__head h3{font-size:1.05rem;font-weight:600;color:var(--ink);}
.thread__head .meta{display:flex;align-items:center;gap:10px;margin-top:6px;flex-wrap:wrap;}
.thread__body{padding:22px 24px;display:flex;flex-direction:column;gap:16px;overflow-y:auto;flex:1;min-height:0;}
.bubble{max-width:80%;padding:14px 17px;border-radius:16px;font-size:var(--fs-sm);line-height:1.55;}
.bubble.them{align-self:flex-start;background:var(--bg-soft);border:1px solid var(--line);color:var(--ink-2);border-bottom-left-radius:5px;}
.bubble.us{align-self:flex-end;background:var(--grad);color:#fff;border-bottom-right-radius:5px;}
.bubble .who{display:block;font-size:11px;font-weight:600;opacity:0.7;margin-bottom:4px;}
.bubble--sending{opacity:0.65;}
.bubble--failed.us{background:var(--bad-wash);color:var(--bad);box-shadow:inset 0 0 0 1px var(--bad);}
.bubble--failed.us .who{opacity:0.85;}
.bubble__status{display:flex;align-items:center;gap:8px;margin-top:6px;font-size:11px;font-weight:600;opacity:0.85;}
.bubble__retry{border:1px solid currentColor;background:transparent;color:inherit;font:inherit;font-size:11px;font-weight:700;padding:2px 10px;border-radius:999px;cursor:pointer;line-height:1.4;}
.bubble__retry:hover{background:var(--bad);color:#fff;border-color:var(--bad);}
.thread__reply{margin-top:auto;border-top:1px solid var(--line-soft);padding:16px 24px;display:flex;gap:11px;align-items:center;}
.thread__reply input{flex:1;border:1px solid var(--line);border-radius:var(--r-pill);padding:12px 18px;font-family:inherit;font-size:var(--fs-sm);outline:none;}
.thread__reply input:focus{border-color:var(--accent-line);}

/* ---------- empty state ---------- */
.empty{text-align:center;padding:56px 20px;color:var(--muted);}
.empty svg{width:40px;height:40px;color:var(--line-strong);margin-bottom:14px;}

/* ---------- metric drawer ---------- */
.drawer-scrim{position:fixed;inset:0;z-index:120;background:rgba(14,18,23,0.34);backdrop-filter:blur(2px);display:flex;justify-content:flex-end;opacity:1;}
.drawer-panel{width:min(520px,94vw);height:100%;background:var(--bg);border-left:1px solid var(--line);box-shadow:-20px 0 60px rgba(14,18,23,0.18);display:flex;flex-direction:column;overflow:hidden;}
@media (prefers-reduced-motion:no-preference){
  .drawer-scrim{animation:scrimIn .2s ease;}
  .drawer-panel{animation:drawerIn .26s var(--ease);}
}
@keyframes scrimIn{from{opacity:0;}to{opacity:1;}}
@keyframes drawerIn{from{transform:translateX(40px);}to{transform:none;}}
.drawer-head{padding:22px 26px 20px;border-bottom:1px solid var(--line-soft);}
.drawer-head__top{display:flex;align-items:center;font-size:18px;margin-bottom:14px;}
.drawer-lab{font-size:var(--fs-xs);font-weight:600;letter-spacing:0.04em;color:var(--muted);text-transform:uppercase;}
.drawer-val{font-size:2.6rem;font-weight:700;letter-spacing:-0.04em;line-height:1;color:var(--ink);margin-top:8px;font-variant-numeric:tabular-nums;}
.drawer-val .u{font-size:0.42em;font-weight:600;color:var(--muted);margin-left:3px;}
.drawer-sub{display:flex;align-items:center;gap:9px;margin-top:12px;font-size:var(--fs-xs);color:var(--muted);}
.drawer-body{padding:20px 26px 40px;overflow-y:auto;}
.drawer-rangerow{display:flex;align-items:center;justify-content:space-between;gap:14px;}
.drawer-secn{font-size:var(--fs-xs);font-weight:600;letter-spacing:0.04em;color:var(--ink-2);text-transform:uppercase;}
.drawer-mini{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-top:16px;}
.drawer-stat{background:var(--bg-soft);border:1px solid var(--line-soft);border-radius:var(--r-sm);padding:14px 16px;}
.drawer-stat span{display:block;font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:0.05em;font-weight:600;}
.drawer-stat b{display:block;font-size:1.3rem;font-weight:700;letter-spacing:-0.02em;color:var(--ink);margin-top:5px;font-variant-numeric:tabular-nums;}

/* ---------- legend ---------- */
.legend{display:flex;flex-wrap:wrap;gap:14px;}
.legend span{display:inline-flex;align-items:center;gap:7px;font-size:var(--fs-xs);color:var(--muted);}
.legend i{width:11px;height:11px;border-radius:3px;display:inline-block;}

/* ---------- admin client row ---------- */
.crow .health{display:flex;align-items:center;gap:9px;}
.dotstat{width:9px;height:9px;border-radius:50%;flex:0 0 auto;}
.dotstat.pos{background:var(--pos);}
.dotstat.warn{background:var(--warn);}
.dotstat.bad{background:var(--bad);}

/* ---------- toggle switch ---------- */
.switch{width:42px;height:24px;border-radius:999px;background:var(--line-strong);position:relative;border:none;cursor:pointer;transition:background .18s ease;flex:0 0 auto;padding:0;}
.switch.on{background:var(--accent-2);}
.switch i{position:absolute;top:3px;left:3px;width:18px;height:18px;border-radius:50%;background:#fff;box-shadow:var(--sh-xs);transition:transform .18s ease;}
.switch.on i{transform:translateX(18px);}

/* ---------- settings ---------- */
.settabs{display:flex;gap:2px;border-bottom:1px solid var(--line);margin-bottom:6px;flex-wrap:wrap;}
.settabs button{border:none;background:none;font-family:inherit;font-size:var(--fs-sm);font-weight:600;color:var(--muted);padding:11px 14px;cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-1px;transition:color .14s ease;}
.settabs button:hover{color:var(--ink-2);}
.settabs button.active{color:var(--ink);border-bottom-color:var(--accent-2);}
.setrow{display:flex;align-items:center;justify-content:space-between;gap:24px;padding:16px 0;border-bottom:1px solid var(--line-soft);}
.setrow:last-child{border-bottom:none;}
.setrow .lab b{display:block;font-size:var(--fs-sm);font-weight:600;color:var(--ink);}
.setrow .lab span{display:block;font-size:12.5px;color:var(--muted);margin-top:2px;max-width:56ch;line-height:1.45;}
.setinput{border:1px solid var(--line-strong);border-radius:var(--r-sm);padding:10px 13px;font-family:inherit;font-size:var(--fs-sm);color:var(--ink);background:var(--bg);outline:none;min-width:230px;}
.setinput:focus{border-color:var(--accent-line);}

/* ---------- notifications dropdown ---------- */
.noti__scrim{position:fixed;inset:0;z-index:105;}
.noti{position:fixed;top:62px;right:clamp(16px,3vw,38px);width:min(392px,92vw);background:var(--bg);border:1px solid var(--line);border-radius:var(--r-lg);box-shadow:var(--sh-pop);z-index:110;overflow:hidden;}
.noti__head{display:flex;align-items:center;justify-content:space-between;padding:15px 18px;border-bottom:1px solid var(--line-soft);}
.noti__head b{font-size:var(--fs-sm);font-weight:600;color:var(--ink);}
.noti__list{max-height:62vh;overflow-y:auto;}
.noti__item{display:grid;grid-template-columns:34px 1fr;gap:12px;padding:14px 18px;border-bottom:1px solid var(--line-soft);}
.noti__item.unread{background:rgba(255,74,28,0.04);}
.noti__item:last-child{border-bottom:none;}
.noti__b b{font-size:13.5px;font-weight:600;color:var(--ink);display:block;}
.noti__b p{font-size:12.5px;color:var(--muted);margin-top:1px;}
.noti__b time{font-size:11px;color:var(--faint);display:block;margin-top:4px;}

/* ---------- integration cards ---------- */
.intg-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:18px;}
.intg{background:var(--bg);border:1px solid var(--line);border-radius:var(--r-lg);box-shadow:var(--sh-ring);padding:22px;display:flex;flex-direction:column;}
.intg__top{display:flex;align-items:center;gap:13px;}
.intg__tile{width:42px;height:42px;border-radius:11px;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:13px;letter-spacing:0.02em;flex:0 0 auto;}
.intg__tile--logo{background:#fff;border:1px solid var(--line);overflow:hidden;}
.intg__tile--logo img{width:100%;height:100%;object-fit:contain;}
.intg__name{font-size:1.02rem;font-weight:600;color:var(--ink);display:block;}
.intg__cat{font-size:12px;color:var(--muted);display:block;margin-top:1px;}
.intg__desc{font-size:13.5px;color:var(--body);line-height:1.5;margin-top:14px;flex:1;}
.intg__foot{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-top:18px;}
.intg__detail{font-size:12px;color:var(--muted);font-variant-numeric:tabular-nums;}

/* ---------- modal ---------- */
.modal__scrim{position:fixed;inset:0;z-index:130;background:rgba(14,18,23,0.4);backdrop-filter:blur(2px);display:flex;align-items:center;justify-content:center;padding:20px;}
.modal{width:min(480px,94vw);background:var(--bg);border:1px solid var(--line);border-radius:var(--r-xl);box-shadow:var(--sh-lg);overflow:hidden;}
.modal__head{display:flex;align-items:center;gap:13px;padding:20px 22px;border-bottom:1px solid var(--line-soft);}
.modal__body{padding:22px;}
.modal__note{display:flex;gap:12px;align-items:flex-start;margin-top:16px;padding:15px;border-radius:var(--r-sm);background:var(--bg-soft);border:1px solid var(--line-soft);font-size:13px;color:var(--ink-2);line-height:1.5;}
.modal__note svg{width:18px;height:18px;color:var(--pos);flex:0 0 auto;margin-top:1px;}
.modal__note code{font-family:var(--f-mono);font-size:12px;background:var(--bg-soft-2);padding:1px 6px;border-radius:5px;color:var(--ink-2);}
.modal__foot{display:flex;justify-content:flex-end;gap:10px;padding:16px 22px;border-top:1px solid var(--line-soft);}

/* ---------- lead / contact drawer ---------- */
.lead-av{width:42px;height:42px;border-radius:12px;background:var(--grad);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:14px;flex:0 0 auto;letter-spacing:-0.02em;}
.lead-actions{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;margin-top:18px;}
.lead-act{display:flex;flex-direction:column;align-items:center;gap:5px;padding:11px 6px;border:1px solid var(--line);border-radius:var(--r-sm);background:var(--bg);cursor:pointer;font-family:inherit;color:var(--ink-2);font-size:11.5px;font-weight:600;transition:.14s;}
.lead-act:hover{border-color:var(--accent-line);background:var(--accent-wash);color:var(--accent-ink);transform:translateY(-2px);}
.lead-act svg{width:18px;height:18px;}
.lead-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;}
.lead-field{display:flex;align-items:center;gap:11px;padding:13px;border:1px solid var(--line-soft);border-radius:var(--r-sm);background:var(--bg-soft);text-decoration:none;}
a.lead-field{cursor:pointer;transition:border-color .14s ease,background .14s ease;}
a.lead-field:hover{border-color:var(--line-strong);background:var(--bg);}
.lead-field__ic{width:32px;height:32px;border-radius:9px;background:#fff;border:1px solid var(--line);display:flex;align-items:center;justify-content:center;color:var(--ink-2);flex:0 0 auto;}
.lead-field__ic svg{width:16px;height:16px;}
.lead-field__l{display:block;font-size:11px;color:var(--muted);margin-bottom:2px;}
.lead-field b{font-size:13px;color:var(--ink);font-weight:600;word-break:break-word;}
.lead-secn{display:flex;align-items:center;justify-content:space-between;gap:10px;font-size:var(--fs-xs);font-weight:600;letter-spacing:0.04em;text-transform:uppercase;color:var(--ink-2);margin:24px 0 10px;}
.lead-sync{display:inline-flex;align-items:center;gap:5px;font-size:10.5px;font-weight:600;letter-spacing:0;text-transform:none;color:var(--pos);}
.lead-sync svg{width:12px;height:12px;}
.lead-notes{width:100%;min-height:96px;border:1px solid var(--line-strong);border-radius:var(--r-sm);padding:12px 14px;font-family:inherit;font-size:var(--fs-sm);color:var(--ink);background:var(--bg);outline:none;resize:vertical;line-height:1.5;}
.lead-notes:focus{border-color:var(--accent-line);}

/* ---------- kanban drag ---------- */
.kcard{cursor:grab;}
.kcard:active{cursor:grabbing;}
.kcard.dragging{opacity:0.5;}
.kcol.dragover{outline:2px dashed var(--accent-line);outline-offset:-2px;background:var(--accent-wash);}
.kcard__stagebtn{margin-top:10px;}

/* ---------- inbox channel bar + composer ---------- */
.thread__chan{display:flex;align-items:center;gap:7px;flex-wrap:wrap;margin-top:10px;}
.chanbtn{display:inline-flex;align-items:center;gap:6px;padding:7px 12px;border:1px solid var(--line);border-radius:var(--r-pill);background:var(--bg);cursor:pointer;font-family:inherit;font-size:12px;font-weight:600;color:var(--ink-2);transition:.14s;}
.chanbtn:hover{border-color:var(--accent-line);background:var(--accent-wash);color:var(--accent-ink);}
.chanbtn svg{width:14px;height:14px;}
.composer{margin-top:auto;border-top:1px solid var(--line-soft);padding:14px 24px 18px;}
.composer__tabs{display:flex;gap:4px;margin-bottom:11px;}
.composer__tab{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;border-radius:var(--r-pill);border:1px solid transparent;background:none;cursor:pointer;font-family:inherit;font-size:12px;font-weight:600;color:var(--muted);}
.composer__tab svg{width:14px;height:14px;}
.composer__tab.active{background:var(--bg-soft-2);color:var(--ink);}
.composer__row{display:flex;gap:11px;align-items:center;}
.composer__row input{flex:1;border:1px solid var(--line);border-radius:var(--r-pill);padding:12px 18px;font-family:inherit;font-size:var(--fs-sm);outline:none;}
.composer__row input:focus{border-color:var(--accent-line);}
.composer__hint{font-size:11px;color:var(--muted);margin-top:8px;display:flex;align-items:center;gap:6px;}
.composer__hint svg{width:12px;height:12px;color:var(--pos);}
/* channel-aware email composer */
.composer__email{display:flex;flex-direction:column;gap:8px;}
.composer__email input,.composer__email textarea,.composer__email select{border:1px solid var(--line);border-radius:12px;padding:10px 14px;font-family:inherit;font-size:var(--fs-sm);outline:none;background:#fff;}
.composer__email input:focus,.composer__email textarea:focus,.composer__email select:focus{border-color:var(--accent-line);}
.composer__subject,.composer__preheader{width:100%;}
.composer__preheader{font-size:12px;color:var(--muted);}
.composer__row{display:flex;gap:11px;align-items:center;}
.composer__email .composer__row{align-items:flex-end;gap:8px;}
.composer__body{flex:1;resize:none;min-height:38px;max-height:200px;line-height:1.5;}
.composer__domain{max-width:200px;}
.composer__attach{width:34px;height:34px;border-radius:8px;font-size:18px;line-height:1;border:1px solid var(--line);background:var(--bg-soft);cursor:pointer;flex:none;}
.composer__attach:hover{border-color:var(--accent-line);}
.composer__chips,.bubble__atts{display:flex;flex-wrap:wrap;gap:6px;}
.bubble__atts{margin-top:8px;}
.att-chip{display:inline-flex;align-items:center;gap:6px;padding:3px 8px;border-radius:999px;background:var(--chip-bg,#eef2ff);color:var(--ink-2);font-size:12px;}
.bubble.us .att-chip{background:rgba(255,255,255,0.22);color:#fff;}
.att-chip__x{border:none;background:none;cursor:pointer;font-size:14px;line-height:1;color:inherit;padding:0;}
.att-chip--sm{font-size:11px;}
.bubble__subject{font-weight:600;margin-bottom:2px;}

/* ---------- bookings schedule ---------- */
.bk-day{margin-bottom:10px;}
.bk-day__h{display:flex;align-items:center;gap:10px;font-size:var(--fs-xs);font-weight:700;letter-spacing:0.04em;text-transform:uppercase;color:var(--muted);padding:14px 4px 10px;}
.bk-day__h .ln{flex:1;height:1px;background:var(--line-soft);}
.bk{display:grid;grid-template-columns:96px 1fr auto;gap:16px;align-items:center;padding:15px 16px;border:1px solid var(--line);border-radius:var(--r-lg);background:var(--bg);box-shadow:var(--sh-xs);margin-bottom:10px;cursor:pointer;transition:transform .15s ease,box-shadow .2s ease,border-color .15s ease;}
.bk:hover{transform:translateY(-2px);box-shadow:var(--sh-sm);border-color:var(--line-strong);}
.bk__time{text-align:center;border-right:1px solid var(--line-soft);padding-right:14px;}
.bk__time b{display:block;font-size:1.05rem;font-weight:700;color:var(--ink);letter-spacing:-0.02em;}
.bk__time span{display:block;font-size:11px;color:var(--muted);margin-top:2px;}
.bk__who{display:flex;align-items:center;gap:12px;min-width:0;}
.bk__who .av{width:38px;height:38px;border-radius:50%;background:var(--bg-soft-2);border:1px solid var(--line);display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;color:var(--ink-2);flex:0 0 auto;}
.bk__who b{font-size:var(--fs-sm);font-weight:600;color:var(--ink);display:block;}
.bk__who span{font-size:12px;color:var(--muted);}

/* ---------- filter chips ---------- */
.chip{display:inline-flex;align-items:center;gap:6px;padding:7px 13px;border-radius:var(--r-pill);border:1px solid var(--line-strong);background:var(--bg);font-size:var(--fs-xs);font-weight:600;color:var(--ink-2);cursor:pointer;transition:.14s;white-space:nowrap;}
.chip:hover{border-color:var(--ink-2);}
.chip.active{background:var(--accent-wash);border-color:var(--accent);color:var(--accent-ink);}
.chip small{font-weight:700;opacity:0.65;font-size:0.85em;}
.inbox__filter{display:flex;gap:8px;padding:12px 14px;border-bottom:1px solid var(--line-soft);}
.bk__status{border:none;background:none;cursor:pointer;padding:0;}

/* ---------- custom select ---------- */
.rsel{position:relative;display:inline-block;min-width:230px;}
.rsel--full{display:block;width:100%;min-width:0;}
.rsel__btn{display:flex;align-items:center;justify-content:space-between;gap:10px;width:100%;border:1px solid var(--line-strong);border-radius:var(--r-sm);padding:10px 13px;font-family:inherit;font-size:var(--fs-sm);font-weight:500;color:var(--ink);background:var(--bg);cursor:pointer;transition:border-color .14s ease,box-shadow .14s ease;}
.rsel__btn:hover{border-color:var(--ink-2);}
.rsel__btn.open{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-wash);}
.rsel__btn svg{width:16px;height:16px;color:var(--muted);transition:transform .18s ease;flex:0 0 auto;}
.rsel__btn.open svg{transform:rotate(180deg);}
.rsel__ph{color:var(--muted);}
.rsel__menu{position:absolute;top:calc(100% + 6px);left:0;right:0;background:var(--bg);border:1px solid var(--line);border-radius:var(--r-sm);box-shadow:var(--sh-pop);padding:5px;z-index:140;max-height:260px;overflow-y:auto;animation:rselin .14s ease;}
@keyframes rselin{from{opacity:0;transform:translateY(-4px);}to{opacity:1;transform:none;}}
.rsel__opt{display:flex;align-items:center;justify-content:space-between;gap:10px;width:100%;border:none;background:none;font-family:inherit;font-size:var(--fs-sm);font-weight:500;color:var(--ink-2);text-align:left;padding:9px 11px;border-radius:8px;cursor:pointer;transition:background .12s ease,color .12s ease;}
.rsel__opt:hover{background:var(--bg-soft-2);color:var(--ink);}
.rsel__opt.active{background:var(--accent-wash);color:var(--accent-ink);font-weight:600;}
.rsel__opt svg{width:15px;height:15px;flex:0 0 auto;}

/* editable hire-status pill — content-width trigger + small dropdown */
.statpill{position:relative;display:inline-flex;}
.statpill__btn{border:none;cursor:pointer;font-family:inherit;}
.statpill__chev{width:11px;height:11px;margin-left:1px;opacity:.6;transition:opacity .14s ease;}
.statpill__btn:hover .statpill__chev{opacity:1;}
.statpill__menu{position:absolute;top:calc(100% + 6px);left:0;background:var(--bg);border:1px solid var(--line);border-radius:var(--r-sm);box-shadow:var(--sh-pop);padding:5px;z-index:140;white-space:nowrap;animation:rselin .14s ease;}
.statpill__opt{display:flex;align-items:center;gap:8px;width:100%;border:none;background:none;font-family:inherit;font-size:var(--fs-sm);font-weight:500;color:var(--ink-2);text-align:left;padding:8px 11px;border-radius:8px;cursor:pointer;white-space:nowrap;transition:background .12s ease,color .12s ease;}
.statpill__opt:hover{background:var(--bg-soft-2);color:var(--ink);}
.statpill__opt.active{color:var(--ink);font-weight:600;}
.statpill__opt svg{width:14px;height:14px;margin-left:4px;color:var(--accent);flex:0 0 auto;}
.statpill__dot{width:7px;height:7px;border-radius:50%;flex:0 0 auto;}
.statpill__dot--info{background:var(--info);}
.statpill__dot--pos{background:var(--pos);}

/* ---------- toast ---------- */
.ry-toasts{position:fixed;left:50%;bottom:24px;transform:translateX(-50%);z-index:200;display:flex;flex-direction:column;gap:10px;align-items:center;pointer-events:none;}
.ry-toast{display:flex;align-items:center;gap:10px;background:var(--ink-bg);color:#fff;padding:12px 18px;border-radius:var(--r-pill);box-shadow:var(--sh-lg);font-size:var(--fs-sm);font-weight:500;white-space:nowrap;transition:opacity .26s ease,transform .26s ease;}
.ry-toast__c{width:8px;height:8px;border-radius:50%;background:#3DDC8B;box-shadow:0 0 0 4px rgba(61,220,139,0.18);flex:0 0 auto;}

/* ---------- chart hover ---------- */
.chartwrap{position:relative;cursor:crosshair;}
.chart-cross{position:absolute;top:4px;bottom:24px;width:1px;background:var(--line-strong);transform:translateX(-0.5px);pointer-events:none;}
.chart-dot{position:absolute;width:11px;height:11px;border-radius:50%;background:#fff;border:2.5px solid var(--ink);transform:translate(-50%,-50%);box-shadow:var(--sh-sm);pointer-events:none;}
.chart-tip{position:absolute;top:0;transform:translateX(-50%);background:var(--ink-bg);color:#fff;border-radius:10px;padding:9px 12px;box-shadow:var(--sh-lg);pointer-events:none;min-width:96px;z-index:5;}
.chart-tip b{display:block;font-size:11px;font-weight:600;color:rgba(255,255,255,0.7);margin-bottom:5px;letter-spacing:0.02em;}
.chart-tip__r{display:flex;align-items:center;gap:7px;font-size:12.5px;line-height:1.5;}
.chart-tip__r i{width:9px;height:9px;border-radius:3px;flex:0 0 auto;}
.chart-tip__r span{color:rgba(255,255,255,0.78);}
.chart-tip__r em{font-style:normal;font-weight:700;margin-left:auto;font-variant-numeric:tabular-nums;}

/* ---------- responsive ---------- */
@media (max-width:1100px){
  .grid-32,.grid-23,.grid-2,.grid-3{grid-template-columns:1fr;}
  .kanban{grid-template-columns:1fr 1fr;}
  .inbox{grid-template-columns:1fr;height:auto;}
  .inbox__list{max-height:none;border-right:none;border-bottom:1px solid var(--line-soft);}
}
@media (max-width:860px){
  :root{--side-w:0px;}
  .side{display:none;}
  .shell{grid-template-columns:1fr;}
  .kanban{grid-template-columns:1fr;}
  .topbar__search{display:none;}
}
