/* Hanken Grotesk — self-hosted (CSP: font-src 'self') */
@font-face{font-family:Hanken;src:url("./fonts/hanken-300.woff2") format("woff2");font-weight:300;font-style:normal;font-display:swap}
@font-face{font-family:Hanken;src:url("./fonts/hanken-400.woff2") format("woff2");font-weight:400;font-style:normal;font-display:swap}
@font-face{font-family:Hanken;src:url("./fonts/hanken-500.woff2") format("woff2");font-weight:500;font-style:normal;font-display:swap}
@font-face{font-family:Hanken;src:url("./fonts/hanken-700.woff2") format("woff2");font-weight:700;font-style:normal;font-display:swap}
@font-face{font-family:Hanken;src:url("./fonts/hanken-800.woff2") format("woff2");font-weight:800;font-style:normal;font-display:swap}

/* per-brand theme vars are set in theme.css (:root):
   --bg --bg-2 --ink --muted --line --accent --accent-soft --wordmark-weight --tracking */
:root{
  --ease:cubic-bezier(.16,1,.3,1);
  --maxw:60rem;
  --pad:clamp(1.5rem,5vw,4.5rem);
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{-webkit-text-size-adjust:100%}
body{
  font-family:Hanken,-apple-system,BlinkMacSystemFont,"Segoe UI",system-ui,sans-serif;
  background:var(--bg);color:var(--ink);
  min-height:100svh;position:relative;overflow:hidden;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
}

/* ---- atmosphere: drifting accent aurora + vignette + grain ---- */
.atmos{position:fixed;inset:0;z-index:0;overflow:hidden;pointer-events:none;background:var(--bg)}
.orb{position:absolute;border-radius:50%;filter:blur(90px);will-change:transform,opacity}
.orb-1{width:62vmax;height:62vmax;left:-14vmax;top:-22vmax;
  background:radial-gradient(circle at 50% 50%,var(--accent) 0%,transparent 62%);
  opacity:.40;animation:drift1 26s var(--ease) infinite alternate}
.orb-2{width:48vmax;height:48vmax;right:-12vmax;bottom:-18vmax;
  background:radial-gradient(circle at 50% 50%,var(--accent-soft) 0%,transparent 60%);
  opacity:.30;animation:drift2 34s var(--ease) infinite alternate}
.orb-3{width:30vmax;height:30vmax;left:38%;top:30%;
  background:radial-gradient(circle at 50% 50%,var(--accent) 0%,transparent 58%);
  opacity:.16;animation:drift3 22s var(--ease) infinite alternate}
.vignette{position:fixed;inset:0;z-index:1;pointer-events:none;
  background:radial-gradient(120% 95% at 50% 36%,transparent 38%,var(--bg) 100%)}
.grain{position:fixed;inset:0;z-index:1;pointer-events:none;opacity:.05;mix-blend-mode:overlay;
  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='.85' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}
canvas.spark{position:fixed;inset:0;z-index:1;pointer-events:none;opacity:.7}

@keyframes drift1{from{transform:translate3d(0,0,0) scale(1)}to{transform:translate3d(7vmax,5vmax,0) scale(1.12)}}
@keyframes drift2{from{transform:translate3d(0,0,0) scale(1)}to{transform:translate3d(-6vmax,-4vmax,0) scale(1.15)}}
@keyframes drift3{from{transform:translate3d(0,0,0) scale(.9);opacity:.10}to{transform:translate3d(-4vmax,6vmax,0) scale(1.1);opacity:.20}}

/* ---- content ---- */
main{position:relative;z-index:2;min-height:100svh;
  display:grid;align-content:center;gap:clamp(1.4rem,3vh,2.2rem);
  max-width:var(--maxw);margin-inline:auto;padding:var(--pad)}

.status{display:inline-flex;align-items:center;gap:.6rem;justify-self:start;
  font-size:.78rem;font-weight:500;letter-spacing:.16em;text-transform:uppercase;
  color:var(--muted);padding:.5rem .9rem;border:1px solid var(--line);border-radius:100px}
.status .dot{width:7px;height:7px;border-radius:50%;background:var(--accent);
  box-shadow:0 0 0 0 var(--accent);animation:pulse 2.6s var(--ease) infinite}
@keyframes pulse{0%{box-shadow:0 0 0 0 color-mix(in oklab,var(--accent) 60%,transparent)}
  70%{box-shadow:0 0 0 9px transparent}100%{box-shadow:0 0 0 0 transparent}}

.wordmark{font-weight:var(--wordmark-weight,300);
  font-size:clamp(2.6rem,9vw,5.5rem);line-height:1.02;
  letter-spacing:var(--tracking,-.035em);text-wrap:balance;
  color:var(--ink)}
.wordmark .soft{color:var(--accent)}
.tagline{font-weight:400;font-size:clamp(1.05rem,2.4vw,1.5rem);line-height:1.5;
  max-width:34ch;color:var(--muted);text-wrap:pretty}

.meta{display:flex;flex-wrap:wrap;align-items:center;gap:1.4rem;margin-top:.6rem}
.contact{font-weight:500;font-size:1rem;color:var(--ink);text-decoration:none;
  display:inline-flex;align-items:center;gap:.5rem;padding-bottom:3px;
  border-bottom:1px solid var(--accent);transition:color .3s var(--ease)}
.contact:hover{color:var(--accent)}
.contact .arrow{transition:transform .3s var(--ease)}
.contact:hover .arrow{transform:translateX(3px)}
.preview{font-weight:400;font-size:.95rem;color:var(--muted);text-decoration:none;
  border-bottom:1px solid var(--line);padding-bottom:3px;transition:border-color .3s var(--ease)}
.preview:hover{border-color:var(--muted)}

footer{position:fixed;left:var(--pad);right:var(--pad);bottom:clamp(1.2rem,3vh,2rem);z-index:2;
  display:flex;justify-content:space-between;gap:1rem;flex-wrap:wrap;
  font-size:.8rem;letter-spacing:.02em;color:var(--muted);opacity:.8}

/* ---- entrance choreography (enhances already-visible content) ---- */
.rise{animation:rise 1s var(--ease) both}
.rise-2{animation-delay:.12s}.rise-3{animation-delay:.22s}.rise-4{animation-delay:.34s}.rise-5{animation-delay:.46s}
@keyframes rise{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:none}}
.atmos{animation:atmosIn 1.6s var(--ease) both}
@keyframes atmosIn{from{opacity:0}to{opacity:1}}

@media (prefers-reduced-motion:reduce){
  .orb,.status .dot,.rise,.atmos,.contact .arrow{animation:none!important}
  .contact,.preview{transition:none}
  .orb{opacity:.28}
}
