/* ==========================================================================
   VPJ Beef Express — Console (admin)  ·  sober enterprise design system
   Inter · base clara · sidebar grafite · vinho VPJ como acento contido.
   Responsivo: desktop (TV) + mobile (reunião no celular).
   ========================================================================== */
:root{
  --bg:#F5F6F8; --surface:#FFFFFF; --surface-2:#FAFBFC; --surface-3:#F2F4F7;
  --line:#E6E8EC; --line-2:#EEF0F3;
  --ink:#15171C; --ink-2:#3A404A; --muted:#6B7280; --faint:#9AA0A6;
  --sidebar:#15171C; --sidebar-2:#1B1E25; --sidebar-line:rgba(255,255,255,.07);
  --sidebar-text:#9298A3; --sidebar-hover:#C9CDD4; --sidebar-active:#FFFFFF;
  --wine:#7A0D14; --wine-2:#9A1620; --wine-soft:#FBEEF0;
  --green:#127A4B; --green-bg:#E6F4EC; --amber:#B45309; --amber-bg:#FBF1E1;
  --red:#B42318; --red-bg:#FBEAE7; --blue:#1D4ED8; --blue-bg:#E9EEFB; --slate:#475569;
  --r-sm:7px; --r:10px; --r-lg:14px;
  --shadow:0 1px 2px rgba(16,24,40,.06),0 1px 3px rgba(16,24,40,.05);
  --shadow-lg:0 12px 32px rgba(16,24,40,.16);
  --ff:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
  --sb-w:248px;
}
*{box-sizing:border-box;-webkit-tap-highlight-color:transparent;}
html,body{margin:0;padding:0;}
body{font-family:var(--ff);background:var(--bg);color:var(--ink);font-size:14px;line-height:1.45;-webkit-font-smoothing:antialiased;}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit;}
input,select,textarea{font-family:inherit;font-size:14px;}
a{color:inherit;text-decoration:none;}
.tnum{font-variant-numeric:tabular-nums;}
::selection{background:#d9c4a0;color:var(--ink);}
.muted{color:var(--muted);} .faint{color:var(--faint);}

/* ---------- shell ---------- */
.shell{display:flex;min-height:100vh;}
.sidebar{width:var(--sb-w);flex-shrink:0;background:var(--sidebar);color:var(--sidebar-text);
  display:flex;flex-direction:column;position:fixed;top:0;bottom:0;left:0;z-index:40;border-right:1px solid var(--sidebar-line);}
.sb-brand{display:flex;align-items:center;gap:10px;padding:18px 18px 16px;border-bottom:1px solid var(--sidebar-line);}
.sb-brand img{width:30px;height:30px;object-fit:contain;}
.sb-brand .nm{font-size:14.5px;font-weight:700;color:#fff;letter-spacing:-.2px;line-height:1;}
.sb-brand .tg{font-size:9px;letter-spacing:1.5px;color:var(--faint);margin-top:3px;font-weight:600;}
.sb-nav{flex:1;overflow-y:auto;padding:10px 10px 16px;scrollbar-width:thin;}
.sb-nav::-webkit-scrollbar{width:6px;} .sb-nav::-webkit-scrollbar-thumb{background:#2a2e36;border-radius:6px;}
.sb-group{font-size:10px;letter-spacing:1px;color:#5a5f69;font-weight:700;margin:16px 12px 6px;text-transform:uppercase;}
.sb-item{display:flex;align-items:center;gap:10px;width:100%;padding:8.5px 12px;border-radius:8px;font-size:13.5px;
  font-weight:500;color:var(--sidebar-text);transition:background .12s,color .12s;text-align:left;}
.sb-item svg{width:17px;height:17px;flex-shrink:0;opacity:.85;}
.sb-item:hover{color:var(--sidebar-hover);background:rgba(255,255,255,.04);}
.sb-item.on{color:var(--sidebar-active);background:rgba(255,255,255,.07);font-weight:600;}
.sb-item.on svg{opacity:1;color:#E8B4B8;}
.sb-item .count{margin-left:auto;font-size:11px;font-weight:700;background:var(--wine);color:#fff;border-radius:20px;padding:1px 7px;min-width:20px;text-align:center;}
.sb-item .dot{margin-left:auto;width:7px;height:7px;border-radius:50%;background:var(--green);}
.sb-user{display:flex;align-items:center;gap:10px;padding:12px 16px;border-top:1px solid var(--sidebar-line);}
.sb-user .av{width:32px;height:32px;border-radius:50%;background:linear-gradient(135deg,var(--wine),var(--wine-2));display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:12px;flex-shrink:0;}
.sb-user .nm{font-size:12.5px;color:#E6E7EA;font-weight:600;line-height:1.1;}
.sb-user .rl{font-size:10.5px;color:var(--faint);}

.main{flex:1;min-width:0;margin-left:var(--sb-w);display:flex;flex-direction:column;}
.topbar{position:sticky;top:0;z-index:30;background:rgba(245,246,248,.86);backdrop-filter:blur(10px);
  border-bottom:1px solid var(--line);padding:14px 28px;display:flex;align-items:center;gap:16px;min-height:62px;}
.topbar .ttl{font-size:18px;font-weight:700;letter-spacing:-.3px;line-height:1.1;}
.topbar .sub{font-size:12px;color:var(--muted);margin-top:1px;}
.topbar .right{margin-left:auto;display:flex;align-items:center;gap:10px;}
.hamb{display:none;width:38px;height:38px;border-radius:8px;border:1px solid var(--line);background:var(--surface);align-items:center;justify-content:center;}
.search{display:flex;align-items:center;gap:8px;background:var(--surface);border:1px solid var(--line);border-radius:8px;padding:7px 11px;width:220px;color:var(--faint);font-size:13px;}
.search input{border:none;outline:none;background:none;flex:1;color:var(--ink);width:100%;}
.pill-sel{display:flex;align-items:center;gap:7px;background:var(--surface);border:1px solid var(--line);border-radius:8px;padding:7px 11px;font-size:12.5px;font-weight:600;}
.content{padding:24px 28px 56px;animation:fade .18s ease;}
@keyframes fade{from{opacity:0;transform:translateY(4px)}to{opacity:1;transform:none}}

/* ---------- primitives ---------- */
.card{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);box-shadow:var(--shadow);}
.card-p{padding:18px;}
.card-h{display:flex;align-items:center;justify-content:space-between;padding:15px 18px;border-bottom:1px solid var(--line-2);}
.card-h .t{font-size:14px;font-weight:700;letter-spacing:-.2px;}
.grid{display:grid;gap:16px;}
.cols-4{grid-template-columns:repeat(4,1fr);} .cols-3{grid-template-columns:repeat(3,1fr);} .cols-2{grid-template-columns:repeat(2,1fr);}
.span2{grid-column:span 2;}
.row{display:flex;align-items:center;gap:12px;}
.between{display:flex;align-items:center;justify-content:space-between;gap:12px;}
.mt{margin-top:16px;} .mt-s{margin-top:10px;}

/* KPI */
.kpi{padding:16px 18px;}
.kpi .lbl{font-size:12px;color:var(--muted);font-weight:600;display:flex;align-items:center;gap:7px;}
.kpi .lbl svg{width:15px;height:15px;color:var(--faint);}
.kpi .val{font-size:27px;font-weight:750;letter-spacing:-.6px;margin-top:9px;line-height:1;}
.kpi .delta{font-size:11.5px;font-weight:600;margin-top:7px;display:inline-flex;align-items:center;gap:4px;}
.up{color:var(--green);} .down{color:var(--red);}

/* badges / pills */
.badge{display:inline-flex;align-items:center;gap:5px;font-size:11px;font-weight:600;padding:3px 9px;border-radius:20px;border:1px solid transparent;white-space:nowrap;}
.badge .d{width:6px;height:6px;border-radius:50%;}
.b-green{background:var(--green-bg);color:var(--green);} .b-amber{background:var(--amber-bg);color:var(--amber);}
.b-red{background:var(--red-bg);color:var(--red);} .b-blue{background:var(--blue-bg);color:var(--blue);}
.b-gray{background:var(--surface-3);color:var(--slate);} .b-wine{background:var(--wine-soft);color:var(--wine);}

/* buttons */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:7px;font-size:13px;font-weight:600;
  padding:8px 14px;border-radius:8px;border:1px solid transparent;transition:filter .12s,background .12s;white-space:nowrap;}
.btn:active{transform:translateY(.5px);}
.btn-pri{background:var(--wine);color:#fff;} .btn-pri:hover{background:var(--wine-2);}
.btn-sec{background:var(--surface);border-color:var(--line);color:var(--ink-2);} .btn-sec:hover{background:var(--surface-3);}
.btn-dark{background:var(--ink);color:#fff;} .btn-sm{padding:6px 10px;font-size:12px;}
.btn-ghost{color:var(--wine);font-weight:600;}

/* tables */
.tbl{width:100%;border-collapse:collapse;font-size:13px;}
.tbl thead th{font-size:11px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.3px;
  text-align:left;padding:11px 14px;background:var(--surface-2);border-bottom:1px solid var(--line-2);position:sticky;top:62px;}
.tbl tbody td{padding:12px 14px;border-bottom:1px solid var(--line-2);vertical-align:middle;}
.tbl tbody tr:last-child td{border-bottom:none;}
.tbl tbody tr:hover{background:var(--surface-2);}
.tbl .ralign{text-align:right;} .tbl .calign{text-align:center;}
.tbl-wrap{overflow:auto;border:1px solid var(--line);border-radius:var(--r-lg);background:var(--surface);box-shadow:var(--shadow);}
.tbl-wrap .tbl thead th{top:0;}
/* ordenação + filtro de tabela (tableWrap) */
.tbl th.th-sort{cursor:pointer;user-select:none;white-space:nowrap;transition:color .12s;}
.tbl th.th-sort:hover{color:var(--wine);}
.tbl th .sarr{display:inline-block;width:0;height:0;margin-left:5px;vertical-align:middle;border-left:3.5px solid transparent;border-right:3.5px solid transparent;border-top:4px solid currentColor;opacity:.22;}
.tbl th.sort-asc .sarr{border-top:0;border-bottom:5px solid currentColor;opacity:.95;}
.tbl th.sort-desc .sarr{border-top:5px solid currentColor;opacity:.95;}
.tbl th.sort-asc,.tbl th.sort-desc{color:var(--wine);}
.tbl-outer{display:block;}
.tbl-filter{display:flex;align-items:center;gap:8px;padding:0 0 11px;}
.tbl-filter svg{color:var(--faint);flex-shrink:0;}
.tbl-filter input{flex:0 1 280px;min-width:0;border:1px solid var(--line);border-radius:9px;padding:8px 11px;font-size:13px;font-family:inherit;color:var(--ink);background:#fff;outline:none;transition:border-color .12s;}
.tbl-filter input:focus{border-color:var(--wine);}
.tbl-filter .tbl-fcount{font-size:11.5px;color:var(--faint);font-variant-numeric:tabular-nums;}
.cellmain{font-weight:600;color:var(--ink);} .cellsub{font-size:11.5px;color:var(--muted);}
.avth{width:34px;height:34px;border-radius:8px;object-fit:cover;background:var(--surface-3);flex-shrink:0;}
.avround{width:34px;height:34px;border-radius:50%;background:linear-gradient(135deg,#3a404a,#15171c);color:#fff;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;flex-shrink:0;}

/* kanban */
.kanban{display:grid;grid-template-columns:repeat(5,1fr);gap:14px;align-items:start;}
.kcol{background:var(--surface-3);border-radius:var(--r-lg);padding:10px;min-height:60vh;}
.kcol-h{display:flex;align-items:center;justify-content:space-between;padding:6px 8px 12px;}
.kcol-h .t{font-size:12.5px;font-weight:700;display:flex;align-items:center;gap:7px;}
.kcard{background:var(--surface);border:1px solid var(--line);border-radius:10px;padding:12px;box-shadow:var(--shadow);margin-bottom:9px;cursor:pointer;transition:box-shadow .12s,transform .1s;}
.kcard:hover{box-shadow:var(--shadow-lg);transform:translateY(-1px);}

/* segmented */
.seg{display:inline-flex;background:var(--surface-3);border-radius:9px;padding:3px;gap:2px;}
.seg button{padding:6px 12px;border-radius:7px;font-size:12.5px;font-weight:600;color:var(--muted);}
.seg button.on{background:var(--surface);color:var(--ink);box-shadow:var(--shadow);}

/* toggle */
.tgl{width:38px;height:22px;border-radius:20px;background:#cbd0d8;position:relative;transition:background .15s;flex-shrink:0;}
.tgl.on{background:var(--green);}
.tgl::after{content:"";position:absolute;top:2px;left:2px;width:18px;height:18px;border-radius:50%;background:#fff;box-shadow:0 1px 2px rgba(0,0,0,.2);transition:left .15s;}
.tgl.on::after{left:18px;}

/* form fields */
.field{display:flex;flex-direction:column;gap:6px;margin-bottom:14px;}
.field label{font-size:12px;font-weight:600;color:var(--ink-2);}
.field input,.field select,.field textarea{border:1px solid var(--line);border-radius:8px;padding:9px 11px;background:var(--surface);color:var(--ink);outline:none;transition:border-color .12s,box-shadow .12s;}
.field input:focus,.field select:focus,.field textarea:focus{border-color:var(--wine);box-shadow:0 0 0 3px var(--wine-soft);}
.field .hint{font-size:11px;color:var(--faint);}
.frow{display:flex;gap:12px;} .frow>*{flex:1;}

/* drawer */
.scrim{position:fixed;inset:0;background:rgba(16,18,22,.42);z-index:60;opacity:0;pointer-events:none;transition:opacity .2s;}
.scrim.show{opacity:1;pointer-events:auto;}
.drawer{position:fixed;top:0;right:0;bottom:0;width:460px;max-width:94vw;background:var(--surface);z-index:70;
  box-shadow:var(--shadow-lg);transform:translateX(102%);transition:transform .24s cubic-bezier(.4,0,.2,1);display:flex;flex-direction:column;}
.drawer.show{transform:none;}
.drawer-h{display:flex;align-items:center;justify-content:space-between;padding:18px 20px;border-bottom:1px solid var(--line-2);}
.drawer-h .t{font-size:16px;font-weight:700;}
.drawer-b{flex:1;overflow-y:auto;padding:20px;}
.drawer-f{padding:14px 20px;border-top:1px solid var(--line-2);display:flex;gap:8px;flex-wrap:wrap;}
.xbtn{width:32px;height:32px;border-radius:8px;background:var(--surface-3);display:flex;align-items:center;justify-content:center;color:var(--muted);font-size:18px;}

/* mini bar/donut/spark */
.bars{display:flex;align-items:flex-end;gap:8px;height:150px;}
.bars .col{flex:1;display:flex;flex-direction:column;align-items:center;gap:6px;justify-content:flex-end;height:100%;}
.bars .b{width:100%;border-radius:5px 5px 0 0;background:linear-gradient(180deg,var(--wine),#a8434a);min-height:3px;}
.bars .b.alt{background:linear-gradient(180deg,#3a404a,#5a626e);}
.bars .lab{font-size:9.5px;color:var(--faint);}
.spark{display:flex;align-items:flex-end;gap:2px;height:44px;}
.spark span{flex:1;background:var(--wine-soft);border-radius:2px 2px 0 0;min-height:2px;}

/* list rows */
.lrow{display:flex;align-items:center;gap:12px;padding:13px 18px;border-bottom:1px solid var(--line-2);}
.lrow:last-child{border-bottom:none;}

/* map block */
.mapwrap{position:relative;border-radius:var(--r-lg);overflow:hidden;background:#11131a;}
.mapgrid{position:absolute;inset:0;opacity:.5;background:repeating-linear-gradient(0deg,transparent 0 26px,rgba(255,255,255,.05) 26px 27px),repeating-linear-gradient(90deg,transparent 0 30px,rgba(255,255,255,.05) 30px 31px);}
.pin{position:absolute;transform:translate(-50%,-50%);width:13px;height:13px;border-radius:50%;border:2px solid #11131a;box-shadow:0 0 0 1px rgba(255,255,255,.3);}
.pin.hub{width:16px;height:16px;background:#E8B4B8;}
.pin.on{background:var(--green);} .pin.busy{background:var(--amber);} .pin.off{background:#6B7280;}

/* progress */
.prog{height:7px;border-radius:6px;background:var(--surface-3);overflow:hidden;}
.prog>span{display:block;height:100%;border-radius:6px;background:var(--wine);}

/* toast */
.toast{position:fixed;bottom:22px;left:50%;transform:translate(-50%,16px);z-index:90;background:var(--ink);color:#fff;
  font-size:13px;font-weight:600;padding:11px 18px;border-radius:10px;box-shadow:var(--shadow-lg);opacity:0;transition:.22s;}
.toast.show{opacity:1;transform:translate(-50%,0);}

/* empty */
.empty{padding:60px 20px;text-align:center;color:var(--muted);font-size:13.5px;}

/* ---------- media CRUD (conteúdo do app) ---------- */
.med-thumb{position:relative;width:128px;height:66px;border-radius:10px;overflow:hidden;background:#1a120c;flex-shrink:0;}
.med-thumb img{width:100%;height:100%;object-fit:cover;opacity:.85;display:block;}
.med-thumb.med-thumb-sq{width:60px;height:60px;}
.med-thumb.med-thumb-sm{width:90px;height:50px;}
.med-thumb-ov{position:absolute;inset:0;background:linear-gradient(100deg,rgba(17,16,14,.78),transparent);}
.med-thumb-logo{position:absolute !important;left:8px;top:7px;height:13px !important;width:auto !important;background:rgba(251,247,240,.92);border-radius:4px;padding:2px 4px;opacity:1 !important;}
.med-thumb-kind{position:absolute;left:9px;bottom:7px;color:#F3E7CE;font-size:8px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;}
.med-logo{width:96px;height:48px;border-radius:8px;background:#fff;border:1px solid var(--line);display:flex;align-items:center;justify-content:center;flex-shrink:0;overflow:hidden;}
.med-logo img{max-height:30px;max-width:84px;object-fit:contain;}
.med-inp{border:1px solid var(--line);border-radius:7px;padding:6px 9px;font-size:12px;width:100%;background:var(--surface);color:var(--ink);outline:none;}
.med-inp:focus{border-color:var(--wine);box-shadow:0 0 0 3px var(--wine-soft);}
.med-btn{flex-shrink:0;}
.med-icon{padding:4px 8px;min-width:30px;font-size:13px;}

/* BI galáctico — inteligência (ECharts) */
.bi-insights{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:14px;}
.bi-chip{display:flex;align-items:center;gap:7px;background:var(--wine-soft);border:1px solid #ECD3D7;color:var(--wine);border-radius:20px;padding:7px 13px;font-size:12.5px;font-weight:600;}
.bi-chip svg{width:14px;height:14px;flex-shrink:0;}
.bi-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px;}
.bi-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);box-shadow:var(--shadow);padding:16px 16px 12px;display:flex;flex-direction:column;}
.bi-card-h{display:flex;align-items:baseline;justify-content:space-between;gap:10px;margin-bottom:6px;}
.bi-card-h .bi-t{font-size:13.5px;font-weight:700;letter-spacing:-.2px;color:var(--ink);}
.bi-card-h .bi-sub{font-size:11px;color:var(--faint);text-align:right;}
.bi-canvas{width:100%;}
.bi-note{font-size:11.5px;color:var(--muted);text-align:center;margin-top:2px;}
/* KDS — horário de funcionamento */
.kds-hours{border-top:1px solid var(--line-2);padding-top:10px;}
.kds-days{display:flex;gap:6px;flex-wrap:wrap;margin-top:4px;}
.kds-day{border:1px solid var(--line);background:var(--surface);color:var(--muted);border-radius:8px;padding:7px 11px;font-size:12px;font-weight:600;cursor:pointer;transition:.12s;min-width:42px;}
.kds-day.on{background:var(--wine);border-color:var(--wine);color:#fff;}

/* 3A — API & Tokens · Webhooks · Explorer · Cofre · RBAC */
.api-mono{font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;font-size:12px;}
.api-token-box{background:var(--surface-3);border:1px solid var(--line);border-radius:8px;padding:10px 12px;}
.api-token-box code{font-size:12px;line-height:1.6;color:var(--ink);}
.api-evt{display:inline-block;background:var(--surface-3);border:1px solid var(--line);border-radius:6px;padding:4px 9px;}
.api-ep{gap:12px;align-items:center;}
.api-method{flex-shrink:0;font-weight:700;font-size:10.5px;letter-spacing:.4px;border-radius:6px;padding:3px 8px;min-width:54px;text-align:center;}
.api-path{flex-shrink:0;font-weight:600;}
.api-desc{flex:1;font-size:12px;text-align:right;min-width:0;}
.api-token-box .api-mono{word-break:break-all;}
/* RBAC matriz */
.rbac-wrap{max-height:480px;}
.rbac-tbl th,.rbac-tbl td{white-space:nowrap;}
.rbac-modh{font-size:10.5px;font-weight:700;text-transform:none;}
.rbac-cell{padding:8px 10px;}
.rbac-cb{width:16px;height:16px;accent-color:var(--wine);cursor:pointer;}
@media(max-width:680px){ .api-ep{flex-wrap:wrap;} .api-desc{text-align:left;flex-basis:100%;} }

/* Leva 4 — Canais (tombamento) · repasse automático */
.ch-foot{display:flex;gap:6px;padding:0 18px 16px;flex-wrap:wrap;}
.ch-sim{display:flex;gap:8px;flex-wrap:wrap;}

/* 3B — Comms (Atendente WhatsApp · Contratos · E-mail Resend) */
.wa-qr-holder{display:flex;flex-direction:column;align-items:flex-start;}
.wa-qr{background:#fff;border:1px solid var(--line);border-radius:12px;padding:14px;box-shadow:var(--shadow);}
.wa-qr img{display:block;width:208px;height:208px;image-rendering:pixelated;}
.wa-tmpl{border:1px solid var(--line);border-radius:8px;padding:8px 10px;background:var(--surface);color:var(--ink);font-family:inherit;font-size:13px;line-height:1.45;resize:vertical;outline:none;transition:border-color .12s,box-shadow .12s;}
.wa-tmpl:focus{border-color:var(--wine);box-shadow:0 0 0 3px var(--wine-soft);}
.wa-vault,.wa-vault-form{display:block;}
.wa-vault summary{padding:6px 0;}
.contract-terms{background:var(--surface-3);border:1px solid var(--line);border-radius:10px;padding:16px 18px;font-size:12.5px;line-height:1.65;color:var(--ink-2);max-height:340px;overflow-y:auto;white-space:normal;}
/* contratos — modelos & categorias */
.ct-cat-head{font-size:10.5px;font-weight:700;letter-spacing:.6px;text-transform:uppercase;color:var(--faint);margin:14px 0 6px;}
.ct-cat-head:first-child{margin-top:0;}
.ct-tpl{display:flex;align-items:center;gap:12px;padding:11px 0;border-bottom:1px solid var(--line-2);}
.ct-tpl:last-child{border-bottom:none;}
.ct-tpl-main{flex:1;min-width:0;display:flex;flex-direction:column;gap:3px;}
.ct-tpl-main b{font-size:13.5px;margin-right:6px;}
.ct-tpl-sub{font-size:11.5px;color:var(--muted);line-height:1.4;}
.ct-chips{display:flex;flex-wrap:wrap;gap:8px;}
.ct-chip{display:inline-flex;align-items:center;gap:7px;background:var(--wine-soft);border:1px solid #ECD3D7;color:var(--wine);border-radius:20px;padding:6px 7px 6px 12px;font-size:12.5px;font-weight:600;}
.ct-chip-x{display:inline-flex;align-items:center;justify-content:center;width:18px;height:18px;border-radius:50%;font-size:11px;color:var(--wine);background:transparent;border:none;cursor:pointer;line-height:1;}
.ct-chip-x:hover{background:rgba(122,13,20,.12);}
.ct-add-inp{border:1px solid var(--line);border-radius:8px;padding:9px 11px;background:var(--surface);color:var(--ink);outline:none;font-size:13px;transition:border-color .12s,box-shadow .12s;}
.ct-add-inp:focus{border-color:var(--wine);box-shadow:0 0 0 3px var(--wine-soft);}
.ct-select{width:100%;border:1px solid var(--line);border-radius:8px;padding:9px 11px;background:var(--surface);color:var(--ink);outline:none;font-size:13px;transition:border-color .12s,box-shadow .12s;}
.ct-select:focus{border-color:var(--wine);box-shadow:0 0 0 3px var(--wine-soft);}
.ct-ph{font-size:11px;color:var(--faint);margin:-6px 0 12px;line-height:1.5;}
.ct-ph code{background:var(--surface-3);border:1px solid var(--line-2);border-radius:5px;padding:1px 5px;font-size:10.5px;color:var(--ink-2);}
.ct-note{background:var(--amber-bg);border:1px solid #EAD9B0;color:#8a6a1a;border-radius:8px;padding:9px 12px;font-size:11.5px;line-height:1.5;margin-bottom:12px;}
.email-editor{display:flex;gap:0;}
.email-events{flex:0 0 200px;border-right:1px solid var(--line-2);display:flex;flex-direction:column;}
.email-evt{display:flex;align-items:center;justify-content:space-between;gap:8px;padding:11px 16px;font-size:12.5px;color:var(--ink-2);border-bottom:1px solid var(--line-2);text-align:left;transition:.12s;}
.email-evt:hover{background:var(--surface-3);}
.email-evt.on{background:var(--wine-soft);color:var(--wine);font-weight:600;box-shadow:inset 3px 0 0 var(--wine);}
.email-evt-st{font-size:11px;color:var(--green);}
.email-pane{flex:1;min-width:0;padding:16px 18px;}
.email-preview{width:100%;height:200px;border:1px solid var(--line);border-radius:8px;background:#fff;}
@media(max-width:680px){ .email-editor{flex-direction:column;} .email-events{flex-basis:auto;border-right:none;border-bottom:1px solid var(--line-2);flex-direction:row;overflow-x:auto;} .email-evt{border-bottom:none;white-space:nowrap;} .email-evt.on{box-shadow:inset 0 -3px 0 var(--wine);} .wa-qr img{width:170px;height:170px;} }

/* ---------- Checklist & Documentação (estilo Notion) ---------- */
.ckl-card .card-h{align-items:baseline;}
.ckl-total{font-size:12px;}
.ckl-saving{color:var(--amber);font-weight:600;}
.ckl-body{padding:8px 18px 18px;}
.ckl-sec{padding:14px 0 10px;border-bottom:1px solid var(--line-2);}
.ckl-sec:first-child{padding-top:6px;}
.ckl-sec-h{display:flex;align-items:center;gap:10px;margin-bottom:6px;}
.ckl-sec-t{flex:1;font-size:14.5px;font-weight:700;letter-spacing:-.2px;color:var(--ink);padding:3px 6px;border-radius:7px;outline:none;min-width:40px;transition:background .12s;}
.ckl-sec-t:hover{background:var(--surface-3);}
.ckl-sec-t:focus{background:var(--surface-3);box-shadow:0 0 0 2px var(--wine-soft);}
.ckl-sec-prog{font-size:11.5px;font-weight:700;color:var(--muted);background:var(--surface-3);border-radius:20px;padding:2px 10px;flex-shrink:0;}
.ckl-sec-x{width:24px;height:24px;border-radius:6px;color:var(--faint);font-size:12px;flex-shrink:0;display:flex;align-items:center;justify-content:center;opacity:0;transition:.12s;}
.ckl-sec:hover .ckl-sec-x{opacity:1;}
.ckl-sec-x:hover{background:var(--red-bg);color:var(--red);}
.ckl-items{display:flex;flex-direction:column;}
.ckl-item{display:flex;align-items:flex-start;gap:10px;padding:5px 6px;border-radius:8px;transition:background .12s;}
.ckl-item:hover{background:var(--surface-2);}
.ckl-cb{flex-shrink:0;width:19px;height:19px;border-radius:5px;border:1.6px solid #c4c9d1;background:var(--surface);color:#fff;font-size:12px;line-height:1;display:flex;align-items:center;justify-content:center;margin-top:2px;transition:.12s;}
.ckl-cb:hover{border-color:var(--wine);}
.ckl-cb.on{background:var(--green);border-color:var(--green);}
.ckl-item-main{flex:1;min-width:0;display:flex;flex-direction:column;gap:1px;}
.ckl-text{font-size:13.5px;color:var(--ink);padding:2px 5px;border-radius:6px;outline:none;line-height:1.45;transition:background .12s;}
.ckl-text:hover{background:var(--surface-3);}
.ckl-text:focus{background:var(--surface-3);box-shadow:0 0 0 2px var(--wine-soft);}
.ckl-text:empty::before,.ckl-note:empty::before{content:attr(data-ph);color:var(--faint);pointer-events:none;}
.ckl-item.done .ckl-text{text-decoration:line-through;color:var(--faint);}
.ckl-note{font-size:11.5px;color:var(--muted);padding:1px 5px;border-radius:6px;outline:none;line-height:1.4;transition:background .12s,color .12s;}
.ckl-note:empty::before{font-size:11px;color:var(--faint);opacity:0;transition:opacity .12s;}
.ckl-item:hover .ckl-note:empty::before{opacity:1;}
.ckl-note:focus{background:var(--surface-3);box-shadow:0 0 0 2px var(--wine-soft);}
.ckl-note:focus:empty::before{opacity:1;}
.ckl-x{flex-shrink:0;width:22px;height:22px;border-radius:6px;color:var(--faint);font-size:12px;display:flex;align-items:center;justify-content:center;margin-top:1px;opacity:0;transition:.12s;}
.ckl-item:hover .ckl-x{opacity:1;}
.ckl-x:hover{background:var(--red-bg);color:var(--red);}
.ckl-add{font-size:12.5px;font-weight:600;color:var(--muted);padding:6px 6px;border-radius:7px;margin-top:4px;text-align:left;transition:.12s;}
.ckl-add:hover{background:var(--surface-3);color:var(--wine);}
.ckl-add-item{margin-left:29px;}
.ckl-add-sec{margin-top:12px;color:var(--wine);font-weight:700;}

/* responsive — mobile (reunião no celular) */
.sb-scrim{display:none;}
@media(max-width:1080px){ .cols-4{grid-template-columns:repeat(2,1fr);} .kanban{grid-template-columns:1fr 1fr;} }
@media(max-width:860px){ .bi-grid{grid-template-columns:1fr;} }
@media(max-width:860px){
  .sidebar{transform:translateX(-102%);transition:transform .24s;box-shadow:var(--shadow-lg);}
  .sidebar.open{transform:none;}
  .sb-scrim{display:block;position:fixed;inset:0;background:rgba(0,0,0,.4);z-index:39;opacity:0;pointer-events:none;transition:.2s;}
  .sb-scrim.show{opacity:1;pointer-events:auto;}
  .main{margin-left:0;}
  .hamb{display:flex;}
  .search{display:none;}
  .content{padding:18px 16px 60px;}
  .topbar{padding:12px 16px;}
  .cols-4,.cols-3,.cols-2,.kanban{grid-template-columns:1fr;}
  .span2{grid-column:auto;}
  .drawer{width:100%;}
  .tbl thead th{top:0;}
}
