/* ===== NabiTherapegs — coming soon ===== */
:root{
  --ink:#141414;
  --paper:#fbf4e4;
  --paper-2:#f3e8cf;
  --olive:#6f7b2e;
  --leaf:#7cb342;
  --sky:#4f9fd8;
  --salmon:#e0a08a;
  --pink:#e3b3a4;
  --sun:#ffd93b;
  --tomato:#e23b2e;
  --shadow: 7px 7px 0 var(--ink);
  --shadow-sm: 4px 4px 0 var(--ink);
  --r: 22px;
  --maxw: 1180px;
}

*{box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{
  margin:0;
  font-family:"Nunito",system-ui,sans-serif;
  color:var(--ink);
  background-color:var(--paper);
  background-image:radial-gradient(var(--ink) 1.1px, transparent 1.2px);
  background-size:26px 26px;
  background-position:-13px -13px;
  overflow-x:hidden;
}
img{display:block;max-width:100%;}
a{color:inherit;text-decoration:none;}
strong{font-weight:800;}
em{font-style:normal;}

/* ---- floating doodles ---- */
.doodles{position:fixed;inset:0;pointer-events:none;z-index:0;}
.doodle{position:absolute;font-size:clamp(22px,3vw,40px);opacity:.18;animation:float 7s ease-in-out infinite;}
.d1{top:18%;left:6%;color:var(--tomato);}
.d2{top:60%;left:3%;color:var(--sky);animation-delay:1.5s;}
.d3{top:30%;right:7%;color:var(--olive);animation-delay:.8s;}
.d4{top:72%;right:5%;color:var(--tomato);animation-delay:2.2s;}
@keyframes float{0%,100%{transform:translateY(0) rotate(-6deg);}50%{transform:translateY(-18px) rotate(8deg);}}

/* ---- buttons ---- */
.btn{
  display:inline-flex;align-items:center;gap:.45em;
  font-weight:800;font-size:1rem;
  padding:.7em 1.2em;border:3px solid var(--ink);border-radius:999px;
  background:#fff;cursor:pointer;
  box-shadow:var(--shadow-sm);
  transition:transform .12s ease, box-shadow .12s ease;
  white-space:nowrap;
}
.btn:hover{transform:translate(-2px,-2px);box-shadow:6px 6px 0 var(--ink);}
.btn:active{transform:translate(2px,2px);box-shadow:1px 1px 0 var(--ink);}
.btn-primary{background:var(--sun);}
.btn-x{background:var(--ink);color:#fff;}
.btn-ghost{background:transparent;box-shadow:none;}
.btn-ghost:hover{background:#fff;box-shadow:var(--shadow-sm);}
.btn.big{font-size:1.15rem;padding:.85em 1.6em;box-shadow:var(--shadow);}
.btn.small{font-size:.9rem;padding:.55em .9em;}

/* ---- nav ---- */
.nav{
  position:sticky;top:0;z-index:50;
  display:flex;align-items:center;justify-content:space-between;
  gap:1rem;padding:.7rem clamp(1rem,4vw,2.4rem);
  background:rgba(251,244,228,.82);backdrop-filter:blur(8px);
  border-bottom:3px solid var(--ink);
}
.brand{display:flex;align-items:center;gap:.6rem;font-family:"Caveat";font-weight:700;font-size:1.7rem;min-width:0;}
.brand img{width:42px;height:42px;border:3px solid var(--ink);border-radius:50%;object-fit:cover;background:var(--sky);flex:none;}
.brand span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.nav-links{display:flex;align-items:center;gap:1.4rem;font-weight:700;flex:none;}
.nav-links a:not(.btn):hover{color:var(--tomato);}
@media(max-width:720px){.nav-links a:not(.btn){display:none;}}

/* ---- hero ---- */
.hero{position:relative;z-index:1;max-width:var(--maxw);margin:0 auto;padding:clamp(2rem,6vw,4.5rem) clamp(1rem,4vw,2.4rem);}
.hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(2rem,5vw,4rem);align-items:center;}
@media(max-width:880px){.hero-grid{grid-template-columns:1fr;}}

.badge{
  display:inline-flex;align-items:center;gap:.5em;
  font-weight:800;font-size:.85rem;letter-spacing:.04em;text-transform:uppercase;
  background:#fff;border:3px solid var(--ink);border-radius:999px;
  padding:.4em .9em;box-shadow:var(--shadow-sm);
}
.badge .dot{width:11px;height:11px;border-radius:50%;background:var(--tomato);border:2px solid var(--ink);animation:blink 1.4s steps(1) infinite;}
@keyframes blink{50%{background:var(--sun);}}

h1{margin:1.1rem 0 0;line-height:.92;}
h1 .line-1{display:block;font-family:"Caveat";font-weight:500;font-size:clamp(1.8rem,5vw,2.6rem);transform:rotate(-2deg);}
.logotype{
  display:block;font-family:"Caveat";font-weight:700;
  font-size:clamp(3.6rem,12vw,7rem);line-height:.85;
  color:var(--ink);
  text-shadow:4px 4px 0 var(--sun), 5px 5px 0 var(--ink);
}
.lead{font-size:clamp(1.05rem,1.6vw,1.25rem);line-height:1.55;max-width:34ch;margin:1.4rem 0 0;font-weight:600;}
.cta-row{display:flex;flex-wrap:wrap;gap:.8rem;margin:1.8rem 0 0;}
.credits-inline{margin:1.4rem 0 0;font-size:.92rem;opacity:.7;font-weight:700;}

/* hero media — CRT/polaroid frame for the video */
.hero-media{position:relative;display:flex;justify-content:center;}
.tv{
  background:#fff;border:4px solid var(--ink);border-radius:var(--r);
  padding:14px 14px 0;box-shadow:var(--shadow);
  transform:rotate(2deg);max-width:440px;width:100%;
}
.tv-screen{
  width:100%;aspect-ratio:656/448;object-fit:cover;
  border:3px solid var(--ink);border-radius:12px;background:var(--leaf);
  image-rendering:auto;
}
.tv-foot{display:flex;align-items:center;justify-content:space-between;padding:.55rem .2rem .7rem;font-weight:800;font-size:.8rem;}
.rec{color:var(--tomato);}
.tv-label{font-family:"Caveat";font-size:1.15rem;opacity:.8;}
.sticker-tag{
  position:absolute;bottom:-14px;left:-10px;
  background:var(--leaf);border:3px solid var(--ink);border-radius:14px;
  font-family:"Caveat";font-weight:700;font-size:1.5rem;
  padding:.1em .6em;box-shadow:var(--shadow-sm);transform:rotate(-7deg);
}

/* ---- marquee ---- */
.marquee{
  position:relative;z-index:1;overflow:hidden;
  background:var(--ink);border-top:3px solid var(--ink);border-bottom:3px solid var(--ink);
  padding:14px 0;margin-top:1rem;
}
.marquee-track{display:flex;gap:18px;width:max-content;animation:scroll 32s linear infinite;}
.marquee-track img{height:120px;width:120px;border:3px solid #fff;border-radius:14px;background:#fff;object-fit:cover;}
@keyframes scroll{from{transform:translateX(0);}to{transform:translateX(-50%);}}
.marquee:hover .marquee-track{animation-play-state:paused;}

/* ---- the nabis ---- */
.nabis{position:relative;z-index:1;max-width:var(--maxw);margin:0 auto;padding:clamp(3rem,7vw,5rem) clamp(1rem,4vw,2.4rem);}
.section-title{
  font-family:"Nunito";font-weight:900;letter-spacing:-.02em;
  font-size:clamp(2rem,5vw,3.2rem);line-height:1.02;margin:0;text-align:center;
}
.section-title em{color:var(--tomato);font-family:"Caveat";font-weight:700;}
.section-sub{text-align:center;font-weight:700;font-size:1.1rem;opacity:.72;margin:.7rem 0 0;}
.section-title.light,.section-sub.light{color:var(--paper);}
.section-title.light em{color:var(--sun);}

.card-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;margin-top:2.6rem;
}
@media(max-width:880px){.card-grid{grid-template-columns:repeat(2,1fr);}}
@media(max-width:560px){.card-grid{grid-template-columns:1fr;}}

.card{
  margin:0;border:4px solid var(--ink);border-radius:var(--r);overflow:hidden;
  background:#fff;box-shadow:var(--shadow);
  transition:transform .15s ease, box-shadow .15s ease;
}
.card:hover{transform:translate(-3px,-3px) rotate(-1deg);box-shadow:10px 10px 0 var(--ink);}
.card img{width:100%;aspect-ratio:1/1;object-fit:cover;border-bottom:4px solid var(--ink);}
.c-grey img{background:#cfcfcf;}
.c-olive img{background:var(--olive);}
.c-leaf img{background:var(--leaf);}
.c-salmon img{background:var(--salmon);}
.c-pink img{background:var(--pink);}
.card figcaption{padding:.9rem 1.1rem 1.1rem;}
.card figcaption b{display:block;font-size:1.3rem;font-weight:900;}
.card figcaption span{display:block;font-weight:600;opacity:.7;margin-top:.15rem;}

.c-soon{background:var(--sky);}
.c-soon .soon-inner{height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:2rem 1.2rem;color:#fff;min-height:280px;}
.c-soon .qm{font-family:"Caveat";font-weight:700;font-size:5rem;line-height:1;text-shadow:3px 3px 0 var(--ink);}
.c-soon b{font-size:1.5rem;font-weight:900;margin-top:.4rem;}
.c-soon span{font-weight:700;opacity:.95;margin-top:.3rem;}

/* ---- story ---- */
.story{position:relative;z-index:1;background:var(--olive);border-top:4px solid var(--ink);border-bottom:4px solid var(--ink);padding:clamp(3rem,7vw,5rem) clamp(1rem,4vw,2.4rem);margin-top:1rem;}
.story-head{max-width:var(--maxw);margin:0 auto;text-align:center;}
.story-head .section-title{text-align:center;}
.story-row{max-width:var(--maxw);margin:2.8rem auto 0;display:grid;grid-template-columns:repeat(3,1fr);gap:1.6rem;align-items:start;}
@media(max-width:880px){.story-row{grid-template-columns:1fr;max-width:460px;}}
.poly{margin:0;background:#fff;border:4px solid var(--ink);border-radius:8px;padding:12px 12px 8px;box-shadow:var(--shadow);transform:rotate(-2deg);}
.poly-2{transform:rotate(1.5deg);margin-top:1rem;}
.poly-3{transform:rotate(-1deg);}
.poly img{width:100%;border:2px solid var(--ink);border-radius:4px;background:#eee;}
.poly figcaption{font-family:"Caveat";font-weight:700;font-size:1.4rem;text-align:center;padding:.5rem 0 .2rem;}

/* ---- final cta ---- */
.final-cta{position:relative;z-index:1;padding:clamp(3rem,7vw,5rem) clamp(1rem,4vw,2.4rem);}
.cta-card{
  max-width:760px;margin:0 auto;text-align:center;
  background:var(--sun);border:4px solid var(--ink);border-radius:32px;
  padding:clamp(2rem,5vw,3.4rem);box-shadow:var(--shadow);position:relative;
}
.cta-nabi{width:90px;height:90px;border:4px solid var(--ink);border-radius:50%;object-fit:cover;background:var(--sky);margin:-65px auto .6rem;box-shadow:var(--shadow-sm);}
.cta-card h2{font-family:"Nunito";font-weight:900;font-size:clamp(1.7rem,4vw,2.6rem);margin:.2rem 0 0;}
.cta-card p{font-weight:700;font-size:1.15rem;margin:.6rem 0 1.6rem;}

/* ---- footer ---- */
.footer{position:relative;z-index:1;background:var(--ink);color:var(--paper);border-top:4px solid var(--ink);padding:2.4rem clamp(1rem,4vw,2.4rem) 1.4rem;}
.footer-in{max-width:var(--maxw);margin:0 auto;display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:1.2rem;}
.f-brand{display:flex;align-items:center;gap:.6rem;font-family:"Caveat";font-weight:700;font-size:1.7rem;}
.f-brand img{width:40px;height:40px;border:3px solid var(--paper);border-radius:50%;object-fit:cover;background:var(--sky);}
.f-credit{font-weight:700;line-height:1.5;opacity:.85;font-size:.95rem;}
.footer .btn-x{background:var(--paper);color:var(--ink);border-color:var(--paper);}
.copy{max-width:var(--maxw);margin:1.6rem auto 0;text-align:center;opacity:.5;font-size:.8rem;font-weight:700;}

/* ---- reveal on scroll ---- */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .5s ease, transform .5s ease;}
.reveal.in{opacity:1;transform:none;}
@media(prefers-reduced-motion:reduce){
  .reveal{opacity:1;transform:none;}
  .doodle,.marquee-track,.badge .dot{animation:none;}
}
