/* ── VARIABLES ─────────────────────────────────────────────── */
:root {
  --gold: #E8450A; --gold-light: #FF7043;
  --dark: #0A0E1A; --dark2: #111827; --dark3: #1C2333; --dark4: #232D42;
  --text: #E8EDF5; --muted: #8A94A8;
  --green: #10B981; --red: #EF4444; --blue: #3B82F6;
  --border: rgba(232,69,10,0.15); --iborder: rgba(255,255,255,0.1);
}
*{ margin:0; padding:0; box-sizing:border-box; }
html{ scroll-behavior:smooth; }
body{ background:var(--dark); color:var(--text); font-family:'DM Sans',sans-serif; overflow-x:hidden; }


/* ── FLASH ─────────────────────────────────────────────────── */
.flash{
  position:fixed; top:20px; right:20px; z-index:9999;
  padding:13px 20px; border-radius:10px; font-size:.87rem;
  display:flex; align-items:center; gap:10px; max-width:340px;
  animation:slideIn .4s cubic-bezier(.34,1.56,.64,1);
}
.flash-success{ background:var(--dark3); border:1px solid var(--green); }
.flash-error  { background:var(--dark3); border:1px solid var(--red); }
@keyframes slideIn{ from{transform:translateX(120%);opacity:0} to{transform:translateX(0);opacity:1} }

/* ── LOGO ──────────────────────────────────────────────────── */
.logo{ font-family:'Playfair Display',serif; font-size:1.45rem; font-weight:700; color:var(--gold); text-decoration:none; letter-spacing:.4px; }
.logo em{ color:var(--text); font-style:normal; }

/* ── BUTTONS ───────────────────────────────────────────────── */
.btn-primary{
  padding:10px 24px; background:linear-gradient(135deg,var(--gold),#C0380A);
  border-radius:6px; color:#0A0E1A; text-decoration:none; font-size:.88rem;
  font-weight:600; transition:all .25s; border:none; cursor:pointer;
}
.btn-primary:hover{ transform:translateY(-1px); box-shadow:0 8px 24px rgba(232,69,10,.35); }
.btn-outline{
  padding:10px 22px; border:1px solid var(--border); border-radius:6px;
  color:var(--text); text-decoration:none; font-size:.88rem; font-weight:500;
  transition:all .2s; background:transparent; cursor:pointer;
}
.btn-outline:hover{ border-color:var(--gold); color:var(--gold); }

/* ── NAV (landing page only — scoped to avoid bleeding into .sidebar-nav) ── */
body:not(.app-body) nav {
  position:fixed; top: 0; width:100%; z-index:100; padding:20px 60px;
  display:flex; align-items:center; justify-content:space-between;
  background:rgba(10,14,26,0.85); backdrop-filter:blur(16px);
  border-bottom:1px solid var(--border);
}
.nav-links{ display:flex; gap:36px; list-style:none; }
.nav-links a{ color:var(--muted); text-decoration:none; font-size:.9rem; font-weight:500; transition:color .2s; }
.nav-links a:hover{ color:var(--gold); }
.nav-cta{ display:flex; gap:12px; align-items:center; }

/* ── HERO ──────────────────────────────────────────────────── */
.hero{
  min-height:100vh; padding:60px 60px 80px;
  display:flex; align-items:center; position:relative; overflow:hidden;
}
.hero-bg{
  position:absolute; inset:0;
  background: radial-gradient(ellipse 80% 60% at 70% 50%,rgba(232,69,10,.07) 0%,transparent 60%),
              radial-gradient(ellipse 50% 80% at 10% 80%,rgba(59,130,246,.05) 0%,transparent 50%);
}
.hero-grid{
  position:absolute; inset:0;
  background-image:linear-gradient(rgba(232,69,10,.04) 1px,transparent 1px),linear-gradient(90deg,rgba(232,69,10,.04) 1px,transparent 1px);
  background-size:60px 60px;
}
.hero-content{ position:relative; z-index:2; max-width:680px; animation:fadeUp .8s ease .2s both; }
.hero-badge{
  display:inline-flex; align-items:center; gap:8px;
  background:rgba(232,69,10,.1); border:1px solid rgba(232,69,10,.25);
  border-radius:100px; padding:6px 16px; font-size:.8rem; color:var(--gold-light);
  margin-bottom:28px; font-weight:500;
}
.hero-badge::before{ content:''; width:6px; height:6px; border-radius:50%; background:var(--green); animation:pulse 2s infinite; }
.hero h1{ font-family:'Playfair Display',serif; font-size:clamp(2.8rem,5vw,4.2rem); line-height:1.15; font-weight:700; margin-bottom:24px; }
.hero h1 .highlight{ background:linear-gradient(135deg,var(--gold),var(--gold-light)); -webkit-background-clip:text; -webkit-text-fill-color:transparent; }
.hero p{ font-size:1.1rem; color:var(--muted); line-height:1.7; margin-bottom:40px; max-width:520px; font-weight:300; }
.hero-actions{ display:flex; gap:14px; flex-wrap:wrap; }
.hero-actions .btn-primary,.hero-actions .btn-outline{ padding:14px 32px; font-size:.95rem; }
.hero-stats{ display:flex; gap:40px; margin-top:56px; flex-wrap:wrap; }
.stat-item{ display:flex; flex-direction:column; gap:4px; }
.stat-num{ font-family:'Playfair Display',serif; font-size:1.9rem; font-weight:700; color:var(--gold); }
.stat-label{ font-size:.82rem; color:var(--muted); }
.hero-visual{ position:absolute; right:60px; top:50%; transform:translateY(-50%); width:420px; animation:fadeLeft .9s ease .4s both; }

/* ── CHART CARD ────────────────────────────────────────────── */
.chart-card{
  background:var(--dark3); border:1px solid var(--border); border-radius:16px; padding:28px;
  position:relative; overflow:hidden;
}
.chart-card::before{ content:''; position:absolute; top:0; left:0; right:0; height:2px; background:linear-gradient(90deg,transparent,var(--gold),transparent); }
.card-header{ display:flex; justify-content:space-between; align-items:center; margin-bottom:20px; }
.card-title{ font-size:.85rem; color:var(--muted); }
.card-value{ font-family:'Playfair Display',serif; font-size:1.6rem; }
.card-change{ font-size:.8rem; color:var(--green); font-weight:600; background:rgba(16,185,129,.1); padding:3px 8px; border-radius:4px; }
.mini-chart{ width:100%; margin:16px 0; }
.portfolio-items{ display:flex; flex-direction:column; gap:12px; }
.portfolio-item{ display:flex; align-items:center; justify-content:space-between; }
.portfolio-label{ display:flex; align-items:center; gap:10px; font-size:.83rem; color:var(--muted); }
.dot{ width:8px; height:8px; border-radius:50%; }
.portfolio-bar-wrap{ flex:1; margin:0 16px; height:4px; background:var(--dark4); border-radius:2px; overflow:hidden; }
.portfolio-bar{ height:100%; border-radius:2px; transition:width 1.5s ease; }
.portfolio-val{ font-size:.83rem; font-weight:600; }

/* ── SECTIONS ──────────────────────────────────────────────── */
section{ padding:100px 60px; }
.section-badge{ display:inline-block; font-size:.75rem; font-weight:600; letter-spacing:2px; text-transform:uppercase; color:var(--gold); margin-bottom:16px; }
.section-title{ font-family:'Playfair Display',serif; font-size:clamp(1.9rem,3.5vw,2.8rem); font-weight:700; line-height:1.25; margin-bottom:16px; }
.section-sub{ color:var(--muted); font-size:1rem; line-height:1.7; max-width:500px; font-weight:300; }

/* ── FEATURES ──────────────────────────────────────────────── */
.features{ background:var(--dark2); }
.features-header{ display:flex; justify-content:space-between; align-items:flex-end; margin-bottom:60px; flex-wrap:wrap; gap:24px; }
.features-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:24px; }
.feature-card{ background:var(--dark3); border:1px solid var(--border); border-radius:14px; padding:32px; transition:all .3s; position:relative; overflow:hidden; }
.feature-card:hover{ border-color:rgba(232,69,10,.4); transform:translateY(-4px); box-shadow:0 20px 40px rgba(0,0,0,.3); }
.feature-card::after{ content:''; position:absolute; bottom:0; left:0; right:0; height:2px; background:linear-gradient(90deg,transparent,var(--gold),transparent); opacity:0; transition:opacity .3s; }
.feature-card:hover::after{ opacity:1; }
.feature-icon{ width:48px; height:48px; border-radius:12px; background:rgba(232,69,10,.1); border:1px solid rgba(232,69,10,.2); display:flex; align-items:center; justify-content:center; font-size:1.4rem; margin-bottom:20px; }
.feature-card h3{ font-size:1.05rem; font-weight:600; margin-bottom:10px; }
.feature-card p{ font-size:.87rem; color:var(--muted); line-height:1.65; font-weight:300; }

/* ── PLANS ─────────────────────────────────────────────────── */
.plans-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:24px; margin-top:56px; }
.plan-card{ background:var(--dark3); border:1px solid var(--border); border-radius:16px; padding:36px 32px; position:relative; transition:border-color .25s, transform .25s; }
.plan-card:hover{ transform:translateY(-3px); border-color:rgba(232,69,10,.35); }
.plan-card.featured{ border-color:var(--gold); background:linear-gradient(145deg,var(--dark3),rgba(232,69,10,.05)); }
.plan-badge{ position:absolute; top:-12px; left:50%; transform:translateX(-50%); background:var(--gold); color:#0A0E1A; font-size:.72rem; font-weight:700; letter-spacing:1px; text-transform:uppercase; padding:4px 14px; border-radius:100px; }
.plan-name{ font-family:'Playfair Display',serif; font-size:1.3rem; font-weight:600; margin-bottom:6px; }
.plan-desc{ font-size:.82rem; color:var(--muted); margin-bottom:24px; font-weight:300; }
.plan-range{ display:flex; justify-content:space-between; background:var(--dark4); border-radius:8px; padding:12px 16px; margin-bottom:24px; }
.range-item{ display:flex; flex-direction:column; gap:3px; }
.range-label{ font-size:.72rem; color:var(--muted); text-transform:uppercase; letter-spacing:1px; }
.range-val{ font-size:.95rem; font-weight:600; }
.plan-features{ list-style:none; display:flex; flex-direction:column; gap:10px; margin-bottom:28px; }
.plan-features li{ font-size:.85rem; color:var(--muted); display:flex; align-items:center; gap:8px; }
.plan-features li::before{ content:'✓'; color:var(--green); font-weight:700; flex-shrink:0; }
.plan-cta{ display:block; text-align:center; padding:12px; border-radius:8px; font-size:.88rem; font-weight:600; text-decoration:none; transition:all .25s; }
.plan-card:not(.featured) .plan-cta{ border:1px solid var(--border); color:var(--text); }
.plan-card:not(.featured) .plan-cta:hover{ border-color:var(--gold); color:var(--gold); }
.plan-card.featured .plan-cta{ background:linear-gradient(135deg,var(--gold),#C0380A); color:#0A0E1A; }
.plan-card.featured .plan-cta:hover{ opacity:.9; }

/* ── HOW IT WORKS ──────────────────────────────────────────── */
.how{ background:var(--dark2); }
.steps-grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:0; margin-top:56px; position:relative; }
.steps-grid::before{ content:''; position:absolute; top:28px; left:12.5%; right:12.5%; height:1px; background:linear-gradient(90deg,transparent,var(--gold),var(--gold),var(--gold),transparent); opacity:.2; }
.step{ text-align:center; padding:0 24px; }
.step-num{ width:56px; height:56px; border-radius:50%; border:1px solid var(--gold); display:flex; align-items:center; justify-content:center; margin:0 auto 24px; font-family:'Playfair Display',serif; font-size:1.2rem; color:var(--gold); background:var(--dark2); position:relative; z-index:1; }
.step h3{ font-size:1rem; font-weight:600; margin-bottom:10px; }
.step p{ font-size:.83rem; color:var(--muted); line-height:1.6; font-weight:300; }

/* ── TESTIMONIALS ──────────────────────────────────────────── */
.testimonials-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:24px; margin-top:56px; }
.testimonial-card{ background:var(--dark3); border:1px solid var(--border); border-radius:14px; padding:28px; transition:all .3s; }
.testimonial-card:hover{ border-color:rgba(232,69,10,.3); }
.stars{ color:var(--gold); font-size:.85rem; margin-bottom:14px; letter-spacing:2px; }
.testimonial-text{ font-size:.88rem; color:var(--muted); line-height:1.7; font-weight:300; margin-bottom:20px; font-style:italic; }
.reviewer{ display:flex; align-items:center; gap:12px; }
.reviewer-avatar{ width:36px; height:36px; border-radius:50%; background:linear-gradient(135deg,var(--gold),#6C3A1F); display:flex; align-items:center; justify-content:center; font-size:.8rem; font-weight:700; color:#0A0E1A; flex-shrink:0; }
.reviewer-name{ font-size:.88rem; font-weight:600; }
.reviewer-role{ font-size:.75rem; color:var(--muted); }

/* ── CTA ───────────────────────────────────────────────────── */
.cta-section{ text-align:center; background:linear-gradient(145deg,var(--dark3),var(--dark2)); border-top:1px solid var(--border); border-bottom:1px solid var(--border); }
.cta-section p{ color:var(--muted); margin-bottom:36px; font-weight:300; }

/* ── FOOTER ────────────────────────────────────────────────── */
footer{ background:var(--dark); padding:60px 60px 32px; border-top:1px solid var(--border); }
.footer-top{ display:grid; grid-template-columns:2fr 1fr 1fr 1fr; gap:60px; margin-bottom:48px; }
.footer-brand p{ font-size:.85rem; color:var(--muted); line-height:1.7; margin-top:14px; font-weight:300; max-width:280px; }
.footer-col h4{ font-size:.82rem; font-weight:600; letter-spacing:1px; text-transform:uppercase; color:var(--gold); margin-bottom:16px; }
.footer-col ul{ list-style:none; display:flex; flex-direction:column; gap:10px; }
.footer-col a{ font-size:.85rem; color:var(--muted); text-decoration:none; transition:color .2s; }
.footer-col a:hover{ color:var(--text); }
.footer-bottom{ border-top:1px solid var(--border); padding-top:24px; display:flex; justify-content:space-between; align-items:center; font-size:.8rem; color:var(--muted); flex-wrap:wrap; gap:12px; }
.footer-bottom a{ color:var(--muted); text-decoration:none; }
.footer-bottom a:hover{ color:var(--gold); }

/* ── AUTH PAGE ─────────────────────────────────────────────── */
.auth-wrapper{ display:grid; grid-template-columns:1fr 1fr; min-height:100vh; }
.panel-left{ background:var(--dark3); border-right:1px solid var(--border); padding:64px 52px; display:flex; flex-direction:column; justify-content:center; position:relative; overflow:hidden; }
.panel-left::before{ content:''; position:absolute; inset:0; background:radial-gradient(ellipse 80% 60% at 25% 45%,rgba(232,69,10,.07) 0%,transparent 65%); }
.panel-left::after{ content:''; position:absolute; inset:0; background-image:linear-gradient(rgba(232,69,10,.03) 1px,transparent 1px),linear-gradient(90deg,rgba(232,69,10,.03) 1px,transparent 1px); background-size:52px 52px; }
.panel-left-inner{ position:relative; z-index:2; }
.pl-tagline{ display:inline-flex; align-items:center; gap:7px; background:rgba(232,69,10,.1); border:1px solid rgba(232,69,10,.25); border-radius:100px; padding:5px 14px; font-size:.75rem; color:var(--gold-light); font-weight:600; letter-spacing:.5px; margin-bottom:26px; }
.pl-tagline::before{ content:''; width:6px; height:6px; border-radius:50%; background:var(--green); animation:pulse 2s infinite; }
.pl-title{ font-family:'Playfair Display',serif; font-size:2.1rem; font-weight:700; line-height:1.2; margin-bottom:14px; }
.pl-title span{ background:linear-gradient(135deg,var(--gold),var(--gold-light)); -webkit-background-clip:text; -webkit-text-fill-color:transparent; }
.pl-sub{ color:var(--muted); font-size:.92rem; line-height:1.7; font-weight:300; margin-bottom:38px; }
.trust-list{ display:flex; flex-direction:column; gap:18px; }
.trust-item{ display:flex; align-items:flex-start; gap:14px; }
.trust-icon{ width:42px; height:42px; flex-shrink:0; border-radius:10px; background:rgba(232,69,10,.1); border:1px solid rgba(232,69,10,.2); display:flex; align-items:center; justify-content:center; font-size:1.15rem; }
.trust-item h4{ font-size:.88rem; font-weight:600; margin-bottom:3px; }
.trust-item p{ font-size:.78rem; color:var(--muted); line-height:1.5; }
.stats-row{ display:flex; margin-top:36px; border:1px solid var(--border); border-radius:10px; overflow:hidden; }
.stat{ flex:1; padding:14px; text-align:center; border-right:1px solid var(--border); }
.stat:last-child{ border-right:none; }
.stat-n{ font-family:'Playfair Display',serif; font-size:1.25rem; font-weight:700; color:var(--gold); }
.stat-l{ font-size:.7rem; color:var(--muted); margin-top:2px; }
.panel-right{ background:var(--dark2); padding:60px 52px; display:flex; flex-direction:column; justify-content:center; }
.tabs{ display:flex; background:var(--dark4); border-radius:10px; padding:4px; margin-bottom:34px; }
.tab{ flex:1; padding:11px; border:none; background:transparent; color:var(--muted); font-family:'DM Sans',sans-serif; font-size:.9rem; font-weight:500; border-radius:7px; cursor:pointer; transition:all .25s; }
.tab.on{ background:linear-gradient(135deg,var(--gold),#C0380A); color:#0A0E1A; font-weight:700; }
.form{ display:none; animation:fadeIn .3s ease; }
.form.on{ display:block; }
.f-title{ font-family:'Playfair Display',serif; font-size:1.55rem; font-weight:700; margin-bottom:5px; }
.f-sub{ color:var(--muted); font-size:.82rem; margin-bottom:26px; font-weight:300; }
.row2{ display:grid; grid-template-columns:1fr 1fr; gap:14px; }
.field{ display:flex; flex-direction:column; gap:6px; margin-bottom:15px; }
.field label{ font-size:.8rem; font-weight:500; color:var(--muted); letter-spacing:.3px; }
.iw{ position:relative; }
.iw .ic{ position:absolute; left:13px; top:50%; transform:translateY(-50%); font-size:.9rem; color:var(--muted); pointer-events:none; line-height:1; }
.iw input,.iw select{ width:100%; padding:11px 14px 11px 38px; background:var(--dark3); border:1px solid var(--iborder); border-radius:8px; color:var(--text); font-family:'DM Sans',sans-serif; font-size:.88rem; outline:none; transition:border-color .2s,box-shadow .2s; -webkit-appearance:none; }
.iw input::placeholder{ color:var(--muted); opacity:.55; }
.iw input:focus,.iw select:focus{ border-color:var(--gold); box-shadow:0 0 0 3px rgba(232,69,10,.12); }
.eye{ position:absolute; right:13px; top:50%; transform:translateY(-50%); cursor:pointer; font-size:.95rem; color:var(--muted); background:none; border:none; padding:0; transition:color .2s; line-height:1; }
.eye:hover{ color:var(--gold); }
.pws{ margin-top:5px; }
.pws-bar{ height:3px; background:var(--dark4); border-radius:2px; overflow:hidden; margin-bottom:4px; }
.pws-fill{ height:100%; border-radius:2px; transition:width .3s,background .3s; width:0; }
.pws-txt{ font-size:.7rem; color:var(--muted); }
.cbox{ display:flex; align-items:flex-start; gap:9px; margin-bottom:18px; }
.cbox input[type=checkbox]{ width:15px; height:15px; flex-shrink:0; margin-top:2px; accent-color:var(--gold); cursor:pointer; }
.cbox label{ font-size:.8rem; color:var(--muted); line-height:1.5; cursor:pointer; }
.cbox a{ color:var(--gold-light); text-decoration:none; }
.forgot{ text-align:right; margin-top:-8px; margin-bottom:14px; }
.forgot a{ font-size:.76rem; color:var(--muted); text-decoration:none; }
.forgot a:hover{ color:var(--gold); }
.submit{ width:100%; padding:13px; border:none; border-radius:8px; background:linear-gradient(135deg,var(--gold),#C0380A); color:#0A0E1A; font-family:'DM Sans',sans-serif; font-size:.92rem; font-weight:700; cursor:pointer; letter-spacing:.3px; transition:all .25s; }
.submit:hover{ transform:translateY(-2px); box-shadow:0 10px 28px rgba(232,69,10,.35); }
.submit:disabled{ opacity:.55; cursor:not-allowed; transform:none; }
.switch{ text-align:center; margin-top:18px; font-size:.8rem; color:var(--muted); }
.switch a{ color:var(--gold-light); text-decoration:none; cursor:pointer; }

/* ── DISCLAIMER ────────────────────────────────────────────── */
.disclaimer{ background:rgba(232,69,10,.05); border:1px solid rgba(232,69,10,.15); border-radius:10px; padding:16px 20px; font-size:.78rem; color:var(--muted); line-height:1.6; margin-top:40px; max-width:760px; }
.disclaimer strong{ color:var(--gold-light); }
.disclaimer a{ color:var(--gold-light); text-decoration:none; }

/* ── ANIMATIONS ────────────────────────────────────────────── */
@keyframes fadeUp{ from{opacity:0;transform:translateY(24px)} to{opacity:1;transform:translateY(0)} }
@keyframes fadeLeft{ from{opacity:0;transform:translateX(40px) translateY(-50%)} to{opacity:1;transform:translateX(0) translateY(-50%)} }
@keyframes fadeIn{ from{opacity:0;transform:translateY(8px)} to{opacity:1;transform:translateY(0)} }
@keyframes pulse{ 0%,100%{opacity:1;transform:scale(1)} 50%{opacity:.5;transform:scale(.8)} }
.reveal{ opacity:0; transform:translateY(30px); transition:opacity .7s ease,transform .7s ease; }
.reveal.visible{ opacity:1; transform:translateY(0); }
.reveal-delay-1{ transition-delay:.1s; }
.reveal-delay-2{ transition-delay:.2s; }
.reveal-delay-3{ transition-delay:.3s; }

/* ── MOBILE ────────────────────────────────────────────────── */
@media(max-width:900px){
  body:not(.app-body) nav{
    
    padding:0 20px;
    height:60px;
    display:flex;
    align-items:center;
    justify-content:space-between;
    flex-wrap:nowrap;
  }
  .nav-links{ display:none; }
  .logo{ font-size:1.05rem; flex-shrink:0; }
  .nav-cta{
    display:flex;
    align-items:center;
    gap:8px;
    flex-shrink:0;
  }
  .nav-cta .btn-outline,
  .nav-cta .btn-primary{
    padding:7px 12px;
    font-size:.76rem;
    white-space:nowrap;
  }
  section{ padding:70px 24px; }
  .hero{ padding:43px 24px 60px; }
  .hero-visual{ display:none; }
  .features-grid,.plans-grid,.steps-grid,.testimonials-grid{ grid-template-columns:1fr; }
  .footer-top{ grid-template-columns:1fr 1fr; gap:32px; }
  .auth-wrapper{ grid-template-columns:1fr; }
  .panel-left{ display:none; }
  .panel-right{ padding:40px 24px; }
  .row2{ grid-template-columns:1fr; }
}
/* ── MARKET TICKER BAR ──────────────────────────────────────── */
.market-ticker-wrap {
  position: relative;
  width: 100%;
  height: 46px;
  margin-top: 80px;
  background: #0d1117;
  border-bottom: 1px solid rgba(232,69,10,.2);
  overflow: hidden;
  z-index: 1;
}
@media (max-width: 900px) {
  .market-ticker-wrap {
    margin-top: 50px;
    height: 70px;
  }
}
@media (max-width: 900px) {
}