/* ═══════════════════════════════════════════════════
   SKLARP.COM  —  style.css  v5
   Bricolage Grotesque · DM Sans · JetBrains Mono
   Palette: warm umber · sage-olive · terracotta · ochre
   (Rothko / Clyfford Still color-field background)
═══════════════════════════════════════════════════ */

:root {
  --bg:             #0e0807;
  --surface:        #1a100d;
  --card:           rgba(255,238,218,.045);
  --card-hover:     rgba(255,238,218,.075);
  --border:         rgba(255,238,218,.085);
  --border-strong:  rgba(255,238,218,.17);
  --text:           #f3e9d9;
  --muted:          #b0a094;
  --muted-2:        #7a6b60;
  --teal:           #a8c47a;
  --teal-dim:       rgba(168,196,122,.12);
  --teal-glow:      rgba(168,196,122,.22);
  --violet:         #d6856a;
  --violet-dim:     rgba(214,133,106,.12);
  --violet-glow:    rgba(214,133,106,.22);
  --warm:           #e8a567;
  --warm-dim:       rgba(232,165,103,.12);
  --font-display:   "Bricolage Grotesque", ui-sans-serif, system-ui, sans-serif;
  --font-body:      "DM Sans", ui-sans-serif, system-ui, -apple-system, sans-serif;
  --font-mono:      "JetBrains Mono", "SFMono-Regular", ui-monospace, monospace;
  --max:            1160px;
  --radius:         20px;
  --radius-sm:      12px;
  --radius-xs:      8px;
  --nav-h:          80px;
  --ease:           cubic-bezier(.4,0,.2,1);
  --t:              200ms;
  --t-slow:         360ms;
  --shadow:         0 4px 28px rgba(0,0,0,.42);
  --shadow-teal:    0 6px 32px rgba(168,196,122,.16);
  --shadow-violet:  0 6px 32px rgba(214,133,106,.18);
}

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

/* Cross-document view transitions — supported browsers crossfade
   between pages automatically; unsupported ones just navigate. */
@view-transition { navigation: auto; }
::view-transition-old(root),
::view-transition-new(root) {
  animation-duration: 220ms;
  animation-timing-function: cubic-bezier(.4, 0, .2, 1);
}
.site-header { view-transition-name: site-header; }
.site-footer { view-transition-name: site-footer; }
@media (prefers-reduced-motion: reduce) {
  ::view-transition-group(*),
  ::view-transition-old(*),
  ::view-transition-new(*) { animation: none !important; }
}
body {
  background: var(--bg);
  color: var(--text);
  font-family: var(--font-body);
  font-size: 1rem;
  line-height: 1.7;
  overflow-x: hidden;
  -webkit-font-smoothing: antialiased;
}
img { max-width: 100%; display: block; }
a { color: inherit; text-decoration: none; }
button { font: inherit; cursor: pointer; }
strong { font-weight: 600; }

/* Rothko / Clyfford Still color-field background.
   Stacked, soft-edged ellipses paint horizontal-ish
   territories of ochre, oxblood, moss and rose.
   A second layer (::after) adds a torn, flame-like
   vertical edge — a nod to Still's jagged forms. */
body::before {
  content: '';
  position: fixed;
  inset: 0;
  background:
    /* upper band — warm ochre / sienna haze */
    radial-gradient(ellipse 130% 55% at 50% -8%,  rgba(196,108,52,.22)  0%, transparent 62%),
    /* mid band — deep oxblood field, left-heavy */
    radial-gradient(ellipse 135% 42% at 22% 42%, rgba(112,32,28,.32)   0%, transparent 64%),
    /* lower band — dusty moss / olive */
    radial-gradient(ellipse 115% 48% at 78% 78%, rgba(102,116,58,.18)  0%, transparent 62%),
    /* foot — dusty rose flare */
    radial-gradient(ellipse  90% 32% at 55% 112%, rgba(190,98,82,.20)  0%, transparent 62%),
    /* slow vertical wash to deepen everything */
    linear-gradient(180deg, rgba(20,8,6,.0) 0%, rgba(8,4,3,.55) 100%);
  pointer-events: none;
  z-index: 0;
}
body::after {
  content: '';
  position: fixed;
  inset: 0;
  /* torn vertical edge — Clyfford Still flame, very faint */
  background:
    linear-gradient(96deg,
      rgba(60,20,14,.0)  0%,
      rgba(60,20,14,.0) 38%,
      rgba(78,28,18,.22) 39%,
      rgba(78,28,18,.0)  41%,
      rgba(60,20,14,.0)  58%,
      rgba(140,72,46,.14) 60%,
      rgba(140,72,46,.0) 63%,
      rgba(60,20,14,.0) 100%);
  mix-blend-mode: screen;
  pointer-events: none;
  z-index: 0;
}
body > * { position: relative; z-index: 1; }

/* ── Accessibility ── */
.skip-link {
  position: absolute; left: 1rem; top: -6rem; z-index: 200;
  background: var(--teal); color: #14100a;
  padding: .75rem 1.25rem; border-radius: 999px; font-weight: 600;
  transition: top var(--t);
}
.skip-link:focus { top: 1rem; }

/* ── Shell ── */
.shell, .nav-shell, main { width: min(100% - 2.5rem, var(--max)); margin-inline: auto; }

/* ───── NAV ───── */
.site-header {
  position: sticky; top: 0; z-index: 100;
  background: rgba(14,8,7,.82);
  backdrop-filter: blur(22px) saturate(160%);
  border-bottom: 1px solid rgba(255,238,218,.06);
}
.nav-shell {
  min-height: var(--nav-h);
  display: flex; align-items: center; justify-content: space-between; gap: 1rem;
}
.brand {
  display: inline-flex; align-items: center; gap: .8rem;
  font-family: var(--font-display); font-weight: 700;
  font-size: 1.05rem; letter-spacing: -.03em;
}
.brand-mark {
  display: grid; place-items: center;
  width: 2.4rem; height: 2.4rem;
  border-radius: var(--radius-xs);
  background: linear-gradient(135deg, var(--teal-dim), var(--violet-dim));
  border: 1px solid rgba(255,255,255,.1);
  color: var(--teal); font-family: var(--font-mono); font-size: .9rem;
}
.brand-sub {
  display: block;
  font: 500 .72rem/1.2 var(--font-mono);
  color: var(--muted); margin-top: .1rem;
}
.nav-links { display: flex; gap: .15rem; align-items: center; }
.nav-links a {
  font-size: .88rem; font-weight: 500; color: var(--muted);
  padding: .55rem 1rem; border-radius: 999px;
  border: 1px solid transparent;
  transition: color var(--t), background var(--t), border-color var(--t);
}
.nav-links a:hover { color: var(--text); background: rgba(255,255,255,.05); border-color: var(--border); }
.nav-links a[aria-current="page"] { color: var(--teal); background: var(--teal-dim); border-color: rgba(94,234,212,.22); }
.nav-toggle {
  display: none; width: 2.6rem; height: 2.6rem;
  border-radius: var(--radius-xs); border: 1px solid var(--border);
  background: var(--card); color: var(--text);
  flex-direction: column; align-items: center; justify-content: center; gap: 4px;
}
.nav-toggle span { display: block; width: 1.1rem; height: 2px; background: currentColor; border-radius: 2px; }
.mobile-panel {
  display: none;
  width: min(100% - 2.5rem, var(--max)); margin: 0 auto .75rem;
  padding: .6rem; border: 1px solid var(--border); border-radius: var(--radius);
  background: rgba(14,8,7,.97); backdrop-filter: blur(20px);
}
.mobile-panel a {
  display: block; padding: .8rem 1rem; border-radius: var(--radius-sm);
  color: var(--muted); font-weight: 500; transition: background var(--t), color var(--t);
}
.mobile-panel a:hover, .mobile-panel a[aria-current="page"] { background: var(--card); color: var(--text); }

/* ───── SECTIONS ───── */
section { padding: 5.5rem 0; }
.pt-0 { padding-top: 0 !important; }
.mt-sm { margin-top: 1rem !important; }
.mt-md { margin-top: 1.75rem !important; }

.section-head {
  display: flex; align-items: flex-end; justify-content: space-between;
  gap: 1.75rem; margin-bottom: 2.5rem;
}
.section-head h2 {
  margin: .4rem 0 0;
  font-family: var(--font-display); font-weight: 700;
  font-size: clamp(1.55rem, 2.8vw, 2.35rem);
  line-height: 1.1; letter-spacing: -.04em;
}

/* ───── CHIPS ───── */
.eyebrow, .kicker, .pill, .meta-chip, .tag {
  display: inline-flex; align-items: center; gap: .4rem;
  padding: .32rem .75rem; border-radius: 999px;
  border: 1px solid var(--border); background: var(--card);
  color: var(--muted); font: 500 .78rem/1 var(--font-mono); letter-spacing: .02em;
}
.eyebrow, .kicker { color: var(--teal); border-color: rgba(94,234,212,.2); background: var(--teal-dim); }
.pill { color: var(--violet); border-color: rgba(167,139,250,.22); background: var(--violet-dim); }

/* ───── HERO ───── */
.hero, .page-hero { min-height: calc(68vh - var(--nav-h)); display: grid; align-items: center; }
.hero { padding: 4rem 0; }
.page-hero { padding: 3rem 0 1rem; }

.hero-grid {
  display: grid; grid-template-columns: 1.25fr .85fr;
  gap: 4.5rem; align-items: center;
}
.hero h1, .page-hero h1 {
  margin: 1rem 0 1.25rem;
  font-family: var(--font-display); font-weight: 800;
  font-size: clamp(2.8rem, 6.2vw, 5.4rem);
  line-height: .97; letter-spacing: -.055em;
}
.hero h1 .accent-line { color: var(--violet); }
.hero h1 em { font-style: normal; color: var(--teal); }
.lead { max-width: 58ch; color: var(--muted); font-size: clamp(.98rem, 1.4vw, 1.14rem); line-height: 1.78; }
.hero-actions { display: flex; gap: .75rem; flex-wrap: wrap; margin-top: 2rem; }

.cursor {
  width: .55rem; height: 1rem; display: inline-block;
  background: var(--teal); border-radius: 1px;
  animation: blink 1.1s step-end infinite; vertical-align: middle;
}
@keyframes blink { 50% { opacity: 0; } }

.motd-card {
  background: linear-gradient(140deg, var(--violet-dim) 0%, var(--teal-dim) 100%);
  border: 1px solid rgba(167,139,250,.22); border-radius: var(--radius); padding: 2rem;
}
.motd-card .label {
  font: 600 .72rem/1 var(--font-mono); color: var(--violet);
  letter-spacing: .1em; text-transform: uppercase; margin-bottom: .8rem; display: block;
}
.motd-card p { color: var(--muted); font-size: .93rem; margin: .5rem 0; }
.motd-card small { font-family: var(--font-mono); font-size: .75rem; color: var(--muted-2); }

/* ───── BUTTONS ───── */
.btn {
  display: inline-flex; align-items: center; gap: .5rem;
  padding: .82rem 1.65rem; border-radius: 999px;
  border: 1px solid var(--border-strong);
  font-weight: 600; font-size: .88rem; letter-spacing: .01em;
  transition: transform var(--t) var(--ease), box-shadow var(--t) var(--ease),
              background var(--t), border-color var(--t), color var(--t);
}
.btn:hover { transform: translateY(-2px); }
.btn-primary {
  background: var(--teal); color: #14100a;
  border-color: transparent; box-shadow: 0 2px 14px rgba(168,196,122,.22);
}
.btn-primary:hover { box-shadow: var(--shadow-teal); }
.btn-secondary {
  background: transparent; color: var(--violet);
  border-color: rgba(167,139,250,.38);
}
.btn-secondary:hover { background: var(--violet-dim); border-color: rgba(167,139,250,.6); box-shadow: var(--shadow-violet); }
.btn-ghost {
  background: var(--card); color: var(--muted); border-color: var(--border);
}
.btn-ghost:hover { color: var(--text); background: var(--card-hover); border-color: var(--border-strong); }

/* ───── CARDS ───── */
.card, .panel, .feature-card, .project-card, .gallery-card, .note, .story-block, .meme-card {
  padding: 1.75rem;
  background: var(--card); border: 1px solid var(--border);
  border-radius: var(--radius);
  transition: border-color var(--t), box-shadow var(--t), transform var(--t-slow) var(--ease);
}
.card:hover, .feature-card:hover, .note:hover { border-color: var(--border-strong); box-shadow: var(--shadow); transform: translateY(-2px); }
.card p, .panel p, .feature-card p, .project-card p, .note p, .story-block p, .gallery-card p { color: var(--muted); }
.feature-card { border-color: rgba(167,139,250,.14); }
.feature-card:hover { border-color: rgba(167,139,250,.32); box-shadow: var(--shadow-violet); }
.feature-card h3, .card h3 {
  font-family: var(--font-display); font-size: 1.2rem; font-weight: 700;
  margin: .6rem 0 .5rem; letter-spacing: -.025em;
}

/* ───── GRIDS ───── */
.grid-2       { display: grid; grid-template-columns: repeat(2,minmax(0,1fr)); gap: 1.75rem; }
.grid-3       { display: grid; grid-template-columns: repeat(3,minmax(0,1fr)); gap: 1.75rem; }
.project-grid { display: grid; grid-template-columns: repeat(3,minmax(0,1fr)); gap: 1.75rem; }
.footer-grid  { display: grid; grid-template-columns: 2fr 1fr 1fr; gap: 4rem; }

/* ───── INLINE HELPERS ───── */
.tag-row, .project-tags, .inline-links, .filter-row { display: flex; gap: .4rem; flex-wrap: wrap; }
.clean-list { list-style: none; padding: 0; }
.clean-list li { padding: .32rem 0 .32rem 1.4rem; position: relative; color: var(--muted); font-size: .92rem; }
.clean-list li::before { content: "▸"; position: absolute; left: 0; color: var(--teal); font-size: .72rem; top: .55rem; }
.breadcrumbs { display: flex; gap: .4rem; flex-wrap: wrap; color: var(--muted-2); font-size: .82rem; margin-bottom: .75rem; font-family: var(--font-mono); }
.breadcrumbs a { color: var(--muted); }
.breadcrumbs a:hover { color: var(--teal); }
.text-link { color: var(--teal); font-weight: 600; }
.text-link:hover { text-decoration: underline; }
.muted { color: var(--muted); }

/* ───── RESUME LAYOUT ───── */
.resume-layout { display: grid; grid-template-columns: 300px minmax(0,1fr); gap: 4.5rem; align-items: start; }
.sticky { position: sticky; top: calc(var(--nav-h) + 1.5rem); }
.panel { padding: 1.5rem; }
.panel-title { font-family: var(--font-display); font-size: 1.45rem; font-weight: 700; letter-spacing: -.03em; margin: .6rem 0 .55rem; }
.sticky .panel { border-color: rgba(167,139,250,.16); background: linear-gradient(155deg, rgba(167,139,250,.07) 0%, var(--card) 60%); }
.sticky .panel + .panel { margin-top: 1rem; }

/* ───── TIMELINE ───── */
.timeline { display: flex; flex-direction: column; }
.timeline-card {
  display: grid; grid-template-columns: 138px minmax(0,1fr);
  gap: 2rem; padding: 1.85rem 0;
  border-bottom: 1px solid var(--border);
  background: none; box-shadow: none; border-radius: 0;
  transition: background var(--t);
}
.timeline-card:first-child { padding-top: 0; }
.timeline-card:last-child { border-bottom: none; }
.timeline-card:hover { background: none; transform: none; box-shadow: none; }
.timeline-card:hover .timeline-copy h3 { color: var(--teal); }
.tl-meta { padding-top: .1rem; }
.period { display: block; font: 600 .8rem/1.2 var(--font-mono); color: var(--violet); margin-bottom: .5rem; }
.timeline-copy h3 {
  font-family: var(--font-display); font-size: 1.1rem; font-weight: 700;
  letter-spacing: -.025em; margin-bottom: .4rem; transition: color var(--t);
}
.timeline-copy p { color: var(--muted); font-size: .92rem; line-height: 1.72; }
.timeline-copy ul { margin: .75rem 0 0; padding-left: 1.1rem; color: var(--muted); font-size: .88rem; }
.timeline-copy ul li { margin: .35rem 0; }
.timeline-copy ul li strong { color: var(--text); }

/* ───── PROJECTS ───── */
.project-card { display: flex; flex-direction: column; gap: .7rem; }
.project-card.featured {
  grid-column: span 2;
  background: linear-gradient(135deg, var(--teal-dim) 0%, var(--violet-dim) 100%);
  border-color: rgba(94,234,212,.22);
}
.project-card.featured:hover { box-shadow: var(--shadow-teal); border-color: rgba(94,234,212,.38); }
.project-card h3 { font-family: var(--font-display); font-size: 1.1rem; font-weight: 700; letter-spacing: -.025em; margin: .1rem 0; }
.project-card p { font-size: .9rem; color: var(--muted); flex: 1; margin: 0; }
.media-frame {
  border-radius: var(--radius-sm); border: 1px dashed rgba(255,255,255,.14);
  background: linear-gradient(135deg, var(--teal-dim), var(--violet-dim));
  aspect-ratio: 16/9; display: grid; place-items: center;
  text-align: center; color: var(--muted); padding: 1.25rem; font-size: .85rem;
}
.media-frame strong { display: block; color: var(--text); margin-bottom: .3rem; }
.media-frame small { margin-top: .4rem; font-family: var(--font-mono); font-size: .72rem; opacity: .5; }
.media-frame.square { aspect-ratio: 1/1; }
.media-frame.tall { aspect-ratio: 4/5; }

/* ───── FILTER CHIPS ───── */
.filter-chip {
  border: 1px solid var(--border); background: var(--card);
  color: var(--muted); padding: .5rem 1.05rem; border-radius: 999px;
  font-size: .83rem; font-weight: 500;
  transition: color var(--t), background var(--t), border-color var(--t);
}
.filter-chip.is-active, .filter-chip:hover { color: var(--teal); border-color: rgba(168,196,122,.32); background: var(--teal-dim); }

/* Make the [hidden] attribute actually hide project cards.
   .project-card sets display:flex, which has the same specificity
   as the user-agent [hidden]{display:none} rule and wins by being
   later in the cascade. This restores hidden's expected behavior. */
.project-card[hidden] { display: none !important; }

/* ───── CAMINO / LIFE STATS ───── */
.stat-row {
  display: grid; grid-template-columns: repeat(4,1fr); gap: 1.75rem;
  padding: 2rem 2.25rem;
  background: linear-gradient(135deg, var(--warm-dim), rgba(167,139,250,.08));
  border: 1px solid rgba(251,146,60,.2); border-radius: var(--radius);
  margin-bottom: 2.5rem;
}
.stat-block { text-align: center; }
.stat-num { display: block; font-family: var(--font-display); font-size: 2.5rem; font-weight: 800; letter-spacing: -.04em; color: var(--warm); line-height: 1; margin-bottom: .3rem; }
.stat-label { font-size: .78rem; color: var(--muted); font-family: var(--font-mono); }

/* Route */
.route { display: flex; flex-direction: column; gap: 0; padding-left: 1.5rem; position: relative; }
.route::before { content: ''; position: absolute; left: 6px; top: 10px; bottom: 10px; width: 2px; background: linear-gradient(to bottom, var(--warm), var(--violet)); opacity: .45; }
.route-stop { position: relative; padding: .85rem 0 .85rem 1.5rem; }
.route-stop::before { content: ''; position: absolute; left: -1.44rem; top: 1.2rem; width: 10px; height: 10px; border-radius: 50%; border: 2px solid var(--warm); background: var(--bg); }
.route-stop.end::before { background: var(--warm); }
.route-stop strong { display: block; font-size: .96rem; color: var(--text); margin-bottom: .1rem; }
.route-stop span { font-family: var(--font-mono); font-size: .72rem; color: var(--muted-2); }

/* Wine notes */
.wine-note { background: var(--card); border: 1px solid var(--border); border-radius: var(--radius); padding: 1.5rem; transition: border-color var(--t), transform var(--t-slow) var(--ease); }
.wine-note:hover { border-color: rgba(251,146,60,.28); transform: translateY(-2px); }
.wine-note .region { font-family: var(--font-mono); font-size: .72rem; color: var(--warm); letter-spacing: .08em; text-transform: uppercase; margin-bottom: .4rem; display: block; }
.wine-note h4 { font-family: var(--font-display); font-size: 1rem; font-weight: 700; margin-bottom: .35rem; letter-spacing: -.02em; }
.wine-note p { color: var(--muted); font-size: .87rem; line-height: 1.65; }
.wine-note .descriptors { display: flex; gap: .35rem; flex-wrap: wrap; margin-top: .75rem; }
.wine-note .descriptor { font-family: var(--font-mono); font-size: .7rem; padding: .2rem .55rem; border: 1px solid rgba(251,146,60,.2); border-radius: 999px; color: var(--muted); background: var(--warm-dim); }

/* Secret */
.secret-panel { display: none; margin-top: 1rem; padding: 1rem 1.25rem; border-radius: var(--radius-sm); border: 1px dashed rgba(94,234,212,.35); background: var(--teal-dim); font-size: .9rem; }
.secret-panel.is-visible { display: block; }
.meme-card { max-width: 540px; margin: 0 auto; text-align: center; }
.meme-card img { margin: 1.25rem auto 0; border-radius: var(--radius-sm); border: 1px solid var(--border); }

/* Lang cards */
.lang-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 1rem; }
.lang-card { background: var(--card); border: 1px solid var(--border); border-radius: var(--radius); padding: 1.4rem; transition: border-color var(--t), transform var(--t-slow) var(--ease); }
.lang-card:hover { border-color: var(--border-strong); transform: translateY(-2px); }
.lang-card .lang-name { font-family: var(--font-display); font-weight: 700; font-size: 1.05rem; display: block; margin-bottom: .2rem; letter-spacing: -.02em; }
.lang-card .lang-level { font-family: var(--font-mono); font-size: .72rem; color: var(--violet); display: block; margin-bottom: .5rem; }
.lang-card p { color: var(--muted); font-size: .83rem; }
.lang-native { border-color: rgba(94,234,212,.25); }
.lang-fluent { border-color: rgba(167,139,250,.2); }

/* Vibecheck */
.vibe-board { display: grid; grid-template-columns: 1fr 1fr; gap: 1.75rem; margin-bottom: 2.5rem; }
.vibe-card { background: linear-gradient(135deg, var(--violet-dim), var(--teal-dim)); border: 1px solid rgba(167,139,250,.22); border-radius: var(--radius); padding: 2rem; }
.vibe-label { font: 600 .72rem/1 var(--font-mono); color: var(--violet); letter-spacing: .1em; text-transform: uppercase; display: block; margin-bottom: .75rem; }
.vibe-text { font-family: var(--font-display); font-size: 1.35rem; font-weight: 700; min-height: 2em; transition: opacity .2s; margin-bottom: 1rem; }
.vibe-stats { display: flex; flex-direction: column; gap: .75rem; }
.stat-counter { background: var(--card); border: 1px solid var(--border); border-radius: var(--radius); padding: 1rem 1.4rem; display: flex; align-items: center; gap: 1rem; }
.stat-counter .num { font-family: var(--font-mono); font-size: 1.55rem; color: var(--teal); min-width: 3ch; transition: transform .15s; }
.stat-counter .lbl { color: var(--muted); font-size: .83rem; flex: 1; }
.stat-btn { width: 28px; height: 28px; border-radius: 50%; border: 1px solid var(--border-strong); background: none; color: var(--muted); font-size: .95rem; display: grid; place-items: center; transition: background var(--t), border-color var(--t), color var(--t); }
.stat-btn:hover { background: var(--teal-dim); border-color: var(--teal); color: var(--teal); }

/* ───── FOOTER ───── */
.site-footer { padding: 3.5rem 0 3rem; background: rgba(10,5,4,.7); border-top: 1px solid var(--border); margin-top: 2rem; }
.footer-heading { font-family: var(--font-display); font-size: .95rem; font-weight: 700; letter-spacing: -.01em; margin-bottom: .9rem; }
.footer-list { list-style: none; display: flex; flex-direction: column; gap: .55rem; }
.footer-grid p, .footer-grid a { color: var(--muted); font-size: .87rem; }
.footer-grid a:hover { color: var(--teal); }

/* ───── SCROLL REVEAL ───── */
.reveal { opacity: 0; transform: translateY(18px); transition: opacity .5s var(--ease), transform .5s var(--ease); }
.reveal.is-visible { opacity: 1; transform: translateY(0); }

/* ───── RESPONSIVE ───── */
@media (max-width: 1024px) {
  .resume-layout { grid-template-columns: 1fr; gap: 2.5rem; }
  .sticky { position: static; }
  .hero-grid { grid-template-columns: 1fr; gap: 2.5rem; }
  .motd-card { display: none; }
  .footer-grid { grid-template-columns: 1fr 1fr; gap: 2.5rem; }
}
@media (max-width: 820px) {
  .grid-2, .grid-3, .project-grid { grid-template-columns: 1fr; }
  .project-card.featured { grid-column: auto; }
  .stat-row { grid-template-columns: repeat(2,1fr); }
  .lang-grid { grid-template-columns: repeat(2,1fr); }
  .vibe-board { grid-template-columns: 1fr; }
  .footer-grid { grid-template-columns: 1fr; gap: 1.75rem; }
}
@media (max-width: 680px) {
  :root { --nav-h: 70px; }
  .nav-links { display: none; }
  .nav-toggle { display: flex; }
  .mobile-panel.is-open { display: block; }
  .timeline-card { grid-template-columns: 1fr; gap: .6rem; }
  .shell, .nav-shell, main { width: min(100% - 1.5rem, var(--max)); }
  section { padding: 3.5rem 0; }
  .stat-row { grid-template-columns: repeat(2,1fr); padding: 1.5rem; gap: 1rem; }
  .lang-grid { grid-template-columns: 1fr; }
}
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after { animation-duration:.01ms!important; animation-iteration-count:1!important; transition-duration:.01ms!important; }
  .reveal { opacity: 1; transform: none; }
  html { scroll-behavior: auto; }
}

/* ═══════════════════════════════════════════════════
   CAMINO PAGE — highlights grid + interactive map
═══════════════════════════════════════════════════ */
.highlight-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 1.5rem;
}
.highlight-card {
  display: flex; flex-direction: column; gap: .7rem;
  padding: 1.65rem 1.75rem;
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  transition: border-color var(--t), transform var(--t-slow) var(--ease), box-shadow var(--t);
}
.highlight-card:hover {
  border-color: rgba(232,165,103,.32);
  transform: translateY(-2px);
  box-shadow: var(--shadow);
}
.highlight-card .when {
  font: 600 .7rem/1 var(--font-mono);
  color: var(--warm);
  letter-spacing: .09em;
  text-transform: uppercase;
}
.highlight-card h3 {
  font-family: var(--font-display);
  font-size: 1.12rem;
  font-weight: 700;
  letter-spacing: -.025em;
  margin: 0;
}
.highlight-card p {
  color: var(--muted);
  font-size: .9rem;
  line-height: 1.7;
  margin: 0;
}
.highlight-card blockquote {
  border-left: 2px solid rgba(232,165,103,.32);
  padding: .15rem 0 .15rem 1rem;
  color: var(--text);
  font-size: .9rem;
  font-style: italic;
  line-height: 1.65;
  opacity: .92;
  margin: 0;
}

#camino-map {
  width: 100%;
  height: 540px;
  border-radius: var(--radius);
  border: 1px solid var(--border-strong);
  background: #0a0606;
  box-shadow: var(--shadow);
  overflow: hidden;
}
.map-frame { position: relative; }
.map-hint {
  margin-top: .9rem;
  text-align: center;
  font-family: var(--font-mono);
  font-size: .78rem;
  letter-spacing: .02em;
}
.map-cta {
  display: flex;
  justify-content: center;
  margin-top: 1.5rem;
}

/* Leaflet warm-tone overrides — match the Rothko palette */
.leaflet-tile-pane {
  filter: hue-rotate(-18deg) sepia(.32) saturate(1.05) brightness(.94);
}
.leaflet-container {
  background: #0e0807;
  font-family: var(--font-body);
}
.leaflet-popup-content-wrapper {
  background: rgba(26,16,13,.97);
  color: var(--text);
  border: 1px solid var(--border-strong);
  border-radius: var(--radius-sm);
  box-shadow: var(--shadow);
}
.leaflet-popup-tip {
  background: rgba(26,16,13,.97);
  box-shadow: var(--shadow);
}
.leaflet-popup-content {
  margin: .85rem 1.05rem;
  font-family: var(--font-body);
  font-size: .88rem;
  line-height: 1.55;
}
.leaflet-popup-close-button {
  color: var(--muted) !important;
  padding: .4rem .55rem 0 0 !important;
}
.leaflet-popup-close-button:hover {
  color: var(--text) !important;
}
.map-popup .day {
  display: block;
  font: 600 .68rem/1 var(--font-mono);
  color: var(--warm);
  letter-spacing: .09em;
  text-transform: uppercase;
  margin-bottom: .45rem;
}
.map-popup h4 {
  font-family: var(--font-display);
  font-size: 1rem;
  font-weight: 700;
  margin: 0 0 .4rem;
  letter-spacing: -.02em;
  color: var(--text);
}
.map-popup p {
  color: var(--muted);
  font-size: .82rem;
  line-height: 1.55;
  margin: 0;
}
.leaflet-control-attribution {
  background: rgba(14,8,7,.72) !important;
  color: var(--muted-2) !important;
  font-family: var(--font-mono);
  font-size: .68rem;
}
.leaflet-control-attribution a {
  color: var(--muted) !important;
}
.leaflet-control-zoom a {
  background: rgba(26,16,13,.92) !important;
  color: var(--text) !important;
  border-color: var(--border-strong) !important;
}
.leaflet-control-zoom a:hover {
  background: rgba(60,30,22,.95) !important;
}

@media (max-width: 820px) {
  .highlight-grid { grid-template-columns: 1fr; }
  #camino-map { height: 440px; }
}
@media (max-width: 680px) {
  #camino-map { height: 380px; }
}

/* ═══════════════════════════════════════════════════
   AVAILABILITY PILL (homepage hero)
═══════════════════════════════════════════════════ */
.availability-pill {
  display: inline-flex;
  align-items: center;
  gap: .55rem;
  padding: .4rem .9rem .4rem .75rem;
  margin-bottom: 1rem;
  border-radius: 999px;
  background: rgba(168,196,122,.09);
  border: 1px solid rgba(168,196,122,.28);
  color: var(--teal);
  font: 600 .76rem/1 var(--font-mono);
  letter-spacing: .04em;
  text-decoration: none;
  transition: background var(--t), border-color var(--t), transform var(--t) var(--ease), color var(--t);
}
.availability-pill:hover {
  background: rgba(168,196,122,.16);
  border-color: rgba(168,196,122,.45);
  color: var(--text);
  transform: translateY(-1px);
}
.availability-dot {
  width: .55rem;
  height: .55rem;
  border-radius: 50%;
  background: var(--teal);
  box-shadow: 0 0 0 0 rgba(168,196,122,.55);
  animation: availability-pulse 2.4s ease-out infinite;
}
@keyframes availability-pulse {
  0%   { box-shadow: 0 0 0 0 rgba(168,196,122,.6); }
  70%  { box-shadow: 0 0 0 9px rgba(168,196,122,0); }
  100% { box-shadow: 0 0 0 0 rgba(168,196,122,0); }
}

/* ═══════════════════════════════════════════════════
   MINI TERMINAL (homepage hero)
═══════════════════════════════════════════════════ */
.terminal {
  margin-top: 1.5rem;
  max-width: 100%;
  background: rgba(20,12,10,.62);
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  font-family: var(--font-mono);
  font-size: .82rem;
  color: var(--text);
  overflow: hidden;
  backdrop-filter: blur(8px);
  cursor: text;
  transition: border-color var(--t);
}
.terminal:focus-within { border-color: rgba(168,196,122,.36); }
.terminal-output {
  padding: .85rem 1.1rem .1rem;
  max-height: 14rem;
  overflow-y: auto;
  display: flex;
  flex-direction: column;
  gap: .15rem;
  scrollbar-width: thin;
  scrollbar-color: rgba(168,196,122,.25) transparent;
}
.terminal-output::-webkit-scrollbar { width: 6px; }
.terminal-output::-webkit-scrollbar-thumb { background: rgba(168,196,122,.2); border-radius: 3px; }
.terminal-line {
  display: flex;
  gap: .5rem;
  align-items: baseline;
  white-space: pre-wrap;
  word-break: break-word;
  line-height: 1.55;
}
.terminal-prompt {
  color: var(--teal);
  flex-shrink: 0;
  font-weight: 600;
  user-select: none;
}
/* AI replies use a terracotta prompt so you can see at a glance
   which lines came from the model vs. your shell. */
.terminal-prompt.terminal-ai-prompt { color: var(--violet); }

/* ═══════════════════════════════════════════════════
   SKLARPLE — wordle but the word is always 'sklarp'
═══════════════════════════════════════════════════ */
.sklarple-card {
  max-width: 540px;
  margin: 0 auto;
  text-align: center;
}
.sklarple-card .pill { margin-bottom: .5rem; }
.sklarple-card p {
  color: var(--muted);
  font-size: .92rem;
  margin: .5rem 0 0;
}
.sklarple-card p em { color: var(--teal); font-style: italic; }

.sklarple-board {
  display: grid;
  grid-template-rows: repeat(6, 1fr);
  gap: 6px;
  width: 100%;
  max-width: 340px;
  aspect-ratio: 1 / 1;
  margin: 1.5rem auto 0;
}
.sklarple-row {
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  gap: 6px;
}
.sklarple-tile {
  display: grid;
  place-items: center;
  font-family: var(--font-display);
  font-size: clamp(1.1rem, 5vw, 1.6rem);
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: -.02em;
  background: transparent;
  border: 2px solid var(--border-strong);
  border-radius: 6px;
  color: var(--text);
  user-select: none;
  transition: background var(--t), border-color var(--t), color var(--t);
}
.sklarple-tile.filled { border-color: var(--text); }
.sklarple-tile.correct {
  background: var(--teal);
  border-color: var(--teal);
  color: #14100a;
}
.sklarple-tile.present {
  background: var(--warm);
  border-color: var(--warm);
  color: #14100a;
}
.sklarple-tile.absent {
  background: var(--muted-2);
  border-color: var(--muted-2);
  color: var(--surface);
  opacity: .75;
}
.sklarple-tile.flip { animation: sklarple-flip .55s ease forwards; }
@keyframes sklarple-flip {
  0%   { transform: rotateX(0); }
  50%  { transform: rotateX(90deg); }
  100% { transform: rotateX(0); }
}
.sklarple-row.shake { animation: sklarple-shake .35s ease; }
@keyframes sklarple-shake {
  10%, 90% { transform: translateX(-2px); }
  20%, 80% { transform: translateX(4px); }
  30%, 50%, 70% { transform: translateX(-8px); }
  40%, 60% { transform: translateX(8px); }
}

.sklarple-msg {
  min-height: 1.6em;
  font-family: var(--font-mono);
  font-size: .85rem;
  color: var(--muted);
  letter-spacing: .02em;
  margin: 1rem 0 .25rem;
}
.sklarple-msg.win { color: var(--teal); font-weight: 700; }
.sklarple-msg.lose { color: var(--warm); }

.sklarple-keyboard {
  display: flex;
  flex-direction: column;
  gap: 6px;
  margin: .5rem auto 0;
  max-width: 480px;
}
.sklarple-keyboard-row {
  display: flex;
  gap: 4px;
  justify-content: center;
}
.sklarple-key {
  flex: 1;
  min-width: 0;
  max-width: 40px;
  height: 48px;
  border-radius: 4px;
  border: 1px solid var(--border-strong);
  background: var(--card);
  color: var(--text);
  font-family: var(--font-mono);
  font-weight: 600;
  font-size: .85rem;
  text-transform: uppercase;
  cursor: pointer;
  transition: background var(--t), border-color var(--t), color var(--t), transform var(--t);
}
.sklarple-key:hover { background: var(--card-hover); }
.sklarple-key:active { transform: translateY(1px); }
.sklarple-key.wide { max-width: 60px; flex: 1.5; font-size: 1rem; }
.sklarple-key.correct {
  background: var(--teal);
  border-color: var(--teal);
  color: #14100a;
}
.sklarple-key.present {
  background: var(--warm);
  border-color: var(--warm);
  color: #14100a;
}
.sklarple-key.absent {
  background: var(--muted-2);
  border-color: var(--muted-2);
  color: var(--surface);
  opacity: .6;
}

.sklarple-reset {
  display: inline-flex;
  margin-top: 1rem;
}

@media (max-width: 680px) {
  .sklarple-board { max-width: 280px; }
  .sklarple-key { height: 42px; }
}

/* Warning banner sitting right above the interactive terminal,
   making it obvious the AI is fallible. */
.terminal-warn {
  display: flex;
  align-items: flex-start;
  gap: .65rem;
  margin: 1.5rem 0 .65rem;
  padding: .7rem .95rem;
  background: rgba(232,165,103,.09);
  border: 1px solid rgba(232,165,103,.3);
  border-left: 3px solid var(--warm);
  border-radius: var(--radius-sm);
  font: 500 .8rem/1.5 var(--font-mono);
  color: var(--muted);
  letter-spacing: .01em;
}
.terminal-warn strong {
  color: var(--warm);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .04em;
  margin-right: .15rem;
}
.terminal-warn-icon {
  color: var(--warm);
  font-size: 1rem;
  line-height: 1.4;
  flex-shrink: 0;
}
.terminal-text { color: var(--text); }
.terminal-text.muted { color: var(--muted); }
.terminal-text.warn { color: var(--warm); }
.terminal-suggest {
  color: var(--warm);
  cursor: pointer;
  background: rgba(232,165,103,.1);
  padding: 0 .35rem;
  border-radius: 4px;
  font: inherit;
  border: 0;
  transition: background var(--t), color var(--t);
}
.terminal-suggest:hover {
  background: rgba(232,165,103,.22);
  color: var(--text);
}
.terminal-input-row {
  display: flex;
  align-items: center;
  gap: .5rem;
  padding: .45rem 1.1rem .9rem;
  margin: 0;
}
.terminal-input {
  flex: 1;
  background: transparent;
  border: 0;
  outline: 0;
  color: var(--text);
  font: inherit;
  caret-color: var(--teal);
  padding: 0;
  min-width: 0;
}
.terminal-cursor {
  width: .55rem;
  height: 1rem;
  display: inline-block;
  background: var(--teal);
  border-radius: 1px;
  animation: blink 1.1s step-end infinite;
}

/* ═══════════════════════════════════════════════════
   BUILD METADATA (footer, all pages)
═══════════════════════════════════════════════════ */
.build-meta {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: .5rem;
  margin: 2rem auto 0;
  padding-top: 1.4rem;
  border-top: 1px solid var(--border);
  font: 500 .72rem/1 var(--font-mono);
  color: var(--muted-2);
  letter-spacing: .04em;
}
.build-pill {
  display: inline-flex;
  align-items: center;
  padding: .28rem .65rem;
  border-radius: 999px;
  background: var(--card);
  border: 1px solid var(--border);
  color: var(--muted);
}
.build-sep { opacity: .45; margin: 0 .15rem; }
.build-sub { color: var(--muted-2); }
.build-sub a {
  color: var(--muted);
  text-decoration: none;
  border-bottom: 1px dotted rgba(255,238,218,.22);
  transition: color var(--t), border-color var(--t);
}
.build-sub a:hover { color: var(--teal); border-bottom-color: rgba(168,196,122,.45); }
@media (max-width: 680px) {
  .build-meta { font-size: .68rem; gap: .4rem; }
}

/* ═══════════════════════════════════════════════════
   WINE-BAR SCHEDULE PANEL (wine.html)
═══════════════════════════════════════════════════ */
.schedule-panel {
  padding: 1.85rem 2rem;
  background: linear-gradient(150deg, var(--warm-dim) 0%, rgba(214,133,106,.08) 100%);
  border: 1px solid rgba(232,165,103,.22);
  border-radius: var(--radius);
  transition: border-color var(--t), box-shadow var(--t);
}
.schedule-panel:hover {
  border-color: rgba(232,165,103,.36);
  box-shadow: var(--shadow);
}
.schedule-head { margin-bottom: 1.25rem; }
.schedule-head h2 {
  font-family: var(--font-display);
  font-size: clamp(1.4rem, 2.4vw, 1.85rem);
  font-weight: 700;
  letter-spacing: -.035em;
  margin: .55rem 0 .45rem;
}
.schedule-blurb {
  color: var(--muted);
  font-size: .92rem;
  line-height: 1.7;
  max-width: 56ch;
}
.schedule-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: .55rem;
}
.schedule-item {
  display: grid;
  grid-template-columns: minmax(120px, 1fr) minmax(120px, 1fr) 2fr;
  align-items: baseline;
  gap: 1rem;
  padding: .85rem 1rem;
  background: rgba(20,12,10,.4);
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  font-size: .92rem;
  transition: border-color var(--t), background var(--t);
}
.schedule-item:hover {
  border-color: rgba(232,165,103,.32);
  background: rgba(20,12,10,.55);
}
.schedule-day {
  font-family: var(--font-display);
  font-weight: 700;
  letter-spacing: -.02em;
  color: var(--text);
}
.schedule-time {
  font-family: var(--font-mono);
  color: var(--warm);
  font-size: .86rem;
}
.schedule-where {
  font-family: var(--font-mono);
  font-size: .78rem;
  color: var(--muted);
}
.schedule-empty {
  padding: 1rem 1.2rem;
  border: 1px dashed var(--border);
  border-radius: var(--radius-sm);
  color: var(--muted);
  font: 500 .88rem/1.5 var(--font-body);
  text-align: center;
}
.schedule-foot {
  margin-top: 1rem;
  font: 500 .72rem/1 var(--font-mono);
  color: var(--muted-2);
  letter-spacing: .04em;
}
@media (max-width: 680px) {
  .schedule-panel { padding: 1.5rem 1.4rem; }
  .schedule-item {
    grid-template-columns: 1fr;
    gap: .15rem;
    padding: .8rem .9rem;
  }
  .schedule-time { font-size: .82rem; }
}

/* ═══════════════════════════════════════════════════
   WRITING — list page + post pages
═══════════════════════════════════════════════════ */

/* ── List page: post cards ───────────────────────── */
.post-list { display: flex; flex-direction: column; gap: 1.5rem; }

.post-card {
  display: flex; flex-direction: column; gap: .65rem;
  padding: 1.65rem 1.85rem;
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  transition: border-color var(--t), transform var(--t-slow) var(--ease), box-shadow var(--t);
}
.post-card:hover {
  border-color: rgba(168,196,122,.34);
  transform: translateY(-2px);
  box-shadow: var(--shadow);
}
.post-card .when {
  font: 600 .72rem/1 var(--font-mono);
  color: var(--terra, var(--warm));
  letter-spacing: .08em;
  text-transform: uppercase;
}
.post-card h2 {
  font-family: var(--font-display);
  font-size: 1.35rem;
  font-weight: 700;
  letter-spacing: -.025em;
  margin: 0;
}
.post-card h2 a {
  color: var(--text);
  text-decoration: none;
  transition: color var(--t);
}
.post-card:hover h2 a { color: var(--teal); }
.post-card .abstract {
  color: var(--muted);
  font-size: .94rem;
  line-height: 1.65;
}
.post-tags { display: flex; gap: .4rem; flex-wrap: wrap; margin-top: .15rem; }
.post-tags .tag {
  font: 500 .72rem/1 var(--font-mono);
  padding: .3rem .65rem;
  border-radius: 999px;
  background: var(--violet-dim);
  border: 1px solid rgba(214,133,106,.22);
  color: var(--violet);
}

/* ── Inside a post: typography + structure ───────── */
.post {
  max-width: 70ch;
  margin: 0 auto;
  padding: 0;
}
.post-header { margin-bottom: 2.5rem; }
.post-header .when {
  display: block;
  font: 600 .74rem/1 var(--font-mono);
  color: var(--warm);
  letter-spacing: .08em;
  text-transform: uppercase;
  margin-bottom: .9rem;
}
.post-header h1 {
  font-family: var(--font-display);
  font-size: clamp(2.1rem, 4.2vw, 3.1rem);
  font-weight: 800;
  letter-spacing: -.04em;
  line-height: 1.05;
  margin-bottom: 1rem;
}
.post-header .lede {
  color: var(--muted);
  font-size: 1.08rem;
  line-height: 1.65;
  max-width: 62ch;
}

.post-content { font-size: 1.02rem; line-height: 1.75; color: var(--text); }
.post-content > p { margin-bottom: 1.1rem; color: var(--text); }
.post-content > p:last-child { margin-bottom: 0; }

.post-content h2 {
  font-family: var(--font-display);
  font-size: 1.55rem;
  font-weight: 700;
  letter-spacing: -.03em;
  margin: 2.6rem 0 .9rem;
  color: var(--text);
}
.post-content h2::before {
  content: "// ";
  font-family: var(--font-mono);
  color: var(--warm);
  font-size: .85em;
  font-weight: 600;
}
.post-content h3 {
  font-family: var(--font-display);
  font-size: 1.18rem;
  font-weight: 700;
  letter-spacing: -.02em;
  margin: 1.8rem 0 .6rem;
}

.post-content a {
  color: var(--teal);
  text-decoration: none;
  border-bottom: 1px solid rgba(168,196,122,.35);
  transition: border-color var(--t), color var(--t);
}
.post-content a:hover {
  color: var(--text);
  border-bottom-color: var(--teal);
}

.post-content em { color: var(--text); font-style: italic; }
.post-content strong { color: var(--text); font-weight: 600; }

.post-content ul, .post-content ol {
  margin: 0 0 1.2rem 0;
  padding-left: 1.5rem;
  color: var(--muted);
}
.post-content ul li, .post-content ol li {
  margin-bottom: .55rem;
  line-height: 1.7;
}
.post-content ul li strong { color: var(--text); }

.post-content blockquote {
  margin: 1.4rem 0;
  padding: .15rem 0 .15rem 1.2rem;
  border-left: 3px solid rgba(232,165,103,.4);
  color: var(--text);
  font-style: italic;
  font-size: 1.02rem;
  line-height: 1.65;
}

.post-content code {
  font-family: var(--font-mono);
  font-size: .9em;
  padding: .15rem .42rem;
  border-radius: 4px;
  background: rgba(168,196,122,.1);
  color: var(--teal);
  border: 1px solid rgba(168,196,122,.18);
}
.post-content pre {
  margin: 1.4rem 0;
  padding: 1.15rem 1.3rem;
  background: rgba(20,12,10,.55);
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  overflow-x: auto;
  font-family: var(--font-mono);
  font-size: .88rem;
  line-height: 1.6;
}
.post-content pre code {
  background: transparent;
  border: 0;
  padding: 0;
  color: var(--text);
}

.post-content .callout {
  margin: 1.6rem 0;
  padding: 1.1rem 1.3rem;
  background: linear-gradient(140deg, var(--violet-dim), var(--teal-dim));
  border: 1px solid rgba(214,133,106,.28);
  border-radius: var(--radius-sm);
  font-size: .95rem;
  line-height: 1.65;
  color: var(--text);
}
.post-content .callout strong {
  display: block;
  margin-bottom: .35rem;
  font-family: var(--font-mono);
  font-size: .72rem;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--warm);
  font-weight: 700;
}

/* ── Post footer: tags + nav between posts ───────── */
.post-footer {
  margin-top: 3rem;
  padding-top: 1.5rem;
  border-top: 1px solid var(--border);
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
}
.post-footer .post-tags { margin: 0; }
.post-footer .back-link {
  font-family: var(--font-mono);
  font-size: .85rem;
  color: var(--muted);
}
.post-footer .back-link:hover { color: var(--teal); }

@media (max-width: 680px) {
  .post-card { padding: 1.4rem; }
  .post-card h2 { font-size: 1.18rem; }
  .post-content { font-size: .98rem; }
}
