:root{
  --cream:#FBF5E9; --paper:#FFFFFF; --ink:#231A11; --espresso:#171009; --muted:#6B5D4C; --faint:#9A8B76;
  --orange:#E8631A; --cta:#F97B2C; --green:#5C8245; --rule:rgba(35,26,17,.13); --border:#E7DCC9;
}
*{box-sizing:border-box;margin:0;padding:0}
html{-webkit-text-size-adjust:100%;overflow-x:hidden}
html.lenis,html.lenis body{height:auto}.lenis.lenis-smooth{scroll-behavior:auto!important}
body{background:var(--cream);color:var(--ink);font-family:'Instrument Sans',system-ui,sans-serif;line-height:1.55;-webkit-font-smoothing:antialiased;font-size:17px;overflow-x:hidden}
.serif{font-family:'Fraunces',Georgia,serif}
a{color:inherit;text-decoration:none}
.wrap{max-width:1240px;margin:0 auto;padding:0 clamp(20px,5vw,56px)}
em{font-style:normal;color:var(--orange)}
/* custom cursor */
.cursor,.cursor-d{position:fixed;top:0;left:0;border-radius:50%;pointer-events:none;z-index:120;mix-blend-mode:normal;transform:translate(-50%,-50%);will-change:transform}
.cursor{width:7px;height:7px;background:var(--orange)}
.cursor-d{width:38px;height:38px;border:1px solid rgba(232,99,26,.55);transition:width .25s,height .25s,background .25s,border-color .25s}
.cursor-d.hot{width:64px;height:64px;background:rgba(232,99,26,.10);border-color:transparent}
@media(hover:none){.cursor,.cursor-d{display:none}}
/* nav */
.nav{position:fixed;top:0;left:0;right:0;z-index:60;transition:background .3s,border-color .3s}
.nav.scrolled{background:rgba(251,245,233,.86);backdrop-filter:blur(12px) saturate(1.4);border-bottom:1px solid var(--rule)}
.nav .wrap{display:flex;justify-content:space-between;align-items:center;height:70px}
.logo{font-family:'Fraunces',serif;font-weight:600;font-size:24px;letter-spacing:-.01em}
.pill{display:inline-flex;align-items:center;background:var(--cta);color:#fff;font-family:'Fraunces',serif;font-weight:600;font-size:14.5px;padding:14px 22px;border-radius:999px;box-shadow:0 8px 20px -8px rgba(249,123,44,.7);will-change:transform}
/* HERO */
.hero{position:relative;min-height:100svh;display:flex;align-items:center;padding:108px 0 40px;overflow:visible}
.aurora{position:absolute;inset:0;z-index:0;pointer-events:none;filter:blur(70px);opacity:.55;overflow:hidden}
.aurora i{position:absolute;border-radius:50%;display:block}
.aurora .a1{width:560px;height:560px;background:radial-gradient(circle,rgba(232,99,26,.55),transparent 70%);top:-160px;right:-60px}
.aurora .a2{width:520px;height:520px;background:radial-gradient(circle,rgba(92,130,69,.42),transparent 70%);bottom:-180px;left:-120px}
.hero .wrap{position:relative;z-index:2;display:grid;grid-template-columns:1.12fr .88fr;gap:clamp(20px,4vw,56px);align-items:center;width:100%}
.eyebrow-h{font-size:12px;font-weight:600;letter-spacing:.2em;text-transform:uppercase;color:var(--muted);margin-bottom:24px}
h1.cover{font-family:'Fraunces',serif;font-weight:500;font-variation-settings:'opsz' 144;font-size:clamp(46px,8.2vw,118px);line-height:.92;letter-spacing:-.035em;margin-bottom:26px}
h1.cover .ln{display:block;overflow:hidden}.h1.cover .ln>span{display:block}
.sub{font-size:clamp(17px,1.5vw,21px);line-height:1.5;color:var(--muted);max-width:42ch;margin-bottom:30px}
.signup{display:flex;gap:9px;max-width:460px;flex-wrap:wrap}
.signup input{flex:1 1 230px;min-width:0;padding:16px 18px;border:1px solid var(--border);border-radius:999px;font-size:16px;font-family:inherit;background:var(--paper);color:var(--ink)}
.signup input:focus{outline:none;border-color:var(--orange);box-shadow:0 0 0 3px rgba(232,99,26,.16)}
.signup input::placeholder{color:var(--faint)}
.signup button{flex:0 0 auto;padding:16px 27px;border:0;border-radius:999px;background:var(--cta);color:#fff;font-family:'Fraunces',serif;font-weight:600;font-size:16px;cursor:pointer;box-shadow:0 10px 24px -10px rgba(249,123,44,.7);will-change:transform}
.micro{font-size:13.5px;color:var(--muted);margin-top:14px}.micro b{color:var(--ink)}
.err{color:#b4431a;font-size:13.5px;margin-top:8px;display:none}.err.show{display:block}
.thanks{display:none;font-size:16px;color:var(--muted);margin-top:6px;max-width:460px}.thanks.show{display:block}
.thanks b{font-family:'Fraunces',serif;color:var(--ink);font-size:19px;display:block;margin-bottom:3px;font-weight:600}
.hero-visual{display:flex;justify-content:center;align-items:center;perspective:1200px}
/* cap to viewport minus nav+padding so the FULL phone frame always fits (never clipped by .hero overflow) */
.hero-visual img{width:auto;height:min(calc(100svh - 250px),clamp(440px,48vw,700px));will-change:transform}
.scrollcue{position:absolute;left:0;right:0;bottom:20px;text-align:center;z-index:2;font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--faint)}
/* STORY (sticky phone + scrolling steps) */
.story{padding:clamp(40px,7vh,90px) 0}
.story .wrap{display:grid;grid-template-columns:1fr 1fr;gap:clamp(30px,6vw,90px);align-items:start}
.story-stage{position:sticky;top:0;height:100svh;display:flex;align-items:center;justify-content:center}
.story-stage img{height:clamp(420px,60vh,640px);width:auto}
.story-steps{padding:8vh 0}
.story-step{min-height:78vh;display:flex;flex-direction:column;justify-content:center}
.story-step .idx{font-family:'Fraunces',serif;font-variation-settings:'opsz' 144;font-size:clamp(54px,7vw,104px);line-height:1;color:var(--orange);letter-spacing:-.04em}
.story-step h3{font-family:'Fraunces',serif;font-weight:500;font-size:clamp(28px,3.6vw,46px);line-height:1.04;letter-spacing:-.02em;margin:10px 0 12px}
.story-step p{font-size:clamp(17px,1.5vw,20px);color:var(--muted);max-width:34ch}
/* INTERSTITIAL (dark full-bleed) */
.inter{position:relative;min-height:92svh;display:flex;align-items:center;color:var(--cream);overflow:hidden}
.inter .bg{position:absolute;inset:-12%;z-index:0}.inter .bg img{width:100%;height:100%;object-fit:cover;will-change:transform}
.inter::after{content:"";position:absolute;inset:0;z-index:1;background:linear-gradient(180deg,rgba(15,10,5,.55),rgba(15,10,5,.72))}
.inter .wrap{position:relative;z-index:2}
.inter blockquote{font-family:'Fraunces',serif;font-weight:500;font-style:italic;font-size:clamp(30px,5.6vw,76px);line-height:1.06;letter-spacing:-.025em;max-width:18ch}
.qln{display:block;overflow:hidden}.qln>span{display:block}
/* FEATURES (editorial) */
.features{padding:clamp(50px,8vh,110px) 0}
.feat{display:grid;grid-template-columns:1fr 1fr;gap:clamp(28px,6vw,80px);align-items:center;padding:clamp(28px,5vh,60px) 0}
.feat:nth-of-type(even) .feat-img{order:2}
.feat-img{overflow:hidden;border-radius:22px;box-shadow:0 30px 56px -26px rgba(35,26,17,.42)}
.feat-img img{width:100%;aspect-ratio:5/4;object-fit:cover;display:block;will-change:transform;transform:scale(1.14)}
.feat-text .fi{font-size:12px;font-weight:600;letter-spacing:.16em;text-transform:uppercase;color:var(--orange);margin-bottom:14px}
.feat-text h3{font-family:'Fraunces',serif;font-weight:500;font-size:clamp(28px,3.6vw,46px);line-height:1.04;letter-spacing:-.02em;margin-bottom:12px}
.feat-text p{font-size:clamp(16px,1.4vw,19px);color:var(--muted);max-width:42ch}
/* RATE (how the score works) */
.rate{padding:clamp(50px,8vh,100px) 0}
.rate .wrap{display:grid;grid-template-columns:.92fr 1.08fr;gap:clamp(30px,6vw,80px);align-items:center}
.scorecard{background:var(--paper);border:1px solid var(--border);border-radius:22px;padding:26px;box-shadow:0 30px 56px -26px rgba(35,26,17,.32)}
.sc-top{display:flex;align-items:center;gap:16px;margin-bottom:14px}
.sc-ring{width:74px;height:74px;border-radius:50%;flex:0 0 auto;display:grid;place-items:center;background:conic-gradient(var(--orange) 0 82%,rgba(35,26,17,.1) 82% 100%)}
.sc-ring span{width:56px;height:56px;border-radius:50%;background:var(--paper);display:grid;place-items:center;font-size:24px;color:var(--orange);font-weight:600}
.sc-t{font-size:17px;font-weight:600}.sc-s{font-size:13.5px;color:var(--muted)}
.sc-name{font-family:'Fraunces',serif;font-size:23px;font-weight:600;margin-bottom:10px}
.sc-badge{display:inline-block;border-radius:999px;padding:8px 17px;font-weight:700;font-size:15px;color:#fff}
.sc-rows{margin-top:14px;border-top:1px solid var(--rule)}
.sc-row{display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid var(--rule);padding:11px 0;font-size:14.5px}
.sc-row b{color:var(--green)}
.rate-eyebrow{font-size:12px;font-weight:600;letter-spacing:.16em;text-transform:uppercase;color:var(--orange);margin-bottom:12px}
.rate h2{font-family:'Fraunces',serif;font-weight:500;font-size:clamp(28px,4vw,48px);line-height:1.02;letter-spacing:-.02em}
.rate p{color:var(--muted);font-size:clamp(16px,1.4vw,18px);max-width:46ch;margin:18px 0 26px}
.scale-seg{display:flex;border-radius:12px;overflow:hidden;margin-top:8px}
.scale-seg div{flex:1;padding:12px 6px;text-align:center;color:#fff;font-weight:700;font-size:13px;letter-spacing:.02em}
.scale-grad{position:relative;height:14px;border-radius:999px;background:linear-gradient(90deg,#C2452F,#D9922A,#5C8245);margin-top:8px}
.scale-grad i{position:absolute;top:50%;width:18px;height:18px;border-radius:50%;background:#fff;border:3px solid var(--ink);transform:translate(-50%,-50%)}
.scale-lab{display:flex;justify-content:space-between;font-size:12px;color:var(--faint);margin-top:9px;font-weight:600;letter-spacing:.04em;text-transform:uppercase}
.ratebtn{display:inline-block;background:var(--cta);color:#fff;font-family:'Fraunces',serif;font-weight:600;font-size:16px;padding:15px 27px;border-radius:999px;box-shadow:0 10px 24px -10px rgba(249,123,44,.7);will-change:transform}
/* BROWSE */
.browse{padding:clamp(50px,8vh,100px) 0;text-align:center}
.browse .eyebrow{font-size:12px;font-weight:600;letter-spacing:.16em;text-transform:uppercase;color:var(--orange);margin-bottom:14px}
.browse h2{font-family:'Fraunces',serif;font-weight:500;font-size:clamp(30px,5vw,60px);line-height:1.0;letter-spacing:-.025em;margin-bottom:14px}
.browse>.wrap>p{color:var(--muted);font-size:clamp(16px,1.5vw,19px);max-width:48ch;margin:0 auto 24px}
.chips{display:flex;flex-wrap:wrap;justify-content:center;gap:10px;margin-top:30px;max-width:940px;margin-left:auto;margin-right:auto}
.chip{border:1px solid var(--border);background:var(--paper);border-radius:999px;padding:11px 18px;font-size:15px;color:var(--ink);font-weight:500}
/* CLAIM */
.claim{padding:clamp(60px,12vh,150px) 0;text-align:center}
.claim p{font-family:'Fraunces',serif;font-weight:500;font-size:clamp(30px,6vw,84px);line-height:1.0;letter-spacing:-.03em;max-width:16ch;margin:0 auto}
.claim .cw{display:inline-block;overflow:hidden}.claim .cw>span{display:inline-block}
/* FAQ */
.faqsec{padding:clamp(30px,5vh,60px) 0 clamp(50px,8vh,90px)}
.faq-h{font-family:'Fraunces',serif;font-weight:500;font-size:clamp(28px,4vw,44px);letter-spacing:-.02em;margin-bottom:18px}
details.faq{border-top:1px solid var(--rule);padding:4px 0}details.faq:last-of-type{border-bottom:1px solid var(--rule)}
details.faq summary{list-style:none;cursor:pointer;padding:22px 0;font-family:'Fraunces',serif;font-weight:500;font-size:clamp(20px,2.6vw,26px);display:flex;justify-content:space-between;gap:16px;align-items:center}
details.faq summary::-webkit-details-marker{display:none}
details.faq summary::after{content:"+";font-size:26px;color:var(--orange);transition:transform .2s}
details.faq[open] summary::after{transform:rotate(45deg)}
details.faq p{padding:0 0 24px;color:var(--muted);font-size:17px;max-width:64ch}
/* CLOSE (dark full viewport) */
.close{position:relative;min-height:100svh;display:flex;align-items:center;text-align:center;color:var(--cream);overflow:hidden}
.close .bg{position:absolute;inset:-12%;z-index:0}.close .bg img{width:100%;height:100%;object-fit:cover;will-change:transform}
.close::after{content:"";position:absolute;inset:0;z-index:1;background:linear-gradient(180deg,rgba(15,10,5,.62),rgba(15,10,5,.80))}
.close .wrap{position:relative;z-index:2;width:100%}
.close h2{font-family:'Fraunces',serif;font-weight:500;font-size:clamp(44px,9vw,120px);line-height:.94;letter-spacing:-.035em;margin-bottom:16px}
.close .cs{color:rgba(251,245,233,.82);font-size:clamp(16px,1.6vw,19px);margin-bottom:30px}
.close .signup{margin:0 auto;justify-content:center}.close .signup input{background:rgba(255,255,255,.96);border-color:transparent}
.close .micro{color:rgba(251,245,233,.78)}.close .micro b{color:#fff}
.close .thanks{margin:0 auto;color:rgba(251,245,233,.9)}.close .thanks b{color:#fff}
/* footer */
.footer{padding:38px 0 110px;text-align:center;border-top:1px solid var(--rule)}
.footer .logo{font-size:21px}.footer .by{font-size:13px;color:var(--muted);margin:4px 0 12px}
.footer nav{display:flex;justify-content:center;gap:10px;font-size:13.5px;margin-bottom:8px}
.footer nav a{color:var(--muted);display:inline-block;padding:12px 8px}
.footer .legal{font-size:12.5px;color:var(--faint)}
.sticky{position:fixed;left:0;right:0;bottom:0;z-index:55;padding:10px 16px calc(10px + env(safe-area-inset-bottom));background:rgba(251,245,233,.94);backdrop-filter:blur(10px);border-top:1px solid var(--rule);display:none;transform:translateY(120%);transition:transform .35s cubic-bezier(.22,1,.36,1)}
.sticky.show{transform:translateY(0)}
.sticky a{display:block;text-align:center;background:var(--cta);color:#fff;font-family:'Fraunces',serif;font-weight:600;font-size:16px;border-radius:999px;padding:14px}
/* anim base (JS-gated) */
html.js .anim{opacity:0;transform:translateY(28px)}
@media(prefers-reduced-motion:reduce){html.js .anim,html.js .ln>span,html.js .qln>span,html.js .cw>span{opacity:1!important;transform:none!important}}
@media(max-width:820px){
  .hero{min-height:auto;padding-top:96px}
  .hero .wrap{grid-template-columns:1fr;text-align:center;gap:30px}
  .eyebrow-h,.sub,.signup{margin-left:auto;margin-right:auto}
  .hero-visual{order:2}.hero-visual img{height:min(56vh,clamp(380px,84vw,470px))}
  .scrollcue{display:none}
  .story{padding:18px 0 8px}
  .story .wrap{grid-template-columns:1fr;gap:0}
  .story-stage{display:none}
  .story-steps{padding:0}
  .story-step{min-height:auto;padding:22px 0;text-align:center;border-top:1px solid var(--rule)}
  .story-step:first-child{border-top:0}.story-step .idx{font-size:46px}.story-step p{margin:0 auto}
  .feat{grid-template-columns:1fr;gap:18px;text-align:center}.feat:nth-of-type(even) .feat-img{order:0}.feat-text{order:-1}.feat-text p{margin:0 auto}
  .rate .wrap{grid-template-columns:1fr;gap:26px}.scorecard{max-width:420px;margin:0 auto}.rate-text{text-align:center}.rate p{margin-left:auto;margin-right:auto}
  .sticky{display:block}
  .survey-card{padding:28px 20px 24px}
}
/* SURVEY (post-signup) */
.survey[hidden]{display:none}
.survey{position:fixed;inset:0;z-index:200;display:flex;align-items:center;justify-content:center;padding:20px;background:rgba(23,16,9,.55);backdrop-filter:blur(7px);overflow-y:auto}
.survey-card{position:relative;background:var(--paper);border:1px solid var(--border);border-radius:24px;max-width:470px;width:100%;padding:34px clamp(24px,5vw,40px);box-shadow:0 44px 90px -30px rgba(23,16,9,.62);max-height:calc(100svh - 40px);overflow-y:auto}
.survey-x{position:absolute;top:12px;right:14px;border:0;background:transparent;font-size:24px;line-height:1;color:var(--faint);cursor:pointer;padding:11px 13px;border-radius:50%}
.survey-x:hover{color:var(--ink)}
.survey-intro{font-size:14px;color:var(--muted);margin:2px 30px 16px 0}.survey-intro span{color:var(--orange);font-weight:600}
.survey-prog{height:5px;background:var(--border);border-radius:999px;overflow:hidden;margin-bottom:24px}
.survey-prog i{display:block;height:100%;width:25%;background:var(--cta);border-radius:999px;transition:width .35s cubic-bezier(.22,1,.36,1)}
.survey .q h3{font-family:'Fraunces',serif;font-weight:500;font-size:clamp(21px,3.4vw,27px);line-height:1.14;letter-spacing:-.01em;margin-bottom:18px}
.survey .opts{display:flex;flex-direction:column;gap:9px}
.survey .opt{text-align:left;border:1px solid var(--border);background:var(--cream);border-radius:14px;padding:15px 16px;font-family:inherit;font-size:15.5px;color:var(--ink);cursor:pointer;transition:border-color .15s,background .15s}
.survey .opt:hover{border-color:var(--orange)}
.survey .opt.sel{border-color:var(--orange);background:rgba(232,99,26,.09)}
.survey-text{width:100%;border:1px solid var(--border);border-radius:14px;padding:14px 16px;font-family:inherit;font-size:16px;color:var(--ink);background:var(--cream);resize:vertical;margin-bottom:14px;display:block}
.survey-text:focus{outline:none;border-color:var(--orange);box-shadow:0 0 0 3px rgba(232,99,26,.14)}
.opt-done{width:100%;text-align:center;background:var(--cta);color:#fff;border:0;border-radius:999px;padding:16px;font-family:'Fraunces',serif;font-weight:600;font-size:16px;cursor:pointer}
.survey-skip{display:block;margin:18px auto 0;background:transparent;border:0;color:var(--faint);font-size:13.5px;cursor:pointer;text-decoration:underline;font-family:inherit;padding:8px}
.survey-thanks{display:none;text-align:center;padding:24px 6px}.survey-thanks.show{display:block}
.survey-thanks b{font-family:'Fraunces',serif;font-size:25px;display:block;margin-bottom:8px;color:var(--ink);font-weight:600}
