/* ---------- TOKENS ---------- */
  :root{
    --bg:#07040f;
    --bg-2:#0d0820;
    --ink:#f4e9ff;
    --ink-dim:#b8a8d4;
    --ink-mute:#6f5d8e;
    --line:rgba(255,120,230,.18);
    --line-soft:rgba(180,140,255,.10);
    --magenta:#ff3df0;
    --pink:#ff6ad5;
    --cyan:#4de8ff;
    --amber:#ffb347;
    --violet:#8a5bff;
    --accent-h:310;          /* tweakable hue */
    --accent:oklch(0.72 0.24 var(--accent-h));
    --accent-soft:oklch(0.72 0.24 var(--accent-h) / .18);
    --glitch:1;              /* 0..2 */
    --scan:1;                /* 0 or 1 */
    --density:1;             /* 0.85..1.15 */
    --maxw:1240px;
    --pad: calc(24px * var(--density));
  }

  *{box-sizing:border-box}
  html,body{margin:0;padding:0;background:var(--bg);color:var(--ink);font-family:'Inter',system-ui,sans-serif;-webkit-font-smoothing:antialiased;overflow-x:hidden}
  body{font-size: calc(15px * var(--density));line-height:1.6}
  a{color:inherit;text-decoration:none}
  img{max-width:100%;display:block}
  ::selection{background:var(--accent);color:#000}

  /* Smooth scroll + reduce motion */
  html{scroll-behavior:smooth}
  @media (prefers-reduced-motion: reduce){html{scroll-behavior:auto}}

  /* ---------- BACKDROP ---------- */
  .bg-gradient{
    position:fixed;inset:0;z-index:-3;
    background:
      radial-gradient(60% 50% at 50% 90%, rgba(255,61,240,.15), transparent 60%),
      radial-gradient(80% 60% at 50% 0%, rgba(77,232,255,.08), transparent 60%),
      linear-gradient(180deg,#060312 0%, #0a0620 40%, #07040f 100%);
  }
  .bg-stars{position:fixed;inset:0;z-index:-2;opacity:.6;pointer-events:none}
  .bg-scan{
    position:fixed;inset:0;z-index:60;pointer-events:none;opacity:calc(var(--scan)*.35);
    background:repeating-linear-gradient(180deg, rgba(255,255,255,.04) 0 1px, transparent 1px 3px);
    mix-blend-mode:overlay;
  }
  .bg-vignette{
    position:fixed;inset:0;z-index:59;pointer-events:none;
    background:radial-gradient(120% 80% at 50% 50%, transparent 50%, rgba(0,0,0,.65));
  }

  /* ---------- LAYOUT ---------- */
  .wrap{max-width:var(--maxw);margin:0 auto;padding:0 var(--pad)}
  section{position:relative;padding: calc(120px * var(--density)) 0}
  section + section::before{
    content:"";position:absolute;top:0;left:0;right:0;height:1px;
    background:linear-gradient(90deg,transparent, var(--line) 20%, var(--line) 80%, transparent);
  }

  /* ---------- NAV ---------- */
  nav.top{
    position:fixed;top:0;left:0;right:0;z-index:50;
    display:flex;align-items:center;justify-content:space-between;
    padding:18px var(--pad);
    backdrop-filter: blur(12px);
    background:linear-gradient(180deg, rgba(7,4,15,.65), rgba(7,4,15,.2));
    border-bottom:1px solid var(--line-soft);
    font-family:'JetBrains Mono',monospace;font-size:12px;letter-spacing:.08em;text-transform:uppercase;
  }
  nav.top .logo{color:var(--ink);font-weight:700}
  nav.top .logo b{color:var(--accent)}
  nav.top ul{display:flex;gap:22px;list-style:none;margin:0;padding:0}
  nav.top a{color:var(--ink-dim);transition:color .2s}
  nav.top a:hover{color:var(--accent)}
  nav.top a .n{color:var(--ink-mute);margin-right:6px}
  nav.top .cta{color:var(--accent);border:1px solid var(--accent);padding:8px 14px;border-radius:2px;box-shadow:0 0 16px var(--accent-soft)}
  nav.top .cta:hover{background:var(--accent);color:#000}

  /* burger */
  nav.top .burger{
    display:none;width:40px;height:40px;border:1px solid var(--line);
    background:rgba(7,4,15,.6);cursor:pointer;padding:0;border-radius:2px;
    position:relative;
  }
  nav.top .burger span{
    position:absolute;left:10px;right:10px;height:1.5px;background:var(--ink);
    transition:transform .3s, opacity .2s, top .3s;
  }
  nav.top .burger span:nth-child(1){top:13px}
  nav.top .burger span:nth-child(2){top:19px}
  nav.top .burger span:nth-child(3){top:25px}
  nav.top .burger.on span{background:var(--accent)}
  nav.top .burger.on span:nth-child(1){top:19px;transform:rotate(45deg)}
  nav.top .burger.on span:nth-child(2){opacity:0}
  nav.top .burger.on span:nth-child(3){top:19px;transform:rotate(-45deg)}

  /* mobile drawer */
  .mobile-menu{
    position:fixed;inset:0;z-index:48;
    background:rgba(7,4,15,.97);backdrop-filter:blur(16px);
    display:flex;flex-direction:column;align-items:center;justify-content:center;
    gap:28px;padding:80px 24px 40px;
    opacity:0;pointer-events:none;transition:opacity .3s;
    font-family:'JetBrains Mono',monospace;text-transform:uppercase;letter-spacing:.12em;
  }
  .mobile-menu.on{opacity:1;pointer-events:auto}
  .mobile-menu a{color:var(--ink);font-size:22px;display:flex;align-items:baseline;gap:12px}
  .mobile-menu a .n{color:var(--ink-mute);font-size:13px}
  .mobile-menu a:hover, .mobile-menu a:focus{color:var(--accent)}
  .mobile-menu .cta{
    color:var(--accent);border:1px solid var(--accent);padding:14px 24px;
    margin-top:10px;font-size:13px;
  }

  @media(max-width:780px){
    nav.top{padding:14px var(--pad)}
    nav.top ul{display:none}
    nav.top > .cta{display:none}
    nav.top .burger{display:block}
    .entry{padding-top:3px !important;}
  }
  @media(min-width:781px){
    .mobile-menu{display:none !important}
  }

  /* ---------- HUD ---------- */
  .hud{
    position:fixed;bottom:18px;right:18px;z-index:55;
    font-family:'JetBrains Mono',monospace;font-size:10.5px;letter-spacing:.06em;
    color:var(--ink-mute);text-transform:uppercase;
    background:rgba(7,4,15,.55);
    border:1px solid rgba(255,106,213,.22);
    backdrop-filter: blur(10px);
    padding:10px 12px;border-radius:2px;
    display:grid;grid-template-columns:auto auto;gap:4px 12px;
    min-width:200px;
  }
  .hud b{color:var(--ink-dim);font-weight:400}
  .hud .dot{display:inline-block;width:6px;height:6px;border-radius:50%;background:var(--accent);box-shadow:0 0 8px var(--accent);margin-right:6px;animation:pulse 2s infinite}
  @keyframes pulse{50%{opacity:.35}}
  @media(max-width:540px){.hud{display:none}}

  /* ---------- BOOT SEQUENCE ---------- */
  .boot{
    position:fixed;inset:0;z-index:100;background:var(--bg);color:var(--accent);
    font-family:'JetBrains Mono',monospace;font-size:13px;
    display:flex;align-items:flex-start;justify-content:flex-start;
    padding:60px;
    transition:opacity .6s ease, transform .6s ease;
  }
  .boot.done{opacity:0;pointer-events:none;transform:scale(1.05)}
  .boot-lines{white-space:pre;line-height:1.65;max-width:680px}
  .boot-lines .ok{color:#7dff9f}
  .boot-lines .dim{color:var(--ink-mute)}
  .boot-caret{display:inline-block;width:9px;height:14px;background:var(--accent);vertical-align:-2px;animation:blink 1s step-end infinite}
  @keyframes blink{50%{opacity:0}}
  .boot-bar{margin-top:18px;width:320px;max-width:100%;height:6px;border:1px solid var(--accent);position:relative;overflow:hidden}
  .boot-bar::after{content:"";position:absolute;inset:0;background:var(--accent);transform-origin:left;animation:fill 1.8s ease-in forwards}
  @keyframes fill{from{transform:scaleX(0)}to{transform:scaleX(1)}}

  /* ---------- HERO ---------- */
  .hero{min-height:100svh;max-height:1100px;display:flex;align-items:safe center;padding:120px 0 80px;position:relative}

  /* Short-viewport compaction — shrink the name, keep the intro text visible */
  @media (max-height: 860px){
    .hero{padding: 96px 0 64px}
    .hero .tag{margin-bottom:18px}
    .hero h1{font-size: clamp(40px, 7vw, 88px); line-height:.94}
    .hero h1 .sub{font-size:.36em;margin-top:6px}
    .hero .role{margin-top:18px}
    .hero .lede{margin:20px 0 26px;font-size: calc(16px * var(--density))}
  }
  @media (max-height: 740px){
    .hero{padding: 84px 0 52px}
    .hero .tag{margin-bottom:14px;font-size:11px;padding:6px 12px}
    .hero h1{font-size: clamp(34px, 5.6vw, 64px)}
    .hero h1 .sub{font-size:.38em}
    .hero .role{margin-top:14px;font-size:13px}
    .hero .lede{margin:14px 0 20px;font-size:14.5px;max-width:520px}
    .hero .cta-row .btn{padding:12px 18px}
  }
  @media (max-height: 640px){
    .hero{padding: 76px 0 44px}
    .hero h1{font-size: clamp(30px, 5vw, 52px)}
    .hero .lede{margin:12px 0 16px;font-size:13.5px}
    .scroll-ind{display:none}
  }
  #three-canvas{position:absolute;inset:0;z-index:0}
  .hero .inner{position:relative;z-index:2;width:100%}
  .hero .tag{
    display:inline-flex;align-items:center;gap:10px;
    font-family:'JetBrains Mono',monospace;font-size:11.5px;letter-spacing:.2em;text-transform:uppercase;
    color:var(--accent);padding:8px 14px;border:1px solid var(--accent);border-radius:2px;
    background:rgba(7,4,15,.4);margin-bottom:28px;
  }
  .hero .tag::before{content:"";width:6px;height:6px;background:var(--accent);box-shadow:0 0 10px var(--accent);border-radius:50%}
  .hero h1{
    font-family:'Orbitron',sans-serif;font-weight:900;
    font-size: clamp(40px, 6vw, 86px);line-height:.95;letter-spacing:-.02em;margin:0;
    text-transform:uppercase;
  }
  .hero h1 .name{
    display:inline-block;
    position:relative;
    color: transparent;
    -webkit-text-stroke: 1px rgba(255,255,255,.15);
  }
  .hero h1 .name::before,
  .hero h1 .name::after{
    content: attr(data-text);
    position: absolute; left:0; top:0; width:100%;
    -webkit-text-stroke: 0;
  }
  .hero h1 .name::before{
    color: #4de8ff;
    transform: translate(-3px, 0);
    text-shadow: 0 0 18px rgba(77,232,255,.6);
    mix-blend-mode: screen;
  }
  .hero h1 .name::after{
    color: #ff3df0;
    transform: translate(3px, 0);
    text-shadow: 0 0 18px rgba(255,61,240,.6);
    mix-blend-mode: screen;
  }
  .hero h1 .sub{display:block;font-size:.38em;color:var(--ink-dim);-webkit-text-fill-color:var(--ink-dim);font-weight:500;margin-top:8px;letter-spacing:.02em}
  .hero .role{
    font-family:'JetBrains Mono',monospace;font-size:14px;color:var(--cyan);
    margin:22px 0 0;letter-spacing:.1em;
  }
  .hero .role .caret{display:inline-block;width:10px;height:16px;background:var(--cyan);vertical-align:-3px;margin-left:2px;animation:blink 1s step-end infinite}
  .hero .lede{
    max-width:580px;margin:28px 0 36px;color:var(--ink-dim);font-size: calc(17px * var(--density));line-height:1.6;
  }
  .hero .cta-row{display:flex;gap:14px;flex-wrap:wrap}
  .btn{
    --b: var(--accent);
    position:relative;
    display:inline-flex;align-items:center;gap:10px;
    padding:14px 22px;
    font-family:'JetBrains Mono',monospace;font-size:12px;letter-spacing:.15em;text-transform:uppercase;font-weight:700;
    border:1px solid var(--b);color:var(--b);background:transparent;cursor:pointer;
    border-radius:2px;transition:all .25s;
    box-shadow:0 0 0 var(--b);
  }
  .btn:hover{background:var(--b);color:#000;box-shadow:0 0 30px var(--b)}
  .btn.ghost{--b:var(--ink-dim);color:var(--ink-dim)}
  .btn.ghost:hover{background:var(--ink-dim);color:#000}
  .btn .arrow{transition:transform .25s}
  .btn:hover .arrow{transform:translateX(4px)}

  /* corner brackets */
  .frame{position:relative;padding:28px}
  .frame::before,.frame::after{content:"";position:absolute;width:14px;height:14px;border:1px solid var(--accent)}
  .frame::before{top:0;left:0;border-right:0;border-bottom:0}
  .frame::after{bottom:0;right:0;border-left:0;border-top:0}
  .frame .corner-tr,.frame .corner-bl{position:absolute;width:14px;height:14px;border:1px solid var(--accent)}
  .frame .corner-tr{top:0;right:0;border-left:0;border-bottom:0}
  .frame .corner-bl{bottom:0;left:0;border-right:0;border-top:0}

  /* scroll indicator */
  .scroll-ind{
    position:absolute;bottom:30px;left:50%;transform:translateX(-50%);
    font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:.3em;color:var(--ink-mute);
    text-transform:uppercase;display:flex;flex-direction:column;align-items:center;gap:10px;z-index:3;
  }
  .scroll-ind .line{width:1px;height:40px;background:linear-gradient(180deg,var(--accent),transparent);animation:scrolld 2s infinite}
  @keyframes scrolld{0%{transform:scaleY(0);transform-origin:top}50%{transform:scaleY(1);transform-origin:top}51%{transform:scaleY(1);transform-origin:bottom}100%{transform:scaleY(0);transform-origin:bottom}}

  /* ---------- SECTION HEADERS ---------- */
  .sec-head{margin-bottom:60px;display:flex;align-items:flex-end;justify-content:space-between;gap:24px;flex-wrap:wrap}
  .sec-head .num{font-family:'JetBrains Mono',monospace;font-size:12px;color:var(--accent);letter-spacing:.2em}
  .sec-head h2{
    font-family:'Orbitron',sans-serif;font-weight:700;font-size:clamp(32px,5vw,56px);
    letter-spacing:.02em;margin:6px 0 0;text-transform:uppercase;
    color:var(--ink);
  }
  .sec-head h2 .slash{color:var(--accent)}
  .sec-head .meta{font-family:'JetBrains Mono',monospace;font-size:11px;color:var(--ink-mute);letter-spacing:.15em;text-transform:uppercase}

  /* ---------- PROFILE ---------- */
  .profile-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:48px;align-items:start}
  @media(max-width:900px){.profile-grid{grid-template-columns:1fr}}
  .profile-grid p{color:var(--ink-dim);font-size:calc(16px * var(--density));line-height:1.75;margin:0 0 18px}
  .profile-grid p b{color:var(--ink);font-weight:600}
  .profile-grid .highlight{color:var(--accent);font-weight:600}

  .stats{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin:24px 0 32px}
  .stat{border:1px solid var(--line);padding:16px;border-radius:2px;background:rgba(255,255,255,.01)}
  .stat .n{font-family:'Orbitron',sans-serif;font-size:28px;color:var(--accent);font-weight:700;letter-spacing:.02em}
  .stat .l{font-family:'JetBrains Mono',monospace;font-size:10px;color:var(--ink-mute);letter-spacing:.15em;text-transform:uppercase;margin-top:4px}

  .tech-panel{
    border:1px solid var(--line);background:linear-gradient(180deg, rgba(138,91,255,.04), rgba(0,0,0,0));
    padding:24px;border-radius:2px;position:relative;
  }
  .tech-panel .label{font-family:'JetBrains Mono',monospace;font-size:10.5px;color:var(--accent);letter-spacing:.2em;text-transform:uppercase;margin-bottom:18px;display:flex;justify-content:space-between}
  .tech-grid{display:flex;flex-wrap:wrap;gap:8px}
  .chip{
    font-family:'JetBrains Mono',monospace;font-size:11.5px;
    padding:6px 12px;border:1px solid var(--line);color:var(--ink-dim);
    border-radius:2px;transition:all .2s;cursor:default;
    background:rgba(255,255,255,.02);
  }
  .chip:hover{border-color:var(--accent);color:var(--accent);box-shadow:0 0 14px var(--accent-soft)}
  .chip.hot{border-color:var(--accent);color:var(--accent)}

  /* ---------- LOG / EXPERIENCE ---------- */
  .log{position:relative}
  .log::before{
    content:"";position:absolute;left:200px;top:0;bottom:0;width:1px;
    background:linear-gradient(180deg,transparent,var(--line) 5%,var(--line) 95%,transparent);
  }
  @media(max-width:780px){.log::before{left:14px}}
  .entry{display:grid;grid-template-columns:160px 1fr;gap:80px;padding:24px 0;position:relative;align-items:start}
  @media(max-width:780px){.entry{grid-template-columns:1fr;gap:8px;padding-left:36px}}
  .entry .date{font-family:'JetBrains Mono',monospace;font-size:11px;color:var(--ink-mute);letter-spacing:.1em;text-transform:uppercase;padding-top:4px;text-align:right}
  @media(max-width:780px){.entry .date{text-align:left}}
  .entry::after{
    content:"";position:absolute;left:196px;top:32px;width:9px;height:9px;
    background:var(--bg);border:1px solid var(--accent);box-shadow:0 0 12px var(--accent);
  }
  @media(max-width:780px){.entry::after{left:10px;top:8px}}
  .entry:hover::after{background:var(--accent)}
  .entry .card{
    border:1px solid var(--line);padding:24px;border-radius:2px;
    background:linear-gradient(180deg, rgba(138,91,255,.03), rgba(0,0,0,0));
    transition: all .25s;
  }
  .entry:hover .card{border-color:var(--accent);box-shadow:0 0 32px var(--accent-soft)}
  .entry h3{font-family:'Orbitron',sans-serif;font-size:20px;font-weight:700;margin:0 0 4px;color:var(--ink);letter-spacing:.01em}
  .entry .co{font-family:'JetBrains Mono',monospace;font-size:13px;color:var(--accent);margin:0 0 4px;font-weight:500}
  .entry .loc{font-family:'JetBrains Mono',monospace;font-size:11px;color:var(--ink-mute);letter-spacing:.1em;text-transform:uppercase;margin:0 0 14px}
  .entry p.desc{color:var(--ink-dim);font-size:14.5px;line-height:1.65;margin:0 0 14px}
  .entry ul{margin:0;padding-left:0;list-style:none;display:grid;gap:7px}
  .entry li{font-size:14px;color:var(--ink-dim);padding-left:22px;position:relative;line-height:1.55}
  .entry li::before{content:"▸";position:absolute;left:0;color:var(--accent)}
  .entry.legacy{opacity:.6}
  .entry.legacy:hover{opacity:1}

  .log-toggle{
    display:flex;justify-content:center;margin-top:40px;
  }

  /* ---------- ARCHIVE / PROJECTS ---------- */
  .archive-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
  @media(max-width:900px){.archive-grid{grid-template-columns:repeat(2,1fr)}}
  @media(max-width:560px){.archive-grid{grid-template-columns:1fr}}
  .proj{
    position:relative;
    border:1px solid var(--line);border-radius:2px;overflow:hidden;
    background:linear-gradient(180deg, rgba(138,91,255,.04), rgba(0,0,0,0));
    transition: all .3s;
    display:flex;flex-direction:column;
  }
  .proj:hover{border-color:var(--accent);transform:translateY(-4px);box-shadow:0 20px 60px -20px var(--accent-soft),0 0 30px var(--accent-soft)}
  .proj .thumb{
    position:relative;aspect-ratio:16/10;background:#0a0620;overflow:hidden;border-bottom:1px solid var(--line);
  }
.proj .thumb img{width:100%;height:100%;object-fit:cover;filter:saturate(1.1) contrast(1.05);transition:transform .6s, filter .4s}
  .proj:hover .thumb img{transform:scale(1.04);filter:saturate(1.3) contrast(1.1)}
  .proj .thumb::before{
    content:"";position:absolute;inset:0;z-index:2;
    background:linear-gradient(180deg,transparent 40%, rgba(7,4,15,.9) 100%), linear-gradient(135deg, rgba(255,61,240,.12), transparent 50%);
    pointer-events:none;
  }
  .proj .thumb::after{
    content:"";position:absolute;inset:0;z-index:3;pointer-events:none;
    background:repeating-linear-gradient(180deg, rgba(255,255,255,.04) 0 1px, transparent 1px 3px);
    opacity:calc(var(--scan)*.6);
  }
  .proj .tag-row{
    position:absolute;top:12px;left:12px;z-index:4;display:flex;gap:6px;flex-wrap:wrap;
  }
  .proj .tag-row .t{font-family:'JetBrains Mono',monospace;font-size:9.5px;letter-spacing:.15em;text-transform:uppercase;background:rgba(7,4,15,.75);border:1px solid var(--line);padding:4px 8px;color:var(--ink-dim);backdrop-filter:blur(6px)}
  .proj .tag-row .t.feat{border-color:var(--accent);color:var(--accent)}
  .proj .body{padding:20px;display:flex;flex-direction:column;flex:1}
  .proj .idx{font-family:'JetBrains Mono',monospace;font-size:11px;color:var(--ink-mute);letter-spacing:.15em;margin-bottom:6px}
  .proj h3{font-family:'Orbitron',sans-serif;font-size:17px;font-weight:700;margin:0 0 8px;color:var(--ink);letter-spacing:.01em}
  .proj p{font-size:13.5px;color:var(--ink-dim);line-height:1.5;margin:0 0 14px;flex:1}
  .proj .chips{display:flex;flex-wrap:wrap;gap:5px;margin-bottom:14px}
  .proj .chips .chip{font-size:10px;padding:3px 8px}
  .proj .go{font-family:'JetBrains Mono',monospace;font-size:11px;color:var(--accent);letter-spacing:.15em;text-transform:uppercase;display:inline-flex;align-items:center;gap:6px;margin-top:auto}
  .proj .go .arrow{transition:transform .25s}
  .proj:hover .go .arrow{transform:translateX(4px)}
  .proj.legacy{opacity:.65}
  .proj.legacy:hover{opacity:1}

  /* ---------- UPLINK / CONTACT ---------- */
  .uplink{position:relative}
  .uplink-grid{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:start}
  @media(max-width:820px){.uplink-grid{grid-template-columns:1fr;gap:36px}}
  .uplink h2 + .lede{color:var(--ink-dim);font-size:calc(17px * var(--density));line-height:1.6;max-width:500px;margin-bottom:32px}
  .channels{display:grid;gap:14px;margin-top:24px}
  .chan{
    display:flex;align-items:center;gap:16px;
    border:1px solid var(--line);padding:18px 20px;border-radius:2px;
    background:linear-gradient(90deg, rgba(138,91,255,.04), transparent);
    transition:all .25s;
  }
  .chan:hover{border-color:var(--accent);box-shadow:0 0 24px var(--accent-soft);transform:translateX(4px)}
  .chan .ico{width:42px;height:42px;display:grid;place-items:center;border:1px solid var(--line);color:var(--accent);font-family:'JetBrains Mono',monospace;font-size:16px;font-weight:700}
  .chan .meta{flex:1}
  .chan .meta .l{font-family:'JetBrains Mono',monospace;font-size:10px;color:var(--ink-mute);letter-spacing:.2em;text-transform:uppercase}
  .chan .meta .v{font-family:'Orbitron',sans-serif;font-size:15px;color:var(--ink);letter-spacing:.02em;margin-top:2px}
  .chan .arrow{color:var(--accent);transition:transform .2s}
  .chan:hover .arrow{transform:translateX(4px)}

  form.contact{display:grid;gap:14px;border:1px solid var(--line);padding:28px;border-radius:2px;background:linear-gradient(180deg, rgba(138,91,255,.04), rgba(0,0,0,0));position:relative}
  form.contact .f{display:grid;gap:6px}
  form.contact label{font-family:'JetBrains Mono',monospace;font-size:10.5px;color:var(--ink-mute);letter-spacing:.2em;text-transform:uppercase}
  form.contact input, form.contact textarea{
    background:rgba(0,0,0,.3);border:1px solid var(--line);color:var(--ink);
    font-family:'Inter',sans-serif;font-size:14px;padding:12px 14px;border-radius:2px;
    transition:all .2s;resize:vertical;
  }
  form.contact textarea{min-height:110px}
  form.contact input:focus, form.contact textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}

  /* ---------- FOOTER ---------- */
  footer{
    padding:40px var(--pad);border-top:1px solid var(--line-soft);
    font-family:'JetBrains Mono',monospace;font-size:11px;color:var(--ink-mute);
    display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;letter-spacing:.1em;text-transform:uppercase;
  }
  footer .lh{color:var(--accent);font-size:1.8em;vertical-align:middle;display:inline-block;animation:heartbeat 1.2s ease-in-out infinite;padding-bottom: 4px;}
  @keyframes heartbeat{0%,100%{transform:scale(1)}14%{transform:scale(1.3)}28%{transform:scale(1)}42%{transform:scale(1.2)}70%{transform:scale(1)}}

  /* ---------- GLITCH TEXT ---------- */
  .glitch{position:relative;display:inline-block}
  .glitch[data-text]:hover::before,
  .glitch[data-text]:hover::after{
    content:attr(data-text);position:absolute;left:0;top:0;width:100%;
    -webkit-background-clip:text;background-clip:text;
  }
  .glitch[data-text]:hover::before{color:var(--cyan);transform:translate(calc(-2px * var(--glitch)),0);clip-path:polygon(0 0,100% 0,100% 45%,0 45%);mix-blend-mode:screen}
  .glitch[data-text]:hover::after{color:var(--magenta);transform:translate(calc(2px * var(--glitch)),0);clip-path:polygon(0 55%,100% 55%,100% 100%,0 100%);mix-blend-mode:screen}
  .glitch:first-child{padding-right: 16px}

  /* utility */
  .mono{font-family:'JetBrains Mono',monospace}
  .hide-mob{display:block}
  @media(max-width:640px){.hide-mob{display:none}}

  /* reveal on scroll */
  .reveal{opacity:0;transform:translateY(20px);transition:opacity .7s ease, transform .7s ease}
  .reveal.in{opacity:1;transform:none}

  /* collapsible hide */
  .is-collapsed{display:none !important}
