/* ============================================================
   OCTOPUS · DESIGN TOKENS  (Livro de Design @jorgesouza.eth v1.0)
   Aplicação: PilotFlow — preview de identidade visual
   ============================================================ */
@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800&family=JetBrains+Mono:wght@400;700&display=swap');

:root{
  /* --- Paleta: 5 cores (regra 80/15/5) --- */
  --navy:#1A2545;          /* Azul Marinho — estrutura */
  --orange:#E8743D;        /* Laranja Marca — pontuação 5% */
  --cream:#FAF4EC;         /* Cream Fundo */
  --cream-callout:#FCF1E3; /* Cream Callout */
  --ink:#1A1A1A;           /* Preto Texto */

  /* --- Funcionais (só acerto/erro, nunca decoração) --- */
  --green:#0E3A2B; --green-on:#178a52; --green-soft:#E5F4EC;
  --red:#3A1010;  --red-on:#C2453F; --red-soft:#FBEAE9;
  --amber-on:#B9772A;

  /* --- Derivados (transparências de navy sobre cream) --- */
  --navy-72:rgba(26,37,69,.72);
  --navy-55:rgba(26,37,69,.55);
  --navy-15:rgba(26,37,69,.14);
  --navy-09:rgba(26,37,69,.09);
  --navy-05:rgba(26,37,69,.05);
  --cream-70:rgba(250,244,236,.70);
  --cream-45:rgba(250,244,236,.45);
  --white-10:rgba(255,255,255,.10);
  --white-06:rgba(255,255,255,.06);

  /* --- Espaçamento base 4 --- */
  --s-1:4px; --s-2:8px; --s-3:12px; --s-4:16px; --s-5:20px;
  --s-6:24px; --s-8:32px; --s-10:40px; --s-12:48px; --s-16:64px; --s-20:80px;

  --radius:10px; --radius-sm:6px; --radius-lg:14px;
  --shadow-card:0 1px 2px rgba(26,37,69,.05), 0 6px 18px rgba(26,37,69,.06);
  --shadow-node:0 2px 4px rgba(26,37,69,.08), 0 8px 22px rgba(26,37,69,.10);
}

*{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%}
body{
  font-family:'Inter',system-ui,sans-serif;
  background:var(--cream); color:var(--ink);
  -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility;
  font-size:16px; line-height:1.65;
}

/* ---------- Tipografia ---------- */
.eyebrow{font:600 11px/1 'Inter';letter-spacing:.2em;text-transform:uppercase;color:var(--orange)}
.eyebrow--muted{color:var(--navy-55)}
h1,.h1{color:var(--navy);font-weight:800;letter-spacing:-.025em;line-height:1.05;font-size:34px}
h2,.h2{color:var(--navy);font-weight:800;letter-spacing:-.02em;line-height:1.08;font-size:24px}
h3,.h3{color:var(--navy);font-weight:700;letter-spacing:-.01em;font-size:18px}
.mono{font-family:'JetBrains Mono',monospace}
.muted{color:var(--navy-55)}

/* ---------- Ícones lucide ---------- */
[data-lucide]{width:18px;height:18px;stroke-width:2}

/* ============================================================
   APP SHELL
   ============================================================ */
.app{display:flex;height:100vh;overflow:hidden}

/* ---- Sidebar (navy) ---- */
.side{width:256px;flex:none;background:var(--navy);color:var(--cream);display:flex;flex-direction:column;height:100%}
.side__brand{display:flex;align-items:center;gap:var(--s-3);padding:var(--s-5) var(--s-5) var(--s-4)}
.logo{width:30px;height:30px;border-radius:8px;background:var(--orange);display:grid;place-items:center;
  font-weight:800;font-size:13px;letter-spacing:-.02em;color:#fff;flex:none}
.side__brand b{font-weight:700;font-size:18px;letter-spacing:-.02em;color:#fff}
.side__switch{margin:0 var(--s-3) var(--s-3);padding:var(--s-2) var(--s-3);border-radius:var(--radius-sm);
  background:var(--white-06);display:flex;align-items:center;gap:var(--s-2);font-size:13px;color:var(--cream-70);
  border:1px solid var(--white-06)}
.side__switch .av{width:20px;height:20px;border-radius:50%;background:var(--orange);display:grid;place-items:center;
  font-size:9px;font-weight:700;color:#fff}
.side__switch [data-lucide]{margin-left:auto;width:14px;height:14px;color:var(--cream-45)}
.nav{flex:1;overflow-y:auto;padding:var(--s-2) var(--s-3)}
.nav__group{font:600 10px/1 'Inter';letter-spacing:.2em;text-transform:uppercase;color:var(--cream-45);
  padding:var(--s-4) var(--s-3) var(--s-2)}
.nav a{display:flex;align-items:center;gap:var(--s-3);padding:9px var(--s-3);border-radius:var(--radius-sm);
  color:var(--cream-70);font-size:13.5px;font-weight:500;text-decoration:none;position:relative;margin-bottom:1px}
.nav a [data-lucide]{width:17px;height:17px;color:var(--cream-45)}
.nav a:hover{background:var(--white-06);color:#fff}
.nav a.is-active{background:var(--white-10);color:#fff;font-weight:600}
.nav a.is-active::before{content:"";position:absolute;left:-2px;top:7px;bottom:7px;width:3px;border-radius:3px;background:var(--orange)}
.nav a.is-active [data-lucide]{color:var(--orange)}
.side__user{margin-top:auto;display:flex;align-items:center;gap:var(--s-3);padding:var(--s-4) var(--s-5);
  border-top:1px solid var(--white-06)}
.side__user .av{width:32px;height:32px;border-radius:50%;background:var(--cream);color:var(--navy);
  display:grid;place-items:center;font-weight:700;font-size:12px;flex:none}
.side__user .meta{min-width:0;line-height:1.2}
.side__user .meta b{display:block;font-size:13px;font-weight:600;color:#fff}
.side__user .meta span{display:block;font-size:11px;color:var(--cream-45);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.side__user [data-lucide]{margin-left:auto;width:16px;height:16px;color:var(--cream-45)}

/* ---- Main ---- */
.main{flex:1;display:flex;flex-direction:column;min-width:0;height:100%}
.topbar{height:56px;flex:none;background:var(--cream);border-bottom:1px solid var(--navy-09);
  display:flex;align-items:center;padding:0 var(--s-8);gap:var(--s-4)}
.topbar h2{font-size:19px}
.topbar .spacer{flex:1}
.bell{position:relative;color:var(--navy);display:grid;place-items:center}
.bell::after{content:"";position:absolute;top:-1px;right:-1px;width:7px;height:7px;border-radius:50%;
  background:var(--orange);border:1.5px solid var(--cream)}
.content{flex:1;overflow-y:auto;padding:var(--s-8)}

/* ---------- Botões ---------- */
.btn{display:inline-flex;align-items:center;gap:var(--s-2);height:36px;padding:0 var(--s-4);border-radius:var(--radius-sm);
  font:600 13px/1 'Inter';letter-spacing:.01em;border:1px solid transparent;cursor:pointer;white-space:nowrap}
.btn [data-lucide]{width:15px;height:15px}
.btn--primary{background:var(--orange);color:#fff}            /* CTA = laranja (5%) */
.btn--navy{background:var(--navy);color:var(--cream)}
.btn--outline{background:transparent;color:var(--navy);border-color:var(--navy-15)}
.btn--ghost{background:transparent;color:var(--navy-72)}
.btn--sm{height:32px;padding:0 var(--s-3);font-size:12.5px}

/* ---------- Tabs (período) ---------- */
.tabs{display:inline-flex;background:var(--navy-05);border:1px solid var(--navy-09);border-radius:8px;padding:3px}
.tabs button{border:0;background:transparent;font:600 12.5px/1 'Inter';color:var(--navy-55);padding:7px 14px;
  border-radius:6px;cursor:pointer}
.tabs button.is-active{background:#fff;color:var(--navy);box-shadow:0 1px 2px rgba(26,37,69,.08)}

/* ---------- Cards ---------- */
.card{background:#fff;border:1px solid var(--navy-09);border-radius:var(--radius);box-shadow:var(--shadow-card)}
.card--cream{background:var(--cream-callout)}
.grid{display:grid;gap:var(--s-4)}
.cols-4{grid-template-columns:repeat(4,1fr)}
.cols-2{grid-template-columns:repeat(2,1fr)}

/* KPI */
.kpi{padding:var(--s-5) var(--s-5) var(--s-6)}
.kpi__top{display:flex;align-items:center;justify-content:space-between}
.kpi__ic{width:30px;height:30px;border-radius:8px;background:var(--cream-callout);display:grid;place-items:center;color:var(--navy)}
.kpi__ic [data-lucide]{width:16px;height:16px}
.kpi__num{font-weight:800;font-size:46px;line-height:1;letter-spacing:-.03em;color:var(--orange);margin-top:var(--s-3)}
.kpi__lbl{font:600 11px/1 'Inter';letter-spacing:.13em;text-transform:uppercase;color:var(--navy-55);margin-top:var(--s-3)}
.kpi__delta{display:inline-flex;align-items:center;gap:4px;font-size:11.5px;font-weight:600;margin-top:var(--s-2);color:var(--green-on)}
.kpi__delta.is-down{color:var(--red-on)}

/* Callout */
.callout{display:flex;align-items:center;gap:var(--s-4);padding:var(--s-4) var(--s-5);background:var(--cream-callout);
  border-left:3px solid var(--orange);border-radius:var(--radius);margin-bottom:var(--s-6)}
.callout .ic{color:var(--orange)}
.callout b{color:var(--navy);font-weight:700;font-size:14px}
.callout p{font-size:13px;color:var(--navy-72)}
.callout .btn{margin-left:auto}

/* Section head */
.shead{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:var(--s-4)}
.shead .left{display:flex;flex-direction:column;gap:6px}

/* Chart card */
.chart{padding:var(--s-5)}
.chart__head{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--s-4)}
.legend{display:flex;gap:var(--s-4)}
.legend span{display:inline-flex;align-items:center;gap:6px;font-size:11.5px;font-weight:600;color:var(--navy-72)}
.legend i{width:9px;height:9px;border-radius:2px;display:inline-block}

/* mini table */
.mtable{width:100%;border-collapse:collapse;margin-top:var(--s-4)}
.mtable th{font:600 10px/1 'Inter';letter-spacing:.13em;text-transform:uppercase;color:var(--navy-55);
  text-align:left;padding:0 0 var(--s-2);border-bottom:1px solid var(--navy-09)}
.mtable td{font-size:13px;color:var(--navy);padding:9px 0;border-bottom:1px solid var(--navy-05)}
.mtable td.r,.mtable th.r{text-align:right}

/* Conversas list */
.conv{display:flex;align-items:center;gap:var(--s-3);padding:var(--s-3) 0;border-bottom:1px solid var(--navy-05)}
.conv .av{width:34px;height:34px;border-radius:50%;background:var(--navy);color:var(--cream);display:grid;place-items:center;
  font-weight:700;font-size:12px;flex:none}
.conv .tx{min-width:0;flex:1}
.conv .tx b{font-size:13.5px;font-weight:600;color:var(--navy)}
.conv .tx p{font-size:12.5px;color:var(--navy-55);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}

/* Badges */
.badge{display:inline-flex;align-items:center;gap:5px;font:600 11px/1 'Inter';padding:5px 9px;border-radius:999px}
.badge--ok{background:var(--green-soft);color:var(--green-on)}
.badge--warn{background:#FBF1E2;color:var(--amber-on)}
.badge--off{background:var(--navy-05);color:var(--navy-55)}
.badge--err{background:var(--red-soft);color:var(--red-on)}
.badge .dot{width:6px;height:6px;border-radius:50%;background:currentColor}

/* ============================================================
   FLOW EDITOR
   ============================================================ */
.rail{width:56px;flex:none;background:var(--navy);display:flex;flex-direction:column;align-items:center;
  padding:var(--s-4) 0;gap:6px;height:100%}
.rail .logo{margin-bottom:var(--s-3)}
.rail a{width:38px;height:38px;border-radius:9px;display:grid;place-items:center;color:var(--cream-45);position:relative}
.rail a [data-lucide]{width:19px;height:19px}
.rail a:hover{background:var(--white-06);color:#fff}
.rail a.is-active{background:var(--white-10);color:var(--orange)}
.rail a.is-active::before{content:"";position:absolute;left:-9px;top:9px;bottom:9px;width:3px;border-radius:3px;background:var(--orange)}
.rail .bottom{margin-top:auto}
.rail .av{width:32px;height:32px;border-radius:50%;background:var(--cream);color:var(--navy);display:grid;place-items:center;font-weight:700;font-size:12px}

/* palette */
.palette{width:248px;flex:none;background:#fff;border-right:1px solid var(--navy-09);display:flex;flex-direction:column;height:100%}
.palette__head{padding:var(--s-4);border-bottom:1px solid var(--navy-09)}
.palette__head .eyebrow{margin-bottom:var(--s-3)}
.search{display:flex;align-items:center;gap:var(--s-2);height:34px;padding:0 var(--s-3);background:var(--cream-callout);
  border:1px solid var(--navy-09);border-radius:var(--radius-sm);color:var(--navy-55);font-size:13px}
.search [data-lucide]{width:14px;height:14px}
.palette__body{flex:1;overflow-y:auto;padding:var(--s-3)}
.cat{font:600 10px/1 'Inter';letter-spacing:.2em;text-transform:uppercase;color:var(--orange);padding:var(--s-4) 6px var(--s-2)}
.cat:first-child{padding-top:6px}
.pitem{display:flex;align-items:center;gap:var(--s-3);padding:8px;border-radius:var(--radius-sm);cursor:grab;margin-bottom:2px;border:1px solid transparent}
.pitem:hover{background:var(--cream-callout);border-color:var(--navy-09)}
.pchip{width:28px;height:28px;border-radius:7px;background:var(--cream-callout);border:1px solid var(--navy-09);
  display:grid;place-items:center;font-size:14px;flex:none}
.pitem .tx{min-width:0}
.pitem .tx b{display:block;font-size:12.5px;font-weight:600;color:var(--navy);line-height:1.3}
.pitem .tx span{display:block;font-size:10px;color:var(--navy-55);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.palette__foot{padding:var(--s-3);border-top:1px solid var(--navy-09);font-size:10px;color:var(--navy-55);text-align:center}

/* canvas */
.canvas{flex:1;position:relative;min-width:0;height:100%;overflow:hidden;
  background-color:var(--cream);
  background-image:radial-gradient(var(--navy-15) 1.1px, transparent 1.1px);
  background-size:18px 18px}
.cv-tl{position:absolute;top:var(--s-4);left:var(--s-4);z-index:5;background:rgba(255,255,255,.85);backdrop-filter:blur(6px);
  border:1px solid var(--navy-09);border-radius:var(--radius-sm);padding:8px 14px}
.cv-tl b{font-size:14px;font-weight:700;color:var(--navy);letter-spacing:-.01em}
.cv-tl span{display:inline-flex;align-items:center;gap:5px;font-size:11.5px;font-weight:600;color:var(--green-on);margin-top:2px}
.cv-tl span .dot{width:6px;height:6px;border-radius:50%;background:var(--green-on)}
.cv-tr{position:absolute;top:var(--s-4);right:var(--s-4);z-index:5;display:flex;gap:8px}
.cv-zoom{position:absolute;left:var(--s-4);bottom:var(--s-4);z-index:5;display:flex;flex-direction:column;
  background:#fff;border:1px solid var(--navy-09);border-radius:var(--radius-sm);overflow:hidden}
.cv-zoom button{width:34px;height:32px;border:0;background:#fff;color:var(--navy);cursor:pointer;display:grid;place-items:center;border-bottom:1px solid var(--navy-09)}
.cv-zoom button:last-child{border-bottom:0}
.cv-zoom [data-lucide]{width:15px;height:15px}
.minimap{position:absolute;right:var(--s-4);bottom:var(--s-4);z-index:5;width:170px;height:108px;background:rgba(255,255,255,.9);
  border:1px solid var(--navy-09);border-radius:var(--radius-sm);overflow:hidden}

/* edges layer */
.edges{position:absolute;inset:0;width:100%;height:100%;pointer-events:none;z-index:1}
.edge{fill:none;stroke:var(--navy);stroke-width:2;opacity:.55;stroke-linecap:round}
.edge--yes{stroke:var(--green-on);opacity:.7;stroke-dasharray:6 6;animation:flow 1s linear infinite}
.edge--no{stroke:var(--red-on);opacity:.65;stroke-dasharray:6 6;animation:flow 1s linear infinite}
.edge--main{stroke-dasharray:6 6;animation:flow 1s linear infinite}
@keyframes flow{to{stroke-dashoffset:-12}}

/* nodes */
.node{position:absolute;z-index:2;width:188px;background:#fff;border:1.5px solid var(--navy-15);
  border-radius:var(--radius);box-shadow:var(--shadow-node);overflow:hidden}
.node__hd{display:flex;align-items:center;gap:8px;padding:9px 12px;background:var(--navy);color:#fff}
.node__hd .ic{font-size:14px}
.node__hd b{font-size:13px;font-weight:600;letter-spacing:-.005em}
.node__hd .tag{margin-left:auto;font:600 9px/1 'Inter';letter-spacing:.16em;text-transform:uppercase;
  color:var(--orange);background:rgba(232,116,61,.16);padding:4px 6px;border-radius:4px}
.node--trigger .node__hd{background:var(--orange)}
.node--end .node__hd{background:var(--red-on)}
.node__bd{padding:10px 12px;background:var(--cream-callout);font-size:11.5px;color:var(--navy-72);line-height:1.45}
.node__bd .k{color:var(--navy);font-weight:600}
.node__ports{display:flex;border-top:1px solid var(--navy-09);background:#fff}
.node__ports .p{flex:1;text-align:center;padding:7px 0;font:600 11px/1 'Inter';position:relative}
.node__ports .p+.p{border-left:1px solid var(--navy-09)}
.node__ports .yes{color:var(--green-on)}
.node__ports .no{color:var(--red-on)}
.dotPort{position:absolute;width:9px;height:9px;border-radius:50%;background:#fff;border:2px solid var(--navy);bottom:-5px;left:50%;transform:translateX(-50%)}
.dotPort.in{top:-5px;bottom:auto}
.dotPort.g{border-color:var(--green-on)} .dotPort.r{border-color:var(--red-on)} .dotPort.o{border-color:var(--orange)}

/* config panel */
.config{width:300px;flex:none;background:#fff;border-left:1px solid var(--navy-09);display:flex;flex-direction:column;height:100%}
.config__head{display:flex;align-items:center;gap:10px;padding:var(--s-4);border-bottom:1px solid var(--navy-09)}
.config__head .pchip{width:30px;height:30px}
.config__head b{font-size:14px;font-weight:700;color:var(--navy)}
.config__head .x{margin-left:auto;color:var(--navy-55);cursor:pointer}
.config__body{padding:var(--s-4);overflow-y:auto;flex:1}
.field{margin-bottom:var(--s-5)}
.field>label{display:block;font:600 11px/1 'Inter';letter-spacing:.1em;text-transform:uppercase;color:var(--navy-55);margin-bottom:8px}
.input,.select,.textarea{width:100%;background:var(--cream-callout);border:1px solid var(--navy-15);border-radius:var(--radius-sm);
  padding:10px 12px;font:500 13px/1.4 'Inter';color:var(--navy)}
.select{display:flex;align-items:center;justify-content:space-between}
.textarea{height:88px;line-height:1.5}
.chips{display:flex;flex-wrap:wrap;gap:6px;margin-top:8px}
.chip{font:600 11px/1 'JetBrains Mono';color:var(--orange);background:rgba(232,116,61,.12);
  border:1px solid rgba(232,116,61,.28);padding:5px 7px;border-radius:5px}
.config__foot{padding:var(--s-4);border-top:1px solid var(--navy-09)}
.config__foot .btn{width:100%;justify-content:center}

/* ============================================================
   TELAS EXTRA (Conversas, Analytics, Broadcasts, Templates)
   ============================================================ */
.content.flexcol{display:flex;flex-direction:column}
.toolbar{display:flex;align-items:center;gap:var(--s-3);margin-bottom:var(--s-5)}
.search.grow{flex:1;max-width:420px}
.cols-3{grid-template-columns:repeat(3,1fr)}
.live{display:inline-flex;align-items:center;gap:6px;font-size:12px;font-weight:600;color:var(--green-on)}
.live .dot{width:7px;height:7px;border-radius:50%;background:var(--green-on)}

/* ---- tabela de dados (Analytics) ---- */
.dwrap{border:1px solid var(--navy-09);border-radius:var(--radius);overflow:hidden;background:#fff;box-shadow:var(--shadow-card)}
.dtable{width:100%;border-collapse:collapse}
.dtable th{font:600 10px/1 'Inter';letter-spacing:.09em;text-transform:uppercase;color:var(--navy-55);
  text-align:left;padding:13px 12px;background:var(--cream);border-bottom:1px solid var(--navy-09);white-space:nowrap}
.dtable th.r,.dtable td.r{text-align:right}
.dtable td{padding:11px 12px;border-bottom:1px solid var(--navy-05);font-size:12.5px;color:var(--navy);vertical-align:middle}
.dtable tbody tr:last-child td{border-bottom:0}
.dtable tbody tr:hover{background:var(--cream-callout)}
.dtable .num{font-variant-numeric:tabular-nums;color:var(--navy-72)}
.dtable .eng{font-weight:700;color:var(--orange);font-variant-numeric:tabular-nums}
.tcell{display:flex;align-items:center;gap:10px}
.thumb-sm{width:38px;height:38px;border-radius:8px;background:var(--navy);flex:none;display:grid;place-items:center;color:var(--cream-45);overflow:hidden}
.thumb-sm [data-lucide]{width:16px;height:16px}
.tcap{font-size:12px;color:var(--navy);line-height:1.35;max-width:220px;overflow:hidden;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}
.tbadge{display:inline-flex;align-items:center;gap:5px;font:600 11px/1 'Inter';padding:5px 8px;border-radius:6px;background:var(--navy-05);color:var(--navy-72);white-space:nowrap}
.tbadge [data-lucide]{width:12px;height:12px}

/* ---- summary cards (Analytics topo) ---- */
.scard{padding:var(--s-5)}
.scard .row{display:flex;align-items:center;gap:12px;margin-bottom:10px}
.scard .thumb-sm{width:46px;height:46px}
.scard .val{font-weight:800;font-size:26px;line-height:1;letter-spacing:-.02em;color:var(--orange)}
.scard .cap{font-size:11.5px;color:var(--navy-55);line-height:1.4;overflow:hidden;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}

/* ---- inbox (Conversas) ---- */
.inbox{display:flex;flex:1;min-height:0;border:1px solid var(--navy-09);border-radius:var(--radius);overflow:hidden;background:#fff;box-shadow:var(--shadow-card)}
.inbox__list{width:344px;flex:none;border-right:1px solid var(--navy-09);display:flex;flex-direction:column;min-height:0}
.inbox__listhd{padding:var(--s-4);border-bottom:1px solid var(--navy-09)}
.inbox__rows{overflow-y:auto;flex:1}
.irow{display:flex;gap:12px;padding:13px 16px;border-bottom:1px solid var(--navy-05);cursor:pointer;position:relative}
.irow:hover{background:var(--cream)}
.irow.is-active{background:var(--cream-callout)}
.irow.is-active::before{content:"";position:absolute;left:0;top:8px;bottom:8px;width:3px;background:var(--orange)}
.irow .av{width:40px;height:40px;border-radius:50%;background:var(--navy);color:var(--cream);display:grid;place-items:center;font-weight:700;font-size:13px;flex:none}
.irow .body{flex:1;min-width:0}
.irow .top{display:flex;align-items:center;gap:7px}
.irow .top b{font-size:13.5px;color:var(--navy);font-weight:600}
.irow .prev{font-size:12.5px;color:var(--navy-55);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-top:3px}
.irow .meta{text-align:right;flex:none;display:flex;flex-direction:column;align-items:flex-end;gap:6px}
.irow .meta .t{font-size:11px;color:var(--navy-55)}
.irow .unread{background:var(--orange);color:#fff;font:700 10px/1 'Inter';min-width:18px;height:18px;border-radius:9px;display:grid;place-items:center;padding:0 5px}

/* ---- thread + bolhas ---- */
.thread{flex:1;display:flex;flex-direction:column;min-width:0}
.thread__hd{display:flex;align-items:center;gap:12px;padding:13px 18px;border-bottom:1px solid var(--navy-09)}
.thread__hd .av{width:38px;height:38px;border-radius:50%;background:var(--navy);color:var(--cream);display:grid;place-items:center;font-weight:700;font-size:12px}
.thread__hd .who{flex:1}
.thread__hd .who b{font-size:14px;color:var(--navy);font-weight:700}
.switch{display:inline-flex;align-items:center;gap:8px;font-size:12px;font-weight:600;color:var(--navy-72)}
.switch .track{width:34px;height:20px;border-radius:999px;background:var(--green-on);position:relative}
.switch .track::after{content:"";position:absolute;width:14px;height:14px;border-radius:50%;background:#fff;top:3px;right:3px}
.thread__msgs{flex:1;overflow-y:auto;padding:20px 18px;display:flex;flex-direction:column;gap:14px;background:var(--cream)}
.bubble{max-width:76%;padding:10px 13px;border-radius:14px;font-size:13.5px;line-height:1.5}
.bubble .w{display:flex;align-items:center;gap:6px;font:600 10px/1 'Inter';letter-spacing:.08em;text-transform:uppercase;margin-bottom:6px;opacity:.7}
.bubble .ts{font-size:10.5px;opacity:.55;margin-top:6px}
.bubble--in{align-self:flex-start;background:#fff;border:1px solid var(--navy-09);color:var(--navy);border-bottom-left-radius:4px}
.bubble--out{align-self:flex-end;background:var(--navy);color:var(--cream);border-bottom-right-radius:4px}
.bubble--out .w{color:var(--orange);opacity:1}
.composer{display:flex;align-items:center;gap:10px;padding:14px 18px;border-top:1px solid var(--navy-09)}
.composer .inp{flex:1;background:var(--cream-callout);border:1px solid var(--navy-15);border-radius:999px;padding:11px 16px;font-size:13.5px;color:var(--navy-55)}
.composer .send{width:40px;height:40px;border-radius:50%;background:var(--orange);color:#fff;display:grid;place-items:center;flex:none;border:0;cursor:pointer}
.composer .send [data-lucide]{width:18px;height:18px}

/* ---- broadcast cards ---- */
.bcard{padding:var(--s-5);margin-bottom:var(--s-4)}
.bcard .hd{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}
.bcard h3{font-size:16px}
.bcard .desc{font-size:12px;color:var(--navy-55);margin-top:5px}
.bcard .ft{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-top:15px;padding-top:14px;border-top:1px solid var(--navy-05)}
.bcard .msg{font-size:13px;color:var(--navy-72);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:520px}
.bcard .acts{display:flex;gap:8px;flex:none}

/* ---- templates ---- */
.chips-row{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:var(--s-6)}
.fchip{font:600 12.5px/1 'Inter';padding:8px 14px;border-radius:999px;border:1px solid var(--navy-15);color:var(--navy-72);background:#fff;cursor:pointer}
.fchip.is-active{background:var(--orange);color:#fff;border-color:var(--orange)}
.tpl{padding:var(--s-5);display:flex;flex-direction:column;gap:14px;min-height:184px}
.tpl h3{font-size:16px;line-height:1.25}
.tpl .desc{font-size:13px;color:var(--navy-55);line-height:1.5;flex:1;overflow:hidden;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}
.tpl .meta{display:flex;align-items:center;gap:12px;flex-wrap:wrap}
.tpl .meta .mi{display:inline-flex;align-items:center;gap:5px;font-size:11.5px;color:var(--navy-55)}
.tpl .meta .mi [data-lucide]{width:13px;height:13px}
