/* =========================================================
   AI WARRIOR × TE PĀ LITERACY — base design system
   ========================================================= */

:root {
  /* Whenua palette — earth, blood, bush, sky */
  --whenua:      #2b1a12;   /* deep earth / near-black */
  --muku:        #0f0b09;   /* ink */
  --toto:        #a4181a;   /* blood red — resistance */
  --kōkōwai:     #c65a2e;   /* red-ochre */
  --hina:        #f5efe4;   /* bone / lime-plaster */
  --harakeke:    #3a5a3a;   /* flax green */
  --moana:       #1c3f57;   /* deep sea */
  --kōura:       #d9a441;   /* copper / kōura */
  --paper:       #efe6d3;   /* aged paper */
  --line:        rgba(15,11,9,0.14);

  /* Type */
  --sans: "Inter", "Helvetica Neue", system-ui, sans-serif;
  --display: "Fraunces", "Times New Roman", serif;
  --mono: "JetBrains Mono", ui-monospace, monospace;

  /* Scale */
  --text-xs: 0.78rem;
  --text-sm: 0.88rem;
  --text-base: 1rem;
  --text-lg: 1.15rem;
  --text-xl: 1.4rem;
  --text-2xl: 1.9rem;
  --text-3xl: 2.6rem;
  --text-hero: clamp(2.8rem, 6.5vw, 5.6rem);

  /* Space */
  --s-1: 4px; --s-2: 8px; --s-3: 12px; --s-4: 16px;
  --s-5: 24px; --s-6: 32px; --s-7: 48px; --s-8: 72px;
  --s-9: 112px;

  --radius: 4px;
  --maxw: 1180px;
}

*, *::before, *::after { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }

html {
  background: var(--paper);
  color: var(--muku);
  font-family: var(--sans);
  font-size: 17px;
  line-height: 1.55;
  -webkit-font-smoothing: antialiased;
}

body {
  min-height: 100vh;
  background:
    radial-gradient(1200px 600px at 90% -10%, rgba(198,90,46,0.10), transparent 60%),
    radial-gradient(900px 500px at -10% 30%, rgba(58,90,58,0.10), transparent 60%),
    var(--paper);
}

img, svg { max-width: 100%; display: block; }
a { color: var(--toto); text-decoration: none; }
a:hover { text-decoration: underline; text-underline-offset: 3px; }

h1, h2, h3, h4 {
  font-family: var(--display);
  font-weight: 600;
  letter-spacing: -0.01em;
  line-height: 1.05;
  margin: 0 0 var(--s-4);
  color: var(--muku);
}
h1 { font-size: var(--text-hero); letter-spacing: -0.03em; line-height: 0.98; }
h2 { font-size: var(--text-3xl); }
h3 { font-size: var(--text-xl); }
p  { margin: 0 0 var(--s-4); max-width: 68ch; }

.mono { font-family: var(--mono); font-size: var(--text-xs); letter-spacing: 0.06em; text-transform: uppercase; }

.wrap { max-width: var(--maxw); margin: 0 auto; padding: 0 var(--s-5); }
.section { padding: var(--s-8) 0; }
.section-tight { padding: var(--s-7) 0; }

/* =========================================================
   HEADER / NAV
   ========================================================= */
.site-header {
  position: sticky; top: 0; z-index: 40;
  background: rgba(239,230,211,0.85);
  backdrop-filter: blur(10px);
  border-bottom: 1px solid var(--line);
}
.nav-row {
  display: flex; align-items: center; justify-content: space-between;
  padding: var(--s-4) var(--s-5);
  max-width: var(--maxw); margin: 0 auto;
}
.brand {
  display: flex; align-items: center; gap: var(--s-3);
  font-family: var(--display); font-weight: 700; font-size: var(--text-lg);
  color: var(--muku); text-decoration: none;
}
.brand svg { width: 34px; height: 34px; }
.brand small {
  display: block; font-family: var(--sans); font-weight: 500;
  font-size: 10px; letter-spacing: 0.14em; text-transform: uppercase;
  color: var(--toto); margin-top: 2px;
}
.nav { display: flex; gap: var(--s-5); align-items: center; }
.nav a {
  color: var(--muku); font-size: var(--text-sm); font-weight: 500;
  text-decoration: none; padding: 6px 2px; border-bottom: 2px solid transparent;
}
.nav a:hover, .nav a.active { border-color: var(--toto); color: var(--toto); }
.nav-cta {
  background: var(--toto); color: var(--hina) !important;
  padding: 8px 14px !important; border-radius: var(--radius);
  border: none !important; font-weight: 600;
}
.nav-cta:hover { background: var(--muku); }

@media (max-width: 780px) {
  .nav { display: none; }
  .nav.open { display: flex; flex-direction: column; position: absolute; top: 100%; left: 0; right: 0; background: var(--paper); padding: var(--s-5); border-bottom: 1px solid var(--line); gap: var(--s-4); }
  .nav-toggle { display: block; }
}
.nav-toggle {
  display: none; background: none; border: 1px solid var(--muku);
  padding: 6px 10px; border-radius: 4px; font-family: var(--mono); cursor: pointer;
}

/* =========================================================
   COMPONENTS
   ========================================================= */
.eyebrow {
  display: inline-block;
  font-family: var(--mono); font-size: var(--text-xs); letter-spacing: 0.14em; text-transform: uppercase;
  color: var(--toto);
  padding-left: var(--s-4);
  position: relative;
  margin-bottom: var(--s-4);
}
.eyebrow::before {
  content: ""; position: absolute; left: 0; top: 50%;
  width: 10px; height: 2px; background: var(--toto);
}

.btn {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 12px 20px; border-radius: var(--radius);
  font-weight: 600; font-size: var(--text-sm); letter-spacing: 0.02em;
  text-decoration: none; border: 1.5px solid var(--muku);
  transition: transform .15s ease, background .2s ease, color .2s ease;
  cursor: pointer;
}
.btn:hover { transform: translateY(-1px); text-decoration: none; }
.btn-primary { background: var(--toto); color: var(--hina); border-color: var(--toto); }
.btn-primary:hover { background: var(--muku); border-color: var(--muku); color: var(--hina); }
.btn-ghost { background: transparent; color: var(--muku); }
.btn-ghost:hover { background: var(--muku); color: var(--hina); }

.card {
  background: var(--hina);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  padding: var(--s-6);
  transition: transform .2s ease, box-shadow .2s ease;
}
.card:hover { transform: translateY(-2px); box-shadow: 0 10px 30px rgba(15,11,9,0.08); }
.card h3 { margin-top: 0; }

.grid {
  display: grid; gap: var(--s-5);
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
}
.grid-2 { grid-template-columns: repeat(auto-fit, minmax(320px, 1fr)); }

/* Tukutuku divider */
.tukutuku {
  height: 22px;
  background-image:
    linear-gradient(45deg, var(--muku) 25%, transparent 25%),
    linear-gradient(-45deg, var(--muku) 25%, transparent 25%),
    linear-gradient(45deg, transparent 75%, var(--muku) 75%),
    linear-gradient(-45deg, transparent 75%, var(--muku) 75%);
  background-size: 22px 22px;
  background-position: 0 0, 0 11px, 11px -11px, -11px 0;
  opacity: 0.85;
  margin: 0;
}
.tukutuku-red {
  background-image:
    linear-gradient(45deg, var(--toto) 25%, transparent 25%),
    linear-gradient(-45deg, var(--toto) 25%, transparent 25%),
    linear-gradient(45deg, transparent 75%, var(--toto) 75%),
    linear-gradient(-45deg, transparent 75%, var(--toto) 75%);
}

/* Big serif quote */
blockquote.pull {
  font-family: var(--display); font-size: var(--text-2xl); line-height: 1.2;
  border-left: 4px solid var(--toto);
  padding: var(--s-4) 0 var(--s-4) var(--s-5);
  margin: var(--s-6) 0;
  color: var(--muku);
  font-style: italic;
}
blockquote.pull cite {
  display: block; margin-top: var(--s-3);
  font-family: var(--mono); font-size: var(--text-xs); font-style: normal;
  letter-spacing: 0.1em; text-transform: uppercase; color: var(--kōkōwai);
}

/* Hero */
.hero {
  padding: var(--s-9) 0 var(--s-8);
  position: relative;
  overflow: hidden;
}
.hero-eyebrow {
  font-family: var(--mono); font-size: var(--text-xs); letter-spacing: 0.2em;
  text-transform: uppercase; color: var(--toto); margin-bottom: var(--s-4);
}
.hero h1 span.accent { color: var(--toto); font-style: italic; }
.hero-sub { font-size: var(--text-lg); max-width: 60ch; color: var(--whenua); margin: var(--s-5) 0 var(--s-6); }
.hero-actions { display: flex; gap: var(--s-4); flex-wrap: wrap; }

/* Footer */
.site-footer {
  background: var(--muku); color: var(--paper);
  padding: var(--s-7) 0 var(--s-6);
  margin-top: var(--s-8);
}
.site-footer a { color: var(--kōura); }
.site-footer h4 { color: var(--paper); font-family: var(--sans); font-size: var(--text-sm); text-transform: uppercase; letter-spacing: 0.14em; }
.footer-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(200px, 1fr)); gap: var(--s-6); margin-bottom: var(--s-6); }
.footer-grid ul { list-style: none; padding: 0; margin: 0; }
.footer-grid li { margin-bottom: 8px; font-size: var(--text-sm); }
.footer-bottom { font-size: var(--text-xs); font-family: var(--mono); text-transform: uppercase; letter-spacing: 0.1em; opacity: 0.7; padding-top: var(--s-5); border-top: 1px solid rgba(239,230,211,0.15); }

/* Utility */
.text-center { text-align: center; }
.mt-6 { margin-top: var(--s-6); }
.mt-7 { margin-top: var(--s-7); }
.mb-6 { margin-bottom: var(--s-6); }
.two-col { display: grid; grid-template-columns: 1.2fr 1fr; gap: var(--s-8); align-items: center; }
@media (max-width: 780px) { .two-col { grid-template-columns: 1fr; gap: var(--s-6); } }

/* Callout / panel */
.panel {
  background: var(--muku); color: var(--hina);
  padding: var(--s-7); border-radius: var(--radius);
  position: relative; overflow: hidden;
}
.panel::before {
  content: ""; position: absolute; inset: 0;
  background:
    repeating-linear-gradient(45deg, transparent 0 22px, rgba(164,24,26,0.12) 22px 24px);
  pointer-events: none;
}
.panel h2, .panel h3 { color: var(--kōura); }
.panel p { color: var(--paper); max-width: 60ch; }

/* Course cards */
.course-item {
  display: flex; gap: var(--s-5); padding: var(--s-5) 0;
  border-bottom: 1px solid var(--line);
}
.course-item:last-child { border-bottom: 0; }
.course-num {
  font-family: var(--display); font-size: var(--text-3xl); color: var(--toto);
  min-width: 68px; line-height: 1;
}
.course-body h3 { margin-bottom: 6px; }
.course-body p { margin-bottom: 8px; color: var(--whenua); }
.course-meta { font-family: var(--mono); font-size: var(--text-xs); letter-spacing: 0.1em; text-transform: uppercase; color: var(--kōkōwai); }

/* ---------- Language toggle ---------- */
.lang-toggle {
  display: inline-flex;
  gap: 2px;
  padding: 3px;
  border: 1px solid var(--line);
  border-radius: 999px;
  background: rgba(15,11,9,0.04);
  margin-left: var(--s-3);
}
.lang-toggle button {
  font-family: var(--mono);
  font-size: 0.72rem;
  font-weight: 600;
  letter-spacing: 0.08em;
  padding: 4px 10px;
  border: none;
  background: transparent;
  color: var(--whenua);
  border-radius: 999px;
  cursor: pointer;
  transition: background 120ms ease, color 120ms ease;
}
.lang-toggle button:hover { color: var(--toto); }
.lang-toggle button.active {
  background: var(--muku);
  color: var(--paper);
}
@media (max-width: 780px) {
  .lang-toggle { margin: var(--s-3) 0 0 0; align-self: flex-start; }
}
