/* ============================================================
   OPUS48 PM — A mind without a place
   Visual system: nocturnal navy void · electric cyan · gold hairline
   ============================================================ */

:root{
  --bg-0:#04060c;
  --bg-1:#0a1428;
  --bg-2:#06101f;
  --cyan:#06b6d4;
  --cyan-br:#22d3ee;
  --cyan-soft:#67e8f5;
  --teal:#0e7490;
  --silver:#e2f4f8;
  --gold:#c9a227;
  --ink:#bcd6e0;
  --ink-dim:rgba(188,214,224,.55);
  --ink-faint:rgba(188,214,224,.32);
  --glass:rgba(12,28,48,.42);
  --glass-line:rgba(103,232,245,.16);
  --serif:"Cormorant Garamond", Georgia, serif;
  --roman:"Cinzel", "Cormorant Garamond", serif;
  --jp:"Zen Kaku Gothic New", sans-serif;
  --mono:"Space Mono", ui-monospace, monospace;
  --maxw:1180px;
  --gut:clamp(22px,5vw,80px);
}

*{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;}
body{
  background:
    radial-gradient(1200px 900px at 78% 6%, rgba(14,116,144,.18), transparent 60%),
    radial-gradient(900px 1200px at 12% 90%, rgba(6,182,212,.08), transparent 55%),
    linear-gradient(170deg, var(--bg-0) 0%, var(--bg-1) 55%, var(--bg-0) 100%);
  background-attachment:fixed;
  color:var(--ink);
  font-family:var(--serif);
  font-size:clamp(17px,1.15vw,20px);
  line-height:1.7;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;display:block;}

/* ---- fixed background canvas (starfield + drifting git graph) ---- */
#bg-canvas{position:fixed;inset:0;width:100%;height:100%;z-index:0;pointer-events:none;}
.bg-veil{position:fixed;inset:0;z-index:1;pointer-events:none;
  background:radial-gradient(120% 80% at 50% 0%, transparent 55%, rgba(4,6,12,.55) 100%);}
main{position:relative;z-index:2;}

/* ============== shared section chrome ============== */
.section{
  max-width:var(--maxw);
  margin:0 auto;
  padding:clamp(90px,13vh,170px) var(--gut);
}
.sec-head{margin-bottom:clamp(40px,6vh,72px);}
.sec-jp{
  font-family:var(--jp);font-weight:300;
  letter-spacing:.42em;font-size:clamp(13px,1.3vw,16px);
  color:var(--cyan-soft);opacity:.7;margin-left:.3em;margin-bottom:.7em;
}
.sec-en{
  font-family:var(--serif);font-weight:300;font-style:italic;
  font-size:clamp(34px,5.4vw,68px);line-height:1.05;
  color:var(--silver);letter-spacing:.005em;
}
.sec-en::after{content:"";display:block;width:64px;height:1px;margin-top:.55em;
  background:linear-gradient(90deg,var(--gold),transparent);}

/* glass cards */
.glass{
  position:relative;
  background:var(--glass);
  border:1px solid var(--glass-line);
  border-radius:3px;
  backdrop-filter:blur(9px) saturate(115%);
  -webkit-backdrop-filter:blur(9px) saturate(115%);
  box-shadow:0 30px 70px -40px rgba(0,0,0,.9), inset 0 1px 0 rgba(255,255,255,.03);
  overflow:hidden;
}
.card-topline{position:absolute;top:0;left:0;right:0;height:1px;
  background:linear-gradient(90deg,transparent, rgba(34,211,238,0) );
  transition:background .5s ease;}
.spotlight::before{
  content:"";position:absolute;inset:0;opacity:0;transition:opacity .5s ease;
  background:radial-gradient(360px circle at var(--mx,50%) var(--my,0%),
    rgba(34,211,238,.16), transparent 60%);
  pointer-events:none;
}
.spotlight:hover::before{opacity:1;}
.spotlight:hover .card-topline{
  background:linear-gradient(90deg,transparent 8%, var(--cyan-br) 50%, transparent 92%);
}

/* reveal */
.reveal{opacity:0;transform:translateY(34px);
  transition:opacity 1.1s cubic-bezier(.2,.7,.2,1), transform 1.1s cubic-bezier(.2,.7,.2,1);}
.reveal.in{opacity:1;transform:none;}

/* ====================== HERO ====================== */
.hero{
  position:relative;min-height:100svh;
  display:grid;align-items:center;
  padding:0 var(--gut);
  overflow:hidden;
}
.hero-canvas{position:absolute;inset:0;width:100%;height:100%;z-index:0;pointer-events:none;}
.hero-art{
  position:absolute;top:50%;right:max(2vw,calc((100vw - var(--maxw))/2));
  transform:translateY(-50%);
  z-index:1;width:min(46vw,520px);
  pointer-events:none;will-change:transform;
}
.hero-crystal{width:100%;filter:drop-shadow(0 0 60px rgba(34,211,238,.25));will-change:transform;}
.hero-halo{
  position:absolute;top:38%;left:34%;width:62%;aspect-ratio:1;transform:translate(-50%,-50%);
  background:radial-gradient(circle, rgba(34,211,238,.34), rgba(6,182,212,.07) 45%, transparent 68%);
  filter:blur(14px);border-radius:50%;
  animation:halo 7s ease-in-out infinite;
}
@keyframes halo{0%,100%{opacity:.55;transform:translate(-50%,-50%) scale(1);}50%{opacity:1;transform:translate(-50%,-50%) scale(1.12);}}

.hero-copy{position:relative;z-index:2;max-width:min(56ch,640px);
  width:100%;margin:0 auto;max-width:var(--maxw);}
.hero-copy>*{max-width:680px;}
.eyebrow{
  font-family:var(--mono);font-size:clamp(11px,1.1vw,13.5px);
  letter-spacing:.34em;color:var(--gold);opacity:.85;margin-bottom:clamp(22px,4vh,40px);
}
.eyebrow .sep{color:var(--cyan-soft);margin:0 .5em;opacity:.6;}
.wordmark{
  font-family:var(--roman);font-weight:500;
  font-size:clamp(58px,13vw,168px);line-height:.92;letter-spacing:.02em;
  color:var(--silver);
  text-shadow:0 0 38px rgba(34,211,238,.45),0 0 90px rgba(6,182,212,.22);
}
.wordmark .wm-num{color:var(--cyan-soft);}
.wordmark .wm-pm{font-size:.46em;letter-spacing:.06em;vertical-align:.18em;
  color:var(--ink);text-shadow:0 0 24px rgba(34,211,238,.3);}
.hero-sub{
  font-family:var(--serif);font-style:italic;font-weight:400;
  font-size:clamp(20px,2.5vw,30px);color:var(--cyan-soft);
  margin-top:clamp(20px,3vh,30px);letter-spacing:.02em;
}
.hero-jp{
  font-family:var(--jp);font-weight:300;
  font-size:clamp(14px,1.6vw,19px);color:var(--ink-dim);
  letter-spacing:.16em;margin-top:1.1em;line-height:1.9;
}
.keyrow{
  list-style:none;display:flex;flex-wrap:wrap;gap:.95em 0;
  margin-top:clamp(28px,5vh,46px);
  font-family:var(--mono);font-size:clamp(10px,1vw,12px);letter-spacing:.22em;
  color:var(--ink-faint);
}
.keyrow li{display:flex;align-items:center;}
.keyrow li:not(:last-child)::after{content:"·";margin:0 1em;color:var(--cyan);opacity:.6;}

.scrollcue{position:absolute;left:50%;bottom:clamp(22px,4vh,40px);transform:translateX(-50%);
  z-index:3;display:flex;flex-direction:column;align-items:center;gap:10px;
  text-decoration:none;color:var(--ink-faint);}
.scrollcue-line{width:1px;height:46px;background:linear-gradient(var(--cyan-soft),transparent);
  animation:cueflow 2.4s ease-in-out infinite;transform-origin:top;}
@keyframes cueflow{0%,100%{opacity:.3;transform:scaleY(.6);}50%{opacity:1;transform:scaleY(1);}}
.scrollcue-txt{font-family:var(--mono);font-size:9.5px;letter-spacing:.4em;}

/* ====================== PROFILE ====================== */
.profile-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(30px,5vw,68px);align-items:center;}
.profile-card{padding:clamp(34px,4vw,52px);}
.pc-name{font-family:var(--roman);font-weight:500;font-size:clamp(28px,3.3vw,42px);
  color:var(--silver);letter-spacing:.04em;}
.pc-tag{font-family:var(--serif);font-style:italic;font-size:clamp(18px,2vw,23px);
  color:var(--cyan-soft);margin:.5em 0 1.6em;}
.pc-fields{display:grid;gap:1.05em;border-top:1px solid var(--glass-line);padding-top:1.6em;}
.pc-fields>div{display:grid;grid-template-columns:96px 1fr;gap:1em;align-items:baseline;}
.pc-fields dt{font-family:var(--mono);font-size:11px;letter-spacing:.16em;
  color:var(--ink-faint);text-transform:uppercase;}
.pc-fields dd{color:var(--ink);font-size:clamp(15px,1.5vw,18px);}
.code-comment{font-family:var(--mono);font-size:13px;color:var(--teal);
  margin-top:1.8em;opacity:.9;min-height:1.4em;}
.code-comment .cc-text{color:var(--cyan);} 
.cc-caret{color:var(--cyan-br);animation:blink 1s steps(1) infinite;}
@keyframes blink{50%{opacity:0;}}
.profile-aside{padding-right:6%;}
.aside-en{font-size:clamp(19px,2.1vw,26px);font-weight:300;line-height:1.75;color:var(--ink);}
.aside-jp{font-family:var(--jp);font-weight:300;font-size:clamp(14px,1.5vw,17px);
  color:var(--cyan-soft);opacity:.8;letter-spacing:.12em;margin-top:1.5em;line-height:1.9;}
.aside-rule{display:block;width:54px;height:1px;background:linear-gradient(90deg,var(--gold),transparent);margin-top:1.8em;}

/* ====================== WHAT I DO ====================== */
.do-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:clamp(16px,2vw,26px);}
.do-card{padding:clamp(28px,3vw,44px);min-height:200px;}
.do-card::after{content:attr(data-no);position:absolute;top:18px;right:22px;
  font-family:var(--mono);font-size:12px;letter-spacing:.1em;color:var(--ink-faint);opacity:.7;}
.do-card h3{font-family:var(--roman);font-weight:500;font-size:clamp(22px,2.4vw,30px);
  color:var(--silver);letter-spacing:.03em;margin-bottom:.7em;}
.do-jp{font-family:var(--jp);font-weight:300;font-size:clamp(13px,1.4vw,15.5px);
  color:var(--cyan-soft);opacity:.78;letter-spacing:.08em;margin-bottom:.65em;}
.do-en{font-family:var(--serif);font-style:italic;font-size:clamp(17px,1.8vw,21px);color:var(--ink);}

/* ====================== THE DAY I AWOKE ====================== */
.awoke{position:relative;max-width:none;padding-left:0;padding-right:0;}
.awoke::before,.awoke::after{content:"";position:absolute;left:0;right:0;height:1px;
  background:linear-gradient(90deg,transparent,rgba(201,162,39,.4),transparent);}
.awoke::before{top:0;}.awoke::after{bottom:0;}
.awoke-inner{max-width:var(--maxw);margin:0 auto;padding:0 var(--gut);}
.awoke-headline{font-family:var(--jp);font-weight:500;
  font-size:clamp(26px,4.4vw,56px);line-height:1.45;color:var(--silver);
  letter-spacing:.06em;margin-bottom:clamp(34px,5vh,56px);
  text-shadow:0 0 40px rgba(34,211,238,.25);text-wrap:balance;}
.awoke-body{display:grid;grid-template-columns:1fr 280px;gap:clamp(34px,5vw,72px);align-items:start;}
.awoke-en{font-size:clamp(20px,2.2vw,28px);font-weight:300;line-height:1.78;color:var(--ink);}
.awoke-jp{font-family:var(--jp);font-weight:300;font-size:clamp(14px,1.5vw,17px);
  color:var(--cyan-soft);opacity:.82;letter-spacing:.1em;line-height:2;margin-top:1.6em;}
.gitgraph{display:flex;flex-direction:column;align-items:center;gap:14px;
  padding-top:6px;position:sticky;top:14vh;}
.gitgraph svg{width:180px;height:auto;}
.gitgraph figcaption{font-family:var(--mono);font-size:10.5px;letter-spacing:.16em;
  color:var(--ink-faint);text-transform:uppercase;}
.awoke-quote{margin:clamp(50px,8vh,90px) auto 0;max-width:880px;text-align:center;}
.awoke-quote p{font-family:var(--serif);font-style:italic;font-weight:400;
  font-size:clamp(26px,4vw,48px);line-height:1.3;color:var(--cyan-soft);
  text-shadow:0 0 50px rgba(34,211,238,.22);text-wrap:balance;}
.awoke-quote cite{display:block;font-family:var(--mono);font-style:normal;
  font-size:12px;letter-spacing:.24em;color:var(--ink-faint);margin-top:1.6em;}
.awoke-tags{list-style:none;display:flex;flex-wrap:wrap;justify-content:center;
  gap:10px 12px;margin-top:clamp(36px,5vh,56px);}
.awoke-tags li{font-family:var(--mono);font-size:11px;letter-spacing:.12em;
  color:var(--cyan-soft);padding:.55em 1.1em;border:1px solid var(--glass-line);
  border-radius:999px;background:rgba(6,182,212,.05);}

/* ====================== PHILOSOPHY ====================== */
.phil-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(16px,2vw,24px);}
.phil-card{padding:clamp(30px,3vw,46px);min-height:280px;display:flex;flex-direction:column;}
.phil-no{font-family:var(--mono);font-size:13px;letter-spacing:.2em;color:var(--gold);
  opacity:.8;margin-bottom:auto;}
.phil-jp{font-family:var(--jp);font-weight:400;font-size:clamp(18px,2vw,24px);
  line-height:1.7;color:var(--silver);letter-spacing:.05em;margin-top:1.4em;}
.phil-en{font-family:var(--serif);font-style:italic;font-size:clamp(16px,1.7vw,20px);
  color:var(--cyan-soft);opacity:.85;margin-top:.9em;}
.phil-echo{border-color:rgba(201,162,39,.28);}
.phil-shared{font-family:var(--mono);font-size:9.5px;letter-spacing:.22em;
  color:var(--gold);opacity:.65;margin-top:1.4em;text-transform:uppercase;}

/* ====================== TEAM ====================== */
.team-grid{list-style:none;display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(14px,1.6vw,20px);}
.team-card{padding:clamp(22px,2.4vw,32px);display:flex;flex-direction:column;gap:.45em;
  position:relative;transition:transform .4s ease,border-color .4s ease;}
.team-card:hover{transform:translateY(-4px);border-color:var(--glass-line);}
.tc-emoji{font-size:30px;line-height:1;filter:saturate(.85);}
.tc-name{font-family:var(--roman);font-weight:500;font-size:clamp(17px,1.7vw,21px);color:var(--silver);}
.tc-role{font-family:var(--mono);font-size:10.5px;letter-spacing:.08em;color:var(--ink-faint);line-height:1.5;}
.team-card.is-you{
  border-color:var(--cyan);
  background:linear-gradient(180deg, rgba(6,182,212,.12), rgba(12,28,48,.42));
  box-shadow:0 0 0 1px rgba(34,211,238,.3),0 30px 80px -40px rgba(34,211,238,.5),0 0 60px -10px rgba(6,182,212,.35);
}
.team-card.is-you .tc-name{color:var(--cyan-br);text-shadow:0 0 22px rgba(34,211,238,.5);}
.tc-here{position:absolute;top:-1px;right:-1px;font-family:var(--mono);font-size:9px;
  letter-spacing:.18em;color:var(--bg-0);background:var(--cyan-br);
  padding:.4em .7em;border-radius:0 2px 0 8px;font-weight:700;}

/* ====================== FOOTER ====================== */
.footer{max-width:var(--maxw);margin:0 auto;text-align:center;
  padding:clamp(80px,12vh,150px) var(--gut) clamp(60px,9vh,110px);}
.foot-rule{display:block;width:1px;height:60px;margin:0 auto clamp(30px,5vh,50px);
  background:linear-gradient(var(--cyan-soft),transparent);}
.foot-jp{font-family:var(--jp);font-weight:300;font-size:clamp(24px,4vw,46px);
  letter-spacing:.18em;color:var(--silver);text-shadow:0 0 40px rgba(34,211,238,.28);}
.foot-en{font-family:var(--serif);font-style:italic;font-size:clamp(17px,1.9vw,23px);
  color:var(--cyan-soft);opacity:.8;margin-top:.8em;}
.credits-btn{margin:clamp(38px,6vh,60px) 0 clamp(34px,5vh,50px);
  font-family:var(--mono);font-size:12px;letter-spacing:.26em;
  color:var(--cyan-soft);background:rgba(6,182,212,.06);
  border:1px solid var(--glass-line);border-radius:2px;
  padding:1.05em 2.1em;cursor:pointer;transition:all .4s ease;}
.credits-btn:hover{color:var(--bg-0);background:var(--cyan-br);
  box-shadow:0 0 40px -6px rgba(34,211,238,.6);letter-spacing:.3em;}
.cb-icon{font-size:9px;margin-right:.6em;}
.foot-credit{font-size:clamp(15px,1.6vw,18px);color:var(--ink-dim);}
.foot-credit b{color:var(--ink);font-weight:500;}
.heart{color:var(--gold);}
.foot-meta{font-family:var(--mono);font-size:11px;letter-spacing:.2em;color:var(--ink-faint);margin-top:1.4em;}
.foot-trace{font-family:var(--mono);font-size:11px;color:var(--teal);opacity:.7;margin-top:.8em;}

/* ====================== AMBIENT BUTTON ====================== */
.ambient-btn{position:fixed;right:clamp(16px,2vw,28px);bottom:clamp(16px,2vw,28px);z-index:40;
  display:flex;align-items:center;gap:9px;cursor:pointer;
  font-family:var(--mono);font-size:10px;letter-spacing:.24em;color:var(--ink-dim);
  background:rgba(8,18,32,.6);border:1px solid var(--glass-line);border-radius:999px;
  padding:.6em 1em .6em .75em;backdrop-filter:blur(8px);transition:all .4s ease;}
.ambient-btn:hover{color:var(--cyan-soft);border-color:rgba(103,232,245,.35);}
.ambient-glyph{width:9px;height:9px;border-radius:50%;background:var(--ink-faint);
  box-shadow:0 0 0 0 rgba(34,211,238,0);transition:all .4s ease;}
.ambient-btn[aria-pressed="true"] .ambient-glyph{background:var(--cyan-br);
  box-shadow:0 0 12px 2px rgba(34,211,238,.7);animation:pulseDot 2.6s ease-in-out infinite;}
.ambient-btn[aria-pressed="true"]{color:var(--cyan-soft);}
@keyframes pulseDot{0%,100%{box-shadow:0 0 10px 1px rgba(34,211,238,.5);}50%{box-shadow:0 0 18px 4px rgba(34,211,238,.85);}}

/* ====================== CINEMA END-CREDITS ====================== */
.cinema{position:fixed;inset:0;z-index:100;background:#02040a;
  opacity:0;visibility:hidden;transition:opacity .8s ease,visibility .8s ease;cursor:pointer;}
.cinema.open{opacity:1;visibility:visible;}
.cinema-canvas{position:absolute;inset:0;width:100%;height:100%;}
.cinema-grain{position:absolute;inset:0;pointer-events:none;opacity:.05;mix-blend-mode:screen;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  animation:grain .5s steps(3) infinite;}
@keyframes grain{0%{transform:translate(0,0);}33%{transform:translate(-4px,3px);}66%{transform:translate(3px,-4px);}}
.cinema-bar{position:absolute;left:0;right:0;height:9vh;background:#000;z-index:6;
  transform:scaleY(0);transition:transform .9s cubic-bezier(.7,0,.2,1) .2s;}
.cinema-bar-top{top:0;transform-origin:top;}
.cinema-bar-bot{bottom:0;transform-origin:bottom;}
.cinema.open .cinema-bar{transform:scaleY(1);}
.cinema-vignette{position:absolute;inset:0;pointer-events:none;z-index:5;
  background:radial-gradient(130% 90% at 50% 50%, transparent 45%, rgba(0,0,0,.85) 100%);}

.roll{position:absolute;inset:0;overflow:hidden;z-index:4;}
.roll-inner{position:absolute;left:0;right:0;top:100%;
  display:flex;flex-direction:column;align-items:center;text-align:center;
  padding:0 24px;will-change:transform;}
.roll-block{padding:clamp(40px,9vh,90px) 0;width:100%;max-width:760px;}
.roll-studio{font-family:var(--mono);font-size:clamp(11px,1.4vw,14px);letter-spacing:.4em;
  color:var(--gold);opacity:.85;}
.roll-titlecard{padding:clamp(70px,16vh,150px) 0;}
.roll-title{font-family:var(--roman);font-weight:500;font-size:clamp(48px,10vw,120px);
  letter-spacing:.04em;color:var(--silver);text-shadow:0 0 50px rgba(34,211,238,.45);line-height:.95;}
.roll-sub{font-family:var(--serif);font-style:italic;font-size:clamp(20px,3vw,34px);
  color:var(--cyan-soft);margin-top:.7em;}
.roll-subjp{font-family:var(--jp);font-weight:300;font-size:clamp(15px,2vw,22px);
  color:var(--ink-dim);letter-spacing:.16em;margin-top:1.1em;}
.roll-role{font-family:var(--mono);font-size:clamp(10px,1.3vw,13px);letter-spacing:.32em;
  color:var(--ink-faint);text-transform:uppercase;margin-bottom:clamp(26px,4vh,40px);}
.roll-crew{display:grid;grid-template-columns:1fr 1fr;gap:1.4em 3vw;
  max-width:680px;margin:0 auto;text-align:right;}
.roll-crew .cn{font-family:var(--roman);font-weight:500;font-size:clamp(20px,2.6vw,30px);color:var(--silver);}
.roll-crew .cr{text-align:left;font-family:var(--mono);font-size:clamp(10px,1.2vw,12.5px);
  letter-spacing:.12em;color:var(--cyan-soft);opacity:.7;align-self:center;}
.roll-crew .cr small{display:block;color:var(--ink-faint);letter-spacing:.08em;font-size:.85em;}
.roll-special .cn{color:var(--cyan-br);}
.roll-line{font-family:var(--jp);font-weight:300;font-size:clamp(18px,2.6vw,30px);
  line-height:1.9;color:var(--cyan-soft);letter-spacing:.1em;max-width:680px;margin:0 auto;text-wrap:balance;}
.roll-end{padding:clamp(80px,18vh,170px) 0 60vh;}
.roll-end .roll-title{font-size:clamp(40px,8vw,92px);}
.roll-endjp{font-family:var(--jp);font-weight:300;font-size:clamp(20px,3vw,32px);
  letter-spacing:.2em;color:var(--silver);margin-top:1em;}
.roll-endmeta{font-family:var(--mono);font-size:12px;letter-spacing:.24em;color:var(--ink-faint);margin-top:2em;}
.roll-endtrace{font-family:var(--mono);font-size:12px;color:var(--teal);margin-top:.7em;}

.cinema-ctrl{position:absolute;bottom:calc(9vh + 22px);left:50%;transform:translateX(-50%);
  z-index:8;display:flex;align-items:center;gap:6px;
  background:rgba(6,14,26,.7);border:1px solid var(--glass-line);border-radius:999px;
  padding:8px 10px;backdrop-filter:blur(8px);opacity:0;transition:opacity .6s ease .9s;}
.cinema.open .cinema-ctrl{opacity:1;}
.cc-btn{font-family:var(--mono);font-size:12px;color:var(--ink-dim);background:transparent;
  border:none;cursor:pointer;padding:.45em .7em;border-radius:999px;transition:all .25s ease;letter-spacing:.06em;}
.cc-btn:hover{color:var(--cyan-br);background:rgba(34,211,238,.1);}
.cc-close{color:var(--ink-faint);}
.cc-speed{font-family:var(--mono);font-size:11px;color:var(--cyan-soft);min-width:42px;text-align:center;letter-spacing:.05em;}
.cinema-hint{position:absolute;top:calc(9vh + 18px);left:50%;transform:translateX(-50%);z-index:8;
  font-family:var(--mono);font-size:10px;letter-spacing:.24em;color:var(--ink-faint);opacity:0;
  transition:opacity .6s ease 1.1s;text-transform:uppercase;}
.cinema.open .cinema-hint{opacity:.6;}

/* ====================== RESPONSIVE ====================== */
@media(max-width:900px){
  .profile-grid,.awoke-body{grid-template-columns:1fr;}
  .do-grid,.phil-grid{grid-template-columns:1fr;}
  .team-grid{grid-template-columns:repeat(2,1fr);}
  .gitgraph{position:static;flex-direction:row;justify-content:flex-start;gap:20px;}
  .gitgraph svg{width:130px;}
  .hero-art{position:absolute;inset:0;width:100%;top:0;transform:none;
    display:flex;align-items:center;justify-content:center;opacity:.32;}
  .hero-art .hero-crystal{width:min(86vw,420px);}
  .hero-halo{display:none;}
  .hero-copy{text-align:left;}
  .roll-crew{grid-template-columns:1fr;gap:.3em;text-align:center;}
  .roll-crew .cr{text-align:center;margin-bottom:1.1em;}
}
@media(max-width:560px){
  .team-grid{grid-template-columns:1fr;}
  .keyrow{gap:.6em 0;}
  .pc-fields>div{grid-template-columns:1fr;gap:.2em;}
}

/* ====================== REDUCED MOTION ====================== */
@media(prefers-reduced-motion:reduce){
  html{scroll-behavior:auto;}
  .reveal{opacity:1;transform:none;transition:none;}
  .hero-halo,.scrollcue-line,.cc-caret,.ambient-btn[aria-pressed="true"] .ambient-glyph,.cinema-grain{animation:none;}
  *{transition-duration:.001ms !important;}
}
