/* ==========================================================================
   SISTEMA MAZI — UI premium (base C.R.M Paraná, refinada)
   Inter + JetBrains Mono · sombras em camadas · micro-interações · direto ao ponto
   ========================================================================== */
@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800;900&family=JetBrains+Mono:wght@400;500;700&display=swap');

:root{
  --bg:#f6f7f9; --bg-2:#eef1f5; --panel:#fff; --ink:#13151a; --ink-soft:#3b4150;
  --muted:#6b7280; --muted-2:#949bab; --line:#edeff3; --line-2:#e2e6ec;
  --brand:#f4b400; --brand-1:#ffc83d; --brand-d:#9a7400; --brand-bg:#fff6db;
  --green:#0e9f57; --green-bg:#e7f7ed; --green-tx:#0b6b3a;
  --yellow:#d98500; --yellow-bg:#fff3de; --yellow-tx:#8a5300;
  --red:#e23a3a; --red-bg:#fdecec; --red-tx:#a11f1f;
  --blue:#2f6bff; --blue-bg:#eaf0ff; --blue-tx:#1b47b5;
  --ring:0 0 0 3px rgba(244,180,0,.22);
  --sh-xs:0 1px 2px rgba(16,24,40,.05);
  --sh-sm:0 1px 2px rgba(16,24,40,.04), 0 2px 6px rgba(16,24,40,.05);
  --sh-md:0 4px 12px rgba(16,24,40,.07), 0 2px 4px rgba(16,24,40,.04);
  --sh-lg:0 18px 50px rgba(16,24,40,.16);
  --r:16px; --r-sm:11px; --mono:"JetBrains Mono",monospace; --sans:"Inter",system-ui,Arial,sans-serif;
}
*{box-sizing:border-box}
[hidden]{display:none!important}
html{scroll-behavior:smooth}
body{margin:0;background:var(--bg);color:var(--ink);font-family:var(--sans);font-size:14px;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
button,input,select,textarea{font:inherit}
button{cursor:pointer}
a{color:var(--blue-tx);text-decoration:none}
h1,h2,h3{margin:0;letter-spacing:-.02em}
::selection{background:rgba(244,180,0,.3)}
.mono{font-family:var(--mono);font-weight:500}
.money{font-family:var(--mono);font-weight:700;white-space:nowrap;font-variant-numeric:tabular-nums}
.muted{color:var(--muted)}.right{text-align:right}.center{text-align:center}
::-webkit-scrollbar{width:10px;height:10px}::-webkit-scrollbar-thumb{background:#d4d9e1;border-radius:9px;border:2px solid var(--bg)}::-webkit-scrollbar-thumb:hover{background:#c2c8d2}

/* ---------------- LOGIN ---------------- */
.login-page{min-height:100vh;display:grid;place-items:center;padding:24px;position:relative;
  background:radial-gradient(900px 500px at 50% -5%,#22242c,#0c0d10 70%)}
.login-page:before{content:"";position:absolute;inset:0;opacity:.5;
  background-image:linear-gradient(rgba(255,255,255,.025) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.025) 1px,transparent 1px);
  background-size:34px 34px;mask-image:radial-gradient(circle at 50% 35%,#000,transparent 70%)}
.login-card{position:relative;width:min(404px,100%);background:#fff;border-radius:22px;box-shadow:0 40px 90px rgba(0,0,0,.5);padding:34px 32px;display:grid;gap:16px;border:1px solid rgba(255,255,255,.6)}
.login-logo{width:86px;height:86px;margin:0 auto;border-radius:20px;background:#fff;box-shadow:var(--sh-md);display:grid;place-items:center;border:1px solid var(--line-2)}
.login-logo img{width:64px;height:64px;object-fit:contain}
.login-brand{text-align:center}
.login-brand strong{font-size:19px;font-weight:900;letter-spacing:-.02em;display:block}
.login-brand small{color:var(--muted);font-weight:600;font-size:12.5px}
.login-card h1{font-size:23px;font-weight:900;text-align:center;margin-top:2px}
.login-eyebrow{text-align:center;color:var(--brand-d);font-size:11px;font-weight:900;text-transform:uppercase;letter-spacing:.12em;margin:0}
.login-status{min-height:18px;margin:0;color:var(--muted);font-size:13px;font-weight:600;text-align:center}
.login-status.error{color:var(--red-tx)}.login-status.ok{color:var(--green-tx)}

/* ---------------- CAMPOS ---------------- */
.field{display:grid;gap:9px}
.field label,label.lab{font-size:11.5px;font-weight:800;color:var(--ink-soft);text-transform:uppercase;letter-spacing:.05em}
input,select,textarea{width:100%;height:46px;border:1px solid var(--line-2);border-radius:11px;padding:12px 14px;outline:none;background:#f5f7fa;color:var(--ink);transition:border-color .15s,box-shadow .15s,background .15s}
textarea{height:auto;min-height:90px;resize:vertical;line-height:1.5}
input::placeholder,textarea::placeholder{color:var(--muted-2)}
input:focus,select:focus,textarea:focus{border-color:var(--brand);background:#fff;box-shadow:var(--ring)}
.hint{font-size:12px;color:var(--muted)}

/* ---------------- BOTÕES ---------------- */
.btn{height:40px;border:1px solid var(--line-2);background:#fff;color:var(--ink);border-radius:var(--r-sm);padding:0 15px;font-size:13px;font-weight:700;display:inline-flex;align-items:center;gap:8px;white-space:nowrap;transition:transform .12s ease,box-shadow .15s,border-color .15s,background .15s}
.btn:hover{border-color:#cfd5de;box-shadow:var(--sh-sm)}
.btn:active{transform:translateY(1px)}
.btn i{font-size:19px;line-height:1}
.btn.brand{background:linear-gradient(180deg,var(--brand-1),var(--brand));border-color:#dca700;color:#241c00;box-shadow:0 1px 2px rgba(154,116,0,.25),0 6px 16px rgba(244,180,0,.28)}
.btn.brand:hover{filter:brightness(1.03);box-shadow:0 2px 4px rgba(154,116,0,.3),0 10px 22px rgba(244,180,0,.34)}
.btn.dark{background:var(--ink);border-color:var(--ink);color:#fff}
.btn.dark:hover{background:#22242c}
.btn.green{background:#1fab54;border-color:#1c9c4d;color:#fff}
.btn.wpp{background:#25d366;border-color:#1ea952;color:#fff}
.btn.danger{background:var(--red);border-color:#cf2f2f;color:#fff}
.btn.gh{border-color:transparent;background:transparent;color:var(--muted)}
.btn.gh:hover{background:#fff;box-shadow:var(--sh-sm);color:var(--ink)}
.btn.resume{background:var(--brand-bg);border-color:#f0d68a;color:var(--brand-d);font-weight:800}
.btn.resume:hover{background:#ffefc2;border-color:var(--brand);box-shadow:var(--sh-sm)}
.btn.sm{height:34px;padding:0 11px;border-radius:9px;font-size:12.5px}
.btn.sm i{font-size:17px}
.btn.lg{height:48px;padding:0 22px;font-size:15px;border-radius:13px}
.btn.block{width:100%;justify-content:center}

/* ---------------- LAYOUT ---------------- */
.shell{display:grid;grid-template-columns:240px 1fr;min-height:100vh}
.side{background:#fff;border-right:1px solid var(--line);position:sticky;top:0;height:100vh;display:flex;flex-direction:column}
.brandbox{padding:18px 16px 14px;display:flex;align-items:center;gap:12px;border-bottom:1px solid var(--line)}
.brandbox .logo{width:46px;height:46px;border-radius:13px;background:#fff;border:1px solid var(--line-2);box-shadow:var(--sh-xs);display:grid;place-items:center;flex:none;overflow:hidden}
.brandbox .logo img{width:38px;height:38px;object-fit:contain}
.brandbox b{font-size:16px;font-weight:900;letter-spacing:-.02em;display:block;line-height:1.05}
.brandbox span{font-size:11px;color:var(--muted)}
.nav{padding:12px 12px;display:flex;flex-direction:column;gap:3px;overflow:auto}
.nav small{font-size:10.5px;color:var(--muted-2);font-weight:800;text-transform:uppercase;letter-spacing:.08em;margin:14px 10px 6px}
.nav button{position:relative;border:0;background:transparent;border-radius:11px;height:42px;padding:0 12px;display:flex;align-items:center;gap:11px;color:var(--ink-soft);font-weight:600;font-size:14px;text-align:left;transition:background .15s,color .15s}
.nav button i{font-size:22px;line-height:1;color:var(--muted-2);transition:color .15s}
.nav button:hover{background:#f3f5f8;color:var(--ink)}
.nav button:hover i{color:var(--ink-soft)}
.nav button.on{background:var(--ink);color:#fff}
.nav button.on i{color:var(--brand)}
.nav button.on:before{content:"";position:absolute;left:-12px;top:9px;bottom:9px;width:3px;border-radius:0 3px 3px 0;background:var(--brand)}
.nav .count{margin-left:auto;background:#eef1f5;color:var(--muted);border-radius:999px;padding:2px 9px;font-size:11px;font-weight:800}
.nav button.on .count{background:rgba(255,255,255,.16);color:#fff}
.side-foot{margin-top:auto;border-top:1px solid var(--line);padding:12px}
.side-user{display:flex;align-items:center;gap:11px;padding:10px 11px;background:linear-gradient(180deg,#fbfcfd,#f4f6f9);border:1px solid var(--line);border-radius:13px;margin-bottom:9px}
.side-user .av{width:38px;height:38px;border-radius:11px;background:linear-gradient(180deg,var(--brand-1),var(--brand));color:#241c00;display:grid;place-items:center;font-weight:900;box-shadow:0 2px 6px rgba(244,180,0,.35)}
.side-user .ui{min-width:0;flex:1}
.side-user b{font-size:13.5px;display:block;line-height:1.1}.side-user span{font-size:11.5px;color:var(--muted)}
.logout{width:100%;height:42px;border:1px solid var(--line-2);background:#fff;border-radius:12px;display:flex;align-items:center;justify-content:center;gap:9px;color:var(--ink-soft);font-weight:700;font-size:13.5px;transition:transform .12s,background .15s,color .15s,border-color .15s,box-shadow .15s}
.logout i{font-size:20px}
.logout:hover{background:var(--red-bg);border-color:#f4b5b5;color:var(--red-tx);box-shadow:var(--sh-xs)}
.logout:active{transform:translateY(1px)}

.main{min-width:0;display:flex;flex-direction:column}
.top{height:66px;background:rgba(246,247,249,.82);backdrop-filter:saturate(140%) blur(10px);border-bottom:1px solid var(--line);display:flex;align-items:center;gap:16px;padding:0 24px;position:sticky;top:0;z-index:20}
.crumb{display:flex;align-items:center;gap:7px;color:var(--muted);min-width:160px;font-size:13px}
.crumb b{color:var(--ink);font-weight:800}
.crumb i{font-size:18px;color:var(--muted-2)}
.search{position:relative;flex:1;max-width:480px}
.search i{position:absolute;left:13px;top:50%;transform:translateY(-50%);font-size:20px;color:var(--muted-2)}
.search input{height:42px;padding-left:42px;border-radius:12px;background:#fff;box-shadow:var(--sh-xs)}
.top-actions{margin-left:auto;display:flex;gap:9px;align-items:center}
.top-date{display:inline-flex;align-items:center;gap:7px;height:40px;padding:0 13px;border:1px solid var(--line-2);border-radius:11px;background:#fff;color:var(--ink-soft);font-weight:600;font-size:13px;box-shadow:var(--sh-xs)}
.top-date i{font-size:18px;color:var(--muted)}
.menu-toggle{display:none}

.content{padding:26px 28px 60px;max-width:1340px;width:100%;margin:0 auto}
.vh{margin-bottom:22px;display:flex;align-items:flex-end;justify-content:space-between;gap:16px;flex-wrap:wrap}
.vh h1{font-size:24px;font-weight:900}
.vh p{margin:6px 0 0;color:var(--muted);font-size:13.5px}

.view{display:none}
.view.active{display:block;animation:fade .22s ease}
@keyframes fade{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}

/* ---------------- CARDS / KPI ---------------- */
.card{background:var(--panel);border:1px solid var(--line);border-radius:var(--r);box-shadow:var(--sh-sm);overflow:hidden}
.card.pad,.pad{padding:18px}
.card-h{padding:16px 18px;border-bottom:1px solid var(--line);display:flex;align-items:center;justify-content:space-between;gap:12px}
.card-h h3{font-size:15px;font-weight:800;display:flex;align-items:center;gap:8px}
.card-h h3 i{font-size:21px;color:var(--muted)}
.card-h .lnk{color:var(--muted);font-size:13px;font-weight:700;display:inline-flex;align-items:center;gap:3px;transition:color .15s}
.card-h .lnk:hover{color:var(--ink)}

.grid4{display:grid;grid-template-columns:repeat(auto-fit,minmax(206px,1fr));gap:16px;margin-bottom:20px}
.grid2{display:grid;grid-template-columns:1.5fr 1fr;gap:18px}
.kpi{position:relative;padding:18px;display:flex;flex-direction:column;transition:transform .14s,box-shadow .15s}
.kpi:before{content:"";position:absolute;left:0;right:0;top:0;height:3px;background:linear-gradient(90deg,var(--brand-1),var(--brand));opacity:0;transition:opacity .15s}
.kpi:hover{transform:translateY(-3px);box-shadow:var(--sh-md)}
.kpi:hover:before{opacity:1}
.kpi-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}
.kpi .ico{width:42px;height:42px;border-radius:12px;display:grid;place-items:center;background:var(--brand-bg);color:var(--brand-d)}
.kpi .ico i{font-size:24px}
.kpi .ico.g{background:var(--green-bg);color:var(--green-tx)}
.kpi .ico.b{background:var(--blue-bg);color:var(--blue-tx)}
.kpi .ico.r{background:var(--red-bg);color:var(--red-tx)}
.kpi .lab{font-size:12.5px;color:var(--muted);font-weight:600}
.kpi .val{font-size:28px;font-weight:900;letter-spacing:-.03em;margin-top:3px;line-height:1}
.trend{display:inline-flex;align-items:center;gap:3px;height:24px;padding:0 9px;border-radius:999px;font-size:12px;font-weight:800}
.trend i{font-size:15px}
.trend.up{background:var(--green-bg);color:var(--green-tx)}
.trend.flat{background:#eef1f5;color:var(--muted)}
.trend.warn{background:var(--yellow-bg);color:var(--yellow-tx)}

/* admin — stat cards horizontais uniformes */
.astat{display:flex;align-items:center;gap:14px;padding:18px}
.astat .ico{width:46px;height:46px;border-radius:13px;display:grid;place-items:center;background:var(--brand-bg);color:var(--brand-d);flex:none}
.astat .ico i{font-size:25px}
.astat .ico.g{background:var(--green-bg);color:var(--green-tx)}
.astat .ico.b{background:var(--blue-bg);color:var(--blue-tx)}
.astat .ai{min-width:0}
.astat .lab{display:block;color:var(--muted);font-size:12px;font-weight:600}
.astat b{display:block;font-size:23px;font-weight:900;letter-spacing:-.02em;line-height:1.1;margin-top:2px}
.astat .pill{margin-left:auto;align-self:flex-start}

/* formulário em colunas */
.form2{display:grid;grid-template-columns:1fr 1fr;gap:22px 22px}
.form2 .full{grid-column:1/-1}
.form3{display:grid;grid-template-columns:repeat(3,1fr);gap:22px 22px}
.form3 .full{grid-column:1/-1}
/* dados da empresa: form + painel da logo */
.empresa-grid{display:grid;grid-template-columns:1fr 300px;gap:26px;align-items:start}
.logo-up{border:1.5px dashed var(--line-2);border-radius:16px;padding:20px;display:grid;place-items:center;gap:14px;background:#fbfcfd}
.logo-up img{width:104px;height:104px;object-fit:contain;border-radius:14px;background:#fff;border:1px solid var(--line);padding:10px}

/* atividade recente — timeline */
.feed{position:relative;display:flex;flex-direction:column}
.feed-item{display:flex;gap:13px;padding:11px 0;position:relative}
.feed-item:not(:last-child)::before{content:"";position:absolute;left:17px;top:42px;bottom:-11px;width:2px;background:var(--line)}
.feed-ic{width:36px;height:36px;border-radius:11px;display:grid;place-items:center;flex:none;background:var(--brand-bg);color:var(--brand-d);z-index:1}
.feed-ic i{font-size:19px}
.feed-ic.g{background:var(--green-bg);color:var(--green-tx)}
.feed-ic.b{background:var(--blue-bg);color:var(--blue-tx)}
.feed-ic.n{background:#eef1f5;color:var(--muted)}
.feed-bd{min-width:0;padding-top:1px}
.feed-bd b{display:block;font-weight:600;font-size:13.5px;color:var(--ink);line-height:1.35}
.feed-bd time{display:block;font-size:12px;color:var(--muted);margin-top:3px}
.feed-bd time .mono{color:var(--ink-soft);font-weight:700}

/* ---------------- AÇÕES RÁPIDAS ---------------- */
.quick{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-bottom:22px}
.quick button{display:flex;align-items:center;gap:14px;text-align:left;background:#fff;border:1px solid var(--line);border-radius:var(--r);box-shadow:var(--sh-sm);padding:18px;transition:transform .14s,box-shadow .15s,border-color .15s}
.quick button:hover{border-color:#f0d68a;box-shadow:var(--sh-md);transform:translateY(-3px)}
.quick .ico{width:50px;height:50px;border-radius:14px;display:grid;place-items:center;background:var(--brand-bg);color:var(--brand-d);flex:none}
.quick .ico i{font-size:26px}
.quick .ico.dark{background:var(--ink);color:var(--brand)}
.quick b{font-size:15.5px;font-weight:800;display:block}
.quick span{font-size:13px;color:var(--muted)}
.quick .go{margin-left:auto;color:var(--muted-2);font-size:20px;transition:transform .15s,color .15s}
.quick button:hover .go{color:var(--brand-d);transform:translateX(3px)}

/* ---------------- TABELA ---------------- */
.table-wrap{overflow:auto}
.table{width:100%;border-collapse:collapse}
.table th{font-size:11px;color:var(--muted-2);text-align:left;text-transform:uppercase;letter-spacing:.05em;padding:13px 16px;background:#fbfcfd;border-bottom:1px solid var(--line);font-weight:800;white-space:nowrap}
.table th.right{text-align:right}
.table th.center{text-align:center}
.table td{padding:14px 16px;border-bottom:1px solid var(--line);vertical-align:middle}
.table tr:last-child td{border-bottom:0}
.table tr.click{cursor:pointer;transition:background .12s}
.table tr.click:hover{background:#fffdf4}
.client-name{display:flex;align-items:center;gap:11px}
.avc{width:36px;height:36px;border-radius:10px;display:grid;place-items:center;font-weight:900;font-size:13px;background:var(--brand-bg);color:var(--brand-d);flex:none}
.cn b{font-weight:800;display:block}
.cn span{font-size:12px;color:var(--muted)}

/* ---------------- PILLS / TAGS ---------------- */
.pill{display:inline-flex;align-items:center;gap:7px;height:26px;padding:0 11px;border-radius:8px;font-size:12px;font-weight:800}
.pill:before{content:"";width:8px;height:8px;border-radius:50%;background:currentColor}
.pill.green{background:var(--green-bg);color:var(--green-tx)}
.pill.yellow{background:var(--yellow-bg);color:var(--yellow-tx)}
.pill.blue{background:var(--blue-bg);color:var(--blue-tx)}
.pill.red{background:var(--red-bg);color:var(--red-tx)}
.pill.gray{background:#eef1f5;color:var(--muted)}

/* ---------------- HERO (ficha) ---------------- */
.hero{background:linear-gradient(135deg,#15161a,#1f2127);color:#fff;border-radius:18px;padding:24px 26px;box-shadow:var(--sh-lg);position:relative;overflow:hidden;margin-bottom:18px}
.hero:after{content:"";position:absolute;right:-50px;top:-60px;width:260px;height:260px;border-radius:50%;background:radial-gradient(circle,rgba(244,180,0,.2),transparent 68%)}
.hero:before{content:"";position:absolute;inset:0;opacity:.4;background-image:linear-gradient(rgba(255,255,255,.03) 1px,transparent 1px);background-size:100% 30px}
.hero-top{display:flex;gap:18px;align-items:center;position:relative;z-index:1;flex-wrap:wrap}
.hero .av{width:66px;height:66px;border-radius:17px;background:linear-gradient(180deg,#2b2d35,#202229);color:var(--brand);display:grid;place-items:center;font-size:26px;font-weight:900;flex:none;border:1px solid rgba(255,255,255,.08)}
.hero h2{font-size:25px;font-weight:900}
.hero-meta{display:flex;gap:14px;flex-wrap:wrap;color:#aeb4bf;font-size:13.5px;margin-top:7px;align-items:center}
.hero-meta .mono{color:var(--brand);font-weight:700}
.hero-selo{display:inline-flex;align-items:center;gap:6px;margin-top:11px;background:rgba(244,180,0,.13);border:1px solid rgba(244,180,0,.32);color:var(--brand);padding:5px 11px;border-radius:999px;font-size:12px;font-weight:800}
.hero-actions{margin-left:auto;display:flex;gap:10px;position:relative;z-index:1;flex-wrap:wrap}
.hero-actions .btn{background:#fff;color:var(--ink);border-color:transparent}
.hero-actions .btn.wpp{background:#25d366;color:#fff}
.hero-actions .btn.brand{background:linear-gradient(180deg,var(--brand-1),var(--brand));color:#241c00}
.hero-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;margin-top:20px;position:relative;z-index:1;background:rgba(255,255,255,.09);border:1px solid rgba(255,255,255,.1);border-radius:14px;overflow:hidden}
.hero-stat{padding:13px 16px;background:linear-gradient(180deg,rgba(255,255,255,.03),rgba(255,255,255,0))}
.hero-stat span{display:block;color:#8b92a0;font-size:10.5px;font-weight:800;text-transform:uppercase;letter-spacing:.05em}
.hero-stat b{display:block;font-size:17px;font-weight:800;margin-top:5px;color:#fff;font-family:var(--mono)}
.hero-stat b.y{color:var(--brand)}

/* dados cadastrais — linhas horizontais contínuas (sem divisória vertical quebrada) */
.info-grid{display:grid;grid-template-columns:1fr 1fr;border:1px solid var(--line);border-radius:13px;overflow:hidden;background:#fff}
.info-item{display:flex;flex-direction:column;gap:5px;padding:15px 18px;border-bottom:1px solid var(--line);min-width:0}
.info-item.full{grid-column:1/-1}
.info-grid .info-item:last-child,.info-grid .info-item:nth-last-child(2):not(.full){border-bottom:0}
.info-item dt{font-size:10px;font-weight:800;color:var(--muted-2);text-transform:uppercase;letter-spacing:.06em}
.info-item dd{margin:0;font-weight:600;font-size:14px;color:var(--ink);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.info-item.full dd{white-space:normal}

/* documentos — lista refinada */
.doclist{display:flex;flex-direction:column;gap:12px}
.doc{display:flex;align-items:center;gap:14px;padding:15px 16px;border:1px solid var(--line);border-radius:14px;background:#fbfcfd;transition:transform .12s,box-shadow .15s,border-color .15s,background .15s}
.doc:hover{background:#fff;border-color:var(--line-2);box-shadow:var(--sh-sm);transform:translateY(-1px)}
.doc .di{width:46px;height:46px;border-radius:12px;display:grid;place-items:center;background:#eef1f5;color:var(--muted);flex:none}
.doc .di i{font-size:25px}
.doc.pdf .di{background:var(--red-bg);color:var(--red-tx)}
.doc.img .di{background:var(--blue-bg);color:var(--blue-tx)}
.doc .info{flex:1;min-width:0}
.doc .info b{display:block;font-size:14px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.doc .info small{color:var(--muted);display:block;margin-top:3px}
.doc .dl{width:40px;height:40px;border-radius:11px;border:1px solid var(--line-2);background:#fff;display:grid;place-items:center;color:var(--muted);flex:none;transition:.15s}
.doc .dl i{font-size:20px}
.doc .dl:hover{border-color:var(--ink);color:var(--ink);box-shadow:var(--sh-xs)}
.doc-add{display:flex;align-items:center;justify-content:center;gap:8px;height:52px;border:1.5px dashed var(--line-2);border-radius:14px;color:var(--muted);font-weight:700;font-size:13px;background:transparent;width:100%;transition:.15s;margin-top:2px}
.doc-add:hover{border-color:var(--brand);color:var(--brand-d);background:var(--brand-bg)}

/* busca de produto (wizard) */
.prod-sug{margin-top:10px;border:1px solid var(--line);border-radius:13px;overflow:hidden;display:none}
.prod-sug.show{display:block}
.prod-sug .ps{display:grid;grid-template-columns:auto 1fr auto auto;gap:12px;align-items:center;padding:12px 14px;border-bottom:1px solid var(--line);cursor:pointer;transition:background .12s}
.prod-sug .ps:last-child{border-bottom:0}
.prod-sug .ps:hover{background:#fffdf4}
.prod-sug .pcod{font-family:var(--mono);font-size:11px;font-weight:700;color:var(--muted);background:#f0f2f5;padding:3px 8px;border-radius:7px}
.prod-sug .pnome{font-weight:700;font-size:13.5px;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.prod-sug .pest{font-size:11.5px;font-weight:700}
.prod-sug .padd{width:32px;height:32px;border-radius:9px;background:var(--brand-bg);color:var(--brand-d);display:grid;place-items:center}

/* estoque pill */
.stk{display:inline-flex;align-items:center;gap:5px;font-size:12px;font-weight:800}
.stk.ok{color:var(--green-tx)}.stk.low{color:var(--yellow-tx)}.stk.no{color:var(--red-tx)}

/* campo de data premium + chips */
.date-field{position:relative}
.date-field i{position:absolute;left:13px;top:50%;transform:translateY(-50%);font-size:20px;color:var(--muted-2);pointer-events:none}
.date-field input{padding-left:42px;font-family:var(--mono);font-weight:600;letter-spacing:.02em}
.chips{display:flex;gap:8px;margin-top:9px;flex-wrap:wrap}
.chips button{height:32px;padding:0 14px;border-radius:999px;border:1px solid var(--line-2);background:#fff;font-weight:700;font-size:12.5px;color:var(--ink-soft);cursor:pointer;transition:.15s}
.chips button:hover{border-color:var(--brand);background:var(--brand-bg);color:var(--brand-d)}

/* ---------------- WIZARD ---------------- */
.steps{display:flex;gap:10px;margin-bottom:20px;flex-wrap:wrap}
.step{flex:1;min-width:120px;display:flex;align-items:center;gap:11px;padding:14px;border:1px solid var(--line);border-radius:13px;background:#fff;box-shadow:var(--sh-xs);transition:border-color .15s}
.step .n{width:30px;height:30px;border-radius:50%;background:#eef1f5;color:var(--muted);display:grid;place-items:center;font-weight:900;flex:none;transition:background .15s,color .15s}
.step .t{font-weight:700;font-size:13.5px}
.step.on{border-color:var(--brand);box-shadow:0 0 0 3px rgba(244,180,0,.12)}
.step.on .n{background:linear-gradient(180deg,var(--brand-1),var(--brand));color:#241c00}
.step.done .n{background:var(--green);color:#fff}
.wstep{display:none}.wstep.on{display:block;animation:fade .2s ease}
.wfoot{display:flex;justify-content:space-between;gap:12px;margin-top:22px}
.item-row{display:grid;grid-template-columns:80px 1fr 130px 130px 40px;gap:10px;align-items:end;margin-bottom:10px}
.item-row .del{height:44px;border-radius:11px;padding:0;width:44px;justify-content:center}
.total-box{display:flex;justify-content:space-between;align-items:center;background:linear-gradient(135deg,#15161a,#1f2127);color:#fff;border-radius:15px;padding:18px 24px;margin-top:14px;box-shadow:var(--sh-md);position:relative;overflow:hidden}
.total-box:after{content:"";position:absolute;right:-30px;top:-40px;width:160px;height:160px;border-radius:50%;background:radial-gradient(circle,rgba(244,180,0,.18),transparent 70%)}
.total-box .l{color:#aeb4bf;font-weight:700;text-transform:uppercase;font-size:13px;letter-spacing:.04em}
.total-box .v{font:900 32px var(--mono);color:var(--brand);position:relative;z-index:1}
.done{text-align:center;padding:34px 20px}
.done .ck{width:88px;height:88px;border-radius:50%;background:var(--green-bg);color:var(--green-tx);display:grid;place-items:center;margin:0 auto 16px;animation:pop .35s ease}
@keyframes pop{0%{transform:scale(.6);opacity:0}60%{transform:scale(1.08)}100%{transform:scale(1);opacity:1}}
.done .ck i{font-size:50px}
.done h2{font-size:26px;font-weight:900}
.done .acts{display:flex;gap:12px;justify-content:center;margin-top:24px;flex-wrap:wrap}

/* helper / empty */
.helper{background:var(--blue-bg);color:var(--blue-tx);border-radius:12px;padding:13px 15px;font-weight:600;font-size:13.5px;display:flex;gap:9px;align-items:center}
.helper i{font-size:20px}
.empty{padding:52px 20px;text-align:center;color:var(--muted)}
.empty .ei{width:76px;height:76px;border-radius:20px;background:var(--brand-bg);color:var(--brand-d);display:grid;place-items:center;margin:0 auto 16px;box-shadow:var(--sh-xs)}
.empty .ei i{font-size:40px}
.empty h2{font-size:20px;font-weight:800;color:var(--ink)}

/* toast */
.toast-wrap{position:fixed;right:20px;top:20px;display:grid;gap:10px;z-index:80}
.toast{display:flex;align-items:center;gap:10px;background:var(--ink);color:#fff;padding:13px 18px;border-radius:13px;box-shadow:var(--sh-lg);font-weight:700;min-width:260px;animation:slidein .25s ease}
@keyframes slidein{from{opacity:0;transform:translateX(20px)}to{opacity:1;transform:none}}
.toast i{font-size:20px}
.toast.ok{border-left:4px solid var(--green)}
.toast.err{border-left:4px solid var(--red)}

/* ---------------- FINANCEIRO ---------------- */
.fin3{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-bottom:4px}
.fin-box{border:1px solid var(--line);border-radius:12px;padding:14px 16px;background:#fbfcfd}
.fin-box span{display:block;font-size:10.5px;font-weight:800;text-transform:uppercase;letter-spacing:.05em;color:var(--muted-2)}
.fin-box b{display:block;font:700 22px var(--mono);margin-top:5px;color:var(--ink)}
.fin-box.red b{color:var(--red-tx)}
.fin-box.green b{color:var(--green-tx)}
.fin-box.yellow b{color:var(--yellow-tx)}
.hero-alert{display:inline-flex;align-items:center;gap:7px;margin-top:11px;margin-left:8px;padding:5px 12px;border-radius:999px;font-size:12px;font-weight:800}
.hero-alert.ok{background:rgba(14,159,87,.16);border:1px solid rgba(14,159,87,.4);color:#7ee2af}
.hero-alert.bad{background:rgba(226,58,58,.18);border:1px solid rgba(226,58,58,.45);color:#ffb4b4}

/* ---------------- MODAL ---------------- */
.modal-bg{position:fixed;inset:0;background:rgba(13,16,22,.55);backdrop-filter:blur(3px);display:none;place-items:center;z-index:60;padding:20px}
.modal-bg.open{display:grid;animation:fade .15s ease}
.modal{background:#fff;border-radius:18px;box-shadow:var(--sh-lg);width:min(540px,100%);max-height:90vh;overflow:auto;animation:pop .2s ease}
.modal-h{display:flex;align-items:center;justify-content:space-between;padding:20px 22px;border-bottom:1px solid var(--line)}
.modal-h h3{font-size:18px;font-weight:900;display:flex;align-items:center;gap:9px}
.modal-h h3 i{font-size:22px;color:var(--brand-d)}
.modal-h .x{width:34px;height:34px;border-radius:10px;border:1px solid var(--line-2);background:#fff;display:grid;place-items:center;color:var(--muted);cursor:pointer;transition:.15s}
.modal-h .x:hover{color:var(--ink);border-color:var(--ink)}
.modal-b{padding:22px}
.modal-f{display:flex;justify-content:flex-end;gap:10px;padding:16px 22px;border-top:1px solid var(--line);background:#fbfcfd}
.cnpj-row{display:flex;gap:8px;align-items:stretch}
.cnpj-row input{flex:1;min-width:0}
.cnpj-row .btn{flex:none;background:#fff;border-color:var(--line-2);color:var(--muted);font-weight:700;box-shadow:none;padding:0 13px}
.cnpj-row .btn i{font-size:17px;color:var(--muted)}
.cnpj-row .btn:hover{border-color:var(--brand);background:var(--brand-bg);color:var(--brand-d)}
.cnpj-row .btn:hover i{color:var(--brand-d)}
.spin{animation:spin .9s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}

/* ---------------- RESPONSIVO ---------------- */
@media(max-width:980px){
  .shell{grid-template-columns:1fr}
  .side{position:fixed;left:-248px;width:240px;z-index:40;transition:left .22s;box-shadow:var(--sh-lg)}
  .side.open{left:0}
  .menu-toggle{display:inline-grid;place-items:center;width:42px;height:42px;border-radius:11px;border:1px solid var(--line-2);background:#fff;box-shadow:var(--sh-xs)}
  .top-date{display:none}
  .grid2,.quick,.dl,.form2{grid-template-columns:1fr}
  .form3{grid-template-columns:1fr 1fr}
  .empresa-grid{grid-template-columns:1fr}
  .fin3{grid-template-columns:1fr}
  .info-grid{grid-template-columns:1fr}
  .info-grid .info-item{border-right:0}
  .info-grid .info-item:nth-last-child(2):not(.full){border-bottom:1px solid var(--line)}
  .hero-stats{grid-template-columns:1fr 1fr}
  .item-row{grid-template-columns:1fr 1fr}
}
