/* =========================================================
   PURPLE CLOVER CREATIONS — toy-store crochet world
   ========================================================= */

:root{
  --purple:#9D6FE0;
  --purple-deep:#7B4FC4;
  --purple-soft:#C9A6F0;
  --purple-wash:#EFE3FB;
  --mint:#8FD8B6;
  --sage:#A9D8B0;
  /* accent shifted from butter yellow to clover green (#93db68) */
  --butter:#93db68;
  --butter-deep:#4f9128;
  --pink:#FF9DC0;
  --pink-deep:#F47FB0;
  --cream:#FFF8EA;
  --paper:#FFFDF7;
  --ink:#4A3B6B;
  --ink-soft:#6E5E94;
  --crayon:#FF6B6B;
  --thread:#C9A6F0;
  --shadow:0 10px 0 rgba(123,79,196,.12), 0 16px 30px rgba(74,59,107,.14);
  --shadow-sm:0 5px 0 rgba(123,79,196,.14), 0 8px 16px rgba(74,59,107,.1);
  --round:22px;
  --display:"Fredoka",system-ui,"Segoe UI",sans-serif;
  --body:"Nunito",system-ui,"Segoe UI",sans-serif;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth; scroll-padding-top:90px}
body{
  margin:0;
  font-family:var(--body);
  color:var(--ink);
  background:var(--cream);
  background-image:
    radial-gradient(circle at 12% 18%, rgba(157,111,224,.07) 0 2px, transparent 3px),
    radial-gradient(circle at 80% 30%, rgba(255,157,192,.08) 0 2px, transparent 3px),
    radial-gradient(circle at 45% 75%, rgba(143,216,182,.08) 0 2px, transparent 3px),
    radial-gradient(circle at 90% 85%, rgba(147,219,104,.1) 0 2px, transparent 3px);
  background-size:120px 120px,160px 160px,140px 140px,180px 180px;
  line-height:1.6;
  overflow-x:hidden;
}
img,svg{max-width:100%;display:block}
a{color:var(--purple-deep);text-decoration:none}

:focus-visible{outline:3px dashed var(--purple);outline-offset:3px;border-radius:6px}

/* ---------- AMBIENT DOODLES ---------- */
.doodles{position:fixed;inset:0;pointer-events:none;z-index:0;overflow:hidden}
.doodle{position:absolute;opacity:.5;filter:drop-shadow(0 4px 6px rgba(74,59,107,.1))}
.doodle.d1{top:14%;left:4%;animation:float 9s ease-in-out infinite}
.doodle.d2{top:42%;right:5%;animation:float 11s ease-in-out infinite reverse}
.doodle.d3{bottom:18%;left:6%;animation:float 8s ease-in-out infinite}
.doodle.d4{bottom:36%;right:8%;animation:float 12s ease-in-out infinite reverse}
.doodle--yarn{animation-name:bob}
.stitch{position:absolute;width:2px;height:22px;border-radius:3px;background:var(--purple-soft);opacity:.45;transform:rotate(20deg)}
.s1{top:24%;left:24%;animation:bob 7s ease-in-out infinite}
.s2{top:60%;left:30%;height:14px;background:var(--pink);animation:bob 9s ease-in-out infinite}
.s3{top:30%;right:26%;height:18px;background:var(--mint);animation:bob 8s ease-in-out infinite}
.s4{bottom:30%;left:40%;height:12px;background:var(--butter);animation:bob 10s ease-in-out infinite}
.s5{bottom:10%;right:34%;height:20px;background:var(--purple-soft);animation:bob 7.5s ease-in-out infinite}

@keyframes float{0%,100%{transform:translateY(0) rotate(-4deg)}50%{transform:translateY(-16px) rotate(4deg)}}
@keyframes bob{0%,100%{transform:translateY(0)}50%{transform:translateY(-12px)}}
@keyframes wiggle{0%,100%{transform:rotate(-3deg)}50%{transform:rotate(3deg)}}
@keyframes wobble{0%,100%{transform:rotate(0)}25%{transform:rotate(-2.5deg)}75%{transform:rotate(2.5deg)}}

/* ---------- HEADER ---------- */
.site-header{
  position:sticky;top:0;z-index:50;
  display:flex;align-items:center;gap:18px;
  padding:12px clamp(16px,4vw,40px);
  background:rgba(255,248,234,.85);
  backdrop-filter:blur(8px);
  border-bottom:3px dashed var(--purple-soft);
}
.brand{display:flex;align-items:center;gap:10px;color:var(--ink);font-family:var(--display)}
.brand-name{font-size:1.18rem;line-height:1.05}
.brand-name em{display:block;font-style:normal;color:var(--purple-deep);font-size:.8rem;letter-spacing:2px;text-transform:uppercase}
.clover-logo{animation:wiggle 6s ease-in-out infinite}
.site-nav{display:flex;gap:6px;margin-left:auto;flex-wrap:wrap}
.site-nav a{
  padding:7px 12px;border-radius:999px;font-weight:700;font-size:.95rem;color:var(--ink-soft);
  transition:transform .2s,background .2s,color .2s;
}
.site-nav a:hover{background:var(--purple-wash);color:var(--purple-deep);transform:translateY(-2px)}
.nav-cta{margin-left:4px}

/* ---------- BUTTONS ---------- */
.btn{
  display:inline-flex;align-items:center;gap:8px;justify-content:center;
  font-family:var(--display);font-weight:600;font-size:1.02rem;
  padding:13px 24px;border-radius:999px;border:3px solid var(--ink);
  cursor:pointer;transition:transform .15s,box-shadow .15s,background .15s;
  background:var(--paper);color:var(--ink);box-shadow:0 5px 0 var(--ink);
}
.btn:hover{transform:translateY(-2px);box-shadow:0 7px 0 var(--ink)}
.btn:active{transform:translateY(3px);box-shadow:0 2px 0 var(--ink)}
.btn--primary{background:var(--purple);color:#fff;border-color:var(--purple-deep);box-shadow:0 5px 0 var(--purple-deep)}
.btn--primary:hover{box-shadow:0 7px 0 var(--purple-deep)}
.btn--primary:active{box-shadow:0 2px 0 var(--purple-deep)}
.btn--ghost{background:var(--butter);border-color:var(--butter-deep);box-shadow:0 5px 0 var(--butter-deep)}
.btn--ghost:hover{box-shadow:0 7px 0 var(--butter-deep)}
.btn--ghost:active{box-shadow:0 2px 0 var(--butter-deep)}
.btn--pop{background:var(--pink);border-color:var(--pink-deep);box-shadow:0 5px 0 var(--pink-deep)}
.wobble:hover{animation:wobble .5s ease-in-out}
.tag--wiggle{animation:wiggle 5s ease-in-out infinite}

/* ---------- LAYOUT HELPERS ---------- */
main{position:relative;z-index:1}
section{padding:clamp(48px,7vw,90px) clamp(16px,5vw,56px);position:relative}
.section-head{text-align:center;max-width:640px;margin:0 auto clamp(28px,4vw,46px)}
.kicker{
  display:inline-block;font-family:var(--display);font-weight:600;text-transform:uppercase;
  letter-spacing:2px;font-size:.78rem;color:var(--purple-deep);
  background:var(--purple-wash);padding:5px 14px;border-radius:999px;margin-bottom:10px;
}
.section-head h2,.hero-title,.how h2,.maker-text h2,.inquiry h2,.basket h2,.faq h2{
  font-family:var(--display);font-weight:700;line-height:1.05;margin:0 0 8px;
}
.section-head h2{font-size:clamp(1.9rem,5vw,3rem)}
.section-head p{color:var(--ink-soft);margin:0;font-size:1.05rem}

/* ---------- HERO ---------- */
.hero{
  display:grid;grid-template-columns:1.1fr .9fr;gap:30px;align-items:center;
  max-width:1180px;margin:0 auto;padding-top:clamp(40px,7vw,80px);
}
.hero-stack{position:relative;z-index:2}
.tag{
  display:inline-block;background:var(--butter);color:var(--ink);
  font-weight:700;font-size:.85rem;padding:6px 16px;border-radius:999px;
  border:2px solid var(--ink);box-shadow:0 3px 0 var(--ink);transform:rotate(-2deg);margin-bottom:18px;
}
.hero-title{font-size:clamp(2.4rem,7vw,4.6rem);font-family:var(--display);font-weight:700;line-height:.98}
.hero-title .swap{position:relative;color:var(--purple-deep);display:inline-block}
.hero-title .swap::after{
  content:"";position:absolute;left:-4px;right:-4px;bottom:6px;height:14px;
  background:var(--butter);z-index:-1;border-radius:6px;transform:rotate(-1deg);
}
.hero-sub{font-size:clamp(1.02rem,2vw,1.2rem);color:var(--ink-soft);max-width:34ch;margin:18px 0 26px}
.hero-ctas{display:flex;gap:14px;flex-wrap:wrap}
.hero-badges{display:flex;gap:10px;flex-wrap:wrap;margin-top:26px}
.chip{
  font-size:.85rem;font-weight:700;color:var(--purple-deep);
  background:var(--paper);border:2px dashed var(--purple-soft);padding:5px 13px;border-radius:999px;
}
.hero-mascot{position:relative;z-index:1;animation:bob 5s ease-in-out infinite}
.floaty{position:absolute;font-size:clamp(1.6rem,4vw,2.6rem);z-index:3}
.floaty--a{top:8%;right:8%;animation:bob 6s ease-in-out infinite}
.floaty--b{bottom:14%;left:6%;animation:bob 7s ease-in-out infinite reverse}
.floaty--c{top:40%;right:42%;animation:bob 8s ease-in-out infinite}

/* ---------- WAVE DIVIDER ---------- */
.wave{position:relative;margin-top:-1px;line-height:0}
.wave svg{width:100%;height:50px;display:block}

/* ---------- SHELF ---------- */
.shelves{max-width:1080px;margin:0 auto}
.shelf-board{
  position:relative;display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(16px,3vw,30px);
  margin-bottom:clamp(30px,5vw,54px);
}
.shelf-board::after{
  content:"";position:absolute;left:-2%;right:-2%;bottom:-14px;height:18px;
  background:linear-gradient(#d8a86a,#c08e4e);border-radius:8px;
  box-shadow:0 8px 0 #a9763c, 0 14px 18px rgba(74,59,107,.18);
}
.shelf-board:nth-child(2){margin-top:clamp(40px,6vw,70px)}

.toy-card,.critter,.maker-card,.form-card,.basket{
  position:relative;background:var(--paper);
  border:3px solid var(--ink);border-radius:var(--round);
  padding:22px 20px 24px;box-shadow:var(--shadow-sm);
}
.toy-card{padding-top:30px}
.tilt-l{transform:rotate(-2.2deg)}
.tilt-r{transform:rotate(2.2deg)}
.toy-card:hover,.critter:hover,.maker-card:hover,.form-card:hover{transform:rotate(0deg) translateY(-6px)}
.card-art{width:clamp(90px,14vw,130px);height:clamp(90px,14vw,130px);margin:0 auto 10px;transition:transform .3s}
.toy-card:hover .card-art,.critter:hover .critter-art{transform:scale(1.06) rotate(-3deg)}
.toy-card h3{font-family:var(--display);font-size:1.18rem;margin:8px 0 4px;text-align:center}
.toy-card p{margin:0;font-size:.92rem;color:var(--ink-soft);text-align:center}
.card--wild{background:var(--purple-wash)}
.sticker{
  position:absolute;top:-12px;right:14px;z-index:2;
  background:var(--crayon);color:#fff;font-family:var(--display);font-weight:600;
  font-size:.72rem;letter-spacing:1px;text-transform:uppercase;
  padding:5px 12px;border-radius:6px;transform:rotate(8deg);
  box-shadow:0 3px 0 var(--ink);border:2px solid var(--ink);
}
.sticker--mint{background:var(--mint);color:var(--ink)}
.sticker--butter{background:var(--butter);color:var(--ink)}
.tilt-l .sticker{transform:rotate(-8deg)}
.tilt-r .sticker{transform:rotate(10deg)}

/* ---------- HOW IT WORKS ---------- */
.how{background:linear-gradient(180deg,transparent,var(--purple-wash) 18%,var(--purple-wash) 82%,transparent)}
.steps{position:relative;max-width:980px;margin:0 auto;display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.steps-path{position:absolute;left:0;right:0;top:30px;height:70px;width:100%;z-index:0}
.step{position:relative;z-index:1;text-align:center}
.step-num{
  width:64px;height:64px;margin:0 auto 14px;border-radius:50%;
  display:grid;place-items:center;font-family:var(--display);font-weight:700;font-size:1.7rem;color:#fff;
  background:var(--purple);border:3px solid var(--ink);box-shadow:0 5px 0 var(--ink);
  animation:bob 4s ease-in-out infinite;
}
.step-num--pink{background:var(--pink-deep);box-shadow:0 5px 0 var(--ink);animation-delay:.4s}
.step-num--mint{background:var(--mint);color:var(--ink);box-shadow:0 5px 0 var(--ink);animation-delay:.8s}
.step-num--butter{background:var(--butter);color:var(--ink);box-shadow:0 5px 0 var(--ink);animation-delay:1.2s}
.step h3{font-family:var(--display);font-size:1.12rem;margin:0 0 4px}
.step p{margin:0;font-size:.92rem;color:var(--ink-soft)}
.steps-note{text-align:center;color:var(--ink-soft);font-size:.85rem;margin-top:34px;font-style:italic}

/* ---------- GALLERY ---------- */
.gallery-grid{max-width:1040px;margin:0 auto;display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(18px,3vw,30px)}
.critter{padding:18px;background:var(--paper)}
.critter-art{width:100%;aspect-ratio:1;transition:transform .3s}
.critter figcaption{display:flex;flex-direction:column;text-align:center;margin-top:6px}
.critter figcaption b{font-family:var(--display);font-size:1.08rem}
.critter figcaption span{font-size:.84rem;color:var(--ink-soft)}
.critter:nth-child(odd){background:var(--purple-wash)}
.critter:nth-child(3n){background:#FFF0F6}

/* ---------- SECRET / IDEA BASKET ---------- */
.secret{padding-top:clamp(40px,6vw,70px);padding-bottom:clamp(40px,6vw,70px)}
.basket{
  max-width:560px;margin:0 auto;text-align:center;
  background:transparent;border:none;padding:0;
}
.basket-head{margin-bottom:4px}
.basket-head h2{font-size:clamp(1.6rem,4vw,2.3rem)}
.basket-cue{color:var(--ink-soft);margin:6px auto 0;max-width:34ch;font-size:1.02rem}

/* --- decorative woven basket scene --- */
.basket-stage{
  position:relative;width:clamp(230px,82%,360px);aspect-ratio:5/4;margin:18px auto 0;
  perspective:640px;
}
.basket-handle{
  position:absolute;top:6%;left:26%;right:26%;height:36%;z-index:1;
  border:11px solid #8a5520;border-bottom:none;border-radius:90px 90px 0 0;
  background:transparent;box-shadow:inset 0 7px 0 rgba(255,235,190,.16);
}
.basket-body{
  position:absolute;left:5%;right:5%;bottom:3%;height:60%;z-index:2;
  border-radius:18px 18px 34px 34px;border-top:10px solid #efd49a;
  background:
    repeating-linear-gradient(0deg, rgba(90,56,18,.20) 0 3px, transparent 3px 12px),
    repeating-linear-gradient(90deg, rgba(255,240,205,.16) 0 3px, transparent 3px 12px),
    linear-gradient(180deg,#d29445,#a86722);
  box-shadow:inset 0 -12px 0 rgba(80,46,12,.22),0 9px 0 #6e4514,0 16px 22px rgba(74,59,107,.18);
}
.basket-band{
  position:absolute;left:0;right:0;bottom:26%;height:12px;
  background:linear-gradient(180deg,#7c4a17,#5e3710);
  box-shadow:inset 0 2px 0 rgba(255,235,190,.18);
}
.peek-balls{
  position:absolute;left:14%;right:14%;bottom:58%;height:26%;z-index:3;
  display:flex;align-items:flex-end;justify-content:center;gap:5%;
}
.peek-ball{
  position:relative;width:23%;aspect-ratio:1;border-radius:50%;
  box-shadow:inset -4px -6px 0 rgba(0,0,0,.12),0 3px 5px rgba(74,59,107,.2);
  transform-origin:50% 100%;transition:transform .4s cubic-bezier(.34,1.56,.64,1);
}
.peek-ball::after{content:"";position:absolute;top:18%;right:26%;width:20%;height:20%;border-radius:50%;background:rgba(255,255,255,.6)}
.pp1{background:radial-gradient(circle at 38% 32%,#E7D2FA,var(--purple))}
.pp2{background:radial-gradient(circle at 38% 32%,#FFE0EE,var(--pink))}
.pp3{background:radial-gradient(circle at 38% 32%,#DFF5EC,var(--mint))}
.pp4{background:radial-gradient(circle at 38% 32%,#FFF3B8,#FFE27A)}
.basket[data-open="true"] .pp1{transform:translateY(-12px) rotate(-8deg);animation:spill 1.7s ease-in-out infinite}
.basket[data-open="true"] .pp2{transform:translateY(-9px) rotate(6deg);animation:spill 1.9s ease-in-out infinite .12s}
.basket[data-open="true"] .pp3{transform:translateY(-15px) rotate(-4deg);animation:spill 1.8s ease-in-out infinite .22s}
.basket[data-open="true"] .pp4{transform:translateY(-8px) rotate(10deg);animation:spill 2s ease-in-out infinite .06s}
@keyframes spill{0%,100%{transform:translateY(0) rotate(0)}50%{transform:translateY(-7px) rotate(4deg)}}
.basket-lid{
  position:absolute;left:5%;right:5%;bottom:60%;height:15%;z-index:4;
  border-radius:12px;transform-origin:50% 0%;
  transition:transform .5s cubic-bezier(.34,1.56,.64,1);
  background:
    repeating-linear-gradient(0deg, rgba(90,56,18,.20) 0 3px, transparent 3px 12px),
    repeating-linear-gradient(90deg, rgba(255,240,205,.16) 0 3px, transparent 3px 12px),
    linear-gradient(180deg,#d89a4f,#b9762c);
  box-shadow:0 4px 0 #6e4514,0 6px 10px rgba(74,59,107,.2);
}
.lid-knob{
  position:absolute;left:50%;top:50%;width:16px;height:16px;border-radius:50%;
  transform:translate(-50%,-50%);
  background:radial-gradient(circle at 38% 32%,#fff,var(--purple-soft));
  box-shadow:inset -2px -3px 0 rgba(123,79,196,.3);
}
.basket[data-open="true"] .basket-lid{transform:rotateX(-138deg)}

/* --- the yarn pull --- */
.yarn-pull{
  position:relative;display:flex;flex-direction:column;align-items:center;
  margin-top:-4px;
}
.yarn-string{
  width:5px;height:14px;border-radius:4px;
  background-image:repeating-linear-gradient(180deg,var(--purple) 0 6px,var(--purple-deep) 6px 12px);
  transition:height .35s cubic-bezier(.34,1.56,.64,1);
}
/* open = the string stretches in normal flow, so the ball + label ride down
   with it. No translateY on the ball, no magic margin on the label: the three
   pieces stay attached and can never overlap in either state. */
.basket[data-open="true"] .yarn-string{height:64px}
.yarn-ball{
  width:58px;height:58px;padding:0;border:none;border-radius:50%;cursor:grab;
  touch-action:none;position:relative;z-index:2;
  background:radial-gradient(circle at 38% 32%,#E7D2FA,var(--purple));
  box-shadow:inset -6px -8px 0 rgba(123,79,196,.3),0 6px 0 var(--purple-deep),0 10px 16px rgba(74,59,107,.25);
  transition:transform .35s cubic-bezier(.34,1.56,.64,1),box-shadow .2s;
}
.yarn-ball-core{
  position:absolute;inset:0;border-radius:50%;pointer-events:none;
  background:
    repeating-linear-gradient(115deg, rgba(255,255,255,.12) 0 2px, transparent 2px 7px),
    repeating-linear-gradient(65deg, rgba(80,40,130,.18) 0 2px, transparent 2px 8px);
}
.yarn-ball:hover{transform:scale(1.08)}
.yarn-ball:active{cursor:grabbing}
.yarn-ball:focus-visible{outline:3px dashed var(--ink);outline-offset:4px}
/* open ball just settles a touch smaller (string did the pulling) */
.basket[data-open="true"] .yarn-ball{transform:scale(.93)}
.yarn-pull-label{
  margin-top:14px;font-family:var(--display);font-weight:600;font-size:.92rem;
  color:var(--purple-deep);background:var(--purple-wash);padding:4px 12px;border-radius:999px;
}
/* tiny "pull down" affordance under the label — shown only when closed.
   Nudge is DOWN-only so it can never collide with the label above it. */
@keyframes pullNudge{0%,100%{transform:translateY(0)}50%{transform:translateY(4px)}}
.pull-hint{
  margin-top:8px;font-family:var(--display);font-weight:600;font-size:.7rem;
  letter-spacing:1.5px;text-transform:uppercase;color:var(--purple-deep);opacity:.8;
  animation:pullNudge 2.2s ease-in-out infinite;
}
.basket[data-open="true"] .pull-hint{display:none}

/* --- the reveal --- */
.reveal-panel{
  max-height:0;overflow:hidden;opacity:0;transform:translateY(10px);
  transition:max-height .55s ease,opacity .4s ease,transform .4s ease;
}
.basket[data-open="true"] .reveal-panel{max-height:920px;opacity:1;transform:none}
.basket-interior{
  margin-top:20px;background:var(--paper);border:3px dashed var(--purple-deep);
  border-radius:20px;padding:clamp(18px,4vw,26px);text-align:left;position:relative;
  box-shadow:var(--shadow-sm);
}
.clover-mini{font-size:1.6rem}
.basket-interior h3{font-family:var(--display);margin:2px 0 14px;font-size:1.2rem;text-align:center}
.story-steps{list-style:none;margin:0 auto 16px;padding:0;max-width:42ch;display:grid;gap:6px}
.story-step{display:flex;gap:12px;align-items:flex-start;background:var(--purple-wash);border-radius:14px;padding:10px 12px}
.story-emoji{font-size:1.5rem;line-height:1.1;flex:0 0 auto}
.story-text{display:flex;flex-direction:column}
.story-text b{font-family:var(--display);color:var(--purple-deep);font-size:.98rem}
.story-text em{font-style:normal;color:#5a4a7e;font-size:.92rem}
.story-arrow{text-align:center;color:var(--purple-deep);font-weight:700;font-size:1rem;line-height:1}
.story-cta{margin:6px auto 16px;display:inline-flex}
.story-cta span{font-family:var(--display)}
.reveal-note{
  position:relative;background:#FFF6E0;border:2px dashed #E0B400;border-radius:14px;
  padding:12px 14px 12px 40px;font-size:.95rem;color:var(--ink);
}
.note-tag{
  position:absolute;left:-6px;top:-10px;background:#FFE27A;color:#7a5b00;
  font-family:var(--display);font-size:.72rem;letter-spacing:1px;text-transform:uppercase;
  padding:3px 8px;border-radius:999px;transform:rotate(-6deg);box-shadow:0 2px 0 #cba800;
}
.reveal-fine{font-size:.78rem;opacity:.85;text-align:center;font-style:italic;margin-top:10px}

/* --- reduced motion: stop the infinite peek-ball spill + snap transitions --- */
@media (prefers-reduced-motion: reduce){
  .basket .peek-ball,
  .basket[data-open="true"] .peek-ball{animation:none !important}
  .basket .basket-lid,
  .basket .yarn-string,
  .basket .yarn-ball,
  .basket .reveal-panel,
  .basket .pull-hint{transition-duration:.01ms !important;animation:none !important}
}

/* ---------- MAKER ---------- */
.maker-card{max-width:860px;margin:0 auto;display:grid;grid-template-columns:200px 1fr;gap:28px;align-items:center;padding:clamp(22px,4vw,34px)}
.maker-portrait{width:100%;max-width:200px;margin:0 auto}
.maker-portrait svg{border-radius:50%;background:var(--purple-wash);box-shadow:var(--shadow-sm)}
.maker-text h2{font-size:clamp(1.7rem,4vw,2.4rem)}
.maker-text p{color:var(--ink-soft);margin:0 0 12px}

/* ---------- INQUIRY ---------- */
.inquiry{background:linear-gradient(180deg,transparent,var(--purple-wash) 20%,var(--purple-wash) 80%,transparent)}
.form-card{max-width:620px;margin:0 auto;padding:clamp(26px,4vw,40px)}
.form-card h2{font-size:clamp(1.5rem,4vw,2.2rem);line-height:1.1}
.form-intro{color:var(--ink-soft);margin:6px 0 22px}
.dream-form{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.field{display:flex;flex-direction:column;gap:6px}
.field--full{grid-column:1 / -1}
.field label{font-weight:700;font-size:.92rem;font-family:var(--display)}
.opt{font-weight:400;color:var(--ink-soft);font-family:var(--body)}
.field input,.field textarea{
  font-family:var(--body);font-size:1rem;color:var(--ink);
  padding:12px 14px;border:3px solid var(--ink);border-radius:14px;background:var(--cream);
  transition:box-shadow .2s,transform .15s;
}
.field input::placeholder,.field textarea::placeholder{color:#b6a9d4}
.field input:focus,.field textarea:focus{
  outline:none;border-color:var(--purple-deep);
  box-shadow:0 0 0 4px var(--purple-wash);background:var(--paper);
}
.field textarea{resize:vertical}
.submit-btn{grid-column:1 / -1;margin-top:6px;width:100%}
.form-fine{grid-column:1 / -1;font-size:.78rem;color:var(--ink-soft);opacity:.8;text-align:center;margin:6px 0 0}

.form-success{text-align:center;padding:10px 0}
.success-burst{position:absolute;inset:0;pointer-events:none;overflow:hidden;border-radius:var(--round)}
.big-emoji{font-size:3.4rem;display:block;animation:bob 2s ease-in-out infinite}
.form-success h3{font-family:var(--display);font-size:1.6rem;margin:8px 0}
.form-success p{color:var(--ink-soft);margin:0 0 20px}

/* confetti stitch bits */
.bit{position:absolute;width:8px;height:8px;border-radius:2px;opacity:0;animation:pop 1s ease-out forwards}
@keyframes pop{0%{opacity:1;transform:translate(0,0) scale(1) rotate(0)}100%{opacity:0;transform:translate(var(--x),var(--y)) scale(.4) rotate(360deg)}}

/* ---------- FAQ ---------- */
.faq-list{max-width:760px;margin:0 auto;display:flex;flex-direction:column;gap:14px}
.faq-item{
  background:var(--paper);border:3px solid var(--ink);border-radius:16px;
  padding:4px 18px;box-shadow:var(--shadow-sm);
}
.faq-item summary{
  cursor:pointer;list-style:none;font-family:var(--display);font-weight:600;font-size:1.08rem;
  padding:14px 0;display:flex;align-items:center;justify-content:space-between;
}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary::after{
  content:"+";font-size:1.5rem;color:var(--purple-deep);transition:transform .25s;
}
.faq-item[open] summary::after{transform:rotate(45deg)}
.faq-item[open] summary{color:var(--purple-deep)}
.faq-item p{margin:0 0 16px;color:var(--ink-soft)}
.ph{font-style:italic;color:var(--ink-soft);opacity:.75}

/* ---------- WORKSHOP / CUSTOM STUFFY BUILDER ---------- */
.workshop{background:linear-gradient(180deg,transparent,var(--purple-wash) 10%,var(--purple-wash) 90%,transparent)}
.workshop .section-head{margin-bottom:22px}

.workshop-topbar{
  position:sticky;top:74px;z-index:20;
  display:flex;align-items:center;gap:14px;flex-wrap:wrap;
  max-width:1080px;margin:0 auto clamp(18px,3vw,28px);
  padding:12px 16px;border-radius:18px;
  background:rgba(255,253,247,.94);backdrop-filter:blur(8px);
  border:3px solid var(--ink);box-shadow:var(--shadow-sm);
}
.nametag{
  display:inline-flex;align-items:center;gap:8px;
  background:var(--butter);border:2px solid var(--ink);
  padding:6px 14px;border-radius:8px;transform:rotate(-2deg);
  font-family:var(--display);font-weight:600;color:var(--ink);
  box-shadow:0 3px 0 var(--ink);max-width:220px;
}
.nametag-pin{font-size:1rem}
.nametag-text{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:160px}
.meter{display:flex;align-items:center;gap:8px;flex:1 1 220px;min-width:200px}
.meter-label{font-family:var(--display);font-weight:600;font-size:.74rem;text-transform:uppercase;letter-spacing:1px;color:var(--ink-soft)}
.meter-track{flex:1;height:14px;border-radius:999px;background:var(--purple-wash);border:2px solid var(--ink);overflow:hidden;position:relative}
.meter-bar{display:block;height:100%;width:70%;border-radius:999px;background:linear-gradient(90deg,var(--mint),var(--butter),var(--pink),var(--purple));transition:width .45s cubic-bezier(.34,1.56,.64,1)}
.meter-value{font-family:var(--display);font-weight:700;font-size:1.2rem;color:var(--purple-deep);min-width:22px;text-align:right}
.workshop-actions{display:flex;gap:10px;flex-wrap:wrap;margin-left:auto}
.workshop-actions .btn{padding:9px 16px;font-size:.9rem}

.workshop-grid{
  display:grid;grid-template-columns:1fr 1fr;gap:clamp(18px,3vw,30px);
  max-width:1080px;margin:0 auto;align-items:start;
}
.ws-preview-pane,.ws-controls-pane{
  background:var(--paper);border:3px solid var(--ink);border-radius:var(--round);
  box-shadow:var(--shadow-sm);padding:18px;
}
.ws-preview-pane{position:sticky;top:150px;display:flex;flex-direction:column;gap:12px}
.ws-preview-label{
  font-family:var(--display);font-weight:600;font-size:.74rem;text-transform:uppercase;
  letter-spacing:2px;color:var(--purple-deep);background:var(--purple-wash);
  padding:5px 12px;border-radius:999px;align-self:flex-start;
}
.ws-stage{
  aspect-ratio:1/1;width:100%;max-width:380px;margin:0 auto;
  background:radial-gradient(circle at 50% 38%, #fff, var(--cream));
  border:3px dashed var(--purple-soft);border-radius:20px;
  display:grid;place-items:center;padding:12px;
}
.ws-stage svg{width:100%;height:100%;animation:bob 5s ease-in-out infinite}
.ws-shaking{animation:wsShake .55s ease-in-out}
@keyframes wsShake{
  0%,100%{transform:rotate(0)}
  15%{transform:rotate(-7deg) translateY(-8px)}
  35%{transform:rotate(6deg) translateY(5px)}
  55%{transform:rotate(-5deg) translateY(-4px)}
  75%{transform:rotate(4deg) translateY(3px)}
}
.ws-summary{
  text-align:center;font-size:.94rem;color:var(--ink-soft);
  font-family:var(--display);min-height:1.4em;margin:0;
}

/* progress rail — full-width, one polished row on desktop, intentional wrap below */
.ws-rail{
  list-style:none;margin:0 auto clamp(16px,2.5vw,24px);padding:10px 12px;
  max-width:1080px;display:flex;align-items:stretch;gap:6px;
  background:var(--cream);border:3px dashed var(--purple-soft);border-radius:18px;
  position:relative;
}
.ws-rail::before{
  /* dotted connector line that runs behind the numbered chips */
  content:"";position:absolute;left:26px;right:26px;top:50%;
  height:0;border-top:3px dotted var(--purple-soft);transform:translateY(-50%);
  z-index:0;pointer-events:none;
}
.ws-rail li{
  position:relative;z-index:1;
  flex:1 1 0;min-width:92px;
  display:flex;flex-direction:column;align-items:center;gap:5px;
  cursor:pointer;font-family:var(--display);font-weight:600;
  font-size:.78rem;color:var(--ink-soft);text-align:center;
  padding:8px 4px 6px;border-radius:14px;transition:background .2s,color .2s,transform .15s;
  border:none;background:var(--cream);
}
.ws-rail li span{
  display:inline-grid;place-items:center;width:30px;height:30px;border-radius:50%;
  background:#fff;color:var(--purple-deep);font-size:.82rem;
  border:3px solid var(--purple-soft);
  box-shadow:0 2px 0 rgba(123,79,196,.18);
  transition:background .2s,color .2s,border-color .2s,box-shadow .2s,transform .15s;
}
.ws-rail li em{font-style:normal;line-height:1;letter-spacing:.2px}
.ws-rail li:hover{background:var(--purple-wash);color:var(--purple-deep);transform:translateY(-1px)}
.ws-rail li:hover span{border-color:var(--purple)}
.ws-rail li:focus-visible{outline:3px dashed var(--purple);outline-offset:2px}
.ws-rail li.is-active{background:var(--purple);color:#fff;transform:translateY(-2px)}
.ws-rail li.is-active span{
  background:#fff;border-color:#fff;color:var(--purple-deep);
  box-shadow:0 4px 0 var(--purple-deep);transform:scale(1.08);
}
.ws-rail li.is-done span{background:var(--mint);border-color:var(--mint);color:var(--ink)}
.ws-rail li.is-done{opacity:.85}
.ws-rail li.is-done::after{
  content:"✓";position:absolute;top:4px;right:8px;font-size:.7rem;color:var(--mint);
  font-family:var(--body);font-weight:700;
}

.ws-panels{position:relative;min-height:250px}
.ws-panel{display:none}
.ws-panel.is-active{display:block;animation:wsFade .3s ease}
.ws-panel h3{font-family:var(--display);font-size:1.14rem;margin:0 0 12px;color:var(--ink)}
.ws-sub{font-family:var(--body);font-weight:400;font-size:.82rem;color:var(--ink-soft)}
@keyframes wsFade{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}

.ws-choices{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}
.ws-choice{
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;
  padding:12px 8px;border-radius:14px;cursor:pointer;
  background:var(--cream);border:3px solid transparent;
  font-family:var(--display);font-weight:600;font-size:.86rem;color:var(--ink);
  transition:transform .15s,border-color .15s,background .15s,box-shadow .15s;
  box-shadow:0 3px 0 rgba(123,79,196,.12);
}
.ws-choice:hover{transform:translateY(-3px);border-color:var(--purple-soft)}
.ws-choice:focus-visible{outline:3px dashed var(--purple);outline-offset:2px}
.ws-choice[aria-pressed="true"]{
  border-color:var(--purple-deep);background:var(--purple-wash);
  box-shadow:0 3px 0 var(--purple-deep);transform:translateY(-2px);
}
.ws-choice-emoji{font-size:1.6rem;line-height:1}
.ws-choice-label{text-align:center;line-height:1.1}
.ws-choice--color{padding:10px 8px 8px}
.ws-swatch{display:block;width:100%;height:26px;border-radius:8px;border:2px solid var(--ink);margin-bottom:2px}

.ws-field-label{display:block;font-family:var(--display);font-weight:600;margin-bottom:6px}
.ws-input{
  width:100%;font-family:var(--body);font-size:1.08rem;color:var(--ink);
  padding:12px 14px;border:3px solid var(--ink);border-radius:14px;background:var(--cream);
}
.ws-input:focus{outline:none;border-color:var(--purple-deep);box-shadow:0 0 0 4px var(--purple-wash);background:var(--paper)}
.ws-hint{font-size:.82rem;color:var(--ink-soft);margin-top:10px}

/* finished card */
.ws-card{
  display:grid;grid-template-columns:130px 1fr;gap:16px;align-items:center;
  background:linear-gradient(135deg,var(--purple-wash),#FFF0F6);
  border:3px dashed var(--purple-deep);border-radius:18px;padding:16px;
}
.ws-card-art{width:100%;height:auto;background:var(--paper);border-radius:12px;border:2px solid var(--ink)}
.ws-card-body{display:flex;flex-direction:column;gap:3px}
.ws-card-name{font-family:var(--display);font-weight:700;font-size:1.28rem;color:var(--purple-deep);line-height:1.1}
.ws-card-tag{font-size:.84rem;color:var(--ink-soft);font-style:italic;margin-bottom:6px}
.ws-card-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:3px}
.ws-card-list li{font-size:.86rem;color:var(--ink)}
.ws-card-list b{color:var(--purple-deep);font-family:var(--display)}
.ws-card-made{margin:8px 0 0;font-size:.78rem;color:var(--ink-soft)}

.ws-nav{display:flex;gap:10px;flex-wrap:wrap;margin-top:18px}
.ws-nav .btn{flex:1;min-width:120px;padding:11px 14px;font-size:.94rem}
.ws-nav .btn:disabled{opacity:.4;cursor:not-allowed;transform:none;box-shadow:0 3px 0 var(--butter-deep)}

.ws-foot{max-width:760px;margin:24px auto 0;text-align:center;font-size:.85rem;color:var(--ink-soft);font-style:italic}

@media (max-width:900px){
  .workshop-grid{grid-template-columns:1fr}
  .ws-preview-pane{position:static;top:auto;order:-1}
  .workshop-topbar{position:static;top:auto}
  .workshop-actions{margin-left:0}
}
@media (max-width:760px){
  /* rail becomes an intentional 4+3 grid instead of a cramped single row */
  .ws-rail::before{display:none}
  .ws-rail{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;padding:10px}
  .ws-rail li{flex:none;min-width:0;font-size:.74rem}
  .ws-rail li span{width:26px;height:26px;font-size:.74rem}
}
@media (max-width:560px){
  .ws-choices{grid-template-columns:repeat(2,1fr)}
  .ws-card{grid-template-columns:1fr;text-align:center}
  .ws-card-art{max-width:160px;margin:0 auto}
  .ws-nav .btn{flex:1 1 100%}
  .meter{flex-basis:100%}
  .nametag,.workshop-actions{flex:1 1 100%}
  .ws-rail li{font-size:.66rem}
  .ws-rail li span{width:24px;height:24px;border-width:2px}
}

/* ---------- FOOTER ---------- */
.site-footer{
  background:var(--purple);color:#fff;margin-top:30px;padding:clamp(34px,5vw,52px) clamp(16px,5vw,56px) 22px;
  position:relative;z-index:1;border-top:4px dashed rgba(255,255,255,.5);
}
.foot-inner{max-width:1080px;margin:0 auto;display:flex;flex-wrap:wrap;gap:24px;align-items:flex-start;justify-content:space-between}
.foot-brand{display:flex;align-items:center;gap:12px;font-family:var(--display)}
.foot-brand strong{display:block;font-size:1.15rem}
.foot-brand span{font-size:.9rem;opacity:.85;font-family:var(--body)}
.foot-brand .clover-logo{filter:saturate(.4) brightness(2.4)}
.foot-nav{display:flex;gap:14px;flex-wrap:wrap}
.foot-nav a{color:#fff;opacity:.9;font-weight:700;font-size:.95rem;border-bottom:2px dashed transparent}
.foot-nav a:hover{opacity:1;border-color:#fff}
.foot-contact{display:flex;flex-direction:column;gap:2px;text-align:right}
.foot-contact a{color:#fff;font-weight:700}
.foot-contact .ph{color:rgba(255,255,255,.7)}
.foot-fine{text-align:center;font-size:.78rem;opacity:.8;max-width:760px;margin:30px auto 0;font-family:var(--body)}
.site-footer .ph{color:rgba(255,255,255,.7)}

/* ---------- BACK TO TOP ---------- */
.to-top{
  position:fixed;right:18px;bottom:18px;width:54px;height:54px;border-radius:50%;
  border:3px solid var(--ink);background:var(--butter);font-size:24px;cursor:pointer;
  box-shadow:0 5px 0 var(--ink);z-index:60;opacity:0;pointer-events:none;transform:translateY(20px) scale(.8);
  transition:opacity .3s,transform .3s;
}
.to-top.show{opacity:1;pointer-events:auto;transform:none;animation:bob 3s ease-in-out infinite}
.to-top:hover{transform:scale(1.08)}

/* ---------- ENTRANCE REVEAL ---------- */
.reveal{opacity:1;transform:none}
.reveal.in{opacity:1;transform:none;transition:transform .6s ease}

/* ---------- RESPONSIVE ---------- */
@media (max-width:900px){
  .site-nav{display:none}
  .hero{grid-template-columns:1fr;text-align:center;padding-top:30px}
  .hero-stack{order:2}
  .hero-mascot{order:1;max-width:300px;margin:0 auto}
  .hero-ctas,.hero-badges{justify-content:center}
  .hero-sub{margin-left:auto;margin-right:auto}
  .floaty--c{display:none}
  .gallery-grid{grid-template-columns:repeat(2,1fr)}
  .maker-card{grid-template-columns:1fr;text-align:center}
  .maker-portrait{max-width:160px}
}
@media (max-width:680px){
  .shelf-board{grid-template-columns:1fr;gap:22px}
  .shelf-board::after{display:none}
  .steps{grid-template-columns:1fr 1fr;gap:24px 14px}
  .steps-path{display:none}
  .dream-form{grid-template-columns:1fr}
  .gallery-grid{grid-template-columns:1fr 1fr}
  .brand-name{font-size:1rem}
  .nav-cta{padding:9px 16px;font-size:.9rem}
}
@media (max-width:440px){
  .gallery-grid{grid-template-columns:1fr}
  .hero-title{font-size:2.3rem}
  .floaty{display:none}
}

/* ---------- MOTION PREFERENCE ---------- */
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation:none !important;transition:none !important;scroll-behavior:auto !important}
  .reveal{opacity:1;transform:none}
}
