/* Capaztec CRM — tema dark premium (sem dependências externas) */
:root{
  --bg:#05070d; --panel:#0c1322; --panel2:#111a2e; --line:#1e2a44;
  --fg:#e7eef9; --muted:#93a2bd; --brand:#22c2f5; --brand2:#8b5cf6;
  --ok:#34d399; --warn:#fbbf24; --err:#f87171;
  --radius:14px; --shadow:0 10px 40px -18px rgba(0,0,0,.6);
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{background:var(--bg);color:var(--fg);font:15px/1.5 ui-sans-serif,system-ui,"Segoe UI",Roboto,Arial,sans-serif;-webkit-font-smoothing:antialiased}
a{color:inherit;text-decoration:none}
h1,h2,h3{margin:0;font-weight:700;letter-spacing:-.01em}
small{font-size:.8em}
::selection{background:rgba(34,194,245,.3)}

/* ---------- Shell ---------- */
.shell{display:flex;min-height:100vh}
.sidebar{width:240px;flex:0 0 240px;background:linear-gradient(180deg,#0a1120,#070b14);border-right:1px solid var(--line);padding:18px 14px;position:sticky;top:0;height:100vh;display:flex;flex-direction:column;gap:8px}
.brand{display:flex;align-items:center;gap:10px;font-size:18px;font-weight:700;padding:6px 8px 16px}
.brand b{background:linear-gradient(90deg,var(--brand),var(--brand2));-webkit-background-clip:text;background-clip:text;color:transparent}
.brand small{color:var(--muted);font-weight:600;font-size:11px;border:1px solid var(--line);padding:1px 6px;border-radius:6px;margin-left:2px}
.nav{display:flex;flex-direction:column;gap:4px}
.nav a{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:10px;color:var(--muted);font-weight:600;transition:.15s}
.nav a:hover{background:var(--panel);color:var(--fg)}
.nav a.active{background:linear-gradient(90deg,rgba(34,194,245,.16),rgba(139,92,246,.14));color:#fff;box-shadow:inset 0 0 0 1px var(--line)}
.nav a .ic{width:20px;text-align:center;color:var(--brand)}
.nav-soon{margin-top:auto;border-top:1px solid var(--line);padding-top:12px;display:flex;flex-direction:column;gap:2px}
.nav-soon span{font-size:10px;text-transform:uppercase;letter-spacing:.1em;color:var(--muted);padding:4px 12px}
.nav-soon a.disabled{padding:8px 12px;color:#54617c;font-weight:600;cursor:not-allowed;font-size:14px}

.main{flex:1;min-width:0;display:flex;flex-direction:column}
.topbar{display:flex;align-items:center;gap:14px;padding:14px 22px;border-bottom:1px solid var(--line);position:sticky;top:0;background:rgba(5,7,13,.82);backdrop-filter:blur(10px);z-index:20}
.topbar h1{font-size:18px;flex:1}
.burger{display:none;background:var(--panel);border:1px solid var(--line);color:var(--fg);font-size:18px;border-radius:8px;width:38px;height:38px;cursor:pointer}
.user{display:flex;align-items:center;gap:12px}
.uname{color:var(--muted);font-weight:600;font-size:14px}
.content{padding:22px;max-width:1200px;width:100%}

/* ---------- Cards / KPIs ---------- */
.card{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:18px;box-shadow:var(--shadow)}
.cards{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.kpi{display:flex;flex-direction:column;gap:6px}
.kpi-label{color:var(--muted);font-size:13px;font-weight:600}
.kpi-value{font-size:30px;font-weight:800;background:linear-gradient(90deg,var(--brand),var(--brand2));-webkit-background-clip:text;background-clip:text;color:transparent}

.sec-title{font-size:15px;text-transform:uppercase;letter-spacing:.06em;color:var(--muted);margin:26px 0 12px}
.sec-head{display:flex;align-items:center;justify-content:space-between;margin:26px 0 12px}
.sec-head .sec-title{margin:0}

/* ---------- Pipeline ---------- */
.pipeline{display:grid;grid-template-columns:repeat(6,1fr);gap:10px}
.pipe{background:var(--panel);border:1px solid var(--line);border-radius:12px;padding:14px;display:flex;flex-direction:column;gap:4px;transition:.15s;border-top:3px solid var(--line)}
.pipe:hover{transform:translateY(-2px);border-color:var(--brand)}
.pipe-n{font-size:24px;font-weight:800}
.pipe-l{color:var(--muted);font-size:12px;font-weight:600}
.pipe.st-novo{border-top-color:#38bdf8}.pipe.st-atend{border-top-color:#818cf8}
.pipe.st-prop{border-top-color:#a78bfa}.pipe.st-nego{border-top-color:#fbbf24}
.pipe.st-fech{border-top-color:#34d399}.pipe.st-perd{border-top-color:#f87171}

/* ---------- Tabela ---------- */
.table-wrap{padding:0;overflow:hidden}
.table{width:100%;border-collapse:collapse}
.table th{text-align:left;font-size:12px;text-transform:uppercase;letter-spacing:.04em;color:var(--muted);padding:12px 16px;border-bottom:1px solid var(--line);background:var(--panel2)}
.table td{padding:13px 16px;border-bottom:1px solid var(--line);vertical-align:middle}
.table tr:last-child td{border-bottom:0}
.table tbody tr:hover{background:rgba(34,194,245,.04)}
.lead-link{font-weight:600}.lead-link:hover{color:var(--brand)}
.muted{color:var(--muted)}.small{font-size:12px}.nowrap{white-space:nowrap}
.empty{text-align:center;color:var(--muted);padding:40px 16px!important}

/* ---------- Badges ---------- */
.badge{display:inline-block;padding:3px 10px;border-radius:999px;font-size:12px;font-weight:700;border:1px solid transparent}
.badge.lg{padding:6px 14px;font-size:13px}
.badge.st-novo{background:rgba(56,189,248,.14);color:#7dd3fc;border-color:rgba(56,189,248,.3)}
.badge.st-atend{background:rgba(129,140,248,.14);color:#a5b4fc;border-color:rgba(129,140,248,.3)}
.badge.st-prop{background:rgba(167,139,250,.14);color:#c4b5fd;border-color:rgba(167,139,250,.3)}
.badge.st-nego{background:rgba(251,191,36,.14);color:#fcd34d;border-color:rgba(251,191,36,.3)}
.badge.st-fech{background:rgba(52,211,153,.14);color:#6ee7b7;border-color:rgba(52,211,153,.3)}
.badge.st-perd{background:rgba(248,113,113,.14);color:#fca5a5;border-color:rgba(248,113,113,.3)}

/* ---------- Botões ---------- */
.btn-primary{background:linear-gradient(90deg,var(--brand),var(--brand2));color:#fff;border:0;padding:10px 18px;border-radius:10px;font-weight:700;cursor:pointer;font-size:14px;transition:.15s}
.btn-primary:hover{filter:brightness(1.1)}
.btn-ghost{background:transparent;border:1px solid var(--line);color:var(--muted);padding:7px 14px;border-radius:9px;font-weight:600;cursor:pointer;font-size:13px}
.btn-ghost:hover{color:var(--fg);border-color:var(--brand)}
.btn-sm{display:inline-block;background:var(--panel2);border:1px solid var(--line);color:var(--fg);padding:6px 12px;border-radius:8px;font-weight:600;font-size:13px}
.btn-sm:hover{border-color:var(--brand);color:var(--brand)}
.btn-wa{display:inline-block;background:#25D366;color:#06270f;padding:8px 14px;border-radius:9px;font-weight:700;font-size:14px}
.btn-wa:hover{filter:brightness(1.05)}

/* ---------- Filtros / tabs ---------- */
.filters{display:flex;gap:10px;margin-bottom:14px}
.filters input[type=search]{flex:1;max-width:480px}
.tabs{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:14px}
.tabs a{padding:7px 13px;border-radius:9px;border:1px solid var(--line);color:var(--muted);font-weight:600;font-size:13px}
.tabs a span{opacity:.7;font-size:12px;margin-left:4px}
.tabs a:hover{color:var(--fg)}
.tabs a.on{background:var(--panel);color:#fff;border-color:var(--brand)}
.pager{display:flex;align-items:center;justify-content:center;gap:16px;margin-top:16px}

/* ---------- Forms ---------- */
input,select,textarea{width:100%;background:var(--panel2);border:1px solid var(--line);color:var(--fg);border-radius:10px;padding:10px 12px;font:inherit;outline:none;transition:.15s}
input:focus,select:focus,textarea:focus{border-color:var(--brand);box-shadow:0 0 0 3px rgba(34,194,245,.18)}
input::placeholder,textarea::placeholder{color:#5b6b85}
.form label{display:block;margin-bottom:14px;font-weight:600;font-size:14px}
.form label input{margin-top:6px;font-weight:400}

/* ---------- Lead detail ---------- */
.back{display:inline-block;color:var(--muted);font-weight:600;margin-bottom:14px}
.back:hover{color:var(--brand)}
.lead-grid{display:grid;grid-template-columns:1fr 320px;gap:18px;align-items:start}
.col-main{display:flex;flex-direction:column;gap:18px;min-width:0}
.col-side{display:flex;flex-direction:column;gap:18px}
.lead-head{display:flex;align-items:center;justify-content:space-between;gap:12px}
.lead-head h2{font-size:22px}
.block-title{font-size:13px;text-transform:uppercase;letter-spacing:.05em;color:var(--muted);margin-bottom:12px}
.message{white-space:pre-wrap;line-height:1.6}
.note-form{display:flex;gap:10px;margin-bottom:16px;align-items:flex-start}
.note-form textarea{flex:1}
.status-form{display:flex;flex-direction:column;gap:10px}
.contact{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:10px}
.contact li{display:flex;flex-direction:column}
.contact li span{font-size:11px;text-transform:uppercase;color:var(--muted);letter-spacing:.05em}
.contact li a{font-weight:600}.contact li a:hover{color:var(--brand)}
.contact-actions{display:flex;gap:8px;margin-top:14px}
.meta-card dl{display:grid;grid-template-columns:auto 1fr;gap:6px 14px;margin:0}
.meta-card dt{color:var(--muted);font-size:13px}.meta-card dd{margin:0;text-align:right;font-size:13px}

/* Timeline */
.timeline{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:2px}
.tl-item{display:flex;gap:12px;padding:10px 0;border-top:1px solid var(--line)}
.tl-ic{flex:0 0 26px;height:26px;border-radius:50%;background:var(--panel2);border:1px solid var(--line);display:flex;align-items:center;justify-content:center;color:var(--brand);font-size:13px}
.tl-note .tl-ic{color:var(--warn)}.tl-status .tl-ic{color:var(--brand2)}
.tl-body{flex:1;min-width:0}
.tl-text{margin:0 0 2px;white-space:pre-wrap}
.tl-meta{font-size:11px;color:var(--muted)}

/* ---------- Alerts ---------- */
.alert{padding:12px 16px;border-radius:10px;margin-bottom:16px;font-weight:600;font-size:14px;border:1px solid}
.alert.ok{background:rgba(52,211,153,.12);color:#6ee7b7;border-color:rgba(52,211,153,.3)}
.alert.err{background:rgba(248,113,113,.12);color:#fca5a5;border-color:rgba(248,113,113,.3)}

/* ---------- Login ---------- */
.login-body{display:flex;align-items:center;justify-content:center;min-height:100vh;padding:20px;background:radial-gradient(900px 500px at 80% -10%,rgba(139,92,246,.18),transparent),radial-gradient(800px 500px at 0% 110%,rgba(34,194,245,.18),transparent),var(--bg)}
.login-card{width:100%;max-width:400px;background:var(--panel);border:1px solid var(--line);border-radius:18px;padding:34px;box-shadow:var(--shadow)}
.login-brand{text-align:center;margin-bottom:24px}
.login-brand img{margin-bottom:10px}
.login-brand h1{font-size:24px}
.login-brand h1 b{background:linear-gradient(90deg,var(--brand),var(--brand2));-webkit-background-clip:text;background-clip:text;color:transparent}
.login-brand h1 span{color:var(--muted);font-weight:600;font-size:15px}
.login-brand p{color:var(--muted);margin:4px 0 0;font-size:14px}
.login-card .btn-primary{width:100%;padding:12px}
.login-foot{text-align:center;color:var(--muted);font-size:12px;margin:18px 0 0}
.center-card{text-align:center;padding:50px}

.ticket-banner{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-top:22px;padding:14px 18px;border-radius:12px;border:1px solid var(--brand);background:linear-gradient(90deg,rgba(34,194,245,.12),rgba(139,92,246,.1));font-weight:600}
.ticket-banner:hover{filter:brightness(1.1)}

/* ---------- Chamados: badges de status/prioridade ---------- */
.badge.tk-aberto{background:rgba(56,189,248,.14);color:#7dd3fc;border-color:rgba(56,189,248,.3)}
.badge.tk-andamento{background:rgba(129,140,248,.14);color:#a5b4fc;border-color:rgba(129,140,248,.3)}
.badge.tk-aguard{background:rgba(251,191,36,.14);color:#fcd34d;border-color:rgba(251,191,36,.3)}
.badge.tk-resolv{background:rgba(52,211,153,.14);color:#6ee7b7;border-color:rgba(52,211,153,.3)}
.badge.tk-fechado{background:rgba(148,163,184,.14);color:#cbd5e1;border-color:rgba(148,163,184,.3)}
.badge.pr-baixa{background:rgba(148,163,184,.12);color:#cbd5e1;border-color:rgba(148,163,184,.25)}
.badge.pr-normal{background:rgba(56,189,248,.12);color:#7dd3fc;border-color:rgba(56,189,248,.25)}
.badge.pr-alta{background:rgba(251,146,60,.16);color:#fdba74;border-color:rgba(251,146,60,.3)}
.badge.pr-urgente{background:rgba(248,113,113,.16);color:#fca5a5;border-color:rgba(248,113,113,.35)}

/* Thread de mensagens */
.thread{list-style:none;margin:0 0 6px;padding:0;display:flex;flex-direction:column;gap:12px}
.msg{border:1px solid var(--line);border-radius:12px;padding:12px 14px;background:var(--panel2)}
.msg-team{border-left:3px solid var(--brand)}
.msg-client{border-left:3px solid var(--brand2)}
.msg-h{display:flex;justify-content:space-between;gap:10px;align-items:baseline;margin-bottom:6px;flex-wrap:wrap}
.msg-b{white-space:pre-wrap;line-height:1.55}
.reply-form{display:flex;flex-direction:column;gap:10px;margin-top:14px;border-top:1px solid var(--line);padding-top:14px}
.reply-form .btn-primary{align-self:flex-start}
.fld{display:block;margin-bottom:12px;font-size:13px;color:var(--muted);font-weight:600}
.fld select{margin-top:5px}

/* ---------- Central do Cliente ---------- */
.central-body{background:var(--bg);min-height:100vh}
.central-top{display:flex;align-items:center;justify-content:space-between;gap:14px;padding:14px 22px;border-bottom:1px solid var(--line);background:rgba(5,7,13,.85);backdrop-filter:blur(10px);position:sticky;top:0;z-index:20;flex-wrap:wrap}
.central-brand{display:flex;align-items:center;gap:10px;font-size:18px;font-weight:700}
.central-brand b{background:linear-gradient(90deg,var(--brand),var(--brand2));-webkit-background-clip:text;background-clip:text;color:transparent}
.central-brand small{color:var(--muted);font-size:11px;border:1px solid var(--line);padding:1px 6px;border-radius:6px;font-weight:600}
.central-nav{display:flex;align-items:center;gap:12px;flex-wrap:wrap}
.central-nav>a:first-child{color:var(--muted);font-weight:600}
.central-nav>a:first-child:hover{color:var(--fg)}
.central-user{color:var(--muted);font-size:14px;font-weight:600}
.central-main{max-width:880px;margin:0 auto;padding:26px 22px}
.central-title{font-size:22px;margin-bottom:18px}
.central-foot{text-align:center;color:var(--muted);font-size:12px;padding:24px;border-top:1px solid var(--line);margin-top:30px}

/* ---------- Orçamentos: badges ---------- */
.badge.q-rascunho{background:rgba(148,163,184,.14);color:#cbd5e1;border-color:rgba(148,163,184,.3)}
.badge.q-enviado{background:rgba(56,189,248,.14);color:#7dd3fc;border-color:rgba(56,189,248,.3)}
.badge.q-aprovado{background:rgba(52,211,153,.14);color:#6ee7b7;border-color:rgba(52,211,153,.3)}
.badge.q-recusado{background:rgba(248,113,113,.14);color:#fca5a5;border-color:rgba(248,113,113,.3)}
.badge.q-cancelado{background:rgba(100,116,139,.14);color:#94a3b8;border-color:rgba(100,116,139,.3)}

/* Forms 2 colunas / checkbox */
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.check{display:flex;align-items:center;gap:8px;font-weight:600;margin-bottom:12px}
.check input{width:auto}

/* Itens do orçamento (form) */
.items-head{display:grid;grid-template-columns:1fr 80px 130px 120px 34px;gap:8px;font-size:11px;text-transform:uppercase;letter-spacing:.04em;color:var(--muted);padding:0 2px 6px}
.qrow{display:grid;grid-template-columns:1fr 80px 130px 120px 34px;gap:8px;align-items:center;margin-bottom:8px}
.qrow input{margin:0}
.q-sub{font-weight:600;font-size:14px;text-align:right}
.q-del{background:transparent;border:1px solid var(--line);color:var(--err);border-radius:8px;height:38px;cursor:pointer}
.q-del:hover{border-color:var(--err)}
.quote-total-row{text-align:right;font-size:18px;margin:14px 0;padding-top:12px;border-top:1px solid var(--line)}
.quote-total-row b{color:var(--brand);font-size:22px;margin-left:8px}
.actions-col{display:flex;flex-direction:column;gap:10px}
.decide-actions{display:flex;gap:10px;flex-wrap:wrap}

/* Documento do orçamento (visualização) */
.quote-doc-head{display:flex;justify-content:space-between;gap:16px;align-items:flex-start;border-bottom:1px solid var(--line);padding-bottom:14px;margin-bottom:14px}
.quote-doc-head h2{font-size:20px}
.quote-doc-meta{text-align:right}
.quote-client{margin-bottom:14px}
.quote-items th.r,.quote-items td.r{text-align:right}
.quote-items tfoot td{padding:12px 16px;border-top:2px solid var(--line);font-size:15px}
.quote-notes{margin-top:14px;border-top:1px solid var(--line);padding-top:12px}
.only-print{display:none}
.central-section{font-size:18px;margin:0 0 12px}

/* Impressão */
@media print{
  body{background:#fff;color:#000}
  .sidebar,.topbar,.no-print,.central-top,.central-foot,.back{display:none!important}
  .main,.content,.central-main{padding:0;margin:0;max-width:none}
  .lead-grid{display:block}
  .card{border:0;box-shadow:none;background:#fff;color:#000;padding:0}
  .only-print{display:block}
  .quote-items th,.quote-items td{border-color:#ccc;color:#000}
  .badge{border:1px solid #ccc;color:#000}
  a{color:#000;text-decoration:none}
}

/* ---------- Anexos na mensagem do lead ---------- */
.msg-link{color:var(--brand);word-break:break-all}
.msg-link:hover{text-decoration:underline}
.attach-thumb{display:inline-block;margin:8px 8px 0 0;border:1px solid var(--line);border-radius:10px;overflow:hidden;vertical-align:top}
.attach-thumb img{display:block;height:120px;width:auto;max-width:200px;object-fit:cover}
.attach-thumb:hover{border-color:var(--brand)}

/* ---------- Configurações ---------- */
.evt-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:8px}
.evt-list li{display:flex;align-items:center;gap:8px;font-size:14px}
.howto{margin:0;padding-left:18px;display:flex;flex-direction:column;gap:8px;font-size:14px;color:var(--muted)}
.howto b{color:var(--fg)}
code{background:var(--panel2);border:1px solid var(--line);border-radius:5px;padding:1px 5px;font-size:12px}

/* ---------- Responsivo ---------- */
@media (max-width:920px){
  .cards{grid-template-columns:repeat(2,1fr)}
  .pipeline{grid-template-columns:repeat(3,1fr)}
  .lead-grid{grid-template-columns:1fr}
  .grid2{grid-template-columns:1fr}
  .items-head{display:none}
  .qrow{grid-template-columns:1fr 1fr;gap:6px}
  .qrow input[name="item_desc[]"]{grid-column:1 / -1}
  .q-sub{text-align:left}
}
@media (max-width:760px){
  .sidebar{position:fixed;left:-260px;z-index:40;transition:.25s;box-shadow:0 0 60px rgba(0,0,0,.6)}
  .sidebar.open{left:0}
  .burger{display:block}
  .content{padding:16px}
  .table thead{display:none}
  .table,.table tbody,.table tr,.table td{display:block;width:100%}
  .table tr{border-bottom:1px solid var(--line);padding:8px 0}
  .table td{border:0;padding:5px 16px}
}
