/* =================================================================
   INTELVORA CRM — JARVIS EDITION
   Tema: hacker / dinheiro / Jarvis / cyberpunk profissional
   ================================================================= */

@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800;900&family=JetBrains+Mono:wght@400;500;600;700&family=Orbitron:wght@500;600;700;800;900&display=swap');

:root{
  --bg-0:#02050d;
  --bg-1:#050a18;
  --bg-2:#070d22;
  --panel:rgba(10,18,38,.72);
  --panel-solid:#0a1226;
  --card:rgba(14,24,52,.55);
  --card-hover:rgba(20,34,72,.72);
  --line:rgba(0,229,255,.12);
  --line-soft:rgba(255,255,255,.06);
  --line-strong:rgba(0,229,255,.32);

  --brand:#00e5ff;
  --brand-2:#7c3aed;
  --brand-3:#22d3ee;
  --money:#10f5a0;
  --gold:#ffd700;
  --danger:#ff3d6e;
  --warn:#ffb547;

  --text:#e6f1ff;
  --text-soft:#a9bdd9;
  --muted:#7689a8;

  --glow-brand:0 0 24px rgba(0,229,255,.45), 0 0 60px rgba(0,229,255,.15);
  --glow-money:0 0 24px rgba(16,245,160,.4), 0 0 60px rgba(16,245,160,.15);
  --glow-purple:0 0 24px rgba(124,58,237,.45), 0 0 60px rgba(124,58,237,.15);
  --glow-danger:0 0 18px rgba(255,61,110,.4);

  --r-sm:10px;
  --r-md:14px;
  --r-lg:20px;
  --r-xl:28px;

  --font-display:'Orbitron','Inter',system-ui,sans-serif;
  --font-body:'Inter',system-ui,Segoe UI,Arial,sans-serif;
  --font-mono:'JetBrains Mono',ui-monospace,SFMono-Regular,Menlo,monospace;
}

*{box-sizing:border-box}
*::-webkit-scrollbar{width:10px;height:10px}
*::-webkit-scrollbar-track{background:transparent}
*::-webkit-scrollbar-thumb{background:linear-gradient(180deg,rgba(0,229,255,.25),rgba(124,58,237,.25));border-radius:99px}
*::-webkit-scrollbar-thumb:hover{background:linear-gradient(180deg,rgba(0,229,255,.55),rgba(124,58,237,.55))}

html,body{height:100%}
body{
  margin:0;
  font-family:var(--font-body);
  color:var(--text);
  background:var(--bg-0);
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
  line-height:1.5;
  position:relative;
}

/* ========== BACKGROUND ========== */
body::before{
  content:'';
  position:fixed;inset:0;
  background:
    radial-gradient(ellipse 80% 60% at 15% 10%, rgba(0,229,255,.18), transparent 50%),
    radial-gradient(ellipse 70% 50% at 85% 90%, rgba(124,58,237,.22), transparent 55%),
    radial-gradient(ellipse 40% 30% at 50% 50%, rgba(16,245,160,.06), transparent 60%),
    linear-gradient(180deg, var(--bg-0) 0%, var(--bg-1) 60%, var(--bg-0) 100%);
  z-index:-3;
  pointer-events:none;
}
body::after{
  content:'';
  position:fixed;inset:0;
  background-image:
    linear-gradient(rgba(0,229,255,.04) 1px, transparent 1px),
    linear-gradient(90deg, rgba(0,229,255,.04) 1px, transparent 1px);
  background-size:48px 48px;
  background-position:-1px -1px;
  z-index:-2;
  pointer-events:none;
  mask-image:radial-gradient(ellipse 80% 80% at 50% 50%, #000 30%, transparent 80%);
  -webkit-mask-image:radial-gradient(ellipse 80% 80% at 50% 50%, #000 30%, transparent 80%);
}

#bgCanvas{position:fixed;inset:0;z-index:-1;opacity:.35;pointer-events:none}

/* ========== TYPOGRAPHY ========== */
h1,h2,h3,h4{margin:0;font-weight:700;letter-spacing:.01em;color:var(--text)}
h1{font-size:28px;font-family:var(--font-display);letter-spacing:.06em}
h2{font-size:24px;font-family:var(--font-display);letter-spacing:.04em}
h3{font-size:16px;letter-spacing:.02em}
p{margin:0;color:var(--text-soft)}
a{color:var(--brand);text-decoration:none}
a:hover{text-shadow:0 0 12px rgba(0,229,255,.6)}
code,pre{font-family:var(--font-mono)}

/* ========== BUTTONS ========== */
button,.btn{
  position:relative;
  border:1px solid var(--line);
  background:linear-gradient(180deg,rgba(255,255,255,.04),rgba(255,255,255,.01));
  color:var(--text);
  padding:10px 16px;
  border-radius:var(--r-md);
  cursor:pointer;
  text-decoration:none;
  display:inline-flex;
  gap:8px;
  align-items:center;
  justify-content:center;
  font-weight:600;
  font-size:13.5px;
  letter-spacing:.01em;
  transition:all .22s cubic-bezier(.4,0,.2,1);
  font-family:var(--font-body);
  white-space:nowrap;
  user-select:none;
}
button:hover,.btn:hover{
  border-color:var(--brand);
  background:linear-gradient(180deg,rgba(0,229,255,.08),rgba(0,229,255,.02));
  box-shadow:var(--glow-brand);
  transform:translateY(-1px);
}
button:active,.btn:active{transform:translateY(0)}

button.primary,.primary{
  background:linear-gradient(135deg, var(--brand) 0%, var(--brand-2) 100%);
  border:0;
  color:#021018;
  font-weight:800;
  box-shadow:0 8px 24px rgba(0,229,255,.25), 0 0 0 1px rgba(255,255,255,.1) inset;
  text-shadow:0 1px 0 rgba(255,255,255,.2);
}
button.primary:hover,.primary:hover{
  box-shadow:0 12px 36px rgba(0,229,255,.45), 0 0 60px rgba(124,58,237,.3), 0 0 0 1px rgba(255,255,255,.15) inset;
  filter:brightness(1.1);
}
button.money{
  background:linear-gradient(135deg, var(--money) 0%, #0fbf80 100%);
  border:0;color:#021810;font-weight:800;
  box-shadow:0 8px 24px rgba(16,245,160,.3);
}
button.money:hover{box-shadow:var(--glow-money), 0 8px 32px rgba(16,245,160,.5)}
button.ghost{background:transparent;border-color:var(--line-soft)}
button.danger{border-color:rgba(255,61,110,.4);color:#ffb8c9}
button.danger:hover{background:rgba(255,61,110,.1);box-shadow:var(--glow-danger);border-color:var(--danger)}
button.icon{padding:9px 11px;font-size:14px}
.full{width:100%}

/* ========== FORMS ========== */
input,textarea,select{
  width:100%;
  border:1px solid var(--line);
  background:rgba(5,10,24,.7);
  color:var(--text);
  padding:11px 13px;
  border-radius:var(--r-md);
  outline:none;
  font-size:14px;
  font-family:var(--font-body);
  transition:all .2s;
}
input:focus,textarea:focus,select:focus{
  border-color:var(--brand);
  box-shadow:0 0 0 3px rgba(0,229,255,.12), 0 0 24px rgba(0,229,255,.18);
  background:rgba(5,10,24,.9);
}
input::placeholder,textarea::placeholder{color:var(--muted)}
textarea{min-height:96px;resize:vertical;font-family:var(--font-mono);font-size:13px;line-height:1.6}
label{display:block;margin:14px 0 6px;color:var(--text-soft);font-size:12px;font-weight:600;letter-spacing:.05em;text-transform:uppercase}
input[type="color"]{height:44px;padding:4px;cursor:pointer}
input[type="date"],input[type="datetime-local"]{color-scheme:dark}

.hidden{display:none!important}

/* ========== LOGIN ========== */
.login-screen{
  min-height:100vh;
  display:grid;
  place-items:center;
  padding:24px;
  position:relative;
}
.login-screen::before{
  content:'';
  position:absolute;
  width:600px;height:600px;
  background:radial-gradient(circle, rgba(0,229,255,.18), transparent 60%);
  filter:blur(40px);
  animation:pulse 6s ease-in-out infinite;
  pointer-events:none;
}
@keyframes pulse{
  0%,100%{transform:scale(1);opacity:.7}
  50%{transform:scale(1.15);opacity:1}
}
.login-card{
  position:relative;
  width:min(460px,100%);
  background:linear-gradient(180deg, rgba(10,18,38,.85), rgba(7,13,34,.85));
  border:1px solid var(--line);
  border-radius:var(--r-xl);
  padding:36px;
  box-shadow:
    0 30px 100px rgba(0,0,0,.55),
    0 0 80px rgba(0,229,255,.08),
    0 0 0 1px rgba(255,255,255,.03) inset;
  backdrop-filter:blur(20px) saturate(140%);
  -webkit-backdrop-filter:blur(20px) saturate(140%);
  z-index:2;
}
.login-card::before{
  content:'';
  position:absolute;inset:-1px;
  border-radius:inherit;
  padding:1px;
  background:linear-gradient(135deg, rgba(0,229,255,.5), rgba(124,58,237,.4), transparent 60%);
  -webkit-mask:linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
  -webkit-mask-composite:xor;
  mask-composite:exclude;
  pointer-events:none;
  opacity:.6;
}
.login-card.wide-card{width:min(820px,100%);padding:40px}

/* ========== LOGO ========== */
.logo{
  font-family:var(--font-display);
  font-weight:900;
  font-size:22px;
  letter-spacing:.14em;
  background:linear-gradient(135deg, var(--brand) 0%, var(--brand-2) 100%);
  -webkit-background-clip:text;
  background-clip:text;
  color:transparent;
  display:inline-block;
}
.logo small{
  display:block;
  margin-top:4px;
  font-family:var(--font-mono);
  font-size:10px;
  letter-spacing:.4em;
  color:var(--brand);
  -webkit-text-fill-color:var(--brand);
  font-weight:600;
  opacity:.85;
}
.logo.big{font-size:38px;line-height:1}
.logo.big small{font-size:11px;letter-spacing:.5em;margin-top:8px}
.brand-logo{max-height:36px;max-width:140px;object-fit:contain;margin-bottom:8px}

.brand-mark{display:inline-flex;align-items:center;gap:10px}
.brand-mark .dot{
  width:10px;height:10px;border-radius:50%;
  background:var(--brand);
  box-shadow:0 0 12px var(--brand), 0 0 24px var(--brand);
  animation:livePulse 1.6s ease-in-out infinite;
}
@keyframes livePulse{
  0%,100%{box-shadow:0 0 8px var(--brand), 0 0 16px var(--brand);transform:scale(1)}
  50%{box-shadow:0 0 18px var(--brand), 0 0 36px var(--brand);transform:scale(1.2)}
}

/* ========== APP LAYOUT ========== */
.app{display:grid;grid-template-columns:280px 1fr;min-height:100vh}

.sidebar{
  position:sticky;top:0;height:100vh;
  overflow-y:auto;overflow-x:hidden;
  border-right:1px solid var(--line);
  background:linear-gradient(180deg, rgba(4,8,20,.92), rgba(2,5,14,.96));
  backdrop-filter:blur(20px);
  -webkit-backdrop-filter:blur(20px);
  padding:22px 16px;
  z-index:5;
}
.sidebar .logo-row{padding:0 8px 18px;border-bottom:1px solid var(--line-soft);margin-bottom:18px}
.sidebar nav{display:flex;flex-direction:column;gap:3px}
.nav-section{
  padding:14px 12px 6px;
  font-size:10px;letter-spacing:.25em;
  color:var(--muted);text-transform:uppercase;
  font-weight:700;
  display:flex;align-items:center;gap:6px;
}
.nav-section::after{
  content:'';flex:1;height:1px;
  background:linear-gradient(90deg, var(--line-soft), transparent);
}

.nav{
  justify-content:flex-start;
  border-radius:var(--r-md);
  background:transparent;
  border:1px solid transparent;
  color:var(--text-soft);
  padding:10px 12px;
  font-weight:500;
  font-size:13.5px;
  text-align:left;
  width:100%;
  position:relative;
  transition:all .2s;
}
.nav .nav-icon{width:18px;text-align:center;font-size:14px;opacity:.7;transition:all .2s;display:inline-block}
.nav:hover{
  background:rgba(0,229,255,.05);
  color:var(--text);
  transform:none;
  box-shadow:none;
}
.nav:hover .nav-icon{opacity:1;color:var(--brand);text-shadow:0 0 8px rgba(0,229,255,.6)}
.nav.active{
  background:linear-gradient(90deg, rgba(0,229,255,.14), rgba(124,58,237,.08));
  border-color:rgba(0,229,255,.32);
  color:var(--text);
  box-shadow:0 0 24px rgba(0,229,255,.12) inset;
}
.nav.active::before{
  content:'';position:absolute;left:-16px;top:50%;
  width:3px;height:24px;
  background:linear-gradient(180deg, var(--brand), var(--brand-2));
  border-radius:0 4px 4px 0;
  transform:translateY(-50%);
  box-shadow:0 0 12px var(--brand);
}
.nav.active .nav-icon{opacity:1;color:var(--brand);text-shadow:0 0 12px rgba(0,229,255,.8)}

.sidebar-footer{
  margin-top:16px;
  padding:14px;border-top:1px solid var(--line-soft);
  display:flex;align-items:center;gap:10px;
}
.user-avatar{
  width:36px;height:36px;border-radius:50%;
  background:linear-gradient(135deg, var(--brand), var(--brand-2));
  display:grid;place-items:center;
  font-weight:700;color:#021018;font-size:14px;
  box-shadow:var(--glow-brand);
}
.user-info{flex:1;min-width:0}
.user-info b{display:block;font-size:13px;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.user-info span{font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:.1em}

/* ========== MAIN ========== */
.main{padding:24px 28px 40px;overflow-x:hidden;min-width:0}

.topbar{
  display:flex;justify-content:space-between;align-items:center;gap:16px;
  margin-bottom:24px;padding:0;
}
.topbar h2{margin:0;font-size:26px;font-family:var(--font-display);letter-spacing:.05em;display:flex;align-items:center}
.topbar h2::before{
  content:'';display:inline-block;width:4px;height:24px;
  background:linear-gradient(180deg, var(--brand), var(--brand-2));
  border-radius:2px;margin-right:12px;
  box-shadow:0 0 12px var(--brand);
}
.topbar p{margin:6px 0 0 16px;color:var(--text-soft);font-size:13px}
.top-actions{display:flex;gap:8px;flex-wrap:wrap}
.notif{position:relative;padding:9px 12px}
.notif span{
  position:absolute;top:-6px;right:-6px;
  background:var(--danger);color:white;border-radius:99px;
  padding:2px 6px;font-size:10px;font-weight:700;
  min-width:18px;text-align:center;
  box-shadow:var(--glow-danger);
}

.tab{display:none;animation:fadeUp .35s ease}
.tab.active{display:block}
@keyframes fadeUp{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}

/* ========== GRID / CARDS ========== */
.grid{display:grid;gap:18px}
.grid.two{grid-template-columns:repeat(2,minmax(0,1fr))}
.grid.three{grid-template-columns:repeat(3,minmax(0,1fr))}
.kpis{grid-template-columns:repeat(4,minmax(0,1fr));margin-bottom:18px}

.card,.module{
  position:relative;
  background:linear-gradient(180deg, rgba(14,24,52,.72), rgba(10,18,38,.6));
  border:1px solid var(--line);
  border-radius:var(--r-lg);
  padding:20px;
  margin-bottom:18px;
  backdrop-filter:blur(14px);
  -webkit-backdrop-filter:blur(14px);
  transition:border-color .2s, transform .2s;
}
.card:hover,.module:hover{border-color:var(--line-strong)}
.card::before,.module::before{
  content:'';position:absolute;inset:0;
  border-radius:inherit;
  background:linear-gradient(135deg, rgba(0,229,255,.06), transparent 40%);
  pointer-events:none;
}
.card>*,.module>*{position:relative}

.section-head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:14px;flex-wrap:wrap}
.section-head h3{margin:0;font-size:15px;font-weight:700}
.section-head .actions{display:flex;gap:6px;flex-wrap:wrap}
.section-head p.muted{margin-top:4px;font-size:12.5px}

/* ========== KPI ========== */
.kpi{
  position:relative;
  padding:18px 20px;
  background:linear-gradient(135deg, rgba(0,229,255,.08), rgba(124,58,237,.04));
  border:1px solid var(--line);
  border-radius:var(--r-lg);
  overflow:hidden;
  transition:all .25s;
}
.kpi:hover{
  border-color:var(--line-strong);
  transform:translateY(-2px);
  box-shadow:0 12px 32px rgba(0,0,0,.3), 0 0 32px rgba(0,229,255,.12);
}
.kpi::before{
  content:'';position:absolute;
  top:-40%;right:-20%;
  width:140px;height:140px;
  background:radial-gradient(circle, rgba(0,229,255,.15), transparent 70%);
  pointer-events:none;
}
.kpi span{
  display:block;color:var(--muted);
  font-size:11px;text-transform:uppercase;letter-spacing:.15em;
  font-weight:600;
}
.kpi b{
  display:block;
  font-size:30px;font-weight:800;
  font-family:var(--font-display);
  background:linear-gradient(135deg, var(--text) 0%, var(--brand) 100%);
  -webkit-background-clip:text;
  background-clip:text;
  color:transparent;
  margin:4px 0;
  letter-spacing:.02em;
}
.kpi small{display:block;color:var(--brand);margin-top:4px;font-size:11.5px;font-weight:500}
.kpi.money b{background:linear-gradient(135deg, var(--money), #58e8a4);-webkit-background-clip:text;background-clip:text;color:transparent}
.kpi.money small{color:var(--money)}
.kpi.purple b{background:linear-gradient(135deg, var(--brand-2), #b794ff);-webkit-background-clip:text;background-clip:text;color:transparent}
.kpi.purple small{color:#b794ff}

/* ========== TABLES ========== */
.table-wrap{
  overflow:auto;
  border:1px solid var(--line);
  border-radius:var(--r-md);
  background:rgba(5,10,24,.4);
}
table{width:100%;border-collapse:collapse;min-width:760px}
th,td{text-align:left;padding:12px 14px;border-bottom:1px solid var(--line-soft);vertical-align:top}
th{
  color:var(--brand);
  font-size:10.5px;text-transform:uppercase;letter-spacing:.12em;
  background:rgba(0,229,255,.04);
  font-weight:700;
  position:sticky;top:0;
  backdrop-filter:blur(8px);
}
td{font-size:13.5px;color:var(--text-soft)}
tr:hover td{background:rgba(0,229,255,.03);color:var(--text)}
tr:last-child td{border-bottom:0}
.actions{display:flex;gap:6px;flex-wrap:wrap}
.actions button{padding:6px 10px;font-size:12px;border-radius:8px}

/* ========== PILL ========== */
.pill{
  display:inline-flex;align-items:center;gap:5px;
  padding:4px 10px;border-radius:99px;
  background:rgba(0,229,255,.1);
  color:#c8f4ff;border:1px solid rgba(0,229,255,.3);
  font-size:11.5px;font-weight:600;letter-spacing:.02em;
}
.pill::before{
  content:'';width:6px;height:6px;border-radius:50%;
  background:currentColor;box-shadow:0 0 8px currentColor;
}
.pill.bad{background:rgba(255,61,110,.1);color:#ffb8c9;border-color:rgba(255,61,110,.32)}
.pill.ok{background:rgba(16,245,160,.1);color:#a4f5d3;border-color:rgba(16,245,160,.32)}
.pill.warn{background:rgba(255,181,71,.1);color:#ffdfa8;border-color:rgba(255,181,71,.32)}

.muted{color:var(--muted);font-size:13px}

/* ========== RESULT / TERMINAL ========== */
.result{
  white-space:pre-wrap;word-break:break-word;
  background:linear-gradient(180deg, #02070f, #04091a);
  border:1px solid var(--line);
  border-radius:var(--r-md);
  padding:14px 16px;
  color:#c8e5ff;
  min-height:48px;max-height:380px;overflow:auto;
  font-family:var(--font-mono);
  font-size:12.5px;line-height:1.6;
  margin-top:10px;
  position:relative;
}
.result::before{
  content:'> jetflix';
  display:block;
  font-size:10px;letter-spacing:.2em;
  color:var(--brand);opacity:.45;
  margin-bottom:8px;font-weight:600;
}
.result.compact{max-height:180px}
.result.tall{max-height:560px}
.msg{margin-top:12px;color:var(--warn);font-size:13px;font-weight:500}

/* ========== CHECKS / BARS ========== */
.checks{display:grid;gap:8px}
.check{
  display:flex;justify-content:space-between;gap:10px;align-items:center;
  padding:11px 14px;
  background:rgba(255,255,255,.025);
  border:1px solid var(--line-soft);
  border-radius:var(--r-md);
  transition:all .2s;
}
.check:hover{border-color:var(--line-strong);background:rgba(0,229,255,.04)}
.check b{font-size:13px;font-weight:600}
.check span.muted{font-size:11.5px}

.bar{margin:12px 0}
.bar label{display:flex;justify-content:space-between;margin-bottom:6px;font-size:12.5px;text-transform:none;letter-spacing:0;color:var(--text-soft)}
.bar label b{color:var(--text);font-weight:700}
.bar>div{
  height:10px;border-radius:99px;
  background:rgba(5,10,24,.8);
  overflow:hidden;
  border:1px solid var(--line-soft);
  position:relative;
}
.bar i{
  display:block;height:100%;
  background:linear-gradient(90deg, var(--brand), var(--brand-2), var(--money));
  background-size:200% 100%;
  border-radius:99px;
  box-shadow:0 0 12px rgba(0,229,255,.4);
  animation:shimmer 3s linear infinite;
  transition:width .5s cubic-bezier(.4,0,.2,1);
}
@keyframes shimmer{0%{background-position:0% 50%}100%{background-position:200% 50%}}

/* ========== MODAL ========== */
.modal{
  position:fixed;inset:0;
  background:rgba(2,5,14,.75);
  backdrop-filter:blur(8px);
  -webkit-backdrop-filter:blur(8px);
  display:grid;place-items:center;
  padding:18px;z-index:100;
  animation:fadeIn .2s ease;
}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
.modal-card{
  width:min(780px,96vw);max-height:90vh;overflow:auto;
  background:linear-gradient(180deg, rgba(14,24,52,.95), rgba(8,14,32,.95));
  border:1px solid var(--line-strong);
  border-radius:var(--r-xl);
  padding:24px;
  box-shadow:0 40px 120px rgba(0,0,0,.6), 0 0 100px rgba(0,229,255,.1);
  backdrop-filter:blur(20px);
  animation:modalUp .3s cubic-bezier(.34,1.56,.64,1);
}
@keyframes modalUp{from{opacity:0;transform:translateY(24px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}

.form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}
.form-grid .wide{grid-column:1/-1}
.form-grid label{margin-top:0}

/* ========== MISC ========== */
.manual{line-height:1.8;font-size:14px}
.manual ol{padding-left:22px}
.manual li{margin:8px 0;color:var(--text-soft)}
.manual code{background:rgba(0,229,255,.1);padding:2px 7px;border-radius:6px;color:var(--brand);font-size:12.5px;border:1px solid var(--line)}
.copy-row{display:flex;gap:8px}
.row-card{
  padding:14px 16px;
  border:1px solid var(--line-soft);
  border-radius:var(--r-md);
  margin:10px 0;
  background:rgba(255,255,255,.025);
  font-size:13.5px;
  transition:all .2s;
}
.row-card:hover{border-color:var(--line);background:rgba(0,229,255,.04)}
.row-card b{color:var(--text);font-weight:600}

/* ========== TOAST ========== */
.toast-wrap{
  position:fixed;right:20px;bottom:20px;z-index:9999;
  display:grid;gap:10px;max-width:380px;
}
.toast{
  padding:13px 16px;
  background:linear-gradient(180deg, rgba(10,18,38,.95), rgba(7,13,34,.95));
  border:1px solid var(--brand);
  border-radius:var(--r-md);
  box-shadow:0 12px 40px rgba(0,0,0,.5), 0 0 32px rgba(0,229,255,.18);
  backdrop-filter:blur(14px);
  color:var(--text);
  font-size:13.5px;
  animation:slideIn .35s cubic-bezier(.34,1.56,.64,1);
  display:flex;gap:10px;align-items:center;
}
.toast::before{
  content:'';width:8px;height:8px;border-radius:50%;
  background:var(--brand);
  box-shadow:0 0 12px currentColor;
  flex:none;
}
.toast.bad{border-color:var(--danger)}
.toast.bad::before{background:var(--danger)}
.toast.ok::before{background:var(--money);color:var(--money)}
@keyframes slideIn{from{opacity:0;transform:translateX(40px)}to{opacity:1;transform:translateX(0)}}

/* ========== PLANS ========== */
.wide-card{width:min(980px,100%)}
.plans-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px;margin:20px 0}
.plan-card{
  position:relative;
  display:flex;flex-direction:column;align-items:flex-start;text-align:left;
  gap:8px;min-height:200px;padding:20px;
  background:linear-gradient(180deg, rgba(14,24,52,.6), rgba(8,14,32,.6));
  border:1px solid var(--line);border-radius:var(--r-lg);
  cursor:pointer;transition:all .25s;
  font-family:var(--font-body);
}
.plan-card:hover{border-color:var(--line-strong);transform:translateY(-3px);box-shadow:0 16px 48px rgba(0,229,255,.12)}
.plan-card b{font-size:14px;font-weight:700;color:var(--text);letter-spacing:.05em;text-transform:uppercase}
.plan-card strong{
  font-size:32px;font-family:var(--font-display);font-weight:800;
  background:linear-gradient(135deg, var(--brand), var(--money));
  -webkit-background-clip:text;background-clip:text;color:transparent;
}
.plan-card small{color:var(--muted);font-size:11px;text-transform:uppercase;letter-spacing:.15em}
.plan-card span{color:var(--text-soft);font-weight:500;font-size:13px;line-height:1.5}
.plan-card em{color:var(--muted);font-size:11.5px;font-style:normal;margin-top:auto}
.plan-card.active{
  border-color:var(--brand);
  box-shadow:0 0 0 2px rgba(0,229,255,.25), var(--glow-brand);
  background:linear-gradient(180deg, rgba(0,229,255,.08), rgba(124,58,237,.04));
}
.plan-card.active::after{
  content:'✓ Selecionado';position:absolute;top:12px;right:12px;
  font-size:10.5px;color:var(--brand);font-weight:700;letter-spacing:.1em;text-transform:uppercase;
}

/* ========== FILTERS / QR ========== */
.filters{display:grid;grid-template-columns:2fr 1fr 1fr 1fr auto auto;gap:8px;margin:14px 0}
.qr-box{margin-top:14px;display:grid;place-items:center}
.qr-box img{
  max-width:240px;width:100%;
  border:8px solid #fff;border-radius:18px;background:#fff;
  box-shadow:0 12px 40px rgba(0,229,255,.25), 0 0 60px rgba(0,229,255,.15);
}

/* ========== MOBILE ========== */
.mobile-menu{display:none;padding:9px 11px;font-size:18px}

@media (max-width:1100px){
  .kpis{grid-template-columns:repeat(2,minmax(0,1fr))}
}
@media (max-width:900px){
  .grid.two,.grid.three{grid-template-columns:1fr}
  .plans-grid{grid-template-columns:1fr}
}
@media (max-width:980px){
  .mobile-menu{display:inline-flex}
  .app{display:block}
  .sidebar{
    position:fixed;z-index:100;left:-300px;top:0;
    width:280px;height:100vh;
    transition:left .3s cubic-bezier(.4,0,.2,1);
    box-shadow:30px 0 80px rgba(0,0,0,.5);
  }
  body.sidebar-open .sidebar{left:0}
  body.sidebar-open::after{content:'';position:fixed;inset:0;background:rgba(0,0,0,.6);z-index:99;backdrop-filter:blur(4px)}
  .main{padding:16px}
  .filters{grid-template-columns:1fr 1fr}
  .topbar{align-items:flex-start;flex-direction:column;gap:12px}
  .top-actions{width:100%}
  .topbar{
    position:sticky;top:0;z-index:50;
    background:rgba(2,5,14,.92);backdrop-filter:blur(14px);
    border-bottom:1px solid var(--line);
    margin:-16px -16px 18px;padding:14px 16px;
  }
}
@media (max-width:640px){
  .filters{grid-template-columns:1fr}
  .kpi b{font-size:24px}
  .top-actions>*{flex:1;justify-content:center}
  .modal-card{width:100vw;height:100vh;max-height:100vh;border-radius:0;border-left:0;border-right:0}
  .form-grid{grid-template-columns:1fr}
  table{font-size:12.5px;min-width:560px}
  th,td{padding:10px}
}

/* ========== JARVIS SPECIAL ========== */
.jarvis-shell{
  background:linear-gradient(180deg, #010410, #02061a);
  border:1px solid var(--brand);
  border-radius:var(--r-lg);
  padding:18px;
  font-family:var(--font-mono);
  position:relative;
  box-shadow:0 0 32px rgba(0,229,255,.15), 0 0 0 1px rgba(0,229,255,.08) inset;
}
.jarvis-shell::before{
  content:'● ● ●';position:absolute;top:10px;left:14px;
  font-size:10px;letter-spacing:6px;color:var(--brand);opacity:.5;
}
.jarvis-shell .jarvis-title{
  margin:0 0 14px 60px;font-size:11px;letter-spacing:.3em;color:var(--brand);
  text-transform:uppercase;font-weight:700;font-family:var(--font-mono);
}
.jarvis-shell textarea{
  background:#000a16;border:1px solid var(--line);
  color:#a4f5d3;font-family:var(--font-mono);font-size:13px;
  caret-color:var(--brand);
}
.jarvis-shell textarea::placeholder{color:rgba(16,245,160,.4)}

/* status strip */
.status-strip{
  display:flex;align-items:center;gap:14px;flex-wrap:wrap;
  padding:14px 18px;margin-bottom:18px;
  background:linear-gradient(90deg, rgba(0,229,255,.06), rgba(124,58,237,.04), transparent);
  border:1px solid var(--line);border-radius:var(--r-md);
  font-size:12.5px;
}
.status-strip .status-dot{display:flex;align-items:center;gap:7px;color:var(--text-soft)}
.status-strip .status-dot::before{
  content:'';width:8px;height:8px;border-radius:50%;
  background:var(--money);box-shadow:0 0 10px var(--money);
  animation:livePulse 1.8s ease-in-out infinite;
}
.status-strip code{
  background:rgba(0,229,255,.08);padding:2px 8px;border-radius:6px;
  color:var(--brand);font-size:11.5px;border:1px solid var(--line);
}
.status-strip .clock{margin-left:auto;color:var(--brand);font-family:var(--font-mono);font-weight:600}

.divider{
  height:1px;
  background:linear-gradient(90deg, transparent, var(--line-strong), transparent);
  margin:18px 0;
}

.callout{
  display:flex;gap:14px;align-items:center;
  padding:14px 16px;
  background:linear-gradient(90deg, rgba(0,229,255,.08), rgba(124,58,237,.04));
  border:1px solid var(--line);border-radius:var(--r-md);
  margin:10px 0;
}
.callout .ico{font-size:22px;color:var(--brand);text-shadow:0 0 12px rgba(0,229,255,.6)}
.callout b{display:block;color:var(--text);font-size:13.5px}
.callout small{color:var(--muted);font-size:12px}

.hero-actions{display:flex;gap:10px;justify-content:center;flex-wrap:wrap;margin-top:18px}

.skeleton{
  background:linear-gradient(90deg, rgba(255,255,255,.02), rgba(0,229,255,.06), rgba(255,255,255,.02));
  background-size:200% 100%;
  border-radius:var(--r-md);
  animation:skeleton 1.5s ease infinite;
}
@keyframes skeleton{0%{background-position:0% 50%}100%{background-position:-200% 50%}}

button:focus-visible,.btn:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible{
  outline:2px solid var(--brand);outline-offset:2px;
}

html{scroll-behavior:smooth}

/* HUD ring decoration for login */
.hud-ring{
  position:absolute;pointer-events:none;
  width:520px;height:520px;border-radius:50%;
  border:1px dashed rgba(0,229,255,.18);
  animation:rotate 60s linear infinite;
}
.hud-ring.inner{width:380px;height:380px;border-style:solid;border-color:rgba(124,58,237,.12);animation-duration:40s;animation-direction:reverse}
@keyframes rotate{to{transform:rotate(360deg)}}

/* ========================================================================
   V1 JARVIS — Brand mark, HUD wrappers, divider, footer (auth pages)
   ======================================================================== */

.hud-rings{
  position:absolute; inset:0; pointer-events:none; z-index:0;
  display:flex; align-items:center; justify-content:center;
}
.hud-rings span{
  position:absolute; border-radius:50%; border:1px dashed rgba(0,229,255,.18);
  animation:rotate 60s linear infinite;
}
.hud-rings span:nth-child(1){ width:560px; height:560px; }
.hud-rings span:nth-child(2){ width:400px; height:400px; border-style:solid; border-color:rgba(124,58,237,.14); animation-duration:42s; animation-direction:reverse; }
.hud-rings span:nth-child(3){ width:240px; height:240px; border-color:rgba(16,245,160,.18); animation-duration:32s; }
@media (max-width:560px){
  .hud-rings span:nth-child(1){ width:380px; height:380px; }
  .hud-rings span:nth-child(2){ width:280px; height:280px; }
  .hud-rings span:nth-child(3){ width:170px; height:170px; }
}

.brand-mark{
  position:relative; z-index:2;
  display:flex; flex-direction:column; align-items:center; gap:8px;
  margin-bottom:14px;
}
.brand-logo{
  font-family:var(--font-display);
  font-weight:900; font-size:30px; letter-spacing:.5px;
  color:var(--text);
  display:inline-flex; align-items:center; gap:10px;
  text-transform:uppercase;
}
.brand-logo em{
  font-style:normal; font-weight:800; font-size:18px;
  padding:3px 10px; border-radius:6px;
  background:linear-gradient(135deg, var(--brand), var(--brand-2));
  color:#001018; letter-spacing:2px;
  box-shadow:0 0 18px rgba(0,229,255,.45);
}
.brand-dot{
  width:11px; height:11px; border-radius:50%;
  background:var(--money);
  box-shadow:0 0 0 4px rgba(16,245,160,.18), 0 0 14px rgba(16,245,160,.7);
  animation:livePulse 1.8s ease-in-out infinite;
}
.brand-tag{
  font-family:var(--font-mono);
  font-size:11px; letter-spacing:2.4px;
  color:var(--muted);
  padding:4px 10px; border-radius:999px;
  border:1px solid var(--line);
  background:rgba(0,229,255,.04);
}

.login-title{
  position:relative; z-index:2;
  text-align:center;
  font-family:var(--font-display);
  font-size:24px; font-weight:800;
  margin:6px 0 6px;
  background:linear-gradient(90deg, var(--text), var(--brand));
  -webkit-background-clip:text; background-clip:text; color:transparent;
}
.login-sub{
  position:relative; z-index:2;
  text-align:center; color:var(--muted);
  font-size:13.5px; margin:0 0 18px;
}
.login-divider{
  position:relative; z-index:2;
  text-align:center; margin:18px 0 12px;
  display:flex; align-items:center; gap:10px; color:var(--muted); font-size:11px;
  letter-spacing:2px; text-transform:uppercase;
}
.login-divider::before, .login-divider::after{
  content:""; flex:1; height:1px;
  background:linear-gradient(90deg, transparent, var(--line-strong), transparent);
}
.login-foot{
  position:relative; z-index:2;
  text-align:center; color:var(--muted);
  font-size:11px; letter-spacing:1.4px; text-transform:uppercase;
  margin-top:16px;
}
.signup-status{ justify-content:center; margin:0 0 18px; }
.code-tag{
  font-family:var(--font-mono); font-size:10.5px; letter-spacing:1.5px;
  padding:3px 9px; border-radius:999px;
  border:1px solid var(--line); color:var(--muted);
  background:rgba(0,229,255,.04);
}
.code-tag.accent{ color:var(--brand); border-color:rgba(0,229,255,.35); }
.code-tag.green{ color:var(--money); border-color:rgba(16,245,160,.35); background:rgba(16,245,160,.06); }

/* ========================================================================
   LANDING PAGE
   ======================================================================== */
body.landing{ background:var(--bg); color:var(--text); }
body.landing #bgCanvas{ position:fixed; inset:0; z-index:0; pointer-events:none; opacity:.7; }

.land-nav{
  position:sticky; top:0; z-index:50;
  backdrop-filter:blur(14px);
  background:rgba(7,11,18,.65);
  border-bottom:1px solid var(--line);
}
.land-nav-inner{
  max-width:1240px; margin:auto;
  padding:14px 22px;
  display:flex; align-items:center; justify-content:space-between; gap:18px;
}
.land-nav .brand-logo{ font-size:22px; }
.land-nav .brand-logo em{ font-size:13px; padding:2px 8px; }
.land-links{ display:flex; align-items:center; gap:20px; }
.land-links a{
  color:var(--muted); text-decoration:none; font-size:13.5px; font-weight:500;
  transition:color .2s;
}
.land-links a:hover{ color:var(--brand); }
.land-links a.btn{ padding:8px 16px; font-size:13px; }
.land-links a.btn.ghost{ color:var(--text); border:1px solid var(--line); background:transparent; }
.land-links a.btn.primary{ color:#001018; }
@media (max-width:820px){
  .land-links a:not(.btn){ display:none; }
}

.land-main{ position:relative; z-index:1; }

/* HERO */
.hero{ padding:60px 22px 30px; max-width:1240px; margin:auto; }
.hero-inner{
  display:grid; grid-template-columns:1.05fr .95fr; gap:48px; align-items:center;
}
@media (max-width:980px){
  .hero-inner{ grid-template-columns:1fr; gap:34px; }
}
.hero-pill{
  display:inline-flex; align-items:center; gap:8px;
  padding:6px 14px; border-radius:999px;
  border:1px solid rgba(16,245,160,.3);
  background:rgba(16,245,160,.07);
  color:var(--money); font-size:12px; letter-spacing:1.5px; text-transform:uppercase;
  font-family:var(--font-mono);
  margin-bottom:18px;
}
.hero-title{
  font-family:var(--font-display);
  font-size:clamp(34px, 5.4vw, 60px);
  line-height:1.04; font-weight:900;
  margin:0 0 18px; letter-spacing:-1px;
}
.grad-brand{
  background:linear-gradient(90deg, var(--brand), var(--brand-2));
  -webkit-background-clip:text; background-clip:text; color:transparent;
}
.grad-money{
  background:linear-gradient(90deg, var(--money), var(--gold));
  -webkit-background-clip:text; background-clip:text; color:transparent;
}
.hero-sub{
  color:var(--muted); font-size:16px; line-height:1.6;
  max-width:560px; margin:0 0 26px;
}
.hero-actions{ display:flex; gap:12px; flex-wrap:wrap; margin-bottom:24px; }
.btn.big{ padding:13px 22px; font-size:14px; font-weight:600; }
.btn.ghost{ background:transparent; border:1px solid var(--line-strong); color:var(--text); }
.btn.ghost:hover{ border-color:var(--brand); color:var(--brand); }
.hero-trust{
  display:flex; gap:18px; flex-wrap:wrap; color:var(--muted); font-size:12.5px;
}
.hero-trust span{ display:inline-flex; align-items:center; gap:6px; }

/* HERO VISUAL — HUD frame */
.hero-visual{ position:relative; min-height:480px; display:flex; align-items:center; justify-content:center; }
.hud-frame{
  position:relative; width:100%; max-width:520px; aspect-ratio:1/1;
  display:flex; align-items:center; justify-content:center;
}
.hud-screen{
  position:relative; z-index:2;
  width:88%; padding:22px;
  background:linear-gradient(155deg, rgba(15,22,38,.88), rgba(10,16,28,.92));
  border:1px solid var(--line-strong);
  border-radius:18px;
  box-shadow:0 30px 80px rgba(0,0,0,.55), 0 0 0 1px rgba(0,229,255,.1) inset, 0 0 40px rgba(0,229,255,.15);
  backdrop-filter:blur(12px);
}
.hud-row{ display:flex; gap:8px; flex-wrap:wrap; margin-bottom:16px; }
.hud-chip{
  font-family:var(--font-mono); font-size:10.5px; letter-spacing:1.4px;
  padding:4px 10px; border-radius:6px;
  background:rgba(0,229,255,.08); color:var(--brand);
  border:1px solid rgba(0,229,255,.3);
}
.hud-chip.green{ background:rgba(16,245,160,.08); color:var(--money); border-color:rgba(16,245,160,.3); }
.hud-chip.purple{ background:rgba(124,58,237,.1); color:#a78bfa; border-color:rgba(124,58,237,.35); }
.hud-bars{ display:grid; gap:10px; margin-bottom:18px; }
.hud-bars > div{ display:grid; grid-template-columns:80px 1fr; align-items:center; gap:10px; font-size:11.5px; color:var(--muted); font-family:var(--font-mono); }
.hud-bars i{
  display:block; height:6px; border-radius:99px;
  background:linear-gradient(90deg, var(--brand), var(--brand-2));
  box-shadow:0 0 10px rgba(0,229,255,.45);
  animation:shimmer 2.6s linear infinite;
}
.hud-bars i.green{ background:linear-gradient(90deg, var(--money), #4ade80); box-shadow:0 0 10px rgba(16,245,160,.5); }
.hud-bars i.purple{ background:linear-gradient(90deg, var(--brand-2), #a78bfa); }
.hud-bars i.gold{ background:linear-gradient(90deg, var(--gold), #fbbf24); box-shadow:0 0 10px rgba(255,215,0,.4); }
.hud-grid-mini{ display:grid; grid-template-columns:repeat(4,1fr); gap:8px; padding:10px 0; border-top:1px solid var(--line); border-bottom:1px solid var(--line); margin-bottom:14px; }
.hud-grid-mini > div{ text-align:center; }
.hud-grid-mini b{ display:block; font-family:var(--font-display); font-size:16px; color:var(--brand); }
.hud-grid-mini small{ color:var(--muted); font-size:10px; letter-spacing:1.2px; text-transform:uppercase; }
.hud-term{
  background:rgba(0,0,0,.45); border:1px solid var(--line);
  border-radius:8px; padding:10px 12px;
  font-family:var(--font-mono); font-size:11.5px;
}
.hud-term em{ display:block; font-style:normal; color:#94a3b8; margin:2px 0; }
.hud-term .t-cmd{ color:var(--brand); }
.hud-term .ok{ color:var(--money); }
.hud-term .caret{ color:var(--brand); animation:blink 1s steps(2) infinite; }
@keyframes blink{ 50%{ opacity:0; } }

/* KPI strip */
.kpi-strip{
  max-width:1240px; margin:30px auto; padding:0 22px;
  display:grid; grid-template-columns:repeat(5,1fr); gap:14px;
}
.kpi-cell{
  text-align:center; padding:20px 14px;
  background:var(--surface); border:1px solid var(--line);
  border-radius:14px;
  transition:all .25s;
}
.kpi-cell:hover{ border-color:var(--brand); transform:translateY(-2px); }
.kpi-cell b{
  display:block; font-family:var(--font-display);
  font-size:26px; font-weight:800;
  background:linear-gradient(90deg, var(--brand), var(--money));
  -webkit-background-clip:text; background-clip:text; color:transparent;
}
.kpi-cell span{ display:block; color:var(--muted); font-size:11.5px; margin-top:4px; letter-spacing:1px; text-transform:uppercase; }
@media (max-width:820px){ .kpi-strip{ grid-template-columns:repeat(2,1fr); } }

/* Section heads */
.sec-head{ text-align:center; max-width:780px; margin:0 auto 36px; padding:0 22px; }
.sec-tag{
  display:inline-block; font-family:var(--font-mono); font-size:11px; letter-spacing:2.4px;
  color:var(--brand); padding:4px 12px; border:1px solid rgba(0,229,255,.3);
  background:rgba(0,229,255,.06); border-radius:999px; margin-bottom:14px;
}
.sec-head h2{
  font-family:var(--font-display); font-size:clamp(26px, 3.4vw, 38px);
  font-weight:800; margin:0 0 12px; letter-spacing:-.5px;
}
.sec-head p{ color:var(--muted); font-size:15px; margin:0; }

/* FEATURES */
.features{ padding:70px 22px; max-width:1240px; margin:auto; }
.feat-grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:16px; }
@media (max-width:1024px){ .feat-grid{ grid-template-columns:repeat(2,1fr); } }
@media (max-width:560px){ .feat-grid{ grid-template-columns:1fr; } }
.feat{
  padding:22px; background:var(--surface);
  border:1px solid var(--line); border-radius:14px;
  transition:all .25s;
}
.feat:hover{ border-color:var(--brand); transform:translateY(-3px); box-shadow:0 16px 40px rgba(0,229,255,.12); }
.feat-ico{
  width:44px; height:44px; border-radius:10px;
  display:flex; align-items:center; justify-content:center;
  background:rgba(0,229,255,.1); color:var(--brand);
  font-size:20px; margin-bottom:14px;
  border:1px solid rgba(0,229,255,.25);
}
.feat-ico.green{ background:rgba(16,245,160,.1); color:var(--money); border-color:rgba(16,245,160,.3); }
.feat-ico.purple{ background:rgba(124,58,237,.12); color:#a78bfa; border-color:rgba(124,58,237,.35); }
.feat-ico.gold{ background:rgba(255,215,0,.08); color:var(--gold); border-color:rgba(255,215,0,.3); }
.feat h3{ font-family:var(--font-display); font-size:17px; font-weight:700; margin:0 0 8px; }
.feat p{ color:var(--muted); font-size:13.5px; line-height:1.55; margin:0; }

/* STACK */
.stack{ padding:50px 22px 70px; max-width:1240px; margin:auto; }
.stack-grid{ display:flex; flex-wrap:wrap; justify-content:center; gap:10px; }
.stack-chip{
  font-family:var(--font-mono); font-size:12.5px;
  padding:9px 18px; border-radius:999px;
  background:var(--surface); border:1px solid var(--line);
  color:var(--text); letter-spacing:.5px;
  transition:all .25s;
}
.stack-chip:hover{
  border-color:var(--brand); color:var(--brand);
  box-shadow:0 0 16px rgba(0,229,255,.18);
}

/* PLANS */
.plans{ padding:60px 22px; max-width:1100px; margin:auto; }

/* LEAD CAPTURE */
.lead-cap{ padding:60px 22px 80px; max-width:680px; margin:auto; }
.lead-card{
  position:relative; padding:40px 30px;
  background:linear-gradient(155deg, rgba(15,22,38,.88), rgba(10,16,28,.95));
  border:1px solid var(--line-strong); border-radius:20px;
  box-shadow:0 30px 80px rgba(0,0,0,.5), 0 0 0 1px rgba(0,229,255,.08) inset;
  overflow:hidden;
}
.lead-card .hud-rings{ opacity:.55; }

/* Footer */
.land-foot{
  border-top:1px solid var(--line);
  padding:22px;
  max-width:1240px; margin:auto;
  display:flex; justify-content:space-between; align-items:center; flex-wrap:wrap;
  gap:14px; color:var(--muted); font-size:12.5px;
}
.land-foot a{ color:var(--brand); text-decoration:none; }
.land-foot a:hover{ text-decoration:underline; }

/* Small code helper */
.muted.code{ font-family:var(--font-mono); font-size:12.5px; color:var(--brand); text-align:center; padding:8px; background:rgba(0,229,255,.04); border:1px solid var(--line); border-radius:8px; }

/* Badge */
.badge{ display:inline-block; padding:3px 9px; border-radius:999px; font-size:11px; font-family:var(--font-mono); letter-spacing:.5px; }
.badge.on{ background:rgba(16,245,160,.12); color:var(--money); border:1px solid rgba(16,245,160,.3); }
.badge.off{ background:rgba(255,61,110,.12); color:var(--danger); border:1px solid rgba(255,61,110,.3); }
