/* =====================================================
   AJ — Portfolio · Hi-fi styles
   Geist Sans + Geist Mono · B&W + per-case accents
   ===================================================== */

:root{
  /* === LIGHT THEME (default) — all pairs meet WCAG AA === */
  --ink:      #0a0a0a;             /* 19:1 on paper — AAA */
  --ink-2:    #1a1a1a;             /* 16:1 on paper — AAA */
  --muted:    #595959;             /* 7.5:1 on paper — AAA (bumped from #6b6b6b for AA on small text) */
  --muted-2:  #757575;             /* 4.7:1 on paper — AA */
  --paper:    #f5f3ee;
  --paper-2:  #eeebe3;
  --rule:     #0a0a0a;
  --rule-soft:rgba(10,10,10,0.14);
  --accent:   oklch(0.78 0.17 30);
  --radius:   4px;
  --ease:     cubic-bezier(.2,.7,.2,1);
  --max:      1440px;
  --gutter:   clamp(20px, 3.5vw, 48px);
  color-scheme: light;
}

:root[data-theme="dark"]{
  /* === DARK THEME — all pairs meet WCAG AA on #14110f === */
  --ink:      #ebe7df;             /* 14.5:1 on paper — AAA */
  --ink-2:    #d4cfc4;             /* 11:1 on paper — AAA */
  --muted:    #a39e94;             /* 6.6:1 on paper — AAA */
  --muted-2:  #8a8579;             /* 4.7:1 on paper — AA */
  --paper:    #14110f;             /* warm near-black */
  --paper-2:  #1d1a17;
  --rule:     #ebe7df;
  --rule-soft:rgba(235,231,223,0.14);
  --accent:   oklch(0.78 0.17 30);
  color-scheme: dark;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;text-size-adjust:100%}
html,body{margin:0;padding:0}
body{
  background:var(--paper);
  color:var(--ink);
  font-family:'Geist','Geist Fallback',system-ui,sans-serif;
  font-weight:400;
  font-feature-settings:"ss01","ss02","cv11";
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
  cursor:none;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
em{font-style:normal;font-weight:500}
.mono{font-family:'Geist Mono',ui-monospace,SFMono-Regular,Menlo,monospace;font-weight:500;letter-spacing:0.02em}
::selection{background:var(--ink);color:var(--paper)}

/* Grain — subtle, fixed, screen-blend */
.grain{
  position:fixed;inset:-10%;pointer-events:none;z-index:80;
  opacity:.08;mix-blend-mode:multiply;
  background-image:
    radial-gradient(rgba(0,0,0,.9) 1px, transparent 1.5px),
    radial-gradient(rgba(0,0,0,.6) 1px, transparent 1.5px);
  background-size: 3px 3px, 5px 5px;
  background-position: 0 0, 1px 2px;
}

/* Cursor */
.cursor{
  position:fixed;top:0;left:0;z-index:100;pointer-events:none;
  width:36px;height:36px;border-radius:50%;
  border:2px solid var(--ink);
  /* cream halo around the ink ring — visible against any bg */
  box-shadow: 0 0 0 1.5px var(--paper), 0 2px 8px rgba(0,0,0,0.18);
  background: transparent;
  transform:translate(-50%,-50%);
  transition: width .22s var(--ease), height .22s var(--ease),
              background .2s var(--ease), border-color .2s var(--ease),
              box-shadow .2s var(--ease), opacity .2s;
  display:flex;align-items:center;justify-content:center;
}
.cursor .cc-dot{
  width:7px;height:7px;border-radius:50%;background:var(--ink);
  /* cream micro-halo around the dot too, so it stays visible if the ring lands on ink */
  box-shadow: 0 0 0 1px var(--paper);
  transition:opacity .2s;
}
.cursor .cc-label{
  position:absolute;color:var(--paper);font-family:'Geist Mono';font-size:11px;
  letter-spacing:.06em;text-transform:uppercase;opacity:0;white-space:nowrap;
}
.cursor.active{
  width:88px;height:88px;background:var(--ink);border-color:var(--ink);
  box-shadow: 0 0 0 1.5px var(--paper), 0 6px 24px rgba(0,0,0,0.35);
}
.cursor.active .cc-dot{opacity:0}
.cursor.active .cc-label{opacity:1}
.cursor.hide{opacity:0}

@media (hover:none){
  body{cursor:auto}
  .cursor{display:none}
}

/* Scroll progress */
.progress{
  position:fixed;top:0;left:0;right:0;height:2px;z-index:90;
  background:transparent;
}
.progress-fill{
  height:100%;width:0%;background:var(--ink);
  transition: width .08s linear;
}
.progress-counter{
  position:fixed;top:14px;right:calc(var(--gutter));z-index:90;
  font-family:'Geist Mono';font-size:11px;letter-spacing:.06em;color:var(--ink);
}

/* NAV */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:70;
  display:grid;grid-template-columns: 1fr auto 1fr;align-items:center;
  padding: 22px var(--gutter);
  background: color-mix(in oklab, var(--paper) 85%, transparent);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  border-bottom: 1px solid var(--rule-soft);
}
.nav-brand{display:flex;align-items:center;gap:10px;font-weight:500}
.brand-mark{
  display:inline-flex;align-items:center;justify-content:center;
  width:28px;height:28px;border:1.5px solid var(--ink);border-radius:50%;
  font-size:0; /* hides the "A" text fallback while keeping it in the DOM for accessibility */
  color:var(--ink);
}
.brand-mark::before{
  content:"";
  display:block;
  width:14px;height:18px;
  background-color: currentColor;
  -webkit-mask: url("assets/logos/d1-aj-wave.svg") center / contain no-repeat;
  mask: url("assets/logos/d1-aj-wave.svg") center / contain no-repeat;
}
.brand-name{font-size:14px;letter-spacing:-0.01em}
.nav-brand-active .brand-mark{background:var(--ink);color:var(--paper)}
.nav-links{display:flex;gap:4px;justify-content:center}
.nav-links a{
  padding:8px 14px;border-radius:999px;font-size:13px;letter-spacing:-0.005em;
  transition: background .18s var(--ease), color .18s var(--ease);
}
.nav-links a:hover{background:var(--ink);color:var(--paper)}
.nav-links a.nav-active{background:var(--ink);color:var(--paper)}
.nav-right{display:flex;align-items:center;gap:10px;justify-content:flex-end}
/* Life nav: outlined pill button — distinct from regular nav links */
a.nav-life-btn{
  display:inline-block;
  padding:6px 16px;border:1px solid var(--ink);border-radius:999px;
  font-size:13px;font-weight:500;letter-spacing:-.005em;
  transition: background .18s var(--ease), color .18s var(--ease), border-color .18s var(--ease);
}
a.nav-life-btn:hover,
a.nav-life-btn.nav-active{background:var(--ink);color:var(--paper);border-color:var(--ink)}
.nav-links a.nav-life-btn{margin-left:8px}
.footer-cell a.nav-life-btn{margin-top:8px}
@media(max-width:640px){
  a.nav-life-btn{padding:5px 12px;font-size:12px}
  .nav-links a.nav-life-btn{margin-left:4px}
}
.nav-status{
  display:flex;align-items:center;gap:8px;justify-content:flex-end;
  font-family:'Geist Mono';font-size:11px;letter-spacing:.02em;
}
.nav-status .dot{
  width:8px;height:8px;border-radius:50%;background:#3bbd63;
  box-shadow: 0 0 0 3px rgba(59,189,99,.2);
  animation: pulse 2.4s infinite;
}
@keyframes pulse{
  0%,100%{box-shadow:0 0 0 3px rgba(59,189,99,.2)}
  50%    {box-shadow:0 0 0 6px rgba(59,189,99,0)}
}

/* =========== HERO =========== */
.hero{
  position:relative;
  padding: 140px var(--gutter) 48px;
  max-width:var(--max);margin:0 auto;
  min-height: 92vh;
  display:flex;flex-direction:column;justify-content:space-between;
}
.hero-meta{
  position:absolute;top:110px;display:flex;gap:16px;align-items:center;font-size:11px;color:var(--ink);
}
.hero-meta-l{left:var(--gutter)}
.hero-meta-r{right:var(--gutter)}
.hero-title{
  font-family:'Geist';font-weight:600;
  font-size: clamp(54px, 11vw, 176px);
  line-height: 0.92;
  letter-spacing: -0.045em;
  margin: 40px 0 0;
}
.hero-title .line{display:block}
.hero-title .outlined{
  color:transparent;
  -webkit-text-stroke: 1.5px var(--ink);
  font-weight:500;
  font-style:italic;
  letter-spacing: -0.04em;
}
/* Rotator */
.rotator{
  display:inline-flex;position:relative;vertical-align:baseline;
  height:1em;overflow:hidden;align-items:baseline;
  min-width: 6ch;
}
.rotator .rw{
  display:inline-block;position:absolute;left:0;top:0;
  transform: translateY(110%);
  opacity:0;
  transition: transform .6s var(--ease), opacity .45s var(--ease);
  font-style:italic;font-weight:500;
  background: linear-gradient(180deg, var(--ink) 0%, var(--ink) 100%);
  -webkit-background-clip:text;background-clip:text;
  color:var(--ink);
  white-space:nowrap;
  padding-right:.3em;
}
.rotator .rw.is-active{ transform: translateY(0%); opacity:1; position:relative }
.rotator .rw.is-out{ transform: translateY(-110%); opacity:0 }

.hero-foot{
  display:grid;grid-template-columns: 1.3fr 1fr;gap:48px;align-items:end;
  margin-top: 60px;
}
.hero-intro p{
  font-size: clamp(16px, 1.2vw, 19px);
  line-height:1.5;margin:0;
  max-width:52ch;color:var(--ink);
}
.hero-actions{display:flex;gap:10px;justify-content:flex-end;flex-wrap:wrap}

/* Buttons */
.btn{
  display:inline-flex;align-items:center;gap:10px;
  padding: 14px 22px;border-radius:999px;
  font-size:14px;font-weight:500;letter-spacing:-0.005em;
  transition: transform .22s var(--ease), background .2s var(--ease), color .2s var(--ease), box-shadow .22s var(--ease);
  will-change:transform;
}
.btn-primary{background:var(--ink);color:var(--paper)}
.btn-primary:hover{box-shadow: 0 8px 24px -10px rgba(0,0,0,.45)}
.btn-ghost{border:1px solid var(--ink);color:var(--ink)}
.btn-ghost:hover{background:var(--ink);color:var(--paper)}
.btn-lg{padding:18px 30px;font-size:15px}

/* Hero marquee */
.hero-marquee{
  margin-top:42px;
  border-top:1px solid var(--rule);
  border-bottom:1px solid var(--rule);
  overflow:hidden;
  padding: 14px 0;
}
.marq-track{
  display:inline-flex;white-space:nowrap;gap:28px;
  font-family:'Geist';font-weight:500;font-size:15px;
  animation: marq 38s linear infinite;
}
.marq-track.slow{animation-duration: 56s;font-family:'Geist';font-weight:600;font-size:clamp(40px,6vw,92px);letter-spacing:-0.03em}
@keyframes marq{
  to{transform: translateX(-50%)}
}

/* =========== SECTIONS =========== */
section{
  max-width:var(--max);margin:0 auto;
  padding: 120px var(--gutter);
  position:relative;
}
.section-head{
  display:grid;grid-template-columns: 120px 1fr 240px;gap:24px;align-items:baseline;
  padding-bottom: 36px;border-bottom:1px solid var(--rule);margin-bottom:16px;
}
.section-label{display:flex;flex-wrap:wrap;gap:4px 14px;font-size:11px;color:var(--ink)}
.section-title{
  font-family:'Geist';font-weight:500;
  font-size: clamp(28px, 3.4vw, 48px);
  line-height:1.05;letter-spacing:-0.03em;margin:0;
  max-width: 22ch;
}
.section-side{font-size:11px;color:var(--muted);text-align:right}

/* =========== WORK / CASE STUDY ROWS =========== */
.cs-list{list-style:none;margin:0;padding:0}
.cs-row{
  --bg: var(--paper);
  border-bottom:1px solid var(--rule);
  position:relative;
  isolation:isolate;
  overflow: hidden;
}
.cs-row::before{
  content:"";position:absolute;inset:0;background:var(--accent);
  transform: scaleY(0);transform-origin: bottom;
  transition: transform .45s var(--ease);
  z-index:-1;
}
.cs-row:hover::before{transform: scaleY(1);transform-origin: top}

.cs-link{
  display:grid;
  grid-template-columns: 60px minmax(280px, 1fr) 90px 160px minmax(220px, 1fr) 40px;
  gap: 32px;align-items:center;
  padding: 34px 8px;
  transition: padding .35s var(--ease), color .35s var(--ease);
}
.cs-row:hover .cs-link{padding-left: 28px; padding-right: 28px}

.cs-num{font-size:11px;color:var(--muted);letter-spacing:.06em}
.cs-row:hover .cs-num{color:var(--ink)}

.cs-title{display:flex;align-items:baseline;gap:14px;flex-wrap:wrap}
.cs-name{
  font-family:'Geist';font-weight:500;
  font-size: clamp(28px, 3.6vw, 52px);
  letter-spacing:-0.03em;line-height:1;
}
.cs-sub{
  font-family:'Geist';font-style:italic;font-weight:400;
  font-size: clamp(16px, 1.5vw, 22px);
  letter-spacing:-0.01em;color:var(--muted);
}
.cs-row:hover .cs-sub{color:var(--ink)}

.cs-year{font-size:11px;color:var(--muted)}
.cs-role{font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:.08em}
.cs-row:hover .cs-year, .cs-row:hover .cs-role{color:var(--ink)}

.cs-desc{font-size:14px;line-height:1.5;color:var(--ink);max-width:46ch}
.cs-desc em{font-family:'Geist Mono';font-style:normal;font-weight:600;font-size:12px;padding:1px 6px;background:var(--ink);color:var(--paper);border-radius:3px;margin:0 2px}

.cs-arrow{font-size:22px;justify-self:end;transition:transform .3s var(--ease)}
.cs-row:hover .cs-arrow{transform: translate(6px,-6px)}

/* Peek image */
.cs-peek{
  position:absolute;
  right: 8%;top:50%;
  transform: translate(40%, -50%) rotate(-3deg) scale(.94);
  width: 280px;height: 180px;
  opacity:0;pointer-events:none;z-index:4;
  transition: opacity .35s var(--ease), transform .4s var(--ease);
}
.cs-row:hover .cs-peek{opacity:1;transform: translate(0,-50%) rotate(-3deg) scale(1)}
.cs-peek-img{
  width:100%;height:100%;
  background:
    linear-gradient(135deg, rgba(255,255,255,.12), rgba(255,255,255,0) 60%),
    repeating-linear-gradient(135deg, transparent 0 10px, rgba(0,0,0,.1) 10px 11px),
    color-mix(in oklab, var(--accent), #000 20%);
  border: 1px solid rgba(0,0,0,.4);
  box-shadow: 0 24px 44px -18px rgba(0,0,0,.35);
  border-radius: 2px;
  display:flex;align-items:flex-end;padding:10px 12px;
  font-family:'Geist Mono';font-size:10px;color:#fff;letter-spacing:.06em;text-transform:uppercase;
}
.cs-peek-img::after{ content: attr(data-label); }

@media (max-width: 1100px){
  .cs-link{grid-template-columns: 40px 1fr 80px 40px;gap:16px;padding:24px 8px}
  .cs-link .cs-role, .cs-link .cs-desc{display:none}
  .cs-peek{display:none}
}

/* =========== ABOUT =========== */
.about-grid{
  display:grid;grid-template-columns: 1fr 1.6fr;gap:64px;padding-top:48px;align-items:start;
}
.about-photo{position:sticky;top:100px}
.about-img{
  width:100%;aspect-ratio:3/4;object-fit:cover;object-position:top center;
  border-radius:4px;border:1px solid var(--rule-soft);filter:grayscale(18%);
}
.about-right{display:flex;flex-direction:column;gap:40px}
.about-p{
  font-family:'Geist';font-weight:400;
  font-size: clamp(22px, 2.1vw, 30px);
  line-height:1.35;letter-spacing:-0.015em;
  margin:0 0 20px;max-width:26ch;
}
.about-p em{
  font-style:italic;font-weight:500;
  color: var(--ink);
}
.about-facts{display:grid;grid-template-columns:1fr 1fr;gap:2px 24px;margin:0;padding:0;align-self:start;text-align:left}
.fact{padding:14px 0;border-bottom:1px solid var(--rule-soft);display:flex;justify-content:flex-start;gap:14px;text-align:left}
.fact dt{font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:.08em;margin:0;flex:0 0 110px;text-align:left}
.fact dd{margin:0;font-size:14px;text-align:left;flex:1}

/* =========== SERVICES =========== */
.svc-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;padding-top:48px}
.svc{
  border:1px solid var(--rule);border-radius:var(--radius);
  padding:24px;display:flex;flex-direction:column;gap:14px;min-height:240px;
  background:var(--paper);
  transition: background .2s var(--ease), color .2s var(--ease), transform .2s var(--ease);
}
.svc:hover{background:var(--ink);color:var(--paper);transform:translateY(-4px)}
.svc-n{font-size:11px;color:var(--muted)}
.svc:hover .svc-n{color:var(--muted-2)}
.svc h3{font-family:'Geist';font-weight:500;font-size:22px;margin:0;letter-spacing:-0.02em}
.svc p{font-size:14px;line-height:1.5;margin:0;opacity:.85}
.svc-engage{font-size:10px;color:var(--muted);text-transform:uppercase;letter-spacing:.08em;margin-top:auto}
.svc:hover .svc-engage{color:var(--muted-2)}
.svc-icon{width:28px;height:28px;flex-shrink:0;opacity:.7;transition:opacity .2s var(--ease)}
.svc:hover .svc-icon{opacity:1}

/* =========== PROCESS =========== */
.proc-list{list-style:none;margin:0;padding:48px 0 0;display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.proc-step{
  border:1px solid var(--rule);padding:24px 24px 24px 16px;border-radius:var(--radius);
  display:flex;flex-direction:column;gap:10px;min-height:200px;background:var(--paper);
  transition: transform .22s var(--ease), box-shadow .22s var(--ease);
}
.proc-step:hover{transform:translateY(-3px);box-shadow:0 14px 30px -18px rgba(0,0,0,.4)}
.proc-n{font-size:11px;color:var(--muted)}
.proc-icon{width:26px;height:26px;flex-shrink:0;opacity:.6;transition:opacity .22s var(--ease)}
.proc-step:hover .proc-icon{opacity:1}
.proc-step h4{font-family:'Geist';font-weight:500;font-size:22px;margin:0;letter-spacing:-0.02em}
.proc-step p{font-size:13px;line-height:1.5;margin:0;color:var(--ink)}
.tools{display:flex;flex-wrap:wrap;gap:8px;margin-top:28px}
.tool{
  border:1px solid var(--rule);padding:8px 14px;border-radius:999px;
  font-family:'Geist Mono';font-size:12px;letter-spacing:.02em;
  transition: background .2s var(--ease), color .2s var(--ease);
}
.tool:hover{background:var(--ink);color:var(--paper)}

/* =========== QUOTES =========== */
.quote-featured{
  margin: 48px 0 1px;
  display: grid;
  grid-template-columns: 1.5fr 1fr;
  gap: 1px;
  background: var(--rule);
  border: 1px solid var(--rule);
}
.qf-media{
  background: #0a0a0a;
  position: relative;
  aspect-ratio: 16 / 9;
  overflow: hidden;
}
.qf-video{
  width: 100%; height: 100%; display: block;
  object-fit: contain;
  background: #0a0a0a;
}
.qf-cap{
  background: var(--paper);
  padding: 36px;
  display: flex; flex-direction: column;
  gap: 20px;
}
.qf-tag{
  align-self: flex-start;
  display: inline-flex; align-items: center; gap: 8px;
  font-size: 10px; letter-spacing: .12em; text-transform: uppercase;
  color: var(--ink);
  border: 1px solid var(--rule-soft);
  padding: 6px 10px; border-radius: 999px;
}
.qf-tag-dot{
  width: 6px; height: 6px; border-radius: 50%;
  background: oklch(0.68 0.14 150);
  box-shadow: 0 0 0 2px color-mix(in oklab, oklch(0.68 0.14 150) 22%, transparent);
}
.qf-quote{
  margin: 0;
  font-family: 'Geist'; font-weight: 400;
  font-size: clamp(16px, 1.3vw, 18px);
  line-height: 1.4; letter-spacing: -0.01em;
  color: var(--muted);
  flex: 1;
}
.qf-author{
  display: flex; align-items: center; gap: 12px;
  border-top: 1px solid var(--rule-soft);
  padding-top: 16px;
}
.qf-author-meta{display:flex;flex-direction:column;gap:2px}
.qf-author-meta .q-name{font-weight:500;font-size:14px}
.qf-author-meta .q-role{font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:.08em}

.quote-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1px;padding-top:0;background:var(--rule);border:1px solid var(--rule);border-top:none}
.quote-card{
  background:var(--paper);padding:36px;margin:0;display:flex;flex-direction:column;justify-content:space-between;gap:32px;
  transition: background .2s var(--ease);
}
.quote-card:hover{background:var(--paper-2)}
.quote-card blockquote{
  margin:0;
  font-family:'Geist';font-weight:400;
  font-size: clamp(18px, 1.7vw, 24px);
  line-height:1.35;letter-spacing:-0.015em;
  position:relative;
}
.quote-card blockquote::before{
  content:"“";font-family:'Geist';font-size:72px;line-height:0.6;color:var(--muted-2);
  position:absolute;left:-4px;top:-10px;
}
.quote-card blockquote{padding-left:34px}
.quote-card blockquote p{margin:0}
.quote-card blockquote p + p{margin-top:0.65em}

.quote-card--full{
  grid-column: 1 / -1;
  display: grid;
  grid-template-columns: 1.9fr 1fr;
  gap: 64px;
  align-items: center;
}
.quote-card--full > blockquote{
  padding-left: 34px;
  margin: 0;
}
.quote-card.quote-card--full > figcaption{
  display: grid;
  grid-template-columns: auto 1fr;
  column-gap: 14px;
  row-gap: 2px;
  align-items: center;
  border-top: none;
  padding-top: 0;
  width: 100%;
}
.quote-card--full .q-author{display: contents}
.quote-card--full .q-avatar{
  width: 44px; height: 44px;
  grid-row: 1 / span 2;
  align-self: center;
}
.quote-card--full .q-name{
  grid-column: 2; grid-row: 1;
  align-self: end;
  font-size: 15px; font-weight: 500;
  line-height: 1.2;
}
.quote-card--full .q-role{
  grid-column: 2; grid-row: 2;
  align-self: start;
  border-top: none;
  padding-top: 0;
  padding-left: 0;
  width: auto;
}
@media (max-width: 1000px){
  .quote-card--full{grid-template-columns: 1fr; gap: 24px; align-items: stretch}
  .quote-card--full .q-role{padding-left: 0}
}
.quote-card figcaption{display:flex;justify-content:space-between;align-items:center;font-size:13px;border-top:1px solid var(--rule-soft);padding-top:16px}
.q-author{display:flex;align-items:center;gap:10px}
.q-avatar{width:36px;height:36px;border-radius:50%;object-fit:cover;flex-shrink:0}
.q-name{font-weight:500}
.q-role{font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:.08em}

/* =========== MEDIA / SPEAKING & TEACHING =========== */
.media-list{
  list-style:none;margin:0;padding:48px 0 0;
}
.media-item{
  display:grid;
  grid-template-columns: 96px 1fr auto auto;
  align-items:center;
  gap:28px;
  padding:28px 4px;
  border-bottom:1px solid var(--rule);
  transition: background .2s var(--ease), padding .25s var(--ease);
}
.media-item:hover{
  background:var(--ink);color:var(--paper);
  padding-left:20px;padding-right:20px;
}
.media-type{
  font-size:10px;letter-spacing:.12em;text-transform:uppercase;
  color:var(--ink);
  border:1px solid var(--rule-soft);
  padding:6px 10px 6px 8px;border-radius:999px;
  justify-self:start;
  display:inline-flex;align-items:center;gap:7px;
  transition: border-color .2s var(--ease), color .2s var(--ease);
}
.media-item:hover .media-type{border-color:var(--muted-2);color:var(--paper)}
.media-dot{
  width:6px;height:6px;border-radius:50%;
  background: var(--media-c, var(--ink));
  display:inline-block;flex-shrink:0;
  box-shadow: 0 0 0 2px color-mix(in oklab, var(--media-c, var(--ink)) 22%, transparent);
}
.media-type[data-type="talk"]    { --media-c: oklch(0.70 0.18 30); }   /* coral */
.media-type[data-type="class"]   { --media-c: oklch(0.78 0.16 80); }   /* amber */
.media-type[data-type="workshop"]{ --media-c: oklch(0.68 0.14 150); }  /* green */
.media-type[data-type="podcast"] { --media-c: oklch(0.65 0.16 270); }  /* violet */
.media-body{display:flex;flex-direction:column;gap:6px;min-width:0}
.media-title{
  font-family:'Geist';font-weight:500;
  font-size: clamp(18px, 1.5vw, 22px);
  line-height:1.25;letter-spacing:-0.015em;
  margin:0;
}
.media-venue{
  font-size:13px;color:var(--muted);
  transition: color .2s var(--ease);
}
.media-item:hover .media-venue{color:var(--muted-2)}
.media-date{
  font-size:11px;color:var(--muted);
  text-transform:uppercase;letter-spacing:.08em;
  transition: color .2s var(--ease);
}
.media-item:hover .media-date{color:var(--muted-2)}
.media-link{
  font-size:12px;letter-spacing:.04em;
  padding:8px 14px 8px 12px;border-radius:999px;
  border:1px solid var(--rule);
  display:inline-flex;align-items:center;gap:7px;
  transition: background .2s var(--ease), color .2s var(--ease), border-color .2s var(--ease);
}
.media-ico{width:13px;height:13px;flex-shrink:0;opacity:.85;transition:opacity .2s var(--ease)}
.media-item:hover .media-link{
  background:var(--paper);color:var(--ink);border-color:var(--paper);
}
.media-item:hover .media-ico{opacity:1}

/* Upcoming / in-the-works row */
.media-item--soon{
  background: color-mix(in oklab, var(--paper) 92%, var(--ink) 8%);
}
.media-item--soon:hover{
  background: color-mix(in oklab, var(--paper) 92%, var(--ink) 8%);
  color: var(--ink);
  padding-left: 4px; padding-right: 4px;
}
.media-item--soon .media-title{ color: var(--muted); }
.media-item--soon .media-venue{ color: var(--muted-2); }
.media-item--soon .media-date{ color: var(--muted); }
.media-link--soon{
  cursor: default;
  border-style: dashed !important;
  color: var(--muted);
  background: transparent;
}
.media-item--soon:hover .media-link--soon{
  background: transparent;
  color: var(--muted);
  border-color: var(--rule-soft);
}

/* =========== CTA =========== */
.cta{
  border-top:1px solid var(--rule);
  padding-top:100px;padding-bottom:80px;
  text-align:center;
}
.cta-meta{
  display:flex;justify-content:space-between;font-size:11px;color:var(--muted);
  padding-bottom:40px;max-width:none;
}
.cta-title{
  font-family:'Geist';font-weight:600;
  font-size: clamp(64px, 12vw, 200px);
  line-height:0.9;letter-spacing:-0.05em;margin: 20px 0 40px;
}
.cta-line{display:block}
.cta-line.outlined{color:transparent;-webkit-text-stroke:1.5px var(--ink);font-style:italic;font-weight:500}
.cta-email{
  display:inline-block;font-family:'Geist';font-size: clamp(18px,1.6vw,24px);
  padding: 8px 4px;border-bottom:1.5px solid var(--ink);
  transition: letter-spacing .2s var(--ease);
}
.cta-email:hover{letter-spacing:.01em}
.cta-actions{display:flex;gap:12px;justify-content:center;margin-top:40px;flex-wrap:wrap}
.cta-socials{list-style:none;margin:60px 0 0;padding:0;display:flex;justify-content:center;gap:28px;font-size:12px;color:var(--muted)}
.cta-socials a:hover{color:var(--ink)}

/* =========== FOOTER =========== */
.footer{
  border-top:1px solid var(--rule);
  margin-top:0;
}
.footer-marquee{
  overflow:hidden;padding:26px 0;border-bottom:1px solid var(--rule);
}
.footer-marquee .marq-track span:nth-child(2n-1){
  font-style:italic;color:transparent;-webkit-text-stroke:1.5px var(--ink);font-weight:500;
}
.footer-grid{
  max-width:var(--max);margin:0 auto;
  display:grid;grid-template-columns:repeat(4,1fr);gap:32px;
  padding: 48px var(--gutter) 24px;
}
.footer-cell{display:flex;flex-direction:column;gap:10px}
.footer-h{font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:.1em}
.footer-cell p{margin:0;font-size:14px;line-height:1.7}
.footer-cell a:hover{text-decoration:underline;text-decoration-thickness:1px;text-underline-offset:3px}
.footer-time{
  max-width:var(--max);margin:0 auto;
  padding: 20px var(--gutter) 32px;
  font-size:11px;color:var(--muted);display:flex;justify-content:flex-end;
}

/* =========== NOW WIDGET =========== */
.now{
  position:fixed;bottom:24px;right:24px;z-index:85;
}
.now-toggle{
  display:inline-flex;align-items:center;gap:8px;
  padding:10px 14px;border-radius:999px;
  background:var(--ink);color:var(--paper);
  border:none;cursor:pointer;font-family:'Geist Mono';font-size:11px;letter-spacing:.06em;
  box-shadow: 0 14px 30px -12px rgba(0,0,0,.4);
}
.now-toggle .now-dot{
  width:8px;height:8px;border-radius:50%;background:#3bbd63;
  box-shadow:0 0 0 3px rgba(59,189,99,.35);
  animation: pulse 2s infinite;
}
.now-panel{
  position:absolute;bottom:52px;right:0;
  width: 320px;max-width: calc(100vw - 48px);
  background:var(--paper);border:1px solid var(--rule);border-radius:8px;
  padding:18px;display:flex;flex-direction:column;gap:10px;
  transform-origin: bottom right;
  transform: scale(.92) translateY(6px);opacity:0;pointer-events:none;
  transition: transform .25s var(--ease), opacity .2s var(--ease);
  box-shadow: 0 20px 50px -18px rgba(0,0,0,.4);
}
.now.open .now-panel{transform:scale(1) translateY(0);opacity:1;pointer-events:auto}
.now-row{display:grid;grid-template-columns: 100px 1fr;gap:10px;align-items:baseline;font-size:13px;padding-bottom:8px;border-bottom:1px dashed var(--rule-soft)}
.now-row:last-of-type{border-bottom:none;padding-bottom:0}
.now-k{font-size:10px;color:var(--muted);text-transform:uppercase;letter-spacing:.08em}
.now-foot{font-size:10px;color:var(--muted);text-transform:uppercase;letter-spacing:.08em;margin-top:4px}

/* =========== REVEAL =========== */
.reveal{opacity:0;transform:translateY(18px);transition: opacity .7s var(--ease), transform .7s var(--ease)}
.reveal.in{opacity:1;transform:none}
@media (prefers-reduced-motion: reduce){
  .reveal{opacity:1;transform:none;transition:none}
}

/* =========== RESPONSIVE =========== */
@media (max-width: 1000px){
  .nav{grid-template-columns: 1fr auto 1fr}
  .nav-status{display:none}
  .section-head{grid-template-columns:1fr;gap:12px}
  .section-side{text-align:left}
  .hero-title{font-size: clamp(54px, 13vw, 120px)}
  .hero-foot{grid-template-columns:1fr;gap:24px}
  .hero-actions{justify-content:flex-start}
  .hero-meta{position:static;margin-bottom:10px}
  .about-grid{grid-template-columns:1fr;gap:40px}
  .about-photo{position:static}
  .svc-grid{grid-template-columns:repeat(2,1fr)}
  .proc-list{grid-template-columns:repeat(2,1fr)}
  .quote-grid{grid-template-columns:1fr}
  .quote-featured{grid-template-columns:1fr}
  .qf-cap{padding:24px}
  .footer-grid{grid-template-columns:repeat(2,1fr)}
  .media-item{grid-template-columns: auto 1fr;grid-template-rows: auto auto;gap:8px 16px;padding:24px 4px}
  .media-body{grid-column:1 / -1;order:2}
  .media-date{order:3;justify-self:start;grid-column:1}
  .media-link{order:4;justify-self:end;grid-column:2;grid-row:3}
  .media-date{grid-row:3}
  .media-type{grid-row:1}
  .media-item:hover{padding-left:12px;padding-right:12px}
}
@media (max-width: 640px){
  /* Nav */
  .nav{grid-template-columns:auto 1fr;padding:0 16px;height:52px;gap:12px}
  .brand-name{display:none}
  .nav-links{display:flex;gap:0;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;justify-content:flex-end}
  .nav-links::-webkit-scrollbar{display:none}
  .nav-links a{padding:6px 10px;font-size:12px;white-space:nowrap;flex-shrink:0}
  .nav-right{display:none}
  .progress-counter{display:none}

  /* Hero */
  .hero{padding:80px 20px 48px}
  .hero-title{font-size:clamp(44px,14vw,72px);letter-spacing:-.03em}
  .hero-intro p{font-size:16px}
  .hero-actions{flex-direction:column;align-items:flex-start;gap:10px}
  .hero-marquee{margin-top:32px}

  /* Work section */
  .work{padding:60px 20px}

  /* About */
  .about-grid{gap:28px}
  .about-img{aspect-ratio:1/1;max-height:none;object-fit:cover;object-position:center top}
  .about-p{font-size:16px}
  .about-facts{grid-template-columns:1fr;gap:0}
  .about-facts .fact{padding:14px 0}
  .about-facts .fact dt{flex:0 0 100px}

  /* Services */
  .svc-grid,.proc-list,.footer-grid{grid-template-columns:1fr}
  .svc{padding:20px}

  /* Process */
  .proc-step{padding:16px 16px 16px 16px}

  /* Quotes */
  .quote-grid{grid-template-columns:1fr}
  .quote-card{padding:24px}

  /* CTA */
  .cta{padding:80px 20px 60px}
  .cta-title{font-size:clamp(44px,16vw,80px)}
  .cta-actions{flex-direction:column;align-items:center;gap:10px}
  .cta-email{font-size:14px;word-break:break-all}
  .cta-socials{flex-wrap:wrap;gap:12px}

  /* Footer */
  .footer-grid{grid-template-columns:1fr 1fr}
  .footer-marquee{display:none}

  /* Now widget */
  .now{bottom:16px;right:16px}

  /* Sections general */
  .section-head{padding:0 20px 32px}
  .about,.services,.process,.quotes{padding:60px 20px}
}

/* =========== THEME TOGGLE BUTTON =========== */
.theme-toggle{
  width:32px;height:32px;
  display:inline-flex;align-items:center;justify-content:center;
  border:1.5px solid var(--ink);border-radius:50%;
  background:transparent;color:var(--ink);
  cursor:pointer;margin-left:8px;flex-shrink:0;padding:0;
  transition: background .18s var(--ease), color .18s var(--ease), border-color .18s var(--ease);
}
.theme-toggle:hover{background:var(--ink);color:var(--paper)}
.theme-toggle svg{width:15px;height:15px;pointer-events:none}
.theme-toggle .theme-icon-dark{display:none}
:root[data-theme="dark"] .theme-toggle .theme-icon-light{display:none}
:root[data-theme="dark"] .theme-toggle .theme-icon-dark{display:inline-block}

/* =========== HAMBURGER BUTTON =========== */
.nav-menu-btn{display:none;padding:0;background:transparent;border:none;cursor:pointer;color:var(--ink)}
.nav-menu-icon{position:relative;display:block;width:22px;height:14px}
.nav-menu-icon span{
  position:absolute;left:0;right:0;height:1.6px;background:currentColor;border-radius:2px;
  transition: top .25s var(--ease), transform .25s var(--ease), opacity .2s var(--ease);
}
.nav-menu-icon span:nth-child(1){top:2px}
.nav-menu-icon span:nth-child(2){top:10px}
.nav.is-open .nav-menu-icon span:nth-child(1){top:6px;transform:rotate(45deg)}
.nav.is-open .nav-menu-icon span:nth-child(2){top:6px;transform:rotate(-45deg)}

/* Smooth theme transitions */
body{transition: background-color .25s var(--ease), color .25s var(--ease)}
