/* ============================================================
   mireda.me  ·  engineer-instrument minimalism
   ============================================================ */

:root{
  --bg:        #0a0c10;
  --bg-2:      #0e1116;
  --panel:     #10141a;
  --panel-2:   #131820;
  --border:    rgba(255,255,255,0.07);
  --border-2:  rgba(255,255,255,0.13);
  --fg:        #e8eaed;
  --fg-dim:    #9aa3ad;
  --fg-mute:   #5d6772;
  --accent:    #b8ff5c;            /* phosphor green */
  --accent-2:  #6df0c8;            /* mint */
  --warm:      #ff8a47;            /* warning amber */
  --warm-2:    #ffd166;
  --danger:    #ff5470;

  --font-sans: "Space Grotesk", ui-sans-serif, system-ui, -apple-system, "Helvetica Neue", Arial, sans-serif;
  --font-mono: "JetBrains Mono", ui-monospace, "SF Mono", Menlo, Consolas, monospace;

  --maxw: 1240px;
  --pad-x: clamp(20px, 4vw, 64px);
}

*{box-sizing:border-box;margin:0;padding:0;}
html,body{background:var(--bg);color:var(--fg);font-family:var(--font-sans);}
html{scroll-behavior:smooth;}
body{
  min-height:100vh;
  font-size:16px;
  line-height:1.5;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
a{color:inherit;text-decoration:none;}
button{font:inherit;color:inherit;background:none;border:0;cursor:pointer;}
ul,ol{list-style:none;}
canvas{display:block;}

.mono{font-family:var(--font-mono);}
.dim{color:var(--fg-mute);}
.hl{color:var(--accent);}
.hl-warm{color:var(--warm);}

/* ============================================================
   BACKGROUNDS
   ============================================================ */
.bg-grid{
  position:fixed; inset:0; z-index:0; pointer-events:none;
  background-image:
    linear-gradient(rgba(255,255,255,0.018) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,0.018) 1px, transparent 1px);
  background-size: 56px 56px;
  mask-image: radial-gradient(ellipse at 50% 30%, #000 30%, transparent 80%);
  -webkit-mask-image: radial-gradient(ellipse at 50% 30%, #000 30%, transparent 80%);
}
.bg-scanline{
  position:fixed; inset:0; z-index:0; pointer-events:none;
  background: repeating-linear-gradient(
    to bottom,
    rgba(255,255,255,0.012) 0px,
    rgba(255,255,255,0.012) 1px,
    transparent 1px,
    transparent 3px
  );
  mix-blend-mode: overlay;
}
.bg-vignette{
  position:fixed; inset:0; z-index:0; pointer-events:none;
  background: radial-gradient(ellipse at 70% 0%, rgba(184,255,92,0.06), transparent 50%),
              radial-gradient(ellipse at 0% 80%, rgba(255,138,71,0.05), transparent 55%);
}

/* ============================================================
   SCENE BACKGROUNDS (cross-fading schematic art)
   ============================================================ */
.scene-bg{
  position: fixed; inset:0; z-index:0; pointer-events:none;
  overflow:hidden;
}
.scene{
  position:absolute; inset:0;
  opacity: 0;
  transition: opacity 1.4s ease;
  display:flex; align-items:center; justify-content:center;
  /* very subtle drift to give the schematic life */
  animation: scene-drift 38s ease-in-out infinite alternate;
  will-change: transform, opacity;
}
.scene.is-active{ opacity: 0.22; }
.scene svg{
  width: 110%;
  height: 110%;
  display:block;
  filter: drop-shadow(0 0 12px currentColor);
}
/* per-scene drift offsets so they don't all move identically */
.scene[data-scene="pcb"]     { animation-duration: 42s; }
.scene[data-scene="engine"]  { animation-duration: 36s; animation-delay: -10s; }
.scene[data-scene="mcu"]     { animation-duration: 48s; animation-delay: -22s; }
.scene[data-scene="bus"]     { animation-duration: 40s; animation-delay: -6s;  }
.scene[data-scene="harness"] { animation-duration: 44s; animation-delay: -16s; }

@keyframes scene-drift{
  0%   { transform: translate3d(-1.5%, -1%, 0) scale(1.04); }
  50%  { transform: translate3d( 1%,    1.2%, 0) scale(1.06); }
  100% { transform: translate3d(-0.8%,  0.6%, 0) scale(1.05); }
}

@media (prefers-reduced-motion: reduce){
  .scene{ animation:none; }
}

/* ============================================================
   BOOT
   ============================================================ */
.boot{
  position:fixed; inset:0; z-index:100;
  background: #06080b;
  display:flex; align-items:flex-start; justify-content:center;
  padding: 14vh var(--pad-x) 80px;
  transition: opacity .6s ease, visibility .6s;
  overflow-y: auto;
}
.boot.is-done{ opacity:0; visibility:hidden; pointer-events:none; }
.boot-log{
  font-family:var(--font-mono);
  font-size:13px;
  line-height:1.7;
  color:var(--fg-dim);
  white-space: pre-wrap;
  word-break: break-word;
  max-width: 720px;
  width:100%;
  letter-spacing:0.01em;
}
.boot-log .ok{ color: var(--accent); }
.boot-log .warm{ color: var(--warm); }
.boot-log .fg{ color: var(--fg); }
.boot-skip{
  position:fixed; right: var(--pad-x); bottom: 32px;
  font-family:var(--font-mono); font-size:11px; color:var(--fg-mute);
  letter-spacing:0.08em;
  padding:8px 12px; border:1px solid var(--border);
  transition: color .2s, border-color .2s;
}
.boot-skip:hover{ color:var(--fg); border-color: var(--border-2); }
@media (max-width: 520px){
  .boot{ padding-top: 8vh; }
  .boot-log{ font-size: 11px; line-height: 1.6; }
}

/* ============================================================
   NAV
   ============================================================ */
.nav{
  position: sticky; top:0; z-index:50;
  display:flex; align-items:center; gap:24px;
  padding: 18px var(--pad-x);
  background: linear-gradient(to bottom, rgba(10,12,16,0.85), rgba(10,12,16,0.55));
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  border-bottom: 1px solid var(--border);
}
.nav-brand{ display:inline-flex; align-items:center; gap:10px; font-family:var(--font-mono); font-weight:600; letter-spacing:0.02em; }
.brand-dot{
  width:10px; height:10px; background:var(--accent);
  box-shadow: 0 0 12px rgba(184,255,92,0.7), 0 0 2px rgba(184,255,92,1);
  border-radius:1px;
  animation: brand-blink 2.6s steps(1,end) infinite;
}
@keyframes brand-blink{
  0%, 92%, 100%{ opacity:1; }
  94%, 98%{ opacity:0.25; }
}
.brand-text{ font-size:14px; }
.brand-tld{ color: var(--fg-mute); }

.nav-links{ display:flex; gap:22px; margin-left:auto; }
.nav-links a{
  font-family:var(--font-mono); font-size:12px;
  color:var(--fg-dim);
  letter-spacing:0.06em; text-transform:lowercase;
  padding: 4px 0;
  position:relative;
  transition: color .2s;
}
.nav-links a::after{
  content:""; position:absolute; left:0; right:0; bottom:-2px;
  height:1px; background:var(--accent);
  transform: scaleX(0); transform-origin: left;
  transition: transform .25s ease;
}
.nav-links a:hover{ color:var(--fg); }
.nav-links a:hover::after{ transform: scaleX(1); }

.nav-status{
  display:inline-flex; align-items:center; gap:8px;
  font-family:var(--font-mono); font-size:11px; color:var(--fg-mute);
  letter-spacing:0.06em;
}
.nav-sep{ opacity:0.5; }
.pulse-dot{
  width:6px; height:6px; border-radius:50%;
  background: var(--accent);
  box-shadow: 0 0 0 0 rgba(184,255,92,0.6);
  animation: pulse 2s ease-out infinite;
}
@keyframes pulse{
  0%   { box-shadow: 0 0 0 0 rgba(184,255,92,0.55); }
  70%  { box-shadow: 0 0 0 8px rgba(184,255,92,0); }
  100% { box-shadow: 0 0 0 0 rgba(184,255,92,0); }
}

/* ============================================================
   SHARED
   ============================================================ */
main{ position:relative; z-index:1; }

section{
  max-width: var(--maxw);
  margin: 0 auto;
  padding: 0 var(--pad-x);
}

.section-head{
  display:flex; align-items:center; gap:14px;
  margin: 96px 0 32px;
  font-family:var(--font-mono);
  font-size: 12px;
  letter-spacing: 0.12em;
}
.sec-idx{ color: var(--accent); }
.sec-title{ color: var(--fg); }
.sec-meta{ color: var(--fg-mute); margin-left:auto; }
.sec-rule{ flex:1 1 80px; height:1px; background: var(--border); }

.reveal{ opacity:0; transform: translateY(20px); transition: opacity .9s ease, transform .9s ease; }
.reveal.is-in{ opacity:1; transform:none; }

/* ============================================================
   HERO
   ============================================================ */
.hero{
  position:relative;
  max-width: var(--maxw);
  margin: 0 auto;
  padding: 32px var(--pad-x) 80px;
  min-height: calc(100vh - 60px);
  display:flex; flex-direction:column; justify-content:center;
}
.hero-grid{
  display:grid;
  grid-template-columns: 1.15fr 1fr;
  gap: 48px;
  align-items:center;
}
@media (max-width: 980px){
  .hero-grid{ grid-template-columns: 1fr; gap:40px; }
}

.kicker{
  display:inline-flex; gap:10px; align-items:center;
  font-family:var(--font-mono); font-size:11px;
  color:var(--fg-mute); letter-spacing:0.08em;
  margin-bottom: 28px;
}
.kicker-id{ color: var(--accent); }
.kicker-role{ color: var(--fg-dim); }
.kicker-sep{ opacity:0.5; }

.hero-name{
  font-family: var(--font-sans);
  font-weight: 500;
  line-height: 0.92;
  letter-spacing: -0.04em;
}
.hn-line{
  display:block;
  font-size: clamp(72px, 11vw, 168px);
  background: linear-gradient(180deg, #ffffff 0%, #9aa3ad 100%);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  color: transparent;
}
.hn-sub{
  display:block;
  margin-top: 14px;
  font-family:var(--font-mono);
  font-weight:400;
  font-size: clamp(14px, 1.5vw, 18px);
  letter-spacing: 0.02em;
  color: var(--fg-dim);
}
.hn-sub .caret{ color: var(--accent); margin-right:8px; }
.hn-sub .typer{ color: var(--fg); }
.cursor{
  display:inline-block; width:0.55ch; color:var(--accent);
  animation: blink 1.05s steps(1,end) infinite;
}
@keyframes blink{ 50%{ opacity:0; } }

.hero-lede{
  max-width: 480px;
  margin-top: 32px;
  font-size: 16.5px;
  line-height: 1.6;
  color: var(--fg-dim);
}

.hero-cta{ display:flex; gap:12px; margin-top: 32px; flex-wrap:wrap; }
.btn{
  display:inline-flex; align-items:center; gap:8px;
  font-family:var(--font-mono); font-size:12.5px;
  letter-spacing: 0.06em;
  padding: 12px 16px;
  border: 1px solid var(--border-2);
  transition: all .2s ease;
}
.btn-primary{ background: var(--accent); color:#0a0c10; border-color: var(--accent); }
.btn-primary:hover{ background: #cfff7a; box-shadow: 0 0 24px rgba(184,255,92,0.35); transform: translateY(-1px); }
.btn-ghost{ color: var(--fg); }
.btn-ghost:hover{ border-color: var(--fg); background: rgba(255,255,255,0.03); }

/* CAN bus stream */
.canbus{
  margin-top: 56px;
  border: 1px solid var(--border);
  background: linear-gradient(to right, rgba(184,255,92,0.04), transparent 60%);
  max-width: 540px;
}
.canbus-head{
  display:flex; align-items:center; gap:10px;
  padding: 8px 12px;
  border-bottom: 1px solid var(--border);
  font-family:var(--font-mono); font-size:10.5px;
  color:var(--fg-mute); letter-spacing:0.08em;
}
.canbus-label{ color: var(--accent); }
.canbus-sep{ opacity:0.5; }
.canbus-load em{ color: var(--fg); font-style:normal; }
.canbus-wrap{ height: 112px; overflow:hidden; position:relative; }
.canbus-wrap::before, .canbus-wrap::after{
  content:""; position:absolute; left:0; right:0; height:24px; z-index:2; pointer-events:none;
}
.canbus-wrap::before{ top:0; background: linear-gradient(to bottom, var(--bg), transparent); }
.canbus-wrap::after{ bottom:0; background: linear-gradient(to top, var(--bg), transparent); }
.canbus-list{
  font-family:var(--font-mono); font-size:11.5px;
  padding: 8px 12px;
  display:flex; flex-direction:column; gap:4px;
}
.canbus-list li{
  display:grid;
  grid-template-columns: 56px 72px 1fr 50px;
  gap:14px;
  color:var(--fg-dim);
  animation: can-in .4s ease-out;
}
.canbus-list .can-t{ color: var(--fg-mute); }
.canbus-list .can-id{ color: var(--accent); }
.canbus-list .can-data{ color: var(--fg); }
.canbus-list .can-len{ color: var(--fg-mute); text-align:right; }
.canbus-list .alert .can-id{ color: var(--warm); }
@keyframes can-in{ from{ opacity:0; transform:translateY(-6px); } to{ opacity:1; transform:none; } }

/* ============================================================
   TELEMETRY PANEL
   ============================================================ */
.telemetry{
  position:relative;
  background: linear-gradient(180deg, var(--panel) 0%, var(--panel-2) 100%);
  border: 1px solid var(--border-2);
  padding: 16px;
  display:grid;
  grid-template-columns: 1fr;
  gap: 14px;
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,0.04),
    0 30px 80px -40px rgba(0,0,0,0.8),
    0 0 60px -20px rgba(184,255,92,0.08);
}
.telemetry::before{
  content:""; position:absolute; inset:-1px; pointer-events:none;
  background:
    linear-gradient(135deg, transparent 0, transparent 60%, rgba(184,255,92,0.15) 100%);
  mask: linear-gradient(#000,#000) content-box, linear-gradient(#000,#000);
  -webkit-mask: linear-gradient(#000,#000) content-box, linear-gradient(#000,#000);
  mask-composite: exclude; -webkit-mask-composite: xor;
  padding:1px;
}
.tele-head{
  display:flex; align-items:center; justify-content:space-between;
  font-family:var(--font-mono); font-size:11px; color:var(--fg-mute);
  letter-spacing:0.1em;
}
.tele-title{ color: var(--accent); }
.tele-handles{ display:inline-flex; gap:5px; }
.tele-handles i{
  width:8px; height:8px; border:1px solid var(--border-2); display:inline-block;
}
.tele-handles i:nth-child(1){ background: var(--warm); border-color: var(--warm); }
.tele-handles i:nth-child(2){ background: var(--warm-2); border-color: var(--warm-2); }
.tele-handles i:nth-child(3){ background: var(--accent); border-color: var(--accent); }

.tele-block{
  background: rgba(0,0,0,0.25);
  border: 1px solid var(--border);
  padding: 12px;
}
.tele-row{
  display:flex; gap:14px; align-items:center;
  font-family:var(--font-mono); font-size:10.5px;
  color: var(--fg-mute);
  letter-spacing: 0.08em;
  margin-bottom: 6px;
}
.tele-k{ color: var(--fg-mute); }
.tele-k2{ margin-left:auto; }
.tele-v{ color: var(--fg); }

.tele-scope canvas{
  width:100%; height: 160px;
  border: 1px solid var(--border);
  background:
    linear-gradient(to right, rgba(184,255,92,0.04), transparent 70%),
    radial-gradient(ellipse at 50% 50%, rgba(184,255,92,0.04), transparent 70%),
    #06080b;
}
.scope-foot{
  margin-top: 8px;
  display:flex; gap:14px;
  font-family:var(--font-mono); font-size:10.5px; color:var(--fg-mute);
  letter-spacing:0.06em;
}
.scope-foot em{ color: var(--fg); font-style:normal; }

.tele-gauges{
  display:grid; grid-template-columns: 1fr 1fr; gap:14px;
  background: transparent; border:0; padding:0;
}
.gauge{
  background: rgba(0,0,0,0.25);
  border: 1px solid var(--border);
  padding: 10px 12px 12px;
  display:flex; flex-direction:column; gap:6px;
}
.gauge-svg{ width:100%; height:auto; }
.gauge-meta{
  display:flex; justify-content:space-between; align-items:baseline;
  font-family:var(--font-mono); font-size:10.5px; color:var(--fg-mute);
  letter-spacing:0.08em;
}
.gauge-v em{ color: var(--fg); font-style:normal; font-weight:500; }

.tele-stats{
  display:grid; grid-template-columns: repeat(4, 1fr);
  gap: 0;
  padding: 0;
  background:transparent; border:0;
}
.stat{
  border: 1px solid var(--border);
  padding: 10px;
  display:flex; flex-direction:column; gap:4px;
}
.stat + .stat{ border-left: 0; }
.stat-k{ font-family:var(--font-mono); font-size:9.5px; color:var(--fg-mute); letter-spacing:0.1em; }
.stat-v{ font-family:var(--font-mono); font-size:13px; color:var(--fg); }
.stat-v em{ color: var(--accent); font-style:normal; font-weight:500; }

/* hero scroll cue */
.hero-scroll{
  position:absolute; left: var(--pad-x); bottom: 24px;
  display:flex; align-items:center; gap:12px;
  font-family:var(--font-mono); font-size:10.5px; color: var(--fg-mute);
  letter-spacing:0.14em; text-transform: uppercase;
}
.hero-scroll-line{
  display:block; width:48px; height:1px; background: var(--fg-mute); position:relative; overflow:hidden;
}
.hero-scroll-line::after{
  content:""; position:absolute; inset:0;
  background: var(--accent);
  transform: translateX(-100%);
  animation: scroll-cue 2.4s ease-in-out infinite;
}
@keyframes scroll-cue{
  0%   { transform: translateX(-100%); }
  50%  { transform: translateX(0); }
  100% { transform: translateX(100%); }
}

/* ============================================================
   FOCUS
   ============================================================ */
.focus-grid{
  display:grid;
  grid-template-columns: 1.4fr 1fr;
  gap: 64px;
  align-items:start;
}
@media (max-width: 900px){ .focus-grid{ grid-template-columns:1fr; gap:40px; } }

.big{
  font-size: clamp(32px, 4.4vw, 56px);
  line-height: 1.05;
  letter-spacing: -0.025em;
  font-weight: 500;
  max-width: 16ch;
  text-wrap: pretty;
}
.focus-copy p{
  margin-top: 24px;
  max-width: 56ch;
  color: var(--fg-dim);
  font-size: 16px;
  line-height: 1.65;
}

.timeline{
  border-left: 1px solid var(--border-2);
  padding-left: 20px;
  display:flex; flex-direction:column; gap: 22px;
  position:relative;
}
.timeline li{
  display:grid;
  grid-template-columns: 90px 1fr;
  gap: 16px;
  position:relative;
}
.timeline li::before{
  content:""; position:absolute; left:-26px; top:6px;
  width:9px; height:9px; background: var(--bg);
  border:1px solid var(--fg-mute);
}
.timeline li.tl-now::before{
  background: var(--accent);
  border-color: var(--accent);
  box-shadow: 0 0 0 4px rgba(184,255,92,0.15);
}
.tl-year{ font-family:var(--font-mono); font-size:12px; color: var(--accent); letter-spacing:0.06em; }
.timeline li:not(.tl-now) .tl-year{ color: var(--fg-mute); }
.tl-body{ display:flex; flex-direction:column; gap:2px; }
.tl-title{ font-size:15px; color: var(--fg); }
.tl-sub{ font-family:var(--font-mono); font-size:11.5px; color: var(--fg-mute); letter-spacing:0.04em; }

/* ============================================================
   STACK
   ============================================================ */
.stack-grid{
  display:grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 24px;
}
@media (max-width: 900px){ .stack-grid{ grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 520px){ .stack-grid{ grid-template-columns: 1fr; } }

.stack-col{
  border: 1px solid var(--border);
  padding: 18px;
  background: linear-gradient(180deg, rgba(255,255,255,0.018), transparent);
  transition: border-color .2s, transform .2s;
}
.stack-col:hover{ border-color: var(--border-2); transform: translateY(-2px); }
.stack-head{
  font-family:var(--font-mono); font-size:11px; color:var(--accent);
  letter-spacing:0.16em;
  padding-bottom: 12px; border-bottom:1px solid var(--border);
  margin-bottom: 14px;
}
.chips{ display:flex; flex-direction:column; gap: 8px; }
.chips li{
  font-family:var(--font-mono); font-size:13px;
  color: var(--fg);
  display:inline-flex; align-items:center; gap:10px;
  padding: 6px 0;
}
.chip-dot{
  width:6px; height:6px; background: var(--accent);
  border-radius: 1px;
  box-shadow: 0 0 6px rgba(184,255,92,0.5);
}
.chip-dot.warm{ background: var(--warm); box-shadow: 0 0 6px rgba(255,138,71,0.5); }

/* stagger chip indicator pulse */
.chips li:nth-child(1) .chip-dot{ animation: chip-pulse 3.4s ease-in-out infinite; }
.chips li:nth-child(2) .chip-dot{ animation: chip-pulse 3.4s ease-in-out 0.4s infinite; }
.chips li:nth-child(3) .chip-dot{ animation: chip-pulse 3.4s ease-in-out 0.8s infinite; }
.chips li:nth-child(4) .chip-dot{ animation: chip-pulse 3.4s ease-in-out 1.2s infinite; }
.chips li:nth-child(5) .chip-dot{ animation: chip-pulse 3.4s ease-in-out 1.6s infinite; }
.chips li:nth-child(6) .chip-dot{ animation: chip-pulse 3.4s ease-in-out 2.0s infinite; }
@keyframes chip-pulse{
  0%,100%{ opacity:0.35; }
  50%{ opacity:1; }
}

/* ============================================================
   WORKS
   ============================================================ */
.works-grid{
  display:grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 20px;
}
@media (max-width: 820px){ .works-grid{ grid-template-columns: 1fr; } }

.work{
  position:relative;
  display:flex; flex-direction:column; gap:10px;
  padding: 24px;
  border: 1px solid var(--border);
  background: var(--panel);
  overflow:hidden;
  transition: border-color .25s, transform .25s, background .25s;
}
.work::after{
  content:""; position:absolute; left:0; bottom:0; right:0; height:1px;
  background: linear-gradient(to right, transparent, var(--accent), transparent);
  transform: scaleX(0); transform-origin: left;
  transition: transform .5s ease;
}
.work:hover{ border-color: var(--border-2); transform: translateY(-3px); background: var(--panel-2); }
.work:hover::after{ transform: scaleX(1); }
.work:hover .work-arrow{ transform: translate(2px, -2px); color: var(--accent); }
.work:hover .work-traces svg path{ stroke: var(--accent); }

.work-traces{
  position:absolute; inset:0; pointer-events:none;
  opacity: 0.5;
  mask-image: radial-gradient(ellipse at 100% 50%, #000 0%, transparent 75%);
  -webkit-mask-image: radial-gradient(ellipse at 100% 50%, #000 0%, transparent 75%);
}
.work-traces svg{ width:100%; height:100%; }
.work-traces svg path{
  fill:none;
  stroke: var(--fg-mute);
  stroke-width: 0.6;
  stroke-dasharray: 4 6;
  animation: trace 12s linear infinite;
  transition: stroke .25s;
}
.work-traces svg path:nth-child(2){ animation-duration: 14s; animation-direction: reverse; }
.work-traces svg path:nth-child(3){ animation-duration: 10s; }
@keyframes trace{
  to{ stroke-dashoffset: -200; }
}

.work-head{
  display:flex; align-items:center; justify-content:space-between;
  font-family:var(--font-mono); font-size:11px; color:var(--fg-mute);
  letter-spacing: 0.1em;
  position:relative; z-index:1;
}
.work-lang{ display:inline-flex; align-items:center; gap:6px; color: var(--fg); }
.lang-dot{
  width:8px; height:8px; border-radius:50%;
  display:inline-block;
}
.lang-dot.c{ background: #5fa8f8; }
.lang-dot.vhdl{ background: #c89bff; }
.lang-dot.pawn{ background: #ff8a47; }
.lang-dot.html{ background: #f06363; }

.work-title{
  position:relative; z-index:1;
  font-family:var(--font-mono);
  font-size: 20px;
  font-weight: 500;
  color: var(--fg);
  letter-spacing: -0.005em;
}
.work-desc{
  position:relative; z-index:1;
  color: var(--fg-dim);
  font-size: 14.5px;
  line-height: 1.55;
  max-width: 52ch;
}
.work-foot{
  margin-top: auto;
  padding-top: 14px;
  display:flex; flex-wrap:wrap; gap: 6px;
  align-items:center;
  position:relative; z-index:1;
}
.tag{
  font-family:var(--font-mono); font-size:10.5px;
  padding: 3px 8px;
  border:1px solid var(--border);
  color: var(--fg-dim);
  letter-spacing: 0.04em;
}
.work-arrow{
  margin-left:auto;
  font-family:var(--font-mono);
  font-size: 18px;
  color: var(--fg-mute);
  transition: transform .25s, color .25s;
}

.works-more{
  display:inline-flex; align-items:center; gap:10px;
  margin-top: 32px;
  font-family:var(--font-mono); font-size:12px;
  letter-spacing:0.06em;
  color: var(--fg-dim);
  padding: 10px 14px;
  border:1px solid var(--border);
  transition: color .2s, border-color .2s, gap .2s;
}
.works-more:hover{ color: var(--accent); border-color: var(--accent); gap:14px; }

/* ============================================================
   CONTACT
   ============================================================ */
.contact{ padding-bottom: 64px; }
.contact-grid{
  display:grid;
  grid-template-columns: 1.3fr 1fr;
  gap: 48px;
  align-items:end;
}
@media (max-width: 900px){ .contact-grid{ grid-template-columns: 1fr; gap:32px; align-items:start; } }
.contact-sub{
  margin-top: 22px;
  max-width: 52ch;
  color: var(--fg-dim);
  font-size: 16px;
  line-height: 1.6;
}

.contact-list{ display:flex; flex-direction:column; gap:0; border-top: 1px solid var(--border); }
.contact-list li{ border-bottom: 1px solid var(--border); }
.contact-list a{
  display:grid;
  grid-template-columns: 110px 1fr 24px;
  gap: 20px; align-items:center;
  padding: 18px 0;
  font-family:var(--font-mono); font-size:14px;
  transition: padding .25s ease, color .25s;
}
.contact-list a:hover{ padding-left: 12px; color: var(--accent); }
.cl-k{ color: var(--fg-mute); letter-spacing:0.1em; font-size:11px; text-transform:uppercase; }
.cl-v{ color: var(--fg); }
.cl-ar{ color: var(--fg-mute); text-align:right; transition: color .25s, transform .25s; }
.contact-list a:hover .cl-ar{ color: var(--accent); transform: translate(3px,-3px); }

/* ============================================================
   FOOTER
   ============================================================ */
.foot{
  max-width: var(--maxw);
  margin: 80px auto 0;
  padding: 24px var(--pad-x);
  display:flex; align-items:center; justify-content:space-between; gap:24px;
  border-top: 1px solid var(--border);
  font-size: 12px;
  flex-wrap:wrap;
}
.foot-l, .foot-r{ display:inline-flex; gap:10px; align-items:center; flex-wrap:wrap; }
.foot-sep{ opacity:0.5; }

/* ============================================================
   small screens
   ============================================================ */
@media (max-width: 640px){
  .nav-links{ display:none; }
  .hero-scroll{ display:none; }
  .stat-v{ font-size:11.5px; }
}
