:root{
  --paper:#F2E1C5; --paper-2:#FAF0DA; --card:#FCF4E5;
  --ink:#2A1B0F; --ink-soft:#705A3E; --ink-faint:#A78C63;
  --rust:#BC4F2A; --rust-deep:#8E3417;
  --cocoa:#3A2516; --cocoa-2:#2A1A0E;
  --gold:#B0822A; --gold-soft:#DBB35A;
  --clay:#C56A33;
  --line:rgba(42,27,15,.14);
  --line-strong:rgba(42,27,15,.27);
  --shadow:18px 22px 0 rgba(42,27,15,.09);
  --r:18px;
  --serif:"Newsreader",Georgia,serif;
  --display:"Fraunces",Georgia,serif;
  --mono:"JetBrains Mono",ui-monospace,monospace;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0; background:var(--paper); color:var(--ink);
  font-family:var(--serif); font-size:18px; line-height:1.6;
  -webkit-font-smoothing:antialiased;
  background-image:
    radial-gradient(1200px 600px at 85% -10%, rgba(219,179,90,.24), transparent 60%),
    radial-gradient(900px 500px at -5% 8%, rgba(188,79,42,.13), transparent 55%);
  background-attachment:fixed;
}
/* paper grain */
body::before{
  content:""; position:fixed; inset:0; pointer-events:none; z-index:9999;
  opacity:.04; mix-blend-mode:multiply;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.8' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}
a{color:inherit;text-decoration:none}
.wrap{max-width:1120px;margin:0 auto;padding:0 28px}

/* ---------- nav ---------- */
header.topbar{position:sticky;top:0;z-index:50;backdrop-filter:blur(8px);
  background:linear-gradient(var(--paper),rgba(242,225,197,.78));border-bottom:1px solid var(--line)}
.nav{display:flex;align-items:center;justify-content:space-between;height:74px}
.brand{display:flex;align-items:center;gap:12px;font-family:var(--display);
  font-weight:600;font-size:24px;letter-spacing:-.01em}
.brand .seal{width:40px;height:40px;border-radius:50%;overflow:hidden;
  box-shadow:0 0 0 2px var(--paper),0 0 0 3.5px var(--gold)}
.brand .seal img{width:100%;height:100%;object-fit:cover;display:block}
.brand b{color:var(--rust)}
nav.links{display:flex;align-items:center;gap:30px;font-family:var(--mono);
  font-size:12.5px;font-weight:500;text-transform:uppercase;letter-spacing:.14em}
nav.links a{position:relative;color:var(--ink-soft);transition:color .2s}
nav.links a::after{content:"";position:absolute;left:0;bottom:-7px;height:2px;width:0;background:var(--gold);transition:width .25s}
nav.links a:hover{color:var(--ink)} nav.links a:hover::after{width:100%}
.actions{display:flex;align-items:center;gap:18px}
.lang{font-family:var(--mono);font-size:12px;font-weight:700;letter-spacing:.1em;
  display:inline-flex;gap:7px;align-items:center}
.lang a{color:var(--ink-faint);transition:color .2s} .lang a:hover{color:var(--ink)}
.lang a.on{color:var(--rust)}
.lang i{font-style:normal;color:var(--line-strong)}
.btn{font-family:var(--mono);font-size:12.5px;font-weight:700;text-transform:uppercase;
  letter-spacing:.12em;padding:11px 18px;border-radius:999px;border:1.5px solid var(--ink);
  background:var(--ink);color:var(--paper-2);transition:transform .15s, box-shadow .15s;cursor:pointer}
.btn:hover{transform:translateY(-2px);box-shadow:4px 6px 0 rgba(42,27,15,.18)}
.btn.ghost{background:transparent;color:var(--ink)}
.btn.ghost:hover{background:var(--ink);color:var(--paper-2)}

/* ---------- hero ---------- */
.hero{display:grid;grid-template-columns:1.15fr .85fr;gap:48px;align-items:center;
  padding:84px 0 64px}
.eyebrow{font-family:var(--mono);font-size:12.5px;font-weight:700;letter-spacing:.2em;
  text-transform:uppercase;color:var(--clay);display:flex;align-items:center;gap:10px}
.eyebrow::before{content:"";width:34px;height:2px;background:var(--clay)}
.hero h1{font-family:var(--display);font-weight:600;font-size:clamp(38px,5.6vw,64px);
  line-height:1.04;letter-spacing:-.02em;margin:22px 0 0;font-optical-sizing:auto}
.hero h1 em{font-style:italic;color:var(--rust)}
.hero h1 .u{background:linear-gradient(transparent 62%,rgba(219,179,90,.55) 0);padding:0 .04em}
.hero p.lead{font-size:20px;color:var(--ink-soft);max-width:34ch;margin:24px 0 32px}
.hero .cta{display:flex;gap:14px;flex-wrap:wrap}
.hero .meta{margin-top:34px;font-family:var(--mono);font-size:12px;letter-spacing:.1em;
  text-transform:uppercase;color:var(--ink-faint);display:flex;gap:18px;flex-wrap:wrap}
.hero .meta b{color:var(--rust)}

/* hero art */
.art{position:relative;aspect-ratio:1/1;max-width:380px;justify-self:center;width:100%}
.art .disc{position:absolute;inset:6%;border-radius:50%;
  background:radial-gradient(circle at 35% 30%,var(--gold-soft),var(--gold) 55%,#8f6b1f);
  box-shadow:var(--shadow);animation:float 7s ease-in-out infinite}
.art .ring{position:absolute;inset:0;border-radius:50%;border:1.5px dashed var(--line-strong);
  animation:spin 60s linear infinite}
.art .card-float{position:absolute;background:var(--card);border:1.5px solid var(--ink);
  border-radius:12px;padding:12px 14px;font-family:var(--mono);font-size:11px;
  box-shadow:6px 8px 0 rgba(42,27,15,.16);line-height:1.5;z-index:3}
.art .c1{top:2%;left:-6%;animation:float 6s ease-in-out infinite}
.art .c2{bottom:6%;right:-8%;animation:float 8s ease-in-out .6s infinite}
.art .c3{bottom:34%;left:-10%;background:var(--cocoa);color:var(--gold-soft);border-color:var(--cocoa-2);
  animation:float 7.5s ease-in-out .3s infinite}
.art .portrait{position:absolute;inset:24%;border-radius:50%;object-fit:cover;width:52%;height:52%;
  border:5px solid var(--paper-2);box-shadow:0 12px 26px rgba(42,27,15,.34);z-index:2}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-10px)}}
@keyframes spin{to{transform:rotate(360deg)}}

/* ---------- section heading ---------- */
.sec{padding:64px 0}
.sec-head{display:flex;align-items:flex-end;justify-content:space-between;gap:20px;margin-bottom:34px;
  border-bottom:1.5px solid var(--ink);padding-bottom:16px}
.sec-head h2{font-family:var(--display);font-weight:600;font-size:clamp(28px,4vw,40px);
  margin:0;letter-spacing:-.02em}
.sec-head h2 .n{font-family:var(--mono);font-size:14px;color:var(--clay);vertical-align:super;margin-right:8px}
.sec-head a.more{font-family:var(--mono);font-size:12px;text-transform:uppercase;letter-spacing:.14em;color:var(--rust)}
.sec-head a.more:hover{color:var(--clay)}

/* ---------- article cards ---------- */
.grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.post{background:var(--card);border:1.5px solid var(--line-strong);border-radius:var(--r);
  padding:26px 24px 24px;display:flex;flex-direction:column;gap:14px;position:relative;
  transition:transform .18s, box-shadow .18s, border-color .18s}
.post:hover{transform:translateY(-4px);box-shadow:var(--shadow);border-color:var(--ink)}
.tag{align-self:flex-start;font-family:var(--mono);font-size:10.5px;font-weight:700;
  text-transform:uppercase;letter-spacing:.13em;padding:5px 10px;border-radius:999px;
  background:rgba(188,79,42,.12);color:var(--rust)}
.tag.clay{background:rgba(197,106,51,.15);color:var(--clay)}
.tag.gold{background:rgba(185,143,48,.16);color:#8a6916}
.post h3{font-family:var(--display);font-weight:600;font-size:24px;line-height:1.15;margin:0;letter-spacing:-.01em}
.post p{margin:0;color:var(--ink-soft);font-size:16.5px}
.post .pmeta{margin-top:auto;font-family:var(--mono);font-size:11px;letter-spacing:.08em;
  text-transform:uppercase;color:var(--ink-faint);display:flex;gap:12px}
.post .arrow{position:absolute;top:24px;right:22px;color:var(--ink-faint);transition:transform .2s,color .2s}
.post:hover .arrow{transform:translate(3px,-3px);color:var(--clay)}

/* ---------- books ---------- */
.books{background:linear-gradient(160deg,var(--cocoa),var(--cocoa-2));color:var(--paper-2);
  border-radius:28px;padding:54px 48px;margin-top:8px;position:relative;overflow:hidden}
.books::after{content:"&";position:absolute;right:14px;bottom:-104px;font-size:340px;
  font-family:var(--display);font-style:italic;color:rgba(219,179,90,.07);line-height:1}
.books .sec-head{border-color:rgba(255,255,255,.28)}
.books .sec-head h2{color:var(--paper-2)} .books .sec-head h2 .n{color:var(--gold-soft)}
.books .sec-head a.more{color:var(--gold-soft)}
.booklist{display:grid;grid-template-columns:repeat(2,1fr);gap:40px;position:relative;z-index:1}
.book{display:grid;grid-template-columns:180px 1fr;grid-template-rows:1fr auto;gap:24px;align-items:start}
.bookcol{display:flex;flex-direction:column;gap:14px}
.bookcol .btn{display:block;width:100%;text-align:center}
.bookcol .btnrow{display:flex;flex-wrap:nowrap;gap:6px}
.bookcol .btnrow .btn{width:auto;flex:1 1 auto;min-width:0;white-space:nowrap;
  font-size:11px;letter-spacing:.02em;padding-left:5px;padding-right:5px}
.bookcol .alt,.book .bookbtns .alt{font-family:var(--mono);font-size:11px;letter-spacing:.08em;text-transform:uppercase;
  color:var(--gold-soft);text-align:center;text-decoration:underline;text-underline-offset:3px;margin-top:-3px}
.bookcol .alt:hover,.book .bookbtns .alt:hover{color:#fff}
.cover{aspect-ratio:3/4.2;width:140px;align-self:center;border-radius:4px 10px 10px 4px;position:relative;
  box-shadow:14px 16px 30px rgba(0,0,0,.35);transform:rotate(-3deg);transition:transform .25s}
.book:hover .cover{transform:rotate(0) translateY(-4px)}
.cover::before{content:"";position:absolute;left:0;top:0;bottom:0;width:9px;border-radius:4px 0 0 4px;
  background:rgba(0,0,0,.22)}
.cover.b1{background:linear-gradient(150deg,#E9D9B0,#C9A84C)}
.cover.b2{background:linear-gradient(150deg,#A85A2E,#4A2412)}
.cover img{width:100%;height:100%;object-fit:cover;border-radius:inherit;display:block}
.cover.draft{background:#F0E1C2;border:2px dashed var(--cocoa);box-shadow:10px 12px 26px rgba(0,0,0,.20)}
.cover.draft .ct{color:var(--cocoa)}
.cover .stamp{position:absolute;top:54%;left:50%;transform:translate(-50%,-50%) rotate(-13deg);
  font-family:var(--mono);font-weight:700;font-size:12px;letter-spacing:.18em;text-transform:uppercase;
  color:var(--rust);border:2.5px solid var(--rust);border-radius:6px;padding:5px 9px;opacity:.85;white-space:nowrap}
.cover .ct{position:absolute;inset:18px 14px;display:flex;flex-direction:column;color:#1c150a;
  font-family:var(--display);font-weight:600}
.cover.b2 .ct{color:#f3e7c4}
.cover .ct small{font-family:var(--mono);font-size:9px;letter-spacing:.18em;text-transform:uppercase;opacity:.7;font-weight:700}
.cover .ct span{font-size:19px;line-height:1.05;margin-top:auto}
.book h3{font-family:var(--display);font-size:23px;font-weight:600;margin:2px 0 8px}
.book p{margin:0 0 16px;color:rgba(251,245,234,.78);font-size:16px}
.book .price{font-family:var(--mono);font-size:13px;letter-spacing:.06em;color:var(--gold-soft);margin-right:14px}
.btn.buy{border-color:var(--gold-soft);background:var(--gold-soft);color:#1b1405}
.btn.buy:hover{box-shadow:4px 6px 0 rgba(0,0,0,.25)}
.book .bookbtns{grid-column:1/-1;display:flex;flex-direction:column;gap:8px;margin-top:2px}
.book .bookbtns .btnrow{display:flex;flex-wrap:nowrap;gap:8px;align-items:center}
.book .bookbtns .btnrow .btn{flex:1 1 0;width:auto;text-align:center;white-space:nowrap}
.book .bookbtns .altrow{display:flex;align-items:center;justify-content:center;gap:14px;min-height:44px}
.book .bookbtns .altrow .price{margin-right:0;margin-bottom:0}

/* ---------- projects ---------- */
.projects-stack{display:flex;flex-direction:column;gap:26px}
.project{display:grid;grid-template-columns:1.05fr .95fr;background:var(--card);
  border:1.5px solid var(--ink);border-radius:24px;overflow:hidden;position:relative;
  transition:transform .2s,box-shadow .2s}
.project:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.project.rev{grid-template-columns:.95fr 1.05fr}
.project.rev .project-shot{order:2}
.project-shot{position:relative;overflow:hidden;background:var(--cocoa-2);min-height:320px}
.project-shot img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .5s ease}
.project-shot.pixel img{image-rendering:pixelated}
.project:hover .project-shot img{transform:scale(1.05)}
.project-shot::after{content:"";position:absolute;inset:0;pointer-events:none;
  box-shadow:inset -44px 0 70px -34px rgba(42,27,15,.55)}
.project.rev .project-shot::after{box-shadow:inset 44px 0 70px -34px rgba(42,27,15,.55)}
.project-shot .badge{position:absolute;top:16px;left:16px;font-family:var(--mono);font-size:10.5px;
  font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:#1b1405;
  background:var(--gold-soft);border-radius:999px;padding:6px 12px;box-shadow:3px 4px 0 rgba(0,0,0,.25);z-index:2}
.project-body{padding:42px 42px 36px;display:flex;flex-direction:column;gap:14px}
.project-body .eyebrow{color:var(--clay)}
.project-body h3{font-family:var(--display);font-weight:600;font-size:clamp(30px,4vw,46px);
  margin:6px 0 0;letter-spacing:-.02em;line-height:1}
.project-body p{margin:0;color:var(--ink-soft);font-size:17px}
.project-body p b{color:var(--ink)}
.project-body code{font-family:var(--mono);font-size:.84em;background:rgba(42,27,15,.07);
  border:1px solid var(--line);border-radius:5px;padding:1px 6px;color:var(--cocoa)}
.project-tags{display:flex;flex-wrap:wrap;gap:9px;margin-top:2px}
.project-tags .chip{cursor:inherit;font-size:11px;padding:7px 13px}
.project-tags .chip:hover{transform:none;border-color:var(--line-strong)}
.project-cta{margin-top:auto;padding-top:8px;font-family:var(--mono);font-size:12.5px;font-weight:700;
  text-transform:uppercase;letter-spacing:.12em;color:var(--rust);
  display:inline-flex;align-items:center;gap:8px;transition:gap .2s,color .2s}
.project:hover .project-cta{gap:14px;color:var(--clay)}

/* ---------- topics ---------- */
.topics{display:flex;flex-wrap:wrap;gap:12px}
.chip{font-family:var(--mono);font-size:12px;letter-spacing:.06em;padding:9px 16px;border-radius:999px;
  border:1.5px solid var(--line-strong);background:var(--paper-2);transition:.18s;cursor:pointer}
.chip:hover{border-color:var(--ink);transform:translateY(-2px)}
.chip b{color:var(--clay)}

/* ---------- newsletter ---------- */
.news{margin:72px 0 0;background:var(--card);border:1.5px solid var(--ink);border-radius:24px;
  padding:46px 44px;display:grid;grid-template-columns:1fr auto;gap:30px;align-items:center}
.news h2{font-family:var(--display);font-size:30px;font-weight:600;margin:0 0 8px;letter-spacing:-.01em}
.news p{margin:0;color:var(--ink-soft);max-width:50ch}
.news form{display:flex;gap:10px}
.news input{font-family:var(--serif);font-size:16px;padding:13px 18px;border-radius:999px;
  border:1.5px solid var(--line-strong);background:var(--paper);min-width:240px;color:var(--ink)}
.news input:focus{outline:none;border-color:var(--rust)}

/* ---------- article ---------- */
.article{max-width:768px;margin:0 auto}
.article-head{padding:58px 0 26px;border-bottom:1.5px solid var(--ink);margin-bottom:30px}
.article-head .tag{margin-bottom:18px}
.article-head h1{font-family:var(--display);font-size:clamp(34px,5.4vw,54px);font-weight:600;
  line-height:1.05;letter-spacing:-.02em;margin:0 0 16px}
.article-head .ameta{font-family:var(--mono);font-size:12px;letter-spacing:.1em;text-transform:uppercase;
  color:var(--ink-faint);display:flex;gap:14px;flex-wrap:wrap}
.article .prose{max-width:none;font-size:18.5px;line-height:1.7}
.article .prose ul{padding-left:22px} .article .prose li{margin:0 0 8px}
.post-image{width:100%;border-radius:14px;border:1.5px solid var(--line-strong);
  margin:26px 0;display:block;box-shadow:var(--shadow)}
.post-image + .cap{margin-top:-14px}
.prose .cap{font-size:14.5px;color:var(--ink-soft);font-style:italic;text-align:center;margin:0 0 26px}
.post-video{position:relative;width:100%;aspect-ratio:16/9;margin:26px 0;border-radius:14px;
  border:1.5px solid var(--line-strong);box-shadow:var(--shadow);overflow:hidden;background:#000}
.post-video iframe{position:absolute;inset:0;width:100%;height:100%;border:0;display:block}
.backlink{display:inline-block;margin:36px 0 0;font-family:var(--mono);font-size:12px;
  text-transform:uppercase;letter-spacing:.12em;color:var(--rust)}
.backlink:hover{color:var(--clay)}

/* ---------- code & details ---------- */
.prose pre{background:var(--cocoa-2);color:#ede0c6;border-radius:12px;padding:18px 20px;overflow-x:auto;
  font-family:var(--mono);font-size:12.5px;line-height:1.55;margin:0;border:1.5px solid var(--cocoa)}
.prose pre code{font-family:inherit;white-space:pre}
/* syntax highlighting (highlight.js) — warm palette on the existing dark code bg */
.prose pre code.hljs{background:transparent;color:#ede0c6;padding:0}
.hljs-comment,.hljs-quote{color:#9c876a;font-style:italic}
.hljs-keyword,.hljs-selector-tag,.hljs-literal,.hljs-section,.hljs-meta .hljs-keyword{color:#dbb35a;font-weight:600}
.hljs-built_in,.hljs-type,.hljs-class .hljs-title,.hljs-title.class_,.hljs-variable.language_{color:#e0b563}
.hljs-string,.hljs-attr,.hljs-symbol,.hljs-char,.hljs-regexp,.hljs-addition{color:#a8b57e}
.hljs-number,.hljs-literal.number{color:#e08c57}
.hljs-title,.hljs-title.function_,.hljs-function .hljs-title,.hljs-name{color:#efcf8c}
.hljs-meta,.hljs-meta .hljs-string{color:#cf8f5a}
.hljs-variable,.hljs-template-variable,.hljs-attribute{color:#e0b563}
.hljs-deletion{color:#cf7a5a}
.hljs-emphasis{font-style:italic}.hljs-strong{font-weight:700}
details.code{margin:24px 0;border:1.5px solid var(--line-strong);border-radius:12px;overflow:hidden}
details.code summary{font-family:var(--mono);font-size:12px;text-transform:uppercase;letter-spacing:.1em;
  color:var(--rust);cursor:pointer;padding:12px 16px;background:var(--card)}
details.code[open] summary{border-bottom:1.5px solid var(--line-strong)}
details.code pre{border:none;border-radius:0}

/* ---------- articles index ---------- */
.artlist{max-width:760px;margin:0 auto;list-style:none;padding:0}
.artlist li{border-bottom:1px solid var(--line);padding:26px 0}
.artlist li:first-child{padding-top:8px}
.artlist a{display:block;transition:transform .15s}
.artlist a:hover{transform:translateX(4px)}
.artlist h3{font-family:var(--display);font-size:27px;font-weight:600;margin:10px 0 8px;letter-spacing:-.01em}
.artlist a:hover h3{color:var(--rust)}
.artlist p{margin:0 0 10px;color:var(--ink-soft);font-size:17px}
.artlist .pmeta{font-family:var(--mono);font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-faint);display:flex;gap:12px}

/* ---------- hero tag cloud ---------- */
.cloud{display:flex;flex-wrap:wrap;gap:11px 12px;align-content:center;align-items:center;
  justify-content:center;min-height:340px;padding:6px}
.cloud a{font-family:var(--display);font-weight:600;line-height:1.05;color:var(--ink);
  border-radius:999px;padding:8px 15px;border:1.5px solid var(--line-strong);background:var(--card);
  transition:transform .16s,border-color .16s,box-shadow .16s}
.cloud a:hover{border-color:var(--ink);transform:translateY(-2px);box-shadow:4px 6px 0 rgba(42,27,15,.12)}
.cloud a.s1{font-size:15px;color:var(--ink-soft)}
.cloud a.s2{font-size:20px}
.cloud a.s3{font-size:25px;color:var(--rust);border-color:rgba(188,79,42,.5)}
.cloud a.book{background:linear-gradient(160deg,var(--cocoa),var(--cocoa-2));color:var(--gold-soft);border-color:var(--cocoa-2)}

/* ---------- hero tag sphere (3D) ---------- */
.sphere{position:relative;width:100%;max-width:400px;aspect-ratio:1/1;margin:0 auto;justify-self:center}
.sphere a{position:absolute;left:50%;top:50%;white-space:nowrap;font-family:var(--display);font-weight:600;
  color:var(--ink);background:var(--card);border:1.5px solid var(--line-strong);border-radius:999px;
  padding:6px 13px;font-size:15px;text-decoration:none;will-change:transform,opacity;
  transition:background .15s,border-color .15s;cursor:pointer}
.sphere a:hover{border-color:var(--ink);background:var(--paper-2)}
.sphere a.book{background:linear-gradient(160deg,var(--cocoa),var(--cocoa-2));color:var(--gold-soft);border-color:var(--cocoa-2)}
.sphere a.book:hover{color:#fff}

/* ---------- footer ---------- */
footer{margin-top:80px;border-top:1px solid var(--line);padding:40px 0 60px}
.foot{display:flex;justify-content:space-between;align-items:center;gap:20px;flex-wrap:wrap;
  font-family:var(--mono);font-size:12px;letter-spacing:.06em;color:var(--ink-faint);text-transform:uppercase}
.foot a{color:var(--ink-soft)} .foot a:hover{color:var(--clay)}

/* ---------- reveal ---------- */
.reveal{opacity:0;transform:translateY(18px);animation:rise .7s cubic-bezier(.2,.7,.2,1) forwards}
@keyframes rise{to{opacity:1;transform:none}}
.d1{animation-delay:.05s}.d2{animation-delay:.14s}.d3{animation-delay:.23s}
.d4{animation-delay:.32s}.d5{animation-delay:.41s}

@media(max-width:900px){
  .hero{grid-template-columns:1fr;gap:30px;padding:54px 0 40px}
  .art{order:-1;max-width:300px}
  .grid{grid-template-columns:1fr}
  .booklist{grid-template-columns:1fr}
  .news{grid-template-columns:1fr}
  .project,.project.rev{grid-template-columns:1fr}
  .project.rev .project-shot{order:0}
  .project-shot{min-height:220px}
  .project-body{padding:30px 28px 28px}
  nav.links{display:none}
}

/* ---------- about page ---------- */
.about-hero{display:grid;grid-template-columns:200px 1fr;gap:44px;align-items:center;padding:70px 0 36px}
.about-hero .photo{width:200px;height:200px;border-radius:50%;object-fit:cover;
  border:6px solid var(--paper-2);box-shadow:var(--shadow)}
.about-hero h1{font-family:var(--display);font-size:clamp(34px,5vw,52px);font-weight:600;
  margin:0 0 14px;letter-spacing:-.02em}
.about-hero p{font-size:20px;color:var(--ink-soft);margin:0;max-width:48ch}
.banner{display:block;width:100%;height:auto;border-radius:18px;margin:8px 0 4px;
  border:1.5px solid var(--line-strong);box-shadow:var(--shadow)}
.banner-cap{font-family:var(--mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;
  color:var(--ink-faint);margin:12px 0 0;text-align:center}

/* ── projects coverflow ─────────────────────────── */
.coverflow{position:relative;margin:14px 0 4px;padding:64px 0;perspective:1700px;overflow:hidden}
.cov-track{position:relative;height:clamp(140px,15vw,210px);transform-style:preserve-3d}
.cov-item{position:absolute;top:50%;left:0;width:clamp(150px,16vw,230px);cursor:pointer;
  transform-style:preserve-3d;will-change:transform;
  transition:transform .5s cubic-bezier(.2,.7,.2,1),opacity .5s}
.cov-item img{display:block;width:100%;aspect-ratio:16/10;object-fit:cover;border-radius:12px;
  border:1.5px solid var(--line-strong);background:var(--paper-2);
  box-shadow:0 14px 26px rgba(42,27,15,.24);-webkit-user-drag:none}
.cov-item figcaption{position:absolute;left:0;right:0;top:100%;
  font-family:var(--mono);font-size:11px;letter-spacing:.08em;text-transform:uppercase;
  color:var(--ink-soft);text-align:center;margin-top:12px;white-space:nowrap;pointer-events:none;
  opacity:0;transition:opacity .35s}
.cov-item.is-active{z-index:200}
.cov-item.is-active img{border-color:var(--ink);box-shadow:0 26px 48px rgba(42,27,15,.36)}
.cov-item.is-active figcaption{opacity:1}
.cov-item:focus-visible img{border-color:var(--ink)}
@media(prefers-reduced-motion:reduce){
  .cov-item{transition:none}
}
.prose{max-width:70ch;padding:8px 0 8px;font-size:18px}
.prose h2{font-family:var(--display);font-size:28px;font-weight:600;margin:42px 0 12px;letter-spacing:-.01em}
.prose p{margin:0 0 18px}
.prose a{color:var(--rust);text-decoration:underline;text-underline-offset:3px;text-decoration-thickness:1.5px}
.prose .table{overflow-x:auto;margin:22px 0}
.prose table{border-collapse:collapse;width:100%;font-size:15.5px;line-height:1.5}
.prose th,.prose td{border:1px solid var(--line-strong);padding:8px 13px;text-align:left;vertical-align:top}
.prose th{background:var(--card);font-weight:600}
.prose td p,.prose th p{margin:0}
.quote{border-left:3px solid var(--gold);padding:4px 0 4px 24px;margin:30px 0;
  font-family:var(--display);font-style:italic;font-size:22px;line-height:1.4;color:var(--cocoa)}
.credits{display:flex;flex-wrap:wrap;gap:10px;margin:14px 0 0}
.gamegrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(155px,1fr));gap:14px;margin:16px 0 4px}
.game{border:1.5px solid var(--line-strong);border-radius:12px;overflow:hidden;background:var(--paper-2);
  display:flex;flex-direction:column;transition:transform .18s,border-color .18s,box-shadow .18s}
.game:hover{transform:translateY(-3px);border-color:var(--ink);box-shadow:var(--shadow)}
.game img{width:100%;aspect-ratio:16/9;object-fit:cover;display:block;border-bottom:1.5px solid var(--line)}
.game .name{font-family:var(--mono);font-size:11px;letter-spacing:.04em;padding:9px 10px;text-align:center;color:var(--ink-soft)}
.game.noimg{place-content:center;min-height:92px;background:var(--card)}
.game.noimg .name{color:var(--ink)}
.timeline{list-style:none;margin:18px 0 8px;padding:0}
.timeline li{display:flex;gap:16px;align-items:flex-start;padding:0 0 22px}
.timeline li:last-child{padding-bottom:0}
.timeline .logo,.timeline .nologo{width:46px;height:46px;border-radius:10px;flex:0 0 auto;
  border:1.5px solid var(--line-strong);background:#fff}
.timeline .logo{object-fit:contain;padding:3px}
.timeline .nologo{background:var(--paper-2);display:grid;place-items:center}
.timeline .nologo::after{content:"";width:9px;height:9px;border-radius:50%;background:var(--rust)}
.timeline .li-body{flex:1;min-width:0;padding-top:1px}
.timeline .yr{font-family:var(--mono);font-size:11.5px;font-weight:700;letter-spacing:.1em;
  text-transform:uppercase;color:var(--rust)}
.timeline .ev{font-family:var(--display);font-size:20px;font-weight:600;margin:3px 0 4px;letter-spacing:-.01em}
.timeline li p{margin:0;color:var(--ink-soft);font-size:16px}
.support{background:linear-gradient(160deg,var(--cocoa),var(--cocoa-2));color:var(--paper-2);
  border-radius:28px;padding:50px 44px;margin:60px 0 0;position:relative;overflow:hidden}
.support::after{content:"₿";position:absolute;right:24px;bottom:-90px;font-size:300px;
  font-family:var(--display);color:rgba(219,179,90,.06);line-height:1}
.support h2{font-family:var(--display);font-size:30px;font-weight:600;margin:0 0 10px}
.support>p{color:rgba(251,240,218,.82);max-width:56ch;margin:0 0 26px;position:relative;z-index:1}
.tiers{display:grid;grid-template-columns:repeat(auto-fill,minmax(190px,1fr));gap:12px;margin:0 0 30px;position:relative;z-index:1}
.tier{border:1.5px solid rgba(219,179,90,.32);border-radius:12px;padding:14px 16px;background:rgba(0,0,0,.10)}
a.tier{display:block;text-decoration:none;transition:transform .15s,border-color .15s,background .15s}
a.tier:hover{border-color:var(--gold-soft);background:rgba(219,179,90,.12);transform:translateY(-2px)}
.tier b{display:block;font-family:var(--display);font-size:16px;color:var(--gold-soft);font-weight:600;line-height:1.2}
.tier span{font-family:var(--mono);font-size:12px;color:rgba(251,240,218,.7)}
@media(max-width:700px){
  .about-hero{grid-template-columns:1fr;text-align:center;justify-items:center}
  .about-hero p{max-width:none}
}
