/* ===== TrainWiz LP — kawaii cream × candy ===== */
:root{
  --cream:#FBF6EC; --cream-2:#F5ECDB; --paper:#FFFDF8;
  --ink:#2C2620; --ink-2:#6B6052; --line:#EBE0CB;
  --coral:#FF7A66; --mint:#43C9A0; --sky:#5BB4F0; --butter:#FFC247; --grape:#9B8CFF;
  --coral-i:#5A2218; --mint-i:#0E4D3B; --sky-i:#143F5E; --grape-i:#352A6B; --butter-i:#5B3F08;
  --r:22px; --rl:30px;
  --shadow:0 18px 44px -22px rgba(70,50,20,.42);
  --shadow-s:0 8px 22px -12px rgba(70,50,20,.32);
  --display:"Fredoka",system-ui,sans-serif;
  --body:"Hanken Grotesk",system-ui,sans-serif;
  --mono:"Space Mono",ui-monospace,monospace;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth;overflow-x:hidden;max-width:100%}
body{
  margin:0;background:var(--cream);color:var(--ink);
  font-family:var(--body);font-size:17px;line-height:1.62;-webkit-font-smoothing:antialiased;
  overflow-x:clip;
}
.wrap{width:min(1140px,92vw);margin-inline:auto}
a{color:inherit;text-decoration:none}
h1,h2,h3,h4,h5{font-family:var(--display);font-weight:700;line-height:1.04;letter-spacing:-.015em;margin:0}

/* atmosphere */
.atmos{position:fixed;inset:0;z-index:-2;overflow:hidden;pointer-events:none}
.atmos::after{content:"";position:absolute;inset:0;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.32'/%3E%3C/svg%3E");mix-blend-mode:multiply;opacity:.05}
.blob{position:absolute;border-radius:50%;filter:blur(60px);opacity:.5}
.b1{width:520px;height:520px;background:#FFD9CF;top:-160px;right:-120px}
.b2{width:460px;height:460px;background:#CFEFE3;top:760px;left:-180px}
.b3{width:520px;height:520px;background:#DCE9FB;top:2100px;right:-200px}

/* nav */
.nav{position:sticky;top:0;z-index:50;backdrop-filter:saturate(1.2) blur(10px);
  background:color-mix(in srgb,var(--cream) 78%,transparent);border-bottom:1px solid transparent;transition:.3s}
.nav.scrolled{border-color:var(--line);background:color-mix(in srgb,var(--cream) 92%,transparent)}
.nav-in{display:flex;align-items:center;gap:18px;height:68px}
.brand{font-family:var(--display);font-weight:700;font-size:21px;display:inline-flex;align-items:center;gap:8px;letter-spacing:-.02em}
.brand-mark{color:var(--coral);font-size:18px;transform:translateY(1px)}
.brand-icon{width:30px;height:30px;border-radius:9px;box-shadow:0 3px 8px -3px rgba(70,50,20,.5);vertical-align:middle}

/* real app screens inside phone frame */
.screen-real{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;border-radius:36px;background:#cfe0ef}

/* evolution real-screen moment */
.evo-hero{position:relative;display:grid;place-items:center;margin:46px 0 6px}
.evo-hero .phone{width:262px;height:534px}
.evo-burst{position:absolute;inset:0;pointer-events:none}
.evo-burst .spark{font-size:26px}
.evo-burst .s1{top:8%;left:32%;color:var(--butter)}
.evo-burst .s2{top:24%;right:30%;color:var(--coral);animation-delay:.5s}
.evo-burst .s3{bottom:16%;left:34%;color:var(--grape);animation-delay:1s}
.nav-links{display:flex;gap:26px;margin-left:auto;font-weight:600;font-size:15px;color:var(--ink-2)}
.nav-links a:hover{color:var(--ink)}

/* buttons */
.btn{display:inline-flex;align-items:center;gap:9px;font-family:var(--display);font-weight:600;
  background:var(--ink);color:var(--cream);padding:12px 20px;border-radius:999px;font-size:15px;
  border:none;cursor:pointer;transition:transform .18s cubic-bezier(.34,1.56,.64,1),box-shadow .2s;box-shadow:var(--shadow-s)}
.btn:hover{transform:translateY(-2px) scale(1.02)}
.btn svg{transform:translateY(-1px)}
.btn-sm{margin-left:8px;padding:9px 16px;font-size:14px}
.btn-lg{padding:15px 26px;font-size:16.5px}
.btn-ghost{background:var(--paper);color:var(--ink);border:1.5px solid var(--line);box-shadow:none}
.btn-ghost:hover{border-color:var(--ink)}
.btn-dark{background:var(--ink);color:var(--butter)}

/* shared section bits */
.eyebrow{display:inline-block;font-family:var(--mono);font-size:12.5px;letter-spacing:.16em;text-transform:uppercase;
  color:var(--coral);font-weight:700;margin-bottom:14px}
.sec-head{max-width:720px;margin:0 auto;text-align:center}
.sec-head h2{font-size:clamp(30px,4.6vw,46px)}
.sec-sub{color:var(--ink-2);margin-top:14px;font-size:17.5px}
.pill{display:inline-flex;align-items:center;font-family:var(--mono);font-size:12.5px;letter-spacing:.04em;
  background:var(--paper);border:1.5px solid var(--line);color:var(--ink-2);padding:7px 14px;border-radius:999px;font-weight:700}

/* ===== HERO ===== */
.hero{position:relative;padding-top:34px}
.hero-in{display:grid;grid-template-columns:1.05fr .95fr;gap:30px;align-items:center;min-height:74vh}
.hero-copy h1{font-size:clamp(44px,7vw,80px);margin:20px 0 8px}
.hl{position:relative;white-space:nowrap}
.hl::after{content:"";position:absolute;left:-2%;right:-2%;bottom:.1em;height:.34em;border-radius:8px;z-index:-1;opacity:.55}
.hl-coral::after{background:var(--coral)}
.hl-sky::after{background:var(--sky)}
.lede{font-size:19.5px;color:var(--ink-2);max-width:30em;margin:14px 0 0}
.lede-m{display:none}
.tagline{font-family:var(--display);font-weight:600;font-size:clamp(18px,2.4vw,22px);color:var(--ink);margin:6px 0 0}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap;align-items:center;margin-top:26px}
.badges{display:flex;gap:11px;flex-wrap:wrap}
.badge{display:inline-block;transition:transform .18s cubic-bezier(.34,1.56,.64,1)}
.badge img{height:52px;width:auto;display:block}
.badge:hover{transform:translateY(-2px) scale(1.03)}
.hero-proof{display:flex;align-items:center;gap:11px;margin-top:24px;font-size:14.5px;color:var(--ink-2)}
.stars{color:var(--butter);letter-spacing:1px;font-size:15px}

.hero-stage{position:relative;display:flex;justify-content:center;align-items:center}
.orbit{position:relative}
.hero-phone{position:relative;width:252px;height:512px;z-index:2}
.hpet{position:absolute;z-index:3;filter:drop-shadow(0 12px 16px rgba(80,50,20,.18))}
.hp-a{width:142px;top:-20px;right:-42px}
.hp-b{width:104px;left:-46px;top:30%}
.hp-c{width:116px;bottom:-10px;left:-34px}
.pet{position:absolute;filter:drop-shadow(0 16px 20px rgba(80,50,20,.18))}
.p-main{width:60%;left:18%;top:18%;z-index:3}
.p-a{width:30%;left:-4%;top:6%;z-index:2}
.p-b{width:27%;right:2%;top:0;z-index:2}
.p-c{width:31%;left:2%;bottom:2%;z-index:2}
.p-d{width:33%;right:-2%;bottom:6%;z-index:4}
.spark{position:absolute;color:var(--butter);font-size:22px;animation:tw 2.4s ease-in-out infinite}
.s1{top:14%;left:8%;color:var(--coral)}.s2{top:62%;right:6%;color:var(--sky);animation-delay:.7s}.s3{top:30%;right:24%;animation-delay:1.3s}
@keyframes tw{0%,100%{opacity:.25;transform:scale(.8)}50%{opacity:1;transform:scale(1.15)}}
.confetti{position:absolute;width:9px;height:9px;border-radius:2px;opacity:.85}
.c1{background:var(--coral);top:22%;left:30%;transform:rotate(20deg)}
.c2{background:var(--mint);top:70%;left:20%;transform:rotate(-15deg)}
.c3{background:var(--grape);top:12%;right:18%;border-radius:50%}
.c4{background:var(--sky);bottom:18%;right:30%;transform:rotate(40deg)}

/* float keyframes */
.float-a{animation:fl 4.4s ease-in-out infinite}
.float-b{animation:fl 5.2s ease-in-out infinite;animation-delay:-1.1s}
.float-c{animation:fl 4.8s ease-in-out infinite;animation-delay:-2.2s}
@keyframes fl{0%,100%{transform:translateY(0) rotate(-1deg)}50%{transform:translateY(-13px) rotate(1.5deg)}}

/* marquee strip */
.marq-strip{margin-top:26px;border-top:2px solid var(--ink);border-bottom:2px solid var(--ink);
  background:var(--butter);overflow:hidden;transform:rotate(-1.2deg) scale(1.04)}
.marq{display:flex;width:max-content;animation:slide 26s linear infinite}
.marq span{font-family:var(--display);font-weight:700;font-size:16px;letter-spacing:.04em;padding:11px 0;color:var(--ink);white-space:nowrap}
@keyframes slide{to{transform:translateX(-50%)}}

/* ===== HOW ===== */
.how{padding:88px 0 64px}
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:46px}
.step{background:var(--paper);border:1.5px solid var(--line);border-radius:var(--rl);padding:30px 26px 28px;position:relative;box-shadow:var(--shadow-s)}
.step-n{font-family:var(--mono);font-size:13px;color:var(--ink-2);position:absolute;top:22px;right:24px}
.step-emoji{width:62px;height:62px;display:grid;place-items:center;font-size:30px;border-radius:18px;
  background:color-mix(in srgb,var(--a) 18%,var(--paper));border:1.5px solid color-mix(in srgb,var(--a) 40%,var(--line));margin-bottom:18px}
.step h3{font-size:21px;margin-bottom:8px}
.step p{color:var(--ink-2);font-size:15.5px;margin:0}

/* ===== EXPLORE GRID ===== */
.explore{padding:60px 0}
.grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:46px}
.card{grid-column:span 1;background:var(--paper);border:1.5px solid var(--line);border-radius:var(--rl);
  padding:28px;display:flex;flex-direction:column;justify-content:space-between;gap:18px;min-height:250px;
  position:relative;overflow:hidden;box-shadow:var(--shadow-s);transition:transform .25s,box-shadow .25s}
.card:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.card::before{content:"";position:absolute;inset:0;background:radial-gradient(120% 90% at 100% 0,color-mix(in srgb,var(--a) 20%,transparent),transparent 60%);pointer-events:none}
.span-2{grid-column:span 2;flex-direction:row;align-items:center}
.span-2 .card-body{flex:1}
.card-body h3{font-size:23px;margin-bottom:9px}
.card-body p{color:var(--ink-2);font-size:15.5px;margin:0}
.card-art{position:relative;display:grid;place-items:center;min-height:120px}
.art-grow{flex:1.05;display:flex;align-items:center;justify-content:center;gap:8px}
.art-grow img:first-child{width:96px}.art-grow img:last-child{width:148px}
.art-grow .arrow{position:absolute;font-family:var(--display);font-size:26px;color:var(--a);font-weight:700}
.art-streak{font-family:var(--display);font-size:46px;font-weight:700;display:flex;align-items:center;gap:8px}
.art-streak .flame{font-size:38px}
.art-coop{display:flex;gap:6px}.art-coop img{width:96px}
.art-cute img{width:130px}
.art-free{flex:.9}.art-free img{width:120px}
.art-free .spark{position:absolute}.art-free .s1{top:10%;left:14%}.art-free .s2{bottom:14%;right:18%;color:var(--coral)}

/* ===== FEATURES ===== */
.features{padding:70px 0}
.feat{display:grid;grid-template-columns:1fr 1fr;gap:54px;align-items:center;padding:46px 0}
.feat-rev .feat-copy{order:2}.feat-rev .feat-art{order:1}
.feat-copy h2{font-size:clamp(26px,3.6vw,38px);margin:6px 0 14px}
.feat-copy>p{color:var(--ink-2);font-size:17px;margin:0 0 18px}
.ticks{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:10px}
.ticks li{position:relative;padding-left:30px;font-weight:600;font-size:15.5px}
.ticks li::before{content:"✓";position:absolute;left:0;top:-1px;width:21px;height:21px;border-radius:50%;
  display:grid;place-items:center;font-size:12px;color:#fff;background:var(--coral);font-family:var(--display)}
.tk-mint li::before{background:var(--mint)}.tk-sky li::before{background:var(--sky)}

/* phone mockups */
.feat-art{display:grid;place-items:center}
.phone{width:280px;height:570px;background:var(--ink);border-radius:46px;padding:11px;box-shadow:var(--shadow);position:relative}
.phone::before{content:"";position:absolute;top:18px;left:50%;transform:translateX(-50%);width:84px;height:7px;background:#000;border-radius:99px;z-index:5}
.phone-tilt{transform:rotate(-4deg)}.phone-tilt-r{transform:rotate(4deg)}
.feat-art:hover .phone{transform:rotate(0) translateY(-6px);transition:transform .4s cubic-bezier(.34,1.4,.64,1)}
.screen{width:100%;height:100%;border-radius:36px;overflow:hidden;position:relative;padding:46px 18px 20px;display:flex;flex-direction:column}

.scr-home{background:linear-gradient(170deg,#FFE7D6,#FFF6EC 60%,#E9F6F0)}
.scr-top{display:flex;justify-content:space-between;font-family:var(--mono);font-size:13px;font-weight:700}
.streak-chip{background:#fff;border:1.5px solid var(--line);padding:4px 11px;border-radius:99px}
.coins{background:#fff;border:1.5px solid var(--line);padding:4px 11px;border-radius:99px;color:var(--butter-i)}
.scr-pet{flex:1;display:grid;place-items:center;position:relative}
.scr-pet img{width:74%;z-index:2;filter:drop-shadow(0 12px 14px rgba(80,50,20,.2))}
.scr-pet .ring{position:absolute;width:150px;height:150px;border-radius:50%;
  background:radial-gradient(circle,color-mix(in srgb,var(--coral) 22%,transparent),transparent 68%);animation:pulse 3s ease-in-out infinite}
@keyframes pulse{0%,100%{transform:scale(.92);opacity:.7}50%{transform:scale(1.08);opacity:1}}
.scr-name{font-family:var(--display);font-weight:700;text-align:center;font-size:18px;margin-bottom:8px}
.xpbar{height:13px;background:#fff;border:1.5px solid var(--line);border-radius:99px;overflow:hidden}
.xpbar span{display:block;height:100%;background:linear-gradient(90deg,var(--coral),var(--butter));border-radius:99px;animation:fill 2.6s cubic-bezier(.5,0,.2,1) both;animation-delay:.4s}
@keyframes fill{from{width:0 !important}}
.xp-label{font-family:var(--mono);font-size:10.5px;color:var(--ink-2);text-align:center;margin:7px 0 12px}
.scr-card{background:#fff;border:1.5px solid var(--line);border-radius:16px;padding:12px 14px;display:flex;align-items:center;gap:9px;font-size:13.5px;font-weight:600}
.scr-card b{margin-left:auto;font-family:var(--display);color:var(--coral)}
.scr-card .dot{width:9px;height:9px;border-radius:50%}

.scr-cam{background:#1c1916;padding:40px 14px 14px}
.cam-frame{flex:1;border-radius:24px;background:linear-gradient(160deg,#2a2622,#3a332c);position:relative;display:grid;place-items:center;overflow:hidden}
.cam-frame img{width:62%;filter:drop-shadow(0 8px 12px rgba(0,0,0,.4))}
.cam-corner{position:absolute;width:26px;height:26px;border:3px solid var(--mint)}
.cam-corner.tl{top:14px;left:14px;border-right:0;border-bottom:0;border-radius:8px 0 0 0}
.cam-corner.tr{top:14px;right:14px;border-left:0;border-bottom:0;border-radius:0 8px 0 0}
.cam-corner.bl{bottom:14px;left:14px;border-right:0;border-top:0;border-radius:0 0 0 8px}
.cam-corner.br{bottom:14px;right:14px;border-left:0;border-top:0;border-radius:0 0 8px 0}
.rep-count{position:absolute;bottom:16px;left:16px;color:#fff;font-family:var(--display);line-height:.9}
.rep-count b{font-size:38px}.rep-count small{display:block;font-size:11px;color:var(--mint)}
.cam-bar{margin-top:12px;background:#fff;border-radius:14px;padding:11px 14px;display:flex;align-items:center;gap:8px;font-size:13.5px;font-weight:600}
.cam-bar .rec{width:10px;height:10px;border-radius:50%;background:var(--coral);animation:blink 1s steps(2) infinite}
@keyframes blink{50%{opacity:.25}}
.cam-bar b{margin-left:auto;font-family:var(--display);color:var(--mint)}

.scr-coop{background:linear-gradient(170deg,#E7F1FE,#FFF6EC)}
.coop-head{font-family:var(--mono);font-size:12px;font-weight:700;color:var(--sky-i);text-align:center;margin-bottom:6px}
.coop-pets{flex:1;display:flex;align-items:center;justify-content:center;gap:6px}
.coop-slot{display:grid;place-items:center}
.coop-slot img{width:118px;filter:drop-shadow(0 10px 12px rgba(80,50,20,.2))}
.coop-slot span{font-family:var(--mono);font-size:11px;font-weight:700;color:var(--ink-2)}
.vs{font-family:var(--display);font-size:24px;color:var(--sky)}
.coop-bars{display:flex;flex-direction:column;gap:7px;margin:6px 0 12px}
.coop-bars span{height:11px;background:#fff;border:1.5px solid var(--line);border-radius:99px;position:relative;overflow:hidden}
.coop-bars span::after{content:"";position:absolute;inset:0;width:var(--w,70%);background:linear-gradient(90deg,var(--sky),var(--mint));border-radius:99px}
.coop-bars span:nth-child(1)::after{width:74%}.coop-bars span:nth-child(2)::after{width:61%}
.coop-btn{font-family:var(--display);font-weight:600;background:var(--sky);color:#fff;border:none;border-radius:14px;padding:12px;font-size:15px}

/* ===== EVOLVE ===== */
.evolve{padding:78px 0}
.evo-rows{display:flex;flex-direction:column;gap:16px;margin:46px 0 0}
.evo-line{display:flex;align-items:stretch;justify-content:center;gap:12px}
.evo{background:var(--paper);border:1.5px solid var(--line);border-radius:var(--rl);padding:18px 14px 14px;text-align:center;box-shadow:var(--shadow-s);flex:1 1 0;max-width:230px;min-width:0}
.evo-stage{height:120px;display:grid;place-items:center;position:relative;overflow:hidden;margin-bottom:10px}
.evo-stage img{animation:none;max-height:78%;max-width:80%}
.evo:nth-child(1) .evo-stage img{max-height:64%;max-width:58%}
.evo:nth-child(3) .evo-stage img{max-height:70%;max-width:80%}
.evo:nth-child(5) .evo-stage img{max-height:84%;max-width:90%}
.evo-final{border-color:color-mix(in srgb,var(--coral) 45%,var(--line));background:linear-gradient(180deg,#FFF1E9,var(--paper))}
.evo .glow{position:absolute;width:120px;height:120px;border-radius:50%;background:radial-gradient(circle,color-mix(in srgb,var(--butter) 38%,transparent),transparent 66%);z-index:0;animation:pulse 3s ease-in-out infinite}
.evo-tag{font-family:var(--display);font-weight:700;font-size:16px;margin-top:4px}
.evo-lv{font-family:var(--mono);font-size:11px;color:var(--ink-2)}
.evo-arrow{align-self:center;font-family:var(--display);font-size:24px;color:var(--coral);font-weight:700;flex:0 0 auto}
.starter{margin-top:40px;text-align:center}
.starter-h{font-family:var(--display);font-weight:600;font-size:18px;color:var(--ink);margin:0 0 18px}
.starter-row{display:flex;justify-content:center;gap:16px;flex-wrap:wrap}
.starter-opt{background:var(--paper);border:1.5px solid var(--line);border-radius:var(--rl);padding:18px 22px 14px;width:148px;
  box-shadow:var(--shadow-s);cursor:pointer;transition:transform .2s cubic-bezier(.34,1.5,.64,1),border-color .2s,box-shadow .2s}
.starter-opt:hover{transform:translateY(-4px);border-color:color-mix(in srgb,var(--a) 55%,var(--line));box-shadow:var(--shadow)}
.starter-pic{width:96px;height:96px;margin:0 auto 10px;border-radius:50%;display:grid;place-items:center;
  background:radial-gradient(circle,color-mix(in srgb,var(--a) 20%,var(--paper)),color-mix(in srgb,var(--a) 8%,var(--paper)));
  border:1.5px solid color-mix(in srgb,var(--a) 30%,var(--line))}
.starter-pic img{width:78%;filter:drop-shadow(0 6px 8px rgba(80,50,20,.18))}
.starter-opt b{display:block;font-family:var(--display);font-weight:700;font-size:17px;color:var(--ink)}
.starter-opt small{font-family:var(--mono);font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--a);font-weight:700}
.starter-note{font-family:var(--mono);font-size:11.5px;color:var(--ink-2);margin:18px 0 0}

/* ===== TESTIMONIALS ===== */
.loved{padding:64px 0 70px;overflow:hidden}
.tmarq{margin-top:42px;display:flex;flex-direction:column;gap:18px}
.trow{display:flex;gap:18px;width:max-content}
.trow-a{animation:slidet 52s linear infinite}
.trow-b{animation:slidet 60s linear infinite reverse}
@keyframes slidet{to{transform:translateX(calc(-50% - 9px))}}
.tcard{margin:0;background:var(--paper);border:1.5px solid var(--line);border-radius:var(--r);padding:22px 24px;width:330px;flex:0 0 auto;box-shadow:var(--shadow-s)}
.tcard p{margin:0 0 12px;font-size:16px;font-weight:500}
.tcard figcaption{font-family:var(--mono);font-size:12px;color:var(--ink-2)}
.tcard figcaption b{color:var(--coral)}
.tmarq:hover .trow{animation-play-state:paused}

/* ===== FAQ ===== */
.faq{padding:30px 0 80px}
.faq-list{max-width:780px;margin:40px auto 0}
.faq details{background:var(--paper);border:1.5px solid var(--line);border-radius:var(--r);margin-bottom:12px;overflow:hidden}
.faq summary{list-style:none;cursor:pointer;padding:20px 22px;font-family:var(--display);font-weight:600;font-size:18px;
  display:flex;align-items:center;justify-content:space-between;gap:12px}
.faq summary::-webkit-details-marker{display:none}
.plus{position:relative;width:16px;height:16px;flex:0 0 auto}
.plus::before,.plus::after{content:"";position:absolute;background:var(--coral);border-radius:2px;inset:0;margin:auto}
.plus::before{width:16px;height:2.4px}.plus::after{width:2.4px;height:16px;transition:transform .25s}
.faq details[open] .plus::after{transform:rotate(90deg);opacity:0}
.faq details p{margin:0;padding:0 22px 22px;color:var(--ink-2);font-size:15.5px}

/* ===== CTA ===== */
.cta{padding:30px 0 90px}
.cta-in{position:relative;background:linear-gradient(160deg,#FFE2D4,#FFF4E6 55%,#E6F5EE);
  border:2px solid var(--ink);border-radius:40px;padding:64px 30px 56px;text-align:center;box-shadow:var(--shadow);overflow:hidden}
.cta-trio{display:block;width:148px;height:auto;margin:0 auto 18px;filter:drop-shadow(0 10px 16px rgba(80,50,20,.2))}
.cta-in h2{font-size:clamp(30px,4.6vw,48px);position:relative}
.cta-in>p{color:var(--ink-2);max-width:32em;margin:14px auto 26px;font-size:18px;position:relative}
.cta-pets{position:absolute;inset:0}
.cta-pets img{position:absolute;filter:drop-shadow(0 12px 14px rgba(80,50,20,.16))}
.cta-badges{justify-content:center}
.cta-pets img:nth-child(1){width:118px;left:-14px;bottom:-12px}
.cta-pets img:nth-child(2){width:150px;right:-10px;top:-14px}
.cta-pets img:nth-child(3){width:118px;right:-12px;bottom:-12px}

/* ===== FOOTER ===== */
.foot{background:var(--ink);color:var(--cream);padding:56px 0 26px}
.foot-in{display:grid;grid-template-columns:1.4fr 2fr;gap:40px}
.foot-brand .brand{color:var(--cream)}
.foot-brand p{color:#b8ad9c;max-width:24em;font-size:15px;margin-top:12px}
.foot-cols{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.foot-cols h5{font-family:var(--display);font-size:14px;margin-bottom:12px;color:var(--butter)}
.foot-cols a{display:block;color:#cfc6b7;font-size:14.5px;margin-bottom:9px}
.foot-cols a:hover{color:#fff}
.foot-base{display:flex;justify-content:space-between;border-top:1px solid #443c33;margin-top:40px;padding-top:20px;
  font-family:var(--mono);font-size:12px;color:#9b9182}

/* ===== LEGAL PAGES ===== */
.legal-wrap{max-width:760px;margin:0 auto;padding:36px 0 80px}
.legal-back{display:inline-flex;align-items:center;gap:6px;font-family:var(--display);font-weight:600;font-size:14px;color:var(--ink-2);margin-bottom:18px}
.legal-back:hover{color:var(--ink)}
.legal-card{background:var(--paper);border:1.5px solid var(--line);border-radius:var(--rl);padding:38px 42px;box-shadow:var(--shadow-s)}
.legal-prose h1{font-family:var(--display);font-weight:700;font-size:clamp(28px,4vw,38px);letter-spacing:-.015em;margin:0 0 10px}
.legal-prose h2{font-family:var(--display);font-weight:700;font-size:21px;margin:34px 0 10px}
.legal-prose h3{font-family:var(--display);font-weight:600;font-size:16.5px;margin:22px 0 6px}
.legal-prose p{color:var(--ink-2);font-size:15.5px;line-height:1.7;margin:0 0 12px}
.legal-prose ul{margin:0 0 14px;padding-left:22px;display:flex;flex-direction:column;gap:6px}
.legal-prose li{color:var(--ink-2);font-size:15.5px;line-height:1.65}
.legal-prose a{color:var(--coral);font-weight:600;text-decoration:underline;text-underline-offset:2px}
.legal-prose strong{color:var(--ink);font-weight:700}
.legal-prose hr{border:none;border-top:1px solid var(--line);margin:26px 0}
@media(max-width:560px){.legal-card{padding:26px 22px}}

/* ===== reveal ===== */
.js .reveal{opacity:0;transform:translateY(24px);transition:opacity .7s ease,transform .7s cubic-bezier(.2,.7,.3,1)}
.js .reveal.in{opacity:1;transform:none}
.d1{transition-delay:.08s}.d2{transition-delay:.16s}.d3{transition-delay:.24s}.d4{transition-delay:.32s}

/* ===== responsive ===== */
@media(max-width:900px){
  .hero-in{grid-template-columns:1fr;min-height:auto;text-align:center;padding-bottom:8px}
  .hero-copy{order:2}
  .hero{padding-top:8px}
  .lede-full{display:none}
  .lede-m{display:block;margin-inline:auto;margin-top:8px;font-size:17px}
  .hero-stage{order:1;margin:8px 0 8px}
  .hero-phone{width:210px;height:427px}
  .hp-a{width:102px;top:11%;right:-74px}
  .hp-b{width:90px;left:-64px;top:30%}
  .hp-c{width:100px;bottom:-6px;left:-60px}
  .hero-copy h1{margin:0;font-size:34px}
  .hero-cta{margin-top:12px}
  .badges{flex-wrap:nowrap}
  .badge img{height:46px}
  .lede{margin-inline:auto}.hero-cta,.badges,.hero-proof{justify-content:center}
  .feat,.feat-rev{grid-template-columns:1fr;gap:30px}
  .feat-rev .feat-copy{order:1}.feat-rev .feat-art{order:2}
  .nav-links{display:none}
  .foot-in{grid-template-columns:1fr;gap:28px}
  .tgrid{grid-template-columns:1fr 1fr}
  .evo-line{gap:7px}
  .evo{padding:12px 6px 10px}
  .evo-stage{height:88px}
  .evo-tag{font-size:12.5px}.evo-lv{font-size:10px}.evo-arrow{font-size:17px}
}
@media(max-width:560px){
  .tgrid{grid-template-columns:1fr}
  .hero-phone{width:196px;height:399px}
  .hp-a{width:92px;top:11%;right:-66px}
  .hp-b{width:82px;left:-58px;top:30%}
  .hp-c{width:92px;bottom:-4px;left:-54px}
  .evo-stage{height:74px}.evo-tag{font-size:11px}.evo-lv{font-size:9px}
  .evo{padding:10px 4px 9px}.evo-line{gap:5px}.evo-arrow{font-size:14px}
  .cta-in{padding:48px 20px 44px}
}
@media(prefers-reduced-motion:reduce){
  *{animation:none !important}
  .reveal{opacity:1;transform:none;transition:none}
}
