/* ============================================================
   4cast-ai  —  styles.css  v2.0
   Clean · White · Modern SaaS — Apple-inspired
   ============================================================ */

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

:root {
  --bg:          #FFFFFF;
  --bg-2:        #F5F5F7;
  --bg-3:        #FAFAFA;
  --bg-blue:     #EFF6FF;
  --bg-green:    #F0FDF4;
  --bg-dark:     #0A0A0A;
  --text:        #1D1D1F;
  --text-2:      #3D3D3F;
  --text-muted:  #6E6E73;
  --text-dim:    #AEAEB2;
  --text-white:  #FFFFFF;
  --blue:        #2563EB;
  --blue-dark:   #1D4ED8;
  --blue-light:  #3B82F6;
  --blue-tint:   #EFF6FF;
  --blue-border: #BFDBFE;
  --green:       #10B981;
  --green-tint:  #ECFDF5;
  --border:      #E5E7EB;
  --border-2:    #D1D5DB;
  --shadow-xs:   0 1px 2px rgba(0,0,0,0.05);
  --shadow-sm:   0 1px 3px rgba(0,0,0,0.08), 0 1px 2px rgba(0,0,0,0.04);
  --shadow-md:   0 4px 16px rgba(0,0,0,0.08), 0 2px 4px rgba(0,0,0,0.04);
  --shadow-lg:   0 20px 40px rgba(0,0,0,0.10), 0 8px 16px rgba(0,0,0,0.06);
  --shadow-xl:   0 32px 64px rgba(0,0,0,0.12), 0 16px 32px rgba(0,0,0,0.08);
  --shadow-blue: 0 8px 24px rgba(37,99,235,0.25);
  --font: -apple-system, BlinkMacSystemFont, "SF Pro Display", "SF Pro Text", "Inter", "Helvetica Neue", Arial, sans-serif;

  /* ── Legacy variable aliases (backward-compat for inner pages) ── */
  --space-1:  var(--s1); --space-2:  var(--s2); --space-3:  var(--s3);
  --space-4:  var(--s4); --space-5:  var(--s5); --space-6:  var(--s6);
  --space-7:  var(--s7); --space-8:  var(--s8); --space-10: var(--s10);
  --space-12: var(--s12); --space-16: var(--s16); --space-24: var(--s24);
  --size-xs:   var(--text-xs);
  --size-sm:   var(--text-sm);
  --size-base: var(--text-base);
  --size-lg:   var(--text-lg);
  --size-xl:   var(--text-xl);
  --size-2xl:  var(--text-2xl);
  --size-hero: var(--text-hero);
  --black-2:   var(--bg-2);
  --black-3:   var(--bg-3);
  --sand:      var(--blue);
  --accent:    var(--blue);
  --error:     #EF4444;
  --success:   var(--green);
  --border-sand: var(--border-2);
  /* More legacy aliases */
  --black-4:     #0A0A0A;
  --radius:      var(--r);
  --radius-sm:   var(--r-sm);
  --radius-lg:   var(--r-lg);
  --radius-xl:   var(--r-xl);
  --text-primary: var(--text);
  --transition:  var(--t);
  --warning:     #F59E0B;
  --font-mono: "SF Mono", "Fira Code", Consolas, monospace;
  --text-xs:    0.75rem;  --text-sm:   0.875rem; --text-base: 1rem;
  --text-lg:    1.125rem; --text-xl:   1.25rem;  --text-2xl:  1.5rem;
  --text-3xl:   2rem;     --text-4xl:  2.75rem;
  --text-hero:  clamp(2.4rem, 5.5vw, 4.2rem);
  --s1:.25rem;--s2:.5rem;--s3:.75rem;--s4:1rem;--s5:1.25rem;--s6:1.5rem;
  --s8:2rem;--s10:2.5rem;--s12:3rem;--s16:4rem;--s20:5rem;--s24:6rem;
  --r-sm:6px;--r:10px;--r-lg:14px;--r-xl:20px;--r-2xl:28px;
  --t:0.18s ease;--t-slow:0.35s ease;
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--font);background:var(--bg);color:var(--text);line-height:1.65;font-size:var(--text-base);-webkit-font-smoothing:antialiased;overflow-x:hidden}
img,svg{max-width:100%;display:block}
a{color:var(--blue);text-decoration:none;transition:color var(--t)}
a:hover{color:var(--blue-dark)}
button{font-family:var(--font);cursor:pointer;border:none}
input,select,textarea{font-family:var(--font)}

.container{max-width:1140px;margin:0 auto;padding:0 var(--s6)}
.section{padding:var(--s24) 0}
.section-sm{padding:var(--s16) 0}

/* NAV */
.nav{position:fixed;top:0;left:0;right:0;z-index:1000;padding:var(--s4) 0;transition:all var(--t-slow)}
.nav.scrolled{background:rgba(255,255,255,0.92);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-bottom:1px solid var(--border);padding:var(--s3) 0;box-shadow:var(--shadow-sm)}
.nav-inner{display:flex;align-items:center;justify-content:space-between;max-width:1140px;margin:0 auto;padding:0 var(--s6)}
.nav-logo{font-size:1.25rem;font-weight:800;color:var(--text);letter-spacing:-0.03em;text-decoration:none}
.nav-logo span{color:var(--blue)}
.nav-links{display:flex;align-items:center;gap:var(--s8);list-style:none}
.nav-links a{color:var(--text-muted);font-size:var(--text-sm);font-weight:500;transition:color var(--t)}
.nav-links a:hover,.nav-links a.active{color:var(--text)}
.nav-ctas{display:flex;align-items:center;gap:var(--s3)}
.nav-toggle{display:none;flex-direction:column;gap:5px;background:none;padding:var(--s2)}
.nav-toggle span{display:block;width:22px;height:2px;background:var(--text);transition:transform var(--t);border-radius:2px}
.nav-mobile{display:none;flex-direction:column;background:var(--bg);border-top:1px solid var(--border);padding:var(--s4) var(--s6);gap:var(--s3)}
.nav-mobile a{color:var(--text-muted);font-size:var(--text-sm);font-weight:500;padding:var(--s2) 0}
.nav-mobile a:hover{color:var(--text)}
.nav-mobile .btn{text-align:center}
.nav-mobile.open{display:flex}

/* BUTTONS */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--s2);padding:.6em 1.3em;font-size:var(--text-sm);font-family:var(--font);font-weight:600;border-radius:var(--r);transition:all var(--t);white-space:nowrap;cursor:pointer;text-decoration:none;letter-spacing:-.01em}
.btn-primary{background:var(--blue);color:#fff;border:1.5px solid var(--blue)}
.btn-primary:hover{background:var(--blue-dark);border-color:var(--blue-dark);box-shadow:var(--shadow-blue);color:#fff;transform:translateY(-1px)}
.btn-outline{background:transparent;color:var(--text);border:1.5px solid var(--border-2)}
.btn-outline:hover{border-color:var(--text);color:var(--text);background:var(--bg-2)}
.btn-ghost{background:transparent;color:var(--text-muted);border:none}
.btn-ghost:hover{color:var(--text);background:var(--bg-2)}
.btn-dark{background:var(--text);color:#fff;border:1.5px solid var(--text)}
.btn-dark:hover{background:#333;border-color:#333;color:#fff;transform:translateY(-1px)}
.btn-sm{padding:.4em .9em;font-size:var(--text-xs)}
.btn-lg{padding:.8em 1.8em;font-size:var(--text-base)}
.btn-xl{padding:1em 2.2em;font-size:var(--text-lg);border-radius:var(--r-lg)}
.btn:disabled{opacity:.45;cursor:not-allowed;transform:none!important}
.btn.loading::after{content:'';width:14px;height:14px;border:2px solid currentColor;border-top-color:transparent;border-radius:50%;animation:spin .6s linear infinite;margin-left:var(--s2)}

/* SECTION HEADERS */
.eyebrow{display:inline-flex;align-items:center;gap:var(--s2);font-size:var(--text-xs);font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--blue);margin-bottom:var(--s4);background:var(--blue-tint);padding:.3em .8em;border-radius:999px;border:1px solid var(--blue-border)}
.section-title{font-size:clamp(1.8rem,3.5vw,2.6rem);font-weight:800;letter-spacing:-.03em;line-height:1.15;color:var(--text);margin-bottom:var(--s4)}
.section-sub{font-size:var(--text-lg);color:var(--text-muted);max-width:520px;line-height:1.7;margin-bottom:var(--s12)}
.text-center{text-align:center}
.text-center .section-sub{margin-left:auto;margin-right:auto}

/* HERO */
.hero{padding:130px 0 var(--s20);background:var(--bg);position:relative;overflow:hidden}
.hero::before{content:'';position:absolute;top:-200px;right:-200px;width:600px;height:600px;background:radial-gradient(circle,rgba(37,99,235,.08) 0%,transparent 70%);border-radius:50%;pointer-events:none}
.hero::after{content:'';position:absolute;bottom:-100px;left:-100px;width:400px;height:400px;background:radial-gradient(circle,rgba(16,185,129,.06) 0%,transparent 70%);border-radius:50%;pointer-events:none}
.hero-inner{display:grid;grid-template-columns:1fr 1fr;gap:var(--s16);align-items:center;position:relative;z-index:1}
.hero-label{display:inline-flex;align-items:center;gap:var(--s2);font-size:var(--text-xs);font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--blue);margin-bottom:var(--s5);background:var(--blue-tint);padding:.35em .9em;border-radius:999px;border:1px solid var(--blue-border)}
.hero h1{font-size:var(--text-hero);font-weight:800;letter-spacing:-.04em;line-height:1.08;color:var(--text);margin-bottom:var(--s6)}
.hero h1 .accent{color:var(--blue)}
.hero-sub{font-size:var(--text-lg);color:var(--text-muted);max-width:480px;line-height:1.7;margin-bottom:var(--s8)}
.hero-ctas{display:flex;gap:var(--s3);flex-wrap:wrap}
.hero-trust{display:flex;align-items:center;gap:var(--s3);margin-top:var(--s5);font-size:var(--text-xs);color:var(--text-dim);flex-wrap:wrap}
.hero-trust-dot{width:4px;height:4px;border-radius:50%;background:var(--border-2)}
.hero-visual{position:relative}
.dashboard-frame{background:var(--bg);border-radius:var(--r-2xl);box-shadow:var(--shadow-xl);border:1px solid var(--border);overflow:hidden;transform:perspective(1200px) rotateY(-4deg) rotateX(2deg);transition:transform .6s ease}
.dashboard-frame:hover{transform:perspective(1200px) rotateY(-1deg) rotateX(1deg)}
.dashboard-frame-bar{background:var(--bg-2);border-bottom:1px solid var(--border);padding:var(--s3) var(--s4);display:flex;align-items:center;gap:var(--s2)}
.frame-dot{width:10px;height:10px;border-radius:50%}
.frame-dot.r{background:#FF5F57}.frame-dot.y{background:#FFBD2E}.frame-dot.g{background:#28C840}
.hero-badge{position:absolute;background:var(--bg);border:1px solid var(--border);border-radius:var(--r-lg);padding:var(--s3) var(--s4);box-shadow:var(--shadow-md);font-size:var(--text-xs);font-weight:600;color:var(--text);display:flex;align-items:center;gap:var(--s2);animation:float 4s ease-in-out infinite}
.hero-badge.badge-1{bottom:-16px;left:-20px;animation-delay:0s}
.hero-badge.badge-2{top:30px;right:-24px;animation-delay:1.5s}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-6px)}}

/* STATS BAR */
.stats-bar{background:var(--bg-2);border-top:1px solid var(--border);border-bottom:1px solid var(--border);padding:var(--s8) 0}
.stats-bar-inner{display:flex;align-items:center;justify-content:center;gap:var(--s16);flex-wrap:wrap}
.stat-item{text-align:center}
.stat-number{font-size:var(--text-3xl);font-weight:800;color:var(--text);letter-spacing:-.04em;line-height:1}
.stat-number.blue{color:var(--blue)}
.stat-label{font-size:var(--text-xs);color:var(--text-muted);margin-top:var(--s1);font-weight:500}
.stat-divider{width:1px;height:40px;background:var(--border-2)}

/* CARDS */
.card{background:var(--bg);border:1px solid var(--border);border-radius:var(--r-lg);padding:var(--s8);transition:all var(--t-slow)}
.card:hover{border-color:var(--border-2);box-shadow:var(--shadow-md);transform:translateY(-2px)}
.card-icon{width:48px;height:48px;border-radius:var(--r);display:flex;align-items:center;justify-content:center;margin-bottom:var(--s4);font-size:1.4rem}
.icon-blue{background:var(--blue-tint)}
.icon-green{background:var(--green-tint)}
.icon-purple{background:#F5F3FF}
.icon-orange{background:#FFF7ED}
.icon-pink{background:#FDF2F8}
.icon-teal{background:#F0FDFA}
.card-title{font-size:var(--text-base);font-weight:700;margin-bottom:var(--s2);color:var(--text)}
.card-text{font-size:var(--text-sm);color:var(--text-muted);line-height:1.7}

/* GRIDS */
.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--s6)}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--s6)}
.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--s6)}

/* STEPS */
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--s8);position:relative}
.steps::before{content:'';position:absolute;top:22px;left:calc(16.7% + 20px);right:calc(16.7% + 20px);height:2px;background:linear-gradient(90deg,var(--blue-border),var(--blue),var(--blue-border));border-radius:1px}
.step{text-align:center;padding:var(--s6) var(--s4)}
.step-num{width:44px;height:44px;border-radius:50%;background:var(--blue);color:white;display:flex;align-items:center;justify-content:center;font-size:var(--text-sm);font-weight:800;margin:0 auto var(--s4);position:relative;z-index:1;box-shadow:var(--shadow-blue)}
.step-title{font-weight:700;margin-bottom:var(--s2);font-size:var(--text-base)}
.step-text{font-size:var(--text-sm);color:var(--text-muted);line-height:1.7}

/* VIDEO */
.video-section{background:var(--text);color:var(--text-white);padding:var(--s24) 0;position:relative;overflow:hidden}
.video-section::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse 80% 60% at 50% 0%,rgba(37,99,235,.15) 0%,transparent 70%);pointer-events:none}
.video-wrapper{position:relative;border-radius:var(--r-2xl);overflow:hidden;box-shadow:var(--shadow-xl);border:1px solid rgba(255,255,255,.1);background:#111;aspect-ratio:16/9;max-width:900px;margin:0 auto}
.video-wrapper video{width:100%;height:100%;object-fit:cover;display:block}
.video-placeholder{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;background:linear-gradient(135deg,#0F172A 0%,#1E293B 50%,#0F172A 100%);gap:var(--s4)}
.video-play-btn{width:72px;height:72px;border-radius:50%;background:var(--blue);border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 0 0 12px rgba(37,99,235,.2);transition:all var(--t)}
.video-play-btn:hover{transform:scale(1.08);box-shadow:0 0 0 16px rgba(37,99,235,.25)}
.video-play-btn svg{margin-left:4px}
.video-coming-soon{font-size:var(--text-sm);color:rgba(255,255,255,.5);font-weight:500;text-align:center}

/* PRICING */
.pricing-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--s6);align-items:start}
.pricing-card{background:var(--bg);border:1.5px solid var(--border);border-radius:var(--r-xl);padding:var(--s8);position:relative;transition:all var(--t-slow)}
.pricing-card:hover{box-shadow:var(--shadow-md);transform:translateY(-3px)}
.pricing-card.featured{border-color:var(--blue);box-shadow:var(--shadow-blue);transform:translateY(-8px)}
.pricing-card.featured:hover{transform:translateY(-12px)}
.pricing-badge{position:absolute;top:-14px;left:50%;transform:translateX(-50%);background:var(--blue);color:white;font-size:var(--text-xs);font-weight:700;letter-spacing:.06em;text-transform:uppercase;padding:.3em 1em;border-radius:999px;white-space:nowrap}
.pricing-tier{font-size:var(--text-xs);font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--blue);margin-bottom:var(--s3)}
.pricing-price{display:flex;align-items:baseline;gap:2px;margin-bottom:var(--s2)}
.pricing-currency{font-size:var(--text-xl);color:var(--text-muted);font-weight:500}
.pricing-amount{font-size:3.2rem;font-weight:800;letter-spacing:-.04em;color:var(--text);line-height:1}
.pricing-period{font-size:var(--text-sm);color:var(--text-muted)}
.pricing-annual-note{font-size:var(--text-xs);color:var(--green);font-weight:600;margin-bottom:var(--s5)}
.pricing-divider{border:none;border-top:1px solid var(--border);margin:var(--s5) 0}
.pricing-features{list-style:none;display:flex;flex-direction:column;gap:var(--s3);margin-bottom:var(--s8)}
.pricing-features li{display:flex;gap:var(--s3);font-size:var(--text-sm);color:var(--text-muted);align-items:flex-start}
.pricing-features li::before{content:'✓';color:var(--green);font-weight:800;flex-shrink:0;margin-top:1px}
.pricing-features li.disabled{opacity:.35}
.pricing-features li.disabled::before{content:'—';color:var(--text-dim)}
.billing-toggle{display:flex;align-items:center;justify-content:center;gap:var(--s3);margin-bottom:var(--s12)}
.toggle-btn{font-family:var(--font);font-size:var(--text-sm);font-weight:500;background:none;border:1.5px solid var(--border);color:var(--text-muted);padding:.5em 1.3em;border-radius:var(--r-sm);cursor:pointer;transition:all var(--t)}
.toggle-btn.active{border-color:var(--blue);color:var(--blue);background:var(--blue-tint);font-weight:600}
.toggle-save{font-size:var(--text-xs);background:var(--green-tint);color:var(--green);padding:.15em .6em;border-radius:999px;font-weight:700}

/* FORMS */
.form-group{margin-bottom:var(--s5)}
label{display:block;font-size:var(--text-xs);font-weight:600;letter-spacing:.04em;text-transform:uppercase;color:var(--text-muted);margin-bottom:var(--s2)}
input[type="text"],input[type="email"],input[type="password"],select,textarea{width:100%;background:var(--bg);border:1.5px solid var(--border);color:var(--text);padding:.7em .95em;border-radius:var(--r);font-size:var(--text-sm);transition:border-color var(--t),box-shadow var(--t);outline:none;appearance:none;font-family:var(--font)}
input:focus,select:focus,textarea:focus{border-color:var(--blue);box-shadow:0 0 0 3px rgba(37,99,235,.12)}
input::placeholder,textarea::placeholder{color:var(--text-dim)}
select{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' fill='none'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%236E6E73' stroke-width='1.5'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 1em center;padding-right:2.5em}
textarea{resize:vertical;min-height:120px}
.form-error{font-size:var(--text-xs);color:#DC2626;margin-top:var(--s1)}
.form-hint{font-size:var(--text-xs);color:var(--text-dim);margin-top:var(--s1)}
.pw-strength{display:flex;gap:4px;margin-top:var(--s2)}
.pw-bar{height:3px;flex:1;background:var(--border);border-radius:2px;transition:background var(--t)}
.pw-bar.weak{background:#EF4444}.pw-bar.fair{background:#F59E0B}.pw-bar.strong{background:var(--green)}

/* AUTH */
.auth-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:var(--s8) var(--s4);background:var(--bg-2)}
.auth-box{width:100%;max-width:440px;background:var(--bg);border:1px solid var(--border);border-radius:var(--r-xl);padding:var(--s12) var(--s8);box-shadow:var(--shadow-lg)}
.auth-logo{text-align:center;font-size:var(--text-xl);font-weight:800;margin-bottom:var(--s8);letter-spacing:-.03em}
.auth-logo span{color:var(--blue)}
.auth-title{font-size:var(--text-2xl);font-weight:800;text-align:center;margin-bottom:var(--s2);letter-spacing:-.03em}
.auth-sub{text-align:center;font-size:var(--text-sm);color:var(--text-muted);margin-bottom:var(--s8)}
.auth-divider{display:flex;align-items:center;gap:var(--s3);margin:var(--s5) 0}
.auth-divider::before,.auth-divider::after{content:'';flex:1;height:1px;background:var(--border)}
.auth-divider span{font-size:var(--text-xs);color:var(--text-dim);text-transform:uppercase;letter-spacing:.08em}
.auth-footer{text-align:center;margin-top:var(--s5);font-size:var(--text-sm);color:var(--text-muted)}
.signup-steps{display:flex;justify-content:center;gap:var(--s2);margin-bottom:var(--s8)}
.step-dot{width:8px;height:8px;border-radius:50%;background:var(--border);transition:background var(--t)}
.step-dot.active{background:var(--blue)}.step-dot.complete{background:var(--green)}
.signup-step{display:none}.signup-step.active{display:block}

/* PORTAL */
.portal-layout{display:flex;min-height:100vh;background:var(--bg-2)}
.portal-sidebar{width:240px;flex-shrink:0;background:var(--bg);border-right:1px solid var(--border);display:flex;flex-direction:column;padding:var(--s5) 0;position:fixed;top:0;bottom:0;overflow-y:auto}
.portal-sidebar-logo{padding:0 var(--s5) var(--s5);font-size:var(--text-lg);font-weight:800;border-bottom:1px solid var(--border);margin-bottom:var(--s3);letter-spacing:-.03em}
.portal-sidebar-logo span{color:var(--blue)}
.sidebar-nav{flex:1}
.sidebar-link{display:flex;align-items:center;gap:var(--s3);padding:var(--s3) var(--s5);color:var(--text-muted);font-size:var(--text-sm);font-weight:500;transition:all var(--t);text-decoration:none}
.sidebar-link:hover{color:var(--text);background:var(--bg-2)}
.sidebar-link.active{color:var(--blue);background:var(--blue-tint);font-weight:600;border-right:2px solid var(--blue)}
.sidebar-user{padding:var(--s4) var(--s5);border-top:1px solid var(--border);margin-top:auto}
.sidebar-user-name{font-size:var(--text-xs);color:var(--text-muted);margin-bottom:var(--s1);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-weight:500}
.sidebar-user-plan{font-size:var(--text-xs);color:var(--blue);font-weight:700;text-transform:uppercase;letter-spacing:.06em}
.portal-main{margin-left:240px;flex:1;padding:var(--s8)}
.portal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--s8);padding-bottom:var(--s5);border-bottom:1px solid var(--border)}
.portal-title{font-size:var(--text-2xl);font-weight:800;letter-spacing:-.03em;color:var(--text)}
.portal-subtitle{font-size:var(--text-sm);color:var(--text-muted);margin-top:2px}
.dashboard-card{background:var(--bg);border:1.5px solid var(--border);border-radius:var(--r-lg);padding:var(--s6);transition:all var(--t-slow);position:relative}
.dashboard-card:hover{border-color:var(--blue);box-shadow:var(--shadow-md);transform:translateY(-2px)}
.dashboard-card.locked{opacity:.55}
.dashboard-card-sector{font-size:var(--text-xs);font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--blue);margin-bottom:var(--s2)}
.dashboard-card-title{font-size:var(--text-lg);font-weight:700;margin-bottom:var(--s2);color:var(--text);letter-spacing:-.02em}
.dashboard-card-desc{font-size:var(--text-sm);color:var(--text-muted);margin-bottom:var(--s4);line-height:1.6}
.dashboard-card-tier{display:inline-flex;font-size:var(--text-xs);font-weight:600;text-transform:uppercase;letter-spacing:.06em;padding:.2em .7em;border-radius:999px;border:1px solid var(--border);color:var(--text-muted);margin-bottom:var(--s4)}
.lock-overlay{position:absolute;top:var(--s4);right:var(--s4);font-size:1.2rem;opacity:.4}

/* ALERTS */
.alert{padding:var(--s3) var(--s5);border-radius:var(--r);font-size:var(--text-sm);border:1.5px solid;margin-bottom:var(--s4)}
.alert-error{background:#FEF2F2;border-color:#FECACA;color:#991B1B}
.alert-success{background:var(--green-tint);border-color:#A7F3D0;color:#065F46}
.alert-info{background:var(--blue-tint);border-color:var(--blue-border);color:#1E40AF}

/* TAGS */
.tag{display:inline-flex;align-items:center;gap:4px;font-size:var(--text-xs);font-weight:600;letter-spacing:.04em;text-transform:uppercase;padding:.25em .7em;border-radius:999px;background:var(--blue-tint);border:1px solid var(--blue-border);color:var(--blue)}
.tag-green{background:var(--green-tint);border-color:#A7F3D0;color:#065F46}
.tag-grey{background:var(--bg-2);border-color:var(--border);color:var(--text-muted)}
.tag-coming-soon{background:var(--bg-2);border-color:var(--border);color:var(--text-dim)}

/* FAQ */
.faq-item{border-bottom:1px solid var(--border)}
.faq-question{width:100%;background:none;border:none;color:var(--text);font-family:var(--font);font-size:var(--text-base);font-weight:600;text-align:left;padding:var(--s5) 0;cursor:pointer;display:flex;justify-content:space-between;align-items:center;gap:var(--s4);transition:color var(--t)}
.faq-question:hover{color:var(--blue)}
.faq-arrow{font-size:var(--text-sm);transition:transform var(--t);flex-shrink:0;color:var(--text-muted)}
.faq-item.open .faq-arrow{transform:rotate(180deg)}
.faq-answer{max-height:0;overflow:hidden;transition:max-height .35s ease,padding var(--t);font-size:var(--text-sm);color:var(--text-muted);line-height:1.8}
.faq-item.open .faq-answer{max-height:400px;padding-bottom:var(--s5)}

/* FOOTER */
.footer{background:var(--text);color:rgba(255,255,255,.7);padding:var(--s16) 0 var(--s8)}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:var(--s12);margin-bottom:var(--s12)}
.footer-logo{font-size:var(--text-lg);font-weight:800;color:white;margin-bottom:var(--s4);letter-spacing:-.03em}
.footer-logo span{color:var(--blue-light)}
.footer-tagline{font-size:var(--text-sm);color:rgba(255,255,255,.5);line-height:1.7;max-width:260px}
.footer-col-title{font-size:var(--text-xs);font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:rgba(255,255,255,.4);margin-bottom:var(--s4)}
.footer-links{list-style:none;display:flex;flex-direction:column;gap:var(--s2)}
.footer-links a{font-size:var(--text-sm);color:rgba(255,255,255,.55);transition:color var(--t)}
.footer-links a:hover{color:white}
.footer-bottom{border-top:1px solid rgba(255,255,255,.1);padding-top:var(--s5);display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:var(--s4)}
.footer-copy{font-size:var(--text-xs);color:rgba(255,255,255,.35)}

/* UTILITY */
.w-full{width:100%}.hidden{display:none!important}.flex{display:flex}.flex-center{display:flex;align-items:center;justify-content:center}.divider{border:none;border-top:1px solid var(--border);margin:var(--s8) 0}.mt-auto{margin-top:auto}.gap-3{gap:var(--s3)}.gap-4{gap:var(--s4)}

/* ANIMATIONS */
.anim-fade-up{opacity:0;transform:translateY(32px);transition:opacity .65s ease,transform .65s ease}
.anim-fade-up.visible{opacity:1;transform:none}
.anim-fade-left{opacity:0;transform:translateX(40px);transition:opacity .65s ease,transform .65s ease}
.anim-fade-left.visible{opacity:1;transform:none}
.anim-fade-right{opacity:0;transform:translateX(-40px);transition:opacity .65s ease,transform .65s ease}
.anim-fade-right.visible{opacity:1;transform:none}
.anim-scale{opacity:0;transform:scale(.93);transition:opacity .65s ease,transform .65s ease}
.anim-scale.visible{opacity:1;transform:none}
.anim-delay-1{transition-delay:.05s}.anim-delay-2{transition-delay:.12s}.anim-delay-3{transition-delay:.19s}
.anim-delay-4{transition-delay:.26s}.anim-delay-5{transition-delay:.33s}.anim-delay-6{transition-delay:.40s}

@keyframes spin{to{transform:rotate(360deg)}}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-6px)}}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.5}}

/* RESPONSIVE */
@media(max-width:1024px){.grid-4{grid-template-columns:repeat(2,1fr)}.footer-grid{grid-template-columns:1fr 1fr;gap:var(--s8)}.hero-inner{grid-template-columns:1fr}.hero-visual{display:none}}
@media(max-width:768px){:root{--text-hero:2.2rem}.nav-links,.nav-ctas{display:none}.nav-toggle{display:flex}.grid-2,.grid-3,.steps{grid-template-columns:1fr}.steps::before{display:none}.pricing-grid{grid-template-columns:1fr}.pricing-card.featured{transform:none}.portal-sidebar{width:100%;position:static;height:auto;border-right:none;border-bottom:1px solid var(--border);flex-direction:row;padding:var(--s3) var(--s4);overflow-x:auto}.portal-main{margin-left:0}.stats-bar-inner{gap:var(--s6)}.stat-divider{display:none}.footer-grid{grid-template-columns:1fr;gap:var(--s8)}.footer-bottom{flex-direction:column;text-align:center}.auth-box{padding:var(--s8) var(--s5)}}
@media(max-width:480px){.container{padding:0 var(--s4)}.section{padding:var(--s16) 0}.hero{padding:100px 0 var(--s16)}.hero-ctas{flex-direction:column}}

/* ═══════════════════════════════════════════════
   INDEX.HTML — additional component styles
   ═══════════════════════════════════════════════ */

/* ── Stats bar ───────────────────────────────── */
.stats-inner{display:flex;align-items:center;justify-content:center;gap:var(--s10);flex-wrap:wrap}
.stat-item{text-align:center}
.stat-num{font-size:2rem;font-weight:800;color:var(--blue);line-height:1}
.stat-lbl{font-size:var(--text-sm);color:var(--text-2);margin-top:4px}
.stat-divider{width:1px;height:40px;background:var(--border)}

/* ── Hero extras ─────────────────────────────── */
.hero-social-proof{display:flex;align-items:center;gap:var(--s3);margin-top:var(--s6);font-size:var(--text-sm);color:var(--text-2)}
.proof-avatars{display:flex}
.avatar{width:28px;height:28px;border-radius:50%;border:2px solid #fff;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;color:#fff;margin-left:-8px}
.proof-avatars .avatar:first-child{margin-left:0}

/* Float badges on hero */
.float-badge{position:absolute;background:var(--bg);border:1px solid var(--border);border-radius:var(--r-xl);padding:var(--s3) var(--s4);box-shadow:var(--shadow-lg);display:flex;align-items:center;gap:var(--s3);min-width:160px;z-index:10}
.float-badge-1{bottom:-28px;left:-20px;animation:float 5s ease-in-out infinite}
.float-badge-2{top:-20px;right:-24px;animation:float 5s ease-in-out infinite;animation-delay:1.8s}
.float-badge-3{bottom:60px;right:-32px;animation:float 5s ease-in-out infinite;animation-delay:3.2s}
.badge-icon{width:32px;height:32px;border-radius:var(--r-lg);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.badge-val{font-size:var(--text-sm);font-weight:700;color:var(--text);line-height:1.2}
.badge-lbl{font-size:10px;color:var(--text-2)}

/* ── Dashboard mini frame (hero) ─────────────── */
.dash-header{background:var(--bg-2);border-bottom:1px solid var(--border);padding:10px 14px;display:flex;align-items:center;gap:10px}
.dash-dots{display:flex;gap:6px}
.dash-dots span{width:10px;height:10px;border-radius:50%;display:block}
.dash-title-bar{font-size:11px;color:var(--text-2);font-weight:500}
.dash-body{padding:14px}
.dash-kpis{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-bottom:12px}
.dash-kpi{background:var(--bg-2);border-radius:var(--r-lg);padding:8px 10px}
.kpi-label{font-size:9px;color:var(--text-2);text-transform:uppercase;letter-spacing:.5px;font-weight:600}
.kpi-val{font-size:15px;font-weight:800;color:var(--text);margin:2px 0}
.kpi-delta{font-size:9px;font-weight:600}
.kpi-delta.up{color:var(--green)}
.kpi-delta.down{color:#EF4444}
.dash-chart-area{background:var(--bg-2);border-radius:var(--r-lg);padding:10px;margin-bottom:10px}
.dash-chart-svg{width:100%;height:auto;display:block}
.dash-chart-legend{display:flex;gap:12px;font-size:9px;color:var(--text-2);margin-top:4px;justify-content:flex-end}
.legend-dot{display:inline-block;width:8px;height:8px;border-radius:50%;margin-right:3px;vertical-align:middle}
.dash-table{font-size:9px}
.dash-row{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:4px;padding:4px 0;border-bottom:1px solid var(--border);align-items:center}
.dash-row:last-child{border-bottom:none}
.dash-row-head{font-weight:700;color:var(--text-2);font-size:8px;text-transform:uppercase;letter-spacing:.4px}
.override-pill{display:inline-block;padding:1px 5px;border-radius:4px;font-size:8px;font-weight:600;background:transparent;color:var(--text-2)}
.override-pill.edited{background:#FEF9C3;color:#92400E}

/* ── How it works (steps) ────────────────────── */
.steps-grid{display:flex;align-items:flex-start;justify-content:center;gap:0;margin-top:var(--s12);flex-wrap:wrap}
.step-card{flex:1;min-width:200px;max-width:280px;text-align:center;padding:var(--s6)}
.step-card .step-num{font-size:3rem;font-weight:900;color:var(--blue);opacity:.12;line-height:1;margin-bottom:var(--s3)}
.step-icon-wrap{width:52px;height:52px;border-radius:var(--r-xl);display:flex;align-items:center;justify-content:center;margin:0 auto var(--s4)}
.step-card h3{font-size:var(--text-lg);font-weight:700;margin-bottom:var(--s2)}
.step-card p{font-size:var(--text-sm);color:var(--text-2);line-height:1.6}
.step-connector{display:flex;align-items:center;justify-content:center;padding-top:60px;flex-shrink:0}

/* ── Dashboard preview section ───────────────── */
.preview-frame{background:var(--bg);border-radius:var(--r-2xl);box-shadow:var(--shadow-xl);border:1px solid var(--border);overflow:hidden;margin-top:var(--s10)}
.preview-header{background:var(--bg-2);border-bottom:1px solid var(--border);padding:12px 20px;display:flex;align-items:center;gap:12px}
.preview-dots{display:flex;gap:6px}
.preview-dots span{width:11px;height:11px;border-radius:50%;display:block}
.preview-url{flex:1;background:var(--bg);border:1px solid var(--border);border-radius:var(--r-lg);padding:4px 12px;font-size:11px;color:var(--text-2);text-align:center}
.preview-saved{font-size:11px;font-weight:600;color:var(--green)}
.preview-body{padding:20px}
.preview-kpis{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:20px}
.preview-kpi{background:var(--bg-2);border-radius:var(--r-xl);padding:14px 16px;border:1px solid var(--border)}
.pkpi-label{font-size:11px;color:var(--text-2);font-weight:600;text-transform:uppercase;letter-spacing:.5px;margin-bottom:4px}
.pkpi-val{font-size:1.4rem;font-weight:800;color:var(--text);line-height:1.2}
.pkpi-delta{font-size:11px;font-weight:600;margin-top:3px}
.pkpi-delta.up{color:var(--green)}
.pkpi-delta.neutral{color:var(--text-2)}
.preview-content-row{display:grid;grid-template-columns:1.2fr 1fr;gap:16px}
.preview-chart-block,.preview-table-block{background:var(--bg-2);border-radius:var(--r-xl);padding:16px;border:1px solid var(--border)}
.preview-chart-title,.preview-table-title{font-size:12px;font-weight:700;color:var(--text);margin-bottom:10px}
.preview-chart-svg{width:100%;height:auto;display:block}
.preview-chart-legend{display:flex;gap:16px;font-size:11px;color:var(--text-2);margin-top:8px}
.preview-table{width:100%;border-collapse:collapse;font-size:11px}
.preview-table th{font-size:10px;font-weight:700;color:var(--text-2);text-transform:uppercase;letter-spacing:.4px;padding:4px 6px;border-bottom:1px solid var(--border);text-align:left}
.preview-table td{padding:5px 6px;border-bottom:1px solid var(--border);color:var(--text)}
.preview-table tbody tr:last-child td{border-bottom:none}
.tbl-dash{color:var(--text-3)}
.tbl-override{background:#FEF9C3;color:#92400E;border-radius:4px;padding:2px 6px;font-weight:600;font-size:10px}
.tbl-note{background:#EFF6FF;color:#1D4ED8;border-radius:4px;padding:2px 6px;font-size:10px}
.preview-export-row{display:flex;align-items:center;gap:10px;margin-top:10px}
.preview-export-btn{background:var(--blue);color:#fff;border:none;padding:6px 14px;border-radius:var(--r-lg);font-size:11px;font-weight:600;cursor:pointer;font-family:var(--font)}
.preview-export-note{font-size:10px;color:var(--text-2)}
.preview-disclaimer{text-align:center;font-size:var(--text-sm);color:var(--text-2);margin-top:var(--s6);font-style:italic}

/* ── Video section ───────────────────────────── */
.section-video{background:linear-gradient(135deg,#0F172A 0%,#1E3A5F 60%,#0F172A 100%);padding:var(--s24) 0}
.video-inner{display:grid;grid-template-columns:1fr 1fr;gap:var(--s16);align-items:center}
.video-copy .section-label{color:rgba(255,255,255,.5);border-color:rgba(255,255,255,.15)}
.video-copy .section-title{color:#fff}
.video-bullets{list-style:none;margin:0 0 var(--s6);padding:0;display:flex;flex-direction:column;gap:var(--s3)}
.video-bullets li{display:flex;align-items:center;gap:var(--s3);font-size:var(--text-base);color:rgba(255,255,255,.8);font-weight:500}
.video-player{position:relative;border-radius:var(--r-2xl);overflow:hidden;background:#0F172A;aspect-ratio:16/9;box-shadow:0 40px 80px rgba(0,0,0,.5);border:1px solid rgba(255,255,255,.08)}
.video-el{width:100%;height:100%;object-fit:cover;display:block}
.video-placeholder{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#1E293B,#0F172A)}
.video-placeholder-inner{text-align:center;color:rgba(255,255,255,.7)}
.play-ring{width:72px;height:72px;border-radius:50%;border:2px solid rgba(255,255,255,.3);display:flex;align-items:center;justify-content:center;margin:0 auto var(--s4);background:rgba(255,255,255,.08);cursor:pointer;transition:all .2s}
.play-ring:hover{background:rgba(255,255,255,.15);border-color:rgba(255,255,255,.6);transform:scale(1.05)}
.video-placeholder-inner p{font-size:var(--text-base);font-weight:600;margin-bottom:4px;color:rgba(255,255,255,.85)}
.video-placeholder-inner span{font-size:var(--text-sm);color:rgba(255,255,255,.45)}

/* ── Features grid ───────────────────────────── */
.features-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--s6);margin-top:var(--s12)}
.feature-card{background:var(--bg);border:1px solid var(--border);border-radius:var(--r-2xl);padding:var(--s7);transition:transform .2s,box-shadow .2s}
.feature-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-lg)}
.feature-icon{width:48px;height:48px;border-radius:var(--r-xl);display:flex;align-items:center;justify-content:center;margin-bottom:var(--s4)}
.feature-card h3{font-size:var(--text-base);font-weight:700;margin-bottom:var(--s2)}
.feature-card p{font-size:var(--text-sm);color:var(--text-2);line-height:1.65}

/* ── Pricing teaser ──────────────────────────── */
.pricing-teaser-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--s6);margin-top:var(--s10)}
.price-teaser-card{background:var(--bg);border:1px solid var(--border);border-radius:var(--r-2xl);padding:var(--s8);position:relative}
.price-teaser-card--featured{border-color:var(--blue);box-shadow:0 0 0 3px rgba(37,99,235,.12)}
.ptc-badge{position:absolute;top:-12px;left:50%;transform:translateX(-50%);background:var(--blue);color:#fff;font-size:11px;font-weight:700;padding:3px 12px;border-radius:var(--r-lg);white-space:nowrap}
.ptc-plan{font-size:var(--text-xs);font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--text-2);margin-bottom:var(--s2)}
.ptc-price{font-size:2.4rem;font-weight:900;color:var(--text);line-height:1;margin-bottom:var(--s4)}
.ptc-price span{font-size:var(--text-base);font-weight:500;color:var(--text-2)}
.ptc-desc{font-size:var(--text-sm);color:var(--text-2);line-height:1.6;margin-bottom:var(--s6)}
.btn-block{display:block;text-align:center;width:100%}

/* ── CTA section ─────────────────────────────── */
.section-cta{background:linear-gradient(135deg,#1D4ED8 0%,#2563EB 50%,#1E40AF 100%);padding:var(--s24) 0;overflow:hidden}
.cta-inner{text-align:center;position:relative;max-width:600px;margin:0 auto}
.cta-blob{position:absolute;width:400px;height:400px;border-radius:50%;background:rgba(255,255,255,.08);top:-100px;left:50%;transform:translateX(-50%);pointer-events:none}
.cta-inner h2{font-size:clamp(1.8rem,3.5vw,2.8rem);font-weight:800;color:#fff;margin-bottom:var(--s4);position:relative}
.cta-inner p{font-size:var(--text-lg);color:rgba(255,255,255,.8);margin-bottom:var(--s8);position:relative}
.cta-actions{display:flex;gap:var(--s4);justify-content:center;flex-wrap:wrap;position:relative}
.btn-ghost-white{background:transparent;color:#fff;border:2px solid rgba(255,255,255,.4)}
.btn-ghost-white:hover{background:rgba(255,255,255,.1);border-color:#fff}

/* ── Footer ──────────────────────────────────── */
.footer{background:#0F172A;color:rgba(255,255,255,.6);padding:var(--s16) 0 0}
.footer-inner{display:grid;grid-template-columns:1fr 1.5fr;gap:var(--s16);margin-bottom:var(--s12)}
.footer-brand{max-width:280px}
.footer-logo{font-size:1.4rem;font-weight:900;color:#fff;text-decoration:none;display:block;margin-bottom:var(--s4)}
.footer-logo span{color:var(--blue)}
.footer-brand p{font-size:var(--text-sm);line-height:1.6;color:rgba(255,255,255,.55);margin-bottom:var(--s2)}
.footer-tagline{font-size:var(--text-xs);color:rgba(255,255,255,.3);font-style:italic}
.footer-links{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--s8)}
.footer-col h4{font-size:var(--text-sm);font-weight:700;color:#fff;margin-bottom:var(--s4)}
.footer-col a{display:block;font-size:var(--text-sm);color:rgba(255,255,255,.5);text-decoration:none;margin-bottom:var(--s2);transition:color var(--t)}
.footer-col a:hover{color:#fff}
.footer-bottom{border-top:1px solid rgba(255,255,255,.08);padding:var(--s5) 0;display:flex;justify-content:space-between;align-items:center;font-size:var(--text-xs);color:rgba(255,255,255,.3)}

/* ── Responsive additions ────────────────────── */
@media(max-width:1024px){
  .preview-content-row{grid-template-columns:1fr}
  .preview-kpis{grid-template-columns:repeat(2,1fr)}
  .features-grid{grid-template-columns:repeat(2,1fr)}
  .pricing-teaser-cards{grid-template-columns:1fr}
  .footer-inner{grid-template-columns:1fr}
  .footer-brand{max-width:100%}
}
@media(max-width:768px){
  .steps-grid{flex-direction:column;align-items:center}
  .step-connector{display:none}
  .video-inner{grid-template-columns:1fr}
  .features-grid{grid-template-columns:1fr}
  .float-badge{display:none}
  .stats-inner{gap:var(--s6)}
  .stat-divider{display:none}
  .preview-kpis{grid-template-columns:repeat(2,1fr)}
  .footer-links{grid-template-columns:1fr}
  .footer-bottom{flex-direction:column;gap:var(--s2);text-align:center}
  .dash-kpis{grid-template-columns:repeat(3,1fr)}
}

/* ── Legacy animation alias ──────────────────── */
.fade-in{opacity:0;transform:translateY(24px);transition:opacity .6s ease,transform .6s ease}
.fade-in.visible{opacity:1;transform:none}
.stagger .fade-in:nth-child(1){transition-delay:.05s}
.stagger .fade-in:nth-child(2){transition-delay:.1s}
.stagger .fade-in:nth-child(3){transition-delay:.15s}
.stagger .fade-in:nth-child(4){transition-delay:.2s}
.stagger .fade-in:nth-child(5){transition-delay:.25s}
.stagger .fade-in:nth-child(6){transition-delay:.3s}

/* ── Section label ───────────────────────────── */
.section-label{display:inline-block;font-size:var(--text-xs);font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--blue);background:var(--blue-tint);border:1px solid var(--blue-border);padding:.3em .9em;border-radius:999px;margin-bottom:var(--s4)}

/* ── Missing utility aliases ─────────────────── */
.btn-solid{background:var(--blue);color:#fff;border:1.5px solid var(--blue)}
.btn-solid:hover{background:var(--blue-dark);border-color:var(--blue-dark);box-shadow:var(--shadow-blue);color:#fff;transform:translateY(-1px)}
.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--s6)}
