/* SecondAct Design Tokens — REIMAGINED
 * Generated by CMS vision-extract — 2026-04-22
 * Source: jaysamit.com reimagination (Tier 1 CSS heuristic + Tier 3 Gemini synthesis)
 * Design Intent: Reimagination — evolved visual DNA, bolder identity
 * CMS DTCG Source: ~/apps/CMS/projects/jaysamit/tokens.json
 * Audience: 45-75 year old professionals
 * Philosophy: Visionary authority, innovative sophistication
 */

:root {
  /* Primary — deepened midnight navy */
  --sa-navy: #1A233F;
  --sa-navy-light: #2B3D6A;
  --sa-navy-dark: #0C121D;

  /* Accent (evolved teal — from jaysamit.com DNA, reimagined) */
  --sa-accent: #008C9E;
  --sa-accent-light: #00AEC4;
  --sa-accent-dark: #006D7C;

  /* Backward compat — amber aliases (deprecated, use --sa-accent) */
  --sa-amber: var(--sa-accent);
  --sa-amber-light: var(--sa-accent-light);
  --sa-amber-dark: var(--sa-accent-dark);

  /* Secondary — innovation purple (NEW) */
  --sa-secondary: #7E42A8;
  --sa-secondary-hover: #6A368F;

  /* Neutral */
  --sa-white: #F8F9FA;
  --sa-warm-gray: #F3F4F6;
  --sa-cool-gray: #EAEBEC;
  --sa-text: #2C3E50;
  --sa-muted: #5E6A7D;
  --sa-border: #CED4DA;

  /* Functional */
  --sa-cta: #C75B12;
  --sa-cta-hover: #A84D0F;
  --sa-success: #28A745;
  --sa-error: #DC3545;
  --sa-info: #17A2B8;

  /* Shadows — navy-tinted depth system */
  --sa-shadow-sm: 0px 1px 3px rgba(26, 35, 63, 0.08), 0px 1px 2px rgba(26, 35, 63, 0.04);
  --sa-shadow-md: 0px 4px 6px rgba(26, 35, 63, 0.1), 0px 2px 4px rgba(26, 35, 63, 0.06);
  --sa-shadow-lg: 0px 10px 15px rgba(26, 35, 63, 0.12), 0px 4px 6px rgba(26, 35, 63, 0.07);

  /* Typography — Raleway for headings (reimagined from Arial/Inter), Inter for body */
  --sa-font-heading: Raleway, sans-serif;
  --sa-font-body: Inter, sans-serif;
  --sa-font-mono: Roboto Mono, monospace;

  /* Spacing */
  --sa-section-padding: 64px 24px;
  --sa-container-max: 1200px;
  --sa-text-max: 720px;
  --sa-card-padding: 24px;
  --sa-card-gap: 24px;
  --sa-card-radius: 12px;

  /* Font-size scale (18px base — UNCHANGED, audience constraint) */
  --sa-font-2xs: 0.778rem;  /* 14px — badges/decorative only, NOT for body text */
  --sa-font-xs: 0.889rem;   /* 16px — minimum for readable body text */
  --sa-font-sm: 0.944rem;   /* 17px */
  --sa-font-base: 1rem;     /* 18px — base body */
  --sa-font-md: 1.111rem;   /* 20px */
  --sa-font-lg: 1.222rem;   /* 22px — matches h3 */
  --sa-font-xl: 1.556rem;   /* 28px — matches h2 */
  --sa-font-2xl: 2rem;      /* 36px — matches h1 */
  --sa-font-3xl: 2.5rem;    /* 45px — hero titles */

  /* Accent opacity variants (evolved teal #008C9E at common opacities) */
  --sa-accent-5: rgba(0, 140, 158, 0.05);
  --sa-accent-10: rgba(0, 140, 158, 0.10);
  --sa-accent-15: rgba(0, 140, 158, 0.15);
  --sa-accent-20: rgba(0, 140, 158, 0.20);

  /* Navy opacity variants */
  --sa-navy-5: rgba(26, 35, 63, 0.05);
  --sa-navy-10: rgba(26, 35, 63, 0.10);
  --sa-navy-15: rgba(26, 35, 63, 0.15);

  /* Secondary opacity variants (NEW — innovation purple) */
  --sa-secondary-5: rgba(126, 66, 168, 0.05);
  --sa-secondary-10: rgba(126, 66, 168, 0.10);
  --sa-secondary-15: rgba(126, 66, 168, 0.15);

  /* Border-radius scale */
  --sa-radius-xs: 4px;
  --sa-radius-sm: 8px;
  --sa-radius-md: 12px;   /* matches --sa-card-radius */
  --sa-radius-lg: 16px;
  --sa-radius-pill: 999px;

  /* Spacing scale */
  --sa-space-1: 4px;
  --sa-space-2: 8px;
  --sa-space-3: 12px;
  --sa-space-4: 16px;
  --sa-space-5: 20px;
  --sa-space-6: 24px;
  --sa-space-8: 32px;
  --sa-space-10: 40px;
  --sa-space-12: 48px;
  --sa-space-16: 64px;
  --sa-space-24: 96px;

  /* Animation */
  --sa-transition: 0.2s ease;

  /* Semantic colors — evolved from jaysamit.com DNA */
  --sa-tech: var(--sa-accent);
  --sa-tech-light: var(--sa-accent-light);
  --sa-tech-dark: var(--sa-accent-dark);
  --sa-green: #28A745;

  /* Shadows — reimagined depth system */
  --sa-shadow-natural: 0px 20px 25px rgba(26, 35, 63, 0.15), 0px 10px 10px rgba(26, 35, 63, 0.08);
  --sa-shadow-deep: 0px 25px 50px rgba(26, 35, 63, 0.25);
  --sa-shadow-crisp: 0px 4px 0px rgba(26, 35, 63, 0.12);
  --sa-shadow-glow: 0 0 0 3px rgba(0, 140, 158, 0.3);

  /* Gradients — reimagined with new palette */
  --sa-gradient-dusk: linear-gradient(135deg, #1A233F, #2B3D6A);
  --sa-gradient-accent: linear-gradient(135deg, #008C9E, #00AEC4);
  --sa-gradient-warm: var(--sa-gradient-accent); /* backward compat */
  --sa-gradient-midnight: linear-gradient(135deg, #0C121D, #1A233F);
  --sa-gradient-innovation: linear-gradient(135deg, #7E42A8, #9B5DC7);

  /* Z-index scale (UNCHANGED — structural, not visual) */
  --sa-z-dropdown: 100;
  --sa-z-sticky: 200;
  --sa-z-header: 300;
  --sa-z-overlay: 400;
  --sa-z-modal: 500;
  --sa-z-toast: 600;

  /* Overlays */
  --sa-overlay-dark: rgba(12, 18, 29, 0.6);
  --sa-overlay-light: rgba(255, 255, 255, 0.8);

  /* Icon sizing (UNCHANGED — structural) */
  --sa-icon-sm: 16px;
  --sa-icon-md: 20px;
  --sa-icon-lg: 24px;
  --sa-icon-xl: 32px;

  /* Easing curves (UNCHANGED — motion design) */
  --sa-ease-out-back: cubic-bezier(0.34, 1.56, 0.64, 1);
  --sa-ease-out-expo: cubic-bezier(0.16, 1, 0.3, 1);

  /* Duration scale (UNCHANGED — motion design) */
  --sa-duration-fast: 0.15s;
  --sa-duration-normal: 0.3s;
  --sa-duration-slow: 0.5s;
  --sa-duration-reveal: 0.8s;

  /* Production-type tokens (UNCHANGED — layout constraints) */
  --sa-quiz-max-width: 640px;
  --sa-quiz-option-gap: 12px;
  --sa-quiz-option-padding: 20px 24px;
  --sa-score-font: var(--sa-font-mono);
  --sa-score-size: 3rem;
  --sa-directory-columns: repeat(auto-fill, minmax(300px, 1fr));
  --sa-counter-size: 80px;
  --sa-counter-font-size: 2.5rem;
}

@media (min-width: 768px) {
  :root {
    --sa-section-padding: 96px 48px;
  }
}

/* Base reset */
*, *::before, *::after {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

html {
  font-size: 18px;
  -webkit-text-size-adjust: 100%;
}

body {
  font-family: var(--sa-font-body);
  font-weight: 500;
  color: var(--sa-text);
  background: var(--sa-white);
  line-height: 1.7;
  letter-spacing: 0.01em;
  -webkit-font-smoothing: antialiased;
}

h1, h2, h3, h4 {
  font-family: var(--sa-font-heading);
  color: var(--sa-navy);
  line-height: 1.3;
  letter-spacing: -0.025em;
}

h1 { font-size: 2rem; font-weight: 700; line-height: 1.2; }
h2 { font-size: 1.556rem; font-weight: 700; }
h3 { font-size: 1.222rem; font-weight: 600; line-height: 1.4; }

a { color: var(--sa-navy); text-decoration: underline; }
a:hover { color: var(--sa-accent-dark); }

/* Section container */
.sa-section {
  padding: var(--sa-section-padding);
}
.sa-section--alt {
  background: var(--sa-warm-gray);
}
.sa-container {
  max-width: var(--sa-container-max);
  margin: 0 auto;
}
.sa-text-container {
  max-width: var(--sa-text-max);
}

/* Buttons */
.sa-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-family: var(--sa-font-body);
  font-size: 1rem;
  font-weight: 600;
  padding: 16px 32px;
  border-radius: 8px;
  min-height: 48px;
  cursor: pointer;
  transition: all var(--sa-transition);
  text-decoration: none;
  border: none;
  gap: 8px;
}
.sa-btn:focus-visible {
  outline: 3px solid var(--sa-accent);
  outline-offset: 2px;
}
.sa-btn-primary {
  background: var(--sa-cta);
  color: white;
}
.sa-btn-primary:hover {
  background: var(--sa-cta-hover);
  transform: translateY(-1px);
  box-shadow: var(--sa-shadow-md);
  color: white;
}
.sa-btn-secondary {
  background: transparent;
  color: var(--sa-navy);
  border: 2px solid var(--sa-border);
}
.sa-btn-secondary:hover {
  border-color: var(--sa-navy-light);
  background: var(--sa-warm-gray);
}

/* Cards */
.sa-card {
  background: white;
  border-radius: var(--sa-card-radius);
  padding: var(--sa-card-padding);
  box-shadow: var(--sa-shadow-sm);
  border: 1px solid var(--sa-border);
  transition: box-shadow var(--sa-transition), transform var(--sa-transition);
}
.sa-card:hover {
  box-shadow: var(--sa-shadow-md);
  transform: translateY(-2px);
}
.sa-card-grid {
  display: grid;
  gap: var(--sa-card-gap);
  grid-template-columns: 1fr;
}
@media (min-width: 768px) {
  .sa-card-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (min-width: 1024px) {
  .sa-card-grid--3 { grid-template-columns: repeat(3, 1fr); }
}

/* Form inputs */
.sa-input {
  font-family: var(--sa-font-body);
  font-size: 1rem;
  padding: 14px 16px;
  border: 2px solid var(--sa-border);
  border-radius: 8px;
  min-height: 48px;
  width: 100%;
  transition: border-color var(--sa-transition);
}
.sa-input:focus {
  border-color: var(--sa-accent);
  outline: none;
  box-shadow: 0 0 0 3px var(--sa-accent-15);
}

/* Toggle cards (for calculators/quizzes) */
.sa-toggle-card {
  display: flex;
  align-items: center;
  gap: 16px;
  padding: 20px 24px;
  border: 2px solid var(--sa-border);
  border-radius: var(--sa-card-radius);
  cursor: pointer;
  transition: all var(--sa-transition);
  min-height: 64px;
}
.sa-toggle-card.active {
  border-color: var(--sa-accent);
  background: var(--sa-accent-5);
}
.sa-toggle-card:hover {
  border-color: var(--sa-navy-light);
}

/* Progress bar */
.sa-progress {
  height: 8px;
  background: var(--sa-cool-gray);
  border-radius: 4px;
  overflow: hidden;
}
.sa-progress-fill {
  height: 100%;
  background: linear-gradient(90deg, var(--sa-accent), var(--sa-accent-light));
  border-radius: 4px;
  transition: width 0.4s ease;
}

/* Badges */
.sa-badge {
  display: inline-flex;
  align-items: center;
  font-size: var(--sa-font-2xs);
  font-weight: 600;
  padding: 4px 12px;
  border-radius: 999px;
  letter-spacing: 0.02em;
}
.sa-badge--amber, .sa-badge--accent {
  background: var(--sa-accent-15);
  color: var(--sa-accent-dark);
}
.sa-badge--navy {
  background: var(--sa-navy-10);
  color: var(--sa-navy);
}
.sa-badge--success {
  background: rgba(40, 167, 69, 0.1);
  color: #1E7E34;
}
.sa-badge--innovation {
  background: var(--sa-secondary-15);
  color: var(--sa-secondary);
}

/* Utilities */
.sa-text-center { text-align: center; }
.sa-text-muted { color: var(--sa-muted); }
.sa-mt-1 { margin-top: 8px; }
.sa-mt-2 { margin-top: 16px; }
.sa-mt-3 { margin-top: 24px; }
.sa-mt-4 { margin-top: 32px; }
.sa-mb-1 { margin-bottom: 8px; }
.sa-mb-2 { margin-bottom: 16px; }
.sa-mb-3 { margin-bottom: 24px; }
.sa-mb-4 { margin-bottom: 32px; }
.sa-hidden { display: none !important; }

/* Print styles */
@media print {
  .sa-nav, .sa-footer, .sa-share-buttons, .sa-email-gate, .sa-btn { display: none; }
  .sa-card { box-shadow: none; border: 1px solid #ccc; break-inside: avoid; }
  body { font-size: 12pt; line-height: 1.6; color: #000; }
  a { color: #000; text-decoration: underline; }
  a[href]::after { content: " (" attr(href) ")"; font-size: 10pt; }
}

/* Reduced motion */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
  }
}
