/* ============================================================
   HomeyClicks — Landing page (Direction A: "Soft & Polished")
   Ported from design_handoff_homeyclicks_landing.
   Design system + page styles + responsive + a11y.
   Brand: Blue #B9D5F3  +  Green #C2F4A0
   ============================================================ */

:root {
  /* Brand primaries */
  --blue:        #B9D5F3;
  --green:       #C2F4A0;
  --blue-deep:   #6f9fd6;
  --green-deep:  #6fb84a;

  /* Pastel pops (model tiles) */
  --pink:        #FBD0DD;
  --pink-ink:    #c0567a;
  --lav:         #DECDFA;
  --lav-ink:     #7a59c4;
  --peach:       #FBD9B4;
  --peach-ink:   #c47a3a;
  --yellow:      #FBEBA8;
  --yellow-ink:  #b78f1f;
  --mint:        #C2F4A0;
  --mint-ink:    #4e9b3e;
  --sky:         #B9D5F3;
  --sky-ink:     #4a7fc0;

  /* Neutrals */
  --ink:         #1b1b29;
  --ink-soft:    #3a3a4d;
  --muted:       #71718a;
  --line:        #ececf2;
  --bg:          #ffffff;
  --bg-tint:     #f6f9fd;
  --card:        #ffffff;
  --footer:      #16161f;

  /* Brand gradient */
  --grad: linear-gradient(120deg, var(--blue) 0%, var(--green) 100%);
  --grad-soft: linear-gradient(120deg, #eaf3fd 0%, #eefbe4 100%);

  /* Shape */
  --r-sm: 14px;
  --r:    20px;
  --r-lg: 28px;
  --r-xl: 36px;
  --r-pill: 999px;

  /* Shadow */
  --sh-sm: 0 4px 14px rgba(40,60,90,.07);
  --sh:    0 14px 34px rgba(40,60,90,.10);
  --sh-lg: 0 26px 60px rgba(40,60,90,.14);
  --sh-color: 0 18px 40px rgba(120,180,140,.22);

  --ease: cubic-bezier(.22,.61,.36,1);
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  font-family: 'Nunito', system-ui, sans-serif;
  color: var(--ink);
  background: var(--bg);
  -webkit-font-smoothing: antialiased;
  font-size: 18px;
  line-height: 1.6;
}
h1,h2,h3,h4 {
  font-family: 'Fredoka', sans-serif;
  font-weight: 600;
  line-height: 1.05;
  letter-spacing: -.01em;
  margin: 0;
  color: var(--ink);
}
p { margin: 0; }
a { color: inherit; text-decoration: none; }
img { max-width: 100%; display: block; }

.wrap { width: min(1180px, 92vw); margin-inline: auto; }
.wrap-wide { width: min(1340px, 94vw); margin-inline: auto; }

.eyebrow {
  font-family: 'Fredoka', sans-serif;
  font-weight: 600;
  font-size: 14px;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--blue-deep);
  display: inline-flex;
  align-items: center;
  gap: 8px;
}
.eyebrow::before {
  content: '';
  width: 22px; height: 3px; border-radius: 3px;
  background: var(--grad);
}

.grad-text {
  background: linear-gradient(100deg, var(--blue-deep), var(--green-deep));
  -webkit-background-clip: text; background-clip: text;
  -webkit-text-fill-color: transparent;
}

/* ---------- Buttons ---------- */
.btn {
  font-family: 'Fredoka', sans-serif;
  font-weight: 500;
  font-size: 17px;
  border: none;
  cursor: pointer;
  border-radius: var(--r-pill);
  padding: 15px 30px;
  display: inline-flex;
  align-items: center;
  gap: 10px;
  transition: transform .25s var(--ease), box-shadow .25s var(--ease), background .25s var(--ease);
  text-decoration: none;
  white-space: nowrap;
}
.btn-primary { background: var(--grad); color: var(--ink); box-shadow: var(--sh-color); }
.btn-primary:hover { transform: translateY(-3px); box-shadow: 0 26px 50px rgba(120,180,140,.32); }
.btn-ghost { background: #fff; color: var(--ink); border: 2px solid var(--line); }
.btn-ghost:hover { transform: translateY(-3px); border-color: var(--blue); box-shadow: var(--sh-sm); }
.btn-soon { opacity: .96; }
.btn .soon-tag {
  font-family:'Nunito',sans-serif; font-weight:800; font-size:11px; letter-spacing:.04em;
  background: rgba(255,255,255,.6); color: var(--ink-soft);
  padding: 3px 9px; border-radius: var(--r-pill);
}

/* ---------- Nav ---------- */
.nav {
  position: sticky; top: 0; z-index: 50;
  background: rgba(255,255,255,.82);
  backdrop-filter: saturate(160%) blur(14px);
  border-bottom: 1px solid var(--line);
}
.nav-inner { display: flex; align-items: center; justify-content: space-between; height: 78px; }
.brand { display: flex; align-items: center; gap: 11px; font-family:'Fredoka',sans-serif; font-weight:600; font-size: 23px; }
.brand .logo {
  width: 42px; height: 42px; border-radius: 13px;
  background: var(--grad);
  display: grid; place-items: center;
  box-shadow: var(--sh-sm);
  flex: none;
}
.brand .logo svg { width: 22px; height: 22px; }
.brand b { color: var(--ink); font-weight: 600; }
.brand span { color: var(--blue-deep); }
.nav-links { display: flex; align-items: center; gap: 34px; }
.nav-links a { font-family:'Fredoka',sans-serif; font-weight: 500; font-size: 17px; color: var(--ink-soft); transition: color .2s; }
.nav-links a:hover { color: var(--ink); }
.nav-cta {
  font-family:'Fredoka',sans-serif; font-weight: 500; font-size: 16px;
  background: var(--grad); color: var(--ink);
  padding: 11px 20px; border-radius: var(--r-pill);
  display: inline-flex; align-items: center; gap: 9px;
  box-shadow: var(--sh-color);
  transition: transform .25s var(--ease);
}
.nav-cta:hover { transform: translateY(-2px); }
.nav-cta .dot { font-size:11px; font-weight:800; font-family:'Nunito',sans-serif; background:rgba(255,255,255,.55); padding:2px 8px; border-radius:var(--r-pill); }

/* hamburger (mobile) */
.nav-toggle { display:none; flex-direction:column; gap:5px; background:none; border:0; cursor:pointer; padding:8px; }
.nav-toggle span { width:26px; height:3px; background:var(--ink); border-radius:2px; transition:transform .25s var(--ease), opacity .2s; }
.nav-toggle[aria-expanded="true"] span:nth-child(1){ transform:translateY(8px) rotate(45deg); }
.nav-toggle[aria-expanded="true"] span:nth-child(2){ opacity:0; }
.nav-toggle[aria-expanded="true"] span:nth-child(3){ transform:translateY(-8px) rotate(-45deg); }

/* ---------- Placeholder model tile ---------- */
.tile {
  position: relative;
  border-radius: var(--r-lg);
  aspect-ratio: 1 / 1;
  display: grid;
  place-items: center;
  overflow: hidden;
  background: linear-gradient(160deg, var(--t1,#eef), var(--t2,#dde));
  isolation: isolate;
}
.tile::after {
  content:''; position:absolute; inset:0;
  background: radial-gradient(120% 80% at 30% 12%, rgba(255,255,255,.55), transparent 55%);
  pointer-events:none;
}
.tile .face {
  width: 46%; aspect-ratio: 1; border-radius: 50%;
  background: rgba(255,255,255,.72);
  color: var(--fi, #555);
  display: grid; place-items: center;
  box-shadow: inset 0 -6px 16px rgba(0,0,0,.04);
}
.tile .face svg { width: 58%; }
.tile .lbl {
  position: absolute; bottom: 14px; left: 0; right: 0; text-align:center;
  font-family:'Fredoka',sans-serif; font-weight:600; font-size: 16px;
  color: var(--ti, #555);
}
.tile.big .lbl { font-size: 22px; bottom: 22px; }

/* pastel variants */
.t-pink   { --t1:#fde3ec; --t2:#f9c2d6; --ti:var(--pink-ink);   --fi:var(--pink-ink); }
.t-mint   { --t1:#e3f8d6; --t2:#bff0a0; --ti:var(--mint-ink);   --fi:var(--mint-ink); }
.t-sky    { --t1:#e2effd; --t2:#b9d5f3; --ti:var(--sky-ink);    --fi:var(--sky-ink); }
.t-lav    { --t1:#efe6fd; --t2:#dccdf9; --ti:var(--lav-ink);    --fi:var(--lav-ink); }
.t-peach  { --t1:#fdeede; --t2:#fbd9b4; --ti:var(--peach-ink);  --fi:var(--peach-ink); }
.t-yellow { --t1:#fdf5d6; --t2:#fbeba8; --ti:var(--yellow-ink); --fi:var(--yellow-ink); }

/* ---------- Footer ---------- */
.foot { background: var(--footer); color: #c9c9d6; padding: 70px 0 34px; }
.foot a { color:#c9c9d6; transition: color .2s; }
.foot a:hover { color:#fff; }
.foot-grid { display: grid; grid-template-columns: 1.4fr 1fr 1fr; gap: 40px; }
.foot .brand b { color:#fff; }
.foot .brand span { color: var(--blue); }
.foot-tag { margin-top: 18px; max-width: 320px; color:#9a9aae; font-size:16px; }
.foot h5 { font-family:'Fredoka',sans-serif; font-weight:600; font-size:17px; color:#fff; margin:0 0 18px; }
.foot ul { list-style:none; margin:0; padding:0; display:flex; flex-direction:column; gap:13px; font-size:16px; }
.foot-bottom {
  margin-top: 52px; padding-top: 26px; border-top:1px solid rgba(255,255,255,.1);
  font-size:14px; color:#7c7c90; display:flex; justify-content:space-between; flex-wrap:wrap; gap:10px;
}

/* ---------- Section heading ---------- */
.sec-head { text-align:center; max-width: 760px; margin: 0 auto; }
.sec-head h2 { font-size: clamp(34px, 4.4vw, 56px); }
.sec-head p { color: var(--muted); margin-top: 18px; font-size: 19px; }

/* ---------- reveal animation ---------- */
.reveal { opacity:0; transform: translateY(26px); transition: opacity .7s var(--ease), transform .7s var(--ease); }
.reveal.in { opacity:1; transform:none; }

/* ============================================================
   Direction A — Soft & Polished (page sections)
   ============================================================ */
.hero {
  position: relative; text-align: center;
  padding: 84px 0 40px;
  background:
    radial-gradient(70% 60% at 50% -8%, #eefbe4 0%, transparent 62%),
    radial-gradient(50% 50% at 84% 4%, #eaf3fd 0%, transparent 60%);
  overflow: hidden;
}
.hero h1 { font-family:'Sora','Fredoka',sans-serif; font-size: clamp(44px, 6.6vw, 84px); font-weight: 800; letter-spacing:-.03em; }
.hero .sub { color: var(--muted); font-size: clamp(18px,2vw,22px); max-width: 680px; margin: 22px auto 0; }
.hero .sub b { color: var(--ink); }

/* social icon row */
.socials { display:flex; gap:13px; justify-content:center; align-items:center; margin-top:30px; flex-wrap:wrap; }
.socials a {
  width:48px; height:48px; border-radius:50%;
  display:grid; place-items:center;
  background:#fff; border:2px solid var(--line); color:var(--ink-soft);
  box-shadow:var(--sh-sm);
  transition: transform .22s var(--ease), border-color .22s, color .22s, background .22s, box-shadow .22s;
}
.socials a svg { width:21px; height:21px; }
.socials a:hover { transform: translateY(-4px); border-color:transparent; background:var(--grad); color:var(--ink); box-shadow:var(--sh-color); }
.foot .socials { justify-content:flex-start; gap:11px; margin-top:0; }
.foot .socials a { width:44px; height:44px; background:rgba(255,255,255,.07); border-color:rgba(255,255,255,.13); color:#c9c9d6; box-shadow:none; }
.foot .socials a svg { width:19px; height:19px; }
.foot .socials a:hover { background:var(--grad); color:var(--ink); border-color:transparent; }
.foot .mail { display:inline-block; margin-top:18px; font-size:16px; }
.hero-cta { display:flex; gap:14px; justify-content:center; flex-wrap:wrap; margin-top:26px; }
.hero-note { margin-top:14px; color:var(--muted); font-size:15px; }

/* gallery grid */
.gallery { display:grid; grid-template-columns: repeat(5,1fr); gap:20px; margin-top:60px; }
.gallery .tile { box-shadow: var(--sh-sm); transition: transform .3s var(--ease), box-shadow .3s var(--ease); }
.gallery .tile:hover { transform: translateY(-8px) scale(1.02); box-shadow: var(--sh); }

/* generic section spacing */
section.band { padding: 96px 0; }
.band.tint { background: var(--bg-tint); }

/* 3-step */
.steps { display:grid; grid-template-columns: repeat(3,1fr); gap:28px; margin-top:58px; }
.step { text-align:center; position:relative; padding: 0 14px; }
.step .ico { width:74px; height:74px; border-radius:22px; margin:0 auto 22px; display:grid; place-items:center; background:var(--grad); box-shadow:var(--sh-color); }
.step .ico svg { width:34px; height:34px; }
.step h3 { font-size:25px; }
.step p { color:var(--muted); margin-top:12px; font-size:17px; }
.step .n { position:absolute; top:-6px; right:24%; font-family:'Fredoka';font-weight:600;font-size:60px;color:#eef1f6; z-index:-1;}

/* carousel */
.carousel { margin-top:54px; position:relative; }
.track-mask { overflow:hidden; }
.track { display:flex; gap:24px; transition: transform .5s var(--ease); }
.track .tile { flex: 0 0 calc((100% - 72px)/4); box-shadow:var(--sh-sm); }
.car-btn { position:absolute; top:50%; transform:translateY(-50%); width:54px; height:54px; border-radius:50%; background:#fff; border:1px solid var(--line); box-shadow:var(--sh); display:grid; place-items:center; cursor:pointer; z-index:3; transition:transform .2s; }
.car-btn:hover { transform:translateY(-50%) scale(1.08); }
.car-btn svg { width:22px;height:22px;color:var(--ink-soft); }
.car-prev{ left:-22px; } .car-next{ right:-22px; }
.dots { display:flex; gap:9px; justify-content:center; margin-top:30px; }
.dots i { width:9px;height:9px;border-radius:50%;background:#d9dde6; cursor:pointer; transition:.25s; }
.dots i.on { width:28px; border-radius:5px; background:var(--grad); }

/* patreon banner */
.pbanner {
  border-radius: var(--r-xl); padding: 76px 40px; text-align:center; position:relative; overflow:hidden;
  background: var(--grad);
}
.pbanner::before { content:''; position:absolute; inset:0; background: radial-gradient(60% 100% at 80% 120%, rgba(255,255,255,.4), transparent 60%); }
.pbanner h2 { font-size: clamp(32px,4.4vw,56px); position:relative; }
.pbanner .soon-chip { display:inline-flex; align-items:center; gap:8px; background:rgba(255,255,255,.65); color:var(--ink); font-family:'Fredoka'; font-weight:500; padding:9px 18px; border-radius:var(--r-pill); margin-bottom:22px; position:relative; }
.pbanner .pulse { width:9px;height:9px;border-radius:50%;background:var(--green-deep); box-shadow:0 0 0 0 rgba(111,184,74,.6); animation:pulse 2s infinite; }
@keyframes pulse { 70%{box-shadow:0 0 0 10px rgba(111,184,74,0);} 100%{box-shadow:0 0 0 0 rgba(111,184,74,0);} }
.pbanner form { display:flex; gap:10px; justify-content:center; max-width:440px; margin:26px auto 0; position:relative; flex-wrap:wrap; }
.pbanner input { flex:1; min-width:220px; border:none; border-radius:var(--r-pill); padding:15px 22px; font-family:'Nunito';font-size:16px; box-shadow:var(--sh-sm); }
.pbanner input:focus{ outline:3px solid rgba(255,255,255,.7); }
.notify-success { display:none; position:relative; margin-top:16px; font-family:'Fredoka'; color:var(--ink); }

/* exclusive split */
.split { display:grid; grid-template-columns: 1fr 1fr; gap:60px; align-items:center; }
.split h2 { font-size: clamp(32px,4.2vw,52px); }
.split p { color:var(--muted); margin-top:20px; font-size:18px; }
.split .perks { margin-top:26px; display:flex; flex-direction:column; gap:14px; }
.split .perk { display:flex; gap:13px; align-items:center; font-size:17px; }
.split .perk .ck { width:28px;height:28px;border-radius:50%;background:#eefbe4;color:var(--green-deep);display:grid;place-items:center;flex:none; }
.split .perk .ck svg{width:15px;height:15px;}
.split .showcase { aspect-ratio: 1/1; border-radius:var(--r-xl); box-shadow:var(--sh-lg); }

/* ============================================================
   Responsive
   ============================================================ */
@media (max-width: 980px){
  .gallery{ grid-template-columns: repeat(3,1fr); }
  .steps{ grid-template-columns:1fr; }
  .track .tile{ flex-basis: calc((100% - 24px)/2); }
  .split{ grid-template-columns:1fr; }
}
@media (max-width: 860px) {
  body { font-size: 17px; }
  .foot-grid { grid-template-columns: 1fr 1fr; }
  .foot .brand-col { grid-column: 1 / -1; }

  /* mobile menu */
  .nav-toggle { display:flex; }
  .nav-links {
    position:absolute; top:78px; left:0; right:0;
    flex-direction:column; align-items:stretch; gap:0;
    background:rgba(255,255,255,.97); backdrop-filter:saturate(160%) blur(14px);
    border-bottom:1px solid var(--line);
    padding:8px 6vw 18px;
    display:none;
  }
  .nav-links.open { display:flex; }
  .nav-links a { padding:13px 0; font-size:18px; }
  .nav-links .nav-cta { justify-content:center; margin-top:8px; padding:13px 20px; }
}
@media (max-width:560px){
  .gallery{grid-template-columns:repeat(2,1fr);}
  .track .tile{flex-basis:100%;}
  .car-prev{ left:-10px; } .car-next{ right:-10px; }
}

/* ============================================================
   Reduced motion — disable reveal / autoplay-driven transforms / hover lifts
   ============================================================ */
@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  * { animation-duration: .001ms !important; animation-iteration-count: 1 !important; transition-duration: .001ms !important; }
  .reveal { opacity:1 !important; transform:none !important; }
  .track { transition: none !important; }
  .btn:hover, .btn-primary:hover, .btn-ghost:hover,
  .nav-cta:hover, .socials a:hover, .car-btn:hover,
  .gallery .tile:hover { transform: none !important; }
  .pbanner .pulse { animation: none !important; }
}
