/* ============================================================
   VIZO — Painel (admin + portal do cliente)
   ============================================================ */
@import url('https://fonts.googleapis.com/css2?family=Fraunces:opsz,wght@9..144,500;9..144,600;9..144,700&family=Inter:wght@400;500;600;700&family=JetBrains+Mono:wght@400;500;700&display=swap');

:root{
  --ink:#0B0F19;--ink-2:#111827;--panel:#172033;--panel-2:#111827;
  --line:rgba(37,99,255,.16);--line-soft:rgba(245,240,230,.07);
  --gold:#2563FF;--gold-lite:#00C2FF;--ivory:#F5F0E6;--muted:#A29A8C;--muted-2:#6F685D;
  --ok:#6FBF8B;--warn:#E0B15A;--bad:#D9756B;--info:#7FA8D9;
  --display:'Fraunces',serif;--body:'Inter',system-ui,sans-serif;--mono:'JetBrains Mono',monospace;
  --r:12px;
}
*{box-sizing:border-box}
body{margin:0;background:var(--ink);color:var(--ivory);font-family:var(--body);font-size:15px;-webkit-font-smoothing:antialiased}
a{color:inherit;text-decoration:none}
.icon{vertical-align:middle}

/* ---- Login ---- */
.auth{min-height:100vh;display:grid;place-items:center;padding:24px;
  background:radial-gradient(700px 400px at 50% -10%,rgba(37,99,255,.14),transparent 60%)}
.auth-card{width:100%;max-width:420px;background:var(--ink-2);border:1px solid var(--line);
  border-radius:18px;padding:40px}
.auth-card .brand{font-family:var(--display);font-size:30px;font-weight:700;display:flex;align-items:center;gap:10px;margin-bottom:6px}
.auth-card .brand .dot{width:9px;height:9px;border-radius:50%;background:var(--gold)}
.auth-card h1{font-family:var(--display);font-size:22px;margin:18px 0 6px;font-weight:600}
.auth-card p.sub{color:var(--muted);margin:0 0 26px;font-size:14px}

/* ---- Shell ---- */
.shell{display:grid;grid-template-columns:248px 1fr;min-height:100vh}
.side{background:var(--ink-2);border-right:1px solid var(--line-soft);padding:24px 16px;position:sticky;top:0;height:100vh;overflow:auto}
.side .brand{font-family:var(--display);font-size:24px;font-weight:700;display:flex;align-items:center;gap:10px;padding:0 10px 22px}
.side .brand .dot{width:8px;height:8px;border-radius:50%;background:var(--gold)}
.side .grp{font-family:var(--mono);font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--muted-2);padding:18px 12px 8px}
.side a{display:flex;align-items:center;gap:11px;padding:11px 12px;border-radius:9px;color:var(--muted);font-size:14.5px;transition:.18s}
.side a:hover{background:var(--panel);color:var(--ivory)}
.side a.active{background:rgba(37,99,255,.12);color:var(--gold)}
.side a .badge{margin-left:auto;background:var(--gold);color:#fff;font-size:11px;font-weight:700;padding:1px 8px;border-radius:99px}

.main{display:flex;flex-direction:column;min-width:0}
.topbar{height:66px;border-bottom:1px solid var(--line-soft);display:flex;align-items:center;
  justify-content:space-between;padding:0 28px;position:sticky;top:0;background:rgba(14,13,11,.82);backdrop-filter:blur(10px);z-index:10}
.topbar h1{font-family:var(--display);font-size:22px;font-weight:600;margin:0}
.topbar .right{display:flex;align-items:center;gap:16px;color:var(--muted);font-size:14px}
.topbar .avatar{width:34px;height:34px;border-radius:50%;background:rgba(37,99,255,.18);color:var(--gold);
  display:grid;place-items:center;font-weight:700;font-family:var(--display)}
.content{padding:28px;max-width:1200px;width:100%}

/* ---- Cards de stat ---- */
.kpis{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:24px}
.kpi{background:var(--ink-2);border:1px solid var(--line-soft);border-radius:var(--r);padding:20px;position:relative;overflow:hidden}
.kpi .k-lab{font-family:var(--mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--muted)}
.kpi .k-val{font-family:var(--display);font-size:38px;font-weight:600;margin-top:8px;line-height:1}
.kpi .k-val.gold{color:var(--gold)}
.kpi .k-ico{position:absolute;right:16px;top:16px;color:var(--muted-2);opacity:.5}

/* ---- Painéis ---- */
.panel{background:var(--ink-2);border:1px solid var(--line-soft);border-radius:var(--r);margin-bottom:22px;overflow:hidden}
.panel-head{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--line-soft)}
.panel-head h2{font-family:var(--display);font-size:18px;font-weight:600;margin:0}
.panel-body{padding:20px}
.cols-2{display:grid;grid-template-columns:1fr 1fr;gap:22px}

/* ---- Tabelas ---- */
table{width:100%;border-collapse:collapse;font-size:14px}
th{text-align:left;font-family:var(--mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;
  color:var(--muted-2);padding:12px 20px;border-bottom:1px solid var(--line-soft);font-weight:500}
td{padding:14px 20px;border-bottom:1px solid var(--line-soft);vertical-align:middle}
tr:last-child td{border-bottom:0}
tr:hover td{background:rgba(255,255,255,.012)}
td.actions{text-align:right;white-space:nowrap}

/* ---- Badges de status ---- */
.tag{display:inline-flex;align-items:center;gap:6px;font-size:12px;font-weight:600;padding:4px 11px;border-radius:99px;font-family:var(--mono);letter-spacing:.03em}
.tag.new,.tag.open{background:rgba(127,168,217,.14);color:var(--info)}
.tag.contacted,.tag.in_progress,.tag.review{background:rgba(224,177,90,.14);color:var(--warn)}
.tag.qualified{background:rgba(37,99,255,.16);color:var(--gold)}
.tag.won,.tag.done,.tag.active{background:rgba(111,191,139,.14);color:var(--ok)}
.tag.lost,.tag.cancelled,.tag.inactive{background:rgba(217,117,107,.14);color:var(--bad)}
.tag.high,.tag.urgent{background:rgba(217,117,107,.14);color:var(--bad)}
.tag.normal,.tag.low{background:rgba(162,154,140,.12);color:var(--muted)}

/* ---- Botões ---- */
.btn{display:inline-flex;align-items:center;gap:8px;cursor:pointer;font-family:var(--body);
  font-weight:600;font-size:14px;padding:10px 18px;border-radius:9px;border:1px solid transparent;transition:.2s}
.btn-gold{background:var(--gold);color:#fff}.btn-gold:hover{background:var(--gold-lite)}
.btn-ghost{border-color:var(--line);color:var(--ivory)}.btn-ghost:hover{border-color:var(--gold);color:var(--gold)}
.btn-sm{padding:7px 13px;font-size:13px}
.btn-danger{border-color:rgba(217,117,107,.4);color:var(--bad)}.btn-danger:hover{background:rgba(217,117,107,.12)}
.btn-block{width:100%;justify-content:center}

/* ---- Forms ---- */
.form{display:grid;gap:16px}
.field label{display:block;font-size:12px;color:var(--muted);margin-bottom:7px;font-family:var(--mono);letter-spacing:.04em}
.field input,.field select,.field textarea{width:100%;background:var(--panel);border:1px solid var(--line-soft);
  color:var(--ivory);padding:11px 14px;border-radius:9px;font-family:var(--body);font-size:15px;transition:.2s}
.field input:focus,.field select:focus,.field textarea:focus{outline:0;border-color:var(--gold);box-shadow:0 0 0 3px rgba(37,99,255,.1)}
.field textarea{min-height:90px;resize:vertical}
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.grid-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:16px}
.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.check{display:flex;align-items:center;gap:10px}
.check input{width:auto}

/* ---- Flash ---- */
.flash{padding:13px 18px;border-radius:10px;margin-bottom:18px;font-size:14px;border:1px solid}
.flash.success{background:rgba(111,191,139,.1);border-color:rgba(111,191,139,.4);color:#bfe6cd}
.flash.error{background:rgba(217,117,107,.1);border-color:rgba(217,117,107,.4);color:#e8a99f}

/* ---- Misc ---- */
.muted{color:var(--muted)}
.empty{text-align:center;padding:60px 20px;color:var(--muted)}
.empty .icon{color:var(--muted-2);margin-bottom:14px}
.page-actions{display:flex;justify-content:space-between;align-items:center;margin-bottom:22px;gap:16px;flex-wrap:wrap}
.filters{display:flex;gap:8px;flex-wrap:wrap}
.filters a{font-size:13px;padding:6px 13px;border:1px solid var(--line-soft);border-radius:99px;color:var(--muted)}
.filters a.active{border-color:var(--gold);color:var(--gold)}
.report-metrics{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin:18px 0}
.rm{background:var(--panel);border:1px solid var(--line-soft);border-radius:10px;padding:16px}
.rm .l{font-family:var(--mono);font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:.08em}
.rm .v{font-family:var(--display);font-size:28px;font-weight:600;margin-top:6px}
.rm .d{font-size:12px;font-weight:600;margin-top:4px}
.rm .d.up{color:var(--ok)} .rm .d.down{color:var(--bad)}
.thread{display:grid;gap:12px;margin:18px 0}
.msg{padding:14px 16px;border-radius:10px;background:var(--panel);border:1px solid var(--line-soft);max-width:80%}
.msg.mine{margin-left:auto;background:rgba(37,99,255,.1);border-color:var(--line)}
.msg .meta{font-size:11px;color:var(--muted-2);margin-bottom:6px;font-family:var(--mono)}
.dl{display:grid;grid-template-columns:160px 1fr;gap:10px 20px;font-size:14.5px}
.dl dt{color:var(--muted);font-family:var(--mono);font-size:12px;text-transform:uppercase;letter-spacing:.05em;padding-top:2px}
.dl dd{margin:0}
.media-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:14px}
.media-item{border:1px solid var(--line-soft);border-radius:10px;overflow:hidden;background:var(--panel)}
.media-item img{width:100%;height:110px;object-fit:cover}
.media-item .mi-b{padding:10px;font-size:12px;color:var(--muted);display:flex;justify-content:space-between;align-items:center;gap:8px}
.copy-url{cursor:pointer;color:var(--gold);font-family:var(--mono);font-size:11px}

@media(max-width:900px){
  .shell{grid-template-columns:1fr}
  .side{position:fixed;left:-260px;width:248px;z-index:40;transition:.25s}
  .side.open{left:0}
  .kpis,.grid-4,.report-metrics{grid-template-columns:1fr 1fr}
  .cols-2,.grid-2,.grid-3{grid-template-columns:1fr}
  .menu-toggle{display:inline-flex!important}
}
.menu-toggle{display:none;background:none;border:0;color:var(--ivory);cursor:pointer}

/* ---- Logo VIZO (imagem) ---- */
.side .brand{gap:8px;align-items:center}
.brand-logo{height:24px;width:auto;display:block}
.auth-card .brand-logo{height:34px}
.kpis.compact{margin-top:-6px}.kpis.compact .kpi{padding:17px}.kpis.compact .k-val{font-size:32px}

/* ================= Portal do cliente com cara de app ================= */
body.portal-app{background:linear-gradient(180deg,#0c0b09 0%,#11100d 100%)}
.portal-app .portal-shell{grid-template-columns:270px 1fr;gap:0}
.portal-app .app-sidebar{background:linear-gradient(180deg,#12100d 0%,#17130e 100%);padding:18px 14px;border-right:1px solid rgba(255,255,255,.04)}
.portal-app .app-sidebar .brand{padding:8px 12px 20px;margin-bottom:8px;background:rgba(255,255,255,.02);border:1px solid var(--line-soft);border-radius:18px}
.portal-app .app-sidebar a{border-radius:14px;padding:13px 14px;font-size:14px}
.portal-app .app-sidebar a.active{background:linear-gradient(180deg,rgba(37,99,255,.16),rgba(37,99,255,.09));color:#fff;border:1px solid rgba(37,99,255,.18)}
.portal-app .main{background:radial-gradient(1000px 400px at 80% -10%,rgba(37,99,255,.09),transparent 60%)}
.portal-app .app-topbar{height:78px;padding:0 24px;border-bottom:1px solid rgba(255,255,255,.05);background:rgba(12,11,9,.72);backdrop-filter:blur(18px)}
.portal-app .topbar-left{display:flex;align-items:center;gap:14px}
.portal-app .app-overline{font-family:var(--mono);font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--muted-2);margin-bottom:4px}
.portal-app .app-topbar h1{font-size:26px}
.portal-app .app-topbar-right{gap:12px}
.portal-app .app-user-chip{display:flex;align-items:center;gap:12px;padding:8px 10px 8px 14px;border-radius:16px;background:rgba(255,255,255,.03);border:1px solid var(--line-soft)}
.portal-app .app-user-chip strong{display:block;font-size:13px;color:var(--ivory)}
.portal-app .app-user-chip small{display:block;font-size:11px;color:var(--muted-2);margin-top:2px}
.portal-app .app-content{max-width:1280px;padding:24px 24px 110px}
.portal-app .panel,.portal-app .kpi{background:linear-gradient(180deg,rgba(29,25,19,.92),rgba(21,18,14,.96));border:1px solid rgba(255,255,255,.05);border-radius:24px;box-shadow:0 18px 50px rgba(0,0,0,.18)}
.portal-app .panel-head{padding:18px 22px}
.portal-app .panel-head h2{font-size:20px}
.portal-app .panel-body{padding:22px}
.portal-app .app-hero-card{display:flex;align-items:center;justify-content:space-between;gap:20px;padding:26px;border-radius:26px;background:linear-gradient(135deg,rgba(37,99,255,.18),rgba(37,99,255,.05) 48%,rgba(255,255,255,.03));border:1px solid rgba(37,99,255,.18);margin-bottom:18px;box-shadow:0 24px 60px rgba(0,0,0,.18)}
.portal-app .app-hero-card h2{font-family:var(--display);font-size:30px;line-height:1.02;margin:6px 0 8px}
.portal-app .app-hero-card p{margin:0;color:#cbc4b7;max-width:62ch;line-height:1.6}
.portal-app .mini-label{font-family:var(--mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--gold)}
.portal-app .app-hero-actions{display:flex;gap:10px;flex-wrap:wrap}
.portal-app .app-stat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-bottom:20px}
.portal-app .app-stat-card{padding:22px;border-radius:22px;background:linear-gradient(180deg,rgba(255,255,255,.03),rgba(255,255,255,.015));border:1px solid rgba(255,255,255,.05);position:relative;overflow:hidden}
.portal-app .app-stat-card.highlight{background:linear-gradient(180deg,rgba(37,99,255,.12),rgba(255,255,255,.02))}
.portal-app .app-stat-card .k-ico{position:absolute;right:18px;top:18px;color:rgba(255,255,255,.28)}
.portal-app .stat-num{font-family:var(--display);font-size:42px;line-height:1;margin-top:10px}
.portal-app .stat-title{font-family:var(--display);font-size:24px;line-height:1.1;margin-top:10px}
.portal-app .stat-text{font-size:13px;color:var(--muted);margin-top:8px}
.portal-app .app-panel-emphasis{border-color:rgba(37,99,255,.12)}
.portal-app .app-quick-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin:0 0 20px}
.portal-app .quick-app-card{display:block;padding:20px;border-radius:22px;background:linear-gradient(180deg,rgba(255,255,255,.03),rgba(255,255,255,.015));border:1px solid rgba(255,255,255,.05);transition:.2s}
.portal-app .quick-app-card:hover{transform:translateY(-2px);border-color:rgba(37,99,255,.22)}
.portal-app .quick-app-card strong{display:block;font-size:16px;margin-top:10px}
.portal-app .quick-app-card small{display:block;color:var(--muted);margin-top:8px;line-height:1.5}
.portal-app .qa-ico{display:grid;place-items:center;width:42px;height:42px;border-radius:14px;background:rgba(37,99,255,.13);color:var(--gold)}
.portal-app table{border-collapse:separate;border-spacing:0 10px}
.portal-app th{border-bottom:0;padding:0 18px 8px}
.portal-app td{background:rgba(255,255,255,.02);border-top:1px solid rgba(255,255,255,.03);border-bottom:1px solid rgba(255,255,255,.03);padding:16px 18px}
.portal-app td:first-child{border-left:1px solid rgba(255,255,255,.03);border-top-left-radius:14px;border-bottom-left-radius:14px}
.portal-app td:last-child{border-right:1px solid rgba(255,255,255,.03);border-top-right-radius:14px;border-bottom-right-radius:14px}
.portal-app tr:hover td{background:rgba(255,255,255,.03)}
.portal-app .report-metrics{gap:16px}
.portal-app .rm{background:rgba(255,255,255,.03);border-color:rgba(255,255,255,.05);border-radius:18px;padding:18px}
.portal-app .rm .v{font-size:30px}
.portal-app .field input,.portal-app .field select,.portal-app .field textarea{background:rgba(255,255,255,.03);border-color:rgba(255,255,255,.06);border-radius:14px;padding:13px 15px}
.portal-app .btn{border-radius:14px;padding:11px 18px}
.portal-app .btn-sm{padding:8px 13px;border-radius:12px}
.portal-app .tag{border-radius:99px;padding:5px 12px}
.portal-app .msg{border-radius:18px;padding:16px 18px}
.portal-app .msg.mine{background:rgba(37,99,255,.12)}
.portal-app .dl{grid-template-columns:140px 1fr}
.portal-app .page-actions{margin-bottom:18px}
.portal-app .desktop-quick{display:inline-flex}
.portal-app .app-bottom-nav{display:none}
body.portal-login{background:radial-gradient(1000px 420px at 50% -10%,rgba(37,99,255,.18),transparent 58%),linear-gradient(180deg,#0d0c0a 0%,#14120e 100%)}
.portal-login .auth-card{max-width:460px;border-radius:28px;padding:42px;background:linear-gradient(180deg,rgba(24,21,17,.96),rgba(16,14,11,.98));box-shadow:0 35px 80px rgba(0,0,0,.35)}
.portal-login .field input{border-radius:14px;padding:13px 15px}
.portal-login .btn{border-radius:14px;padding:12px 18px}
@media(max-width:900px){
  .portal-app .portal-shell{grid-template-columns:1fr}
  .portal-app .app-content{padding:18px 16px 110px}
  .portal-app .app-topbar{height:72px;padding:0 16px}
  .portal-app .app-topbar h1{font-size:22px}
  .portal-app .desktop-quick,.portal-app .app-user-chip small{display:none}
  .portal-app .app-hero-card{flex-direction:column;align-items:flex-start;padding:22px}
  .portal-app .app-hero-card h2{font-size:24px}
  .portal-app .app-stat-grid,.portal-app .app-quick-grid,.portal-app .report-metrics{grid-template-columns:1fr}
  .portal-app .cols-2,.portal-app .grid-2,.portal-app .grid-3,.portal-app .grid-4{grid-template-columns:1fr}
  .portal-app .app-sidebar{position:fixed;left:-280px;width:270px;z-index:40;transition:.25s;height:100dvh}
  .portal-app .app-sidebar.open{left:0}
  .portal-app .menu-toggle{display:inline-flex!important}
  .portal-app .app-bottom-nav{display:grid;grid-template-columns:repeat(5,1fr);position:fixed;left:12px;right:12px;bottom:12px;background:rgba(18,16,13,.92);backdrop-filter:blur(18px);border:1px solid rgba(255,255,255,.06);border-radius:22px;padding:10px 8px;z-index:50;box-shadow:0 24px 60px rgba(0,0,0,.35)}
  .portal-app .app-bottom-nav a{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:5px;color:var(--muted);font-size:11px;padding:6px 4px;border-radius:14px}
  .portal-app .app-bottom-nav a.active{background:rgba(37,99,255,.14);color:#fff}
  .portal-app table,.portal-app thead,.portal-app tbody,.portal-app tr,.portal-app td{display:block;width:100%}
  .portal-app thead{display:none}
  .portal-app tbody{display:grid;gap:12px}
  .portal-app tr{display:block}
  .portal-app td{border:1px solid rgba(255,255,255,.04)!important;border-radius:14px!important;margin:0 0 8px;padding:14px 16px}
  .portal-app td.actions{text-align:left}
}

/* ================= VIZO Elite 7.0: operação completa ================= */
.kanban{display:grid;grid-template-columns:repeat(7,minmax(210px,1fr));gap:14px;overflow-x:auto;padding-bottom:12px}
.kanban-col{background:rgba(255,255,255,.025);border:1px solid rgba(255,255,255,.05);border-radius:22px;padding:14px;min-height:260px}
.kanban-title{font-family:var(--mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);margin:4px 4px 14px}
.kanban-card{display:block;background:linear-gradient(180deg,rgba(255,255,255,.045),rgba(255,255,255,.018));border:1px solid rgba(255,255,255,.06);border-radius:18px;padding:15px;margin-bottom:12px;transition:.2s}
.kanban-card:hover{transform:translateY(-2px);border-color:rgba(37,99,255,.28)}
.kanban-card strong{display:block;font-size:15px;line-height:1.35;margin-bottom:8px}
.kanban-card small{display:block;color:var(--muted);font-size:12.5px;line-height:1.45;margin-bottom:8px}
.proposal-card{background:linear-gradient(180deg,rgba(24,21,17,.96),rgba(16,14,11,.98));border:1px solid rgba(37,99,255,.16);border-radius:28px;padding:30px;box-shadow:0 30px 80px rgba(0,0,0,.25)}
.proposal-head{display:flex;justify-content:space-between;gap:20px;align-items:flex-start;border-bottom:1px solid var(--line-soft);padding-bottom:22px}
.proposal-head h2{font-family:var(--display);font-size:34px;line-height:1.05;margin:8px 0}
.contract-body{background:rgba(255,255,255,.025);border:1px solid var(--line-soft);border-radius:20px;padding:24px}
.tag.draft,.tag.sent{background:rgba(224,177,90,.14);color:var(--warn)}
.tag.accepted,.tag.approved,.tag.delivered,.tag.paid{background:rgba(111,191,139,.14);color:var(--ok)}
.tag.rejected,.tag.expired,.tag.cancelled,.tag.late,.tag.changes_requested{background:rgba(217,117,107,.14);color:var(--bad)}
.tag.waiting,.tag.pending,.tag.briefing,.tag.planning,.tag.production,.tag.todo,.tag.doing,.tag.review{background:rgba(127,168,217,.14);color:var(--info)}
@media(max-width:900px){.kanban{grid-template-columns:repeat(7,82vw)}.proposal-card{padding:20px}.proposal-head{display:block}.proposal-head h2{font-size:26px}}

/* ===== Formulários: rótulos de seção, erros, tags de status (adicionado) ===== */
.form-section-label{font-family:var(--mono,monospace);font-size:11px;font-weight:800;letter-spacing:.14em;text-transform:uppercase;color:var(--gold,#2563FF);margin:6px 0 12px;display:block}
.form-block-label{font-family:var(--mono,monospace);font-size:11px;font-weight:800;letter-spacing:.12em;text-transform:uppercase;color:var(--muted,#a29a8c);margin:18px 0 10px;display:block;border-top:1px solid var(--line,#262320);padding-top:16px}
.form-block-label:first-child{border-top:0;padding-top:0;margin-top:0}
.field-error{display:block;font-size:12.5px;color:var(--bad,#d9756b);margin-top:6px}
.tag.warn,.tag.pending{background:rgba(224,177,90,.16);color:var(--warn,#e0b15a)}
.tag.rejected{background:rgba(217,117,107,.16);color:var(--bad,#d9756b)}
.tag.approved{background:rgba(111,191,139,.16);color:var(--ok,#6fbf8b)}


/* ===== VIZO 8.4 — experiência de app no celular para todos os membros ===== */
body.portal-app{
  background:
    radial-gradient(900px 360px at 50% -5%, rgba(37,99,255,.12), transparent 58%),
    linear-gradient(180deg,#0c0b09 0%, #14120e 100%);
}
.portal-app .brand-logo{height:34px;width:auto;display:block}
.portal-app .main{min-height:100dvh;background:linear-gradient(180deg,rgba(255,255,255,.01),rgba(255,255,255,0))}
.portal-app .content > *:first-child{margin-top:0}
.portal-app .content > *:last-child{margin-bottom:0}
.portal-app .panel,.portal-app .kpi,.portal-app .app-stat-card,.portal-app .quick-app-card,.portal-app .rm,.portal-app .msg{backdrop-filter:blur(10px)}
.portal-app .app-sidebar-overlay{display:none}
.portal-app .app-data-table td[data-label]{position:relative}
.portal-app .app-data-table td[data-label]::before{content:attr(data-label);display:none;font-family:var(--mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted-2);margin-bottom:6px}
.portal-app .panel.has-table .panel-body{overflow:hidden}
.portal-app .btn,.portal-app .field input,.portal-app .field select,.portal-app .field textarea{min-height:46px}
.portal-app .btn{font-weight:600}
.portal-app .field textarea{min-height:120px}
.portal-app .page-actions{display:flex;flex-wrap:wrap;gap:10px}
.portal-app .page-actions .btn{justify-content:center}
.portal-app .flash{border-radius:18px}
.portal-app .topbar .btn-sm{min-height:40px}

@media(max-width:900px){
  body.portal-app{padding-bottom:calc(env(safe-area-inset-bottom, 0px) + 90px)}
  .portal-app .app-sidebar-overlay{
    display:block;position:fixed;inset:0;background:rgba(4,4,4,.48);backdrop-filter:blur(3px);
    opacity:0;pointer-events:none;transition:.22s;z-index:39;border:0;padding:0
  }
  body.portal-app.app-menu-open .app-sidebar-overlay{opacity:1;pointer-events:auto}
  .portal-app .app-sidebar{
    left:-290px;top:0;bottom:0;width:286px;padding:20px 14px 24px;border-right:1px solid rgba(255,255,255,.05);
    border-top-right-radius:28px;border-bottom-right-radius:28px;
    box-shadow:0 30px 80px rgba(0,0,0,.45);
    background:linear-gradient(180deg,rgba(21,18,14,.98),rgba(13,12,10,.99));
  }
  .portal-app .app-sidebar.open{left:0}
  .portal-app .side .brand{padding:4px 10px 16px;position:sticky;top:0;background:linear-gradient(180deg,rgba(21,18,14,.98),rgba(21,18,14,.88));z-index:2}
  .portal-app .side .grp{padding-top:16px}
  .portal-app .side a{padding:13px 14px;border-radius:16px;font-size:14px}
  .portal-app .topbar.app-topbar{
    position:sticky;top:0;left:0;right:0;height:auto;min-height:76px;padding:14px 14px 12px;
    background:rgba(15,13,10,.82);backdrop-filter:blur(14px);border-bottom:1px solid rgba(255,255,255,.05)
  }
  .portal-app .topbar-left{width:100%;gap:10px;align-items:flex-start}
  .portal-app .menu-toggle{
    width:44px;height:44px;border-radius:16px;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.06);
    display:grid;place-items:center;flex:0 0 44px;color:var(--ivory)
  }
  .portal-app .app-topbar h1{font-size:20px;line-height:1.08;margin-top:2px}
  .portal-app .app-overline{font-size:9px;letter-spacing:.18em}
  .portal-app .app-topbar-right{gap:8px;margin-left:auto;align-self:center}
  .portal-app .app-user-chip{padding:7px 7px 7px 11px;border-radius:16px;gap:8px}
  .portal-app .app-user-chip strong{font-size:12px;max-width:110px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
  .portal-app .app-user-chip .avatar{width:34px;height:34px}
  .portal-app .app-content{padding:14px 12px 110px}
  .portal-app .panel,.portal-app .kpi{border-radius:20px}
  .portal-app .panel-head,.portal-app .panel-body{padding:16px}
  .portal-app .app-hero-card{padding:18px;border-radius:22px;gap:14px}
  .portal-app .app-hero-card h2{font-size:22px}
  .portal-app .app-hero-actions,.portal-app .page-actions{display:grid;grid-template-columns:1fr 1fr;gap:10px}
  .portal-app .app-hero-actions .btn,.portal-app .page-actions .btn{width:100%;text-align:center;justify-content:center}
  .portal-app .grid-2,.portal-app .grid-3,.portal-app .grid-4,.portal-app .cols-2{gap:12px}
  .portal-app .field input,.portal-app .field select,.portal-app .field textarea,.portal-app .btn{font-size:16px}
  .portal-app .field label{font-size:12px;letter-spacing:.04em}
  .portal-app .list-item,.portal-app .notification,.portal-app .msg{border-radius:18px}
  .portal-app .app-bottom-nav{
    left:10px;right:10px;bottom:10px;padding:8px 6px calc(8px + env(safe-area-inset-bottom, 0px));
    border-radius:24px;background:rgba(17,15,12,.92);border:1px solid rgba(255,255,255,.06)
  }
  .portal-app .app-bottom-nav a{min-height:56px;font-size:10.5px;gap:4px}
  .portal-app .app-bottom-nav a span{line-height:1.1}
  .portal-app .app-data-table td[data-label]::before{display:block}
  .portal-app table,.portal-app tbody{gap:10px}
  .portal-app tr{background:transparent;border:0;margin:0}
  .portal-app td{padding:13px 14px 14px}
  .portal-app td.actions .btn{width:100%;justify-content:center}
}

@media(max-width:560px){
  .portal-app .app-user-chip > div{display:none}
  .portal-app .app-hero-actions,.portal-app .page-actions{grid-template-columns:1fr}
  .portal-app .app-bottom-nav{grid-template-columns:repeat(5,minmax(0,1fr))}
  .portal-app .app-stat-card{padding:18px}
  .portal-app .stat-num{font-size:34px}
  .portal-app .stat-title{font-size:20px}
}


/* ===== VIZO 8.5 — painel com leitura mais confortável ===== */
:root{
  --ink:#0B0F19;--ink-2:#171511;--panel:#1D1A15;--panel-2:#242019;
  --line:rgba(37,99,255,.16);--line-soft:rgba(237,231,220,.085);
  --gold:#00A2FF;--gold-lite:#38BDF8;--ivory:#EFE8DD;--muted:#A79C8E;--muted-2:#756C60;
  --display:'Inter',system-ui,sans-serif;
}
body{background:linear-gradient(180deg,#11100e 0%,#15130f 100%);color:var(--ivory);line-height:1.62;letter-spacing:-.004em}
.side,.portal-app .app-sidebar{background:linear-gradient(180deg,#171511,#12100d);border-color:rgba(237,231,220,.08)}
.side a{color:#A79C8E}.side a:hover{background:rgba(237,231,220,.045);color:#F3ECE1}.side a.active{background:rgba(37,99,255,.12);color:#F0B78F}.side a .badge{background:#00A2FF;color:#fff}.side .grp,.app-overline{color:#80776A}
.topbar,.portal-app .app-topbar{background:rgba(17,16,14,.86);border-color:rgba(237,231,220,.08)}.topbar h1,.portal-app .app-topbar h1,h1,h2,h3{font-family:var(--body);font-weight:750;letter-spacing:-.04em;color:#F3ECE1}
.portal-app .panel,.portal-app .kpi,.portal-app .app-stat-card,.portal-app .quick-app-card,.panel,.kpi,.auth-card{background:linear-gradient(180deg,rgba(29,26,21,.92),rgba(22,20,16,.96));border-color:rgba(237,231,220,.095);box-shadow:0 18px 58px -48px rgba(0,0,0,.72)}
.portal-app .app-hero-card{background:linear-gradient(135deg,rgba(37,99,255,.12),rgba(237,231,220,.028));border-color:rgba(37,99,255,.16);box-shadow:0 18px 58px -48px rgba(0,0,0,.72)}
.btn-gold,.portal-app .btn-gold{background:#00A2FF;color:#fff;border-color:#00A2FF;box-shadow:0 14px 34px -26px rgba(37,99,255,.85)}.btn-gold:hover{background:#1D7BFF}.btn-ghost,.portal-app .btn-ghost{border-color:rgba(237,231,220,.12);background:rgba(237,231,220,.035);color:#EFE8DD}.btn-ghost:hover{background:rgba(237,231,220,.065);border-color:rgba(237,231,220,.18)}
.portal-app .field input,.portal-app .field select,.portal-app .field textarea,.field input,.field select,.field textarea{background:rgba(17,16,14,.72);border-color:rgba(237,231,220,.12);color:#F2ECE2}.portal-app .field input:focus,.portal-app .field select:focus,.portal-app .field textarea:focus,.field input:focus,.field select:focus,.field textarea:focus{border-color:rgba(37,99,255,.45);box-shadow:0 0 0 4px rgba(37,99,255,.10)}
.portal-app .stat-num,.portal-app .stat-title,.rm .v,.kpi strong{color:#7DD3FC}.portal-app .qa-ico,.ico{background:rgba(37,99,255,.08);color:#38BDF8}.tag,.badge{border-color:rgba(237,231,220,.08)}
.portal-app td{background:rgba(237,231,220,.025);border-color:rgba(237,231,220,.055)!important}.portal-app tr:hover td{background:rgba(237,231,220,.045)}
.portal-login .auth-card{background:linear-gradient(180deg,rgba(29,26,21,.96),rgba(18,16,13,.98));box-shadow:0 26px 70px rgba(0,0,0,.32)}
@media(max-width:900px){.portal-app .app-bottom-nav{background:rgba(22,20,16,.92);border-color:rgba(237,231,220,.10);box-shadow:0 18px 44px -30px #000}.portal-app .app-bottom-nav a.active{background:rgba(37,99,255,.13);color:#F1C5A8}.portal-app .app-sidebar{background:linear-gradient(180deg,#1a1713,#12100d)}}


/* ===== VIZO 8.9 — financeiro do cliente e ajustes mobile ===== */
.payment-stack{display:grid;gap:16px}
.payment-card{padding:22px;border-radius:22px;background:linear-gradient(180deg,rgba(255,255,255,.03),rgba(255,255,255,.015));border:1px solid rgba(255,255,255,.05)}
.payment-head{display:flex;justify-content:space-between;gap:14px;align-items:flex-start;flex-wrap:wrap}
.payment-head h3{margin:6px 0 0;font-size:22px;line-height:1.15}
.payment-actions-wrap{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-top:16px}
.payment-box{padding:16px;border-radius:18px;background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.05);display:grid;gap:10px}
.small-code{font-size:12px;line-height:1.55;word-break:break-all}
.portal-app .actions{display:flex;align-items:center;justify-content:flex-end;gap:8px;flex-wrap:wrap}
.portal-app td.actions form{margin:0}
@media(max-width:900px){
  .payment-actions-wrap{grid-template-columns:1fr}
  .portal-app .page-actions>*{flex:1 1 180px}
  .portal-app td.actions{display:grid;gap:8px}
  .portal-app td.actions .btn,.portal-app td.actions form,.portal-app td.actions form .btn{width:100%}
}

/* ===== VIZO 8.11 — dashboard admin premium ===== */
.admin-hero-strip{display:flex;justify-content:space-between;gap:20px;align-items:flex-start;padding:26px;border-radius:26px;background:linear-gradient(135deg,rgba(37,99,255,.16),rgba(255,255,255,.03));border:1px solid rgba(37,99,255,.18);margin-bottom:20px}
.admin-hero-strip h2{font-family:var(--display);font-size:30px;line-height:1.05;margin:6px 0 8px}.admin-hero-strip p{max-width:60ch;color:#cbc4b7;margin:0}.admin-hero-actions{display:flex;gap:10px;flex-wrap:wrap}
.admin-kpi-grid-premium{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:20px}.admin-kpi-card{padding:20px;border-radius:22px;background:linear-gradient(180deg,rgba(255,255,255,.03),rgba(255,255,255,.015));border:1px solid rgba(255,255,255,.05)}.admin-kpi-card span{display:block;font-size:12px;color:var(--muted);margin-bottom:10px;text-transform:uppercase;letter-spacing:.12em;font-family:var(--mono)}.admin-kpi-card strong{display:block;font-family:var(--display);font-size:34px;line-height:1;color:var(--ivory)}.admin-kpi-card small{display:block;margin-top:8px;color:var(--muted);font-size:12px}
.premium-dashboard-grid{margin-bottom:20px}.premium-panel-graph .panel-body{padding-top:10px}.admin-mini-metrics{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:16px}.admin-mini-metrics div{padding:14px;border-radius:16px;background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.05)}.admin-mini-metrics span{display:block;font-size:11px;color:var(--muted);letter-spacing:.1em;text-transform:uppercase;font-family:var(--mono)}.admin-mini-metrics strong{display:block;margin-top:8px;font-size:28px;font-family:var(--display)}
.source-bars{display:grid;gap:14px}.source-row{display:grid;grid-template-columns:120px 1fr 40px;align-items:center;gap:12px}.source-row span{font-size:13px;color:#d5cebf}.source-row strong{text-align:right}.source-progress{height:10px;border-radius:99px;background:rgba(255,255,255,.06);overflow:hidden}.source-progress i{display:block;height:100%;background:linear-gradient(90deg,var(--gold),#ff9555);border-radius:99px}
@media(max-width:1100px){.admin-kpi-grid-premium,.admin-mini-metrics{grid-template-columns:repeat(2,1fr)}}
@media(max-width:760px){.admin-hero-strip{display:block}.admin-hero-actions{margin-top:14px}.admin-kpi-grid-premium,.admin-mini-metrics{grid-template-columns:1fr}.source-row{grid-template-columns:1fr}.source-row strong{text-align:left}}

/* ===== VIZO 8.15 — correção definitiva de responsividade mobile ===== */
html,body{width:100%;max-width:100%;overflow-x:hidden}
.portal-app,.portal-app *{box-sizing:border-box}
.portal-app img,.portal-app svg,.portal-app video{max-width:100%;height:auto}
.portal-app .shell,.portal-app .portal-shell,.portal-app .main,.portal-app .content,.portal-app .app-content,.portal-app .panel,.portal-app .panel-body,.portal-app .topbar-left{min-width:0;max-width:100%}
.portal-app .panel{overflow:hidden}
.portal-app .panel.has-table .panel-body{overflow:visible}
.portal-app .btn{max-width:100%;white-space:normal;line-height:1.25;text-align:center}
.portal-app input,.portal-app select,.portal-app textarea{min-width:0;max-width:100%}
.portal-app table{max-width:100%}
.portal-app td,.portal-app th{overflow-wrap:anywhere;word-break:normal}
.portal-app .admin-kpi-card,.portal-app .app-stat-card,.portal-app .quick-app-card,.portal-app .rm,.portal-app .kpi{min-width:0;max-width:100%}
.portal-app .dashboard-hero{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:16px;align-items:center}
.portal-app .grid-2,.portal-app .grid-3,.portal-app .grid-4,.portal-app .cols-2,.portal-app .app-stat-grid,.portal-app .admin-kpi-grid-premium,.portal-app .admin-mini-metrics{min-width:0}
.portal-app .grid-2>*,.portal-app .grid-3>*,.portal-app .grid-4>*,.portal-app .cols-2>*,.portal-app .app-stat-grid>*,.portal-app .admin-kpi-grid-premium>*,.portal-app .admin-mini-metrics>*{min-width:0}

@media(max-width:900px){
  .portal-app .shell,.portal-app .portal-shell{display:block;width:100%}
  .portal-app .main{width:100%;max-width:100vw;overflow-x:hidden}
  .portal-app .app-content{width:100%;padding-left:12px;padding-right:12px;overflow-x:hidden}
  .portal-app .topbar.app-topbar{width:100%;max-width:100vw;display:flex;gap:10px;overflow:hidden}
  .portal-app .topbar-left{flex:1 1 auto;overflow:hidden}
  .portal-app .topbar-left>div:last-child{min-width:0;max-width:100%}
  .portal-app .app-topbar h1{max-width:100%;overflow-wrap:anywhere;word-break:normal}
  .portal-app .app-topbar-right{flex:0 0 auto;min-width:auto}
  .portal-app .app-user-chip{max-width:48px;overflow:hidden;flex:0 0 auto}
  .portal-app .app-user-chip>div{display:none!important}
  .portal-app .avatar{flex:0 0 auto}
  .portal-app .app-sidebar{width:min(286px,calc(100vw - 24px));max-width:calc(100vw - 24px)}
  .portal-app .grid-2,.portal-app .grid-3,.portal-app .grid-4,.portal-app .cols-2,.portal-app .app-stat-grid,.portal-app .app-quick-grid,.portal-app .report-metrics,.portal-app .admin-kpi-grid-premium,.portal-app .admin-mini-metrics,.portal-app .payment-actions-wrap{grid-template-columns:minmax(0,1fr)!important}
  .portal-app .dashboard-hero{grid-template-columns:minmax(0,1fr)!important;align-items:stretch}
  .portal-app .dashboard-hero .admin-kpi-card{min-width:0!important;width:100%;text-align:left!important}
  .portal-app .page-actions,.portal-app .app-hero-actions,.portal-app .admin-hero-actions{display:grid!important;grid-template-columns:minmax(0,1fr)!important;width:100%}
  .portal-app .page-actions>*{min-width:0;width:100%}
  .portal-app .page-actions .btn,.portal-app .page-actions form,.portal-app .page-actions button,.portal-app .app-hero-actions .btn,.portal-app .admin-hero-actions .btn{width:100%;justify-content:center}
  .portal-app table,.portal-app thead,.portal-app tbody,.portal-app tr,.portal-app td{display:block;width:100%;max-width:100%}
  .portal-app thead{display:none!important}
  .portal-app tbody{display:grid;gap:12px}
  .portal-app tr{border:0;background:transparent;overflow:hidden}
  .portal-app td{white-space:normal!important;overflow-wrap:anywhere;padding:13px 14px!important;border:1px solid rgba(255,255,255,.05)!important;border-radius:14px!important;margin:0 0 8px!important;background:rgba(255,255,255,.02)}
  .portal-app td.actions{display:grid!important;grid-template-columns:minmax(0,1fr)!important;gap:8px;text-align:left!important;white-space:normal!important}
  .portal-app td.actions a,.portal-app td.actions form,.portal-app td.actions button{display:flex!important;width:100%!important;max-width:100%;justify-content:center;margin:0!important}
  .portal-app .kanban{grid-template-columns:repeat(7,minmax(250px,82vw));max-width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch}
  .portal-app .contract-body,.portal-app .proposal-card{overflow-wrap:anywhere}
  .portal-app .dl{grid-template-columns:minmax(0,1fr)!important;gap:6px}
  .portal-app .msg{max-width:100%}
  .portal-app .app-bottom-nav{left:8px;right:8px;bottom:8px;grid-template-columns:repeat(5,minmax(0,1fr));overflow:hidden}
  .portal-app .app-bottom-nav a{min-width:0;padding-left:2px;padding-right:2px}
  .portal-app .app-bottom-nav a span{max-width:100%;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-size:10px}
}

@media(max-width:380px){
  .portal-app .app-content{padding-left:10px;padding-right:10px}
  .portal-app .app-bottom-nav a span{font-size:9px}
  .portal-app .btn{font-size:14px;padding-left:12px;padding-right:12px}
  .portal-app .panel-head,.portal-app .panel-body{padding:14px}
}

/* VIZO logo fix: no black box, no card behind logo in admin/client/member areas */
.side .brand,
.portal-app .app-sidebar .brand,
.portal-app .side .brand,
.auth-card .brand,
.admin-logo,
.member-logo,
.brand-logo,
.brand-logo img,
.side .brand img,
.auth-card .brand img {
  background: transparent !important;
  box-shadow: none !important;
}
.side .brand,
.portal-app .app-sidebar .brand{
  border:0!important;
  padding-left:0!important;
  padding-right:0!important;
  border-radius:0!important;
  overflow:visible!important;
}
.brand-logo{height:22px!important;width:auto!important;max-width:90px!important;object-fit:contain!important;display:block!important;background:transparent!important;border:0!important;box-shadow:none!important}
.auth-card .brand-logo{height:30px!important;max-width:120px!important}
.portal-app .brand-logo{height:28px!important;max-width:112px!important}
@media(max-width:720px){
  .brand-logo{height:20px!important;max-width:82px!important}
  .auth-card .brand-logo{height:28px!important;max-width:108px!important}
  .portal-app .brand-logo{height:24px!important;max-width:96px!important}
  .side .brand,.portal-app .side .brand{background:transparent!important}
}

/* VIZO logo unified sizing - transparent original logo across admin/client/member */
:root{
  --logo-side-h: 40px;
  --logo-side-max: 190px;
  --logo-auth-h: 52px;
  --logo-auth-max: 250px;
  --logo-top-h: 40px;
  --logo-top-max: 190px;
}
.side .brand,
.portal-app .app-sidebar .brand,
.portal-app .side .brand,
.auth-card .brand{
  background:transparent!important;
  border:0!important;
  box-shadow:none!important;
  border-radius:0!important;
  padding-top:0!important;
  padding-bottom:18px!important;
  padding-left:0!important;
  padding-right:0!important;
  min-height:auto!important;
}
.side .brand img,
.portal-app .app-sidebar .brand img,
.portal-app .side .brand img,
.brand-logo{
  display:block!important;
  height:var(--logo-side-h)!important;
  width:auto!important;
  max-width:var(--logo-side-max)!important;
  object-fit:contain!important;
  background:transparent!important;
  border:0!important;
  box-shadow:none!important;
}
.auth-card .brand-logo{
  height:var(--logo-auth-h)!important;
  max-width:var(--logo-auth-max)!important;
  margin:0 auto!important;
}
.portal-app .brand-logo{height:var(--logo-top-h)!important;max-width:var(--logo-top-max)!important}
@media (max-width: 980px){
  :root{--logo-side-h: 36px; --logo-side-max: 172px; --logo-auth-h: 46px; --logo-auth-max: 220px; --logo-top-h: 36px; --logo-top-max: 172px;}
}
@media (max-width: 720px){
  :root{--logo-side-h: 30px; --logo-side-max: 144px; --logo-auth-h: 40px; --logo-auth-max: 190px; --logo-top-h: 30px; --logo-top-max: 144px;}
  .side .brand,.portal-app .side .brand,.portal-app .app-sidebar .brand{padding-bottom:14px!important}
}
@media (max-width: 420px){
  :root{--logo-side-h: 28px; --logo-side-max: 132px; --logo-auth-h: 36px; --logo-auth-max: 170px; --logo-top-h: 28px; --logo-top-max: 132px;}
}

/* Final logo correction from uploaded VIZO mark: real transparent PNG, no JPG background */
.side .brand img,
.portal-app .app-sidebar .brand img,
.portal-app .side .brand img,
.brand-logo{
  height:34px!important;
  max-width:132px!important;
  width:auto!important;
  object-fit:contain!important;
}
.auth-card .brand-logo-full,
.auth-card .brand-logo{
  height:58px!important;
  max-width:280px!important;
  width:auto!important;
}
@media(max-width:980px){
  .side .brand img,.portal-app .app-sidebar .brand img,.portal-app .side .brand img,.brand-logo{height:31px!important;max-width:122px!important}
  .auth-card .brand-logo-full,.auth-card .brand-logo{height:52px!important;max-width:250px!important}
}
@media(max-width:720px){
  .side .brand img,.portal-app .app-sidebar .brand img,.portal-app .side .brand img,.brand-logo{height:28px!important;max-width:110px!important}
  .auth-card .brand-logo-full,.auth-card .brand-logo{height:46px!important;max-width:220px!important}
}
@media(max-width:420px){
  .side .brand img,.portal-app .app-sidebar .brand img,.portal-app .side .brand img,.brand-logo{height:26px!important;max-width:102px!important}
  .auth-card .brand-logo-full,.auth-card .brand-logo{height:40px!important;max-width:190px!important}
}

/* FINAL VIZO logo: true transparent PNG + responsive sizing for admin/client/member */
.side .brand,
.portal-app .app-sidebar .brand,
.portal-app .side .brand,
.auth-card .brand,
.side .brand img,
.portal-app .side .brand img,
.auth-card .brand img,
.brand-logo,
.brand-logo-full{
  background:transparent!important;
  border:0!important;
  box-shadow:none!important;
}
.side .brand,
.portal-app .app-sidebar .brand,
.portal-app .side .brand{
  display:flex!important;
  align-items:center!important;
  gap:10px!important;
  padding:0 0 20px 0!important;
  margin:0 0 10px 0!important;
  border-radius:0!important;
  overflow:visible!important;
  min-height:auto!important;
}
.side .brand .brand-logo,
.portal-app .side .brand .brand-logo,
.portal-app .app-sidebar .brand .brand-logo{
  display:block!important;
  width:auto!important;
  height:34px!important;
  max-width:140px!important;
  object-fit:contain!important;
  object-position:left center!important;
}
.auth-card .brand{
  justify-content:center!important;
  padding:0!important;
  margin-bottom:16px!important;
}
.auth-card .brand-logo,
.auth-card .brand-logo-full{
  display:block!important;
  width:auto!important;
  height:62px!important;
  max-width:310px!important;
  object-fit:contain!important;
}
@media(max-width:980px){
  .side .brand .brand-logo,.portal-app .side .brand .brand-logo,.portal-app .app-sidebar .brand .brand-logo{height:31px!important;max-width:126px!important}
  .auth-card .brand-logo,.auth-card .brand-logo-full{height:56px!important;max-width:270px!important}
}
@media(max-width:720px){
  .side .brand,.portal-app .app-sidebar .brand,.portal-app .side .brand{padding-bottom:16px!important}
  .side .brand .brand-logo,.portal-app .side .brand .brand-logo,.portal-app .app-sidebar .brand .brand-logo{height:28px!important;max-width:112px!important}
  .auth-card .brand-logo,.auth-card .brand-logo-full{height:48px!important;max-width:230px!important}
}
@media(max-width:420px){
  .side .brand .brand-logo,.portal-app .side .brand .brand-logo,.portal-app .app-sidebar .brand .brand-logo{height:25px!important;max-width:100px!important}
  .auth-card .brand-logo,.auth-card .brand-logo-full{height:42px!important;max-width:200px!important}
}

/* ================= PROSPECÇÃO INTERNA VIZO ================= */
.prospecting-hero{margin-bottom:18px}
.prospecting-kpi-grid{display:grid;grid-template-columns:repeat(6,minmax(0,1fr));gap:12px;margin:0 0 18px}
.prospecting-kpi{display:block;min-height:112px;padding:16px;border:1px solid rgba(237,231,220,.09);border-radius:18px;background:linear-gradient(180deg,rgba(255,255,255,.036),rgba(255,255,255,.014));text-decoration:none;color:inherit;transition:transform .2s,border-color .2s,background .2s}
.prospecting-kpi:hover,.prospecting-kpi.active{transform:translateY(-2px);border-color:rgba(224,177,90,.48);background:linear-gradient(180deg,rgba(224,177,90,.12),rgba(255,255,255,.02))}
.prospecting-kpi.alert{border-color:rgba(217,117,107,.56)}
.prospecting-kpi span{display:block;color:var(--muted);font-family:var(--mono);font-size:10px;letter-spacing:.11em;text-transform:uppercase}
.prospecting-kpi strong{display:block;margin:10px 0 2px;font-family:var(--display);font-size:31px;line-height:1}
.prospecting-kpi small{display:block;color:var(--muted);font-size:12px}
.prospecting-filter-panel{margin-bottom:16px}
.prospecting-filter-panel .panel-body{padding:16px 18px}
.prospecting-filter-grid{display:grid;grid-template-columns:1.7fr repeat(3,minmax(130px,1fr)) auto auto;gap:10px;align-items:end}
.prospecting-filter-grid .field{margin:0}
.prospecting-filter-grid .btn{height:44px;white-space:nowrap}
.prospecting-list-actions{align-items:center}
.prospecting-view-switch{display:flex;gap:8px;flex-shrink:0}
.prospecting-kanban{grid-template-columns:repeat(8,minmax(230px,1fr));padding-bottom:16px}
.prospecting-kanban .kanban-title{display:flex;align-items:center;justify-content:space-between;gap:10px}
.prospecting-kanban .kanban-title b{display:grid;place-items:center;min-width:24px;height:24px;border-radius:999px;background:rgba(224,177,90,.14);color:var(--gold);font-size:11px}
.prospecting-kanban-card{padding:0;overflow:hidden}
.prospecting-card-link{display:block;padding:15px;color:inherit;text-decoration:none}
.prospecting-card-link:hover{color:inherit}
.prospecting-card-foot{display:flex;justify-content:space-between;gap:8px;align-items:center;margin-top:12px;padding-top:10px;border-top:1px solid rgba(255,255,255,.055);font-size:11px;color:var(--muted)}
.prospecting-card-foot span{max-width:120px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.prospecting-card-foot time{font-style:normal;color:var(--gold);white-space:nowrap}
.prospecting-card-foot time.late,.prospecting-due.late{color:var(--bad)!important}
.prospecting-kanban-empty{padding:16px 7px;color:var(--muted);font-size:12px;line-height:1.45}
.prospecting-dropzone.drag-over{border-color:rgba(224,177,90,.62);background:rgba(224,177,90,.06)}
.prospecting-kanban-card[draggable="true"]{cursor:grab}.prospecting-kanban-card.dragging{opacity:.45;cursor:grabbing}
.prospecting-table-actions{min-width:235px}
.prospecting-table-actions .btn{margin:0 3px 5px 0}
.prospecting-due{display:inline-flex;align-items:center;min-height:27px;padding:4px 9px;border-radius:999px;background:rgba(127,168,217,.12);color:var(--info);font-size:12px;white-space:nowrap}
.tag.prospect-status-new{background:rgba(127,168,217,.14);color:var(--info)}
.tag.prospect-status-called,.tag.prospect-status-whatsapp_sent{background:rgba(224,177,90,.14);color:var(--warn)}
.tag.prospect-status-answered{background:rgba(137,109,218,.16);color:#cbb7ff}
.tag.prospect-status-meeting_scheduled,.tag.prospect-status-proposal_sent{background:rgba(224,177,90,.2);color:var(--gold)}
.tag.prospect-status-won{background:rgba(111,191,139,.15);color:var(--ok)}
.tag.prospect-status-lost{background:rgba(217,117,107,.14);color:var(--bad)}
.prospecting-empty{padding:40px 20px;display:grid;justify-items:center;gap:12px}
.prospecting-form-card{max-width:900px;margin:0 auto}
.prospecting-import-layout{align-items:start}
.prospecting-guide p{line-height:1.65;color:var(--muted)}
.prospecting-guide code{display:block;padding:12px;border-radius:12px;background:rgba(0,0,0,.24);border:1px solid rgba(255,255,255,.05);color:var(--gold);font-size:12px;overflow:auto}
.prospecting-import-result{margin-top:18px}
.prospecting-import-stats{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:10px}
.prospecting-import-stats div{padding:14px;border-radius:15px;background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.05)}
.prospecting-import-stats span{display:block;color:var(--muted);font-family:var(--mono);font-size:10px;letter-spacing:.09em;text-transform:uppercase;line-height:1.35}
.prospecting-import-stats strong{display:block;font-family:var(--display);font-size:27px;margin-top:7px}
.prospecting-duplicate-list{display:grid;gap:8px;margin-top:20px}
.prospecting-duplicate-list>strong{font-size:14px}
.prospecting-duplicate-list a{display:flex;justify-content:space-between;gap:12px;padding:11px 13px;border:1px solid rgba(255,255,255,.05);border-radius:12px;background:rgba(255,255,255,.025);color:inherit;text-decoration:none}
.prospecting-duplicate-list small{color:var(--muted)}
.prospecting-lead-header{display:flex;align-items:flex-end;justify-content:space-between;gap:18px;margin:-2px 0 18px;padding:22px;border:1px solid rgba(224,177,90,.2);border-radius:22px;background:radial-gradient(circle at 90% 0,rgba(224,177,90,.13),transparent 42%),linear-gradient(135deg,rgba(255,255,255,.04),rgba(255,255,255,.015))}
.prospecting-lead-header h2{margin:6px 0 0;font-family:var(--display);font-size:31px;line-height:1.12}
.prospecting-lead-header p{margin:7px 0 0;color:var(--muted)}
.prospecting-lead-header-meta{display:flex;align-items:center;justify-content:flex-end;gap:8px;flex-wrap:wrap}
.prospecting-view-actions{display:flex;gap:8px;flex-wrap:wrap;justify-content:flex-end}
.prospecting-detail-grid{align-items:start}
.prospecting-dl dt{color:var(--muted)}
.prospecting-dl dd a{color:var(--gold);text-decoration:none}
.prospecting-initial-notes{margin-top:18px;padding:14px;border:1px solid rgba(255,255,255,.05);border-radius:14px;background:rgba(255,255,255,.025)}
.prospecting-initial-notes span{display:block;color:var(--muted);font-size:11px;font-family:var(--mono);letter-spacing:.1em;text-transform:uppercase}
.prospecting-initial-notes p{margin:8px 0 0;line-height:1.6}
.prospecting-history-panel{margin-top:18px}
.prospecting-timeline{position:relative;padding-left:20px}
.prospecting-timeline:before{content:"";position:absolute;left:5px;top:8px;bottom:8px;width:1px;background:rgba(255,255,255,.10)}
.prospecting-timeline-item{position:relative;padding:0 0 20px 18px}
.prospecting-timeline-item:last-child{padding-bottom:0}
.prospecting-timeline-dot{position:absolute;left:-1px;top:4px;width:13px;height:13px;border:3px solid var(--ink-2);border-radius:50%;background:var(--gold);box-shadow:0 0 0 1px rgba(224,177,90,.35)}
.prospecting-timeline-item.type-call .prospecting-timeline-dot{background:var(--info);box-shadow:0 0 0 1px rgba(127,168,217,.35)}
.prospecting-timeline-item.type-whatsapp .prospecting-timeline-dot{background:var(--ok);box-shadow:0 0 0 1px rgba(111,191,139,.35)}
.prospecting-timeline-item.type-status .prospecting-timeline-dot{background:#cbb7ff;box-shadow:0 0 0 1px rgba(203,183,255,.35)}
.prospecting-timeline-content{padding:13px 15px;border:1px solid rgba(255,255,255,.05);border-radius:15px;background:rgba(255,255,255,.025)}
.prospecting-timeline-head{display:flex;justify-content:space-between;gap:14px;align-items:flex-start}
.prospecting-timeline-head time{color:var(--muted);font-size:12px;white-space:nowrap}
.prospecting-timeline-content p{margin:10px 0 0;line-height:1.6;color:var(--muted)}
.prospecting-timeline-meta{display:flex;gap:8px;flex-wrap:wrap;margin-top:10px}
.prospecting-timeline-meta span{padding:4px 8px;border-radius:999px;background:rgba(255,255,255,.045);color:var(--muted);font-size:11px}

@media(max-width:1280px){
  .prospecting-kpi-grid{grid-template-columns:repeat(3,minmax(0,1fr))}
  .prospecting-filter-grid{grid-template-columns:repeat(3,minmax(0,1fr))}
  .prospecting-filter-grid .btn{width:100%}
  .prospecting-import-stats{grid-template-columns:repeat(3,minmax(0,1fr))}
}
@media(max-width:760px){
  .prospecting-kpi-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:9px}
  .prospecting-kpi{min-height:96px;padding:13px}
  .prospecting-kpi strong{font-size:27px}
  .prospecting-filter-grid{grid-template-columns:1fr}
  .prospecting-filter-grid .field{width:100%}
  .prospecting-list-actions{display:grid!important;grid-template-columns:1fr!important}
  .prospecting-view-switch{width:100%}.prospecting-view-switch .btn{flex:1}
  .prospecting-kanban{grid-template-columns:repeat(8,minmax(280px,82vw))}
  .prospecting-import-stats{grid-template-columns:repeat(2,minmax(0,1fr))}
  .prospecting-duplicate-list a{display:grid}.prospecting-duplicate-list small{line-height:1.45}
  .prospecting-lead-header{display:grid;padding:18px;align-items:start}.prospecting-lead-header h2{font-size:27px}.prospecting-lead-header-meta{justify-content:flex-start}
  .prospecting-view-actions{width:100%;justify-content:stretch}.prospecting-view-actions .btn{flex:1;justify-content:center}
  .prospecting-timeline{padding-left:14px}.prospecting-timeline-item{padding-left:17px}.prospecting-timeline-head{display:grid;gap:5px}.prospecting-timeline-head time{white-space:normal}
}

/* ================= ABORDAGENS WHATSAPP — PROSPECÇÃO ================= */
.prospect-link-button{padding:0;border:0;background:transparent;color:var(--gold);font:inherit;cursor:pointer;text-align:left}
.prospect-link-button:hover{text-decoration:underline}
.prospecting-wa-modal[hidden]{display:none!important}
.prospecting-wa-modal{position:fixed;z-index:9999;inset:0;display:grid;place-items:center;padding:24px}
.prospecting-wa-backdrop{position:absolute;inset:0;background:rgba(4,7,12,.78);backdrop-filter:blur(10px)}
.prospecting-wa-dialog{position:relative;width:min(760px,100%);max-height:min(720px,calc(100vh - 36px));overflow:auto;padding:28px;border:1px solid rgba(224,177,90,.38);border-radius:26px;background:radial-gradient(circle at 90% 0,rgba(224,177,90,.15),transparent 34%),linear-gradient(145deg,#171a21,#0d1016);box-shadow:0 28px 90px rgba(0,0,0,.55)}
.prospecting-wa-dialog h3{margin:8px 42px 8px 0;font-family:var(--display);font-size:28px;line-height:1.15}
.prospecting-wa-dialog>p{max-width:650px;margin:0;color:var(--muted);line-height:1.58}
.prospecting-wa-close{position:absolute;top:17px;right:17px;width:36px;height:36px;border:1px solid rgba(255,255,255,.10);border-radius:999px;background:rgba(255,255,255,.04);color:var(--text);font-size:27px;line-height:1;cursor:pointer;transition:transform .2s,border-color .2s,background .2s}
.prospecting-wa-close:hover{transform:rotate(90deg);border-color:rgba(224,177,90,.55);background:rgba(224,177,90,.10)}
.prospecting-wa-options{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px;margin-top:23px}
.prospecting-wa-option{display:flex;min-height:235px;flex-direction:column;align-items:flex-start;gap:13px;padding:18px;border:1px solid rgba(255,255,255,.09);border-radius:18px;background:linear-gradient(180deg,rgba(255,255,255,.05),rgba(255,255,255,.018));color:var(--text);font:inherit;text-align:left;cursor:pointer;transition:transform .2s,border-color .2s,background .2s,box-shadow .2s}
.prospecting-wa-option:hover,.prospecting-wa-option:focus-visible{transform:translateY(-4px);border-color:rgba(224,177,90,.7);background:linear-gradient(180deg,rgba(224,177,90,.17),rgba(255,255,255,.045));box-shadow:0 18px 36px rgba(0,0,0,.24);outline:none}
.prospecting-wa-option-top{display:grid;gap:6px}.prospecting-wa-option-top small{color:var(--gold);font-family:var(--mono);font-size:9px;letter-spacing:.1em;text-transform:uppercase}.prospecting-wa-option-top b{font-family:var(--display);font-size:21px;line-height:1.05}.prospecting-wa-option>span:not(.prospecting-wa-option-top){color:var(--muted);font-size:13px;line-height:1.55}.prospecting-wa-option em{margin-top:auto;color:var(--gold);font-size:12px;font-style:normal;font-weight:700}.prospecting-wa-option em span{display:inline-block;margin-left:4px;transition:transform .2s}.prospecting-wa-option:hover em span{transform:translateX(4px)}
body.prospecting-wa-open{overflow:hidden}
@media(max-width:760px){.prospecting-wa-modal{padding:12px}.prospecting-wa-dialog{padding:22px 17px;border-radius:21px}.prospecting-wa-dialog h3{font-size:25px}.prospecting-wa-options{grid-template-columns:1fr}.prospecting-wa-option{min-height:0;padding:16px}.prospecting-wa-option>span:not(.prospecting-wa-option-top){font-size:13px}.prospecting-wa-option em{margin-top:2px}}
