/**
 * Welcome / landing page styles.
 *
 * Standalone promo page (welcome.html) — NOT an app shell, so it
 * deliberately skips the #iphone-frame wrapper and shared app chrome.
 * Self-hosts Nunito (the same display font baked into the App Store
 * screenshots) from store-assets/fonts so the page matches store
 * artwork with no external font request.
 *
 * @file css/welcome.css
 */

/* ───────────────────────── Fonts ───────────────────────── */
@font-face{font-family:'Nunito';font-style:normal;font-weight:400;font-display:swap;
  src:url(../store-assets/fonts/Nunito-400.ttf) format('truetype');}
@font-face{font-family:'Nunito';font-style:normal;font-weight:600;font-display:swap;
  src:url(../store-assets/fonts/Nunito-600.ttf) format('truetype');}
@font-face{font-family:'Nunito';font-style:normal;font-weight:700;font-display:swap;
  src:url(../store-assets/fonts/Nunito-700.ttf) format('truetype');}
@font-face{font-family:'Nunito';font-style:normal;font-weight:800;font-display:swap;
  src:url(../store-assets/fonts/Nunito-800.ttf) format('truetype');}
@font-face{font-family:'Nunito';font-style:normal;font-weight:900;font-display:swap;
  src:url(../store-assets/fonts/Nunito-900.ttf) format('truetype');}

/* ───────────────────────── Tokens ──────────────────────── */
:root{
  --orange:#ff9500;
  --orange-dark:#ff6b00;
  --orange-mid:#ff8833;
  --orange-light:#ffaa33;
  --yellow:#f5c800;
  --yellow-bright:#ffd60a;
  --yellow-tint:#fff8e6;
  --orange-tint:#fff6ec;
  --ink:#1f2330;
  --ink-soft:#4a4f5e;
  --muted:#7b8194;
  --line:#ececf2;
  --card-shadow:0 18px 50px -18px rgba(31,35,48,0.28);
  --font:'Nunito','Segoe UI',Tahoma,Geneva,Verdana,sans-serif;
}

/* ───────────────────────── Reset ───────────────────────── */
*{margin:0;padding:0;box-sizing:border-box;-webkit-tap-highlight-color:transparent;}
html{scroll-behavior:smooth;scroll-padding-top:84px;}
body{
  font-family:var(--font);
  color:var(--ink);
  background:#fff;
  line-height:1.5;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img{max-width:100%;display:block;}
a{color:inherit;text-decoration:none;}
section{position:relative;}
:focus-visible{outline:3px solid var(--orange);outline-offset:3px;border-radius:6px;}

.wrap{max-width:1180px;margin:0 auto;padding:0 24px;}
.eyebrow{
  display:inline-flex;align-items:center;gap:8px;
  font-size:0.78rem;font-weight:800;letter-spacing:0.12em;text-transform:uppercase;
  color:var(--orange-dark);
  background:var(--orange-tint);
  padding:7px 14px;border-radius:999px;
  border:1.5px solid rgba(255,107,0,0.18);
}
.section-head{text-align:center;max-width:720px;margin:0 auto 52px;}
.section-head h2{
  font-size:clamp(1.9rem,4.4vw,3rem);font-weight:900;letter-spacing:-0.02em;
  line-height:1.08;margin:18px 0 14px;
}
.section-head p{font-size:1.12rem;color:var(--ink-soft);}

/* ───────────────────────── Nav ─────────────────────────── */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:100;
  display:flex;align-items:center;justify-content:space-between;
  padding:16px 24px;
  transition:padding .25s ease,background .25s ease,box-shadow .25s ease;
}
.nav.scrolled{
  padding:10px 24px;
  background:rgba(255,255,255,0.82);
  backdrop-filter:saturate(160%) blur(14px);
  -webkit-backdrop-filter:saturate(160%) blur(14px);
  box-shadow:0 1px 0 rgba(31,35,48,0.06),0 10px 30px -22px rgba(31,35,48,0.4);
}
.nav-brand{display:flex;align-items:center;gap:11px;font-weight:900;font-size:1.12rem;color:#fff;letter-spacing:-0.01em;transition:color .25s ease;}
.nav.scrolled .nav-brand{color:var(--ink);}
.nav-brand img{width:38px;height:38px;border-radius:11px;box-shadow:0 4px 14px rgba(0,0,0,0.18);}
.nav-links{display:flex;align-items:center;gap:6px;}
.nav-links a{
  font-weight:700;font-size:0.96rem;color:rgba(255,255,255,0.92);
  padding:9px 14px;border-radius:999px;transition:background .2s ease,color .25s ease;
}
.nav.scrolled .nav-links a{color:var(--ink-soft);}
.nav-links a:hover{background:rgba(255,255,255,0.18);}
.nav.scrolled .nav-links a:hover{background:var(--orange-tint);color:var(--orange-dark);}
.nav-links a.nav-cta{
  background:#fff;color:var(--orange-dark)!important;font-weight:800;
  box-shadow:0 6px 18px -6px rgba(0,0,0,0.35);
}
.nav.scrolled .nav-links a.nav-cta{background:var(--orange);color:#fff!important;}
.nav-links a.nav-cta:hover{transform:translateY(-1px);}
@media(max-width:680px){.nav-links .nav-hide-sm{display:none;}}

/* ───────────────────── Store badges ────────────────────── */
.store-badges{display:flex;flex-wrap:wrap;gap:13px;}
.store-badge{
  display:inline-block;line-height:0;border-radius:13px;
  transition:transform .22s cubic-bezier(.2,.7,.3,1.3),box-shadow .22s ease,filter .22s ease;
  filter:drop-shadow(0 8px 18px rgba(0,0,0,0.22));
}
.store-badge svg{height:56px;width:auto;display:block;}
.store-badge:hover{transform:translateY(-4px) scale(1.035);filter:drop-shadow(0 14px 26px rgba(0,0,0,0.32));}
.store-badge:active{transform:translateY(-1px) scale(.99);}
.badge-rect{transition:fill .2s ease;}

/* ─────────────────────── Hero ──────────────────────────── */
.hero{
  position:relative;overflow:hidden;
  padding:150px 0 110px;
  background:
    radial-gradient(1200px 700px at 78% -10%,#ffd089 0%,transparent 55%),
    radial-gradient(900px 600px at 8% 110%,#ff7a1f 0%,transparent 55%),
    linear-gradient(135deg,var(--orange-light) 0%,var(--orange-mid) 55%,var(--orange-dark) 130%);
  color:#fff;
}
.hero-inner{
  display:grid;grid-template-columns:1.05fr 0.95fr;gap:50px;align-items:center;
}
.hero h1{
  font-size:clamp(2.4rem,5.6vw,4rem);font-weight:900;letter-spacing:-0.03em;
  line-height:1.02;margin:20px 0 18px;text-shadow:0 3px 22px rgba(120,50,0,0.18);
}
.hero h1 .swing{
  background:linear-gradient(100deg,#fff 0%,#ffe7c2 100%);
  -webkit-background-clip:text;background-clip:text;color:transparent;
}
.hero-sub{
  font-size:clamp(1.05rem,1.7vw,1.28rem);font-weight:600;
  color:rgba(255,255,255,0.95);max-width:540px;margin-bottom:30px;
  text-shadow:0 2px 12px rgba(120,50,0,0.16);
}
.hero .eyebrow{background:rgba(255,255,255,0.92);color:var(--orange-dark);border-color:transparent;}
.hero-cta{display:flex;flex-direction:column;gap:18px;}
.web-link{
  display:inline-flex;align-items:center;gap:8px;align-self:flex-start;
  font-weight:800;color:#fff;font-size:0.98rem;
  padding:6px 4px;border-bottom:2px solid rgba(255,255,255,0.5);
  transition:gap .2s ease,border-color .2s ease;
}
.web-link:hover{gap:13px;border-color:#fff;}
.eyebrow-row{display:flex;flex-wrap:wrap;gap:10px;align-items:center;}
.trust-row{display:flex;flex-wrap:wrap;gap:18px;margin-top:26px;font-weight:700;font-size:0.9rem;color:rgba(255,255,255,0.92);}
.trust-row span{display:inline-flex;align-items:center;gap:7px;}

/* floating decorative bears */
.hero-floaties{position:absolute;inset:0;pointer-events:none;z-index:0;}
.floatie{position:absolute;width:64px;opacity:.85;filter:drop-shadow(0 10px 20px rgba(120,50,0,0.25));will-change:transform;}
.floatie.f1{top:16%;left:5%;width:54px;}
.floatie.f2{top:64%;left:11%;width:74px;}
.floatie.f3{top:24%;right:6%;width:60px;}
.floatie.f4{bottom:12%;right:14%;width:46px;}
.hero-inner{position:relative;z-index:1;}

/* Mobile-only hero backdrop (see welcome.html). Hidden on desktop, where the
   floaties + mood-meter already fill the hero. */
.hero-bg-mobile{display:none;}

/* ────────────────── Interactive mood meter ─────────────── */
.mood-meter{
  position:relative;
  background:linear-gradient(180deg,rgba(255,255,255,0.96),rgba(255,255,255,0.9));
  border:1px solid rgba(255,255,255,0.7);
  border-radius:28px;
  padding:30px 30px 26px;
  box-shadow:0 30px 70px -28px rgba(120,50,0,0.55),inset 0 1px 0 rgba(255,255,255,0.6);
  color:var(--ink);
  cursor:ew-resize;
  user-select:none;
  overflow:hidden;
  transition:background .5s ease;
}
.mood-meter::before{
  content:"";position:absolute;inset:0;z-index:0;opacity:.5;transition:background .4s ease;
  background:radial-gradient(420px 240px at 50% 18%,var(--mood-glow,#ffd089) 0%,transparent 70%);
}
.mood-meter>*{position:relative;z-index:1;}
.mm-label{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:6px;}
.mm-label .mm-title{font-size:0.74rem;font-weight:800;letter-spacing:0.1em;text-transform:uppercase;color:var(--muted);}
.mm-label .mm-live{font-size:0.72rem;font-weight:800;color:var(--orange-dark);display:inline-flex;align-items:center;gap:6px;}
.mm-live .dot{width:8px;height:8px;border-radius:50%;background:var(--orange);box-shadow:0 0 0 0 rgba(255,149,0,.6);animation:mmPulse 1.8s infinite;}
@keyframes mmPulse{0%{box-shadow:0 0 0 0 rgba(255,149,0,.5)}70%{box-shadow:0 0 0 9px rgba(255,149,0,0)}100%{box-shadow:0 0 0 0 rgba(255,149,0,0)}}

.mood-stage{position:relative;height:172px;display:flex;align-items:center;justify-content:center;margin-bottom:4px;}
/* Ground shadow lives on a pseudo-element, NOT filter:drop-shadow on the img —
   iOS Safari rasterizes drop-shadow against the img's bounding box while
   opacity/transform transitions run, painting a grey rectangle behind it. */
.mood-stage::after{
  content:"";position:absolute;left:50%;bottom:8px;width:130px;height:28px;z-index:0;
  transform:translateX(-50%);border-radius:50%;
  background:radial-gradient(closest-side,rgba(31,35,48,0.22),rgba(31,35,48,0));
}
.mood-face{
  position:absolute;width:150px;height:150px;object-fit:contain;z-index:1;
  opacity:0;transform:scale(.82);transition:opacity .3s ease,transform .4s cubic-bezier(.2,.8,.3,1.2);
}
.mood-face.active{opacity:1;transform:scale(1);}

.mood-readout{text-align:center;margin-bottom:16px;min-height:54px;}
.mood-name{font-size:1.6rem;font-weight:900;letter-spacing:-0.01em;transition:color .35s ease;color:var(--orange-dark);}
.mood-tag{font-size:0.98rem;font-weight:600;color:var(--ink-soft);}

.mood-track{position:relative;height:96px;margin:0 4px;}
.mood-wave{position:absolute;inset:0;width:100%;height:100%;overflow:visible;}
.mood-wave-line{fill:none;stroke:url(#mmGrad);stroke-width:4;stroke-linecap:round;
  stroke-dasharray:1400;stroke-dashoffset:1400;transition:stroke-dashoffset 1.2s ease;}
.mood-meter.drawn .mood-wave-line{stroke-dashoffset:0;}
.mood-wave-fill{fill:url(#mmFill);opacity:.18;}
.mood-handle{
  position:absolute;width:30px;height:30px;border-radius:50%;
  top:0;left:0;transform:translate(-50%,-50%);
  background:#fff;border:4px solid var(--orange);
  box-shadow:0 6px 16px rgba(255,107,0,0.45),0 0 0 6px rgba(255,149,0,0.14);
  transition:border-color .35s ease,box-shadow .35s ease;
  will-change:left,top;
}
.mood-scale{display:flex;justify-content:space-between;margin-top:8px;font-size:0.72rem;font-weight:800;color:var(--muted);letter-spacing:0.02em;}
.mood-hint{text-align:center;margin-top:14px;font-size:0.82rem;font-weight:700;color:var(--muted);}
.mood-hint b{color:var(--orange-dark);}

/* wave separator at bottom of hero */
.hero-wave{position:absolute;left:0;right:0;bottom:-1px;z-index:1;line-height:0;}
.hero-wave svg{width:100%;height:70px;display:block;}

/* ───────── Anonymous page: yellow hero + dark nav ───────── */
.hero--anon{
  background:
    radial-gradient(1100px 640px at 80% -10%,#fff0a8 0%,transparent 55%),
    radial-gradient(900px 600px at 6% 110%,#ffcf2e 0%,transparent 55%),
    linear-gradient(135deg,#ffe169 0%,var(--yellow) 55%,#e8b400 130%);
  color:#3d2f00;
}
.hero--anon h1{color:#1f1a05;text-shadow:0 2px 18px rgba(160,120,0,0.12);}
.hero--anon h1 .swing{
  background:linear-gradient(100deg,#5a4500 0%,#8a6a00 100%);
  -webkit-background-clip:text;background-clip:text;color:transparent;
}
.hero--anon .hero-sub{color:#4a3c08;text-shadow:none;}
.hero--anon .eyebrow{background:rgba(255,255,255,0.85);color:#a8820a;border-color:transparent;}
.hero--anon .web-link{color:#5a4500;border-color:rgba(90,69,0,0.4);}
.hero--anon .web-link:hover{border-color:#5a4500;}
.hero--anon .trust-row{color:#4a3c08;text-shadow:none;}
/* nav sits over the light-yellow hero → dark text until scrolled */
.nav--anon:not(.scrolled) .nav-brand,
.nav--anon:not(.scrolled) .nav-links a{color:var(--ink);}
.nav--anon:not(.scrolled) .nav-links a:hover{background:rgba(0,0,0,0.06);}
.nav--anon:not(.scrolled) .nav-cta{background:#1f1a05;color:#fff!important;}

/* ───────── Monika shuffler (anon hero interactive) ───────── */
.monika-card{
  position:relative;
  background:linear-gradient(180deg,rgba(255,255,255,0.97),rgba(255,255,255,0.92));
  border:1px solid rgba(255,255,255,0.7);border-radius:28px;
  padding:28px 28px 24px;color:var(--ink);
  box-shadow:0 30px 70px -28px rgba(160,120,0,0.55),inset 0 1px 0 rgba(255,255,255,0.6);
  overflow:hidden;
}
.monika-card .mm-live{color:#a8820a;}
.monika-card .mm-live .dot{background:var(--yellow);box-shadow:0 0 0 0 rgba(245,200,0,.5);animation:mmPulse 1.8s infinite;}
.monika-identity{display:flex;align-items:center;gap:16px;margin:14px 0 18px;}
.monika-avatar{
  flex:0 0 auto;width:60px;height:60px;border-radius:50%;
  display:grid;place-items:center;color:#fff;font-weight:900;font-size:1.25rem;letter-spacing:0.02em;
  box-shadow:0 8px 20px rgba(31,35,48,0.22);transition:background .35s ease;
}
.monika-avatar.sm{width:30px;height:30px;font-size:0.72rem;box-shadow:none;}
.monika-name{font-size:1.5rem;font-weight:900;letter-spacing:-0.01em;transition:opacity .15s ease;}
.monika-sub{font-size:0.86rem;font-weight:600;color:var(--muted);}
.monika-post{
  background:var(--yellow-tint);border:1px solid #f3e3a8;border-radius:16px;padding:14px 16px;margin-bottom:18px;
}
.monika-post-head{display:flex;align-items:center;gap:9px;margin-bottom:8px;}
.monika-post-name{font-weight:800;font-size:0.92rem;}
.monika-post-time{font-size:0.8rem;color:var(--muted);font-weight:600;}
.monika-post-body{font-size:0.98rem;color:var(--ink-soft);line-height:1.45;margin-bottom:10px;min-height:42px;}
.monika-post-react{font-size:0.82rem;font-weight:700;color:var(--muted);}
.monika-shuffle{
  width:100%;padding:13px;border:none;border-radius:14px;cursor:pointer;
  background:#1f1a05;color:#fff;font-family:inherit;font-weight:800;font-size:0.98rem;
  transition:transform .2s ease,background .2s ease;-webkit-tap-highlight-color:transparent;
}
.monika-shuffle:hover{transform:translateY(-2px);background:#a8820a;}
.monika-shuffle:active{transform:translateY(0);}
.monika-hint{text-align:center;margin-top:14px;font-size:0.82rem;font-weight:700;color:var(--muted);}
.monika-hint b{color:#a8820a;}

/* ──────────────────────── Features ─────────────────────── */
.features{padding:96px 0 86px;background:#fff;}
.feature-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;}
.feature-card{
  background:#fff;border:1px solid var(--line);border-radius:22px;padding:30px 26px;
  box-shadow:0 10px 30px -22px rgba(31,35,48,0.4);
  transition:transform .25s ease,box-shadow .25s ease,border-color .25s ease;
}
.feature-card:hover{transform:translateY(-6px);box-shadow:var(--card-shadow);border-color:rgba(255,149,0,0.4);}
.feature-ic{
  width:54px;height:54px;border-radius:15px;display:grid;place-items:center;
  font-size:1.55rem;margin-bottom:18px;
  background:var(--orange-tint);box-shadow:inset 0 0 0 1px rgba(255,107,0,0.12);
  transition:transform .3s cubic-bezier(.2,.8,.3,1.3);
}
.feature-card:hover .feature-ic{transform:rotate(-8deg) scale(1.08);}
.feature-card h3{font-size:1.22rem;font-weight:800;margin-bottom:8px;letter-spacing:-0.01em;}
.feature-card p{color:var(--ink-soft);font-size:1rem;}

/* ──────────────────────── Showcase ─────────────────────── */
.showcase{padding:96px 0;}
.showcase--bear{background:var(--orange-tint);}
.showcase--anon{
  background:
    radial-gradient(900px 500px at 90% 0%,#fff1bf 0%,transparent 60%),
    linear-gradient(180deg,#fffdf3 0%,var(--yellow-tint) 100%);
}
.showcase-top{
  display:grid;grid-template-columns:1fr 1fr;gap:44px;align-items:center;margin-bottom:46px;
}
/* .showcase--flip mirrors a showcase row (image on the opposite side) —
   decoupled from colour variant so either page can flip either app. */
.showcase--flip .showcase-top{direction:rtl;}
.showcase--flip .showcase-top>*{direction:ltr;}
.showcase-badge{display:flex;align-items:center;gap:16px;margin-bottom:22px;}
.showcase-badge img{width:78px;height:78px;border-radius:20px;box-shadow:var(--card-shadow);}
.showcase-badge .sb-name{font-size:1.7rem;font-weight:900;letter-spacing:-0.01em;}
.showcase-badge .sb-dom{font-weight:800;font-size:0.92rem;}
.showcase--bear .sb-dom{color:var(--orange-dark);}
.showcase--anon .sb-dom{color:#a8820a;}
.showcase-copy h2{font-size:clamp(1.9rem,4vw,2.7rem);font-weight:900;letter-spacing:-0.02em;line-height:1.06;margin-bottom:14px;}
.showcase-copy p{font-size:1.12rem;color:var(--ink-soft);margin-bottom:18px;max-width:520px;}
.showcase-list{list-style:none;display:grid;gap:11px;margin-bottom:26px;}
.showcase-list li{display:flex;align-items:flex-start;gap:11px;font-weight:600;color:var(--ink-soft);font-size:1.02rem;}
.showcase-list .tick{
  flex:0 0 auto;width:24px;height:24px;border-radius:7px;display:grid;place-items:center;
  color:#fff;font-size:0.78rem;font-weight:900;margin-top:1px;
}
.showcase--bear .tick{background:var(--orange);}
.showcase--anon .tick{background:var(--yellow);color:#5a4500;}
.showcase--bear .web-link{color:var(--orange-dark);border-color:rgba(255,107,0,0.4);}
.showcase--bear .web-link:hover{border-color:var(--orange-dark);}
.showcase--anon .web-link{color:#a8820a;border-color:rgba(168,130,10,0.4);}
.showcase--anon .web-link:hover{border-color:#a8820a;}

/* the device-shaped screenshot carousel that anchors each showcase */
.carousel{position:relative;justify-self:center;max-width:300px;width:100%;}
/* The screenshot carousel is dressed as a phone: the viewport is the device
   body (dark bezel via padding + a dynamic-island ::before pill), and the
   track of screenshots is clipped to the rounded "screen" inside it. One
   screenshot per screen — swipe / arrows / dots move between them. */
.carousel-viewport{
  position:relative;border-radius:46px;overflow:hidden;
  /* Bezel as a BORDER (not padding) so overflow:hidden clips the screenshot
     to the rounded inner screen (radius = border-radius − border-width = 33px),
     letting the frame sit above the screenshot corners. */
  border:13px solid #1b1e27;
  background:linear-gradient(160deg,#262a35,#14161d);
  box-shadow:0 50px 90px -35px rgba(31,35,48,0.55),inset 0 0 0 2px rgba(255,255,255,0.06);
  touch-action:pan-y;cursor:grab;
}
.carousel-viewport::before{
  content:"";position:absolute;z-index:4;top:12px;left:50%;transform:translateX(-50%);
  width:32%;max-width:104px;height:24px;border-radius:13px;background:#0a0b0e;pointer-events:none;
}
.carousel-viewport:active{cursor:grabbing;}
.carousel-track{display:flex;transition:transform .5s cubic-bezier(.22,.61,.36,1);will-change:transform;}
.carousel-track.no-anim{transition:none;}
.carousel-slide{flex:0 0 100%;width:100%;display:block;-webkit-user-drag:none;user-select:none;}
.carousel-arrow{
  position:absolute;top:50%;transform:translateY(-50%);z-index:3;
  width:44px;height:44px;border-radius:50%;border:none;cursor:pointer;padding:0;
  display:grid;place-items:center;color:var(--ink);
  background:rgba(255,255,255,0.9);backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);
  box-shadow:0 6px 18px rgba(31,35,48,0.3);
  transition:transform .2s ease,background .2s ease,opacity .2s ease;
  -webkit-tap-highlight-color:transparent;
}
.carousel-arrow:hover{background:#fff;transform:translateY(-50%) scale(1.1);}
.carousel-arrow:active{transform:translateY(-50%) scale(.95);}
.carousel-arrow.prev{left:22px;}
.carousel-arrow.next{right:22px;}
/* Hide the arrows on the hero screenshot (slide 1) — the carousel
   auto-advances, so they fade in on the next screenshot. */
.carousel.on-hero .carousel-arrow{opacity:0;pointer-events:none;}
.carousel-dots{display:flex;justify-content:center;flex-wrap:wrap;gap:9px;margin-top:20px;}
.carousel-dot{
  width:9px;height:9px;border-radius:50%;border:none;padding:0;cursor:pointer;
  background:rgba(31,35,48,0.18);transition:transform .2s ease,background .2s ease;
  -webkit-tap-highlight-color:transparent;
}
.carousel-dot:hover{background:rgba(31,35,48,0.35);}
.carousel-dot.active{background:var(--orange);transform:scale(1.35);}
.showcase--anon .carousel-dot.active{background:#e8b800;}

/* ───────── "Two apps" connector band ───────── */
.duo{padding:90px 0;background:#12131a;color:#fff;text-align:center;}
.duo h2{font-size:clamp(1.9rem,4.2vw,2.8rem);font-weight:900;letter-spacing:-0.02em;margin-bottom:14px;}
.duo p{color:rgba(255,255,255,0.72);font-size:1.12rem;max-width:620px;margin:0 auto 40px;}
.duo-cards{display:grid;grid-template-columns:1fr 1fr;gap:22px;max-width:760px;margin:0 auto;}
.duo-card{
  border-radius:24px;padding:30px 26px;text-align:left;position:relative;overflow:hidden;
  transition:transform .25s ease;
}
.duo-card:hover{transform:translateY(-5px);}
.duo-card.bear{background:linear-gradient(150deg,#ff9f1c,#ff6b00);}
.duo-card.anon{background:linear-gradient(150deg,#ffe169,#f5c800);color:#3d2f00;}
.duo-card img{width:60px;height:60px;border-radius:16px;margin-bottom:16px;box-shadow:0 10px 26px rgba(0,0,0,0.25);}
.duo-card h3{font-size:1.4rem;font-weight:900;margin-bottom:6px;}
.duo-card p{font-size:0.98rem;margin:0 0 16px;color:inherit;opacity:.92;max-width:none;}
.duo-card .duo-go{display:inline-flex;align-items:center;gap:8px;font-weight:900;font-size:0.96rem;transition:gap .2s ease;}
.duo-card:hover .duo-go{gap:13px;}
.duo-card.bear,.duo-card.bear .duo-go{color:#fff;}

/* ──────────────────────── Founder ──────────────────────── */
.founder{padding:96px 0;background:#fff;}
.founder-inner{
  display:grid;grid-template-columns:300px 1fr;gap:50px;align-items:center;
  max-width:980px;margin:0 auto;
}
.founder-photo{position:relative;justify-self:center;}
.founder-photo img{
  width:260px;height:260px;object-fit:cover;border-radius:28px;
  box-shadow:var(--card-shadow);
}
.founder-photo::after{
  content:"";position:absolute;inset:-12px;border-radius:36px;z-index:-1;
  background:linear-gradient(135deg,var(--orange-light),var(--orange-dark));
  opacity:.18;
}
.founder-copy .eyebrow{margin-bottom:16px;}
.founder-copy h2{font-size:clamp(1.8rem,3.6vw,2.5rem);font-weight:900;letter-spacing:-0.02em;margin-bottom:14px;}
.founder-copy p{color:var(--ink-soft);font-size:1.08rem;margin-bottom:14px;}
.founder-copy .signoff{font-weight:800;color:var(--ink);}
.btn-pill{
  display:inline-flex;align-items:center;gap:9px;margin-top:8px;
  background:var(--ink);color:#fff;font-weight:800;font-size:1rem;
  padding:13px 22px;border-radius:999px;
  transition:transform .2s ease,box-shadow .2s ease,background .2s ease;
  box-shadow:0 12px 26px -12px rgba(31,35,48,0.7);
}
.btn-pill:hover{transform:translateY(-2px);background:var(--orange-dark);}

/* ──────────────────────── Hosting ──────────────────────── */
.hosting{padding:64px 0;background:linear-gradient(180deg,#fff,var(--orange-tint));text-align:center;}
.hosting .host-label{font-size:0.82rem;font-weight:800;letter-spacing:0.14em;text-transform:uppercase;color:var(--muted);margin-bottom:22px;}
.host-card{
  display:inline-flex;align-items:center;gap:22px;flex-wrap:wrap;justify-content:center;
  background:#fff;border:1px solid var(--line);border-radius:22px;
  padding:24px 34px;box-shadow:var(--card-shadow);
  transition:transform .25s ease,box-shadow .25s ease;
}
.host-card:hover{transform:translateY(-4px);}
.host-card img{height:46px;width:auto;}
.host-card .host-text{text-align:left;max-width:340px;}
.host-card .host-text b{display:block;font-weight:900;font-size:1.05rem;margin-bottom:2px;}
.host-card .host-text span{font-size:0.95rem;color:var(--ink-soft);}
@media(max-width:520px){.host-card .host-text{text-align:center;}}

/* ──────────────────────── Footer ───────────────────────── */
.foot{background:#0f1016;color:rgba(255,255,255,0.72);padding:60px 0 34px;}
.foot-grid{display:flex;flex-wrap:wrap;gap:40px;justify-content:space-between;margin-bottom:40px;}
.foot-brand{max-width:300px;}
.foot-brand .fb-row{display:flex;align-items:center;gap:11px;margin-bottom:14px;}
.foot-brand .fb-row img{width:40px;height:40px;border-radius:12px;}
.foot-brand .fb-row b{color:#fff;font-size:1.15rem;font-weight:900;}
.foot-brand p{font-size:0.95rem;line-height:1.6;}
.foot-col h4{color:#fff;font-size:0.8rem;letter-spacing:0.1em;text-transform:uppercase;margin-bottom:14px;font-weight:800;}
.foot-col a{display:block;padding:6px 0;font-weight:600;font-size:0.96rem;transition:color .2s ease;}
.foot-col a:hover{color:var(--orange-light);}
.foot-note{
  border-top:1px solid rgba(255,255,255,0.1);padding-top:24px;
  display:flex;flex-wrap:wrap;gap:14px;justify-content:space-between;align-items:center;
  font-size:0.85rem;
}
.foot-note .crisis{
  background:rgba(255,255,255,0.06);border:1px solid rgba(255,255,255,0.1);
  border-radius:12px;padding:10px 16px;color:rgba(255,255,255,0.78);max-width:560px;
}
.foot-note .crisis b{color:#fff;}

/* ──────────────── Scroll reveal + motion ───────────────── */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .7s ease,transform .7s cubic-bezier(.2,.7,.2,1);}
.reveal.in{opacity:1;transform:none;}
.reveal.d1{transition-delay:.08s;}
.reveal.d2{transition-delay:.16s;}
.reveal.d3{transition-delay:.24s;}

@media(prefers-reduced-motion:reduce){
  *{animation:none!important;}
  html{scroll-behavior:auto;}
  .reveal{opacity:1;transform:none;transition:none;}
  .floatie{display:none;}
}

/* ──────────────────────── Responsive ───────────────────── */
@media(max-width:900px){
  .hero{padding:128px 0 90px;}
  .hero-floaties{display:none;} /* decorative bears overlap text once single-column */
  /* Bare single-column hero gets a faded bear + mood-line backdrop instead. */
  .hero-bg-mobile{
    display:block;position:absolute;inset:0;z-index:0;pointer-events:none;overflow:hidden;
  }
  .hero-bg-bear{
    position:absolute;top:104px;right:-46px;width:228px;opacity:.14;
    filter:drop-shadow(0 12px 24px rgba(120,50,0,0.25));
  }
  .hero-inner{grid-template-columns:1fr;gap:40px;}
  .hero-cta{align-items:flex-start;}
  .feature-grid{grid-template-columns:1fr;}
  .showcase-top{grid-template-columns:1fr;gap:30px;}
  .showcase--flip .showcase-top{direction:ltr;}
  .carousel{order:-1;}
  .duo-cards{grid-template-columns:1fr;}
  .founder-inner{grid-template-columns:1fr;gap:30px;text-align:center;}
  .founder-copy .eyebrow{margin-inline:auto;}
  .btn-pill{margin-inline:auto;}
}
@media(max-width:520px){
  .wrap{padding:0 18px;}
  .mood-meter{padding:24px 18px 22px;}
  .mood-face{width:128px;height:128px;}
  .shot{width:210px;}
}
