/* ── RESET ── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}

/* ── TOKENS ── */
:root{
  --teal:#2a9d8f;
  --teal-dark:#0a3630;
  --teal-mid:#1a6b5e;
  --teal-light:#d4ede9;
  --teal-pale:#edf7f5;
  --gold:#c9a84c;
  --gold-accessible:#e2c87c;
  --gold-dark:#6b4f15;
  --navy:#0d0d1a;
  --navy2:#12121f;
  --navy3:#1a1a2e;
  --card-bg:rgba(255,255,255,0.04);
  --card-border:rgba(42,157,143,0.2);
  --text:#f0faf8;
  --text-muted:#8ab8b2;
  --text-dim:#4a7a72;
  --btn-text:#ffffff;
  --serif:'Fraunces',Georgia,serif;
  --sans:'DM Sans',system-ui,sans-serif;
  --radius:12px;
  --radius-lg:16px;
  --gap:16px;
  --section-pad:60px 6%;
  --tr:0.3s cubic-bezier(0.4,0,0.2,1);
}

/* ── LIGHT MODE — Heritage Palette (timeless elegance) ── */
[data-theme="light"]{
  --navy:#FBF9F6;
  --navy2:#f0ebe2;
  --navy3:#e5dccc;
  --card-bg:rgba(255,255,253,0.96);
  --card-border:rgba(109,27,40,0.16);
  --text:#2E1A14;
  --text-muted:#4a2818;
  --text-dim:#6b4530;
  --btn-text:#ffffff;
  --teal:#6D1B28;
  --teal-dark:#4a1018;
  --teal-mid:#8a2530;
  --teal-light:#e8d5d8;
  --teal-pale:#f7eded;
  --cta:#C5A021;
  --cta-dark:#9c7e16;
  --wine:#6D1B28;
  --wine-deep:#4a1018;
  --tab-bg:#bcdcee;
  --tab-text:#062340;
}

/* ── BASE ── */
html{scroll-behavior:smooth}
body{
  font-family:var(--sans);
  background:var(--navy);
  color:var(--text);
  line-height:1.7;
  overflow-x:hidden;
  transition:background var(--tr),color var(--tr);
  font-size:18px;
}

/* ── SKIP LINK (WCAG 2.4.1) — visually hidden until keyboard-focused ── */
.skip-link{
  position:absolute;left:0;top:0;
  width:1px;height:1px;overflow:hidden;
  clip:rect(0 0 0 0);clip-path:inset(50%);
  white-space:nowrap;
}
.skip-link:focus,.skip-link:focus-visible{
  width:auto;height:auto;clip:auto;clip-path:none;
  white-space:normal;
  top:12px;left:12px;z-index:9999;
  background:var(--teal);color:#fff;
  padding:10px 18px;border-radius:24px;
  font-size:15px;font-weight:600;text-decoration:none;
  box-shadow:0 6px 22px rgba(0,0,0,0.25);
  outline:2px solid #fff;outline-offset:2px;
}

/* Smooth scroll targets — offset for floating nav */
:where(section[id]){scroll-margin-top:88px}

/* Active nav link via aria-current (set by JS scroll-spy) */
.nav-links a[aria-current="page"]{color:var(--teal);font-weight:600}
[data-theme="light"] .nav-links a[aria-current="page"]{color:#ff7058}

/* Visually-hidden utility for sr-only labels */
.visually-hidden{
  position:absolute!important;width:1px;height:1px;
  padding:0;margin:-1px;overflow:hidden;
  clip:rect(0,0,0,0);white-space:nowrap;border:0;
}

/* ── SCROLLBAR ── */
::-webkit-scrollbar{width:3px}
::-webkit-scrollbar-thumb{background:var(--teal);border-radius:2px}

/* ── FLOATING NAV — matches I go by badge styling ── */
nav[role="navigation"]{
  position:fixed;top:16px;left:50%;transform:translateX(-50%);
  z-index:100;
  background:linear-gradient(135deg,rgba(42,157,143,0.22) 0%,rgba(42,157,143,0.08) 100%);
  backdrop-filter:blur(20px);
  -webkit-backdrop-filter:blur(20px);
  border:1px solid rgba(42,157,143,0.5);
  border-radius:50px;
  padding:9px 22px;
  display:flex;align-items:center;gap:20px;
  position:fixed;overflow:hidden;isolation:isolate;
}
nav[role="navigation"]::before{
  content:"";position:absolute;inset:0;border-radius:50px;
  background:linear-gradient(105deg,transparent 35%,rgba(255,112,88,0.55) 50%,transparent 65%);
  pointer-events:none;z-index:-1;
  transform:translateX(-110%);
  transition:transform 0.9s cubic-bezier(0.4,0,0.2,1);
}
@media(prefers-reduced-motion:no-preference){
  nav[role="navigation"]::before{animation:goByShimmer 7s ease-in-out 1s infinite}
}
nav[role="navigation"]:hover::before{animation:none;transform:translateX(110%);transition:transform 0.9s cubic-bezier(0.4,0,0.2,1)}
[data-theme="light"] nav[role="navigation"]{
  background:linear-gradient(135deg,#ffffff 0%,#ece4d6 100%);
  border-color:rgba(10,54,48,0.28);
}
[data-theme="light"] nav[role="navigation"]::before{
  background:linear-gradient(105deg,transparent 35%,rgba(255,112,88,0.45) 50%,transparent 65%);
}
.nav-logo{
  font-family:var(--serif);font-size:17px;
  color:var(--teal);font-weight:500;
  text-decoration:none;position:relative;z-index:1;
}
[data-theme="light"] .nav-logo{color:#4a1018}
.nav-links{display:flex;gap:18px;align-items:center;position:relative;z-index:1}
.nav-links a{
  font-size:15px;color:var(--text-muted);
  text-decoration:none;transition:color var(--tr);
  font-weight:500;
}
[data-theme="light"] .nav-links a{color:#4a1018}
.nav-links a:hover{color:var(--teal)}
[data-theme="light"] .nav-links a:hover{color:#ff7058}
.theme-btn{
  background:transparent;
  border:1px solid var(--card-border);
  border-radius:20px;padding:4px 12px;
  color:var(--text-muted);font-size:14px;
  cursor:pointer;transition:all var(--tr);
  font-family:var(--sans);font-weight:500;
  min-width:44px;min-height:32px;position:relative;z-index:1;
}
[data-theme="light"] .theme-btn{color:#4a1018;border-color:rgba(10,54,48,0.28)}
.theme-btn:hover,.theme-btn:focus{
  border-color:var(--teal);color:var(--teal);outline:2px solid var(--teal);outline-offset:2px;
}
[data-theme="light"] .theme-btn:hover,[data-theme="light"] .theme-btn:focus{
  border-color:#ff7058;color:#ff7058;outline-color:#ff7058;
}

/* ── HERO ── */
.hero{
  display:flex;flex-direction:column;justify-content:flex-start;
  padding:96px 4% 16px;
  position:relative;overflow:hidden;
}
@media(max-width:920px){.hero{padding-top:88px}}
#about .section-eyebrow{margin-bottom:28px}
#about h2.section-title{margin-bottom:18px}
.mesh{
  position:absolute;inset:0;z-index:0;
  background:
    radial-gradient(ellipse 70% 55% at 15% 25%,rgba(42,157,143,0.1) 0%,transparent 60%),
    radial-gradient(ellipse 50% 45% at 80% 70%,rgba(10,54,48,0.4) 0%,transparent 60%),
    radial-gradient(ellipse 35% 35% at 50% 8%,rgba(201,168,76,0.05) 0%,transparent 50%);
  animation:meshPulse 14s ease-in-out infinite alternate;
}
[data-theme="light"] .mesh{
  background:
    radial-gradient(ellipse 70% 55% at 15% 25%,rgba(201,168,76,0.10) 0%,transparent 60%),
    radial-gradient(ellipse 50% 45% at 80% 70%,rgba(114,47,55,0.06) 0%,transparent 60%),
    radial-gradient(ellipse 35% 35% at 50% 8%,rgba(226,200,124,0.10) 0%,transparent 50%);
}
@keyframes meshPulse{to{opacity:0.92}}
.grain{
  position:absolute;inset:0;z-index:1;opacity:0.025;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  background-size:200px;
}
.hero-inner{
  position:relative;z-index:2;width:100%;max-width:none;
  display:grid;
  grid-template-columns:minmax(0,720px) minmax(260px,320px) 1fr;
  grid-template-areas:
    "chips chips  chips"
    "text  visual ."
    "stats stats  stats";
  gap:18px 182px;align-items:center;
}
.hero-availability{grid-area:chips}
.hero-text{grid-area:text;min-width:0;display:flex;flex-direction:column;gap:14px;padding-right:8px}
.hero-text > *{margin:0}
.hero-text .hero-bio{margin:0}
.hero-visual{
  grid-area:visual;
  display:flex;align-items:center;justify-content:flex-start;
  position:relative;z-index:2;justify-self:start;
  margin-left:0;
}
.hero-visual .hero-monogram{max-width:340px}
.hero-stats{grid-area:stats}
@media(max-width:920px){
  .hero-inner{
    grid-template-columns:1fr;
    grid-template-areas:"chips" "visual" "text" "stats";
    gap:18px;
  }
  .hero-visual{justify-self:start}
  .hero-visual .hero-monogram{max-width:260px}
}
@media(max-width:600px){.hero-visual .hero-monogram{max-width:220px}}

/* Light-mode brand monogram: solid gold disc, black DA (no red anywhere) */
[data-theme="light"] .hero-brand-base{fill:#C5A021}
[data-theme="light"] .hero-brand-inner{fill:#C5A021}
[data-theme="light"] .hero-brand-shimmer{opacity:0.2}
[data-theme="light"] .hero-brand-glow{fill:url(#brandGlowLight)}
[data-theme="light"] .hero-brand-glow-outer{fill:transparent}
[data-theme="light"] .hero-monogram{
  filter:drop-shadow(0 22px 52px rgba(197,160,33,0.28));
}
.hero-stats{
  grid-column:1 / -1;margin-top:20px;
  display:flex;gap:18px;flex-wrap:nowrap;
  padding-top:24px;border-top:0.5px solid rgba(109,27,40,0.18);
  overflow-x:auto;scrollbar-width:none;-ms-overflow-style:none;
}
.hero-stats::-webkit-scrollbar{display:none}
.hero-stats > div{flex:1 1 0;min-width:130px}
.hero-stats .stat-num{font-size:28px}
.hero-stats .stat-label{font-size:11.5px;white-space:normal;line-height:1.35}
@media(max-width:920px){
  .hero-stats{flex-wrap:wrap;overflow-x:visible}
  .hero-stats > div{flex:1 1 130px}
}
.hero-monogram{
  width:100%;max-width:480px;height:auto;display:block;
  filter:drop-shadow(0 22px 52px rgba(255,140,26,0.22));
}
.hero-process-ring{
  transform-origin:220px 220px;transform-box:view-box;
  animation:heroProcessRotate 40s linear infinite;
}
@keyframes heroProcessRotate{
  from{transform:rotate(0deg)}
  to{transform:rotate(360deg)}
}
.hero-brand-disk{
  transform-origin:220px 220px;transform-box:view-box;
  animation:heroBrandDrift 20s ease-in-out infinite;
}
@keyframes heroBrandDrift{
  0%,100%{transform:rotate(0deg) scale(1)}
  50%{transform:rotate(180deg) scale(1.02)}
}
.hero-process-text{
  fill:#0d0d0d;font-family:'DM Sans',sans-serif;
  font-size:12.5px;letter-spacing:7.5px;font-weight:700;
  paint-order:stroke;stroke:rgba(255,250,240,0.55);stroke-width:1.4;stroke-linejoin:round;
}
[data-theme="light"] .hero-process-text{
  fill:#0d0d0d;stroke:rgba(255,253,247,0.7);stroke-width:1.4;
}
.hero-monogram-text{
  fill:#FBF9F6;font-family:'Fraunces',Georgia,serif;
  font-size:92px;font-weight:600;letter-spacing:-2px;
  paint-order:stroke;stroke:rgba(13,8,8,0.55);stroke-width:1.4;stroke-linejoin:round;
}
[data-theme="light"] .hero-monogram-text{
  fill:#0d0d0d;stroke:rgba(255,253,247,0.85);stroke-width:1.8;
}
.hero-tagline-text{
  fill:#0d0d0d;font-family:'DM Sans',sans-serif;
  font-size:14px;letter-spacing:4.5px;font-weight:700;
  paint-order:stroke;stroke:rgba(255,250,240,0.55);stroke-width:0.8;stroke-linejoin:round;
}
[data-theme="light"] .hero-tagline-text{
  fill:#0d0d0d;stroke:rgba(255,253,247,0.7);stroke-width:0.8;
}
@keyframes daShimmer{
  0%,72%,100%{fill:#0d0d0d}
  40%,48%{fill:#FBF9F6}
}
@media(prefers-reduced-motion:reduce){
  .hero-monogram-text,.hero-process-text,.hero-tagline-text{animation:none}
}
.hero-brand-shimmer{
  mix-blend-mode:overlay;opacity:0.6;
  animation:heroShimmer 6s ease-in-out infinite;
}
@keyframes heroShimmer{
  0%,100%{opacity:0.2}
  50%{opacity:0.7}
}
@media(max-width:920px){
  .hero-inner{grid-template-columns:1fr;gap:24px}
  .hero-visual{order:-1;justify-self:center;max-width:280px;width:100%}
}
@media(prefers-reduced-motion:reduce){
  .hero-process-ring,.hero-brand-disk,.hero-brand-shimmer{animation:none}
}
.hero-availability{
  grid-column:1 / -1;width:100%;min-width:0;
  display:grid;grid-auto-flow:column;grid-auto-columns:max-content;
  align-items:center;gap:6px;
  margin-bottom:0;
  overflow-x:auto;scrollbar-width:none;-ms-overflow-style:none;
}
.hero-availability::-webkit-scrollbar{display:none}
@media(max-width:600px){
  .hero-availability{display:flex;flex-wrap:wrap;overflow-x:visible}
}
.hero-avail-pill{
  display:inline-flex;align-items:center;gap:6px;
  background:var(--teal);color:#fff;
  padding:4px 11px;border-radius:18px;
  font-size:11.5px;font-weight:500;letter-spacing:0.02em;
  flex-shrink:0;white-space:nowrap;
}
.hero-avail-dot{
  width:8px;height:8px;border-radius:50%;
  background:#7cf6c2;
  box-shadow:0 0 0 0 rgba(124,246,194,0.6);
  animation:availPulse 2s ease-in-out infinite;
}
.hero-avail-loc{
  display:inline-flex;align-items:center;
  background:rgba(42,157,143,0.08);color:var(--text);
  border:0.5px solid rgba(42,157,143,0.32);
  padding:4px 10px;border-radius:16px;
  font-size:11.5px;font-weight:500;
  flex-shrink:0;white-space:nowrap;
}
[data-theme="light"] .hero-avail-loc{
  color:#2E1A14;background:rgba(197,160,33,0.14);
  border-color:rgba(109,27,40,0.28);
}
.hero-role-tags{
  grid-column:1 / -1;width:100%;min-width:0;
  display:grid;grid-auto-flow:column;grid-auto-columns:max-content;
  align-items:center;gap:10px;margin-bottom:18px;
  overflow-x:auto;scrollbar-width:none;-ms-overflow-style:none;
}
.hero-role-tags::-webkit-scrollbar{display:none}
@media(max-width:600px){
  .hero-role-tags{display:flex;flex-wrap:wrap;overflow-x:visible}
}
.hero-role-tag{
  flex-shrink:0;white-space:nowrap;
  font-size:11.5px;font-weight:500;color:var(--teal);
  background:rgba(42,157,143,0.1);
  border:0.5px solid rgba(42,157,143,0.32);
  padding:4px 10px !important;border-radius:16px !important;
  padding:6px 13px;border-radius:20px;letter-spacing:0.01em;
}
[data-theme="light"] .hero-role-tag{
  color:#2E1A14;background:rgba(197,160,33,0.16);
  border-color:rgba(109,27,40,0.28);
}
.hero-status{
  display:inline-flex;align-items:stretch;gap:0;
  background:var(--card-bg);border:0.5px solid var(--card-border);
  backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);
  border-radius:30px;padding:0;
  margin-bottom:22px;overflow:hidden;
  flex-wrap:wrap;
}
[data-theme="light"] .hero-status{background:rgba(255,255,255,0.85)}
.hero-status-pill{
  display:inline-flex;align-items:center;gap:8px;
  background:var(--teal);color:#fff;
  padding:8px 16px;
  font-size:14px;font-weight:500;letter-spacing:0.02em;
}
.hero-status-dot{
  width:8px;height:8px;border-radius:50%;
  background:#7cf6c2;
  box-shadow:0 0 0 0 rgba(124,246,194,0.6);
  animation:availPulse 2s ease-in-out infinite;
}
.hero-status-meta{
  display:inline-flex;align-items:center;gap:0;
  padding:0 6px;flex-wrap:wrap;
}
.hero-status-meta span{
  font-size:13px;color:var(--text-muted);font-weight:400;
  padding:6px 10px;
}
[data-theme="light"] .hero-status-meta span{color:var(--teal-dark)}
.hero-status-sep{color:var(--text-dim) !important;padding:6px 0 !important}
.hero-cv-link{
  display:inline-block;margin-top:10px;
  font-size:15px;font-weight:500;color:var(--teal);
  text-decoration:none;border-bottom:1px solid transparent;
  transition:border-color var(--tr);
}
.hero-cv-link:hover,.hero-cv-link:focus-visible{
  border-bottom-color:var(--teal);outline:none;
}
.hero-bio-ai{margin-top:8px}
.avail-card{
  background:rgba(255,255,255,0.06);
  border:0.5px solid var(--card-border);
  backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);
  border-radius:var(--radius-lg);
  padding:22px;
  display:flex;flex-direction:column;gap:14px;
  box-shadow:0 12px 40px rgba(10,54,48,0.18);
  animation:availIn 0.7s cubic-bezier(0.4,0,0.2,1) 0.2s both;
}
[data-theme="light"] .avail-card{background:rgba(255,255,255,0.85)}
@keyframes availIn{from{opacity:0;transform:translateX(28px)}to{opacity:1;transform:none}}
.avail-status{
  display:inline-flex;align-items:center;gap:8px;
  font-size:13px;font-weight:500;color:var(--text);letter-spacing:0.02em;
}
.avail-dot{
  width:8px;height:8px;border-radius:50%;
  background:#2ecc71;box-shadow:0 0 0 0 rgba(46,204,113,0.6);
  animation:availPulse 2s ease-in-out infinite;
}
@keyframes availPulse{
  0%,100%{box-shadow:0 0 0 0 rgba(46,204,113,0.55)}
  50%{box-shadow:0 0 0 8px rgba(46,204,113,0)}
}
.avail-pills{display:flex;flex-wrap:wrap;gap:6px}
.avail-pill{
  font-size:12px;font-weight:500;color:var(--teal);
  background:rgba(42,157,143,0.12);
  border:0.5px solid rgba(42,157,143,0.35);
  padding:5px 10px;border-radius:20px;
}
[data-theme="light"] .avail-pill{color:var(--teal-dark);border-color:rgba(10,54,48,0.25)}
.avail-loc{font-size:13px;color:var(--text-muted);font-weight:300}
.avail-cta{
  margin-top:4px;align-self:flex-start;
  background:var(--teal);color:#fff;border:none;
  padding:10px 20px;border-radius:24px;
  font-size:14px;font-weight:500;font-family:inherit;
  cursor:pointer;text-decoration:none;display:inline-block;
  transition:background var(--tr),transform var(--tr);
}
.avail-cta:hover,.avail-cta:focus-visible{background:var(--teal-mid);transform:translateY(-1px);outline:none}
.hero-tag{
  display:inline-flex;align-items:center;gap:8px;
  font-size:14px;color:var(--teal);letter-spacing:0.08em;text-transform:uppercase;font-weight:500;
  background:rgba(42,157,143,0.1);border:0.5px solid rgba(42,157,143,0.3);
  padding:5px 14px;border-radius:20px;margin-bottom:20px;
}
.pulse{width:6px;height:6px;border-radius:50%;background:var(--teal);animation:pulse 2s ease-in-out infinite}
@keyframes pulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:0.4;transform:scale(0.8)}}

/* H1, only one per page */
h1.hero-name{
  font-family:var(--serif);
  font-size:clamp(48px,7.5vw,82px);
  font-weight:300;line-height:1.05;
  color:var(--text);letter-spacing:-0.03em;
  margin-bottom:14px;
}
h1.hero-name span{color:var(--teal)}
.hero-roles{
  font-size:clamp(18px,2.4vw,22px);
  color:var(--text-muted);margin-bottom:20px;
  font-weight:300;min-height:34px;
}
.role-word{
  color:var(--teal);font-weight:500;
}
.hero-bio{
  font-size:18px;color:var(--text-muted);
  max-width:540px;line-height:1.8;margin-bottom:28px;font-weight:300;
}
.hero-btns{display:flex;gap:12px;flex-wrap:wrap}

/* ── BUTTONS, high contrast in both modes ── */
.btn-primary-lg{padding:14px 32px !important;font-size:18px !important}
.btn-primary{
  background:#C5A021;
  color:#fff;
  padding:12px 26px;border-radius:50px;
  text-decoration:none;font-size:17px;font-weight:500;
  border:2px solid #C5A021;
  transition:all var(--tr);display:inline-block;
  font-family:var(--sans);cursor:pointer;
  min-height:44px;
}
.btn-primary:hover,.btn-primary:focus{
  background:#9c7e16;border-color:#9c7e16;
  transform:translateY(-2px);box-shadow:0 8px 24px rgba(138,94,44,0.35);
  outline:2px solid #9c7e16;outline-offset:3px;
}
.btn-ghost{
  background:transparent;
  color:#4a1018;
  padding:12px 26px;border-radius:50px;
  text-decoration:none;font-size:17px;font-weight:500;
  border:2px solid #4a1018;
  transition:all var(--tr);display:inline-block;
  font-family:var(--sans);cursor:pointer;
  min-height:44px;
}
[data-theme="light"] .btn-ghost{
  color:#4a1018;border-color:#4a1018;
}
.btn-ghost:hover,.btn-ghost:focus{
  background:#4a1018;color:#f5efe2;
  transform:translateY(-2px);
  outline:2px solid #4a1018;outline-offset:3px;
}
[data-theme="light"] .btn-ghost:hover{
  background:#4a1018;color:#f5efe2;border-color:#4a1018;
}

/* legacy .hero-stats block removed; styles defined in the layout grid above */
.stat-num{
  font-family:var(--serif);font-size:34px;
  font-weight:500;color:#2E1A14;line-height:1;
}
[data-theme="light"] .stat-num{color:#2E1A14}
.stat-label{
  font-size:13px;color:#4a2818;
  text-transform:uppercase;letter-spacing:0.08em;margin-top:3px;font-weight:500;
}
[data-theme="light"] .stat-label{color:#4a2818}
.hero-creds{
  list-style:none;padding:0;margin:18px 0 0;
  display:flex;flex-direction:column;gap:8px;
  max-width:640px;
}
.hero-creds li{
  display:flex;align-items:flex-start;gap:10px;
  font-size:13.5px;color:var(--text-muted);line-height:1.55;font-weight:300;
  padding:6px 0 6px 12px;
  border-left:2px solid rgba(42,157,143,0.35);
  transition:border-color 0.25s,color 0.25s;
}
.hero-creds li:hover{border-left-color:var(--teal);color:var(--text)}
.hero-creds li strong{color:var(--text);font-weight:500}
.hero-creds-icon{
  font-size:14px;line-height:1.4;flex-shrink:0;
  display:inline-flex;align-items:center;justify-content:center;
  width:22px;height:22px;border-radius:6px;
  background:rgba(42,157,143,0.12);
}
[data-theme="light"] .hero-creds-icon{background:rgba(42,157,143,0.16)}

/* ── SECTION STRUCTURE ── */
section{padding:var(--section-pad);position:relative}
.section-eyebrow{
  font-size:12px;letter-spacing:0.16em;text-transform:uppercase;
  color:var(--teal);font-weight:600;
  display:flex;align-items:center;gap:10px;margin-bottom:12px;
}
.section-eyebrow::before{content:'';display:block;width:24px;height:1px;background:var(--teal)}
[data-theme="light"] .section-eyebrow{color:#6D1B28}
[data-theme="light"] .section-eyebrow::before{background:#6D1B28}

/* H2, section titles — WCAG hierarchy, max ~36px for clean ratio against h1 */
h2.section-title{
  font-family:var(--serif);
  font-size:clamp(26px,3.2vw,36px);
  font-weight:400;line-height:1.2;
  color:var(--text);letter-spacing:-0.015em;
  margin-bottom:28px;
  scroll-margin-top:96px;
}
.section-divider{
  height:0.5px;margin:0 6%;
  background:linear-gradient(90deg,transparent,rgba(42,157,143,0.25),transparent);
}

/* ── ABOUT ── */
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:40px;align-items:start}
.about-text p{font-size:18px;color:var(--text-muted);line-height:1.8;margin-bottom:14px;font-weight:300}
.about-text strong{color:var(--teal);font-weight:500}
.skills-grid{display:flex;flex-direction:column;gap:10px}
.skill-row{
  position:relative;
  background:var(--card-bg);border:0.5px solid var(--card-border);
  border-left:3px solid var(--teal);
  border-radius:var(--radius);padding:12px 16px;
  backdrop-filter:blur(10px);
  transition:border-color var(--tr),transform var(--tr),box-shadow var(--tr);
  overflow:hidden;
}
.skill-row::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(135deg,rgba(42,157,143,0.06) 0%,transparent 60%);
  pointer-events:none;opacity:0;transition:opacity var(--tr);
}
.skill-row:hover{
  border-color:var(--teal);
  transform:translateX(3px);
  box-shadow:-3px 6px 18px rgba(42,157,143,0.12);
}
.skill-row:hover::after{opacity:1}
.skill-cat{
  font-size:13px;text-transform:uppercase;letter-spacing:0.1em;
  color:var(--teal);font-weight:500;margin-bottom:8px;
  display:flex;align-items:center;gap:9px;position:relative;z-index:1;
}
.skill-cat-icon{
  display:inline-grid;place-items:center;
  width:26px;height:26px;border-radius:7px;
  background:rgba(42,157,143,0.15);color:var(--teal);
  font-size:14px;line-height:1;font-weight:500;
  font-family:var(--serif);font-style:normal;
  flex-shrink:0;
}
[data-theme="light"] .skill-row{border-left-color:#6D1B28}
[data-theme="light"] .skill-row::after{background:linear-gradient(135deg,rgba(197,160,33,0.08) 0%,transparent 60%)}
[data-theme="light"] .skill-row:hover{border-color:#6D1B28;box-shadow:-3px 6px 18px rgba(109,27,40,0.14)}
[data-theme="light"] .skill-cat{color:#4a1018}
[data-theme="light"] .skill-cat-icon{background:#6D1B28;color:#FBF9F6}
.skill-cat-count{
  margin-left:auto;font-size:11px;color:var(--text-dim);
  font-weight:400;letter-spacing:0;text-transform:none;
}
.skill-tags{display:flex;flex-wrap:wrap;gap:5px;position:relative;z-index:1}

/* ── SKILL TAGS, shimmer on hover ── */
.stag{
  font-size:13px;color:var(--text-muted);
  background:rgba(42,157,143,0.08);
  border:0.5px solid rgba(42,157,143,0.15);
  padding:3px 8px;border-radius:4px;
  transition:all var(--tr);
  cursor:default;position:relative;overflow:hidden;
}
.stag::before{
  content:'';position:absolute;inset:0;
  background:linear-gradient(90deg,transparent,rgba(42,157,143,0.25),transparent);
  transform:translateX(-100%);
  transition:transform 0s;
}
.stag:hover{
  background:rgba(42,157,143,0.18);
  color:var(--text);
  border-color:var(--teal);
  transform:translateY(-1px);
  box-shadow:0 2px 8px rgba(42,157,143,0.2);
}
.stag:hover::before{
  transform:translateX(100%);
  transition:transform 0.5s ease;
}
[data-theme="light"] .stag{color:#2E1A14;background:#f0ebe2;border-color:rgba(109,27,40,0.22);font-weight:500;padding:5px 12px}
[data-theme="light"] .stag:hover{background:#6D1B28;color:#FBF9F6;border-color:#6D1B28}

.learning-badge{
  display:inline-flex;align-items:center;gap:8px;
  background:#fff;border:1.5px solid #C5A021;
  color:#9c7e16;font-size:15px;padding:7px 14px;border-radius:20px;
  margin-top:16px;font-weight:500;
}
.learning-bolt{
  color:#0d0d0d;
  font-family:"Helvetica Neue",Arial,sans-serif;
  font-variant-emoji:text;
  -webkit-font-feature-settings:"liga" off;
  font-size:20px;font-weight:700;line-height:1;
  display:inline-block;transform:translateY(1px);
  text-shadow:0 0 1px rgba(13,8,8,0.35);
}

/* ── UX PRINCIPLES ── */
.principles-grid{
  display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));
  gap:12px;margin-bottom:8px;
}
.principle-card{
  background:var(--card-bg);border:0.5px solid var(--card-border);
  border-radius:var(--radius);padding:16px;
  transition:all var(--tr);
  opacity:0;transform:translateY(8px);
}
.principle-card.visible{opacity:1;transform:translateY(0)}
.principle-card:hover{border-color:var(--teal);transform:translateY(-2px)}
.principle-icon{font-size:26px;margin-bottom:8px;display:block}

/* H3, card titles */
h3.principle-title{
  font-family:var(--serif);font-size:17px;font-weight:500;
  color:var(--text);margin-bottom:5px;
}
.principle-desc{font-size:15px;color:var(--text-muted);line-height:1.6}

/* ── FILTER BAR ── */
.filter-bar{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:28px}
.filter-btn{
  font-size:14px;padding:7px 16px;border-radius:20px;
  border:1.5px solid rgba(109,27,40,0.32);
  background:transparent;color:#4a1018;
  cursor:pointer;transition:all var(--tr);font-family:var(--sans);
  min-height:36px;font-weight:500;letter-spacing:0.01em;
}
[data-theme="light"] .filter-btn{border-color:rgba(109,27,40,0.32);color:#4a1018}
.filter-btn:hover,.filter-btn.active{
  background:#C5A021;color:#fff;border-color:#C5A021;
}
.filter-btn:focus{outline:2px solid #C5A021;outline-offset:2px}

/* ── BENTO GRID ── */
.bento{display:grid;grid-template-columns:repeat(12,1fr);gap:var(--gap)}
.card{
  background:var(--card-bg);border:0.5px solid var(--card-border);
  border-radius:var(--radius-lg);padding:20px;
  backdrop-filter:blur(12px);
  transition:all var(--tr);position:relative;overflow:hidden;
  opacity:0;transform:translateY(8px);
}
.card.visible{opacity:1;transform:translateY(0);transition:opacity 0.45s ease,transform 0.45s ease,border-color var(--tr),box-shadow var(--tr)}
.card:hover{border-color:var(--teal);box-shadow:0 6px 24px rgba(42,157,143,0.12);transform:translateY(-3px)}
.card::before{
  content:'';position:absolute;top:0;left:0;right:0;height:1px;
  background:linear-gradient(90deg,transparent,var(--teal),transparent);
  opacity:0;transition:opacity var(--tr);
}
.card:hover::before{opacity:1}
[data-theme="light"] .card{background:rgba(255,255,255,0.95);box-shadow:0 1px 4px rgba(0,0,0,0.06)}

.card-wide{grid-column:span 7}
.card-narrow{grid-column:span 5}
.card-half{grid-column:span 6}
.card-third{grid-column:span 4}

.card-num{font-size:12px;color:var(--text-dim);font-style:italic;margin-bottom:6px}
.card-category{
  font-size:12px;text-transform:uppercase;letter-spacing:0.08em;
  color:var(--teal);font-weight:500;margin-bottom:8px;
}

/* H3, project card titles */
h3.card-title{
  font-family:var(--serif);font-size:21px;font-weight:500;
  color:var(--text);line-height:1.25;margin-bottom:7px;
}
.card-desc{font-size:15px;color:var(--text-muted);line-height:1.7;margin-bottom:12px;font-weight:300}
.tag-row{display:flex;flex-wrap:wrap;gap:4px;margin-bottom:14px}
.tech-tag{
  font-size:12px;font-weight:500;color:#9ad4cb;
  background:rgba(255,255,255,0.04);
  border:1px solid rgba(154,212,203,0.32);
  padding:3px 10px;border-radius:6px;letter-spacing:0.01em;
  transition:background 0.2s,border-color 0.2s,color 0.2s;
}
.tech-tag:hover{background:rgba(42,157,143,0.18);border-color:var(--teal);color:#fff}
.role-tag{
  font-size:12px;font-weight:500;color:var(--gold-accessible);
  background:rgba(255,255,255,0.04);
  border:1px solid rgba(226,200,124,0.4);
  padding:3px 10px;border-radius:6px;letter-spacing:0.01em;
  transition:background 0.2s,border-color 0.2s,color 0.2s;
}
.role-tag:hover{background:rgba(201,168,76,0.2);border-color:var(--gold-accessible);color:#fff}
[data-theme="light"] .tech-tag{
  color:#062320;background:#f5efe2;
  border-color:rgba(10,54,48,0.18);font-weight:500;
}
[data-theme="light"] .tech-tag:hover{background:#062320;color:#f5efe2;border-color:#062320}
[data-theme="light"] .role-tag{
  color:#062320;background:#f0e5cc;
  border-color:rgba(107,79,21,0.32);font-weight:500;
}
[data-theme="light"] .role-tag:hover{background:#6b4f15;color:#fff;border-color:#6b4f15}

.card-links{display:flex;gap:8px;flex-wrap:wrap}

/* ── CARD PREVIEW (live + GitHub tile pair, visually invites click) ── */
.card-preview-row{
  display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:10px;margin:10px 0;
}
@media(max-width:520px){.card-preview-row{grid-template-columns:1fr}}
.card-preview{
  position:relative;
  display:flex;align-items:center;gap:12px;
  min-height:84px;padding:14px 16px;
  border:1.5px solid rgba(42,157,143,0.45);
  border-radius:var(--radius);
  background:linear-gradient(135deg,rgba(42,157,143,0.14),rgba(42,157,143,0.05));
  color:var(--text);text-decoration:none;cursor:pointer;
  transition:all var(--tr);
  overflow:hidden;font-family:inherit;text-align:left;
  box-sizing:border-box;width:100%;
}
.card-preview::before{
  content:"";position:absolute;inset:0;
  background:linear-gradient(110deg,transparent 40%,rgba(255,255,255,0.18) 50%,transparent 60%);
  transform:translateX(-110%);transition:transform 0.55s ease;
  pointer-events:none;
}
.card-preview:hover,.card-preview:focus-visible{
  border-color:var(--teal);border-style:solid;
  background:linear-gradient(135deg,rgba(42,157,143,0.14),rgba(42,157,143,0.05));
  color:var(--text);transform:translateY(-2px);
  box-shadow:0 8px 20px rgba(42,157,143,0.12);
  outline:none;
}
.card-preview:hover::before,.card-preview:focus-visible::before{transform:translateX(110%)}
.card-preview-icon{
  display:inline-flex;align-items:center;justify-content:center;
  width:40px;height:40px;flex-shrink:0;
  border-radius:50%;background:rgba(42,157,143,0.18);
  color:var(--teal);font-size:17px;
  transition:transform var(--tr),background var(--tr),color var(--tr);
}
.card-preview:hover .card-preview-icon,.card-preview:focus-visible .card-preview-icon{
  background:var(--teal);color:#fff;transform:scale(1.08);
}
.card-preview-caption{
  font-size:13px;line-height:1.4;font-weight:500;
  letter-spacing:0.01em;flex:1;
}
.card-preview-arrow{
  flex-shrink:0;font-size:14px;color:var(--teal);font-weight:500;
  transition:transform var(--tr),opacity var(--tr);
  opacity:0.55;
}
.card-preview:hover .card-preview-arrow,.card-preview:focus-visible .card-preview-arrow{
  transform:translate(3px,-3px);opacity:1;
}
[data-brand-open].card-preview{gap:10px;padding:12px 14px}
[data-brand-open].card-preview .card-preview-icon{width:30px;height:30px;font-size:12px}
[data-brand-open].card-preview .card-preview-caption{font-size:12.5px}
[data-theme="light"] .card-preview{
  border-color:rgba(10,54,48,0.22);
  background:linear-gradient(135deg,#f5efe2,rgba(245,239,226,0.4));
  color:#062320;
}
[data-theme="light"] .card-preview:hover,[data-theme="light"] .card-preview:focus-visible{
  border-color:#062320;border-style:solid;
  background:linear-gradient(135deg,#ece4d2,#f5efe2);
  box-shadow:0 8px 20px rgba(10,54,48,0.10);
}
[data-theme="light"] .card-preview-icon{background:rgba(10,54,48,0.12);color:#062320}
[data-theme="light"] .card-preview:hover .card-preview-icon{background:#062320;color:#f5efe2}
[data-theme="light"] .card-preview-arrow{color:#062320}

/* ── LINK BUTTONS, visible in both modes ── */
.link-btn{
  font-size:14px;padding:7px 16px;border-radius:20px;
  text-decoration:none;font-weight:500;
  transition:all var(--tr);display:inline-flex;align-items:center;gap:4px;
  min-height:36px;border:2px solid transparent;
  cursor:pointer;font-family:inherit;line-height:1.2;
}
button.link-btn{background-color:transparent}
button.link-live{background-color:#C5A021}
.link-live{background:#C5A021;color:#fff;border-color:#C5A021}
.link-live:hover,.link-live:focus{background:#9c7e16;border-color:#9c7e16;outline:2px solid #9c7e16;outline-offset:2px}
.link-gh{
  background:transparent;color:#4a1018;
  border-color:rgba(109,27,40,0.42);
}
[data-theme="light"] .link-gh{color:#4a1018;border-color:rgba(109,27,40,0.42)}
.link-gh:hover,.link-gh:focus{border-color:#4a1018;color:#4a1018;background:rgba(109,27,40,0.06);outline:2px solid #4a1018;outline-offset:2px}
[data-theme="light"] .link-gh:hover{border-color:#4a1018;color:#4a1018;background:rgba(109,27,40,0.06)}

.highlight-stat{font-family:var(--serif);font-size:32px;font-weight:500;color:var(--teal);line-height:1;margin-bottom:3px}
.highlight-label{font-size:13px;color:var(--text-dim)}
.stat-note{font-size:12px;color:var(--text-dim);line-height:1.5}

/* ── UX WORK ── */
.ux-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:16px}
.ux-card{
  background:var(--card-bg);border:0.5px solid var(--card-border);
  border-radius:var(--radius-lg);overflow:hidden;
  transition:all var(--tr);opacity:0;transform:translateY(8px);
}
.ux-card.visible{opacity:1;transform:translateY(0)}
.ux-card:hover,.ux-card:focus-within{border-color:var(--card-accent,var(--teal));transform:translateY(-3px);box-shadow:0 0 0 1px var(--card-accent,var(--teal)), 0 10px 32px rgba(42,157,143,0.12)}
[data-theme="light"] .ux-card{background:rgba(255,255,255,0.95)}
.ux-card-img{
  height:140px;display:flex;align-items:center;justify-content:center;
  font-family:var(--serif);font-size:24px;
  color:rgba(42,157,143,0.5);font-style:italic;font-weight:300;
  text-align:center;line-height:1.3;
}
.ux-card-body{padding:16px}

/* H3, UX card titles */
h3.ux-card-title{font-family:var(--serif);font-size:17px;font-weight:500;color:var(--text);margin-bottom:5px}
.ux-card-desc{font-size:14px;color:var(--text-muted);line-height:1.7;margin-bottom:10px}
.method-pills{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:10px}
.method-pill{
  font-size:12px;font-weight:500;color:#9ad4cb;
  background:rgba(255,255,255,0.04);
  border:1px solid rgba(154,212,203,0.28);
  padding:3px 10px;border-radius:6px;letter-spacing:0.01em;
  transition:background 0.2s,border-color 0.2s,color 0.2s;
}
.method-pill:hover{background:rgba(42,157,143,0.18);border-color:var(--teal);color:#fff}
[data-theme="light"] .method-pill{
  background:#f5efe2;color:#062320;
  border-color:rgba(10,54,48,0.18);font-weight:500;
}
[data-theme="light"] .method-pill:hover{background:#062320;color:#f5efe2;border-color:#062320}

/* ── PRINCIPLE "IN PRACTICE" LINE ── */
.principle-practice{
  font-size:13px;color:var(--text-dim);line-height:1.6;
  margin-top:10px;padding-top:8px;
  border-top:0.5px solid rgba(42,157,143,0.12);
  font-weight:300;
}
.principle-practice span{
  color:var(--teal);font-weight:500;
  letter-spacing:0.08em;text-transform:uppercase;
  font-size:12px;display:inline-block;margin-right:6px;
}
[data-theme="light"] .principle-practice{color:var(--text-muted)}

/* ── WIDE UX CARD (spans 3 columns, horizontal layout) ── */
.ux-card-wide{grid-column:span 3;display:grid;grid-template-columns:minmax(0,0.9fr) minmax(0,2.1fr);align-items:stretch}
.ux-card-wide .ux-card-img{height:auto;min-height:100%;font-size:28px}
.ux-card-wide .ux-card-body{padding:20px 24px}
@media(max-width:1100px){.ux-card-wide{grid-column:span 2}}
@media(max-width:780px){.ux-card-wide{grid-column:1 / -1;grid-template-columns:1fr}.ux-card-wide .ux-card-img{min-height:140px}}

/* ── DOUBLE UX CARD (spans 2 columns, horizontal layout) ── */
.ux-card-double{grid-column:span 2;display:grid;grid-template-columns:minmax(0,0.8fr) minmax(0,1.6fr);align-items:stretch}
.ux-card-double .ux-card-img{height:auto;min-height:100%;font-size:22px}
.ux-card-double .ux-card-body{padding:18px 22px}
@media(max-width:780px){.ux-card-double{grid-column:1 / -1;grid-template-columns:1fr}.ux-card-double .ux-card-img{min-height:140px}}

/* ── MLD project divider (between case study and brand toolkit halves) ── */
.mld-project-divider{
  position:relative;margin:6px 20px 0;height:1px;
  background:linear-gradient(90deg,transparent 0%,rgba(42,157,143,0.22) 18%,rgba(42,157,143,0.22) 82%,transparent 100%);
}
.mld-project-divider::after{
  content:"Same project · Brand toolkit ↓";
  position:absolute;top:-10px;left:50%;transform:translateX(-50%);
  background:var(--card-bg);padding:2px 12px;
  font-family:var(--sans);font-size:11px;letter-spacing:0.12em;text-transform:uppercase;
  color:var(--teal);font-weight:500;white-space:nowrap;
}
[data-theme="light"] .mld-project-divider::after{background:rgba(255,255,255,0.95)}

/* ── FEATURE UX CARD (full-width case study) ── */
.ux-card-feature{grid-column:1 / -1}
.ux-feature-grid{
  display:grid;
  grid-template-columns:minmax(0,1.35fr) minmax(0,1fr);
  gap:24px;padding:20px;
}
.ux-feature-media{display:flex;flex-direction:column;gap:12px;min-width:0}
.ux-feature-media video{
  width:100%;display:block;
  border-radius:var(--radius);
  border:0.5px solid var(--card-border);
  background:#000;aspect-ratio:16/10;object-fit:cover;
}
.ux-feature-caption{
  font-size:13px;color:var(--text-dim);
  letter-spacing:0.04em;font-weight:300;font-style:italic;
}
.ux-feature-thumbs{
  display:grid;grid-template-columns:repeat(2,1fr);
  gap:8px;
}
.ux-feature-thumbs img{
  width:100%;aspect-ratio:1/1;object-fit:cover;
  border-radius:8px;border:0.5px solid var(--card-border);
  transition:border-color var(--tr),transform var(--tr);
  background:var(--navy3);
}
.ux-feature-thumbs img:hover,.ux-feature-thumbs img:focus{
  border-color:var(--teal);transform:translateY(-2px);
}

/* ── MLD HERO STAGE (inline flickable carousel on the splash) ── */
.mld-hero{
  position:relative;border-radius:var(--radius);overflow:hidden;
  background:linear-gradient(135deg,#0a3630 0%,#1a6b5e 100%);
  border:0.5px solid var(--card-border);
  aspect-ratio:16/10;
}
[data-theme="light"] .mld-hero{background:linear-gradient(135deg,#ece4d6 0%,#f5efe2 100%)}
.mld-hero-stage{
  position:absolute;inset:0;display:flex;align-items:center;justify-content:center;
  cursor:zoom-in;padding:8px;
}
.mld-hero-stage img,.mld-hero-stage video{
  max-width:100%;max-height:100%;width:auto;height:auto;
  object-fit:contain;display:block;
  border-radius:6px;
}
.mld-hero-stage video{background:#000}
.mld-hero-stage[data-type="video"]{cursor:default}
.mld-hero-arrow{
  position:absolute;top:50%;transform:translateY(-50%);z-index:2;
  width:42px;height:42px;border-radius:50%;
  background:rgba(0,0,0,0.55);border:0.5px solid rgba(255,255,255,0.25);
  color:#fff;font-size:24px;line-height:1;cursor:pointer;
  display:grid;place-items:center;
  transition:background var(--tr),transform var(--tr);
  box-shadow:0 0 0 0 rgba(255,255,255,0.55);
  animation:mldArrowPulse 2.6s ease-in-out infinite;
}
.mld-hero-arrow:hover,.mld-hero-arrow:focus-visible{
  background:var(--teal);outline:none;transform:translateY(-50%) scale(1.08);
  animation:none;box-shadow:0 6px 22px rgba(42,157,143,0.45);
}
.mld-hero-prev{left:10px}
.mld-hero-next{right:10px}
@keyframes mldArrowPulse{
  0%,100%{box-shadow:0 0 0 0 rgba(255,255,255,0.5)}
  60%{box-shadow:0 0 0 8px rgba(255,255,255,0)}
}
.mld-hero-meta{
  position:absolute;left:0;right:0;bottom:0;z-index:2;
  display:flex;align-items:center;justify-content:space-between;
  padding:8px 14px;
  background:linear-gradient(to top,rgba(0,0,0,0.65),transparent);
  pointer-events:none;
}
.mld-hero-counter{
  font-size:13px;color:#fff;font-weight:500;letter-spacing:0.06em;
  background:rgba(0,0,0,0.55);padding:4px 12px;border-radius:20px;
  border:0.5px solid rgba(197,160,33,0.55);
}
.mld-hero-expand{
  position:relative;overflow:hidden;
  pointer-events:auto;
  font-size:13px;font-weight:500;color:#fff;
  background:linear-gradient(135deg,#8a0000,#6D1B28);border:none;
  padding:7px 16px;border-radius:20px;cursor:pointer;
  font-family:inherit;transition:background var(--tr),transform var(--tr),box-shadow var(--tr);
  box-shadow:0 4px 14px rgba(109,27,40,0.4);
}
.mld-hero-expand::before{
  content:"";position:absolute;inset:0;
  background:linear-gradient(110deg,transparent 30%,rgba(255,255,255,0.7) 50%,transparent 70%);
  transform:translateX(-110%);
  animation:mldExpandShimmer 2.2s linear infinite;
  pointer-events:none;
}
@keyframes mldExpandShimmer{
  0%{transform:translateX(-110%)}
  100%{transform:translateX(110%)}
}
.mld-hero-expand:hover,.mld-hero-expand:focus-visible{
  background:linear-gradient(135deg,#6D1B28,#8a0000);
  outline:none;transform:translateY(-1px);
  box-shadow:0 8px 22px rgba(109,27,40,0.55);
}
@media(prefers-reduced-motion:reduce){
  .mld-hero-arrow{animation:none}
  .mld-hero-expand::before{animation:none;display:none}
}

/* ── MLD MOODBOARD + TYPOGRAPHY SUB-CARD ── */
.mld-extras{
  grid-column:1 / -1;padding:24px;
  display:grid;grid-template-columns:minmax(0,1.3fr) minmax(0,1fr);
  gap:24px;align-items:start;
}
.mld-extras-block h3{
  font-family:var(--serif);font-size:21px;line-height:1.25;
  color:var(--text);font-weight:500;margin:0 0 4px;
}
.mld-extras-eyebrow{
  font-size:12px;text-transform:uppercase;letter-spacing:0.12em;
  color:var(--teal);font-weight:500;margin-bottom:6px;
}
.mld-extras-intro{
  font-size:14px;color:var(--text-muted);line-height:1.65;
  font-weight:300;margin-bottom:14px;
}

/* Moodboard 3x3 grid */
.mld-moodboard{
  display:grid;grid-template-columns:repeat(3,1fr);
  gap:8px;
}
.mld-mb-tile{
  position:relative;aspect-ratio:1/1;border-radius:8px;
  perspective:900px;background:transparent;border:none;
}
.mld-mb-flip{
  position:relative;width:100%;height:100%;
  transform-style:preserve-3d;
  transition:transform 0.65s cubic-bezier(0.4,0,0.2,1);
  cursor:pointer;border-radius:8px;
  background:transparent;border:none;padding:0;margin:0;
  font-family:inherit;color:inherit;text-align:left;display:block;
}
.mld-mb-flip.flipped{transform:rotateY(180deg)}
.mld-mb-flip:focus-visible{outline:2px solid var(--teal);outline-offset:3px;border-radius:8px}
.mld-mb-front,.mld-mb-back{
  position:absolute;inset:0;
  backface-visibility:hidden;-webkit-backface-visibility:hidden;
  border-radius:8px;overflow:hidden;
  border:0.5px solid var(--card-border);
}
.mld-mb-front{background:var(--navy3)}
.mld-mb-front img{width:100%;height:100%;object-fit:cover;display:block}
.mld-mb-tile-fit .mld-mb-front{background:#bcdcee}
.mld-mb-tile-fit .mld-mb-front img{object-fit:contain;background:#bcdcee;padding:6px}
.mld-mb-tile-brown .mld-mb-front{background:linear-gradient(135deg,#3d2818 0%,#3d2818 45%,#c9a84c 100%)}
.mld-mb-tile-brown .mld-mb-front img{background:transparent}
.mld-mb-back{
  transform:rotateY(180deg);
  background:linear-gradient(135deg,#0a3630 0%,#1a5c52 100%);
  color:#fff;
  display:flex;flex-direction:column;gap:8px;
  align-items:flex-start;justify-content:center;
  padding:16px;text-align:left;
}
[data-theme="light"] .mld-mb-back{background:linear-gradient(135deg,#1a5c52 0%,#2a9d8f 100%)}
.mld-mb-back-eyebrow{display:none}
.mld-mb-back-text{
  font-size:13px;line-height:1.55;color:#fff;font-weight:300;font-family:var(--sans);
}
.mld-mb-flip-hint{
  position:absolute;right:8px;top:8px;
  width:24px;height:24px;border-radius:50%;
  background:rgba(0,0,0,0.45);color:#fff;
  display:flex;align-items:center;justify-content:center;
  font-size:12px;pointer-events:none;z-index:2;
  transition:opacity 0.3s;
}
.mld-mb-flip.flipped .mld-mb-flip-hint{opacity:0}
.mld-mb-tile-label{
  position:absolute;width:1px;height:1px;
  padding:0;margin:-1px;overflow:hidden;
  clip:rect(0,0,0,0);white-space:nowrap;border:0;
}
@media(max-width:480px){
  .mld-mb-back{padding:10px;gap:4px}
  .mld-mb-back-text{font-size:11.5px;line-height:1.4}
  .mld-mb-back-eyebrow{font-size:9px}
}
@media(prefers-reduced-motion:reduce){.mld-mb-flip{transition:none}}
.mld-mb-tile-empty{
  background:repeating-linear-gradient(
    45deg,
    transparent,transparent 8px,
    rgba(42,157,143,0.08) 8px,rgba(42,157,143,0.08) 16px
  );
  border-style:dashed;border-color:rgba(42,157,143,0.4);
  display:flex;align-items:center;justify-content:center;
  text-align:center;padding:8px;
}
.mld-mb-tile-empty span{
  font-size:11px;color:var(--text-dim);font-style:italic;
  text-transform:uppercase;letter-spacing:0.05em;line-height:1.3;
}

/* Typography panel */
.mld-typo{display:flex;flex-direction:column;gap:14px}
.mld-typo-cat{
  font-size:11px;text-transform:uppercase;letter-spacing:0.1em;
  color:var(--text-dim);font-weight:500;
}
.mld-typo-card{
  background:var(--card-bg);border:0.5px solid var(--card-border);
  border-radius:12px;padding:16px;
  display:flex;flex-direction:column;gap:8px;
}
[data-theme="light"] .mld-typo-card{background:rgba(255,255,255,0.92)}
.mld-typo-row{display:flex;align-items:baseline;gap:14px;flex-wrap:wrap}
.mld-typo-aa{
  font-size:48px;line-height:1;color:var(--teal-dark);
  font-weight:500;letter-spacing:-0.02em;
}
[data-theme="dark"] .mld-typo-aa{color:var(--teal-light)}
.mld-typo-aa-light{font-weight:300;color:var(--teal)}
.mld-typo-name{
  font-size:18px;color:var(--text);font-weight:500;line-height:1.2;
}
.mld-typo-meta{
  font-size:13px;color:var(--text-muted);font-weight:300;
}
.mld-palette{
  display:flex;flex-wrap:wrap;gap:14px;margin-top:10px;
}
.mld-palette-swatch{display:block}
.mld-palette-chip{
  display:block;width:56px;height:56px;border-radius:50%;
  border:0.5px solid var(--card-border);
  box-shadow:0 2px 8px rgba(10,54,48,0.18);
}
.mld-palette-meta{
  position:absolute;width:1px;height:1px;
  padding:0;margin:-1px;overflow:hidden;
  clip:rect(0,0,0,0);white-space:nowrap;border:0;
}
.mld-typo-sample{
  font-size:14px;color:var(--text-muted);
  border-top:0.5px solid var(--card-border);padding-top:10px;
}
.font-asul{font-family:'Asul',Georgia,serif}
.font-roboto{font-family:'Roboto',system-ui,sans-serif}
.font-helvetica{font-family:'Helvetica Neue',Helvetica,Arial,sans-serif}

@media(max-width:820px){
  .mld-extras{grid-template-columns:1fr;padding:18px;gap:18px}
  .mld-typo-aa{font-size:40px}
}

/* ── MLD SLIDE CAROUSEL ── */
.mld-carousel{
  position:relative;display:flex;align-items:center;gap:6px;
  margin-top:4px;
}
.mld-carousel-track{
  display:flex;gap:10px;overflow-x:auto;scroll-behavior:smooth;
  scroll-snap-type:x mandatory;padding:4px 2px;flex:1;
  scrollbar-width:thin;scrollbar-color:var(--teal) transparent;
}
.mld-carousel-track::-webkit-scrollbar{height:6px}
.mld-carousel-track::-webkit-scrollbar-thumb{background:var(--teal);border-radius:3px}
.mld-slide{
  position:relative;flex:0 0 110px;aspect-ratio:1/1;
  background:var(--navy3);border:0.5px solid var(--card-border);
  border-radius:8px;overflow:hidden;cursor:pointer;padding:0;
  scroll-snap-align:start;
  transition:border-color var(--tr),transform var(--tr),box-shadow var(--tr);
}
.mld-slide img{width:100%;height:100%;object-fit:cover;display:block}
.mld-slide:hover,.mld-slide:focus-visible{
  border-color:var(--teal);transform:translateY(-2px);
  box-shadow:0 6px 18px rgba(42,157,143,0.25);outline:none;
}
.mld-slide[aria-current="true"]{
  border-color:var(--teal);border-width:2px;
  box-shadow:0 0 0 2px rgba(42,157,143,0.25);
}
.mld-slide-num{
  position:absolute;top:6px;left:6px;
  background:rgba(10,54,48,0.85);color:#fff;
  font-family:var(--serif);font-size:14px;font-weight:500;
  width:22px;height:22px;border-radius:50%;
  display:grid;place-items:center;line-height:1;
}
.mld-slide-play{
  position:absolute;inset:0;display:grid;place-items:center;
  font-size:32px;color:#fff;text-shadow:0 2px 8px rgba(0,0,0,0.7);
  background:rgba(0,0,0,0.25);transition:background var(--tr);
  pointer-events:none;
}
.mld-slide-video:hover .mld-slide-play{background:rgba(0,0,0,0.1)}
.mld-carousel-nav{
  flex:0 0 auto;width:28px;height:28px;border-radius:50%;
  background:var(--card-bg);border:0.5px solid var(--card-border);
  color:var(--text);font-size:21px;line-height:1;cursor:pointer;
  display:grid;place-items:center;
  transition:background var(--tr),border-color var(--tr),color var(--tr);
}
.mld-carousel-nav:hover{background:var(--teal);border-color:var(--teal);color:#fff}

/* ── MLD MODAL / LIGHTBOX ── */
.mld-modal{
  position:fixed;inset:0;z-index:9999;
  display:grid;place-items:center;padding:20px;
}
.mld-modal[hidden]{display:none}
.mld-modal-backdrop{
  position:absolute;inset:0;background:rgba(8,18,16,0.85);
  backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);
}
.mld-modal-panel{
  position:relative;width:min(1080px,100%);max-height:90vh;
  background:var(--navy2);border:0.5px solid var(--card-border);
  border-radius:var(--radius-lg);overflow:hidden;
  box-shadow:0 24px 60px rgba(0,0,0,0.5);
  display:flex;flex-direction:column;
}
[data-theme="light"] .mld-modal-panel{background:#f5efe2;border-color:rgba(114,47,55,0.22)}
.mld-modal-close{
  position:absolute;top:10px;right:10px;z-index:3;
  width:34px;height:34px;border-radius:50%;
  background:rgba(0,0,0,0.55);border:0.5px solid rgba(255,255,255,0.2);
  color:#fff;font-size:26px;line-height:1;cursor:pointer;
  display:grid;place-items:center;
  transition:background var(--tr);
}
.mld-modal-close:hover{background:#6D1B28}
.mld-modal-arrow{
  position:absolute;top:50%;transform:translateY(-50%);z-index:3;
  width:40px;height:40px;border-radius:50%;
  background:rgba(0,0,0,0.55);border:0.5px solid rgba(255,255,255,0.2);
  color:#fff;font-size:28px;line-height:1;cursor:pointer;
  display:grid;place-items:center;
  transition:background var(--tr);
}
.mld-modal-arrow:hover{background:#6D1B28}
.mld-modal-prev{left:10px}
.mld-modal-next{right:10px}
.mld-modal-grid{
  display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr);
  gap:0;flex:1;min-height:0;
}
.mld-modal-media{
  background:linear-gradient(135deg,#f5efe2,#ece4d6);
  display:flex;align-items:center;justify-content:center;
  min-height:280px;padding:14px;
}
[data-theme="light"] .mld-modal-media{background:linear-gradient(135deg,#f5efe2,#ece4d6)}
.mld-modal-media img,.mld-modal-media video{
  max-width:100%;max-height:84vh;width:auto;height:auto;
  object-fit:contain;display:block;border-radius:6px;
}
.mld-modal-media video{background:#000}
.mld-modal-text{
  padding:32px 32px 28px;overflow-y:auto;
  display:flex;flex-direction:column;gap:14px;
}
.mld-modal-eyebrow{
  font-size:12px;text-transform:uppercase;letter-spacing:0.16em;
  color:#6D1B28;font-weight:600;
}
.mld-modal-num{
  font-size:13px;color:#6b4f3a;font-weight:500;
  letter-spacing:0.05em;margin-top:-4px;
}
.mld-modal-title{
  font-family:var(--serif);font-size:30px;line-height:1.2;
  color:#2d1810;font-weight:500;margin:0;letter-spacing:-0.01em;
}
.mld-modal-body{
  font-size:15px;color:#3d2818;line-height:1.75;font-weight:400;
  flex:1;
}
.mld-modal-body p{margin:0 0 12px}
.mld-modal-body p:last-child{margin-bottom:0}
.mld-modal-body strong{color:#2d1810;font-weight:600}
.mld-modal-body em{color:#6D1B28;font-style:italic}
.mld-modal-body ul{margin:6px 0 12px;padding:0;list-style:none;display:grid;gap:6px}
.mld-modal-body li{
  font-size:14px;color:#3d2818;font-weight:400;line-height:1.5;
  padding-left:18px;position:relative;
}
.mld-modal-body li::before{
  content:"";position:absolute;left:0;top:0.55em;
  width:6px;height:6px;border-radius:50%;background:#6D1B28;
}
.mld-modal-body li::before{
  content:"";position:absolute;left:0;top:9px;width:6px;height:6px;
  border-radius:50%;background:var(--teal);
}
.mld-modal-foot{
  margin-top:16px;padding-top:16px;
  border-top:0.5px solid var(--card-border);
  display:flex;align-items:center;justify-content:space-between;gap:10px;
  flex-wrap:wrap;
}
.mld-modal-cta{
  background:var(--teal);color:#fff;border:none;
  padding:10px 18px;border-radius:24px;cursor:pointer;
  font-size:14px;font-weight:500;font-family:inherit;
  transition:background var(--tr);
}
.mld-modal-cta:hover,.mld-modal-cta:focus-visible{background:var(--teal-mid);outline:none}
.mld-modal-cta-ghost{
  background:transparent;color:var(--teal);border:1px solid var(--teal);
}
.mld-modal-cta-ghost:hover,.mld-modal-cta-ghost:focus-visible{background:var(--teal);color:#fff}
@media(max-width:820px){
  .mld-modal-panel{max-height:95vh}
  .mld-modal-grid{grid-template-columns:1fr;grid-template-rows:auto 1fr}
  .mld-modal-media{max-height:42vh}
  .mld-modal-media img,.mld-modal-media video{max-height:42vh}
  .mld-modal-text{padding:18px 18px 20px}
  .mld-modal-arrow{width:34px;height:34px;font-size:24px}
}
.ux-feature-body{display:flex;flex-direction:column;gap:14px;min-width:0}
.ux-feature-body h3.ux-card-title{font-size:26px;line-height:1.25;margin-bottom:0}
.ux-feature-label{
  font-size:12px;text-transform:uppercase;letter-spacing:0.1em;
  color:var(--teal);font-weight:500;margin-bottom:6px;
}
.ux-feature-text{font-size:15px;color:var(--text-muted);line-height:1.7;font-weight:300}
.ux-feature-text strong{color:var(--text);font-weight:500}
.ux-feature-stats{
  display:flex;gap:18px;flex-wrap:wrap;
  padding:12px 0;
  border-top:0.5px solid rgba(42,157,143,0.15);
  border-bottom:0.5px solid rgba(42,157,143,0.15);
}
.ux-feature-stats > div{flex:1;min-width:80px}
.ux-feature-stat-num{
  font-family:var(--serif);font-size:26px;
  color:var(--teal);font-weight:500;line-height:1;
}
.ux-feature-stat-label{
  font-size:12px;color:var(--text-dim);
  text-transform:uppercase;letter-spacing:0.08em;margin-top:3px;
}
@media(max-width:820px){
  .ux-feature-grid{grid-template-columns:1fr;gap:18px;padding:16px}
  .ux-feature-body h3.ux-card-title{font-size:22px}
}

/* ── SKILLS DEEP DIVE ── */
.skills-full-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:12px}
.skill-block{
  background:var(--card-bg);border:0.5px solid var(--card-border);
  border-radius:var(--radius);padding:14px;
  transition:all var(--tr);opacity:0;transform:translateY(14px);
}
.skill-block.visible{opacity:1;transform:translateY(0)}
.skill-block:hover{border-color:var(--teal)}
[data-theme="light"] .skill-block{background:rgba(255,255,255,0.95)}
.skill-block-title{
  font-size:12px;text-transform:uppercase;letter-spacing:0.1em;
  color:var(--teal);font-weight:500;margin-bottom:8px;
}
.skill-block-tags{display:flex;flex-wrap:wrap;gap:8px}
.sk{
  font-size:13px;font-weight:500;color:#2E1A14;
  background:#f0ebe2;
  border:1px solid rgba(109,27,40,0.22);
  padding:6px 14px;border-radius:6px;letter-spacing:0.01em;
  transition:all var(--tr);cursor:default;
  position:relative;overflow:hidden;
}
.sk::before{
  content:'';position:absolute;inset:0;
  background:linear-gradient(90deg,transparent,rgba(197,160,33,0.35),transparent);
  transform:translateX(-100%);
}
.sk:hover{
  background:#6D1B28;color:#FBF9F6;
  border-color:#6D1B28;transform:translateY(-1px);
  box-shadow:0 2px 8px rgba(109,27,40,0.22);
}
.sk:hover::before{transform:translateX(100%);transition:transform 0.45s ease}
[data-theme="light"] .sk{color:#2E1A14;background:#f0ebe2;border-color:rgba(109,27,40,0.22)}
[data-theme="light"] .sk:hover{background:#6D1B28;color:#FBF9F6;border-color:#6D1B28}

/* Currently Learning, cream + tangerine accent, WCAG-AA both themes */
.skill-block-learning{
  border-color:rgba(237,124,28,0.5)!important;
  background:#fdf6ec!important;
}
.skill-block-learning .skill-block-title{color:#a04e0a}
[data-theme="light"] .skill-block-learning{background:#fdf6ec!important}
[data-theme="light"] .skill-block-learning .skill-block-title{color:#a04e0a}
.sk-learning{
  color:#a04e0a!important;
  background:#fdf6ec!important;
  border:1px solid rgba(237,124,28,0.55)!important;
  font-weight:500;
}
[data-theme="light"] .sk-learning{
  color:#a04e0a!important;
  background:#fdf6ec!important;
  border-color:rgba(160,78,10,0.42)!important;
}
.sk-learning:hover{
  background:#ed7c1c!important;color:#fff!important;
  border-color:#ed7c1c!important;
}
[data-theme="light"] .sk-learning:hover{
  background:#a04e0a!important;color:#fff!important;border-color:#a04e0a!important;
}

/* ── CONTACT ── */
.contact-inner{max-width:660px;margin:0 auto;text-align:center}

/* H2, contact heading */
h2.contact-line{
  font-family:var(--serif);
  font-size:clamp(22px,3.5vw,38px);
  font-weight:300;color:var(--text);
  line-height:1.35;margin-bottom:32px;
}
h2.contact-line em{color:var(--teal);font-style:italic}
.contact-links{display:flex;gap:12px;justify-content:center;flex-wrap:wrap;margin-bottom:20px}
.contact-card{
  background:var(--card-bg);border:1.5px solid var(--card-border);
  border-radius:var(--radius);padding:13px 18px;
  text-decoration:none;color:var(--text-muted);font-size:15px;
  transition:all var(--tr);display:flex;align-items:center;gap:7px;
  backdrop-filter:blur(10px);font-weight:500;min-height:44px;
}
[data-theme="light"] .contact-card{
  background:rgba(255,255,255,0.95);color:var(--teal-dark);
  border-color:var(--teal-mid);
}
.contact-card:hover,.contact-card:focus{
  border-color:var(--teal);color:var(--teal);
  transform:translateY(-2px);box-shadow:0 4px 16px rgba(42,157,143,0.15);
  outline:2px solid var(--teal);outline-offset:2px;
}
.contact-card svg{width:16px;height:16px;flex-shrink:0}

/* ── FOOTER ── */
footer{
  padding:24px 6%;border-top:0.5px solid rgba(42,157,143,0.15);
  display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:8px;
}
.footer-name{font-family:var(--serif);color:var(--teal);font-size:16px}
.footer-note{font-size:13px;color:var(--text-dim)}

/* ── BACK TO TOP ── */
.btt{
  position:fixed;bottom:24px;right:24px;width:42px;height:42px;
  border-radius:50%;background:var(--teal);color:#fff;
  border:none;cursor:pointer;font-size:21px;
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 4px 16px rgba(42,157,143,0.4);
  transition:all var(--tr);opacity:0;pointer-events:none;z-index:50;
}
.btt.show{opacity:1;pointer-events:all}
.btt:hover{transform:translateY(-2px);background:var(--teal-mid)}
.btt:focus{outline:2px solid var(--teal);outline-offset:3px}

/* ── RESPONSIVE ── */
@media(max-width:920px){
  .about-grid{grid-template-columns:1fr}
  .card-wide,.card-narrow,.card-half,.card-third{grid-column:span 12}
  .nav-links a:not(.theme-btn){display:none}
  h1.hero-name{font-size:clamp(40px,10vw,68px)}
}
@media(max-width:600px){
  :root{--section-pad:48px 5%}
  nav[role="navigation"]{padding:8px 14px;gap:12px}
  .nav-logo{font-size:14px}
  .hero{padding:76px 5% 44px}
  .hero-stats{gap:18px}
  .bento{grid-template-columns:1fr}
  .card-wide,.card-narrow,.card-half,.card-third{grid-column:auto}
  .ux-feature-grid{padding:14px;gap:14px}
  .ux-feature-stats{gap:12px}
  .ux-feature-stats > div{min-width:70px}
  .method-pills{gap:6px}
  .mld-slide{flex:0 0 92px}
}
@media(max-width:420px){
  :root{--section-pad:40px 4%}
  body{font-size:17px}
  .hero{padding:70px 4% 36px}
  h1.hero-name{font-size:clamp(36px,11vw,56px)}
  .nav-links{gap:12px}
  .ux-feature-grid{padding:12px;gap:12px}
  .ux-feature-stats{flex-direction:column;align-items:flex-start;gap:8px}
  .ux-feature-stats > div{width:100%}
  .mld-slide{flex:0 0 84px}
  .mld-modal{padding:8px}
  .mld-modal-text{padding:14px 14px 16px}
  .mld-modal-title{font-size:20px}
  .card-links{gap:6px}
  .link-btn{padding:6px 12px}
}

/* Focus visible for keyboard users */
:focus-visible{outline:2px solid var(--teal);outline-offset:3px}
a:focus-visible,button:focus-visible{outline:2px solid var(--teal);outline-offset:3px}


/* ── RECOMMENDATIONS ── */
.recs-carousel{position:relative}
.recs-track{
  display:flex;gap:18px;
  overflow-x:auto;scroll-snap-type:x mandatory;
  scroll-behavior:smooth;
  padding:8px 6% 24px;margin:0 -6%;
  scrollbar-width:none;-ms-overflow-style:none;
}
.recs-track::-webkit-scrollbar{display:none}
.recs-track .rec-card{
  flex:0 0 min(460px,86vw);scroll-snap-align:center;
}
.recs-nav{
  display:flex;gap:10px;justify-content:center;align-items:center;
  margin-top:6px;
}
.recs-nav-btn{
  width:42px;height:42px;border-radius:50%;
  background:transparent;border:1px solid var(--card-border);
  color:var(--text);font-size:18px;cursor:pointer;
  display:inline-flex;align-items:center;justify-content:center;
  transition:all 0.25s;font-family:inherit;line-height:1;
}
.recs-nav-btn:hover,.recs-nav-btn:focus-visible{
  border-color:var(--teal);color:var(--teal);outline:none;
}
[data-theme="light"] .recs-nav-btn{color:var(--teal-dark)}
.recs-dots{display:inline-flex;gap:8px;margin:0 8px}
.recs-dot{
  width:9px;height:9px;border-radius:50%;
  background:rgba(109,27,40,0.28);
  border:none;cursor:pointer;padding:0;
  transition:all 0.25s;
}
.recs-dot.active{background:#6D1B28;transform:scale(1.35)}
.recs-dot:hover,.recs-dot:focus-visible{background:#6D1B28;outline:none}
.rec-card{
  position:relative;
  background:var(--card-bg);border:0.5px solid var(--card-border);
  border-radius:var(--radius-lg);padding:26px 26px 22px;
  display:flex;flex-direction:column;gap:16px;
  backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);
  transition:border-color var(--tr),transform var(--tr),box-shadow var(--tr);
}
[data-theme="light"] .rec-card{background:rgba(255,255,255,0.92)}
.rec-card:hover{
  border-color:var(--teal);transform:translateY(-3px);
  box-shadow:0 10px 28px rgba(42,157,143,0.12);
}
.rec-card.is-current{
  border-color:#6D1B28;
  box-shadow:0 0 0 1.5px #6D1B28, 0 12px 32px rgba(109,27,40,0.18);
}
.rec-card::before{
  content:'\201C';position:absolute;top:6px;right:18px;
  font-family:var(--serif);font-size:88px;line-height:1;
  color:rgba(42,157,143,0.18);font-weight:500;
  pointer-events:none;
}
.rec-head{display:flex;align-items:flex-start;gap:14px;position:relative;z-index:1}
.rec-photo{
  width:56px;height:56px;border-radius:50%;
  border:2px solid var(--teal);
  object-fit:cover;flex-shrink:0;
  background:var(--navy3);
}
.rec-meta{min-width:0;flex:1}
.rec-meta-name{
  font-family:var(--serif);font-size:18px;
  color:var(--text);font-weight:500;line-height:1.2;
  display:inline-flex;align-items:center;gap:8px;flex-wrap:wrap;
}
.rec-li{
  display:inline-grid;place-items:center;
  width:18px;height:18px;border-radius:3px;
  background:#0a66c2;color:#fff;
  font-size:10px;font-weight:700;line-height:1;
  font-family:var(--sans);font-style:italic;
}
.rec-meta-title{
  font-size:13px;color:var(--text-muted);
  margin-top:3px;line-height:1.45;font-weight:400;
}
.rec-meta-context{
  font-size:12px;color:var(--text-dim);
  margin-top:5px;line-height:1.4;
}
.rec-quote{
  font-size:15px;color:var(--text);line-height:1.7;
  font-weight:300;
  position:relative;z-index:1;
}
.rec-quote p{margin:0 0 10px}
.rec-quote p:last-child{margin-bottom:0}
.rec-quote em{color:var(--text);font-style:italic}
.rec-quote-placeholder{
  font-style:italic;color:var(--text-dim);font-weight:300;
  padding:14px;border:1px dashed rgba(42,157,143,0.35);
  border-radius:8px;background:rgba(42,157,143,0.04);
}
@media(max-width:600px){
  .rec-card{padding:22px 20px 18px}
  .rec-card::before{font-size:64px;top:0;right:14px}
}

/* ── I GO BY (page-end role badges) ── */
.go-by{
  text-align:center;padding:48px 6% 28px;
  border-top:0.5px solid var(--card-border);
  margin-top:40px;
}
@media(max-width:600px){
  .go-by{padding:20px 5% 18px;margin-top:8px}
  .go-by-eyebrow{margin-bottom:12px}
  #contact{padding-bottom:24px}
}
.go-by-eyebrow{
  font-size:12px;text-transform:uppercase;letter-spacing:0.2em;
  color:var(--text-dim);font-weight:500;margin-bottom:20px;
}
.go-by-badges{
  display:inline-flex;flex-wrap:wrap;gap:10px;justify-content:center;
}
.go-by-badge{
  display:inline-flex;align-items:center;gap:9px;
  padding:10px 22px;border-radius:30px;
  background:linear-gradient(135deg,rgba(42,157,143,0.22) 0%,rgba(42,157,143,0.08) 100%);
  border:1px solid rgba(42,157,143,0.5);
  position:relative;overflow:hidden;isolation:isolate;
  font-family:var(--serif);font-size:17px;color:var(--text);font-weight:500;
  transition:border-color var(--tr),transform var(--tr),box-shadow var(--tr);
}
.go-by-badge::before{
  content:"";position:absolute;inset:0;border-radius:30px;
  background:linear-gradient(105deg,transparent 35%,rgba(255,112,88,0.55) 50%,transparent 65%);
  pointer-events:none;z-index:-1;
  transform:translateX(-110%);
  transition:transform 0.9s cubic-bezier(0.4,0,0.2,1);
}
.go-by-badge:hover::before,.go-by-badge:focus-within::before{transform:translateX(110%)}
.go-by-badge:hover{
  border-color:#ff7058;transform:translateY(-2px);
  box-shadow:0 6px 22px rgba(255,112,88,0.34);
}
[data-theme="light"] .go-by-badge{
  background:linear-gradient(135deg,#ffffff 0%,#ece4d6 100%);
  border-color:rgba(10,54,48,0.28);color:var(--teal-dark);
}
[data-theme="light"] .go-by-badge::before{
  background:linear-gradient(105deg,transparent 35%,rgba(255,112,88,0.45) 50%,transparent 65%);
}
.go-by-badge-icon{
  display:inline-grid;place-items:center;
  width:26px;height:26px;border-radius:7px;
  background:var(--teal);color:#fff;
  font-size:13px;line-height:1;font-weight:500;font-style:normal;
}
[data-theme="light"] .go-by-badge-icon{background:var(--teal);color:#fff}
@keyframes goByShimmer{
  0%{transform:translateX(-110%)}
  60%,100%{transform:translateX(110%)}
}
@media(prefers-reduced-motion:no-preference){
  .go-by-badge:nth-child(1)::before{animation:goByShimmer 6s ease-in-out 0.5s infinite}
  .go-by-badge:nth-child(2)::before{animation:goByShimmer 6s ease-in-out 1.4s infinite}
  .go-by-badge:nth-child(3)::before{animation:goByShimmer 6s ease-in-out 2.3s infinite}
  .go-by-badge:nth-child(4)::before{animation:goByShimmer 6s ease-in-out 3.2s infinite}
  .go-by-badge:nth-child(5)::before{animation:goByShimmer 6s ease-in-out 4.1s infinite}
  .go-by-badge:nth-child(6)::before{animation:goByShimmer 6s ease-in-out 5s infinite}
  .go-by-badge:hover::before,.go-by-badge:focus-within::before{animation:none;transform:translateX(110%)}
}

/* Reduced motion, respect user preference */
@media (prefers-reduced-motion: reduce){
  *,*::before,*::after{
    animation-duration:0.001ms !important;
    animation-iteration-count:1 !important;
    transition-duration:0.001ms !important;
    scroll-behavior:auto !important;
  }
  .principle-card,.card,.ux-card,.animate-card{opacity:1 !important;transform:none !important}
  .mesh{animation:none !important}
}

/* ──────────────────────────────────────────────────────────────
   DARK MODE OVERRIDES — restore the green/teal aesthetic on
   elements that hardcoded light-mode Heritage colours.
   The default :root is dark, but several CTAs/text colours were
   hardcoded with the light Heritage palette during the build.
   These selectors put dark mode back to its original look so
   stats, buttons and tags match the floating nav.
   ────────────────────────────────────────────────────────────── */

:root:not([data-theme="light"]) .btn-primary{
  background:var(--teal);border-color:var(--teal);color:#fff;
}
:root:not([data-theme="light"]) .btn-primary:hover,
:root:not([data-theme="light"]) .btn-primary:focus{
  background:var(--teal-mid);border-color:var(--teal-mid);
  box-shadow:0 8px 24px rgba(42,157,143,0.35);
  outline:2px solid var(--teal-mid);
}
:root:not([data-theme="light"]) .btn-ghost{
  color:var(--teal);border-color:var(--teal);
}
:root:not([data-theme="light"]) .btn-ghost:hover,
:root:not([data-theme="light"]) .btn-ghost:focus{
  background:var(--teal);color:#fff;border-color:var(--teal);
  outline:2px solid var(--teal);
}
:root:not([data-theme="light"]) .filter-btn{
  border-color:rgba(42,157,143,0.45);color:var(--text-muted);
}
:root:not([data-theme="light"]) .filter-btn:hover,
:root:not([data-theme="light"]) .filter-btn.active{
  background:var(--teal);color:#fff;border-color:var(--teal);
}
:root:not([data-theme="light"]) .filter-btn:focus{outline-color:var(--teal)}
:root:not([data-theme="light"]) .link-live,
:root:not([data-theme="light"]) button.link-live{
  background:var(--teal);border-color:var(--teal);color:#fff;
}
:root:not([data-theme="light"]) .link-live:hover,
:root:not([data-theme="light"]) .link-live:focus{
  background:var(--teal-mid);border-color:var(--teal-mid);
  outline-color:var(--teal-mid);
}
:root:not([data-theme="light"]) .link-gh{
  color:var(--text-muted);border-color:rgba(42,157,143,0.45);
  background:transparent;
}
:root:not([data-theme="light"]) .link-gh:hover,
:root:not([data-theme="light"]) .link-gh:focus{
  border-color:var(--teal);color:var(--teal);
  background:rgba(42,157,143,0.08);outline-color:var(--teal);
}

/* Hero stats + credentials in dark mode */
:root:not([data-theme="light"]) .stat-num{color:var(--teal)}
:root:not([data-theme="light"]) .stat-label{color:var(--text-muted)}
:root:not([data-theme="light"]) .hero-stats{border-top-color:rgba(42,157,143,0.22)}

/* Skill tags in dark mode */
:root:not([data-theme="light"]) .sk{
  color:var(--text-muted);background:rgba(42,157,143,0.08);
  border-color:rgba(42,157,143,0.18);font-weight:500;
}
:root:not([data-theme="light"]) .sk:hover{
  background:rgba(42,157,143,0.22);color:var(--text);
  border-color:var(--teal);
}

/* Tech / role / method tags in dark mode */
:root:not([data-theme="light"]) .tech-tag{
  color:#9ad4cb;background:rgba(255,255,255,0.04);
  border-color:rgba(154,212,203,0.32);
}
:root:not([data-theme="light"]) .tech-tag:hover{
  background:rgba(42,157,143,0.22);border-color:var(--teal);color:#fff;
}
:root:not([data-theme="light"]) .role-tag{
  color:var(--gold-accessible);background:rgba(255,255,255,0.04);
  border-color:rgba(226,200,124,0.4);
}
:root:not([data-theme="light"]) .method-pill{
  color:#9ad4cb;background:rgba(255,255,255,0.04);
  border-color:rgba(154,212,203,0.28);
}

/* Section eyebrow + key results in dark mode */
:root:not([data-theme="light"]) .section-eyebrow{color:var(--teal)}
:root:not([data-theme="light"]) .section-eyebrow::before{background:var(--teal)}

/* NDA / co-founder callouts in dark mode (avoid bright cream box) */
:root:not([data-theme="light"]) .ux-card-body .stat-note[style*="background:#f5efe2"]{
  background:rgba(42,157,143,0.06)!important;
  color:var(--text)!important;
  border-left-color:var(--teal)!important;
}

/* ── BRAND GUIDE MODAL ── */
.brand-modal{position:fixed;inset:0;z-index:9999;display:flex;align-items:center;justify-content:center;padding:20px;animation:brandFade 0.25s ease}
.brand-modal[hidden]{display:none}
@keyframes brandFade{from{opacity:0}to{opacity:1}}
.brand-modal-backdrop{position:absolute;inset:0;background:rgba(13,8,8,0.82);backdrop-filter:blur(8px);cursor:pointer}
.brand-modal-panel{position:relative;background:#FBF9F6;border-radius:20px;max-width:960px;width:100%;max-height:92vh;display:flex;flex-direction:column;box-shadow:0 30px 80px rgba(0,0,0,0.45);border:1px solid rgba(197,160,33,0.4);overflow:hidden}
.brand-modal-close{position:absolute;top:16px;right:16px;z-index:10;background:rgba(13,13,13,0.7);color:#fff;border:none;width:38px;height:38px;border-radius:50%;font-size:22px;cursor:pointer;display:grid;place-items:center;transition:all var(--tr);font-family:inherit}
.brand-modal-close:hover,.brand-modal-close:focus-visible{background:#bc0000;outline:none;transform:scale(1.08)}
.brand-modal-content{overflow-y:auto;flex:1}
@media(max-width:640px){
  .brand-modal{padding:0}
  .brand-modal-panel{border-radius:0;max-height:100vh;height:100vh}
}
