/*
 * AWE Radio — canonical design tokens + base styles for public content pages.
 *
 * Load this on any page under aweradio.app/ (landing, blog, why-free,
 * use-cases, features, guide, etc.) so the whole surface reads as one
 * product. Individual pages layer their own classes on top.
 *
 * Don't use this on the listener app or station dashboard — those have
 * their own, denser, state-driven styles.
 */

:root {
  /* Palette */
  --awe-bg:        #0B1628;  /* canonical page background */
  --awe-bg-soft:   #0F1D32;  /* alt surface (cards, toc) */
  --awe-bg-card:   rgba(255,255,255,0.03);
  --awe-border:    rgba(255,255,255,0.07);
  --awe-border-strong: rgba(255,255,255,0.15);

  --awe-sage:      #4ADE80;  /* primary accent / CTA */
  --awe-sage-hov:  #38B866;  /* CTA hover */
  --awe-sage-soft: rgba(74,222,128,0.1);
  --awe-sage-border: rgba(74,222,128,0.25);

  --awe-info:      #60a5fa;  /* blue, for secondary tags */
  --awe-warn:      #f97316;
  --awe-danger:    #F87171;

  /* Text */
  --awe-text:       rgba(255,255,255,0.78);
  --awe-text-dim:   rgba(255,255,255,0.55);
  --awe-text-faint: rgba(255,255,255,0.4);
  --awe-text-mute:  rgba(255,255,255,0.25);
  --awe-text-strong: #fff;

  /* Fonts */
  --awe-sans:    'Outfit', -apple-system, BlinkMacSystemFont, 'Inter', system-ui, sans-serif;
  --awe-display: 'Space Grotesk', var(--awe-sans);

  /* Radii */
  --awe-r-sm: 8px;
  --awe-r-md: 10px;
  --awe-r-lg: 12px;

  /* Spacing scale (use in page CSS for rhythm) */
  --awe-gap-xs: 6px;
  --awe-gap-sm: 12px;
  --awe-gap-md: 20px;
  --awe-gap-lg: 32px;
  --awe-gap-xl: 48px;

  /* Content widths */
  --awe-w-reading: 680px;  /* long-form essay */
  --awe-w-wide:    960px;  /* cards / grids */

  /* Type scale */
  --awe-fs-display: 36px;
  --awe-fs-h2:      22px;
  --awe-fs-lead:    18px;
  --awe-fs-body:    17px;
  --awe-fs-ui:      15px;
  --awe-fs-meta:    13px;
  --awe-lh-body:    1.8;
  --awe-lh-ui:      1.6;
}

/* ── Base ──────────────────────────────────────────────────── */
*, *::before, *::after { margin: 0; padding: 0; box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  font-family: var(--awe-sans);
  background: var(--awe-bg);
  color: var(--awe-text);
  line-height: var(--awe-lh-body);
  -webkit-font-smoothing: antialiased;
}

/* ── Typography ────────────────────────────────────────────── */
h1 {
  font-family: var(--awe-display);
  font-size: var(--awe-fs-display);
  color: var(--awe-text-strong);
  line-height: 1.25;
  letter-spacing: -0.5px;
  font-weight: 700;
  margin-bottom: 16px;
}
h2 {
  font-size: var(--awe-fs-h2);
  color: var(--awe-text-strong);
  font-weight: 600;
  margin-top: 44px;
  margin-bottom: 12px;
}
p  { font-size: var(--awe-fs-body); margin-bottom: var(--awe-gap-md); }
a  { color: var(--awe-sage); }
a:hover { color: var(--awe-sage-hov); }

.awe-lede,
.awe-subtitle {
  font-size: var(--awe-fs-lead);
  color: var(--awe-text-dim);
  line-height: 1.6;
  margin-bottom: var(--awe-gap-xl);
  max-width: var(--awe-w-reading);
}
.awe-meta {
  font-size: var(--awe-fs-meta);
  color: var(--awe-text-mute);
  margin-bottom: 8px;
}

/* ── Layout containers ─────────────────────────────────────── */
.awe-container        { max-width: var(--awe-w-reading); margin: 0 auto; padding: 60px 24px 100px; }
.awe-container-wide   { max-width: var(--awe-w-wide);    margin: 0 auto; padding: 60px 24px 100px; }

/* ── Breadcrumb ────────────────────────────────────────────── */
.awe-breadcrumb {
  display: flex; align-items: center; gap: 8px;
  margin-bottom: 40px;
  font-size: 14px;
}
.awe-breadcrumb a   { color: var(--awe-text-faint); text-decoration: none; }
.awe-breadcrumb a:hover { color: var(--awe-sage); }
.awe-breadcrumb .sep { color: var(--awe-text-mute); }
.awe-breadcrumb .current { color: var(--awe-text-dim); }

/* ── Buttons ───────────────────────────────────────────────── */
.awe-btn {
  display: inline-block;
  padding: 14px 32px;
  border-radius: var(--awe-r-md);
  font-weight: 600;
  font-size: 16px;
  text-decoration: none;
  transition: background 0.2s, color 0.2s, border-color 0.2s;
  border: 1px solid transparent;
  cursor: pointer;
}
.awe-btn-primary {
  background: var(--awe-sage);
  color: var(--awe-bg);
}
.awe-btn-primary:hover { background: var(--awe-sage-hov); color: var(--awe-bg); }
.awe-btn-secondary {
  background: transparent;
  color: var(--awe-sage);
  border-color: var(--awe-sage);
}
.awe-btn-secondary:hover { background: var(--awe-sage-soft); color: var(--awe-sage); }

/* ── CTA box ───────────────────────────────────────────────── */
.awe-cta {
  margin-top: 56px;
  padding: 32px;
  border-radius: var(--awe-r-lg);
  background: rgba(74,222,128,0.06);
  border: 1px solid var(--awe-sage-border);
  text-align: center;
}
.awe-cta h3 { font-size: 20px; color: var(--awe-text-strong); font-weight: 600; margin-bottom: 8px; }
.awe-cta p  { color: var(--awe-text-dim); margin-bottom: 20px; font-size: 15px; }
.awe-cta .awe-btn + .awe-btn { margin-left: 8px; }

/* ── Callout / blockquote ──────────────────────────────────── */
blockquote, .awe-callout {
  border-left: 3px solid var(--awe-sage-border);
  padding: 16px 24px;
  margin: 28px 0;
  background: rgba(74,222,128,0.04);
  border-radius: 0 var(--awe-r-sm) var(--awe-r-sm) 0;
  color: rgba(255,255,255,0.65);
}
blockquote  { font-style: italic; }
.awe-callout { font-style: normal; font-size: 15px; }
.awe-callout strong { color: var(--awe-text-strong); font-weight: 600; }

/* ── Tags ──────────────────────────────────────────────────── */
.awe-tag {
  display: inline-block;
  font-size: 11px; font-weight: 600;
  text-transform: uppercase; letter-spacing: 0.5px;
  padding: 3px 8px;
  border-radius: 4px;
  background: var(--awe-sage-soft); color: var(--awe-sage);
}
.awe-tag-info { background: rgba(96,165,250,0.1); color: var(--awe-info); }

/* ── Footer ────────────────────────────────────────────────── */
.awe-footer {
  margin-top: 64px;
  padding-top: 24px;
  border-top: 1px solid var(--awe-border);
  font-size: var(--awe-fs-meta);
  color: var(--awe-text-mute);
}
.awe-footer a { color: var(--awe-text-faint); text-decoration: none; }
.awe-footer a:hover { color: var(--awe-sage); }

/* ── Card (grid item) ──────────────────────────────────────── */
.awe-card {
  padding: 24px;
  border-radius: var(--awe-r-lg);
  background: var(--awe-bg-card);
  border: 1px solid var(--awe-border);
  transition: border-color 0.2s, transform 0.2s;
}
.awe-card:hover {
  border-color: var(--awe-sage-border);
  transform: translateY(-2px);
}
