
*,*::before,*::after{box-sizing:border-box}
/* The desktop design is tuned to read at ~135% — bake that in. Everything below
   is rem-based, so this scales the whole layout as a unit (like browser zoom).
   The mobile breakpoint drops this back to 100% for comfortable phone sizing. */
html{scroll-behavior:smooth;font-size:135%}
:root{
  --bg:#08090c;--panel:#0e1117;--ink:#d7e0e8;--muted:#5f6b76;--line:#1b2027;
  --blue:#5b86ff;--red:#ff4d52;--accent:#5b86ff;
}
body{margin:0;min-height:100vh;display:flex;flex-direction:column;
  background:
    linear-gradient(rgba(8,9,12,0) 50%,rgba(0,0,0,.18) 50%) 0 0/100% 4px,
    radial-gradient(120% 90% at 50% -10%,#0c1118,#08090c 60%);
  color:var(--ink);font:400 0.9375rem/1.65 ui-monospace,"SFMono-Regular",Menlo,Consolas,monospace}
::selection{background:var(--accent);color:#04101f}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
main{flex:1 0 auto}
.wrap{width:min(68.75rem,92vw);margin-inline:auto}
.reading{max-width:74ch}

/* header / nav */
.site-head{display:flex;align-items:center;justify-content:space-between;gap:1rem;width:min(68.75rem,92vw);margin:0 auto;padding:1.4rem 0;border-bottom:1px solid var(--line)}
.logo img{height:2.875rem;width:auto;transition:transform .4s cubic-bezier(.2,.8,.2,1)}
.logo:hover img{transform:translateY(-2px) scale(1.04)}
.site-nav{display:flex;gap:1.5rem;flex-wrap:wrap}
.site-nav a{color:var(--muted);font-size:.85rem;transition:color .25s}
.site-nav a::before{content:"./";opacity:.4}
.site-nav a:hover,.site-nav a.active{color:var(--accent)}
.site-nav a:hover::before,.site-nav a.active::before{color:var(--accent);opacity:1}

/* footer */
.site-foot{flex-shrink:0;width:min(68.75rem,92vw);margin:5rem auto 2rem;padding-top:1.5rem;border-top:1px dashed var(--line);color:var(--muted);font-size:.78rem}
.foot-social{display:flex;gap:.7rem;align-items:center;flex-wrap:wrap;margin-bottom:.6rem}
.foot-social a{color:var(--accent)}
.foot-social a::before{content:"@";opacity:.5}
.foot-social a:hover{color:var(--red)}
.foot-dot{color:var(--line)}
.foot-meta{opacity:.8}
.foot-clean{margin-top:.3rem}
.foot-meta a{color:var(--accent)}
.foot-meta a:hover{color:var(--red)}

/* reveal */
@keyframes rise{from{opacity:0;transform:translateY(22px)}to{opacity:1;transform:none}}
.reveal{animation:rise .9s both}
@supports (animation-timeline:view()){
  .reveal{animation:rise linear both;animation-timeline:view();animation-range:entry 0% entry 55%}
}
@media (prefers-reduced-motion:reduce){*{animation:none!important;transition:none!important}}

/* buttons */
.hero-actions{display:flex;gap:1rem;flex-wrap:wrap}
.btn{display:inline-block;padding:.7rem 1.4rem;font-weight:600;cursor:pointer;border-radius:6px;font-size:.85rem;transition:transform .3s,background .3s,color .3s,border-color .3s,box-shadow .3s}
.btn:hover{transform:translateY(-2px)}
.btn-primary{background:var(--accent);color:#04101f}
.btn-primary:hover{box-shadow:0 0 0 3px rgba(91,134,255,.25)}
.btn-ghost{border:1px solid var(--line);color:var(--ink)}
.btn-ghost:hover{border-color:var(--accent);color:var(--accent)}

/* hero */
.hero{position:relative;min-height:80vh;display:flex;align-items:center;width:min(68.75rem,92vw);margin-inline:auto}
.hero-bg{position:absolute;inset:0;background-size:cover;background-position:center;opacity:.16;filter:saturate(.85);z-index:-1}
.hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:2.6rem;align-items:center;width:100%}
.hero-side{display:flex;flex-direction:column;gap:1.4rem;min-width:0;position:relative;z-index:1}
.hero-inner{border:1px solid var(--line);background:rgba(14,17,23,.72);backdrop-filter:blur(2px);padding:2.6rem 2.4rem 2.4rem;border-radius:8px;position:relative}
.hero-inner::before{content:"";position:absolute;top:1rem;left:1.2rem;width:10px;height:10px;border-radius:50%;background:var(--red);
  box-shadow:18px 0 0 #2a3140,36px 0 0 #2a3140}
.hero-kicker{color:var(--accent);font-size:.8rem;margin:1.4rem 0 0}
.hero-kicker::before{content:"$ whoami --domain "}
.hero-title{font-size:clamp(2.2rem,7vw,4.2rem);margin:.4rem 0;color:var(--ink);font-weight:600;line-height:1.05}
.hero-title::after{content:"_";color:var(--accent);animation:blink 1.1s steps(1) infinite}
@keyframes blink{50%{opacity:0}}
.hero-tagline{color:var(--muted);font-size:1.05rem;margin:1rem 0 2rem}
.hero-tagline::before{content:"// ";color:var(--accent)}

/* stats strip (lives in the hero side column) */
.stats-strip{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem 1.2rem;padding:1.4rem;border:1px solid var(--line);border-radius:8px;background:var(--panel)}
.stat-n{display:block;font-size:1.9rem;color:var(--accent);font-weight:600}
.stat-l{color:var(--muted);font-size:.78rem}
.stat-l::before{content:"> "}

/* featured */
.featured{margin-top:4rem}
.section-head{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:1.6rem;border-bottom:1px dashed var(--line);padding-bottom:.6rem}
.section-h2{font-size:1.2rem;margin:0}
.section-h2::before{content:"# ";color:var(--accent)}
.more-link{color:var(--accent);font-size:.85rem}
.more-link:hover{color:var(--red)}

/* trips — cover (flag/preview) kept at its natural aspect, links to a sub-page */
.sub-h{font-size:.95rem;margin:2.6rem 0 1.1rem;color:var(--muted);text-transform:uppercase;letter-spacing:.12em;font-weight:600}
.sub-h::before{content:"# ";color:var(--accent)}
.trips{margin-top:1rem}
.trip-grid{display:grid;gap:1.2rem;grid-template-columns:repeat(auto-fit,minmax(20rem,1fr))}
.trip{display:flex;align-items:center;gap:1.2rem;padding:1rem 1.2rem;border:1px solid var(--line);border-radius:10px;background:var(--panel);
  transition:border-color .3s,transform .3s,box-shadow .3s;animation:rise .8s both;animation-delay:calc(var(--i,0)*.07s)}
.trip:hover{border-color:var(--accent);transform:translateY(-3px);box-shadow:0 16px 36px -24px #000}
.trip-flag{flex:0 0 auto;display:flex}
.trip-flag img{height:5.25rem;width:auto;display:block;border:1px solid var(--line);border-radius:4px}
.trip-body{display:flex;flex-direction:column;min-width:0}
.trip-title{font-size:1.5rem;font-weight:600;line-height:1.1}
.trip-title::before{content:"> ";color:var(--accent)}
.trip-count{color:var(--accent);font-size:.85rem;margin-top:.3rem}
.trip-summary{color:var(--muted);font-size:.82rem;margin-top:.55rem;line-height:1.5}

/* panorama rows — one wide panorama per line, name reveals on hover */
.pano-list{display:grid;gap:1.4rem}
.prow{position:relative;display:block;width:100%;overflow:hidden;border-radius:10px;line-height:0;
  animation:rise .8s both;animation-delay:calc(var(--i,0)*.07s)}
.prow-img{width:100%;height:auto;display:block;
  transition:transform .9s cubic-bezier(.2,.8,.2,1),filter .5s;filter:saturate(.95)}
.prow:hover .prow-img{transform:scale(1.04);filter:saturate(1.08)}
.prow .noimg{width:100%;aspect-ratio:3/1}
.noimg{background:linear-gradient(135deg,#12151b,#1b2230)}
.prow-scrim{position:absolute;inset:0;pointer-events:none;opacity:0;transition:opacity .45s;
  background:linear-gradient(100deg,rgba(6,8,12,.94) 0%,rgba(6,8,12,.74) 26%,rgba(6,8,12,.28) 46%,transparent 64%)}
.prow:hover .prow-scrim{opacity:1}
.prow-label{position:absolute;top:50%;left:clamp(1.1rem,3.5vw,2.6rem);max-width:74%;
  transform:translateY(-50%) translateX(-16px);opacity:0;transition:opacity .45s,transform .5s cubic-bezier(.2,.8,.2,1)}
.prow:hover .prow-label{opacity:1;transform:translateY(-50%)}
.prow-num{display:block;color:var(--red);font-size:.8rem;margin-bottom:.35rem}
.prow-num::before{content:"["}.prow-num::after{content:"]"}
.prow-title{display:block;font-size:clamp(1.4rem,3.6vw,2.4rem);font-weight:600;line-height:1.08;color:var(--ink)}
.prow-title::before{content:"> ";color:var(--accent)}
.prow-meta{display:block;margin-top:.55rem;color:var(--muted);font-size:.85rem}
.prow-meta::before{content:"// "}
.prow-meta .ex{color:var(--accent)}
.prow-badge{position:absolute;right:.8rem;top:.8rem;z-index:2;padding:.25rem .6rem;font-size:.72rem;font-weight:700;
  letter-spacing:.06em;background:var(--accent);color:#04101f;border-radius:4px}
/* touch devices have no hover — always show the name */
@media (hover:none){
  .prow-scrim{opacity:1}
  .prow-label{opacity:1;transform:translateY(-50%)}
}

/* page intros & prose */
.page-intro{padding:2.6rem 0 1rem}
.page-h1{font-size:clamp(2rem,6vw,3.2rem);margin:.2rem 0;font-weight:600}
.page-h1::before{content:"~/ ";color:var(--accent)}
.page-sub{color:var(--muted)}
.lead{font-size:1.25rem;color:var(--ink);max-width:42ch;line-height:1.5}
.lead::before{content:"/* ";color:var(--accent)}.lead::after{content:" */";color:var(--accent)}
.prose p{margin:0 0 1.3rem}
.prose .signoff,.outro{color:var(--accent)}
.prose .signoff::before,.outro::before{content:"$ ";opacity:.6}
/* inline links inside article prose — the global reset strips link styling, so
   give them an accent colour + soft underline (the signoff/outro keep theirs) */
.prose p a,.prose li a{color:var(--accent);text-decoration:underline;text-decoration-thickness:1px;
  text-underline-offset:.18em;text-decoration-color:rgba(91,134,255,.45);transition:color .2s,text-decoration-color .2s}
.prose p a:hover,.prose li a:hover{color:var(--red);text-decoration-color:var(--red)}
.prose p a[href^="http"]::after{content:"↗";display:inline-block;margin-left:.12em;font-size:.82em;vertical-align:.05em}
/* anti-harvest contact: no mailto, broken string ("privacy [at] meieralex [dot] com") */
.email{color:var(--accent);white-space:nowrap}
.email i{color:var(--muted);font-style:normal}
.insight-h{font-size:1.2rem;margin:2.6rem 0 1rem;padding-top:1.3rem;border-top:1px dashed var(--line);font-weight:600}
.insight-h::before{content:"## ";color:var(--accent)}

/* big stats */
.bigstats{display:grid;grid-template-columns:repeat(auto-fit,minmax(9.375rem,1fr));gap:1.2rem;margin:2rem 0}
.bigstat{border:1px solid var(--line);border-radius:8px;padding:1.1rem;background:var(--panel)}
.bigstat-n{display:block;font-size:1.9rem;color:var(--accent);font-weight:600}
.bigstat-l{color:var(--muted);font-size:.78rem}

/* figures */
.fig{margin:1.8rem 0;border:1px solid var(--line);border-radius:8px;overflow:hidden;background:var(--panel)}
.fig img{width:100%;display:block}
.fig figcaption{padding:.7rem .9rem;color:var(--muted);font-size:.8rem;border-top:1px solid var(--line)}
.fig figcaption::before{content:"// ";color:var(--accent)}
.fig-wide img{max-height:62vh;object-fit:cover}
/* wide hero image on the Insights page — breaks out of the reading column */
.insight-hero{margin:0 0 2.5rem}

/* source-frame strip */
.frame-strip{margin:1.8rem 0}
.strip-imgs{display:grid;grid-template-columns:repeat(auto-fill,minmax(3.2rem,1fr));gap:.35rem}
.strip-imgs img{width:100%;aspect-ratio:3/4;object-fit:cover;border:1px solid var(--line);border-radius:3px;display:block}
.frame-strip figcaption{margin-top:.7rem;color:var(--muted);font-size:.8rem}
.frame-strip figcaption::before{content:"// ";color:var(--accent)}

/* cube-face cross */
.cube-fig{margin:1.8rem 0}
.cube-cross{display:grid;grid-template-columns:repeat(3,1fr);gap:.35rem;max-width:30rem;
  grid-template-areas:". u ." "l f r" ". d ."}
.cube-cross img{width:100%;aspect-ratio:1;object-fit:cover;border:1px solid var(--line);border-radius:3px;background:#05060a;display:block}
.cube-fig figcaption{margin-top:.7rem;color:var(--muted);font-size:.8rem}
.cube-fig figcaption::before{content:"// ";color:var(--accent)}

/* pure-SVG process diagrams (tile pyramid, in-memory pipeline) */
.diagram{margin:1.8rem 0;border:1px solid var(--line);border-radius:8px;overflow:hidden;background:var(--panel)}
.diagram svg{display:block;width:100%;height:auto;background:#0a0d12}
.diagram figcaption{padding:.7rem .9rem;color:var(--muted);font-size:.8rem;border-top:1px solid var(--line)}
.diagram figcaption::before{content:"// ";color:var(--accent)}
.diagram text{font-family:ui-monospace,SFMono-Regular,Menlo,monospace}
.diagram .hd{fill:var(--muted);font-size:11px;letter-spacing:.04em;text-transform:uppercase}
.diagram .hd.ok{fill:var(--accent);text-transform:none;letter-spacing:0;font-size:12px}
.diagram .lvl{fill:var(--accent);font-size:12px;font-weight:600}
.diagram .sub{fill:var(--muted);font-size:11px}
.diagram .ell{fill:var(--muted);font-size:20px}
.diagram .pl rect{fill:rgba(91,134,255,.08);stroke:var(--accent);stroke-width:1}
.diagram .pl rect.full{fill:rgba(91,134,255,.2)}
.diagram .pl .grid line{stroke:rgba(91,134,255,.4);stroke-width:1}
.diagram .ram{fill:rgba(91,134,255,.05);stroke:var(--accent);stroke-width:1;stroke-dasharray:5 4}
.diagram .step{fill:rgba(91,134,255,.12);stroke:var(--accent);stroke-width:1}
.diagram .st{fill:var(--ink);font-size:12px}
.diagram .arr{fill:var(--accent)}
.diagram .disk{fill:none;stroke:var(--line);stroke-width:1}
.diagram .struck{fill:var(--red);font-size:11px;text-decoration:line-through}

/* code */
.code{margin:1.6rem 0;border:1px solid var(--line);border-radius:8px;overflow:hidden;background:#0a0d12}
.code-cap{padding:.5rem .9rem;font-size:.74rem;color:var(--muted);border-bottom:1px solid var(--line);background:var(--panel)}
.code-cap::before{content:"› ";color:var(--accent)}
.code pre{margin:0;padding:1rem;overflow-x:auto}
.code code{font-size:.82rem;line-height:1.6;color:#aebbe6}

/* callout (red — stderr energy) */
.callout{margin:1.8rem 0;padding:1rem 1.1rem;border:1px solid rgba(255,77,82,.45);border-left:3px solid var(--red);border-radius:8px;background:rgba(255,77,82,.06)}
.callout-h{display:block;color:var(--red);font-size:.78rem;letter-spacing:.04em;text-transform:uppercase;margin-bottom:.4rem}
.callout-h::before{content:"! "}
.callout p{margin:0;color:var(--ink);font-size:.92rem}

/* paths list (terapixel) */
.paths{display:grid;gap:.8rem;margin:1.4rem 0;padding:0}
.paths dt{color:var(--accent);font-weight:600}
.paths dt::before{content:"› "}
.paths dd{margin:.2rem 0 0;color:var(--ink)}

/* contact / link lists */
.links{list-style:none;padding:0;margin:1rem 0}
.links li{margin:.4rem 0}
.links a{color:var(--accent)}
.links a::before{content:"@";opacity:.5}
.links a:hover{color:var(--red)}
.dim{color:var(--muted);font-size:.8rem}

/* astro steps */
.astro-step{margin:1.6rem 0;border:1px solid var(--line);border-radius:8px;overflow:hidden;background:var(--panel)}
.astro-step img{width:100%}
.astro-step figcaption{padding:.7rem .9rem;color:var(--muted);font-size:.85rem;border-top:1px solid var(--line)}
.astro-t{color:var(--accent);font-weight:600}
.astro-t::before{content:"["}.astro-t::after{content:"] "}

/* viewer page */
.view-main{width:min(68.75rem,92vw);margin:1.5rem auto 0}
.view-top{display:flex;justify-content:space-between;align-items:flex-end;gap:1rem;flex-wrap:wrap;margin-bottom:1rem}
.view-title{font-size:1.8rem;margin:0;font-weight:600}
.view-title::before{content:"> ";color:var(--accent)}
.view-meta{color:var(--muted);margin:.3rem 0 0;font-size:.85rem}
.back-link{color:var(--accent);font-size:.85rem}
.back-link::before{content:"cd .. "}
.back-link:hover{color:var(--red)}
.pano-embed{width:100%;height:72vh;min-height:23.75rem;border:1px solid var(--line);border-radius:8px;overflow:hidden}
.view-hint{color:var(--muted);font-size:.8rem;margin-top:1rem}
.view-hint::before{content:"# "}
.view-summary{max-width:64ch;font-size:1.05rem}
.view-desc{max-width:64ch;color:var(--muted);line-height:1.6}
.view-specs{display:flex;flex-wrap:wrap;gap:1.6rem;margin:1.6rem 0 0;padding:0}
.view-specs .spec dt{font-size:.72rem;letter-spacing:.06em;text-transform:uppercase;color:var(--muted)}
.view-specs .spec dd{margin:.2rem 0 0;font-size:1.15rem;font-weight:600;color:var(--accent)}

/* 418 */
.page-418 .teapot{min-height:70vh;display:grid;place-content:center;justify-items:center;text-align:center;gap:.4rem}
.teapot-art{color:var(--accent);animation:tilt 4s ease-in-out infinite}
@keyframes tilt{0%,100%{transform:rotate(-4deg)}50%{transform:rotate(6deg)}}
.teapot-code{font-size:clamp(3.5rem,14vw,8rem);margin:.4rem 0 0;color:var(--accent);font-weight:600}
.teapot-code::before{content:"ERR ";font-size:.4em;color:var(--red);vertical-align:super}
.teapot-line{font-size:1.4rem;margin:0}
.teapot-line::before{content:"$ ";color:var(--accent)}
.teapot-sub{color:var(--muted)}
.teapot .btn{margin-top:1.6rem}

/* ---- pixel counter (pure CSS, animates 0 -> 76,000,000,000 on load) ------- */
@property --pixels{syntax:"<integer>";initial-value:76;inherits:false}
.counterband{text-align:left}
.odo-num{display:block;font-size:clamp(1.7rem,4.4vw,2.7rem);font-weight:600;color:var(--accent);
  font-variant-numeric:tabular-nums;letter-spacing:.01em;line-height:1;white-space:nowrap;
  --pixels:76;counter-reset:pixels var(--pixels);animation:roll 2.8s cubic-bezier(.12,.7,.15,1) both}
.odo-num::after{content:counter(pixels) ",000,000,000"}
@keyframes roll{from{--pixels:0}}
.odo-label{display:block;color:var(--muted);margin-top:.6rem;font-size:.9rem}
.odo-label::before{content:"> ";color:var(--accent)}
@media (prefers-reduced-motion:reduce){.odo-num{animation:none}}

/* ---- reveal: staged zoom ladder (per-image keyframes are generated inline) -- */
.reveal-scene{position:relative;margin-top:5rem;view-timeline-name:--rvl;view-timeline-axis:block}
.reveal-sticky{position:sticky;top:0;height:100vh;display:grid;place-items:center;overflow:hidden;background:#05060a}
/* blurred ambient fill — turns the letterbox into a premium backdrop (no black
   bars) and brightens any crossfade bleed-through */
.reveal-ambient{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0;
  filter:blur(16px) saturate(1.08) brightness(.9);transform:scale(1.1)}
.reveal-band{position:relative;z-index:1;width:100%;overflow:hidden;
  aspect-ratio:var(--rv-aspect,2560 / 960);box-shadow:0 30px 80px -30px #000}
.rv{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transform-origin:50% 50%;
  opacity:0;backface-visibility:hidden}
.rv-0{opacity:1}                       /* no-animation fallback: show the widest */
.reveal-hint{position:absolute;top:1rem;left:50%;transform:translateX(-50%);z-index:30;
  color:#cdd8e6;font-size:.75rem;background:rgba(6,8,13,.5);padding:.3rem .75rem;border-radius:6px;backdrop-filter:blur(4px)}
.reveal-caps{position:absolute;left:0;right:0;bottom:7%;z-index:30;display:grid;place-items:center;padding:0 1rem}
.reveal-cap{grid-area:1/1;margin:0;max-width:min(52ch,92vw);text-align:center;
  font-size:clamp(1rem,2.8vw,1.5rem);color:#eaf0f8;
  background:rgba(6,8,13,.5);backdrop-filter:blur(6px);padding:.5rem 1.15rem;border-radius:10px;
  border:1px solid rgba(91,134,255,.2);text-shadow:0 1px 3px #000}
.reveal-cap b{color:var(--accent)}
a.reveal-cap{transition:border-color .3s}
a.reveal-cap:hover{border-color:var(--accent)}
.cap-b{opacity:0}
@media (prefers-reduced-motion:reduce){
  .reveal-scene{height:auto!important}
  .reveal-sticky{position:static;height:auto}
  .rv:not(.rv-0){display:none}
  .rv-0{opacity:1;transform:none}
  .reveal-hint{display:none}.cap-a{display:none}.cap-b{opacity:1}
}
/* phones: an 8:3 strip is too thin — crop to a taller frame (detail is centred,
   so the sides crop away safely) and shrink the caption */
@media (max-width:640px){
  .reveal-band{aspect-ratio:16 / 9}
  .reveal-cap{font-size:.82rem;max-width:94vw;padding:.45rem .8rem}
  .reveal-caps{bottom:5%}
  .reveal-hint{font-size:.68rem}
}

/* ---- mobile ---------------------------------------------------------------
   Phones drop the 135% zoom back to a comfortable base and stack the header.
   Desktop/tablet (> 640px) keep the exact desktop feel, just zoomed. */
@media (max-width:640px){
  html{font-size:100%}
  .site-head{flex-direction:column;align-items:center;gap:.8rem;padding:1.1rem 0;text-align:center}
  .site-nav{justify-content:center;gap:.7rem 1rem;font-size:.82rem}
  .hero{min-height:auto;padding:1.5rem 0}
  .hero-grid{grid-template-columns:1fr;gap:1.6rem}
  .hero-inner{padding:1.8rem 1.3rem 1.5rem;max-width:100%}
  .hero-title{font-size:clamp(2rem,11vw,2.8rem)}
  .stats-strip{padding:1.2rem;gap:1.1rem 1rem}
  .section-head{flex-wrap:wrap;gap:.3rem .8rem}
  .view-top{align-items:flex-start}
  .pano-embed{height:62vh}
  .bigstats{grid-template-columns:repeat(2,1fr)}
  .prow-title{font-size:clamp(1.3rem,7vw,2rem)}
  .prow-scrim{opacity:1}
  .prow-label{opacity:1;transform:translateY(-50%)}
  .foot-meta{line-height:1.7}
}
@media (max-width:380px){
  .bigstats{grid-template-columns:1fr}
}
