@layer reset, base, layout, components, utilities;

:root {
  --color-governance: #473BF0;
  --color-players: #33CA7F;
  --color-commercial: #FB6107;
  --color-navy: #202030;
  --color-slate: #31393C;
  --color-red: #FB6107;
  --color-accent: #33CA7F;
  --color-success: #33CA7F;
  --color-indigo: #473BF0;
  --color-bg: #f8f9fa;
  --color-bg-dark: #202030;
  --color-text: #202030;
  --color-text-muted: #5a6268;
  --color-text-light: #e2e8f0;
  --color-border: #dee2e6;
  --font-sans: 'Inter', system-ui, sans-serif;
  --font-serif: 'Merriweather', Georgia, serif;
  --text-xs: clamp(0.75rem, 0.7rem + 0.25vw, 0.875rem);
  --text-sm: clamp(0.875rem, 0.8rem + 0.35vw, 1rem);
  --text-base: clamp(1rem, 0.9rem + 0.5vw, 1.125rem);
  --text-lg: clamp(1.125rem, 1rem + 0.6vw, 1.25rem);
  --text-xl: clamp(1.25rem, 1.1rem + 0.75vw, 1.5rem);
  --text-2xl: clamp(1.5rem, 1.2rem + 1.5vw, 2rem);
  --text-3xl: clamp(1.875rem, 1.4rem + 2.4vw, 2.5rem);
  --text-4xl: clamp(2.25rem, 1.5rem + 3.75vw, 3.5rem);
  --text-5xl: clamp(3rem, 2rem + 5vw, 4.5rem);
  --space-xs: 0.25rem;
  --space-sm: 0.5rem;
  --space-md: 1rem;
  --space-lg: 1.5rem;
  --space-xl: 2rem;
  --space-2xl: 3rem;
  --space-3xl: 4rem;
  --space-4xl: 6rem;
  --container-max: 1200px;
  --container-narrow: 800px;
  --transition-fast: 150ms ease;
  --transition-base: 250ms ease;
  --transition-slow: 400ms ease;
  --shadow-sm: 0 1px 3px rgb(0 0 0 / 0.08);
  --shadow-md: 0 4px 12px rgb(0 0 0 / 0.1);
  --shadow-lg: 0 12px 40px rgb(0 0 0 / 0.15);
  --shadow-glow: 0 0 40px rgb(0 0 0 / 0.1);
  --radius-sm: 0.25rem;
  --radius-md: 0.5rem;
  --radius-lg: 1rem;
}

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

  html {
    scroll-behavior: smooth;
    -webkit-text-size-adjust: 100%;
  }

  body {
    min-height: 100dvh;
    line-height: 1.6;
    -webkit-font-smoothing: antialiased;
  }

  img, picture, video, canvas, svg {
    display: block;
    max-width: 100%;
  }

  input, button, textarea, select {
    font: inherit;
  }

  p, h1, h2, h3, h4, h5, h6 {
    overflow-wrap: break-word;
  }

  a {
    color: inherit;
    text-decoration: none;
  }

  ul, ol {
    list-style: none;
  }

  details > summary {
    list-style: none;
  }
  details > summary::-webkit-details-marker {
    display: none;
  }
}

@layer base {
  body {
    font-family: var(--font-sans);
    font-size: var(--text-base);
    color: var(--color-text);
    background-color: var(--color-bg);
  }

  h1, h2, h3, h4 {
    font-weight: 700;
    line-height: 1.2;
    color: var(--color-navy);
  }

  h1 { font-size: var(--text-5xl); }
  h2 { font-size: var(--text-3xl); }
  h3 { font-size: var(--text-2xl); }
  h4 { font-size: var(--text-xl); }

  p + p {
    margin-top: var(--space-md);
  }

  strong {
    font-weight: 600;
  }

  blockquote {
    font-family: var(--font-serif);
    font-size: var(--text-xl);
    color: var(--color-navy);
    border-left: 3px solid var(--color-indigo);
    padding-left: var(--space-lg);
    margin-block: var(--space-xl);
  }

  .text-highlight {
    color: var(--color-red);
    font-weight: 700;
    background: linear-gradient(120deg, color-mix(in srgb, var(--color-red) 12%, transparent) 0%, color-mix(in srgb, var(--color-red) 5%, transparent) 100%);
    padding: 0.1em 0.3em;
    border-radius: var(--radius-sm);
    box-decoration-break: clone;
    -webkit-box-decoration-break: clone;
  }

  a:where(:not(.btn):not(.logo)) {
    color: var(--color-governance);
    text-decoration: underline;
    text-underline-offset: 2px;
    transition: color var(--transition-fast);

    &:hover {
      color: var(--color-navy);
    }
  }

  :focus-visible {
    outline: 2px solid var(--color-governance);
    outline-offset: 2px;
  }
}

@layer layout {
  .container {
    width: min(var(--container-max), 100% - var(--space-lg) * 2);
    margin-inline: auto;

    @media (width >= 768px) {
      width: min(var(--container-max), 100% - var(--space-xl) * 2);
    }
  }

  .container--narrow {
    width: min(var(--container-narrow), 100% - var(--space-lg) * 2);

    @media (width >= 768px) {
      width: min(var(--container-narrow), 100% - var(--space-xl) * 2);
    }
  }

  .section {
    padding-block: var(--space-md);

    @media (width >= 768px) {
      padding-block: var(--space-xl);
    }
  }

  .site-header {
    position: sticky;
    top: 0;
    z-index: 100;
    background: var(--color-navy);
    padding-block: var(--space-md);

    & .container {
      display: flex;
      justify-content: space-between;
      align-items: center;
      gap: var(--space-lg);
    }
  }

  .logo {
    font-size: var(--text-xl);
    font-weight: 800;
    color: white;
    letter-spacing: -0.02em;
    text-decoration: none;

    &:hover {
      text-decoration: none;
    }

    & .logo-highlight {
      color: var(--color-accent);
    }
  }

  .nav-main {
    display: flex;
    gap: var(--space-lg);

    & a {
      color: var(--color-text-light);
      font-weight: 500;
      padding: var(--space-sm) var(--space-md);
      border-radius: var(--radius-sm);
      text-decoration: none;
      transition: background var(--transition-fast), color var(--transition-fast);

      &:hover {
        background: color-mix(in srgb, white 10%, transparent);
        color: white;
      }

      &[aria-current="page"] {
        background: color-mix(in srgb, white 15%, transparent);
        color: white;
      }
    }
  }

  .nav-toggle {
    display: none;
  }

  @media (width < 768px) {
    .nav-toggle {
      display: flex;
      flex-direction: column;
      gap: 5px;
      background: none;
      border: none;
      cursor: pointer;
      padding: var(--space-sm);

      & span {
        display: block;
        width: 24px;
        height: 2px;
        background: white;
        transition: transform var(--transition-base);
      }
    }

    .nav-main {
      position: absolute;
      top: 100%;
      left: 0;
      right: 0;
      flex-direction: column;
      background: var(--color-navy);
      padding: var(--space-md);
      gap: 0;
      display: none;
      border-top: 1px solid color-mix(in srgb, white 10%, transparent);

      &.is-open {
        display: flex;
      }

      & a {
        padding: var(--space-md);
        border-radius: var(--radius-sm);
      }
    }
  }

  .site-footer {
    background: var(--color-bg-dark);
    color: var(--color-text-light);
    padding-block: var(--space-xl);
    margin-top: auto;

    @media (width >= 768px) {
      padding-block: var(--space-3xl);
    }

    & .container {
      display: grid;
      gap: var(--space-lg);

      @media (width >= 768px) {
        gap: var(--space-xl);
        grid-template-columns: 1fr auto;
        align-items: start;
      }
    }
  }

  .footer-nav {
    display: flex;
    flex-wrap: wrap;
    gap: var(--space-sm) var(--space-md);

    @media (width >= 768px) {
      gap: var(--space-md) var(--space-xl);
    }

    & a {
      color: var(--color-text-light);
      font-size: var(--text-sm);
      text-decoration: none;

      @media (width >= 768px) {
        font-size: var(--text-base);
      }

      &:hover {
        color: var(--color-accent);
      }
    }
  }

  .footer-disclaimer {
    font-size: var(--text-xs);
    color: #8a8a9a;
    max-width: 50ch;

    @media (width >= 768px) {
      font-size: var(--text-sm);
    }

    & a {
      color: var(--color-accent);

      &:hover {
        color: white;
      }
    }
  }
}

@layer components {

  .btn {
    display: inline-flex;
    align-items: center;
    gap: var(--space-sm);
    padding: var(--space-md) var(--space-xl);
    font-weight: 600;
    border-radius: var(--radius-md);
    border: none;
    cursor: pointer;
    transition: transform var(--transition-fast), box-shadow var(--transition-fast);

    &:hover {
      transform: translateY(-2px);
      box-shadow: var(--shadow-md);
    }

    &:active {
      transform: translateY(0);
    }
  }

  .btn--primary {
    background: var(--color-indigo);
    color: white;

    &:hover {
      background: var(--color-navy);
    }
  }

  .btn--outline {
    background: transparent;
    border: 2px solid currentColor;
    color: var(--color-indigo);

    &:hover {
      background: var(--color-indigo);
      color: white;
      border-color: var(--color-indigo);
    }
  }

  .hero {
    min-height: 100dvh;
    display: grid;
    place-items: center;
    text-align: center;
    padding: var(--space-4xl) var(--space-xl);
    background:
      linear-gradient(to bottom, var(--color-navy), var(--color-bg-dark));
    color: white;

    & h1 {
      color: white;
      margin-bottom: var(--space-lg);
    }

    & .subhead {
      font-size: var(--text-xl);
      color: var(--color-text-light);
      margin-bottom: var(--space-2xl);
      max-width: 45ch;
    }
  }

  .hero--compact {
    min-height: auto;
    padding: var(--space-2xl) var(--space-lg);
    text-align: center;
    background: var(--color-navy);

    @media (width >= 768px) {
      padding: var(--space-3xl) var(--space-xl);
    }

    & h1 {
      font-size: var(--text-4xl);
      letter-spacing: -0.03em;
      margin-bottom: var(--space-sm);

      @media (width >= 768px) {
        font-size: var(--text-5xl);
        margin-bottom: var(--space-md);
      }
    }

    & .hero-highlight {
      color: var(--color-accent);
    }

    & .hero-tagline {
      font-size: var(--text-base);
      color: var(--color-text-light);
      font-weight: 400;

      @media (width >= 768px) {
        font-size: var(--text-lg);
      }
    }
  }

  .card {
    background: white;
    border-radius: var(--radius-lg);
    padding: var(--space-lg);
    box-shadow: var(--shadow-md);
    transition: transform var(--transition-base), box-shadow var(--transition-base);

    @media (width >= 768px) {
      padding: var(--space-xl);
    }

    @media (hover: hover) {
      &:hover {
        transform: translateY(-4px);
        box-shadow: var(--shadow-lg);
      }
    }
  }

  .pillars-grid {
    display: grid;
    gap: var(--space-xl);

    @media (width >= 768px) {
      grid-template-columns: repeat(3, 1fr);
    }
  }

  .pillar-card {
    border-top: 3px solid var(--pillar-color, var(--color-governance));

    &[data-pillar="governance"] { --pillar-color: var(--color-governance); }
    &[data-pillar="players"] { --pillar-color: var(--color-players); }
    &[data-pillar="commercial"] { --pillar-color: var(--color-commercial); }

    & .pillar-icon {
      width: 48px;
      height: 48px;
      margin-inline: auto;
      margin-bottom: var(--space-md);
      color: var(--pillar-color);
    }

    & h3 {
      margin-bottom: var(--space-sm);
      text-align: center;
    }

    & .tagline {
      font-size: var(--text-sm);
      color: var(--pillar-color);
      margin-bottom: var(--space-md);
      font-weight: 500;
      text-align: center;
    }

    & p:last-of-type {
      color: var(--color-text-muted);
      margin-bottom: var(--space-lg);
    }

    & a {
      font-weight: 600;
      color: var(--pillar-color);
    }
  }

  .stats-grid {
    display: grid;
    gap: var(--space-md);
    grid-template-columns: repeat(2, 1fr);

    @media (width >= 768px) {
      gap: var(--space-lg);
    }

    @media (width >= 1024px) {
      grid-template-columns: repeat(5, 1fr);
    }
  }

  .stat-card {
    display: flex;
    flex-direction: column;
    text-align: center;
    padding: var(--space-md);

    @media (width >= 768px) {
      padding: var(--space-xl);
    }

    & .stat-value {
      display: flex;
      align-items: center;
      justify-content: center;
      white-space: nowrap;
      font-size: var(--text-2xl);
      font-weight: 800;
      color: var(--color-navy);
      margin-bottom: var(--space-xs);

      @media (width >= 768px) {
        font-size: var(--text-3xl);
        margin-bottom: var(--space-sm);
      }
    }

    & .stat-label {
      flex: 1;
      display: flex;
      align-items: flex-start;
      justify-content: center;
      font-size: var(--text-xs);
      color: var(--color-text-muted);

      @media (width >= 768px) {
        font-size: var(--text-sm);
      }
    }

    &.stat-card--alert {
      border-color: var(--color-red);

      & .stat-value {
        color: var(--color-red);
      }
    }
  }

  .accordion {
    display: flex;
    flex-direction: column;
    gap: var(--space-md);
  }

  .accordion-item {
    background: white;
    border-radius: var(--radius-md);
    box-shadow: var(--shadow-sm);
    border-left: 4px solid var(--pillar-color, var(--color-governance));
    overflow: hidden;

    &[data-pillar="governance"] { --pillar-color: var(--color-governance); }
    &[data-pillar="players"] { --pillar-color: var(--color-players); }
    &[data-pillar="commercial"] { --pillar-color: var(--color-commercial); }

    &[open] {
      box-shadow: var(--shadow-md);

      & summary::after {
        transform: rotate(180deg);
      }
    }
  }

  .accordion-item > summary {
    display: flex;
    align-items: flex-start;
    gap: var(--space-sm);
    padding: var(--space-md);
    cursor: pointer;
    transition: background var(--transition-fast);

    @media (width >= 768px) {
      align-items: center;
      gap: var(--space-md);
      padding: var(--space-lg);
    }

    @media (hover: hover) {
      &:hover {
        background: var(--color-bg);
      }
    }

    &::after {
      content: '';
      margin-left: auto;
      margin-top: var(--space-sm);
      width: 10px;
      height: 10px;
      border-right: 2px solid var(--color-text-muted);
      border-bottom: 2px solid var(--color-text-muted);
      transform: rotate(45deg);
      transition: transform var(--transition-base);
      flex-shrink: 0;

      @media (width >= 768px) {
        margin-top: 0;
        width: 12px;
        height: 12px;
      }
    }
  }

  .accordion-number {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 28px;
    height: 28px;
    background: #473BF0;
    color: white;
    font-weight: 700;
    font-size: var(--text-sm);
    border-radius: 50%;
    flex-shrink: 0;

    @media (width >= 768px) {
      width: 32px;
      height: 32px;
      font-size: var(--text-base);
    }
  }

  .accordion-header-text {
    flex: 1;
    min-width: 0;

    & .title {
      font-weight: 600;
      color: var(--color-navy);
      font-size: var(--text-sm);
      display: block;

      @media (width >= 768px) {
        font-size: var(--text-base);
      }
    }

    & .summary {
      font-size: var(--text-xs);
      color: var(--color-text-muted);
      display: block;
      margin-top: 2px;

      @media (width >= 768px) {
        font-size: var(--text-sm);
      }
    }
  }

  .accordion-content {
    padding: 0 var(--space-md) var(--space-md);

    @media (width >= 768px) {
      padding: 0 var(--space-lg) var(--space-lg);
      padding-left: calc(var(--space-lg) + 32px + var(--space-md));
    }

    & > * + * {
      margin-top: var(--space-md);

      @media (width >= 768px) {
        margin-top: var(--space-lg);
      }
    }

    & h4 {
      font-size: var(--text-base);
      font-weight: 600;
      color: var(--color-navy);
      margin-bottom: var(--space-sm);
    }

    & p {
      line-height: 1.7;
    }

  }

  .problem-box,
  .solution-box {
    padding: var(--space-lg);
    border-radius: var(--radius-md);

    & h4 {
      font-size: var(--text-sm);
      text-transform: uppercase;
      letter-spacing: 0.05em;
      margin-bottom: var(--space-sm);
    }
  }

  .problem-box {
    background: color-mix(in srgb, var(--color-red) 8%, white);

    & h4 {
      color: var(--color-red);
    }

    & ul {
      display: flex;
      flex-direction: column;
      gap: var(--space-md);
      margin-top: var(--space-md);
    }

    & li {
      padding-left: var(--space-lg);
      position: relative;

      &::before {
        content: '';
        position: absolute;
        left: 0;
        top: 0.5em;
        width: 8px;
        height: 8px;
        background: var(--color-red);
        border-radius: 50%;
      }
    }
  }

  .solution-box {
    background: color-mix(in srgb, var(--color-success) 10%, white);

    & h4 {
      color: var(--color-success);
    }

    & ul {
      display: flex;
      flex-direction: column;
      gap: var(--space-md);
      margin-top: var(--space-md);
    }

    & li {
      padding-left: var(--space-lg);
      position: relative;

      &::before {
        content: '';
        position: absolute;
        left: 0;
        top: 0.5em;
        width: 8px;
        height: 8px;
        background: var(--color-success);
        border-radius: 50%;
      }
    }
  }

  .precedent-box {
    background: var(--color-bg);
    padding: var(--space-lg);
    border-radius: var(--radius-md);
    border: 1px solid var(--color-border);

    & h4 {
      font-size: var(--text-sm);
      text-transform: uppercase;
      letter-spacing: 0.05em;
      color: var(--color-text-muted);
      margin-bottom: var(--space-md);
    }

    & ul {
      display: flex;
      flex-direction: column;
      gap: var(--space-md);
    }

    & li {
      padding-left: var(--space-lg);
      position: relative;

      &::before {
        content: '';
        position: absolute;
        left: 0;
        top: 0.5em;
        width: 8px;
        height: 8px;
        background: var(--color-governance);
        border-radius: 50%;
      }
    }
  }

  .quote-box {
    background: var(--color-navy);
    color: white;
    padding: var(--space-lg);
    border-radius: var(--radius-md);
    font-size: var(--text-base);
    border-left: 3px solid var(--color-accent);
  }

  .info-box {
    background: var(--color-bg);
    padding: var(--space-md) var(--space-lg);
    border-radius: var(--radius-md);
    border-left: 3px solid var(--color-governance);
    font-size: var(--text-sm);
    color: var(--color-text-muted);
  }

  .alert-banner {
    background: color-mix(in srgb, var(--color-red) 10%, white);
    border: 1px solid var(--color-red);
    border-left: 4px solid var(--color-red);
    padding: var(--space-md);
    border-radius: var(--radius-md);
    display: flex;
    align-items: flex-start;
    gap: var(--space-sm);

    @media (width >= 768px) {
      padding: var(--space-lg);
      align-items: center;
      gap: var(--space-md);
    }

    & .alert-icon {
      flex-shrink: 0;
      width: 20px;
      height: 20px;
      color: var(--color-red);

      @media (width >= 768px) {
        width: 24px;
        height: 24px;
      }
    }

    & p {
      font-size: var(--text-sm);

      @media (width >= 768px) {
        font-size: var(--text-base);
      }
    }

    & a {
      color: var(--color-red);
      font-weight: 600;
    }
  }

  .platform-list {
    counter-reset: platform;
    display: flex;
    flex-direction: column;
    gap: var(--space-sm);
  }

  .platform-list-item {
    counter-increment: platform;
    display: flex;
    align-items: center;
    gap: var(--space-md);
    padding: var(--space-md) var(--space-lg);
    background: white;
    border-radius: var(--radius-md);
    box-shadow: var(--shadow-sm);
    transition: transform var(--transition-fast), box-shadow var(--transition-fast);

    &::before {
      content: counter(platform);
      display: flex;
      align-items: center;
      justify-content: center;
      min-width: 28px;
      height: 28px;
      background: var(--color-navy);
      color: white;
      font-weight: 700;
      font-size: var(--text-sm);
      border-radius: 50%;
    }

    &:hover {
      transform: translateX(4px);
      box-shadow: var(--shadow-md);
    }

    & a {
      flex: 1;
      font-weight: 500;
    }
  }

  .table-wrapper {
    overflow-x: auto;
    margin-block: var(--space-lg);
  }

  table {
    width: 100%;
    border-collapse: collapse;
    font-size: var(--text-sm);

    & th, & td {
      padding: var(--space-md);
      text-align: left;
      border-bottom: 1px solid var(--color-border);
    }

    & th {
      background: var(--color-bg);
      font-weight: 600;
      color: var(--color-navy);
    }

    & tr:hover td {
      background: var(--color-bg);
    }
  }

  .chart-container {
    position: relative;
    height: 300px;
    margin-block: var(--space-xl);

    @media (width >= 768px) {
      height: 400px;
    }
  }

  .page-header {
    background: var(--color-navy);
    color: white;
    padding: var(--space-2xl) var(--space-lg);
    text-align: center;

    @media (width >= 768px) {
      padding: var(--space-3xl) var(--space-xl);
    }

    & h1 {
      color: white;
      margin-bottom: var(--space-sm);
      font-size: var(--text-4xl);
      letter-spacing: -0.03em;

      @media (width >= 768px) {
        margin-bottom: var(--space-md);
        font-size: var(--text-5xl);
      }
    }

    & p {
      color: var(--color-text-light);
      max-width: 60ch;
      margin-inline: auto;
      font-size: var(--text-sm);

      @media (width >= 768px) {
        font-size: var(--text-base);
      }
    }
  }

  .prose {
    max-width: 65ch;

    & > * + * {
      margin-top: var(--space-lg);
    }

    & h2, & h3 {
      margin-top: var(--space-2xl);
    }

    & ul, & ol {
      padding-left: var(--space-xl);
    }

    & ul {
      list-style: disc;
    }

    & ol {
      list-style: decimal;
    }

    & li + li {
      margin-top: var(--space-sm);
    }
  }

  .resource-section {
    & + & {
      margin-top: var(--space-3xl);
    }

    & h2 {
      margin-bottom: var(--space-lg);
      padding-bottom: var(--space-md);
      border-bottom: 2px solid var(--color-border);
    }
  }

  .resource-list {
    display: flex;
    flex-direction: column;
    gap: var(--space-md);
  }

  .resource-item {
    display: flex;
    gap: var(--space-md);
    padding: var(--space-md);
    background: white;
    border-radius: var(--radius-md);
    box-shadow: var(--shadow-sm);

    &:hover {
      box-shadow: var(--shadow-md);
    }

    & .resource-icon {
      flex-shrink: 0;
      width: 40px;
      height: 40px;
      display: flex;
      align-items: center;
      justify-content: center;
      background: var(--color-bg);
      border-radius: var(--radius-sm);
      color: var(--color-governance);
    }

    & .resource-content {
      flex: 1;
      min-width: 0;
    }

    & .resource-title {
      font-weight: 600;
      color: var(--color-navy);
    }

    & .resource-desc {
      font-size: var(--text-sm);
      color: var(--color-text-muted);
    }
  }
}

@layer utilities {
  .sr-only {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border: 0;
  }

  .text-center { text-align: center; }
  .text-muted { color: var(--color-text-muted); }

  .desktop-only {
    display: none;

    @media (width >= 768px) {
      display: inline;
    }
  }

  .mt-0 { margin-top: 0; }
  .mt-md { margin-top: var(--space-md); }
  .mt-lg { margin-top: var(--space-lg); }
  .mt-xl { margin-top: var(--space-xl); }
  .mt-2xl { margin-top: var(--space-2xl); }

  .mb-0 { margin-bottom: 0; }
  .mb-md { margin-bottom: var(--space-md); }
  .mb-lg { margin-bottom: var(--space-lg); }
  .mb-xl { margin-bottom: var(--space-xl); }

  .fade-in {
    opacity: 0;
    transform: translateY(20px);
    transition: opacity var(--transition-slow), transform var(--transition-slow);

    &.is-visible {
      opacity: 1;
      transform: translateY(0);
    }
  }

  @media (prefers-reduced-motion: reduce) {
    .fade-in {
      opacity: 1;
      transform: none;
      transition: none;
    }
  }
}
