﻿/* =================================================================
   JETFLIX BOT — JET AI EDITION
   Tema: hacker / dinheiro / JetAI / 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:#050507;
  --bg-1:#0a0a0f;
  --bg-2:#121018;
  --panel:rgba(18,18,24,.78);
  --panel-solid:#121218;
  --card:rgba(24,24,32,.62);
  --card-hover:rgba(36,28,38,.78);
  --line:rgba(255,23,68,.16);
  --line-soft:rgba(255,255,255,.06);
  --line-strong:rgba(255,23,68,.36);

  --brand:#ff1744;
  --brand-2:#ff8a00;
  --brand-3:#00e5ff;
  --money:#10f5a0;
  --gold:#ffd700;
  --danger:#ff3d6e;
  --warn:#ffb547;

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

  --glow-brand:0 0 24px rgba(255,23,68,.46), 0 0 60px rgba(255,138,0,.16);
  --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}
}

/* ========== JET AI 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)}}

/* ========================================================================
   V15 JET AI — 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); }

/* =====================================================================
   V15 Production — JET AI BOOT + EFFECTS PACK
   ===================================================================== */

/* ===== Boot screen ===== */
.boot-screen{
  position:fixed; inset:0; z-index:9999;
  background:radial-gradient(circle at 50% 50%, #050a18 0%, #02050d 70%);
  display:flex; align-items:center; justify-content:center;
  flex-direction:column; gap:30px;
  font-family:var(--font-mono);
  transition:opacity .6s ease, visibility .6s;
}
.boot-screen.hidden{ opacity:0; visibility:hidden; pointer-events:none; }
.boot-logo{
  font-family:var(--font-display); font-size:54px; font-weight:900;
  letter-spacing:8px; color:var(--brand);
  text-shadow:0 0 30px rgba(0,229,255,.7), 0 0 80px rgba(0,229,255,.3);
  animation:bootPulse 1.4s ease-in-out infinite;
  position:relative;
}
.boot-logo::before, .boot-logo::after{
  content:'JETFLIX BOT'; position:absolute; top:0; left:0; right:0;
  mix-blend-mode:screen; pointer-events:none;
}
.boot-logo::before{ color:#ff3d6e; animation:glitchA 3.6s infinite linear; }
.boot-logo::after{ color:#10f5a0; animation:glitchB 4.2s infinite linear; }
@keyframes bootPulse{
  0%,100%{ text-shadow:0 0 30px rgba(0,229,255,.7), 0 0 80px rgba(0,229,255,.3); }
  50%{ text-shadow:0 0 50px rgba(0,229,255,.9), 0 0 120px rgba(0,229,255,.5); }
}
@keyframes glitchA{
  0%,90%,100%{ transform:translate(0,0); opacity:0; }
  92%{ transform:translate(-3px,1px); opacity:.7; }
  94%{ transform:translate(2px,-1px); opacity:.5; }
  96%{ transform:translate(-1px,0); opacity:.8; }
  98%{ transform:translate(0,0); opacity:0; }
}
@keyframes glitchB{
  0%,80%,100%{ transform:translate(0,0); opacity:0; }
  82%{ transform:translate(2px,-2px); opacity:.6; }
  84%{ transform:translate(-1px,1px); opacity:.4; }
  86%{ transform:translate(0,0); opacity:0; }
}
.boot-sub{
  font-size:11px; color:var(--brand); letter-spacing:6px;
  text-transform:uppercase; opacity:.7;
}
.boot-log{
  width:min(560px,90vw); height:240px; overflow:hidden;
  background:rgba(0,0,0,.45); border:1px solid var(--line);
  border-radius:8px; padding:14px;
  font-size:11.5px; color:#94c8ff; line-height:1.55;
}
.boot-log .ok{ color:var(--money); }
.boot-log .err{ color:var(--danger); }
.boot-log .acc{ color:var(--brand); }
.boot-log .seq{ color:var(--gold); }
.boot-bar{
  width:min(560px,90vw); height:6px;
  background:rgba(0,229,255,.08); border-radius:99px;
  overflow:hidden; position:relative;
}
.boot-bar i{
  position:absolute; left:0; top:0; bottom:0; width:0;
  background:linear-gradient(90deg, var(--brand), var(--money), var(--brand));
  box-shadow:0 0 18px rgba(0,229,255,.7);
  transition:width .25s ease;
}
.boot-grid{
  position:absolute; inset:0; pointer-events:none; opacity:.25;
  background-image:
    linear-gradient(rgba(0,229,255,.08) 1px, transparent 1px),
    linear-gradient(90deg, rgba(0,229,255,.08) 1px, transparent 1px);
  background-size:48px 48px;
  mask-image:radial-gradient(circle at 50% 50%, #000 30%, transparent 75%);
}

/* ===== Scanlines (subtle CRT overlay) ===== */
body::before{
  content:''; position:fixed; inset:0; pointer-events:none; z-index:9000;
  background:repeating-linear-gradient(
    180deg,
    transparent 0,
    transparent 2px,
    rgba(0,229,255,.018) 2px,
    rgba(0,229,255,.018) 3px
  );
  mix-blend-mode:overlay; opacity:.6;
}

/* ===== Health HUD real (corner widget on dashboard) ===== */
.health-hud{
  position:fixed; right:18px; bottom:18px; z-index:60;
  min-width:190px; padding:12px 14px; border-radius:18px;
  background:rgba(2,6,23,.78); border:1px solid rgba(255,23,68,.28);
  box-shadow:0 18px 60px rgba(0,0,0,.35), inset 0 1px 0 rgba(255,255,255,.06);
  backdrop-filter:blur(14px); color:var(--text); display:flex; flex-direction:column; gap:4px;
}
.health-hud b{font-family:var(--font-mono); font-size:12px; letter-spacing:.12em; text-transform:uppercase; color:var(--brand);}
.health-hud span{font-size:13px; font-weight:800;}
.health-hud small{font-size:11px; color:var(--muted);}
@media (max-width:980px){ .health-hud{ display:none; } }

/* ===== Tickertape (live data stream below topbar) ===== */
.ticker{
  border-top:1px solid var(--line); border-bottom:1px solid var(--line);
  background:rgba(0,229,255,.025);
  overflow:hidden; font-family:var(--font-mono); font-size:11.5px;
  padding:6px 0; margin:-8px 0 14px;
  position:relative;
}
.ticker::before, .ticker::after{
  content:''; position:absolute; top:0; bottom:0; width:60px; z-index:2;
}
.ticker::before{ left:0; background:linear-gradient(90deg, var(--bg-0), transparent); }
.ticker::after{ right:0; background:linear-gradient(-90deg, var(--bg-0), transparent); }
.ticker-track{
  display:inline-flex; gap:34px; white-space:nowrap;
  animation:tickerScroll 60s linear infinite;
  padding-left:100%;
}
.ticker-item{ color:var(--text-soft); }
.ticker-item b{ color:var(--brand); margin-right:6px; }
.ticker-item .up{ color:var(--money); }
.ticker-item .down{ color:var(--danger); }
@keyframes tickerScroll{ to{ transform:translateX(-100%); } }

/* ===== KPI cards: streaming dot ===== */
.kpi{ position:relative; }
.kpi::before{
  content:''; position:absolute; top:14px; right:14px;
  width:6px; height:6px; border-radius:50%;
  background:var(--money); box-shadow:0 0 8px var(--money);
  animation:livePulse 1.6s ease-in-out infinite;
}

/* ===== JetAI terminal: typewriter caret + waveform ===== */
.jarvis-shell{ position:relative; }
.jarvis-wave{
  display:flex; align-items:flex-end; gap:3px; height:24px; margin-top:8px;
  padding:0 4px;
}
.jarvis-wave span{
  display:block; width:3px; min-height:3px;
  background:linear-gradient(180deg, var(--brand), var(--brand-2));
  border-radius:2px;
  box-shadow:0 0 6px rgba(0,229,255,.6);
  animation:waveBar 1.2s ease-in-out infinite;
}
.jarvis-wave span:nth-child(1){ animation-delay:0s; }
.jarvis-wave span:nth-child(2){ animation-delay:.1s; }
.jarvis-wave span:nth-child(3){ animation-delay:.2s; }
.jarvis-wave span:nth-child(4){ animation-delay:.3s; }
.jarvis-wave span:nth-child(5){ animation-delay:.4s; }
.jarvis-wave span:nth-child(6){ animation-delay:.5s; }
.jarvis-wave span:nth-child(7){ animation-delay:.6s; }
.jarvis-wave span:nth-child(8){ animation-delay:.5s; }
.jarvis-wave span:nth-child(9){ animation-delay:.4s; }
.jarvis-wave span:nth-child(10){ animation-delay:.3s; }
.jarvis-wave span:nth-child(11){ animation-delay:.2s; }
.jarvis-wave span:nth-child(12){ animation-delay:.1s; }
@keyframes waveBar{ 0%,100%{ height:4px; } 50%{ height:24px; } }

/* ===== Section reveal animation ===== */
.tab.active > *{ animation:fadeUp .5s ease both; }
.tab.active > *:nth-child(1){ animation-delay:.05s; }
.tab.active > *:nth-child(2){ animation-delay:.10s; }
.tab.active > *:nth-child(3){ animation-delay:.15s; }
.tab.active > *:nth-child(4){ animation-delay:.20s; }
.tab.active > *:nth-child(5){ animation-delay:.25s; }
@keyframes fadeUp{ from{ opacity:0; transform:translateY(8px); } to{ opacity:1; transform:translateY(0); } }

/* ===== Tab transitions ===== */
.tab{ transition:opacity .2s; }

/* ===== Glow on hover for primary buttons ===== */
button.primary, .btn.primary{
  position:relative; overflow:hidden;
}
button.primary::after, .btn.primary::after{
  content:''; position:absolute; inset:0; pointer-events:none;
  background:linear-gradient(90deg, transparent, rgba(255,255,255,.18), transparent);
  transform:translateX(-100%);
}
button.primary:hover::after, .btn.primary:hover::after{
  transform:translateX(100%); transition:transform .8s ease;
}

/* ===== Section head money mode for revenue card ===== */
.section-head h3{ display:flex; align-items:center; gap:6px; }

/* ===== Notification badge pulse ===== */
.notif #notifBadge{
  display:inline-block; min-width:18px; padding:1px 6px;
  background:var(--danger); color:#fff; border-radius:999px;
  font-size:10px; font-weight:700; margin-left:4px;
  box-shadow:0 0 10px rgba(255,61,110,.6);
}
.notif #notifBadge:not(:empty):not([data-zero])::after{
  content:''; display:inline-block; width:5px; height:5px;
  border-radius:50%; background:#fff; margin-left:3px;
  animation:livePulse 1.2s ease-in-out infinite;
}

/* ===== Make existing canvas particles a touch brighter ===== */
#bgCanvas{ opacity:.85; }

/* ===== Subtle vignette ===== */
body::after{
  content:''; position:fixed; inset:0; pointer-events:none; z-index:8000;
  background:radial-gradient(ellipse at center, transparent 50%, rgba(0,0,0,.55) 100%);
}


/* =====================================================================
   V15 Production final polish — money cards + chart card glow + matrix rain
   ===================================================================== */

/* KPI cards money mode for revenue-related */
.kpi[data-money] b{
  background:linear-gradient(90deg, var(--money), var(--gold), var(--money));
  background-size:200% 100%;
  -webkit-background-clip:text; background-clip:text; color:transparent;
  animation:moneyShine 4s linear infinite;
}
@keyframes moneyShine{ to{ background-position:200% 0; } }

/* Chart card glow effect on hover */
.card:has(canvas){ position:relative; }
.card:has(canvas):hover{
  box-shadow:0 0 0 1px var(--line-strong), 0 24px 60px rgba(0,229,255,.15);
}

/* Better section head pills */
.pill{
  display:inline-flex; align-items:center; gap:5px;
  padding:3px 9px; border-radius:99px; font-size:10.5px;
  font-family:var(--font-mono); letter-spacing:1.2px; text-transform:uppercase;
  background:rgba(0,229,255,.08); color:var(--brand);
  border:1px solid rgba(0,229,255,.25);
}
.pill.ok{ background:rgba(16,245,160,.1); color:var(--money); border-color:rgba(16,245,160,.3); }
.pill.warn{ background:rgba(255,181,71,.1); color:var(--warn); border-color:rgba(255,181,71,.3); }
.pill.danger{ background:rgba(255,61,110,.1); color:var(--danger); border-color:rgba(255,61,110,.3); }

/* Status dot animation on dashboard */
.status-dot{
  font-family:var(--font-mono); font-size:11px; letter-spacing:1.5px;
  color:var(--money); display:inline-flex; align-items:center; gap:6px;
}
.status-dot::before{
  content:''; width:8px; height:8px; border-radius:50%;
  background:var(--money);
  box-shadow:0 0 0 4px rgba(16,245,160,.18), 0 0 10px var(--money);
  animation:livePulse 1.6s ease-in-out infinite;
}

/* Notification pulse for security tab */
.nav[data-tab="security"]{ position:relative; }

/* Login screen glow ring intensifier */
.login-screen::before{
  content:''; position:absolute; left:50%; top:50%;
  width:600px; height:600px; transform:translate(-50%,-50%);
  background:radial-gradient(circle, rgba(0,229,255,.08) 0%, transparent 60%);
  pointer-events:none; z-index:0;
  animation:loginBreath 4s ease-in-out infinite;
}
@keyframes loginBreath{ 0%,100%{ opacity:.6; } 50%{ opacity:1; } }

/* Sidebar nav buttons hover slide */
.nav{ position:relative; overflow:hidden; }
.nav::before{
  content:''; position:absolute; left:0; top:0; bottom:0; width:3px;
  background:linear-gradient(180deg, var(--brand), var(--brand-2));
  transform:scaleY(0); transform-origin:center;
  transition:transform .25s ease;
}
.nav:hover::before, .nav.active::before{ transform:scaleY(1); }
.nav.active{ background:linear-gradient(90deg, rgba(0,229,255,.12), transparent); }

/* Make tables look more terminal */
table{ border-collapse:collapse; width:100%; font-size:13px; }
table th{
  text-align:left; padding:10px 12px;
  font-family:var(--font-mono); font-size:10.5px; letter-spacing:1.4px;
  color:var(--brand); text-transform:uppercase;
  border-bottom:1px solid var(--line-strong);
  background:rgba(0,229,255,.03);
}
table td{
  padding:11px 12px;
  border-bottom:1px solid var(--line);
  color:var(--text-soft);
}
table tr:hover td{ background:rgba(0,229,255,.04); color:var(--text); }

/* Code inline in muted text */
code{
  font-family:var(--font-mono); font-size:11.5px;
  padding:1.5px 6px; border-radius:4px;
  background:rgba(0,229,255,.08); color:var(--brand);
  border:1px solid rgba(0,229,255,.15);
}


/* =====================================================================
   V15 Production — ONBOARDING WIZARD
   ===================================================================== */
.onboard-main{
  position:relative; z-index:2;
  max-width:780px; margin:auto;
  padding:40px 22px 80px;
}
.onboard-head{
  display:flex; flex-direction:column; align-items:center; gap:8px;
  margin-bottom:30px; text-align:center;
}
.onboard-card{
  position:relative;
  background:linear-gradient(155deg, rgba(15,22,38,.92), rgba(10,16,28,.96));
  border:1px solid var(--line-strong);
  border-radius:20px;
  padding:36px 30px;
  box-shadow:0 30px 80px rgba(0,0,0,.55), 0 0 0 1px rgba(0,229,255,.08) inset, 0 0 40px rgba(0,229,255,.12);
  overflow:hidden;
}
.onboard-card .hud-rings{ opacity:.45; }

.step-bar{
  position:relative; z-index:2;
  display:flex; align-items:center; justify-content:space-between;
  margin-bottom:30px;
}
.step-bar .step{
  display:flex; flex-direction:column; align-items:center; gap:6px;
  flex-shrink:0;
}
.step-bar .step b{
  display:flex; align-items:center; justify-content:center;
  width:36px; height:36px; border-radius:50%;
  background:var(--card); border:1px solid var(--line);
  color:var(--muted); font-family:var(--font-display); font-size:14px; font-weight:800;
  transition:all .3s;
}
.step-bar .step.active b{
  background:linear-gradient(135deg, var(--brand), var(--brand-2));
  border-color:transparent; color:#001018;
  box-shadow:0 0 18px rgba(0,229,255,.5);
}
.step-bar .step.done b{
  background:rgba(16,245,160,.15);
  border-color:var(--money); color:var(--money);
}
.step-bar .step span{
  font-family:var(--font-mono); font-size:10px; letter-spacing:1.5px;
  color:var(--muted); text-transform:uppercase;
}
.step-bar .step.active span{ color:var(--brand); }
.step-bar .step.done span{ color:var(--money); }
.step-bar .step-line{
  flex:1; height:1px; margin:0 6px; margin-bottom:24px;
  background:linear-gradient(90deg, var(--line), var(--line-strong), var(--line));
}
@media (max-width:560px){
  .step-bar .step span{ display:none; }
  .step-bar .step-line{ margin-bottom:0; }
}

.step-panel{ display:none; position:relative; z-index:2; }
.step-panel.active{ display:block; animation:fadeUp .35s ease both; }

.onboard-help{
  margin:14px 0;
  background:rgba(0,229,255,.04);
  border:1px solid var(--line);
  border-radius:12px;
  padding:14px 18px;
}
.onboard-help summary{
  cursor:pointer; font-weight:600;
  color:var(--text); list-style:none;
  display:flex; align-items:center; gap:8px;
}
.onboard-help summary::-webkit-details-marker{ display:none; }
.onboard-help summary::before{
  content:'▶'; color:var(--brand); font-size:10px;
  transition:transform .25s;
}
.onboard-help[open] summary::before{ transform:rotate(90deg); }
.onboard-help[open] summary{ margin-bottom:12px; padding-bottom:10px; border-bottom:1px solid var(--line); }
.onboard-help div{ color:var(--text-soft); font-size:13.5px; line-height:1.65; }
.onboard-help pre{
  background:rgba(0,0,0,.45); border:1px solid var(--line);
  border-radius:8px; padding:10px 12px; margin:8px 0;
  font-family:var(--font-mono); font-size:12px;
  color:var(--brand); overflow-x:auto;
  white-space:pre;
}
.onboard-help a{ color:var(--brand); }

.onboard-nav{
  display:flex; align-items:center; justify-content:space-between;
  gap:10px; margin-top:24px; padding-top:20px;
  border-top:1px solid var(--line);
}
.onboard-nav > div{ display:flex; gap:8px; }
.onboard-nav button{ padding:11px 18px; font-size:13.5px; }

.onboard-summary{
  background:rgba(16,245,160,.04);
  border:1px solid rgba(16,245,160,.2);
  border-radius:12px; padding:18px 22px; margin:20px 0;
  font-size:13.5px; line-height:1.9;
}
.onboard-summary b.ok{ color:var(--money); }
.onboard-actions{ margin-top:24px; }


/* Onboarding banner on dashboard */
.onboard-banner{
  margin-bottom:14px;
  background:linear-gradient(135deg, rgba(0,229,255,.12), rgba(124,58,237,.08));
  border:1px solid var(--line-strong);
  border-radius:14px;
  padding:14px 18px;
  position:relative; overflow:hidden;
  animation:fadeUp .4s ease both;
}
.onboard-banner::before{
  content:''; position:absolute; inset:0; pointer-events:none;
  background:radial-gradient(circle at 0% 50%, rgba(0,229,255,.18), transparent 50%);
}
.onboard-banner-inner{
  display:flex; align-items:center; justify-content:space-between;
  gap:14px; flex-wrap:wrap; position:relative; z-index:1;
}
.onboard-banner b{ display:block; font-size:15px; color:var(--text); margin-bottom:2px; }
.onboard-banner span{ color:var(--text-soft); font-size:13px; }
.onboard-banner-actions{ display:flex; gap:8px; flex-wrap:wrap; }
.onboard-banner-actions .primary{
  padding:9px 16px; font-size:13px; text-decoration:none;
  display:inline-flex; align-items:center;
}


/* =====================================================================
   V15 Production — Pitch effects: Matrix rain + glowing data flow on KPIs
   ===================================================================== */

/* Matrix rain background on login & landing hero */
.matrix-rain{
  position:absolute; inset:0; z-index:0; opacity:.15;
  pointer-events:none; overflow:hidden;
}
.matrix-col{
  position:absolute; top:-100%;
  font-family:var(--font-mono); font-size:14px;
  color:var(--money); writing-mode:vertical-rl;
  letter-spacing:2px; line-height:1.2;
  animation:matrixFall linear infinite;
  text-shadow:0 0 8px rgba(16,245,160,.8);
}
@keyframes matrixFall{
  to{ transform:translateY(220vh); }
}

/* Data flow line between KPI cards */
.kpis{ position:relative; }
.kpis::after{
  content:''; position:absolute; left:0; right:0; top:50%; height:1px;
  background:linear-gradient(90deg, transparent 0%, rgba(0,229,255,.3) 20%, rgba(124,58,237,.3) 50%, rgba(16,245,160,.3) 80%, transparent 100%);
  pointer-events:none; z-index:0;
  animation:dataFlow 6s linear infinite;
}
@keyframes dataFlow{
  0%,100%{ opacity:.3; transform:translateY(0); }
  50%{ opacity:.7; transform:translateY(-2px); }
}

/* Pulsing border glow on active sidebar item */
.nav.active{
  box-shadow:inset 0 0 12px rgba(0,229,255,.1);
  animation:navGlow 3s ease-in-out infinite;
}
@keyframes navGlow{
  0%,100%{ box-shadow:inset 0 0 12px rgba(0,229,255,.1); }
  50%{ box-shadow:inset 0 0 20px rgba(0,229,255,.25); }
}

/* Card border data flicker */
.card{
  position:relative;
  transition:transform .2s, border-color .2s;
}
.card:hover{ transform:translateY(-2px); border-color:var(--line-strong); }

/* Topbar glow border */
.topbar{
  border-bottom:1px solid var(--line);
  background:linear-gradient(180deg, rgba(7,11,18,.85), rgba(7,11,18,.45));
  backdrop-filter:blur(14px);
}

/* Notification with halo when has count */
.notif{ position:relative; }

/* Login screen extras */
.login-screen{ position:relative; overflow:hidden; }


/* =====================================================================
   V15 — Theme switcher (JetAI / Money / Anonymous)
   ===================================================================== */

/* default theme = jarvis (cyan/purple) — already defined */

body[data-theme="money"]{
  --brand:#10f5a0;
  --brand-2:#22d3ee;
  --brand-3:#ffd700;
  --money:#10f5a0;
  --line:rgba(16,245,160,.14);
  --line-strong:rgba(16,245,160,.35);
  --glow-brand:0 0 24px rgba(16,245,160,.45), 0 0 60px rgba(16,245,160,.15);
}

body[data-theme="anonymous"]{
  --brand:#ff3d6e;
  --brand-2:#ff8c42;
  --brand-3:#ffd700;
  --money:#10f5a0;
  --line:rgba(255,61,110,.14);
  --line-strong:rgba(255,61,110,.35);
  --glow-brand:0 0 24px rgba(255,61,110,.45), 0 0 60px rgba(255,61,110,.15);
  --bg-0:#0a0405;
  --bg-1:#180a0c;
}

/* Theme switcher button */
.theme-switch{
  display:inline-flex; gap:5px; align-items:center;
  padding:5px; border:1px solid var(--line); border-radius:99px;
  background:rgba(0,229,255,.04);
}
.theme-switch button{
  width:22px; height:22px; border-radius:50%; padding:0;
  border:1px solid var(--line); cursor:pointer;
  transition:transform .2s;
}
.theme-switch button:hover{ transform:scale(1.15); }
.theme-switch button.active{
  border-color:#fff; box-shadow:0 0 0 2px var(--brand);
}
.theme-switch button[data-theme="jarvis"]{ background:linear-gradient(135deg, #00e5ff, #7c3aed); }
.theme-switch button[data-theme="money"]{ background:linear-gradient(135deg, #10f5a0, #ffd700); }
.theme-switch button[data-theme="anonymous"]{ background:linear-gradient(135deg, #ff3d6e, #ff8c42); }

/* =====================================================================
   V15 — Presentation mode (Ctrl+P)
   ===================================================================== */
body.presenting .sidebar{ display:none; }
body.presenting .topbar{ display:none; }
body.presenting .ticker{ display:none; }
body.presenting .health-hud{ display:none; }
body.presenting .content{ padding:40px 60px; }
body.presenting .kpi b{ font-size:64px !important; }
body.presenting .card{ padding:30px; }
body.presenting .grid.kpis{ grid-template-columns:repeat(4,1fr); gap:24px; }
body.presenting .section-head h3{ font-size:22px; }
body.presenting{ transition:all .4s; }
.presenting-badge{
  position:fixed; top:18px; right:18px; z-index:100;
  background:var(--brand); color:#001018;
  padding:8px 16px; border-radius:99px;
  font-family:var(--font-mono); font-size:11px;
  letter-spacing:2px; text-transform:uppercase;
  box-shadow:0 0 24px var(--brand);
  display:none;
}
body.presenting .presenting-badge{ display:block; animation:livePulse 2s ease-in-out infinite; }

/* =====================================================================
   V15 — Inbox WhatsApp UI
   ===================================================================== */
.inbox-grid{
  display:grid; grid-template-columns:340px 1fr;
  gap:0; height:calc(100vh - 240px); min-height:520px;
  background:var(--card); border:1px solid var(--line); border-radius:14px;
  overflow:hidden;
}
@media (max-width:900px){ .inbox-grid{ grid-template-columns:1fr; height:auto; } }

.inbox-list{
  border-right:1px solid var(--line);
  overflow-y:auto;
  background:rgba(0,0,0,.18);
}
.inbox-search{
  padding:12px; border-bottom:1px solid var(--line);
  position:sticky; top:0; background:rgba(7,11,18,.85); backdrop-filter:blur(8px);
}
.inbox-search input{ width:100%; padding:8px 12px; font-size:13px; }

.inbox-chat{
  padding:14px; border-bottom:1px solid var(--line);
  cursor:pointer; transition:all .15s;
  display:flex; gap:12px;
}
.inbox-chat:hover, .inbox-chat.active{ background:rgba(0,229,255,.06); }
.inbox-chat.active{ border-left:3px solid var(--brand); }
.inbox-avatar{
  width:42px; height:42px; border-radius:50%; flex-shrink:0;
  background:linear-gradient(135deg, var(--brand), var(--brand-2));
  display:flex; align-items:center; justify-content:center;
  color:#001018; font-weight:700; font-family:var(--font-display);
}
.inbox-meta{ flex:1; min-width:0; }
.inbox-meta b{ display:block; font-size:13.5px; color:var(--text); }
.inbox-meta small{ color:var(--muted); font-size:11.5px; }
.inbox-meta .last{
  color:var(--text-soft); font-size:12px;
  overflow:hidden; text-overflow:ellipsis; white-space:nowrap;
  margin-top:2px;
}
.inbox-badge{
  background:var(--money); color:#001018; padding:2px 7px;
  border-radius:99px; font-size:10px; font-weight:700;
}

.inbox-thread{ display:flex; flex-direction:column; }
.inbox-header{
  padding:14px 18px; border-bottom:1px solid var(--line);
  display:flex; align-items:center; gap:12px;
  background:rgba(0,229,255,.03);
}
.inbox-messages{ flex:1; padding:18px; overflow-y:auto; }
.inbox-msg{
  max-width:75%; padding:10px 14px; border-radius:14px;
  margin-bottom:10px; font-size:13.5px; line-height:1.45;
  position:relative;
}
.inbox-msg.in{
  background:rgba(255,255,255,.06); color:var(--text);
  border:1px solid var(--line); border-top-left-radius:4px;
}
.inbox-msg.out{
  margin-left:auto; background:linear-gradient(135deg, rgba(16,245,160,.18), rgba(16,245,160,.08));
  color:var(--text); border:1px solid rgba(16,245,160,.3); border-top-right-radius:4px;
}
.inbox-msg time{
  display:block; font-size:10px; color:var(--muted); margin-top:4px;
  font-family:var(--font-mono);
}
.inbox-compose{
  padding:14px; border-top:1px solid var(--line);
  display:flex; gap:8px; background:rgba(0,0,0,.2);
}
.inbox-compose input{ flex:1; }
.inbox-empty{
  display:flex; flex-direction:column; align-items:center; justify-content:center;
  height:100%; color:var(--muted); font-size:13px; gap:8px;
}
.inbox-empty span{ font-size:42px; opacity:.4; }

/* =====================================================================
   V15 — Kanban
   ===================================================================== */
.kanban{
  display:grid; grid-template-columns:repeat(5, minmax(220px,1fr));
  gap:14px; overflow-x:auto; padding-bottom:8px;
}
.kanban-col{
  background:rgba(0,0,0,.18);
  border:1px solid var(--line); border-radius:12px;
  padding:12px; min-height:400px;
}
.kanban-col header{
  display:flex; align-items:center; justify-content:space-between;
  padding-bottom:10px; margin-bottom:10px;
  border-bottom:1px solid var(--line);
  font-family:var(--font-mono); font-size:11px;
  text-transform:uppercase; letter-spacing:1.5px;
  color:var(--brand);
}
.kanban-col header b{ color:var(--text); font-family:var(--font-body); font-size:12px; }
.kanban-col header span{
  background:rgba(0,229,255,.1); padding:2px 8px;
  border-radius:99px; color:var(--brand); font-size:10px;
}
.kanban-card{
  background:var(--card); border:1px solid var(--line);
  border-radius:10px; padding:12px;
  margin-bottom:8px; cursor:grab;
  transition:all .2s;
}
.kanban-card:hover{ border-color:var(--line-strong); transform:translateY(-2px); }
.kanban-card.dragging{ opacity:.5; transform:rotate(2deg); }
.kanban-card b{ display:block; font-size:13px; color:var(--text); margin-bottom:4px; }
.kanban-card small{ color:var(--muted); font-size:11px; display:block; }
.kanban-card .tags{ display:flex; flex-wrap:wrap; gap:4px; margin-top:8px; }
.kanban-card .tag{
  background:rgba(0,229,255,.1); color:var(--brand);
  padding:2px 7px; border-radius:99px; font-size:10px;
  font-family:var(--font-mono);
}
.kanban-col.dragover{ border-color:var(--brand); background:rgba(0,229,255,.06); }

/* =====================================================================
   V15 — Health 360 page
   ===================================================================== */
.health-grid{
  display:grid; grid-template-columns:repeat(auto-fill, minmax(260px,1fr));
  gap:14px;
}
.health-tile{
  background:var(--card); border:1px solid var(--line);
  border-radius:14px; padding:18px;
  position:relative; overflow:hidden;
}
.health-tile.ok::before{
  content:''; position:absolute; top:0; left:0; right:0; height:3px;
  background:var(--money); box-shadow:0 0 10px var(--money);
}
.health-tile.warn::before{ content:''; position:absolute; top:0; left:0; right:0; height:3px; background:var(--warn); }
.health-tile.err::before{ content:''; position:absolute; top:0; left:0; right:0; height:3px; background:var(--danger); }
.health-tile.loading::before{
  content:''; position:absolute; top:0; left:0; right:0; height:3px;
  background:linear-gradient(90deg, transparent, var(--brand), transparent);
  background-size:200% 100%;
  animation:healthLoad 1.4s linear infinite;
}
@keyframes healthLoad{ 0%{ background-position:-100% 0; } 100%{ background-position:100% 0; } }
.health-tile h4{
  display:flex; align-items:center; gap:8px;
  font-size:14px; margin:0 0 8px;
}
.health-tile .status{
  display:inline-block; padding:3px 9px; border-radius:99px;
  font-size:10.5px; font-family:var(--font-mono); letter-spacing:1.2px;
  text-transform:uppercase;
}
.health-tile.ok .status{ background:rgba(16,245,160,.12); color:var(--money); }
.health-tile.warn .status{ background:rgba(255,181,71,.12); color:var(--warn); }
.health-tile.err .status{ background:rgba(255,61,110,.12); color:var(--danger); }
.health-tile.loading .status{ background:rgba(0,229,255,.12); color:var(--brand); }
.health-tile p{ color:var(--text-soft); font-size:12.5px; margin:6px 0 0; line-height:1.5; }
.health-tile code{ font-size:10.5px; }

/* =====================================================================
   V15 — JARVIS / CYBER HUD layer (puramente visual, sem dado fake).
   Os valores numéricos são preenchidos via /api/health/full, /api/dashboard
   e /api/master/overview. Se a API falhar, o HUD mostra "—" (não inventa).
   ===================================================================== */
@keyframes jvScan { 0%{ transform:translateY(-100%);} 100%{ transform:translateY(100%);} }
@keyframes jvPulse { 0%,100%{ opacity:.55; transform:scale(1);} 50%{ opacity:1; transform:scale(1.06);} }
@keyframes jvFlicker { 0%,18%,22%,25%,53%,57%,100%{ opacity:1;} 20%,24%,55%{ opacity:.72;} }
@keyframes jvRotate { from{ transform:rotate(0deg);} to{ transform:rotate(360deg);} }

.jarvis-hud{
  position:relative; padding:14px 18px; margin:0 0 14px;
  border-radius:14px; overflow:hidden;
  background:linear-gradient(135deg, rgba(2,8,20,.85), rgba(7,16,38,.7));
  border:1px solid rgba(0,229,255,.22);
  box-shadow:0 0 24px rgba(0,229,255,.08), inset 0 0 24px rgba(0,229,255,.05);
  font-family: 'Courier New', monospace;
}
.jarvis-hud::before{
  content:''; position:absolute; left:0; right:0; top:0; height:2px;
  background:linear-gradient(90deg, transparent, rgba(0,229,255,.85), transparent);
  animation: jvScan 4.2s linear infinite;
}
.jarvis-hud::after{
  content:''; position:absolute; inset:0; pointer-events:none;
  background:repeating-linear-gradient( to bottom, rgba(0,229,255,.04) 0 1px, transparent 1px 3px );
  opacity:.45;
}
.jarvis-hud-grid{ display:grid; grid-template-columns:repeat(auto-fit, minmax(140px,1fr)); gap:10px; position:relative; z-index:1; }
.jarvis-hud-cell{
  border:1px solid rgba(124,58,237,.22); border-radius:10px; padding:8px 10px;
  background:rgba(7,16,38,.55); position:relative;
}
.jarvis-hud-cell .lbl{ font-size:10px; letter-spacing:.18em; text-transform:uppercase; color:#7689a8; }
.jarvis-hud-cell .val{ font-size:20px; font-weight:700; color:#e6f1ff; text-shadow:0 0 8px rgba(0,229,255,.35); animation:jvFlicker 6s infinite; }
.jarvis-hud-cell.ok .val{ color:#10f5a0; text-shadow:0 0 10px rgba(16,245,160,.35); }
.jarvis-hud-cell.warn .val{ color:#ffb547; text-shadow:0 0 10px rgba(255,181,71,.35); }
.jarvis-hud-cell.bad .val{ color:#ff3d6e; text-shadow:0 0 10px rgba(255,61,110,.35); }
.jarvis-hud-cell .dot{
  position:absolute; right:10px; top:10px; width:8px; height:8px; border-radius:50%;
  background:#00e5ff; box-shadow:0 0 12px #00e5ff; animation: jvPulse 1.8s ease-in-out infinite;
}
.jarvis-hud-cell.ok .dot{ background:#10f5a0; box-shadow:0 0 12px #10f5a0; }
.jarvis-hud-cell.warn .dot{ background:#ffb547; box-shadow:0 0 12px #ffb547; }
.jarvis-hud-cell.bad .dot{ background:#ff3d6e; box-shadow:0 0 12px #ff3d6e; }

.jv-ring{
  width:34px; height:34px; border-radius:50%;
  border:2px dashed rgba(0,229,255,.45); border-top-color:rgba(124,58,237,.7);
  animation: jvRotate 6s linear infinite;
  display:inline-block; vertical-align:middle; margin-right:8px;
}

.jv-strip{
  display:flex; flex-wrap:wrap; gap:8px; align-items:center;
  font-size:11px; letter-spacing:.14em; text-transform:uppercase; color:#7689a8;
  border-top:1px dashed rgba(124,58,237,.2); margin-top:10px; padding-top:8px;
  position:relative; z-index:1;
}
.jv-strip b{ color:#e6f1ff; letter-spacing:.05em; }

/* Kanban polishing */
.kanban-col.dragover{ box-shadow:0 0 0 2px rgba(0,229,255,.5) inset; background:rgba(0,229,255,.04); }
.kanban-card.dragging{ opacity:.4; }

/* Onboarding checklist buttons */
#onbChecklist .ghost{ filter:saturate(.6); }
#onbChecklist button{ animation: jvFlicker 9s infinite; }

