@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600&display=swap');
/* Tobia — painel admin. Design system v2 (neutros arroxeados + 1 primária violet, Inter). */
:root{
  /* escala neutra (matiz frio, não slate cru) */
  --gray-50:#f8f9fc; --gray-100:#f1f2f7; --gray-200:#e6e8f0; --gray-300:#d4d7e3;
  --gray-400:#9aa0b4; --gray-500:#6b7185; --gray-700:#3a3f52; --gray-900:#16182b;
  /* primária da marca */
  --primary:#6d5efc; --primary-strong:#5646d6; --primary-soft:#eef0ff;
  /* status: par fundo-suave + texto-forte */
  --ok:#067647; --ok-bg:#e7f6ec; --warn:#b45309; --warn-bg:#fdf3e2;
  --danger:#b42318; --danger-bg:#fdeceb; --info:#175cd3; --info-bg:#eaf1fd;
  /* raios e sombras por elevação */
  --radius-sm:6px; --radius-md:10px; --radius-lg:14px;
  --shadow-xs:0 1px 2px rgba(22,24,43,.05); --shadow-md:0 8px 20px -6px rgba(22,24,43,.14);
  /* aliases legados (views antigas usam var(--brand)/--ink/etc via style inline) */
  --bg:var(--gray-50); --card:#fff; --ink:var(--gray-900); --muted:var(--gray-500);
  --line:var(--gray-200); --brand:var(--primary); --brand-d:var(--primary-strong);
  --radius:var(--radius-md); --shadow:var(--shadow-xs);
}
*{box-sizing:border-box}
body{margin:0;font:14px/1.5 Inter,-apple-system,Segoe UI,Roboto,sans-serif;color:var(--gray-700);
  background:var(--gray-50);-webkit-font-smoothing:antialiased;font-feature-settings:'cv02','cv03'}
a{color:var(--primary);text-decoration:none}
a:hover{text-decoration:underline}
h1,h2{margin:0 0 .6rem;color:var(--gray-900);font-weight:600;letter-spacing:-.01em}
.muted{color:var(--gray-500)}
.small{font-size:.82rem}
.num,.kpi-n,.fc,.col-count{font-variant-numeric:tabular-nums}
.ic{width:16px;height:16px;flex:none;vertical-align:-3px}
.ic-lg{width:18px;height:18px}

/* ---- shell: sidebar fixa + conteúdo ---- */
body.has-nav{display:flex;min-height:100vh}
.sidebar{width:236px;flex:none;position:sticky;top:0;height:100vh;overflow-y:auto;background:#fff;border-right:1px solid var(--gray-200);display:flex;flex-direction:column;padding:1rem .7rem;gap:.15rem}
.sidebar__brand{display:flex;align-items:center;gap:.5rem;font-weight:600;font-size:1.05rem;letter-spacing:-.01em;color:var(--gray-900);padding:.4rem .6rem 1rem}
.sidebar__name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.sidebar__nav{display:flex;flex-direction:column;gap:.12rem;flex:1}
.sidebar__nav a{display:flex;align-items:center;gap:.65rem;padding:.55rem .7rem;border-radius:var(--radius-sm);color:var(--gray-600);font-weight:500;font-size:.9rem}
.sidebar__nav a:hover{background:var(--gray-100);color:var(--gray-900);text-decoration:none}
.sidebar__nav a.on{background:var(--primary-soft);color:var(--primary-strong)}
.sidebar__nav a .ic{width:17px;height:17px;flex:none}
.nav-badge{margin-left:auto;min-width:18px;height:18px;line-height:18px;padding:0 5px;border-radius:9px;background:#ef4444;color:#fff;font-size:.72rem;font-weight:700;text-align:center}
.sidebar__foot{border-top:1px solid var(--gray-200);margin-top:.5rem;padding-top:.7rem;display:flex;flex-direction:column;gap:.5rem;font-size:.86rem}
.sidebar__foot .who{color:var(--gray-500);display:flex;align-items:center;gap:.45rem}
.sidebar__foot .who span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.sidebar__foot .who .ic{width:15px;height:15px;flex:none}
.sidebar__foot .logout{background:none;border:0;padding:0;font:inherit;cursor:pointer;color:var(--gray-500);text-align:left}
.sidebar__foot .logout:hover{color:var(--gray-800)}
.content{flex:1;min-width:0;display:flex;flex-direction:column}
.owner-badge{background:var(--primary-soft);color:var(--primary-strong);padding:.1rem .5rem;border-radius:999px;font-weight:600;font-size:.68rem}
.switch-form{display:block}
.switch-back{width:100%;background:var(--primary-soft);color:var(--primary-strong);border:1px solid #d6d9ff;border-radius:var(--radius-sm);padding:.4rem .7rem;font-weight:600;font-size:.84rem;cursor:pointer;display:flex;align-items:center;gap:.4rem;justify-content:center}
.switch-back:hover{background:#e2e5ff}
.switch-back .ic{width:15px;height:15px}
.preview-bar{background:var(--warn-bg);border-bottom:1px solid #f7d9a8;color:var(--warn);padding:.55rem 1.5rem;font-size:.86rem;text-align:center}
.preview-bar .linkbtn{background:none;border:0;color:var(--warn);font-weight:600;text-decoration:underline;cursor:pointer;padding:0;font:inherit}

.wrap{max-width:1180px;margin:1.75rem auto;padding:0 1.75rem;width:100%}
body.embed .wrap{max-width:none;margin:1rem auto}
table.list tr.row-link{cursor:pointer}
table.list tr.row-link:hover td{background:var(--gray-50)}
.foot{text-align:center;color:var(--gray-400);font-size:.8rem;padding:2rem}
.page-title{font-size:1.5rem;letter-spacing:-.02em;color:var(--gray-900)}

/* ---- flash / toast ---- */
.flash{padding:.7rem 1rem;border-radius:var(--radius-sm);margin-bottom:1rem;font-weight:500;border:1px solid transparent}
.flash-error{background:var(--danger-bg);color:var(--danger);border-color:#f6cdc9}
.flash-success{background:var(--ok-bg);color:var(--ok);border-color:#bfe6cc}
#toast-wrap{position:fixed;top:18px;right:18px;z-index:1000;display:flex;flex-direction:column;gap:.5rem;max-width:360px}
.toast{background:#fff;border:1px solid var(--gray-200);border-left:3px solid var(--gray-400);border-radius:var(--radius-sm);
  box-shadow:var(--shadow-md);padding:.7rem .9rem;display:flex;align-items:center;gap:.6rem;color:var(--gray-700);font-weight:500;
  animation:toast-in .16s ease-out}
.toast.ok{border-left-color:var(--ok)} .toast.err{border-left-color:var(--danger)} .toast.info{border-left-color:var(--info)}
.toast svg{width:18px;height:18px;flex:none}
@keyframes toast-in{from{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:none}}
.toast.out{opacity:0;transform:translateY(-6px);transition:opacity .18s,transform .18s}

/* ---- modal (confirm estilizado + modais do board) ---- */
.modal-backdrop{position:fixed;inset:0;z-index:1000;display:flex;align-items:center;justify-content:center;background:rgba(22,24,43,.45)}
.modal-card{background:#fff;border-radius:14px;padding:1.4rem 1.4rem 1.2rem;width:min(400px,92vw);box-shadow:0 20px 50px rgba(0,0,0,.28)}
.modal-card h2{margin:0 0 .2rem;font-size:1.1rem}
.modal-actions{display:flex;gap:.5rem;justify-content:flex-end;margin-top:1.1rem}

/* ---- empty states ---- */
.empty{display:flex;flex-direction:column;align-items:center;text-align:center;gap:.45rem;padding:2.4rem 1rem;color:var(--gray-500)}
.empty .empty-ic{width:40px;height:40px;color:var(--gray-300)}
.empty-title{font-weight:600;color:var(--gray-700)}
.empty-sub{font-size:.85rem;max-width:38ch;margin:0}
.empty .btn-link{margin-top:.4rem}
.empty-row td{padding:0}
.col-empty{border:1.5px dashed var(--gray-200);border-radius:var(--radius-sm);padding:1.1rem .6rem;text-align:center;color:var(--gray-400);font-size:.8rem}

.nowrap{white-space:nowrap}

/* ---- termômetro do lead (frio / morno / quente) ---- */
.therm{display:inline-block;padding:.1rem .5rem;border-radius:999px;font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:.03em;vertical-align:middle;cursor:default}
.therm-frio{background:var(--info-bg);color:var(--info)}
.therm-morno{background:var(--warn-bg);color:var(--warn)}
.therm-quente{background:var(--danger-bg);color:var(--danger)}

/* ---- KPIs ---- */
.kpis{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;margin-bottom:1.5rem}
.kpi{background:#fff;border:1px solid var(--gray-200);border-radius:var(--radius-md);padding:1.25rem;box-shadow:var(--shadow-xs)}
.kpi-n{display:block;font-size:1.875rem;font-weight:600;letter-spacing:-.02em;color:var(--gray-900);margin-top:.35rem}
.kpi-l{color:var(--gray-500);font-size:.82rem}

/* ---- panels / grid ---- */
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.panel{background:#fff;border:1px solid var(--gray-200);border-radius:var(--radius-md);padding:1.25rem;box-shadow:var(--shadow-xs)}
.panel h2{font-size:.95rem;color:var(--gray-900);font-weight:600;text-transform:none;letter-spacing:-.01em}

/* ---- funnel ---- */
.funnel{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.6rem}
.funnel li{display:grid;grid-template-columns:1fr 2fr auto;align-items:center;gap:.6rem}
.fname{display:flex;align-items:center;gap:.4rem;font-size:.88rem}
.dot{width:8px;height:8px;border-radius:50%;display:inline-block;flex:none}
.bar{background:var(--gray-100);border-radius:999px;height:8px;overflow:hidden}
.bar>span{display:block;height:100%;border-radius:999px;min-width:2px}
.fc{font-weight:600}

/* ---- tables ---- */
table{width:100%;border-collapse:collapse}
table.mini td{padding:.4rem 0;border-bottom:1px solid var(--gray-100)}
table.list{background:#fff;border:1px solid var(--gray-200);border-radius:var(--radius-md);overflow:hidden;box-shadow:var(--shadow-xs)}
table.list th{text-align:left;font-size:.75rem;text-transform:none;letter-spacing:0;color:var(--gray-500);font-weight:500;padding:.7rem 1rem;background:var(--gray-50);border-bottom:1px solid var(--gray-200)}
table.list td{padding:.8rem 1rem;border-bottom:1px solid var(--gray-100);font-variant-numeric:tabular-nums}
table.list tr:last-child td{border-bottom:0}

/* ---- badges ---- */
.badge{display:inline-flex;align-items:center;gap:.35rem;color:#fff;padding:.2rem .6rem;border-radius:999px;font-size:.75rem;font-weight:500;white-space:nowrap}
.badge.big{font-size:.85rem;padding:.3rem .8rem}
.status-ativo{background:var(--ok-bg);color:var(--ok)}
.status-trial{background:var(--warn-bg);color:var(--warn)}
.status-suspenso{background:var(--danger-bg);color:var(--danger)}
.recorr{color:var(--warn);font-weight:600;font-size:.8rem}
.recorr.small{font-size:.72rem}

/* ---- filters / forms ---- */
input,select,textarea,button{font:inherit}
input,select,textarea{padding:.55rem .7rem;border:1px solid var(--gray-300);border-radius:var(--radius-sm);background:#fff;width:100%;color:var(--gray-900)}
input::placeholder,textarea::placeholder{color:var(--gray-400)}
input:focus,select:focus,textarea:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px rgba(109,94,252,.15)}
button{cursor:pointer;background:var(--primary);color:#fff;border:0;border-radius:var(--radius-sm);padding:.6rem 1rem;font-weight:600}
button:hover{background:var(--primary-strong)}
button:focus-visible{outline:2px solid var(--primary);outline-offset:2px}
button:disabled{opacity:.5;cursor:not-allowed}
button.danger{background:var(--danger)}button.danger:hover{background:#98271e}
.filters{display:flex;gap:.6rem;margin-bottom:1rem;flex-wrap:wrap;align-items:center}
.filters input[type=search]{flex:1 1 260px;min-width:230px}
.filters input[type=date]{width:auto;flex:0 0 auto}
.filters select{width:auto}
.filters button{width:auto}

/* ---- menu dropdown (details/summary, sem JS de framework) ---- */
.menu{position:relative}
.menu>summary{list-style:none;display:inline-flex;align-items:center;gap:.4rem;background:#fff;border:1px solid var(--gray-300);color:var(--gray-700);border-radius:var(--radius-sm);padding:.45rem .75rem;font-weight:500;font-size:.82rem;cursor:pointer;white-space:nowrap;user-select:none}
.menu>summary::-webkit-details-marker{display:none}
.menu>summary:hover{background:var(--gray-50)}
.menu-list{position:absolute;right:0;top:calc(100% + 6px);background:#fff;border:1px solid var(--gray-200);border-radius:var(--radius-md);box-shadow:var(--shadow-md);min-width:210px;padding:.35rem;z-index:200;display:flex;flex-direction:column}
.menu-list a{padding:.5rem .7rem;border-radius:8px;color:var(--gray-700);text-decoration:none;font-weight:500;font-size:.85rem;display:flex;align-items:center;gap:.55rem}
.menu-list a:hover{background:var(--gray-50);color:var(--gray-900)}
.pager{display:flex;gap:.3rem;margin-top:1rem;flex-wrap:wrap}
.pager a{padding:.35rem .7rem;border:1px solid var(--gray-300);border-radius:var(--radius-sm);background:#fff;color:var(--gray-700)}
.pager a:hover{background:var(--gray-50);text-decoration:none}
.pager a.on{background:var(--primary);color:#fff;border-color:var(--primary)}

/* lead detail */
.lead-head{display:flex;justify-content:space-between;align-items:flex-start;gap:1rem;margin-bottom:1rem}
.row-form{display:flex;gap:.5rem;margin-top:.8rem}
.row-form select{width:auto;flex:1}
.row-form button{width:auto;white-space:nowrap}
.note-form{margin-bottom:1rem}
.note-form textarea{margin-bottom:.5rem}
.note-form button{width:auto}
.timeline{list-style:none;margin:0;padding:0 .45rem 0 0;display:flex;flex-direction:column;gap:.8rem;max-height:360px;overflow-y:auto;scrollbar-width:thin;scrollbar-color:var(--gray-300) transparent}
.timeline::-webkit-scrollbar{width:9px}
.timeline::-webkit-scrollbar-track{background:transparent}
.timeline::-webkit-scrollbar-thumb{background:var(--gray-300);border-radius:6px}
.timeline::-webkit-scrollbar-thumb:hover{background:var(--gray-400)}
.timeline li{border-left:2px solid var(--gray-200);padding:.1rem 0 .1rem .85rem}
.timeline li.t-sistema{border-color:var(--gray-400)}
.timeline li.t-status{border-color:var(--primary)}
.timeline li.t-nota{border-color:var(--ok)}
.timeline li.t-chat{border-color:var(--info)}
.timeline li.t-tarefa{border-color:var(--warn)}
.t-meta{font-size:.72rem;color:var(--gray-500);text-transform:uppercase;letter-spacing:.03em}
.t-meta .ic{width:13px;height:13px;vertical-align:-2px;margin-right:1px}
.tl-filters .btn-soft{padding:.15rem .55rem;font-size:.75rem}
.tl-filters .btn-soft.on{background:var(--primary);color:#fff;border-color:var(--primary)}
.form-card{background:#fff;border:1px solid var(--gray-200);border-radius:var(--radius-md);padding:1.25rem;box-shadow:var(--shadow-xs);display:flex;flex-direction:column;gap:.85rem;max-width:520px}
.form-card label{display:flex;flex-direction:column;gap:.3rem;font-weight:500;font-size:.82rem;color:var(--gray-700)}
.form-card button{width:auto;align-self:flex-start;margin-top:.4rem}

/* ---- botões secundários / detalhes ---- */
.btn-link{display:inline-flex;align-items:center;gap:.4rem;padding:.55rem 1rem;border:1px solid var(--gray-300);border-radius:var(--radius-sm);background:#fff;color:var(--gray-700);font-weight:600}
.btn-link:hover{background:var(--gray-50);text-decoration:none}
.lead-head__actions{display:flex;align-items:center;gap:.6rem;flex-wrap:wrap}
.view-toggle{display:inline-flex;border:1px solid var(--gray-300);border-radius:var(--radius-sm);overflow:hidden;background:#fff}
.view-toggle button{padding:.45rem .95rem;color:var(--gray-500);font-weight:500;font-size:.85rem;background:#fff;border:0;cursor:pointer;border-radius:0}
.view-toggle button:hover{background:var(--gray-50)}
.view-toggle button.on{background:var(--primary);color:#fff}
.view-toggle button.on:hover{background:var(--primary-strong)}
.lead-head__left{display:flex;align-items:center;gap:1rem;flex-wrap:wrap}
.btn-soft{display:inline-flex;align-items:center;gap:.4rem;background:#fff;border:1px solid var(--gray-300);color:var(--gray-700);border-radius:var(--radius-sm);padding:.45rem .75rem;font-weight:500;font-size:.82rem;cursor:pointer;white-space:nowrap}
.btn-soft:hover{background:var(--gray-50)}
.btn-soft.danger-soft{color:var(--danger);border-color:#f0c9c5}
.btn-soft.danger-soft:hover{background:var(--danger-bg)}
.rowlink-name{color:var(--gray-900);font-weight:500}
.etapa-add input[name=name]{flex:1}
.etapa-add input[type=color],.etapa-edit input[type=color]{width:40px;height:38px;padding:2px;flex:none;cursor:pointer}
.etapas-list{display:flex;flex-direction:column;gap:.5rem;max-width:760px}
.etapa-item{display:flex;align-items:center;gap:.6rem;background:#fff;border:1px solid var(--gray-200);border-radius:var(--radius-md);padding:.6rem .8rem;box-shadow:var(--shadow-xs)}
.etapa-edit{display:flex;align-items:center;gap:.5rem;flex:1;flex-wrap:wrap}
.etapa-edit input[name=name]{flex:1;min-width:130px}
.etapa-edit button{width:auto}
.etapa-cli{display:flex;align-items:center;gap:.3rem;font-size:.78rem;color:var(--gray-500);font-weight:500;white-space:nowrap}
.etapa-cli input{width:auto}
.etapa-ord{display:flex;gap:.3rem;flex:none}
.etapa-ord form{display:inline}
.etapa-ord .btn-soft{padding:.35rem .55rem}
details > summary{cursor:pointer}
.newacc{margin-bottom:1rem}
.newacc-form{padding-top:1rem}
.newacc-form .filters{flex-wrap:wrap}
.form-card.bare{box-shadow:none;border:0;padding:0;background:transparent}
.form-card.wide{max-width:none}
.acc-actions{display:flex;gap:.5rem;align-items:stretch}

/* ---- toggle de feature (switch iOS-style) ---- */
.feature-toggle{display:flex;align-items:center;justify-content:space-between;gap:1rem;background:var(--gray-50);border:1px solid var(--gray-200);border-radius:var(--radius-md);padding:.85rem 1rem;margin-bottom:.6rem;cursor:pointer}
/* grid de features: boxes compactos, varios por linha (ocupa menos vertical) */
.feature-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(230px,1fr));gap:.5rem;margin:.2rem 0 .6rem}
.form-card .feature-grid .feature-toggle--compact{flex-direction:row;align-items:center;justify-content:space-between;gap:.6rem;padding:.55rem .7rem;margin:0;min-height:0}
.feature-grid .feature-toggle--compact .feature-toggle__text{flex-direction:row}
.feature-grid .feature-toggle--compact .feature-toggle__text strong{font-size:.8rem;line-height:1.25}
.feature-toggle__text{display:flex;flex-direction:column;gap:.15rem}
.feature-toggle__text strong{color:var(--gray-900);font-weight:600}
.feature-toggle__text small{color:var(--gray-500);font-size:.82rem}
.switch{position:relative;flex:none;width:44px;height:24px}
.switch input{position:absolute;opacity:0;width:0;height:0}
.switch__slider{position:absolute;inset:0;background:var(--gray-300);border-radius:999px;transition:background .2s}
.switch__slider::before{content:"";position:absolute;height:18px;width:18px;left:3px;top:3px;background:#fff;border-radius:50%;box-shadow:0 1px 2px rgba(22,24,43,.25);transition:transform .2s}
.switch input:checked + .switch__slider{background:var(--primary)}
.switch input:checked + .switch__slider::before{transform:translateX(20px)}
.switch input:focus-visible + .switch__slider{outline:2px solid var(--primary);outline-offset:2px}

/* ---- contas (owner) ---- */
.cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:1rem}
.acc-card{background:#fff;border:1px solid var(--gray-200);border-radius:var(--radius-md);padding:1.1rem;box-shadow:var(--shadow-xs);display:flex;flex-direction:column;gap:.5rem}
.acc-head{display:flex;justify-content:space-between;align-items:center}
.acc-card button{width:100%;margin-top:.3rem}
.svc-toggles{display:flex;flex-direction:column;gap:.45rem;margin:.5rem 0 .2rem;padding:.55rem .7rem;background:var(--gray-50);border:1px solid var(--gray-200);border-radius:var(--radius-sm)}
.svc{display:flex;align-items:center;justify-content:space-between;font-size:.85rem;font-weight:500;color:var(--gray-900)}
.svc small{color:var(--gray-500);font-weight:400}

/* ---- chat log (conversa) ---- */
.chat-log{display:flex;flex-direction:column;gap:.6rem}
.msg{max-width:80%;padding:.55rem .8rem;border-radius:var(--radius-md)}
.msg-role{font-size:.72rem;color:var(--gray-500);margin-bottom:.2rem}
.msg-user{align-self:flex-end;background:var(--primary-soft)}
.msg-assistant{align-self:flex-start;background:var(--gray-50);border:1px solid var(--gray-200)}

/* ---- board kanban ---- */
.board{display:flex;gap:.85rem;overflow-x:auto;padding-bottom:.85rem;align-items:flex-start;scrollbar-width:thin;scrollbar-color:var(--gray-400) var(--gray-100)}
.board::-webkit-scrollbar{height:12px}
.board::-webkit-scrollbar-track{background:var(--gray-100);border-radius:7px}
.board::-webkit-scrollbar-thumb{background:var(--gray-300);border-radius:7px;border:2px solid var(--gray-100)}
.board::-webkit-scrollbar-thumb:hover{background:var(--gray-400)}
.board-nav{display:flex;justify-content:flex-end;gap:.4rem;margin-bottom:.55rem}
.scroll-btn{width:34px;height:30px;border:1px solid var(--gray-300);background:#fff;border-radius:var(--radius-sm);color:var(--gray-700);font-size:1.1rem;line-height:1;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow-xs)}
.scroll-btn:hover{background:var(--gray-50)}
.scroll-btn:disabled{opacity:.35;cursor:default}
.col{background:var(--gray-100);border:1px solid var(--gray-200);border-radius:var(--radius-md);min-width:250px;width:250px;flex:none}
.col-head{font-weight:600;font-size:.85rem;padding:.6rem .8rem;border-top:3px solid var(--gray-300);border-radius:var(--radius-md) var(--radius-md) 0 0;display:flex;justify-content:space-between;align-items:center;color:var(--gray-700)}
.col-count{color:var(--gray-500);font-weight:500;background:#fff;border-radius:999px;padding:0 .5rem;font-size:.78rem}
.col-body{padding:.5rem;display:flex;flex-direction:column;gap:.5rem;min-height:60px}
.col.over{outline:2px dashed var(--primary);outline-offset:-3px}
.card{background:#fff;border:1px solid var(--gray-200);border-radius:var(--radius-sm);padding:.6rem .7rem;cursor:pointer;box-shadow:var(--shadow-xs)}
.card:hover{border-color:var(--gray-300);box-shadow:var(--shadow-md)}
.card-name{font-weight:500;font-size:.86rem;line-height:1.3;color:var(--gray-900)}
.card-meta{color:var(--gray-500);font-size:.76rem;line-height:1.35;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.card-foot{display:flex;align-items:center;justify-content:space-between;gap:.4rem;margin-top:.4rem;font-size:.72rem;color:var(--gray-500)}
.card-arch{background:transparent;border:1px solid var(--gray-300);color:var(--gray-500);border-radius:var(--radius-sm);padding:.12rem .45rem;font-size:.7rem;font-weight:500;cursor:pointer}
.card-arch:hover{background:var(--danger-bg);border-color:#f0c9c5;color:var(--danger)}
.card.dragging{opacity:.5}

/* ---- login ---- */
.login-body{display:flex;align-items:center;justify-content:center;min-height:100vh;background:var(--gray-50)}
.login-card{background:#fff;border:1px solid var(--gray-200);border-radius:var(--radius-lg);padding:2rem;width:min(380px,92vw);box-shadow:var(--shadow-md);display:flex;flex-direction:column;gap:.85rem}
.login-card h1{font-size:1.25rem;text-align:center}
.login-card label{display:flex;flex-direction:column;gap:.3rem;font-weight:500;font-size:.82rem;color:var(--gray-700)}
.login-card label.check{flex-direction:row;align-items:center;gap:.5rem;font-weight:400}
.login-card label.check input{width:auto}
.login-card button{margin-top:.4rem;padding:.7rem}
.login-or{display:flex;align-items:center;gap:.6rem;color:var(--gray-400);font-size:.82rem;margin:.2rem 0}
.login-or::before,.login-or::after{content:"";flex:1;height:1px;background:var(--gray-200)}
.g-wrap{display:flex;justify-content:center}

@media(max-width:900px){
  body.has-nav{flex-direction:column}
  .sidebar{position:static;width:auto;height:auto;flex-direction:row;align-items:center;overflow-x:auto;overflow-y:hidden;border-right:0;border-bottom:1px solid var(--gray-200);padding:.5rem .75rem;gap:.35rem}
  .sidebar__brand{padding:0 .5rem 0 .3rem;font-size:1rem;flex:none}
  .sidebar__nav{flex-direction:row;flex:1;gap:.1rem;overflow-x:auto}
  .sidebar__nav a{padding:.45rem .6rem;white-space:nowrap}
  .sidebar__foot{border-top:0;border-left:1px solid var(--gray-200);margin:0 0 0 auto;padding:0 0 0 .6rem;flex-direction:row;align-items:center;gap:.7rem;flex:none}
  .sidebar__foot .switch-back{width:auto}
  .sidebar__foot .who{display:none}
  .nav-badge{margin-left:.3rem}
}
@media(max-width:760px){
  .kpis{grid-template-columns:repeat(2,1fr)}
  .grid2{grid-template-columns:1fr}
  .wrap{padding:0 1rem}
}
