/* Partner — Design System (Voria). Tokens só aqui; componentes usam var(). */
:root{
  /* Marca Voria */
  --accent:#2D7FF9; --accent-2:#7AABD4; --accent-hover:#1E63D0; --accent-soft:#EAF2FE;
  --volt:#A8C8E8;
  /* Superfícies (claro) */
  --bg:#F5F7FA; --surface:#FFFFFF; --surface-2:#F1F4F8; --surface-3:#E9EEF4;
  --ink:#0B0F19;                 /* sidebar/cabeçalho escuros mesmo no claro */
  --ink-2:#141A28; --ink-text:#E7ECF3; --ink-text-2:#9AA6B8;
  /* Bordas / texto */
  --border:#E3E8EF; --border-strong:#CBD3DE;
  --text:#0F1722; --text-2:#4A5868; --text-3:#8593A4;
  /* Semânticas */
  --ok:#0E9F6E; --ok-bg:#E7F8F1; --warn:#C77700; --warn-bg:#FBF3E5;
  --danger:#E02424; --danger-bg:#FCEAEA; --info:#2D7FF9; --info-bg:#EAF2FE;
  /* Layout */
  --sidebar-w:248px; --topbar-h:60px;
  --r:9px; --r-lg:14px; --r-xl:20px; --r-full:999px;
  --shadow-s:0 1px 2px rgba(13,22,38,.06); --shadow:0 10px 30px rgba(13,22,38,.10);
  --shadow-l:0 24px 60px rgba(13,22,38,.18);
  --transition:.16s ease;
  --font:'Plus Jakarta Sans','Inter',-apple-system,system-ui,sans-serif;
}
[data-theme="dark"]{
  --accent:#5A9DFF; --accent-2:#7AABD4; --accent-hover:#7DB2FF; --accent-soft:#16263F;
  --bg:#0A0E16; --surface:#121826; --surface-2:#171F2F; --surface-3:#1E2839;
  --ink:#070A11; --ink-2:#0E1320; --ink-text:#E7ECF3; --ink-text-2:#8493A8;
  --border:#222C3C; --border-strong:#34425A;
  --text:#E8EDF4; --text-2:#AEBACA; --text-3:#6E7C90;
  --ok:#34D399; --ok-bg:#0E2A22; --warn:#F0B429; --warn-bg:#2E2410;
  --danger:#F87171; --danger-bg:#321A1A; --info:#5A9DFF; --info-bg:#16263F;
  --shadow-s:0 1px 2px rgba(0,0,0,.5); --shadow:0 10px 30px rgba(0,0,0,.55);
  --shadow-l:0 24px 60px rgba(0,0,0,.7);
}
*{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%}
body{font-family:var(--font);background:var(--bg);color:var(--text);font-size:14px;line-height:1.5;-webkit-font-smoothing:antialiased}
a{color:inherit;text-decoration:none}
::selection{background:var(--accent-soft)}
::-webkit-scrollbar{width:9px;height:9px}
::-webkit-scrollbar-thumb{background:var(--border-strong);border-radius:var(--r-full)}

/* ── Shell (sidebar + main) ─────────────────────────────────────── */
.app{display:flex;min-height:100vh}
.sidebar{width:var(--sidebar-w);flex-shrink:0;background:var(--ink);color:var(--ink-text);
  display:flex;flex-direction:column;position:sticky;top:0;height:100vh}
.sb-brand{display:flex;align-items:center;gap:11px;padding:20px 20px 18px;border-bottom:1px solid rgba(255,255,255,.07)}
.sb-logo{width:34px;height:34px;border-radius:9px;background:linear-gradient(135deg,var(--accent),var(--accent-2));
  display:grid;place-items:center;font-weight:800;color:#fff;font-size:15px;letter-spacing:-.03em}
.sb-mark{height:30px;width:auto;display:block;flex-shrink:0}
.sb-tenant-logo{display:block;max-height:36px;max-width:100%;width:auto;margin:0 auto 10px;
  border-radius:6px;background:rgba(255,255,255,.06);padding:5px 8px}
.auth-mark{height:42px;width:auto;display:block}
.marca-prev{max-height:90px;max-width:280px;width:auto;border:1px solid var(--border);border-radius:var(--r);padding:14px;background:var(--surface-2)}
.prop-hero-logo{max-height:44px;max-width:170px;width:auto;display:block}
.tenant-card .ic img{width:100%;height:100%;object-fit:contain}
.sb-brand b{font-size:16px;font-weight:700;letter-spacing:-.01em}
.sb-brand span{display:block;font-size:11px;color:var(--ink-text-2);font-weight:500}
.sb-tenant{margin:14px 14px 4px;padding:11px 13px;background:rgba(255,255,255,.05);border-radius:var(--r);
  border:1px solid rgba(255,255,255,.08)}
.sb-tenant .lbl{font-size:10px;text-transform:uppercase;letter-spacing:.12em;color:var(--ink-text-2)}
.sb-tenant .val{font-size:14px;font-weight:700;margin-top:2px;display:flex;align-items:center;justify-content:space-between;gap:8px}
.sb-tenant a{font-size:11px;color:var(--accent-2)}
.sb-nav{padding:12px 12px;display:flex;flex-direction:column;gap:2px;flex:1;overflow-y:auto}
.sb-nav .sec{font-size:10px;text-transform:uppercase;letter-spacing:.13em;color:var(--ink-text-2);padding:14px 12px 6px}
.sb-link{display:flex;align-items:center;gap:11px;padding:10px 12px;border-radius:var(--r);color:var(--ink-text-2);
  font-weight:500;transition:var(--transition)}
.sb-link svg{width:18px;height:18px;flex-shrink:0}
.sb-link:hover{background:rgba(255,255,255,.06);color:var(--ink-text)}
.sb-link.active{background:linear-gradient(90deg,var(--accent),transparent 140%);color:#fff;font-weight:600}
.sb-foot{padding:14px;border-top:1px solid rgba(255,255,255,.07);display:flex;align-items:center;gap:10px}
.sb-avatar{width:34px;height:34px;border-radius:var(--r-full);background:var(--accent);display:grid;place-items:center;
  color:#fff;font-weight:700;font-size:13px;flex-shrink:0}
.sb-foot .who{flex:1;min-width:0}
.sb-foot .who b{font-size:13px;display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.sb-foot .who span{font-size:11px;color:var(--ink-text-2)}
.sb-foot a.ico{color:var(--ink-text-2);padding:6px;border-radius:var(--r)}
.sb-foot a.ico:hover{background:rgba(255,255,255,.08);color:var(--ink-text)}

.main{flex:1;min-width:0;display:flex;flex-direction:column}
.topbar{height:var(--topbar-h);display:flex;align-items:center;justify-content:space-between;gap:16px;
  padding:0 28px;border-bottom:1px solid var(--border);background:var(--surface);position:sticky;top:0;z-index:10}
.topbar h1{font-size:18px;font-weight:700;letter-spacing:-.01em}
.topbar .crumb{font-size:12px;color:var(--text-3)}
.content{padding:28px;flex:1}

/* ── Botões ─────────────────────────────────────────────────────── */
.btn{display:inline-flex;align-items:center;gap:8px;padding:10px 16px;border-radius:var(--r);font-weight:600;
  font-size:14px;cursor:pointer;border:1px solid transparent;transition:var(--transition);font-family:inherit}
.btn svg{width:16px;height:16px}
.btn-primary{background:var(--accent);color:#fff}
.btn-primary:hover{background:var(--accent-hover)}
.btn-ghost{background:var(--surface);color:var(--text-2);border-color:var(--border)}
.btn-ghost:hover{border-color:var(--accent);color:var(--accent)}
.btn-danger{background:var(--danger-bg);color:var(--danger)}
.btn-sm{padding:7px 12px;font-size:13px}
.btn-block{width:100%;justify-content:center}

/* ── Cards / painéis ────────────────────────────────────────────── */
.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);box-shadow:var(--shadow-s)}
.card-pad{padding:22px}
.card-head{padding:18px 22px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;gap:12px}
.card-head h2{font-size:16px;font-weight:700}
.grid{display:grid;gap:18px}

/* ── Inputs ─────────────────────────────────────────────────────── */
.field{margin-bottom:16px}
.field label{display:block;font-size:13px;font-weight:600;color:var(--text-2);margin-bottom:6px}
.input,select,textarea{width:100%;padding:11px 13px;border:1px solid var(--border-strong);border-radius:var(--r);
  background:var(--surface);color:var(--text);font-size:14px;font-family:inherit;transition:var(--transition)}
.input:focus,select:focus,textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}
.row{display:flex;gap:14px}.row>*{flex:1}

/* ── Badges / pills ─────────────────────────────────────────────── */
.badge{display:inline-flex;align-items:center;gap:6px;padding:4px 11px;border-radius:var(--r-full);
  font-size:12px;font-weight:600}
.badge-base{background:var(--info-bg);color:var(--info)}
.badge-add{background:var(--surface-3);color:var(--text-2)}
.badge-ok{background:var(--ok-bg);color:var(--ok)}
.tag-status{display:inline-flex;align-items:center;gap:6px;font-size:12px;font-weight:600;color:var(--text-2)}
.tag-status::before{content:'';width:8px;height:8px;border-radius:var(--r-full);background:var(--accent)}

/* ── Kanban ─────────────────────────────────────────────────────── */
.kanban{display:flex;gap:16px;overflow-x:auto;padding-bottom:8px;align-items:flex-start}
.kcol{flex:0 0 286px;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--r-lg);
  display:flex;flex-direction:column;max-height:calc(100vh - var(--topbar-h) - 56px)}
.kcol-head{padding:14px 16px;display:flex;align-items:center;justify-content:space-between;
  font-weight:700;font-size:13px;position:sticky;top:0}
.kcol-head .count{background:var(--surface-3);color:var(--text-2);border-radius:var(--r-full);
  padding:1px 9px;font-size:12px}
.kcol-body{padding:0 12px 12px;display:flex;flex-direction:column;gap:10px;overflow-y:auto;min-height:60px}
.kcol-body.drag-over{outline:2px dashed var(--accent);outline-offset:-6px;border-radius:var(--r)}
.kcard{background:var(--surface);border:1px solid var(--border);border-radius:var(--r);padding:14px;
  cursor:grab;box-shadow:var(--shadow-s);transition:var(--transition)}
.kcard:hover{border-color:var(--accent);box-shadow:var(--shadow)}
.kcard.dragging{opacity:.5}
.kcard h3{font-size:14px;font-weight:700;margin-bottom:3px}
.kcard .cli{font-size:12px;color:var(--text-3);margin-bottom:10px}
.kcard .meta{display:flex;align-items:center;justify-content:space-between;gap:8px;font-size:12px;color:var(--text-2)}
.kcard .price{font-weight:700;color:var(--accent)}

/* ── Tabelas ────────────────────────────────────────────────────── */
table.tbl{width:100%;border-collapse:collapse}
.tbl th{text-align:left;font-size:11px;text-transform:uppercase;letter-spacing:.07em;color:var(--text-3);
  padding:10px 14px;border-bottom:1px solid var(--border)}
.tbl td{padding:13px 14px;border-bottom:1px solid var(--border);vertical-align:middle}
.tbl tr:last-child td{border-bottom:none}
.tbl tr:hover td{background:var(--surface-2)}
.num{text-align:right;font-variant-numeric:tabular-nums}

/* ── KPIs ───────────────────────────────────────────────────────── */
.kpis{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:16px}
.kpi{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);padding:18px 20px;box-shadow:var(--shadow-s)}
.kpi .lbl{font-size:12px;color:var(--text-3);font-weight:600}
.kpi .val{font-size:26px;font-weight:800;margin-top:6px;letter-spacing:-.02em}
.kpi.accent .val{color:var(--accent)}.kpi.ok .val{color:var(--ok)}

/* ── Toggle switch ──────────────────────────────────────────────── */
.switch{position:relative;display:inline-block;width:42px;height:24px;flex-shrink:0}
.switch input{display:none}
.switch .sl{position:absolute;inset:0;background:var(--border-strong);border-radius:var(--r-full);transition:var(--transition);cursor:pointer}
.switch .sl::before{content:'';position:absolute;width:18px;height:18px;left:3px;top:3px;background:#fff;border-radius:50%;transition:var(--transition)}
.switch input:checked+.sl{background:var(--accent)}
.switch input:checked+.sl::before{transform:translateX(18px)}
.switch input:disabled+.sl{opacity:.55;cursor:not-allowed}

/* ── Links de recurso (protótipo/apresentação) ──────────────────── */
.reslinks{display:flex;flex-wrap:wrap;gap:10px}
.reslink{display:inline-flex;align-items:center;gap:9px;padding:10px 15px;border:1px solid var(--border);
  border-radius:var(--r);background:var(--surface);font-weight:600;font-size:13px;transition:var(--transition)}
.reslink:hover{border-color:var(--accent);color:var(--accent)}
.reslink svg{width:16px;height:16px}
.reslink.empty{opacity:.5;cursor:default}

/* ── Login / seleção de tenant (split) ──────────────────────────── */
.auth{min-height:100vh;display:grid;grid-template-columns:1.05fr .95fr}
.auth-brand{background:var(--ink);color:var(--ink-text);padding:56px;display:flex;flex-direction:column;justify-content:space-between;
  background-image:radial-gradient(120% 90% at 100% 0%,rgba(45,127,249,.30),transparent 55%)}
.auth-brand .logo{display:flex;align-items:center;gap:12px}
.auth-brand .logo .sb-logo{width:40px;height:40px;font-size:17px}
.auth-brand h2{font-size:34px;font-weight:800;letter-spacing:-.02em;line-height:1.1;max-width:14ch}
.auth-brand .pitch{color:var(--ink-text-2);font-size:15px;max-width:42ch;margin-top:14px}
.auth-brand .feats{display:flex;flex-direction:column;gap:12px;margin-top:10px}
.auth-brand .feats div{display:flex;gap:10px;align-items:center;color:var(--ink-text);font-size:14px}
.auth-brand .feats svg{width:18px;height:18px;color:var(--accent-2)}
.auth-form{display:flex;align-items:center;justify-content:center;padding:40px;background:var(--bg)}
.auth-form .box{width:100%;max-width:380px}
.auth-form h1{font-size:24px;font-weight:800;letter-spacing:-.01em}
.auth-form .sub{color:var(--text-3);margin:6px 0 26px}
.alert{background:var(--danger-bg);color:var(--danger);padding:11px 14px;border-radius:var(--r);font-size:13px;font-weight:600;margin-bottom:18px}
.hint{font-size:12px;color:var(--text-3);margin-top:16px;text-align:center}
@media(max-width:860px){.auth{grid-template-columns:1fr}.auth-brand{display:none}}

/* ── Tenant picker grid ─────────────────────────────────────────── */
.tenants{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:16px;max-width:760px}
.tenant-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);padding:22px;
  cursor:pointer;transition:var(--transition);box-shadow:var(--shadow-s)}
.tenant-card:hover{border-color:var(--accent);transform:translateY(-2px);box-shadow:var(--shadow)}
.tenant-card .ic{width:46px;height:46px;border-radius:var(--r);background:linear-gradient(135deg,var(--accent),var(--accent-2));
  display:grid;place-items:center;color:#fff;font-weight:800;font-size:18px;margin-bottom:14px}
.tenant-card h3{font-size:16px;font-weight:700}
.tenant-card span{font-size:12px;color:var(--text-3)}

/* ── Modal ──────────────────────────────────────────────────────── */
.overlay{position:fixed;inset:0;background:rgba(8,12,20,.55);display:none;align-items:center;justify-content:center;z-index:50;padding:20px}
.overlay.open{display:flex}
.modal{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);box-shadow:var(--shadow-l);
  width:100%;max-width:560px;max-height:90vh;overflow:auto}
.modal-head{padding:18px 22px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between}
.modal-head h2{font-size:17px;font-weight:700}
.modal-body{padding:22px}
.modal-foot{padding:16px 22px;border-top:1px solid var(--border);display:flex;justify-content:flex-end;gap:10px}
.x{cursor:pointer;color:var(--text-3);padding:4px;border-radius:var(--r)}.x:hover{background:var(--surface-2);color:var(--text)}

/* ── Treinamento ────────────────────────────────────────────────── */
.train-cat{margin-bottom:30px}
.train-cat-head{margin-bottom:14px}
.train-cat-head h2{font-size:17px;font-weight:700}
.train-cat-head p{font-size:13px;color:var(--text-3);margin-top:2px}
.train-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:14px}
.train-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);padding:18px;
  box-shadow:var(--shadow-s);transition:var(--transition);display:flex;flex-direction:column;gap:10px}
.train-card:hover{border-color:var(--accent);transform:translateY(-2px);box-shadow:var(--shadow)}
.train-card .tc-ic{width:42px;height:42px;border-radius:var(--r);background:var(--accent-soft);color:var(--accent);display:grid;place-items:center}
.train-card .tc-ic svg{width:22px;height:22px}
.train-card h3{font-size:15px;font-weight:700;line-height:1.3}
.train-card p{font-size:13px;color:var(--text-2);flex:1}
.train-card .tc-foot{display:flex;align-items:center;justify-content:space-between;gap:8px}
.train-card .read{font-size:13px;font-weight:600;color:var(--accent);display:inline-flex;align-items:center;gap:5px}

/* Leitura da lição */
.lesson{max-width:760px;margin:0 auto}
.lesson .back{display:inline-flex;align-items:center;gap:6px;font-size:13px;color:var(--text-3);margin-bottom:20px}
.lesson .back:hover{color:var(--accent)}
.lesson .cat{font-size:12px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--accent)}
.lesson h1{font-size:30px;font-weight:800;letter-spacing:-.02em;margin:8px 0 6px;line-height:1.15}
.lesson .resumo{font-size:16px;color:var(--text-2);margin-bottom:26px}
.md-content{font-size:15px;line-height:1.7;color:var(--text)}
.md-content p{margin:0 0 14px}
.md-content h4{font-size:16px;font-weight:700;margin:24px 0 10px;color:var(--text)}
.md-content ul,.md-content ol{margin:0 0 16px;padding-left:22px}
.md-content li{margin-bottom:8px}
.md-content strong{font-weight:700}
.md-content em{color:var(--text-2);font-style:italic}
.lesson-nav{display:flex;justify-content:space-between;gap:12px;margin-top:36px;border-top:1px solid var(--border);padding-top:20px}
.train-card .tc-ic{flex:0 0 42px}
.train-card .tc-ic svg{width:22px;height:22px}
/* Salvaguarda: nenhum ícone deve estourar o layout */
.content svg{max-width:100%;height:auto;vertical-align:middle}
.content .md-content svg{max-width:100%}

/* ── Diagramas (usados no conteúdo das lições) ──────────────────── */
.dgm{margin:18px 0}
.dgm-cap{font-size:12px;color:var(--text-3);text-align:center;margin-top:8px}
.dgm-flow{display:flex;flex-wrap:wrap;align-items:stretch;gap:10px}
.dgm-flow .node{flex:1 1 130px;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--r);
  padding:13px;text-align:center;font-weight:600;font-size:13px;display:flex;flex-direction:column;gap:3px;justify-content:center}
.dgm-flow .node small{font-weight:400;color:var(--text-3);font-size:12px;line-height:1.3}
.dgm-flow .node.accent{background:var(--accent-soft);border-color:var(--accent);color:var(--accent)}
.dgm-flow .node.ok{background:var(--ok-bg);border-color:var(--ok);color:var(--ok)}
.dgm-flow .node.warn{background:var(--warn-bg);border-color:var(--warn);color:var(--warn)}
.dgm-flow .arrow{display:flex;align-items:center;justify-content:center;color:var(--text-3);font-size:20px;flex:0 0 auto;font-weight:700}
@media(max-width:600px){.dgm-flow{flex-direction:column}.dgm-flow .arrow{transform:rotate(90deg)}}

.dgm-vs{display:grid;grid-template-columns:1fr 1fr;gap:12px}
@media(max-width:600px){.dgm-vs{grid-template-columns:1fr}}
.dgm-vs .side{border:1px solid var(--border);border-radius:var(--r-lg);padding:16px;background:var(--surface)}
.dgm-vs .side.bad{border-color:var(--danger)}
.dgm-vs .side.good{border-color:var(--ok)}
.dgm-vs .side h5{font-size:14px;font-weight:700;margin:0 0 10px;display:flex;align-items:center;gap:7px}
.dgm-vs .side.bad h5{color:var(--danger)} .dgm-vs .side.good h5{color:var(--ok)}
.dgm-vs ul{margin:0;padding-left:18px;font-size:13px} .dgm-vs li{margin-bottom:6px}

.dgm-stack{display:flex;flex-direction:column;gap:8px}
.dgm-stack .layer{border:1px solid var(--border);border-radius:var(--r);padding:12px 14px;background:var(--surface-2);font-size:13px}
.dgm-stack .layer b{display:block;font-size:14px}
.dgm-stack .layer small{color:var(--text-3)}
.dgm-stack .layer.base{border-left:3px solid var(--accent)}
.dgm-stack .layer.add{border-left:3px solid var(--text-3);margin-left:22px}

.callout{border-left:3px solid var(--accent);background:var(--accent-soft);padding:13px 16px;border-radius:0 var(--r) var(--r) 0;margin:16px 0;font-size:14px}
.callout b{color:var(--accent)}
.dgm-steps{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:10px}
.dgm-steps .st{background:var(--surface);border:1px solid var(--border);border-radius:var(--r);padding:14px}
.dgm-steps .st .n{width:26px;height:26px;border-radius:var(--r-full);background:var(--accent-soft);color:var(--accent);
  font-weight:700;display:grid;place-items:center;margin-bottom:8px;font-size:13px}
.dgm-steps .st b{font-size:13px;display:block;margin-bottom:2px}
.dgm-steps .st small{font-size:12px;color:var(--text-3)}

/* ── Orçamento / Proposta ───────────────────────────────────────── */
.prop{max-width:860px;margin:0 auto}
.prop-hero{background:var(--ink);color:var(--ink-text);border-radius:var(--r-lg);padding:26px 28px;margin-bottom:22px;
  background-image:radial-gradient(120% 140% at 100% 0%,rgba(45,127,249,.28),transparent 55%)}
.prop-hero .lbl{font-size:12px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--accent-2)}
.prop-hero h1{font-size:26px;font-weight:800;letter-spacing:-.02em;margin:6px 0 2px}
.prop-hero .cli{color:var(--ink-text-2);font-size:14px}
.prop-sec{margin-bottom:26px}
.prop-sec-head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:12px}
.prop-sec-head h2{font-size:16px;font-weight:700}
.prop-sec-head .hint{font-size:12px;color:var(--text-3)}

.fline{display:flex;align-items:center;gap:16px;padding:16px 18px;border:1px solid var(--border);
  border-radius:var(--r-lg);background:var(--surface);margin-bottom:10px;box-shadow:var(--shadow-s);transition:var(--transition)}
.fline .fl-check{flex:0 0 24px;height:24px;border-radius:var(--r-full);display:grid;place-items:center}
.fline.base .fl-check{background:var(--ok);color:#fff}
.fline .fl-check svg{width:14px;height:14px}
.fline .fl-main{flex:1;min-width:0}
.fline .fl-name{font-weight:700;font-size:15px}
.fline .fl-desc{font-size:13px;color:var(--text-3);margin-top:2px}
.fline .fl-price{font-weight:800;font-size:17px;white-space:nowrap;font-variant-numeric:tabular-nums}
.fline.base{border-left:3px solid var(--ok)}
.fline.tag-base{font-size:11px}

/* Adicionais — linha clicável (label > checkbox escondido) */
.fline.add{cursor:pointer;border-style:dashed}
.fline.add .fl-check{border:2px solid var(--border-strong);color:transparent}
.fline.add .fl-check svg{opacity:0}
.fline.add input{position:absolute;opacity:0;pointer-events:none}
.fline.add.on{border-style:solid;border-color:var(--accent);box-shadow:0 0 0 1px var(--accent),var(--shadow-s)}
.fline.add.on .fl-check{background:var(--accent);border-color:var(--accent);color:#fff}
.fline.add.on .fl-check svg{opacity:1}
.fline.add .fl-action{font-size:13px;font-weight:700;color:var(--accent);white-space:nowrap}
.fline.add.on .fl-action{color:var(--text-3)}
.fline.add:hover{border-color:var(--accent)}
.fl-det{flex-shrink:0;white-space:nowrap}
.det-body ul{margin:0;padding-left:20px}
.det-body li{margin-bottom:10px;font-size:14px;line-height:1.55;color:var(--text-2)}
.det-body li::marker{color:var(--accent)}
@media(max-width:600px){.fline{flex-wrap:wrap}.fline .fl-main{flex-basis:100%}.fl-det{order:3}}

/* Barra de total */
.prop-total{position:sticky;bottom:16px;background:var(--surface);border:1px solid var(--border-strong);
  border-radius:var(--r-lg);box-shadow:var(--shadow-l);padding:20px 24px;margin-top:8px;
  display:flex;align-items:center;justify-content:space-between;gap:20px;flex-wrap:wrap}
.prop-total .breakdown{display:flex;gap:26px;flex-wrap:wrap}
.prop-total .bd .k{font-size:12px;color:var(--text-3)}
.prop-total .bd .v{font-size:16px;font-weight:700;font-variant-numeric:tabular-nums}
.prop-total .grand{text-align:right}
.prop-total .grand .k{font-size:12px;color:var(--text-3)}
.prop-total .grand .v{font-size:30px;font-weight:800;color:var(--accent);letter-spacing:-.02em;font-variant-numeric:tabular-nums}
.prop-total .actions{display:flex;gap:10px;align-items:center}
@media(max-width:600px){.prop-total{flex-direction:column;align-items:stretch}.prop-total .grand{text-align:left}}

.empty{text-align:center;color:var(--text-3);padding:50px 20px}
.muted{color:var(--text-3)}
.right{text-align:right}
.flex{display:flex;align-items:center;gap:10px}
.between{display:flex;align-items:center;justify-content:space-between;gap:12px}
.mt{margin-top:18px}.mb{margin-bottom:18px}

/* ── Responsividade global ──────────────────────────────────────── */
@media(max-width:1024px){
  .content{padding:20px}
  .kpis{grid-template-columns:repeat(auto-fit,minmax(150px,1fr))}
}
@media(max-width:820px){
  .app{flex-direction:column}
  .sidebar{position:sticky;top:0;z-index:30;width:100%;height:auto;flex-direction:row;align-items:center;
    overflow-x:auto;gap:6px;padding:8px 10px}
  .sb-brand{border:none;padding:6px 8px;flex-shrink:0}
  .sb-brand span{display:none}
  .sb-tenant{display:none}
  .sb-nav{flex-direction:row;flex:1;padding:0;gap:4px;overflow-x:auto}
  .sb-nav .sec{display:none}
  .sb-link{white-space:nowrap;padding:8px 12px}
  .sb-link span,.sb-link{font-size:13px}
  .sb-foot{border:none;width:auto;padding:6px 8px;flex-shrink:0}
  .sb-foot .who{display:none}
  .topbar{padding:0 16px;height:auto;min-height:var(--topbar-h);flex-wrap:wrap;gap:8px;padding-top:8px;padding-bottom:8px}
  .topbar h1{font-size:16px}
  .content{padding:16px}
  .kpis{grid-template-columns:1fr 1fr;gap:12px}
  .kpi .val{font-size:22px}
  .row{flex-direction:column;gap:0}
  .modal{max-width:100%}
}
@media(max-width:520px){
  .kpis{grid-template-columns:1fr}
  .kcol{flex-basis:84vw}
  .train-grid{grid-template-columns:1fr}
  .lesson h1{font-size:24px}
}
