/* ===== Komptia design system ===== */
:root{
  --bg:#f4f6fb; --panel:#fff; --ink:#0f172a; --muted:#6b7593; --faint:#9aa3bd; --line:#e9ecf6;
  --brand:#4f46e5; --brand2:#6366f1; --brandsoft:#eef0ff;
  --ok:#0f9d6a; --okSoft:#e6f7ef; --warn:#d98a00; --warnSoft:#fdf2dc; --bad:#e23b4e; --badSoft:#fdecee;
  --violet:#8b5cf6; --violetSoft:#f0eaff;
  --side1:#0d1230; --side2:#141a44; --sideink:#aab1d6; --sideink2:#7a83ad;
  --r:16px; --r-sm:11px; --sh:0 10px 30px -12px rgba(20,26,68,.18); --sh-sm:0 4px 14px -8px rgba(20,26,68,.25);
  --t:.22s cubic-bezier(.4,0,.2,1);
}
*{box-sizing:border-box}
html,body{margin:0;height:100%}
body{font-family:Inter,system-ui,sans-serif;color:var(--ink);background:var(--bg);-webkit-font-smoothing:antialiased}
h1,h2,h3,h4{font-family:Sora,Inter,sans-serif;margin:0;letter-spacing:-.02em}
small{color:var(--muted)}
a{cursor:pointer;text-decoration:none;color:inherit}
.hidden{display:none!important}
[data-lucide]{width:18px;height:18px;stroke-width:2}

/* ===== Brand ===== */
.brand{display:flex;align-items:center;gap:10px;font-family:Sora;font-weight:700}
.brand__mark{width:34px;height:34px;border-radius:10px;display:grid;place-items:center;color:#fff;
  background:linear-gradient(135deg,#6366f1,#4f46e5);box-shadow:0 6px 16px -6px rgba(79,70,229,.7)}
.brand__mark [data-lucide]{width:19px;height:19px}
.brand__name{font-size:19px;letter-spacing:-.03em}
.brand--lg .brand__name{font-size:26px}
.brand--lg .brand__mark{width:44px;height:44px;border-radius:13px}

/* ===== Buttons ===== */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;border:0;cursor:pointer;
  font-family:Inter;font-weight:600;font-size:14px;border-radius:11px;padding:11px 16px;transition:var(--t);white-space:nowrap}
.btn [data-lucide]{width:17px;height:17px}
.btn--primary{background:var(--brand);color:#fff;box-shadow:0 8px 18px -8px rgba(79,70,229,.8)}
.btn--primary:hover{background:#4338ca;transform:translateY(-1px)}
.btn--ghost{background:#fff;color:var(--ink);border:1px solid var(--line)}
.btn--ghost:hover{border-color:#cdd3ea;background:#fbfbfe}
.btn--block{width:100%;margin-top:10px}
.btn--sm{padding:8px 13px;font-size:13px}
.btn--xs{padding:6px 9px;font-size:12px;border-radius:9px}
.btn--icon{padding:11px;width:44px}
.btn--block.btn--ghost{color:#e7e9ff;background:rgba(255,255,255,.07);border-color:rgba(255,255,255,.18)}
.btn--block.btn--ghost:hover{background:rgba(255,255,255,.14)}
.iconbtn{display:grid;place-items:center;width:40px;height:40px;border-radius:11px;background:transparent;border:1px solid transparent;cursor:pointer;color:var(--muted);transition:var(--t)}
.iconbtn:hover{background:#eef0f7;color:var(--ink)}

/* ===== LOGIN ===== */
.login{position:fixed;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:26px;
  background:radial-gradient(1200px 700px at 70% -10%,#1f2a6b,transparent),linear-gradient(160deg,#0b1030,#0d1230 55%,#161a44);overflow:hidden;padding:24px}
.login__grid{position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,.04) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.04) 1px,transparent 1px);background-size:46px 46px;mask-image:radial-gradient(900px 600px at 50% 30%,#000,transparent)}
.login__orbs span{position:absolute;border-radius:50%;filter:blur(70px);opacity:.6;animation:float 14s ease-in-out infinite}
.login__orbs span:nth-child(1){width:340px;height:340px;background:#4f46e5;top:-80px;left:-60px}
.login__orbs span:nth-child(2){width:280px;height:280px;background:#8b5cf6;bottom:-60px;right:-40px;animation-delay:-5s}
.login__orbs span:nth-child(3){width:220px;height:220px;background:#0f9d6a;bottom:120px;left:40%;animation-delay:-9s;opacity:.4}
@keyframes float{0%,100%{transform:translate(0,0)}50%{transform:translate(26px,-30px)}}
.login__card{position:relative;z-index:2;width:100%;max-width:420px;background:rgba(255,255,255,.97);border-radius:22px;
  padding:30px 30px 26px;box-shadow:0 40px 90px -30px rgba(0,0,0,.6);animation:rise .5s cubic-bezier(.2,.8,.2,1) both}
@keyframes rise{from{opacity:0;transform:translateY(18px) scale(.98)}}
.login__title{font-size:25px;margin:18px 0 6px}
.login__sub{color:var(--muted);font-size:13.5px;line-height:1.55;margin:0 0 18px}
.field{display:block;margin-bottom:12px}
.field>span{font-size:12.5px;font-weight:600;color:#475067;display:block;margin-bottom:6px}
.field__in{display:flex;align-items:center;gap:9px;border:1px solid var(--line);border-radius:11px;padding:0 12px;background:#fbfbfe;transition:var(--t)}
.field__in:focus-within{border-color:var(--brand);box-shadow:0 0 0 4px var(--brandsoft);background:#fff}
.field__in [data-lucide]{color:var(--faint)}
.field__in input{border:0;outline:0;padding:12px 0;flex:1;background:transparent;font-size:14px;font-family:Inter}
.login__note{display:flex;align-items:center;gap:7px;justify-content:center;font-size:12px;color:var(--muted);margin-top:16px}
.login__note [data-lucide]{width:15px;height:15px;color:var(--ok)}
.login__integrations{position:relative;z-index:2;text-align:center;color:#aab1d6}
.login__integrations>span{font-size:12px;letter-spacing:.04em;text-transform:uppercase}
.chips{display:flex;flex-wrap:wrap;gap:8px;justify-content:center;margin-top:10px}
.chip{font-style:normal;font-size:12.5px;color:#dfe3ff;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.16);padding:5px 11px;border-radius:20px}

/* ===== APP shell ===== */
.app{display:flex;min-height:100vh}
.sidebar{width:262px;flex-shrink:0;background:linear-gradient(180deg,var(--side1),var(--side2));color:var(--sideink);
  display:flex;flex-direction:column;padding:16px 14px;position:sticky;top:0;height:100vh;z-index:40}
.sidebar__top{display:flex;align-items:center;justify-content:space-between;padding:4px 6px 14px}
.sidebar__top .brand__name{color:#fff}
.sidebar__close{display:none;color:var(--sideink)}
.orgcard{display:flex;gap:11px;align-items:center;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.09);border-radius:13px;padding:11px;margin-bottom:14px}
.orgcard__logo{width:38px;height:38px;border-radius:10px;display:grid;place-items:center;font-family:Sora;font-weight:700;color:#fff;background:linear-gradient(135deg,#0f9d6a,#0b7d54);flex-shrink:0}
.orgcard strong{display:block;color:#fff;font-size:13.5px}
.orgcard small{color:var(--sideink2);font-size:11.5px}
.nav{display:flex;flex-direction:column;gap:2px;overflow-y:auto;flex:1}
.nav__label{font-size:10.5px;letter-spacing:.09em;text-transform:uppercase;color:var(--sideink2);margin:14px 8px 5px;font-weight:600}
.nav__item{display:flex;align-items:center;gap:11px;padding:10px 11px;border-radius:11px;color:var(--sideink);font-size:14px;font-weight:500;transition:var(--t);position:relative}
.nav__item [data-lucide]{width:18px;height:18px;flex-shrink:0;opacity:.85}
.nav__item:hover{background:rgba(255,255,255,.07);color:#fff}
.nav__item.is-active{background:rgba(255,255,255,.1);color:#fff}
.nav__item.is-active::before{content:"";position:absolute;left:-14px;top:9px;bottom:9px;width:3px;border-radius:3px;background:#8b5cf6}
.nav__item--ai.is-active{background:linear-gradient(90deg,rgba(139,92,246,.32),rgba(79,70,229,.12))}
.tag{margin-left:auto;font-size:10.5px;font-weight:600;background:rgba(255,255,255,.1);color:#cfd4f3;padding:2px 8px;border-radius:20px}
.tag--ai{background:rgba(139,92,246,.28);color:#e7deff}
.tag--bad{background:rgba(226,59,78,.25);color:#ffd5da}
.tag--warn{background:rgba(217,138,0,.25);color:#ffe6b3}
.tag--sync{background:var(--okSoft);color:#0b7d54}
.sidebar__bottom{border-top:1px solid rgba(255,255,255,.09);padding-top:8px;margin-top:6px}
.scrim{display:none}

.main{flex:1;min-width:0;display:flex;flex-direction:column}
.topbar{position:sticky;top:0;z-index:30;display:flex;align-items:center;gap:14px;padding:13px 22px;background:rgba(255,255,255,.85);backdrop-filter:blur(10px);border-bottom:1px solid var(--line)}
.topbar__burger{display:none}
.topbar__title h2{font-size:18px}
.topbar__title small{font-size:11.5px}
.search{flex:1;max-width:440px;display:flex;align-items:center;gap:9px;background:#f1f3fa;border:1px solid transparent;border-radius:11px;padding:0 13px;margin-left:6px}
.search [data-lucide]{color:var(--faint);width:17px}
.search input{border:0;outline:0;background:transparent;padding:10px 0;flex:1;font-size:13.5px;font-family:Inter}
.search:focus-within{background:#fff;border-color:var(--brand)}
.topbar__right{display:flex;align-items:center;gap:8px;margin-left:auto}
.syncpill{display:inline-flex;align-items:center;gap:7px;font-size:12px;font-weight:600;color:#0b7d54;background:var(--okSoft);padding:6px 11px;border-radius:20px}
.syncpill .dot{background:var(--ok);animation:pulse 2s infinite}
@keyframes pulse{0%,100%{box-shadow:0 0 0 0 rgba(15,157,106,.5)}50%{box-shadow:0 0 0 5px rgba(15,157,106,0)}}
.bellwrap{position:relative}
.bell__dot{position:absolute;top:5px;right:5px;background:var(--bad);color:#fff;font-size:9px;font-weight:700;width:15px;height:15px;border-radius:50%;display:grid;place-items:center;border:2px solid #fff}
.dropdown{position:absolute;right:0;top:48px;width:300px;background:#fff;border:1px solid var(--line);border-radius:14px;box-shadow:var(--sh);padding:8px;opacity:0;transform:translateY(-6px);pointer-events:none;transition:var(--t);z-index:50}
.dropdown.open{opacity:1;transform:none;pointer-events:auto}
.dropdown__h{font-size:11px;text-transform:uppercase;letter-spacing:.06em;color:var(--faint);font-weight:700;padding:6px 10px}
.noti{display:flex;gap:11px;align-items:flex-start;padding:10px;border-radius:10px;transition:var(--t)}
.noti:hover{background:#f6f7fc}
.noti [data-lucide]{color:var(--brand);margin-top:2px}
.noti b{font-size:13px;display:block}
.noti small{font-size:11.5px;line-height:1.4}
.avatar{width:40px;height:40px;border-radius:12px;border:0;cursor:pointer;color:#fff;font-family:Sora;font-weight:700;font-size:13px;background:linear-gradient(135deg,#0f9d6a,#0b7d54)}

/* ===== Views ===== */
.view{padding:22px;max-width:1180px;width:100%;margin:0 auto}
.panel{display:none;animation:fade .3s ease both}
.panel.is-active{display:block}
@keyframes fade{from{opacity:0;transform:translateY(8px)}}

.grid{display:grid;gap:16px}
.grid--2-1{grid-template-columns:1.6fr 1fr}
.cards3{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}

.card{background:var(--panel);border:1px solid var(--line);border-radius:var(--r);padding:18px;box-shadow:var(--sh-sm);margin-bottom:16px}
.card__head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:14px}
.card__head--bare{margin:2px 2px 14px}
.card__head h3{font-size:15.5px}
.card__actions{display:flex;align-items:center;gap:10px}
.link{color:var(--brand);font-weight:600;font-size:13px;display:inline-flex;align-items:center;gap:4px;cursor:pointer}
.link [data-lucide]{width:15px;height:15px}

/* KPIs */
.kpis{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:16px}
.kpis--3{grid-template-columns:repeat(3,1fr)}
.kpi{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:16px;display:flex;gap:13px;align-items:flex-start;box-shadow:var(--sh-sm);transition:var(--t)}
.kpi:hover{transform:translateY(-2px);box-shadow:var(--sh)}
.kpi__ic{width:42px;height:42px;border-radius:12px;display:grid;place-items:center;flex-shrink:0}
.kpi__ic--ok{background:var(--okSoft);color:var(--ok)}
.kpi__ic--brand{background:var(--brandsoft);color:var(--brand)}
.kpi__ic--violet{background:var(--violetSoft);color:var(--violet)}
.kpi__ic--warn{background:var(--warnSoft);color:var(--warn)}
.kpi small{font-size:12px;color:var(--muted)}
.kpi strong{display:block;font-family:Sora;font-size:24px;margin:2px 0 4px;letter-spacing:-.03em}
.delta{display:inline-flex;align-items:center;gap:3px;font-size:11.5px;font-weight:600;color:var(--muted)}
.delta [data-lucide]{width:13px;height:13px}
.delta--ok{color:var(--ok)} .delta--bad{color:var(--bad)} .delta--warn{color:var(--warn)}

/* dots */
.dot{width:9px;height:9px;border-radius:50%;background:var(--faint);display:inline-block;flex-shrink:0}
.dot--ok{background:var(--ok)} .dot--bad{background:var(--bad)} .dot--warn{background:var(--warn)} .dot--brand{background:var(--brand)} .dot--violet{background:var(--violet)}

/* timeline / feed */
.timeline{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:14px}
.timeline li{display:flex;gap:11px;align-items:flex-start}
.timeline .dot{margin-top:5px}
.timeline b{font-size:13.5px} .timeline small{display:block;font-size:12px}
.feed{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:12px}
.feed li{display:flex;gap:12px;align-items:flex-start}
.feed__ic{width:34px;height:34px;border-radius:10px;display:grid;place-items:center;flex-shrink:0}
.feed__ic--ok{background:var(--okSoft);color:var(--ok)} .feed__ic--brand{background:var(--brandsoft);color:var(--brand)} .feed__ic--violet{background:var(--violetSoft);color:var(--violet)}
.feed b{font-size:13.5px} .feed small{display:block;font-size:12px;margin-top:2px}

/* table */
.table{width:100%;border-collapse:collapse;font-size:13.5px}
.table th{text-align:left;font-size:11px;letter-spacing:.05em;text-transform:uppercase;color:var(--faint);font-weight:700;padding:0 12px 10px}
.table td{padding:12px;border-top:1px solid var(--line);vertical-align:middle}
.table tbody tr{transition:var(--t)}
.table tbody tr:hover{background:#fafbff}
.table .r{text-align:right} .r--pos{color:var(--ok);font-weight:600}
.badge{font-size:11.5px;font-weight:600;padding:3px 10px;border-radius:20px;background:#eef0f7;color:#5a6488;white-space:nowrap}
.badge--ok{background:var(--okSoft);color:#0b7d54} .badge--warn{background:var(--warnSoft);color:#9a6200}

/* varlist / steps / partners */
.varlist{list-style:none;margin:0 0 14px;padding:0}
.varlist li{display:grid;grid-template-columns:1fr auto auto;gap:10px;align-items:center;padding:11px 0;border-bottom:1px solid var(--line);font-size:13.5px}
.varlist li:last-child{border:0}
.varlist b{font-family:Sora}
.varlist__warn{background:var(--warnSoft);margin:0 -8px;padding:11px 8px;border-radius:9px;border:0}
.hint{display:flex;gap:8px;align-items:flex-start;font-size:12.5px;color:var(--muted);background:#f6f7fc;padding:11px;border-radius:11px;margin:0}
.hint [data-lucide]{color:var(--brand);width:16px;flex-shrink:0;margin-top:1px}
.steps{list-style:none;margin:0 0 16px;padding:0;position:relative}
.steps li{display:flex;gap:12px;align-items:flex-start;padding-bottom:16px;position:relative}
.steps li::after{content:"";position:absolute;left:14px;top:30px;bottom:-2px;width:2px;background:var(--line)}
.steps li:last-child::after{display:none}
.steps li [data-lucide]{width:16px;height:16px;flex-shrink:0;z-index:1;border-radius:50%;padding:6px;background:#eef0f7;color:var(--faint)}
.steps li.done [data-lucide]{background:var(--okSoft);color:var(--ok)}
.steps b{font-size:13.5px} .steps small{display:block;font-size:12px}
.partners{list-style:none;margin:0;padding:0}
.partners li{display:flex;gap:11px;align-items:center;padding:11px 8px;border-radius:11px;transition:var(--t);cursor:pointer}
.partners li:hover{background:#f6f7fc}
.partners [data-lucide]{margin-left:auto;color:var(--faint);width:16px}
.ava{width:36px;height:36px;border-radius:10px;display:grid;place-items:center;color:#fff;font-weight:700;font-size:12px;font-family:Sora}
.ava--a{background:#6366f1}.ava--b{background:#0f9d6a}.ava--c{background:#8b5cf6}
.partners b{font-size:13.5px;display:block}.partners small{font-size:12px}

/* aid cards */
.aidcard{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:18px;box-shadow:var(--sh-sm);transition:var(--t)}
.aidcard:hover{transform:translateY(-3px);box-shadow:var(--sh);border-color:#dfe3f5}
.aidcard__ic{width:44px;height:44px;border-radius:12px;display:grid;place-items:center;background:var(--brandsoft);color:var(--brand);margin-bottom:12px}
.aidcard h4{font-size:15px;margin-bottom:6px}
.aidcard p{font-size:12.5px;color:var(--muted);line-height:1.5;margin:0 0 14px}

/* files */
.filegrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:12px}
.file{border:1px solid var(--line);border-radius:13px;padding:16px 12px;text-align:center;transition:var(--t);background:#fff}
.file:hover{border-color:var(--brand);background:var(--brandsoft);transform:translateY(-2px)}
.file [data-lucide]{width:26px;height:26px;color:var(--brand);margin-bottom:8px}
.file span{display:block;font-size:13px;font-weight:600}
.file small{font-size:11px}
.file--add{border-style:dashed;color:var(--muted)}.file--add [data-lucide]{color:var(--faint)}

/* chat */
.chat{padding:0;overflow:hidden;display:flex;flex-direction:column;height:calc(100vh - 150px);min-height:460px}
.chat__head{display:flex;gap:12px;align-items:center;padding:16px 18px;border-bottom:1px solid var(--line)}
.chat__ava{width:42px;height:42px;border-radius:12px;display:grid;place-items:center;color:#fff;background:linear-gradient(135deg,#8b5cf6,#6366f1)}
.chat__head b{font-size:14.5px;display:block}
.chat__head small{font-size:12px;display:flex;align-items:center;gap:6px}
.chat__body{flex:1;overflow-y:auto;padding:20px 18px;display:flex;flex-direction:column;gap:14px;background:#fafbff}
.msg{display:flex;max-width:82%}
.msg--ai{align-self:flex-start} .msg--me{align-self:flex-end}
.msg__b{padding:11px 15px;border-radius:15px;font-size:13.8px;line-height:1.55;box-shadow:var(--sh-sm)}
.msg--ai .msg__b{background:#fff;border:1px solid var(--line);border-bottom-left-radius:5px}
.msg--me .msg__b{background:var(--brand);color:#fff;border-bottom-right-radius:5px}
.msg__b b{font-weight:700}
.msg__note{display:block;margin-top:7px;padding-top:7px;border-top:1px dashed var(--line);font-size:11.5px;color:var(--warn);font-weight:600}
.typing{display:flex;gap:4px;padding:14px 16px}
.typing span{width:7px;height:7px;border-radius:50%;background:var(--faint);animation:blink 1.2s infinite}
.typing span:nth-child(2){animation-delay:.2s}.typing span:nth-child(3){animation-delay:.4s}
@keyframes blink{0%,60%,100%{opacity:.3;transform:translateY(0)}30%{opacity:1;transform:translateY(-3px)}}
.chat__chips{display:flex;gap:8px;flex-wrap:wrap;padding:12px 16px 0}
.suggest{border:1px solid var(--line);background:#fff;border-radius:20px;padding:7px 13px;font-size:12.5px;font-family:Inter;cursor:pointer;color:#475067;transition:var(--t)}
.suggest:hover{border-color:var(--brand);color:var(--brand);background:var(--brandsoft)}
.chat__in{display:flex;gap:10px;padding:14px 16px}
.chat__in input{flex:1;border:1px solid var(--line);border-radius:12px;padding:12px 15px;font-size:14px;font-family:Inter;outline:0;transition:var(--t)}
.chat__in input:focus{border-color:var(--brand);box-shadow:0 0 0 4px var(--brandsoft)}

/* workflows */
.wf{display:flex;flex-direction:column;gap:9px}
.wf__row{display:flex;align-items:center;gap:13px;padding:13px 14px;border:1px solid var(--line);border-radius:13px;transition:var(--t)}
.wf__row:hover{border-color:#dfe3f5;background:#fafbff}
.wf__ic{width:36px;height:36px;border-radius:10px;display:grid;place-items:center;background:var(--brandsoft);color:var(--brand);flex-shrink:0}
.wf__txt{flex:1;min-width:0}
.wf__txt b{font-size:13.8px;display:block}
.wf__txt small{font-size:12px}
.wf__meta{font-size:11.5px;color:var(--faint);white-space:nowrap}
.switch{position:relative;width:42px;height:24px;border-radius:20px;background:#d4d9ec;cursor:pointer;transition:var(--t);flex-shrink:0;border:0}
.switch::after{content:"";position:absolute;top:3px;left:3px;width:18px;height:18px;border-radius:50%;background:#fff;transition:var(--t);box-shadow:0 1px 3px rgba(0,0,0,.3)}
.switch.on{background:var(--ok)} .switch.on::after{left:21px}

/* alerts */
.alerts{display:flex;flex-direction:column;gap:12px}
.alert{display:flex;gap:13px;align-items:center;padding:16px;border-radius:var(--r);border:1px solid var(--line);background:#fff;box-shadow:var(--sh-sm)}
.alert [data-lucide]{width:22px;height:22px;flex-shrink:0}
.alert>div{flex:1}.alert b{font-size:14px;display:block}.alert small{font-size:12.5px}
.alert--bad{border-left:4px solid var(--bad)} .alert--bad>[data-lucide]{color:var(--bad)}
.alert--warn{border-left:4px solid var(--warn)} .alert--warn>[data-lucide]{color:var(--warn)}

/* modal */
.modalbg{position:fixed;inset:0;background:rgba(13,18,48,.55);backdrop-filter:blur(4px);display:grid;place-items:center;z-index:80;padding:20px;animation:fade .2s both}
.modal{background:#fff;border-radius:20px;width:100%;max-width:480px;box-shadow:0 40px 90px -30px rgba(0,0,0,.5);animation:rise .3s both;overflow:hidden}
.modal--wide{max-width:560px}
.modal__head{display:flex;align-items:center;justify-content:space-between;padding:18px 20px;border-bottom:1px solid var(--line)}
.modal__head h3{font-size:16px}
.modal__body{padding:20px;max-height:64vh;overflow-y:auto}
.modal__foot{padding:14px 20px;border-top:1px solid var(--line);display:flex;justify-content:flex-end;gap:10px}
.tabs{display:flex;gap:6px;background:#f1f3fa;padding:4px;border-radius:11px;margin-bottom:16px}
.tabs button{flex:1;border:0;background:transparent;padding:9px;border-radius:8px;font-family:Inter;font-weight:600;font-size:13px;cursor:pointer;color:var(--muted);transition:var(--t)}
.tabs button.on{background:#fff;color:var(--ink);box-shadow:var(--sh-sm)}
.frow{margin-bottom:13px}
.frow label{font-size:12.5px;font-weight:600;color:#475067;display:block;margin-bottom:6px}
.frow input,.frow select{width:100%;border:1px solid var(--line);border-radius:10px;padding:11px 12px;font-size:14px;font-family:Inter;outline:0;background:#fbfbfe}
.frow input:focus,.frow select:focus{border-color:var(--brand);box-shadow:0 0 0 4px var(--brandsoft)}
.f2{display:grid;grid-template-columns:1fr 1fr;gap:12px}

/* OCR scan */
.scan{text-align:center;padding:10px 0}
.scan__box{position:relative;height:180px;border:2px dashed #cdd3ea;border-radius:14px;display:grid;place-items:center;overflow:hidden;background:#fbfbfe;margin-bottom:16px}
.scan__doc{font-family:Sora;color:var(--faint)}
.scan__doc [data-lucide]{width:42px;height:42px;display:block;margin:0 auto 8px;color:#cdd3ea}
.scan__laser{position:absolute;left:0;right:0;height:3px;background:linear-gradient(90deg,transparent,var(--brand),transparent);box-shadow:0 0 14px 2px rgba(79,70,229,.6);top:0;display:none}
.scanning .scan__laser{display:block;animation:scan 1.4s ease-in-out infinite}
@keyframes scan{0%{top:6%}50%{top:92%}100%{top:6%}}
.scan__bar{height:7px;border-radius:6px;background:#eef0f7;overflow:hidden;margin-bottom:6px}
.scan__bar i{display:block;height:100%;width:0;background:var(--brand);transition:width .3s}
.kv{display:flex;justify-content:space-between;padding:10px 0;border-bottom:1px solid var(--line);font-size:14px}
.kv:last-child{border:0}
.kv span{color:var(--muted)} .kv b{font-family:Sora}
.kv em{font-style:normal;font-size:11px;font-weight:700;color:#0b7d54;background:var(--okSoft);padding:2px 7px;border-radius:10px;margin-left:8px}
.kv--fix b{color:var(--brand)}

/* report */
.report h4{font-size:13px;text-transform:uppercase;letter-spacing:.05em;color:var(--brand);margin:16px 0 6px}
.report h4:first-child{margin-top:0}
.report p{font-size:13.8px;line-height:1.6;margin:0;color:#33405e}
.report ul{margin:4px 0;padding-left:18px;font-size:13.8px;line-height:1.7;color:#33405e}

/* toasts */
.toastRoot{position:fixed;right:20px;bottom:20px;z-index:100;display:flex;flex-direction:column;gap:10px}
.toast{display:flex;align-items:center;gap:11px;background:#0d1230;color:#fff;padding:13px 16px;border-radius:13px;box-shadow:0 16px 40px -12px rgba(0,0,0,.5);font-size:13.5px;font-weight:500;animation:toastIn .3s both;max-width:340px}
.toast [data-lucide]{width:18px;height:18px;color:#34d399;flex-shrink:0}
@keyframes toastIn{from{opacity:0;transform:translateX(30px)}}
.toast.out{animation:toastOut .3s both}
@keyframes toastOut{to{opacity:0;transform:translateX(30px)}}

/* ===== responsive ===== */
@media(max-width:1000px){
  .grid--2-1{grid-template-columns:1fr}
  .kpis{grid-template-columns:repeat(2,1fr)}
  .cards3{grid-template-columns:1fr 1fr}
}
@media(max-width:820px){
  .sidebar{position:fixed;left:0;top:0;transform:translateX(-100%);transition:transform .3s;box-shadow:0 0 60px rgba(0,0,0,.5)}
  .sidebar.open{transform:none}
  .sidebar__close{display:grid}
  .topbar__burger{display:grid}
  .scrim{display:block;position:fixed;inset:0;background:rgba(13,18,48,.45);z-index:35;opacity:0;pointer-events:none;transition:var(--t)}
  .scrim.open{opacity:1;pointer-events:auto}
  .search{display:none}
}
@media(max-width:560px){
  .kpis,.kpis--3,.cards3{grid-template-columns:1fr}
  .view{padding:14px}
  .syncpill{display:none}
}
