/* =========================================================
   jamespschuler.com — Landing
   ========================================================= */
:root {
  --bg:#0e0c0a; --bg-2:#15120f; --bg-3:#1d1915;
  --fg:#f2ece1; --fg-2:#b4aa9b; --fg-3:#7a7265;
  --line:#2a251f; --line-2:#3a342c;
  --accent:#e7b86a; --accent-2:#d98a5a;
  --serif:"Fraunces","Times New Roman",serif;
  --sans:"Inter",system-ui,-apple-system,sans-serif;
  --mono:"JetBrains Mono",ui-monospace,Menlo,monospace;
  --maxw:1360px;
  --pad-x:clamp(22px,4.2vw,56px);
}
[data-theme="bone"]{--bg:#f1ebdd;--bg-2:#e8e1d0;--bg-3:#ddd4bf;--fg:#171411;--fg-2:#564f44;--fg-3:#8a8274;--line:#d5cbb4;--line-2:#c2b89e;}
[data-theme="ink"] {--bg:#09090d;--bg-2:#111119;--bg-3:#191925;--fg:#ececf4;--fg-2:#9a9aac;--fg-3:#5f5f72;--line:#23232f;--line-2:#32323f;}
[data-theme="mono"]{--bg:#fafaf7;--bg-2:#f0efe9;--bg-3:#e6e5dd;--fg:#0a0a0a;--fg-2:#4a4a48;--fg-3:#878580;--line:#d8d6cd;--line-2:#bfbcb0;--accent:#0a0a0a;--accent-2:#4a4a48;}
[data-accent="amber"] {--accent:#e7b86a;--accent-2:#d98a5a;}
[data-accent="ember"] {--accent:#ff6f3c;--accent-2:#ffc14a;}
[data-accent="violet"]{--accent:#b8a4ff;--accent-2:#6fa7ff;}
[data-accent="mint"]  {--accent:#9fe3c3;--accent-2:#6cc8e3;}

*{box-sizing:border-box;margin:0;padding:0;}
html,body{background:var(--bg);color:var(--fg);font-family:var(--sans);-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;}
body{overflow-x:hidden;transition:background .4s ease,color .4s ease;line-height:1.5;}
a{color:inherit;text-decoration:none;}
img{max-width:100%;display:block;}
button{font:inherit;color:inherit;background:none;border:0;cursor:pointer;}
::selection{background:var(--accent);color:var(--bg);}

.mono{font-family:var(--mono);font-size:13px;letter-spacing:0.14em;text-transform:uppercase;color:var(--fg-3);}
.serif{font-family:var(--serif);font-weight:300;letter-spacing:-0.025em;}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 var(--pad-x);}

/* grain */
.grain{position:fixed;inset:0;pointer-events:none;z-index:70;opacity:.06;mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='200' height='200'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0.9 0'/></filter><rect width='100%' height='100%' filter='url(%23n)'/></svg>");
}
body[data-grain="false"] .grain{display:none;}

/* sans hero override */
body[data-serif-hero="false"] .hero-name{font-family:var(--sans);font-weight:300;letter-spacing:-0.06em;}
body[data-serif-hero="false"] .hero-name em{font-style:normal;}

/* ================== NAV ================== */
.nav{position:fixed;top:0;left:0;right:0;z-index:60;display:flex;align-items:center;justify-content:space-between;padding:20px var(--pad-x);
  background:color-mix(in oklab,var(--bg) 70%,transparent);backdrop-filter:blur(16px) saturate(140%);-webkit-backdrop-filter:blur(16px) saturate(140%);
  border-bottom:1px solid transparent;transition:border-color .3s,padding .3s,background .3s;}
.nav.scrolled{border-bottom-color:var(--line);padding:12px var(--pad-x);}
.nav-mark{font-family:var(--serif);font-size:19px;font-weight:400;letter-spacing:-0.02em;display:flex;align-items:center;gap:12px;}
.nav-mark i{width:7px;height:7px;border-radius:50%;background:var(--accent);box-shadow:0 0 12px var(--accent);animation:pulse 2.2s infinite;}
.nav-links{display:flex;gap:28px;}
.nav-links a{font-family:var(--mono);font-size:12px;letter-spacing:0.16em;text-transform:uppercase;color:var(--fg-2);padding:6px 0;position:relative;transition:color .2s;}
.nav-links a::after{content:"";position:absolute;left:0;bottom:0;width:100%;height:1px;background:currentColor;transform:scaleX(0);transform-origin:right;transition:transform .35s cubic-bezier(.7,0,.3,1);}
.nav-links a:hover{color:var(--fg);}
.nav-links a:hover::after{transform:scaleX(1);transform-origin:left;}
.nav-cta{display:inline-flex;align-items:center;gap:10px;padding:10px 18px;border:1px solid var(--line-2);border-radius:999px;font-family:var(--mono);font-size:12px;letter-spacing:0.16em;text-transform:uppercase;transition:all .2s;}
.nav-cta i{width:6px;height:6px;border-radius:50%;background:var(--accent);animation:pulse 1.8s infinite;}
.nav-cta:hover{background:var(--fg);color:var(--bg);border-color:var(--fg);}
.nav-cta:hover i{background:var(--bg);}
@keyframes pulse{0%,100%{opacity:1;}50%{opacity:.35;}}
@media(max-width:780px){.nav-links{display:none;}}

/* ================== HERO ================== */
.hero{position:relative;min-height:100vh;padding:120px var(--pad-x) 72px;display:grid;grid-template-rows:auto 1fr auto;gap:48px;border-bottom:1px solid var(--line);overflow:hidden;}
.hero::before{content:"";position:absolute;inset:0;background:radial-gradient(ellipse 800px 400px at 50% 100%,color-mix(in oklab,var(--accent) 12%,transparent),transparent 70%);pointer-events:none;}
.hero>*{position:relative;}
.hero-top{display:grid;grid-template-columns:1fr auto 1fr;gap:32px;align-items:center;font-family:var(--mono);font-size:13px;letter-spacing:0.14em;text-transform:uppercase;color:var(--fg-3);}
.hero-top .tag-right{text-align:right;}
.hero-top .live{color:var(--accent);text-align:center;}
.hero-top .live::before{content:"";display:inline-block;width:6px;height:6px;border-radius:50%;background:var(--accent);margin-right:8px;vertical-align:middle;animation:pulse 1.8s infinite;box-shadow:0 0 10px var(--accent);}

.hero-name{font-family:var(--serif);font-weight:300;font-size:clamp(64px,13.5vw,220px);line-height:0.86;letter-spacing:-0.05em;text-align:center;}
.hero-name em,.hero-name .amp,.hero-name .italic{font-style:italic;color:var(--accent);font-weight:300;}
.hero-name .line{display:block;overflow:hidden;padding:0.08em 0 0.22em;}
.hero-name .word{display:inline-block;transform:translateY(110%);opacity:0;animation:rise 1s cubic-bezier(.2,.7,.2,1) forwards;padding-right:0.02em;}
.hero-name .line:nth-child(1) .word:nth-child(1){animation-delay:.1s;}
.hero-name .line:nth-child(1) .word:nth-child(2){animation-delay:.2s;}
.hero-name .line:nth-child(1) .word:nth-child(3){animation-delay:.3s;}
.hero-name .line:nth-child(2) .word:nth-child(1){animation-delay:.4s;}
.hero-name .line:nth-child(2) .word:nth-child(2){animation-delay:.5s;}
.hero-name .line:nth-child(2) .word:nth-child(3){animation-delay:.6s;}
.hero-name .line:nth-child(2) .word:nth-child(4){animation-delay:.7s;}
@keyframes rise{to{transform:translateY(0);opacity:1;}}

.hero-bottom{display:grid;grid-template-columns:1.4fr repeat(3,1fr);gap:40px;align-items:end;padding-top:24px;border-top:1px solid var(--line);}
.hero-blurb{font-family:var(--serif);font-weight:300;font-style:italic;font-size:clamp(17px,1.5vw,20px);line-height:1.5;color:var(--fg-2);max-width:46ch;}
.hero-stat .stat-num{font-family:var(--serif);font-weight:300;font-size:clamp(32px,3.5vw,52px);line-height:1.1;letter-spacing:-0.03em;margin-top:8px;}
.hero-stat .stat-num small{font-size:.5em;color:var(--fg-3);margin-left:4px;}
@media(max-width:900px){.hero-bottom{grid-template-columns:1fr 1fr;}.hero-blurb{grid-column:1/-1;}}

/* ================== MARQUEE ================== */
.marquee{padding:28px 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line);overflow:hidden;background:var(--bg-2);}
.marquee-track{display:flex;gap:56px;animation:slide 44s linear infinite;white-space:nowrap;align-items:center;}
.m-item{font-family:var(--serif);font-size:32px;font-weight:300;letter-spacing:-0.02em;color:var(--fg-2);font-style:italic;}
.m-sep{color:var(--accent);font-size:14px;}
@keyframes slide{from{transform:translateX(0);}to{transform:translateX(-50%);}}

/* ================== SECTION ================== */
.section{padding:120px 0;}
.section + .section{border-top:1px solid var(--line);}
.section-head{display:grid;grid-template-columns:1fr 2fr;gap:40px;align-items:end;margin-bottom:72px;}
.section-head .eyebrow{display:inline-flex;align-items:center;gap:14px;font-family:var(--mono);font-size:13px;letter-spacing:0.18em;text-transform:uppercase;color:var(--fg-3);}
.eyebrow .num{color:var(--accent);}
.eyebrow .bar{width:32px;height:1px;background:var(--line-2);display:inline-block;}
.section-title{font-family:var(--serif);font-weight:300;font-size:clamp(44px,6vw,88px);line-height:1;letter-spacing:-0.04em;max-width:16ch;text-align:right;margin-left:auto;}
.section-title em{font-style:italic;color:var(--accent);font-weight:300;}
.section-sub{margin-top:20px;color:var(--fg-2);max-width:52ch;font-size:16px;line-height:1.6;}
@media(max-width:900px){.section-head{grid-template-columns:1fr;gap:16px;}}

/* ================== ABOUT ================== */
.section-about .about-grid{display:grid;grid-template-columns:1.1fr 1fr;gap:80px;align-items:start;}
.about-lede{position:sticky;top:120px;align-self:start;font-family:var(--serif);font-weight:300;font-size:clamp(26px,2.8vw,40px);line-height:1.28;letter-spacing:-0.025em;padding-left:28px;border-left:3px solid var(--accent);}
.about-lede em{font-style:italic;color:var(--accent);}
.about-body{color:var(--fg-2);font-size:16px;line-height:1.8;max-width:56ch;}
.about-body p + p{margin-top:1.1em;}
.about-body strong{color:var(--fg);font-weight:500;}
@media(max-width:900px){.section-about .about-grid{grid-template-columns:1fr;gap:40px;}}

/* ================== COMPANIES ================== */
.companies{border-top:1px solid var(--line);}
.company{display:grid;grid-template-columns:60px 1fr 2fr 140px;gap:32px;align-items:start;padding:44px 0;border-bottom:1px solid var(--line);position:relative;transition:padding .35s cubic-bezier(.2,.8,.2,1),background .3s;}
.company::before{content:"";position:absolute;inset:0;background:linear-gradient(90deg,color-mix(in oklab,var(--accent) 7%,transparent),transparent 60%);opacity:0;transition:opacity .35s;pointer-events:none;}
.company:hover{padding-left:16px;}
.company:hover::before{opacity:1;}
.company:hover .c-name{color:var(--accent);}
.company:hover .c-link{background:var(--fg);color:var(--bg);border-color:var(--fg);}
.c-idx{font-family:var(--mono);font-size:12px;letter-spacing:0.14em;color:var(--fg-3);padding-top:10px;}
.c-meta{padding-top:10px;}
.c-role{font-family:var(--mono);font-size:14px;letter-spacing:0.14em;color:var(--fg);text-transform:uppercase;white-space:nowrap;}
.c-years{font-family:var(--mono);font-size:14px;letter-spacing:0.14em;color:var(--fg-3);text-transform:uppercase;margin-top:8px;}
.c-body{}
.c-name{font-family:var(--serif);font-weight:300;font-size:clamp(34px,4vw,60px);line-height:1;letter-spacing:-0.035em;transition:color .3s;}
.c-desc{color:var(--fg-2);font-size:15px;line-height:1.6;margin-top:14px;max-width:52ch;}
.c-tags{display:flex;gap:8px;margin-top:18px;flex-wrap:wrap;}
.c-tags span{font-family:var(--mono);font-size:12px;letter-spacing:0.14em;text-transform:uppercase;color:var(--fg-3);border:1px solid var(--line-2);border-radius:99px;padding:5px 11px;}
.c-link{align-self:start;display:inline-flex;align-items:center;gap:10px;padding:11px 18px;border:1px solid var(--line-2);border-radius:99px;font-family:var(--mono);font-size:12px;letter-spacing:0.14em;text-transform:uppercase;transition:all .25s;white-space:nowrap;}
.c-link svg{transition:transform .25s;}
.company:hover .c-link svg{transform:translate(3px,-3px);}
@media(max-width:900px){.company{grid-template-columns:40px 1fr;gap:20px;}.c-meta,.c-link{grid-column:2;}.c-body{grid-column:1/-1;margin-top:8px;}}

/* ===== AWARDS MOBILE (own section, hidden on desktop) ===== */
.awards-mobile{display:none;}
@media(max-width:1024px){
  .awards-timeline{display:none !important;}
  .awards-mobile{display:block;list-style:none;margin:0;padding:0;border-top:1px solid var(--line);}
  .am-row{display:grid;grid-template-columns:64px 1fr;gap:36px;align-items:center;padding:14px 0;border-bottom:1px solid var(--line);}
  .am-row:last-child{border-bottom:none;padding-bottom:14px;}
  .am-tag{display:none;}
  .am-year{font-family:var(--serif);font-style:italic;font-weight:300;font-size:28px;line-height:1;color:var(--fg);letter-spacing:-0.02em;}
  .am-body h3{font-family:var(--serif);font-weight:300;font-size:18px;line-height:1.2;margin:0 0 4px;letter-spacing:-0.01em;}
  .am-org{color:var(--fg-2);font-size:13px;line-height:1.3;}
  .am-tag{font-family:var(--mono);font-size:10px;letter-spacing:0.14em;text-transform:uppercase;color:var(--fg-3);border:1px solid var(--line-2);border-radius:99px;padding:4px 9px;white-space:nowrap;}
  /* tighten awards section vertical rhythm on mobile */
  #awards.section{padding:64px 0;}
  #awards .section-head{margin-bottom:32px;}
}
@media(max-width:480px){
  .am-row{grid-template-columns:56px 1fr;gap:28px;padding:12px 0;}
  .am-row:last-child{padding-bottom:12px;}
}

/* ================== AWARDS ================== */
.awards-timeline{list-style:none;display:grid;grid-template-columns:repeat(5,1fr);gap:88px;position:relative;padding-top:64px;padding-bottom:8px;}
.at-rail{position:absolute;left:0;right:0;top:78px;height:2px;background:linear-gradient(90deg,var(--line),var(--line-2),var(--line));border-radius:2px;}
.award{display:flex;flex-direction:column;align-items:center;gap:14px;padding-top:36px;position:relative;text-align:center;transition:transform .3s;}
.award:hover{transform:translateY(-3px);}
.award:hover .a-name{color:var(--accent);}
.a-dot{position:absolute;top:6px;left:50%;width:18px;height:18px;border-radius:50%;background:var(--accent);border:2px solid var(--accent);transition:transform .3s,box-shadow .3s;z-index:2;transform:translateX(-50%);}
.award:hover .a-dot{transform:translateX(-50%) scale(1.2);box-shadow:0 0 0 6px color-mix(in oklab,var(--accent) 18%,transparent);}
.a-year{font-family:var(--serif);font-weight:300;font-size:clamp(32px,3vw,46px);line-height:1;letter-spacing:-0.03em;color:var(--fg);font-style:italic;}
.a-name{font-family:var(--serif);font-weight:300;font-size:clamp(20px,1.6vw,24px);line-height:1.15;letter-spacing:-0.02em;transition:color .3s;}
.a-org{color:var(--fg-2);font-size:13.5px;margin-top:4px;line-height:1.4;}
.a-tag{font-family:var(--mono);font-size:11px;letter-spacing:0.16em;text-transform:uppercase;color:var(--fg-3);border:1px solid var(--line-2);border-radius:99px;padding:4px 10px;margin-top:auto;align-self:center;}self:flex-start;}
@media(max-width:1024px){.awards-timeline{grid-template-columns:1fr !important;gap:0 !important;padding:0 !important;}.awards-timeline .at-rail{left:9px !important;right:auto !important;top:12px !important;bottom:12px !important;width:2px !important;height:auto !important;background:linear-gradient(180deg,var(--line),var(--line-2),var(--line)) !important;border-radius:2px;}.awards-timeline .award{padding:24px 0 24px 40px !important;text-align:left !important;align-items:flex-start !important;}.awards-timeline .a-dot{top:30px !important;left:1px !important;transform:none !important;}.awards-timeline .award:hover .a-dot{transform:scale(1.2) !important;}}
@media(max-width:720px){.award{grid-template-columns:80px 1fr;}.a-tag{grid-column:2;justify-self:start;margin-top:4px;}}

/* ================== PROJECTS ================== */
.projects{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;max-width:1180px;margin:0 auto;}
/* ---- Carousel ---- */
.carousel{position:relative;}
.carousel-controls{position:absolute;top:-72px;right:0;display:flex;gap:10px;z-index:2;}
.c-arrow{width:48px;height:48px;border-radius:50%;border:1px solid var(--line-2);color:var(--fg);font-size:18px;display:grid;place-items:center;transition:all .25s;background:var(--bg);}
.c-arrow:hover{background:var(--fg);color:var(--bg);border-color:var(--fg);}
.carousel-track{display:grid;grid-auto-flow:column;grid-auto-columns:minmax(420px,42%);gap:24px;overflow-x:auto;scroll-snap-type:x mandatory;scroll-behavior:smooth;padding-bottom:24px;scrollbar-width:none;}
.carousel-track::-webkit-scrollbar{display:none;}
.carousel-track .project{scroll-snap-align:start;display:flex;flex-direction:column;}
.carousel-progress{height:2px;background:var(--line);position:relative;border-radius:2px;overflow:hidden;}
.carousel-progress span{position:absolute;left:0;top:0;height:100%;width:30%;background:var(--accent);transition:left .3s,width .3s;border-radius:2px;}
.p-placeholder{background:linear-gradient(135deg,var(--bg-3),var(--bg-2));display:grid;place-items:center;color:var(--fg-3);}
.p-placeholder svg{width:55%;height:auto;opacity:.7;}
@media(max-width:780px){.carousel-track{grid-auto-columns:85%;}.carousel-controls{position:static;justify-content:flex-end;margin-bottom:16px;}}
.project{display:flex;flex-direction:column;background:var(--bg-2);border:1px solid var(--line);border-radius:var(--radius,14px);overflow:hidden;transition:transform .4s cubic-bezier(.2,.8,.2,1),border-color .3s,box-shadow .3s;position:relative;}
.project:hover{transform:translateY(-4px);border-color:var(--line-2);box-shadow:0 20px 60px -24px color-mix(in oklab,var(--accent) 30%,transparent);}
.project:hover .p-name{color:var(--accent);}
.p-visual{aspect-ratio:16/9;background:linear-gradient(180deg,var(--bg-3),var(--bg-2));display:flex;align-items:center;justify-content:center;color:var(--fg-2);border-bottom:1px solid var(--line);position:relative;overflow:hidden;}
.p-visual svg{width:70%;height:70%;opacity:.8;}
.p-visual::after{content:"";position:absolute;inset:0;background:radial-gradient(ellipse at 50% 120%,color-mix(in oklab,var(--accent) 14%,transparent),transparent 60%);pointer-events:none;}
.p-body{padding:28px;display:flex;flex-direction:column;gap:12px;}
.p-num{font-family:var(--mono);font-size:12px;letter-spacing:0.14em;color:var(--fg-3);}
.p-name{font-family:var(--serif);font-weight:300;font-size:clamp(24px,2.4vw,34px);line-height:1.1;letter-spacing:-0.025em;transition:color .3s;}
.p-desc{color:var(--fg-2);font-size:14.5px;line-height:1.6;}
.p-url{margin-top:auto;font-family:var(--mono);font-size:12px;letter-spacing:0.14em;text-transform:uppercase;color:var(--fg-3);padding-top:14px;}
@media(max-width:1100px){.projects{grid-template-columns:repeat(2,1fr);}}
@media(max-width:700px){.projects{grid-template-columns:1fr;}}

/* ================== CONTACT ================== */
.section-contact{position:relative;overflow:hidden;}
.section-contact::before{content:"";position:absolute;inset:0;background:radial-gradient(ellipse 900px 500px at 50% 0%,color-mix(in oklab,var(--accent) 10%,transparent),transparent 70%);pointer-events:none;}
.contact-inner{position:relative;}
.contact-eyebrow{padding-bottom:40px;margin-bottom:60px;}
.contact-eyebrow .eyebrow{display:inline-flex;align-items:center;gap:14px;font-family:var(--mono);font-size:13px;letter-spacing:0.18em;text-transform:uppercase;color:var(--fg-3);}
.contact-title{font-family:var(--serif);font-weight:300;font-size:clamp(56px,9vw,148px);line-height:0.94;letter-spacing:-0.045em;margin-bottom:72px;}
.contact-title span{display:block;}
.contact-title em{font-style:italic;color:var(--accent);}
.contact-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;}
.contact-card{position:relative;overflow:hidden;display:grid;grid-template-rows:auto 1fr auto;gap:28px;padding:32px 32px 28px;border:1px solid var(--line);border-radius:14px;background:var(--bg-2);min-height:200px;transition:transform .35s,border-color .35s,background .35s;}
.contact-card::before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:var(--accent);opacity:.85;}
.contact-card:hover{transform:translateY(-4px);border-color:var(--accent);background:var(--bg-3);}
.contact-card:hover .cc-arrow{opacity:1;transform:translateX(6px);color:var(--accent);}
.contact-card:hover .cc-label{color:var(--fg-3);}
.cc-label{color:var(--fg-3);}
.cc-value{font-family:var(--serif);font-weight:300;font-size:clamp(20px,1.7vw,24px);letter-spacing:-0.02em;line-height:1.1;}
.cc-arrow{font-size:24px;opacity:.5;transition:transform .3s,opacity .3s;}
.contact-card:hover .cc-arrow{opacity:1;transform:translateX(6px);}
@media(max-width:900px){.contact-grid{grid-template-columns:repeat(2,1fr);}}

/* ================== FOOTER ================== */
.foot{padding:32px 0;border-top:1px solid var(--line);background:var(--bg-2);}
.foot-inner{display:flex;justify-content:space-between;align-items:center;gap:16px;flex-wrap:wrap;}
.foot-mark{display:flex;gap:18px;align-items:center;}
.foot-mark .serif{font-size:16px;}
.foot-meta{display:flex;gap:24px;}

/* ================== TWEAKS PANEL ================== */
.tweaks{position:fixed;top:80px;right:24px;z-index:90;width:280px;background:var(--bg-2);border:1px solid var(--line-2);border-radius:14px;backdrop-filter:blur(12px);box-shadow:0 24px 60px -24px rgba(0,0,0,.6);transform:translateX(calc(100% + 40px));transition:transform .4s cubic-bezier(.2,.8,.2,1);opacity:0;pointer-events:none;}
.tweaks.open{transform:translateX(0);opacity:1;pointer-events:auto;}
.tweaks-head{display:flex;justify-content:space-between;align-items:center;padding:14px 18px;border-bottom:1px solid var(--line);}
.tweaks-close{width:24px;height:24px;border-radius:50%;display:grid;place-items:center;color:var(--fg-3);font-size:14px;transition:background .2s,color .2s;}
.tweaks-close:hover{background:var(--bg-3);color:var(--fg);}
.tweaks-body{padding:18px;display:flex;flex-direction:column;gap:18px;}
.tweak-group label{display:block;margin-bottom:8px;color:var(--fg-3);}
.tweak-opts{display:flex;flex-wrap:wrap;gap:6px;}
.tweak-opts button{font-family:var(--mono);font-size:12px;letter-spacing:0.14em;text-transform:uppercase;padding:7px 11px;border:1px solid var(--line-2);border-radius:99px;color:var(--fg-2);display:inline-flex;align-items:center;gap:7px;transition:all .2s;}
.tweak-opts button i{width:10px;height:10px;border-radius:50%;}
.tweak-opts button.active{background:var(--fg);color:var(--bg);border-color:var(--fg);}
.tweak-opts button:hover:not(.active){background:var(--bg-3);color:var(--fg);}

/* ===== Hero portrait ===== */
.hero-stage{display:grid;grid-template-columns:1fr auto;gap:48px;align-items:end;}
.hero-stage .hero-name{text-align:left;margin:0;}
.hero-portrait{width:clamp(180px,18vw,280px);aspect-ratio:3/4;border-radius:8px;overflow:hidden;border:1px solid var(--line-2);position:relative;background:var(--bg-2);box-shadow:0 30px 60px -30px rgba(0,0,0,.5);}
.hero-portrait img{width:100%;height:100%;object-fit:cover;filter:saturate(.85) contrast(1.02);}
.hero-portrait figcaption{position:absolute;left:12px;bottom:10px;color:#fff;text-shadow:0 1px 4px rgba(0,0,0,.6);font-size:9.5px;letter-spacing:0.16em;}
@media(max-width:900px){.hero-stage{grid-template-columns:1fr;}.hero-portrait{justify-self:start;width:200px;}}

/* ===== Marquee logos ===== */
.marquee{padding:32px 0;}
.marquee-label{text-align:center;color:var(--fg-3);margin-bottom:18px;}
.marquee-track{align-items:center;gap:80px;}
.m-logo{flex:0 0 auto;height:38px;display:flex;align-items:center;}
.m-logo:has(img[alt="Forbes"]){height:78px;transform:translateY(-6px);}
.m-logo:has(img[alt="Thiel Fellowship"]){height:52px;}
.m-logo:has(img[alt="Techstars"]),.m-logo:has(img[alt="Boost VC"]){height:28px;}
.m-logo img{height:100%;width:auto;object-fit:contain;opacity:.65;filter:brightness(0) invert(1);transition:opacity .2s;}
[data-theme="bone"] .m-logo img,[data-theme="mono"] .m-logo img{filter:brightness(0);opacity:.55;}
.m-logo:hover img{opacity:1;}

/* ===== About mosaic ===== */
.about-mosaic{margin-top:80px;display:grid;grid-template-columns:1.6fr 1fr 1fr;gap:16px;align-items:stretch;}
.about-mosaic figure{position:relative;border-radius:12px;overflow:hidden;border:1px solid var(--line);background:var(--bg-2);}
.about-mosaic .am-1{aspect-ratio:16/10;}
.about-mosaic .am-2{aspect-ratio:4/5;}
.about-mosaic .am-3{aspect-ratio:4/5;display:flex;align-items:center;justify-content:center;padding:40px;background:var(--bg-3);}
.about-mosaic img{width:100%;height:100%;object-fit:cover;}
.about-mosaic .sig-img{width:80%;height:auto;object-fit:contain;filter:invert(1) brightness(1.1);opacity:.85;}
[data-theme="bone"] .about-mosaic .sig-img,[data-theme="mono"] .about-mosaic .sig-img{filter:none;}
.about-mosaic figcaption{position:absolute;left:16px;bottom:14px;color:#fff;font-family:var(--mono);font-size:12px;letter-spacing:0.16em;text-transform:uppercase;text-shadow:0 1px 4px rgba(0,0,0,.6);}
@media(max-width:900px){.about-mosaic{grid-template-columns:1fr 1fr;}.about-mosaic .am-1{grid-column:span 2;}}

/* ===== Company thumbs ===== */
.company{grid-template-columns:50px 1fr 240px 1.6fr 110px;}
.c-idx{display:none;}
.company{grid-template-columns:180px 240px 1fr 80px;gap:20px;column-gap:20px;}
.c-meta{grid-column:1;text-align:left;padding-right:0;}
.c-thumb{grid-column:2;grid-row:1;width:240px;height:170px;border-radius:10px;overflow:hidden;border:1px solid var(--line);background:var(--bg-2);margin-left:0;margin-right:24px;}
.c-body{padding-left:0;padding-right:0;}
.c-body{grid-column:3;}
.c-link{grid-column:4;}
.c-thumb img{width:100%;height:100%;object-fit:cover;transition:transform .5s ease;}
.company:hover .c-thumb img{transform:scale(1.06);}
@media(max-width:900px){.company{grid-template-columns:40px 1fr;}.c-idx,.c-meta,.c-thumb,.c-body,.c-link{grid-column:auto;grid-row:auto;}.c-thumb{grid-column:1/-1;width:100%;height:220px;}}

/* ===== Project images replace SVG visuals ===== */
.p-visual{padding:0;}
.p-visual img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .6s cubic-bezier(.2,.8,.2,1);}
.project:hover .p-visual img{transform:scale(1.04);}

/* ===== AI METHODOLOGY ===== */
.section-ai{position:relative;background:var(--bg-2);}
.section-ai::before{content:"";position:absolute;inset:0;background:radial-gradient(ellipse 600px 300px at 80% 20%,color-mix(in oklab,var(--accent) 8%,transparent),transparent 60%);pointer-events:none;}
.section-ai > .wrap{position:relative;}
.ai-split{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:start;margin:48px 0 80px;}
.section-ai .section-head{grid-template-columns:1fr 2fr;align-items:end;}
.section-ai .section-head .eyebrow{grid-column:1;}
.section-ai .section-head .section-title{grid-column:2;}
@media(max-width:900px){.section-ai .section-head{grid-template-columns:1fr;}.section-ai .section-head .eyebrow,.section-ai .section-head .section-title,.section-ai .section-head .section-sub{grid-column:1;grid-row:auto;}}
.ai-pull{font-family:var(--serif);font-weight:300;font-size:clamp(28px,3vw,42px);line-height:1.2;letter-spacing:-0.025em;margin:0;padding-left:24px;border-left:2px solid var(--accent);position:sticky;top:120px;}(--accent);}
.ai-pull em{font-style:italic;color:var(--accent);}
.ai-intro{display:flex;flex-direction:column;gap:18px;color:var(--fg-2);font-size:16px;line-height:1.75;}
.ai-intro p + p{margin-top:0;}
.ai-intro strong{color:var(--fg);font-weight:500;}
@media(max-width:780px){.ai-split{grid-template-columns:1fr;gap:32px;}.ai-pull{position:static;}}

.ai-stack{border-top:1px solid var(--line);padding-top:32px;display:grid;grid-template-columns:repeat(3,1fr);gap:20px;}
.ai-stack-head{color:var(--fg-3);margin-bottom:24px;grid-column:1/-1;}
.ai-card{display:flex;flex-direction:column;gap:14px;padding:32px;border:1px solid var(--line);border-radius:14px;background:var(--bg-3);align-items:flex-start;transition:transform .35s,border-color .35s,background .35s;position:relative;overflow:hidden;}
.ai-card::before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:var(--accent);opacity:.85;}
.ai-card:hover{transform:translateY(-4px);border-color:var(--accent);background:var(--bg-2);}
.ai-card:hover{transform:translateY(-3px);border-color:var(--line-2);}
.ai-card-head{display:flex;align-items:center;gap:16px;justify-content:space-between;width:100%;}
.ai-card-num{font-family:var(--serif);font-weight:300;font-size:clamp(40px,4vw,56px);letter-spacing:-0.03em;color:var(--fg);line-height:1;}
.ai-card-tag{color:var(--bg);background:var(--fg);padding:5px 11px;border-radius:99px;font-family:var(--mono);font-size:12px;letter-spacing:0.16em;text-transform:uppercase;}
.ai-card-title{font-family:var(--serif);font-weight:300;font-size:clamp(22px,2.2vw,30px);line-height:1.15;letter-spacing:-0.025em;margin-bottom:14px;}
.ai-card-body{display:flex;flex-direction:column;flex:1;width:100%;}
.ai-card-desc{color:var(--fg-2);font-size:14.5px;line-height:1.6;margin:0 0 20px;}
.ai-stat{display:flex;flex-direction:column;align-items:flex-start;gap:8px;margin-top:auto;padding-top:36px;border-top:1px solid var(--line);width:100%;}
.ai-stat-num{font-family:var(--serif);font-weight:300;font-size:clamp(48px,5vw,68px);letter-spacing:-0.04em;color:var(--fg);line-height:1;}
.ai-stat-label{font-family:var(--mono);font-size:12px;letter-spacing:0.14em;color:var(--fg-2);text-transform:uppercase;line-height:1.5;}
@media(max-width:900px){.ai-stack{grid-template-columns:1fr;}}

.ai-coda{position:relative;overflow:hidden;margin-top:80px;padding:56px;border:1px solid var(--line);border-radius:14px;background:var(--bg-3);display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center;transition:transform .35s,border-color .35s,background .35s;}
.ai-coda:hover{transform:translateY(-4px);border-color:var(--accent);background:var(--bg-2);}
.ai-coda::before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:var(--accent);opacity:.85;}
.ai-coda-quote{font-size:clamp(28px,2.8vw,40px);line-height:1.2;letter-spacing:-0.025em;}
.ai-coda-body p{color:var(--fg-2);font-size:15px;line-height:1.7;}
.ai-cta{display:inline-flex;align-items:center;gap:14px;margin-top:24px;padding:16px 26px;border-radius:99px;background:var(--fg);color:var(--bg);font-family:var(--mono);font-size:13px;font-weight:600;letter-spacing:0.12em;text-transform:uppercase;transition:transform .25s,background .25s;box-shadow:0 8px 24px -8px color-mix(in oklab,var(--fg) 50%,transparent);}
.ai-cta:hover{transform:translateY(-2px);background:var(--accent);color:var(--bg);}
@media(max-width:780px){.ai-coda{grid-template-columns:1fr;padding:32px;}}

/* ===== LIFE / MORE THAN TECH ===== */
.life-grid{display:grid;grid-template-columns:repeat(12,1fr);gap:18px;align-items:stretch;}
.life-card{position:relative;border:1px solid var(--line);border-radius:14px;overflow:hidden;background:var(--bg-2);transition:transform .4s cubic-bezier(.2,.8,.2,1);}
.life-card:hover{transform:translateY(-4px);}
.life-1{grid-column:span 7;aspect-ratio:16/10;}
.life-2{grid-column:span 5;}
.life-3{grid-column:span 5;}
.life-4{grid-column:span 7;aspect-ratio:16/10;}
.life-card img{width:100%;height:100%;object-fit:cover;transition:transform .8s cubic-bezier(.2,.8,.2,1);}
.life-card:hover img{transform:scale(1.05);}
.life-card figcaption{position:absolute;inset:auto 0 0 0;padding:24px 28px 22px;color:#fff;background:linear-gradient(180deg,transparent 0%,rgba(0,0,0,.0) 30%,rgba(0,0,0,.78) 100%);}
.life-card figcaption .mono{color:rgba(255,255,255,.65);}
.life-card figcaption h3{font-family:var(--serif);font-weight:300;font-size:clamp(22px,2.2vw,32px);line-height:1.1;letter-spacing:-0.025em;margin:6px 0 8px;}
.life-card figcaption p{font-size:13.5px;/*ok*/line-height:1.55;color:rgba(255,255,255,.82);max-width:54ch;}
.life-1 figcaption p,.life-4 figcaption p{max-width:78ch;}
@media(max-width:780px){.life-1,.life-2,.life-3,.life-4{grid-column:span 12;aspect-ratio:16/10;}}

/* ===== Work marquee (bottom of side projects) ===== */
.work-marquee{margin-top:80px;padding-top:0;}
.work-marquee-head{display:flex;align-items:center;gap:14px;margin-bottom:24px;color:var(--fg-3);}
.work-marquee-head .wm-bar{flex:1;height:1px;background:var(--line-2);}
.wm-hint{color:var(--fg-3);}
.work-marquee{position:relative;overflow:hidden;}
.work-marquee::before,.work-marquee::after{content:"";position:absolute;top:80px;bottom:0;width:120px;z-index:2;pointer-events:none;}
.work-marquee::before{left:0;background:linear-gradient(90deg,var(--bg) 0%,transparent 100%);}
.work-marquee::after{right:0;background:linear-gradient(270deg,var(--bg) 0%,transparent 100%);}
.work-marquee-track{display:flex;gap:24px;animation:wmslide 140s linear infinite;width:max-content;will-change:transform;}
.work-marquee:hover .work-marquee-track{animation-play-state:paused;}
.wm-item{flex:0 0 auto;height:280px;width:auto;border-radius:14px;overflow:hidden;border:1px solid var(--line);background:var(--bg-2);position:relative;}
.wm-item img{height:100%;width:auto;display:block;filter:saturate(.95);transition:transform .8s cubic-bezier(.2,.8,.2,1);}
.wm-item:hover img{transform:scale(1.04);}
.wm-item figcaption{position:absolute;left:14px;bottom:14px;padding:6px 10px;border-radius:99px;background:rgba(0,0,0,.55);backdrop-filter:blur(8px);color:#fff;font-size:11px;letter-spacing:0.14em;}
@keyframes wmslide{from{transform:translateX(0);}to{transform:translateX(-50%);}}
@media(max-width:780px){.wm-item{height:200px;}}
.foot-sig{height:38px;width:auto;opacity:.85;filter:invert(1) brightness(1.1);}
[data-theme="bone"] .foot-sig,[data-theme="mono"] .foot-sig{filter:none;opacity:.85;}

/* ================== TABLET (≤1024px) ================== */
@media(max-width:1024px){
  :root{--pad-x:clamp(20px,3.6vw,40px);}
  .section{padding:88px 0;}
  .hero{padding:104px var(--pad-x) 56px;gap:36px;min-height:auto;}
  .hero-name{font-size:clamp(56px,11vw,128px);}
  .hero-stage{grid-template-columns:1fr auto;gap:32px;}
  .hero-portrait{width:clamp(160px,22vw,220px);}
  .hero-bottom{grid-template-columns:1fr 1fr 1fr;gap:28px;}
  .hero-blurb{grid-column:1/-1;}
  .section-head{grid-template-columns:1fr;gap:18px;margin-bottom:56px;}
  .section-title{text-align:left;margin-left:0;max-width:none;font-size:clamp(40px,7vw,72px);}
  .section-sub{max-width:64ch;}
  .about-grid{grid-template-columns:1fr 1fr;gap:32px;}
  .about-lede{position:static;top:auto;}
  .about-mosaic{margin-top:56px;}
  .company{grid-template-columns:200px 1fr 80px;gap:24px;}
  .c-meta{grid-column:1;grid-row:1;}
  .c-thumb{grid-column:1;grid-row:2;width:200px;height:140px;margin-right:0;margin-top:12px;}
  .c-body{grid-column:2;grid-row:1/3;}
  .c-link{grid-column:3;grid-row:1;}
  .projects{grid-template-columns:repeat(2,1fr);gap:20px;}
  .ai-split{grid-template-columns:1fr;gap:32px;}
  .ai-pull{position:static;}
  .ai-stack{grid-template-columns:repeat(2,1fr);}
  .ai-coda{padding:40px;gap:32px;grid-template-columns:1fr;}
  .contact-grid{grid-template-columns:repeat(2,1fr);}
  .life-1,.life-4{grid-column:span 12;aspect-ratio:16/9;}
  .life-2,.life-3{grid-column:span 6;}
  .marquee-track{gap:56px;}
  .m-logo{height:32px;}
  .m-logo:has(img[alt="Forbes"]){height:62px;}
  .m-logo:has(img[alt="Thiel Fellowship"]){height:42px;}
  .wm-item{height:220px;}
  .foot-mark{flex:1;justify-content:space-between;}
  .foot-meta{flex:1;justify-content:center;text-align:center;}
}

/* ================== MOBILE (≤640px) ================== */
@media(max-width:640px){
  :root{--pad-x:20px;}
  .grain{opacity:.04;}
  .nav{padding:14px var(--pad-x);}
  .nav-mark{font-size:16px;}
  .nav-cta{padding:8px 13px;font-size:11px;letter-spacing:0.12em;}
  .section{padding:64px 0;}

  .hero{padding:96px var(--pad-x) 48px;gap:28px;}
  .hero-top{grid-template-columns:1fr;gap:6px;text-align:left;font-size:11px;}
  .hero-top .live,.hero-top .tag-right{text-align:left;}
  .hero-stage{grid-template-columns:1fr;gap:24px;}
  .hero-portrait{width:140px;order:-1;}
  .hero-name{font-size:clamp(48px,15vw,72px);line-height:0.92;letter-spacing:-0.04em;}
  .hero-name .line{padding:0.04em 0 0.16em;}
  .hero-bottom{grid-template-columns:1fr;gap:20px;padding-top:20px;}
  .hero-blurb{font-size:16px;}
  .hero-stat .stat-num{font-size:28px;}

  .marquee{padding:18px 0;}
  .marquee-label{font-size:10px;margin-bottom:10px;}
  .marquee-track{gap:40px;}
  .m-logo{height:22px;}
  .m-logo:has(img[alt="Forbes"]){height:42px;transform:translateY(-3px);}
  .m-logo:has(img[alt="Thiel Fellowship"]){height:30px;}
  .m-logo:has(img[alt="Techstars"]),.m-logo:has(img[alt="Boost VC"]){height:18px;}

  .section-head{margin-bottom:36px;gap:12px;}
  .section-title{font-size:clamp(34px,9vw,52px);letter-spacing:-0.035em;}
  .section-sub{font-size:15px;}

  .about-grid{grid-template-columns:1fr;gap:24px;}
  .about-lede{position:static;top:auto;}
  .about-body{font-size:15px;line-height:1.7;}
  .about-mosaic{margin-top:36px;grid-template-columns:1fr;gap:12px;}
  .about-mosaic .am-1,.about-mosaic .am-2,.about-mosaic .am-3{grid-column:1;}
  .about-mosaic .am-3{aspect-ratio:16/9;padding:24px;}

  .company{grid-template-columns:1fr 100px;gap:14px;padding:28px 0;}
  .company:hover{padding-left:0;}
  .c-meta{grid-column:1;grid-row:1;}
  .c-thumb{grid-column:1/-1;grid-row:2;width:100%;height:200px;margin:8px 0 0 0;}
  .c-body{grid-column:1/-1;grid-row:3;margin-top:4px;}
  .c-name{font-size:24px;}
  .c-link{grid-column:2;grid-row:1;padding:8px 12px;font-size:10px;}

  .awards-timeline{grid-template-columns:1fr;}
  .award{padding:20px 0 20px 36px;gap:8px;}
  .a-name{font-size:18px;}
  .a-tag{font-size:10px;padding:3px 8px;}

  .projects{grid-template-columns:1fr;gap:16px;}
  .carousel-controls{position:static;justify-content:flex-end;margin-bottom:12px;}

  .ai-split{grid-template-columns:1fr;gap:24px;margin:32px 0 56px;}
  .ai-pull{font-size:24px;padding-left:16px;position:static;}
  .ai-intro{font-size:15px;line-height:1.7;}
  .ai-stack{grid-template-columns:1fr;padding-top:24px;}
  .ai-card{padding:24px;}
  .ai-card-num{font-size:36px;}
  .ai-stat-num{font-size:44px;}
  .ai-coda{margin-top:48px;padding:28px;grid-template-columns:1fr;gap:20px;}
  .ai-coda-quote{font-size:24px;}
  .ai-cta{padding:14px 20px;font-size:12px;width:100%;justify-content:center;}

  .life-grid{gap:12px;}
  .life-1,.life-2,.life-3,.life-4{grid-column:span 12;aspect-ratio:4/3;}
  .life-card figcaption{padding:18px 20px 16px;}
  .life-card figcaption h3{font-size:20px;}
  .life-card figcaption p{font-size:13px;}

  .contact-grid{grid-template-columns:1fr;gap:12px;}
  .contact-card{padding:24px;}

  .work-marquee{margin-top:56px;}
  .work-marquee::before,.work-marquee::after{width:60px;top:60px;}
  .wm-item{height:160px;border-radius:10px;}

  footer .wrap{flex-direction:column;align-items:stretch;gap:14px;}
  .foot-mark{flex:1;justify-content:space-between;width:100%;}
  .foot-meta{justify-content:center;text-align:center;width:100%;}
  .foot-sig{height:30px;}
}
