/* ============================================================
   JONG NWBA — Hi-fi design system  ·  "Electric / kinetic energy"
   Flame orange + electric cobalt + lime pop, on warm dark/light.
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Bricolage+Grotesque:opsz,wght@12..96,500;12..96,600;12..96,700;12..96,800&family=Hanken+Grotesk:wght@400;500;600;700&display=swap');

:root {
  /* brand */
  --orange:    #F26722;
  --orange-600:#E0541B;
  --orange-700:#C2440F;
  --peach:     #FBC9A8;
  --peach-300: #FAB799;
  /* electric */
  --cobalt:    #2A41E8;
  --cobalt-700:#1A28B5;
  --violet:    #6B4DF5;
  /* pop */
  --lime:      #D6F24E;
  --lime-ink:  #3c4a00;
  /* neutrals (warm) */
  --ink:       #17130E;
  --ink-2:     #2A241C;
  --paper:     #FDF8F1;
  --paper-2:   #FFFFFF;
  --muted:     #6E6557;
  --muted-2:   #9b9183;
  --line:      #ECE3D5;
  --line-ink:  rgba(255,255,255,.14);

  /* gradients */
  --grad-flame:    linear-gradient(135deg, #F26722 0%, #FF8A3D 45%, #FBC9A8 100%);
  --grad-electric: linear-gradient(135deg, #2A41E8 0%, #6B4DF5 100%);
  --grad-sun:      linear-gradient(120deg, #FFB36B 0%, #F26722 55%, #C2440F 100%);

  /* type */
  --display: 'Bricolage Grotesque', system-ui, sans-serif;
  --body:    'Hanken Grotesk', system-ui, sans-serif;

  /* shape */
  --r-sm: 12px;
  --r:    18px;
  --r-lg: 28px;
  --r-xl: 40px;
  --pill: 999px;

  /* shadow */
  --sh-soft: 0 18px 50px -22px rgba(23,19,14,.45);
  --sh-card: 0 10px 30px -16px rgba(23,19,14,.30);
  --pop:     5px 5px 0 var(--ink);
  --pop-lg:  8px 8px 0 var(--ink);

  --wrap: 1180px;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  font-family: var(--body);
  color: var(--ink);
  background: var(--paper);
  font-size: 17px;
  line-height: 1.55;
  -webkit-font-smoothing: antialiased;
  overflow-x: hidden;
}
img { max-width: 100%; display: block; }
a { color: inherit; text-decoration: none; }

/* ---------- type ---------- */
h1,h2,h3,h4 { font-family: var(--display); font-weight: 800; line-height: 1.02; margin: 0; letter-spacing: -0.02em; }
.display { font-size: clamp(2.8rem, 7vw, 6rem); line-height: .96; letter-spacing: -.03em; }
h1 { font-size: clamp(2.2rem, 5vw, 3.6rem); }
h2 { font-size: clamp(1.8rem, 3.6vw, 2.9rem); }
h3 { font-size: clamp(1.25rem, 2vw, 1.6rem); }
.lead { font-size: clamp(1.05rem, 1.5vw, 1.3rem); color: var(--muted); line-height: 1.5; }
.eyebrow {
  font-family: var(--display); font-weight: 700; font-size: .82rem;
  text-transform: uppercase; letter-spacing: .18em;
  display: inline-flex; align-items: center; gap: .5em;
}
.mono-num { font-variant-numeric: tabular-nums; }

/* ---------- layout ---------- */
.wrap { width: min(var(--wrap), 92vw); margin: 0 auto; }
.section { padding: clamp(56px, 9vw, 130px) 0; position: relative; }
.section.tight { padding: clamp(40px, 6vw, 80px) 0; }
.grid { display: grid; gap: clamp(16px, 2vw, 28px); }
.row { display: flex; gap: clamp(12px, 1.6vw, 22px); }
.center { align-items: center; }
.between { justify-content: space-between; }
.wrap-f { flex-wrap: wrap; }
.col { display: flex; flex-direction: column; }
.stack > * + * { margin-top: 1rem; }

/* ---------- buttons ---------- */
.btn {
  --bg: var(--ink); --fg: #fff;
  font-family: var(--display); font-weight: 700; font-size: 1rem;
  display: inline-flex; align-items: center; gap: .6em;
  background: var(--bg); color: var(--fg);
  border: 2px solid var(--ink);
  padding: .85em 1.4em; border-radius: var(--pill);
  cursor: pointer; transition: transform .18s cubic-bezier(.2,.8,.2,1), box-shadow .18s, background .18s;
  box-shadow: var(--pop);
}
.btn:hover { transform: translate(-2px,-2px); box-shadow: var(--pop-lg); }
.btn:active { transform: translate(2px,2px); box-shadow: 2px 2px 0 var(--ink); }
.btn .arrow { transition: transform .2s; }
.btn:hover .arrow { transform: translateX(4px); }
.btn.primary { --bg: var(--orange); --fg: #fff; }
.btn.cobalt  { --bg: var(--cobalt); --fg: #fff; }
.btn.lime    { --bg: var(--lime); --fg: var(--ink); }
.btn.white   { --bg: #fff; --fg: var(--ink); }
.btn.ghost   { background: transparent; color: var(--ink); box-shadow: none; }
.btn.ghost:hover { background: var(--ink); color: #fff; transform: translateY(-2px); box-shadow: none; }
.btn.sm { font-size: .85rem; padding: .55em 1em; box-shadow: 3px 3px 0 var(--ink); }
.btn.lg { font-size: 1.15rem; padding: 1em 1.7em; }

/* on dark */
.on-dark .btn.ghost { color: #fff; border-color: #fff; }
.on-dark .btn.ghost:hover { background: #fff; color: var(--ink); }

/* ---------- chips / tags ---------- */
.chip {
  display: inline-flex; align-items: center; gap: .4em;
  font-family: var(--display); font-weight: 600; font-size: .8rem;
  padding: .4em .85em; border-radius: var(--pill);
  background: #fff; border: 1.5px solid var(--line);
}
.chip.orange { background: color-mix(in srgb, var(--orange) 14%, #fff); border-color: var(--orange); color: var(--orange-700); }
.chip.cobalt { background: color-mix(in srgb, var(--cobalt) 12%, #fff); border-color: var(--cobalt); color: var(--cobalt-700); }
.chip.lime   { background: color-mix(in srgb, var(--lime) 40%, #fff); border-color: #b9d12f; color: var(--lime-ink); }
.chip.solid-ink { background: var(--ink); color: #fff; border-color: var(--ink); }

/* ---------- cards ---------- */
.card {
  background: var(--paper-2); border: 2px solid var(--ink);
  border-radius: var(--r-lg); padding: 22px;
  box-shadow: var(--pop); transition: transform .2s cubic-bezier(.2,.8,.2,1), box-shadow .2s;
}
.card.lift:hover { transform: translate(-3px,-3px); box-shadow: var(--pop-lg); }
.card.flush { padding: 0; overflow: hidden; }
.card.soft { border: 1.5px solid var(--line); box-shadow: var(--sh-card); }

/* ---------- media placeholder ---------- */
.media {
  position: relative; border-radius: var(--r-lg); overflow: hidden;
  background: var(--grad-sun); display: grid; place-items: center;
  color: rgba(255,255,255,.9); font-family: var(--display); font-weight: 700;
}
.media::after { content: attr(data-label); font-size: .9rem; letter-spacing: .04em; opacity: .85; }
.media.cobalt { background: var(--grad-electric); }
.media.peach  { background: linear-gradient(135deg, #FBC9A8, #FAB799); color: var(--orange-700); }
.media.flat   { background: var(--line); color: var(--muted); }
.avatar {
  border-radius: 50%; background: var(--grad-flame); display: grid; place-items: center;
  color: #fff; font-family: var(--display); font-weight: 800; flex: none; overflow: hidden;
}

/* ---------- nav ---------- */
.nav {
  position: sticky; top: 0; z-index: 100;
  background: color-mix(in srgb, var(--paper) 86%, transparent);
  backdrop-filter: blur(12px);
  border-bottom: 2px solid var(--ink);
}
.nav .wrap { display: flex; align-items: center; gap: 22px; padding: 14px 0; }
.nav .logo img { height: 36px; }
.nav .links { display: flex; gap: 6px; margin-left: auto; align-items: center; }
.nav .links a.navlink {
  font-family: var(--display); font-weight: 600; font-size: .95rem;
  padding: .5em .9em; border-radius: var(--pill); cursor: pointer; transition: .15s;
}
.nav .links a.navlink:hover { background: var(--ink); color: #fff; }
.nav .links a.navlink.active { background: var(--orange); color: #fff; }

/* ---------- footer ---------- */
.footer { background: var(--ink); color: #cfc6b8; padding: 70px 0 36px; }
.footer h4 { color: #fff; font-size: 1rem; margin-bottom: 12px; }
.footer a { color: #cfc6b8; display: block; padding: 3px 0; }
.footer a:hover { color: var(--orange); }
.footer .top { display: flex; gap: 40px; flex-wrap: wrap; justify-content: space-between; }
.footer .logo img { height: 42px; margin-bottom: 14px; }
.footer .legal { margin-top: 40px; border-top: 1px solid var(--line-ink); padding-top: 20px; font-size: .85rem; color: var(--muted-2); display: flex; gap: 18px; flex-wrap: wrap; justify-content: space-between; }

/* ---------- marquee ---------- */
.marquee { overflow: hidden; white-space: nowrap; }
.marquee-track { display: inline-flex; gap: 0; animation: marquee 26s linear infinite; }
.marquee:hover .marquee-track { animation-play-state: paused; }
.marquee-item { font-family: var(--display); font-weight: 800; font-size: clamp(1.6rem,3vw,2.6rem); padding: 0 .5em; display: inline-flex; align-items: center; gap: .5em; }
.marquee-item .star { color: var(--lime); }
@keyframes marquee { to { transform: translateX(-50%); } }

/* ---------- decorative blobs / mesh ---------- */
.mesh { position: absolute; inset: 0; overflow: hidden; z-index: 0; pointer-events: none; }
.blob { position: absolute; border-radius: 50%; filter: blur(40px); opacity: .55; animation: float 14s ease-in-out infinite; }
.blob.b1 { width: 460px; height: 460px; background: var(--orange); top: -160px; right: -120px; }
.blob.b2 { width: 380px; height: 380px; background: var(--cobalt); bottom: -160px; left: -100px; animation-delay: -5s; }
.blob.b3 { width: 240px; height: 240px; background: var(--lime); top: 40%; left: 55%; animation-delay: -9s; opacity: .4; }
@keyframes float { 0%,100% { transform: translate(0,0) scale(1); } 33% { transform: translate(30px,-26px) scale(1.08); } 66% { transform: translate(-22px,18px) scale(.95); } }

/* grain overlay */
.grain::before {
  content: ""; position: absolute; inset: 0; z-index: 1; pointer-events: none; opacity: .05;
  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='.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

/* ---------- reveal on scroll ---------- */
.reveal { opacity: 0; transform: translateY(26px); transition: opacity .7s cubic-bezier(.2,.8,.2,1), transform .7s cubic-bezier(.2,.8,.2,1); }
.reveal.in { opacity: 1; transform: none; }
.reveal.d1 { transition-delay: .08s; } .reveal.d2 { transition-delay: .16s; }
.reveal.d3 { transition-delay: .24s; } .reveal.d4 { transition-delay: .32s; }
@media (prefers-reduced-motion: reduce) {
  .reveal { opacity: 1; transform: none; transition: none; }
  .blob, .marquee-track { animation: none; }
}

/* ---------- forms ---------- */
.field { display: flex; flex-direction: column; gap: 6px; margin-bottom: 16px; }
.field label { font-family: var(--display); font-weight: 600; font-size: .9rem; }
.input, .field input, .field textarea, .field select {
  font-family: var(--body); font-size: 1rem; color: var(--ink);
  border: 2px solid var(--ink); border-radius: var(--r-sm);
  padding: .8em 1em; background: #fff; width: 100%;
}
.input.ph { color: var(--muted-2); }
textarea.input { min-height: 110px; resize: vertical; }
.field input:focus, .field textarea:focus { outline: 3px solid color-mix(in srgb, var(--orange) 40%, #fff); }

/* ---------- pills/stat ---------- */
.statbig { font-family: var(--display); font-weight: 800; font-size: clamp(2.4rem,5vw,3.6rem); line-height: 1; }

/* ---------- view switching (hi-fi single file router) ---------- */
.view { display: none; }
.view.active { display: block; animation: viewin .5s cubic-bezier(.2,.8,.2,1); }
@keyframes viewin { from { opacity: 0; transform: translateY(10px);} to { opacity:1; transform:none; } }

/* ---------- utility ---------- */
.bg-ink { background: var(--ink); color: #fff; }
.bg-cobalt { background: var(--cobalt); color: #fff; }
.bg-lime { background: var(--lime); color: var(--ink); }
.bg-peach { background: var(--peach); }
.txt-orange { color: var(--orange); }
.txt-cobalt { color: var(--cobalt); }
.tac { text-align: center; }
.mt-s{margin-top:.5rem}.mt{margin-top:1rem}.mt-l{margin-top:2rem}.mt-xl{margin-top:3rem}
.muted { color: var(--muted); }
.maxw { max-width: 56ch; }
.rounded-pill { border-radius: var(--pill); }
.divider { height: 2px; background: var(--ink); border: 0; }

@media (max-width: 860px) {
  .nav .links { display: none; }
  .row { flex-direction: column; }
}
