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

@layer reset {
  *, *::before, *::after { box-sizing: border-box; margin: 0; }
  img, picture, video { display: block; max-width: 100%; }
  input, button, textarea { font: inherit; }
  ul, ol { padding-left: 1.25rem; }
}

@layer tokens {
  :root {
    color-scheme: light;
    --bg:       #ffffff;
    --bg-soft:  #fafbfc;
    --bg-card:  #ffffff;
    --fg:       #1a1a1a;
    --fg-soft:  #374151;
    --muted:    #6b7280;
    --pri:      oklch(58% 0.16 250);
    --pri-soft: oklch(95% 0.04 250);
    --pri-hover: color-mix(in oklch, var(--pri), black 12%);
    --accent:   oklch(70% 0.15 145);
    --warn:     oklch(72% 0.16 70);
    --line:     #e5e7eb;
    --line-soft:#f1f3f5;
    --radius:   0.75rem;
    --radius-sm:0.4rem;
    --shadow:   0 1px 2px rgba(0,0,0,0.04), 0 4px 16px rgba(0,0,0,0.04);
    --shadow-hi:0 4px 24px rgba(0,0,0,0.08);
    --space-1: 0.25rem;
    --space-2: 0.5rem;
    --space-3: 1rem;
    --space-4: 1.5rem;
    --space-5: 2rem;
    --space-6: 3rem;
    --font-sans: -apple-system, BlinkMacSystemFont, "Pretendard", "Apple SD Gothic Neo", system-ui, sans-serif;
    --font-mono: ui-monospace, SFMono-Regular, "JetBrains Mono", Menlo, monospace;
    --max-w: 880px;
  }
}

@layer base {
  html { scroll-behavior: smooth; }
  body {
    font-family: var(--font-sans);
    line-height: 1.7;
    background: var(--bg-soft);
    color: var(--fg);
    -webkit-font-smoothing: antialiased;
  }
  h1, h2, h3 { line-height: 1.3; font-weight: 700; letter-spacing: -0.01em; }
  h1 { font-size: clamp(1.9rem, 4vw, 2.6rem); }
  h2 { font-size: clamp(1.4rem, 2.5vw, 1.75rem); margin-block: var(--space-5) var(--space-3); }
  h3 { font-size: 1.1rem; margin-block: var(--space-4) var(--space-2); }
  p { color: var(--fg-soft); }
  a { color: var(--pri); text-decoration: none; }
  a:hover { color: var(--pri-hover); text-decoration: underline; }
  strong { color: var(--fg); font-weight: 600; }
  code { font-family: var(--font-mono); background: var(--line-soft); padding: 0.1em 0.35em; border-radius: 0.25rem; font-size: 0.9em; }
}

@layer components {
  .container { max-width: var(--max-w); margin-inline: auto; padding-inline: var(--space-4); }

  .hero {
    background: linear-gradient(180deg, var(--pri-soft), var(--bg-soft));
    padding-block: var(--space-6) var(--space-5);
    border-bottom: 1px solid var(--line);
  }
  .hero .kicker {
    text-transform: uppercase;
    letter-spacing: 0.12em;
    font-size: 0.75rem;
    font-weight: 600;
    color: var(--pri);
    margin-bottom: var(--space-2);
  }
  .hero .lede {
    margin-top: var(--space-3);
    font-size: 1.05rem;
    color: var(--fg-soft);
  }

  .toc {
    display: flex;
    flex-wrap: wrap;
    gap: var(--space-2);
    margin-top: var(--space-4);
  }
  .toc a {
    padding: 0.35rem 0.8rem;
    background: var(--bg-card);
    border: 1px solid var(--line);
    border-radius: 9999px;
    font-size: 0.85rem;
    color: var(--fg-soft);
    transition: all 0.15s;
  }
  .toc a:hover {
    border-color: var(--pri);
    color: var(--pri);
    text-decoration: none;
    background: var(--pri-soft);
  }

  main { padding-block: var(--space-5) var(--space-6); }

  section { margin-bottom: var(--space-5); scroll-margin-top: var(--space-4); }

  .card {
    background: var(--bg-card);
    border: 1px solid var(--line);
    border-radius: var(--radius);
    padding: var(--space-4);
    box-shadow: var(--shadow);
  }
  .card h2 { margin-top: 0; }

  .highlight {
    border-left: 4px solid var(--pri);
    background: linear-gradient(180deg, var(--pri-soft), var(--bg-card) 60%);
  }

  .callout {
    background: var(--pri-soft);
    border-left: 3px solid var(--pri);
    padding: var(--space-3) var(--space-4);
    border-radius: var(--radius-sm);
    margin-block: var(--space-3);
  }

  .pipeline {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: var(--space-2);
    padding: var(--space-3);
    background: var(--bg-card);
    border: 1px solid var(--line);
    border-radius: var(--radius);
    margin-bottom: var(--space-4);
    font-size: 0.85rem;
  }
  .pipeline > span:not(.arrow) {
    padding: 0.3rem 0.7rem;
    background: var(--pri-soft);
    color: var(--pri);
    border-radius: 9999px;
    font-weight: 500;
    white-space: nowrap;
  }
  .pipeline .arrow { color: var(--muted); font-weight: 600; }
  .pipeline .goal { background: var(--accent); color: white; }

  .table-wrap {
    overflow-x: auto;
    border: 1px solid var(--line);
    border-radius: var(--radius);
    background: var(--bg-card);
  }
  table { width: 100%; border-collapse: collapse; font-size: 0.92rem; }
  th, td {
    padding: 0.7rem 0.9rem;
    text-align: left;
    border-bottom: 1px solid var(--line-soft);
    vertical-align: top;
  }
  th {
    background: var(--bg-soft);
    font-weight: 600;
    font-size: 0.85rem;
    color: var(--fg-soft);
    text-transform: uppercase;
    letter-spacing: 0.04em;
  }
  tr:last-child td { border-bottom: 0; }
  tbody tr:hover { background: var(--bg-soft); }

  .star1 { color: var(--muted); font-weight: 600; }
  .star2 { color: var(--warn); font-weight: 600; }
  .star3 { color: var(--pri); font-weight: 700; }

  .role-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
    gap: var(--space-3);
  }
  .role-grid .card h3 { margin-top: 0; color: var(--pri); }
  .role-grid .card ul { padding-left: 1.1rem; }
  .role-grid .card li { margin-bottom: 0.35rem; color: var(--fg-soft); }

  .checklist { padding-left: 0; list-style: none; counter-reset: ck; }
  .checklist li {
    counter-increment: ck;
    padding: 0.5rem 0 0.5rem 2.2rem;
    position: relative;
    border-bottom: 1px solid var(--line-soft);
  }
  .checklist li:last-child { border-bottom: 0; }
  .checklist li::before {
    content: counter(ck);
    position: absolute;
    left: 0;
    top: 0.5rem;
    width: 1.6rem;
    height: 1.6rem;
    background: var(--pri);
    color: white;
    border-radius: 50%;
    display: grid;
    place-items: center;
    font-size: 0.78rem;
    font-weight: 700;
  }

  .tree {
    font-family: var(--font-mono);
    background: #0f1115;
    color: #e6e8ee;
    padding: var(--space-4);
    border-radius: var(--radius);
    overflow-x: auto;
    font-size: 0.85rem;
    line-height: 1.6;
  }

  .bullets { padding-left: 1.2rem; }
  .bullets li { margin-bottom: 0.3rem; color: var(--fg-soft); }

  details {
    background: var(--bg-card);
    border: 1px solid var(--line);
    border-radius: var(--radius-sm);
    padding: var(--space-3);
    margin-bottom: var(--space-2);
    transition: background 0.15s;
  }
  details[open] { background: var(--pri-soft); border-color: var(--pri); }
  summary {
    cursor: pointer;
    font-weight: 600;
    color: var(--fg);
    list-style: none;
    display: flex;
    align-items: center;
    gap: var(--space-2);
  }
  summary::before {
    content: "▸";
    color: var(--pri);
    transition: transform 0.2s;
  }
  details[open] summary::before { transform: rotate(90deg); }
  details p { margin-top: var(--space-2); }

  .kids {
    background: linear-gradient(180deg, oklch(96% 0.04 80), var(--bg-card) 70%);
    border-left: 4px solid var(--warn);
  }
  .kids-intro {
    font-size: 1.1rem;
    text-align: center;
    padding: var(--space-3);
    background: white;
    border-radius: var(--radius-sm);
    margin-block: var(--space-3);
  }
  .kids-steps {
    list-style: none;
    padding: 0;
    display: grid;
    gap: var(--space-3);
  }
  .kids-steps > li {
    background: var(--bg-card);
    border: 1px solid var(--line);
    border-radius: var(--radius-sm);
    padding: var(--space-3);
  }
  .kids-steps h3 { margin-top: 0; color: var(--fg); }
  .kids-steps p, .kids-steps li { color: var(--fg-soft); }

  footer {
    border-top: 1px solid var(--line);
    padding-block: var(--space-4);
    color: var(--muted);
    font-size: 0.85rem;
    text-align: center;
    background: var(--bg-card);
  }

  @container (max-width: 600px) {
    .role-grid { grid-template-columns: 1fr; }
  }
}
