:root{
  --bg:#fff8ef;
  --bg-2:#fffdf8;
  --surface:#ffffff;
  --text:#223127;
  --muted:#5d6b62;
  --line:#e9dcc8;
  --yellow:#f2c44d;
  --orange:#df8b3e;
  --green:#5b7751;
  --green-dark:#38483a;
  --shadow:0 18px 40px rgba(34,49,39,.08);
  --radius:30px;
  --radius-sm:18px;
  --max:1180px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;
  color:var(--text);
  background:
    radial-gradient(circle at top left, #fff7d8 0, transparent 22%),
    linear-gradient(180deg,var(--bg) 0%,var(--bg-2) 100%);
  line-height:1.6;
}
img{max-width:100%;display:block}
a{text-decoration:none;color:inherit}
.container{width:min(calc(100% - 2rem),var(--max));margin:0 auto}
.section{padding:5rem 0}

.site-header{
  position:sticky;top:0;z-index:50;
  background:rgba(255,248,239,.84);
  backdrop-filter:blur(14px);
  border-bottom:1px solid rgba(233,220,200,.95);
}
.nav{
  min-height:76px;
  display:flex;align-items:center;justify-content:space-between;gap:1rem;
}
.brand{display:flex;align-items:center;gap:.85rem;font-weight:900;letter-spacing:-.03em}
.brand-icon{
  width:52px;height:52px;object-fit:contain;flex-shrink:0;
  filter:drop-shadow(0 6px 10px rgba(0,0,0,.08));
}
.brand-text{display:flex;flex-direction:column;line-height:1.02}
.brand-text small{margin-top:.2rem;font-size:.78rem;font-weight:700;color:var(--muted)}
.nav-links{display:flex;align-items:center;gap:1.2rem;flex-wrap:wrap;color:var(--muted);font-weight:700}
.nav-links a:hover,.footer-links a:hover,.text-link:hover{color:var(--green-dark)}

.eyebrow{
  display:inline-flex;align-items:center;
  padding:.55rem .95rem;
  border-radius:999px;
  background:#fff0b2;
  border:1px solid #f0db9f;
  color:#6d5900;
  font-size:.82rem;font-weight:800;letter-spacing:.08em;text-transform:uppercase;
}

.btn{
  display:inline-flex;align-items:center;justify-content:center;
  padding:.95rem 1.35rem;
  border-radius:999px;
  border:1px solid transparent;
  font-weight:800;font-size:.98rem;
  transition:transform .18s ease, box-shadow .18s ease, background .18s ease;
  cursor:pointer;
}
.btn:hover{transform:translateY(-1px)}
.btn-primary{
  background:linear-gradient(135deg,var(--yellow),var(--orange));
  color:#1f1f1f;
  box-shadow:var(--shadow);
}
.btn-secondary{
  background:rgba(255,255,255,.85);
  border-color:var(--line);
  color:var(--text);
}
.nav-cta{padding:.75rem 1rem}

.hero{padding:4.6rem 0 2.4rem}
.hero-grid{
  display:grid;
  grid-template-columns:1.02fr .98fr;
  gap:2rem;
  align-items:center;
}
.hero h1{
  margin:1rem 0 .9rem;
  font-size:clamp(2.9rem,7vw,5.4rem);
  line-height:.94;
  letter-spacing:-.065em;
  max-width:10ch;
}
.hero-intro,.hero-note,.section-heading p,.feature-card p,.mini-card p,.app-card p,.merch-card p,.cta-panel p,.tagline,.about-grid p,.asset-slot p{color:var(--muted)}
.hero-intro{font-size:1.1rem;max-width:38rem;margin:0 0 1.4rem}
.hero-note{margin:.2rem 0 0}
.hero-actions{display:flex;gap:.9rem;flex-wrap:wrap;margin-bottom:1.1rem}
.section-actions{margin-top:1.5rem;margin-bottom:0}

.stats{
  margin-top:2rem;
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:1rem;
}
.stat,.card{
  background:rgba(255,255,255,.9);
  border:1px solid var(--line);
  border-radius:var(--radius);
  box-shadow:var(--shadow);
}
.stat{padding:1rem 1rem 1.05rem}
.stat strong{
  display:block;
  margin-bottom:.25rem;
  font-size:1.08rem;
  letter-spacing:-.02em;
}
.stat span{color:var(--muted);font-size:.95rem}

.hero-card{
  position:relative;
  min-height:540px;
  border-radius:36px;
  border:1px solid var(--line);
  background:linear-gradient(180deg,#dfeee5 0%,#ffffff 56%,#fff0cf 100%);
  box-shadow:var(--shadow);
  overflow:hidden;
}
.hero-glow{
  position:absolute;border-radius:999px;filter:blur(12px);opacity:.75;
}
.hero-glow-a{
  width:220px;height:220px;top:-40px;right:-30px;
  background:radial-gradient(circle,#fff4b5 0%, rgba(255,244,181,0) 70%);
}
.hero-glow-b{
  width:300px;height:300px;left:-80px;bottom:-90px;
  background:radial-gradient(circle,rgba(223,139,62,.18) 0%, rgba(223,139,62,0) 70%);
}
.hero-duck{
  position:absolute;
  bottom:0;left:52%;
  transform:translateX(-50%);
  width:min(86%,500px);
  max-height:470px;
  object-fit:contain;
  object-position:bottom center;
  filter:drop-shadow(0 20px 24px rgba(0,0,0,.11));
}
.hero-badge{
  position:absolute;right:18px;bottom:18px;
  max-width:220px;
  display:flex;flex-direction:column;gap:.15rem;
  padding:.9rem 1rem;
  border-radius:20px;
  background:rgba(255,255,255,.94);
  border:1px solid var(--line);
  box-shadow:var(--shadow);
  font-size:.92rem;
}
.hero-badge span{color:var(--muted)}

.brand-banner{
  padding:0 0 1.4rem;
}
.brand-banner-card{
  padding:1rem 1.25rem;
  border-radius:28px;
  border:1px solid var(--line);
  background:rgba(255,255,255,.82);
  box-shadow:var(--shadow);
}
.brand-banner-card img{
  width:100%;
  max-height:140px;
  object-fit:contain;
  object-position:center;
}

.feature-strip{padding-top:1rem}
.card-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.25rem}
.card{padding:1.45rem}
.feature-grid .card{background:rgba(255,255,255,.82)}
.feature-icon{
  width:56px;height:56px;
  display:grid;place-items:center;
  margin-bottom:1rem;
  border-radius:16px;
  font-size:1.42rem;
  border:1px solid var(--line);
  background:linear-gradient(135deg,#fff7cb,#ffffff);
}
.feature-card h3,.mini-card h3,.app-card h3,.merch-card h3,.asset-slot h3,.section-heading h2{
  margin:0 0 .55rem;
  letter-spacing:-.03em;
}
.section-heading{max-width:720px;margin-bottom:2rem}
.section-heading h2{
  margin-top:1rem;
  font-size:clamp(2rem,4vw,3rem);
  line-height:1.04;
}

.spotlight-grid{
  display:grid;
  grid-template-columns:1.05fr .95fr;
  gap:1.5rem;
  align-items:start;
}
.spotlight-copy{
  padding:1.7rem;
  border-radius:32px;
  background:linear-gradient(180deg,#fff7d8 0%,#ffffff 100%);
  border:1px solid var(--line);
  box-shadow:var(--shadow);
}
.mini-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem}
.mini-card{height:100%}

.showcase-stack{
  display:grid;
  gap:1rem;
}
.phone-wrap{display:grid;place-items:center}
.phone-frame{
  width:min(100%,330px);
  aspect-ratio:9 / 19;
  position:relative;
  border:10px solid #1f2430;
  border-radius:42px;
  background:#f7f7f7;
  box-shadow:0 24px 45px rgba(31,36,48,.18);
  overflow:hidden;
}
.phone-notch{
  position:absolute;top:10px;left:50%;transform:translateX(-50%);
  width:120px;height:22px;
  background:#1f2430;border-radius:0 0 16px 16px;z-index:2;
}
.phone-screen{
  position:absolute;inset:0;
  background:linear-gradient(180deg,#d8eee1 0%,#ffffff 58%,#ffefc2 100%);
  overflow:hidden;
}
.score-pill{
  position:absolute;top:42px;left:16px;
  padding:.5rem .8rem;
  border-radius:999px;
  background:rgba(255,255,255,.9);
  border:1px solid rgba(31,36,48,.08);
  font-size:.8rem;font-weight:800;
}
.phone-cloud{
  position:absolute;
  width:82px;height:28px;
  background:rgba(255,255,255,.82);
  border-radius:999px;
  box-shadow:24px 6px 0 0 rgba(255,255,255,.82), 48px 0 0 0 rgba(255,255,255,.82);
}
.cloud-a{top:110px;left:14px;transform:scale(.82)}
.cloud-b{top:160px;right:50px;transform:scale(.68)}
.phone-duck{
  position:absolute;
  width:118px;
  left:44px;bottom:82px;
  transform:rotate(-9deg);
  filter:drop-shadow(0 9px 12px rgba(0,0,0,.12));
}
.platform,.nest{position:absolute}
.platform{
  width:110px;height:18px;
  background:#8fd089;
  border:2px solid #4d8f4b;
  border-radius:999px;
}
.p1{bottom:72px;left:28px}
.p2{bottom:152px;right:24px}
.p3{top:188px;left:34px}
.nest{
  top:86px;right:18px;
  width:86px;height:50px;
  background:#ad7647;
  border:3px solid #7b4f28;
  border-radius:50px 50px 30px 30px;
}

.asset-slot{
  padding:1.2rem;
  border-radius:24px;
  border:1px dashed #d5c4a7;
  background:linear-gradient(180deg,#fffaf0 0%,#ffffff 100%);
}
.slot-label{
  display:inline-block;
  margin-bottom:.65rem;
  padding:.35rem .65rem;
  border-radius:999px;
  background:#fff2c7;
  border:1px solid #efd9a0;
  color:#725c00;
  font-size:.75rem;
  font-weight:800;
  letter-spacing:.04em;
  text-transform:uppercase;
}

.apps-grid .featured-app{background:linear-gradient(180deg,#fff8de 0%,#ffffff 100%)}
.status{
  display:inline-flex;
  margin-bottom:.8rem;
  padding:.36rem .72rem;
  border-radius:999px;
  background:#fff1ba;
  border:1px solid #efd99d;
  color:#6d5900;
  font-size:.8rem;font-weight:800;
}
.status.muted{
  background:#f8f4eb;
  color:#6d706b;
  border-color:var(--line);
}
.app-meta{
  margin-top:1rem;
  display:flex;gap:.65rem;flex-wrap:wrap;
}
.chip{
  padding:.42rem .75rem;
  border-radius:999px;
  background:#f7f3ea;
  border:1px solid var(--line);
  color:#5d5d5d;
  font-size:.84rem;font-weight:700;
}
.text-link{
  display:inline-block;
  margin-top:1rem;
  font-weight:800;
  color:var(--green);
}

.about-grid{
  display:grid;
  grid-template-columns:.95fr 1.05fr;
  gap:1.5rem;
  align-items:center;
}
.about-panel{
  min-height:400px;
  display:grid;place-items:center;
  position:relative;
  padding:1.5rem;
  border-radius:32px;
  background:linear-gradient(135deg,#fff2c3,#ffffff);
  border:1px solid var(--line);
  box-shadow:var(--shadow);
  overflow:hidden;
}
.about-bubble{
  position:absolute;top:18px;left:18px;
  max-width:220px;
  padding:.85rem 1rem;
  border-radius:18px;
  background:rgba(255,255,255,.92);
  border:1px solid var(--line);
  box-shadow:var(--shadow);
  font-weight:700;
}
.about-duck{
  width:min(100%,360px);
  max-height:320px;
  object-fit:contain;
  filter:drop-shadow(0 18px 22px rgba(0,0,0,.1));
}

.shop-section{
  background:linear-gradient(180deg, rgba(255,244,224,.42) 0%, rgba(255,244,224,0) 100%);
}
.merch-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem}
.merch-slot{
  aspect-ratio:1;
  display:grid;
  place-items:center;
  text-align:center;
  margin-bottom:1rem;
}
.price{display:inline-block;margin-top:.7rem;font-weight:800}

.cta-panel{
  display:grid;
  grid-template-columns:1fr auto;
  gap:1rem;
  align-items:center;
  padding:2rem;
  border-radius:32px;
  border:1px solid #efd8a7;
  background:linear-gradient(135deg,#fff0b2,#ffd3b7 58%,#ffffff 100%);
  box-shadow:var(--shadow);
}
.cta-title{
  margin:1rem 0 .75rem;
  font-size:clamp(2rem,4vw,2.8rem);
  line-height:1.04;
  letter-spacing:-.04em;
}
.signup{display:flex;gap:.75rem;flex-wrap:wrap;justify-content:flex-end}
.signup input{
  min-width:260px;
  padding:.95rem 1rem;
  border-radius:999px;
  border:1px solid #e3c992;
  background:rgba(255,255,255,.92);
  font:inherit;
}

.footer{
  padding:2rem 0 3rem;
  border-top:1px solid var(--line);
}
.footer-grid{
  display:flex;justify-content:space-between;align-items:center;gap:1rem;flex-wrap:wrap;
}
.footer-links{
  display:flex;gap:1rem;flex-wrap:wrap;color:var(--muted);font-weight:700;
}

@media (max-width:1080px){
  .hero-grid,.spotlight-grid,.about-grid,.cta-panel{grid-template-columns:1fr}
  .card-grid,.merch-grid{grid-template-columns:repeat(2,1fr)}
  .signup{justify-content:flex-start}
  .hero h1{max-width:none}
}
@media (max-width:720px){
  .nav,.footer-grid{flex-direction:column;align-items:flex-start}
  .nav{padding:.8rem 0}
  .nav-links{justify-content:flex-start}
  .stats,.card-grid,.mini-grid,.merch-grid{grid-template-columns:1fr}
  .hero{padding-top:3rem}
  .hero-card{min-height:400px}
  .hero-duck{width:min(82%,290px);max-height:290px}
  .brand-banner-card img{max-height:90px}
  .phone-frame{width:min(100%,292px)}
  .signup input{min-width:100%}
}
