:root{--paper: #ffffff;--ink: #1f1f1f;--pencil: #5c5c5c;--muted: #8a8a8a;--marker: #1f1f1f;--marker-text: #ffffff;--hairline: rgba(31, 31, 31, .14);--card: #ffffff;--grain-opacity: .035;--grain-blend: multiply;--shadow: 0 18px 40px -24px rgba(31, 31, 31, .45);--shadow-soft: 0 8px 24px -18px rgba(31, 31, 31, .5);--font-display: "Caveat", "Bradley Hand", cursive;--font-hand: "Patrick Hand", "Comic Sans MS", system-ui, sans-serif;--maxw: 1120px;--gutter: clamp(1.15rem, 4vw, 3rem);--header-h: 72px}html[data-theme=dark]{--paper: #0e0e0f;--ink: #f5f5f4;--pencil: #b5b5b3;--muted: #7a7a78;--marker: #f5f5f4;--marker-text: #0e0e0f;--hairline: rgba(245, 245, 244, .18);--card: #161617;--grain-opacity: .05;--grain-blend: screen;--shadow: 0 22px 48px -26px rgba(0, 0, 0, .85);--shadow-soft: 0 10px 28px -20px rgba(0, 0, 0, .8)}*,*:before,*:after{box-sizing:border-box}*{margin:0}html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}body{min-height:100dvh;background-color:var(--paper);color:var(--ink);font-family:var(--font-hand);font-size:1.18rem;line-height:1.7;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;overflow-x:hidden;-webkit-tap-highlight-color:transparent;transition:background-color .45s ease,color .45s ease}body:before{content:"";position:fixed;top:0;right:0;bottom:0;left:0;z-index:0;pointer-events:none;opacity:var(--grain-opacity);mix-blend-mode:var(--grain-blend);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' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}img{max-width:100%;display:block}a{color:inherit;text-decoration:none}button{font:inherit;color:inherit;cursor:pointer;background:none;border:none}:focus-visible{outline:2.5px dashed var(--ink);outline-offset:4px;border-radius:3px}.sketchbox{position:relative;isolation:isolate}.sketchbox>.sketch-svg{position:absolute;top:0;right:0;bottom:0;left:0;z-index:-1;overflow:visible;width:100%;height:100%}.wordmark,h1,h2,h3{font-family:var(--font-display);font-weight:700;line-height:1.05;letter-spacing:.4px;padding-inline:.06em}h1{font-size:clamp(3.1rem,9vw,6.5rem)}h2{font-size:clamp(2.3rem,5vw,3.6rem)}h3{font-size:clamp(1.6rem,3vw,2.1rem)}.eyebrow{font-family:var(--font-hand);text-transform:lowercase;letter-spacing:2px;font-size:.92rem;color:var(--muted);display:inline-flex;align-items:center;gap:.6ch}.eyebrow:before{content:"";width:26px;height:2px;background:currentColor;border-radius:2px;transform:rotate(-1.5deg)}.lead{font-size:clamp(1.2rem,2.4vw,1.55rem);color:var(--pencil);line-height:1.55}.muted{color:var(--muted)}.container{width:100%;max-width:var(--maxw);margin-inline:auto;padding-inline:max(var(--gutter),env(safe-area-inset-left));position:relative;z-index:1}section{padding-block:clamp(3.25rem,9vw,7.5rem);position:relative;z-index:1}.section-head{max-width:46ch;margin-bottom:clamp(1.75rem,5vw,3.25rem)}.section-head .lead{margin-top:.6rem}.center{text-align:center}.rule{display:block;width:100%;height:22px}.rule svg{width:100%;height:100%;overflow:visible}.rule path{stroke:var(--ink);stroke-width:2;fill:none;stroke-linecap:round;opacity:.45}.underline{display:block;height:20px;color:var(--ink);overflow:visible}.underline path{fill:none;stroke:var(--ink);stroke-width:3;stroke-linecap:round}.hero-underline{width:min(360px,80%);margin-top:-.1rem}.closer-underline{width:min(280px,62%);height:18px;margin:.2rem auto 0}.legal-underline{width:min(220px,60%);height:16px;margin-bottom:2rem}.legal-underline path{stroke-width:2.5}.site-header{position:sticky;top:0;z-index:60;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:color-mix(in srgb,var(--paper) 82%,transparent);border-bottom:1.5px solid var(--hairline);padding-top:env(safe-area-inset-top)}.site-header .container{display:flex;align-items:center;gap:1.25rem;height:var(--header-h)}.brand{display:inline-flex;align-items:center;gap:.55rem;flex:none}.brand .lock-mark{width:32px;height:32px;color:var(--ink);flex:none}.brand-name{font-family:var(--font-display);font-weight:700;font-size:1.8rem;line-height:1;padding-top:4px}.nav{margin-left:auto;display:flex;align-items:center;gap:clamp(.4rem,1.6vw,1.5rem)}.nav-links{display:flex;align-items:center;gap:clamp(.6rem,1.8vw,1.75rem)}.navlink{font-size:1.05rem;color:var(--pencil);padding:.3rem .2rem;position:relative;transition:color .2s ease}.navlink:hover{color:var(--ink)}.navlink:after{content:"";position:absolute;left:0;right:0;bottom:-2px;height:2px;background:var(--ink);border-radius:2px;transform:scaleX(0);transform-origin:left;transition:transform .25s ease}.navlink:hover:after{transform:scaleX(1)}.theme-toggle{width:44px;height:44px;border-radius:50%;display:grid;place-items:center;color:var(--ink);flex:none;transition:transform .3s ease}.theme-toggle svg{width:22px;height:22px}.theme-toggle:hover{transform:rotate(-8deg)}.hamburger{display:none;width:44px;height:44px;border-radius:12px;flex-direction:column;align-items:center;justify-content:center;gap:5px;flex:none}.hamburger span{display:block;width:22px;height:2.4px;background:var(--ink);border-radius:3px;transition:transform .25s ease,opacity .2s ease}.hamburger.is-open span:nth-child(1){transform:translateY(7.4px) rotate(45deg)}.hamburger.is-open span:nth-child(2){opacity:0}.hamburger.is-open span:nth-child(3){transform:translateY(-7.4px) rotate(-45deg)}.mobile-menu{position:fixed;left:0;right:0;top:calc(var(--header-h) + env(safe-area-inset-top));z-index:60;background:var(--paper);border-bottom:1.5px solid var(--hairline);padding:1rem var(--gutter) 1.5rem;transform:translateY(-12px);opacity:0;visibility:hidden;transition:opacity .22s ease,transform .22s ease,visibility .22s}.mobile-menu.open{transform:none;opacity:1;visibility:visible}.mobile-menu .container{display:flex;flex-direction:column;align-items:stretch;height:auto;gap:.2rem;padding:0}.mobile-link{font-family:var(--font-display);font-weight:700;font-size:1.9rem;color:var(--ink);padding:.55rem .2rem;border-bottom:1.5px solid var(--hairline)}.mobile-cta{margin-top:1.1rem}.menu-scrim{position:fixed;top:0;right:0;bottom:0;left:0;top:var(--header-h);z-index:55;border:0;background:color-mix(in srgb,var(--ink) 28%,transparent);opacity:0;visibility:hidden;transition:opacity .22s ease,visibility .22s}.menu-scrim.open{opacity:1;visibility:visible}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.6ch;font-family:var(--font-hand);font-size:1.18rem;line-height:1.1;padding:.8rem 1.5rem;color:var(--ink);min-height:48px;transition:transform .15s ease}.btn:active{transform:translateY(1px) scale(.99)}.btn--fill{color:var(--marker-text)}.btn--block{width:100%}.btn--lg{font-size:1.3rem;padding:1rem 1.9rem;min-height:56px}.btn-appstore{gap:.7ch}.btn-appstore .apple{width:22px;height:22px;flex:none}.btn-appstore .as-copy{display:flex;flex-direction:column;align-items:flex-start;line-height:1}.btn-appstore .as-copy small{font-size:.7rem;letter-spacing:.5px;opacity:.85;font-family:var(--font-hand)}.btn-appstore .as-copy span{font-family:var(--font-display);font-size:1.5rem}.hero{padding-top:clamp(2rem,6vw,5rem)}.hero .container{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(2rem,5vw,4.5rem);align-items:center}.hero-mark{display:flex;flex-direction:column;align-items:flex-start}.hero h1{margin-top:.4rem}.tagline{font-family:var(--font-display);font-size:clamp(1.9rem,3.6vw,2.7rem);line-height:1.1;margin-top:1.4rem;max-width:16ch}.subtagline{margin-top:1rem;color:var(--pencil);max-width:40ch;font-size:1.18rem}.hero-cta{margin-top:1.9rem;display:flex;flex-wrap:wrap;gap:1rem 1.25rem;align-items:center}.trial-note{color:var(--muted);font-size:1rem;display:inline-flex;align-items:center;gap:.5ch}.hero-art{position:relative;display:flex;justify-content:center}.habit-card{background:var(--card);border-radius:26px;padding:1.6rem 1.5rem 1.9rem;box-shadow:var(--shadow);transform:rotate(-2deg);width:min(360px,100%)}.habit-card .tape{position:absolute;top:-16px;left:50%;translate:-50% 0;width:120px;height:32px;z-index:2;background:color-mix(in srgb,var(--ink) 12%,transparent);border:1.5px dashed var(--hairline);transform:rotate(-3deg)}.hc-top{display:flex;align-items:baseline;justify-content:space-between;gap:1rem}.hc-title{font-family:var(--font-display);font-size:1.9rem;line-height:1}.hc-day{font-family:var(--font-hand);color:var(--muted);font-size:1rem;white-space:nowrap}.streak{display:flex;align-items:flex-end;gap:.6ch;margin:.6rem 0 1.1rem}.streak .num{font-family:var(--font-display);font-weight:700;font-size:4.2rem;line-height:.8}.streak .lbl{font-family:var(--font-hand);color:var(--pencil);font-size:1.05rem;padding-bottom:.5rem}.day-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:8px}.day-cell{aspect-ratio:1;color:var(--ink)}.day-cell svg{width:100%;height:100%;overflow:visible}.day-cell .ring{fill:none;stroke:var(--ink);stroke-width:1.6;opacity:.6}.day-cell.done .ring{opacity:1}.day-cell.future .ring{opacity:.22}.day-cell .tick{fill:none;stroke:var(--ink);stroke-width:2.2;stroke-linecap:round;stroke-linejoin:round}.shot{display:block;width:100%;height:auto;filter:drop-shadow(0 22px 38px rgba(31,31,31,.26))}html[data-theme=dark] .shot{filter:invert(1) hue-rotate(180deg) brightness(.92) drop-shadow(0 22px 40px rgba(0,0,0,.6))}.hero-shot{width:min(300px,82%)}.shots{display:grid;grid-template-columns:repeat(2,1fr);gap:clamp(2rem,6vw,5rem);max-width:760px;margin-inline:auto;align-items:start}.shot-card{text-align:center}.shot-card .shot{width:min(280px,78%);margin:0 auto 1.3rem}.shot-card h3{font-size:1.7rem}.shot-card p{color:var(--pencil);margin-top:.4rem;font-size:1.08rem}@media (prefers-reduced-motion: no-preference){.hero-shot{animation:floatPlain 7s ease-in-out infinite}@keyframes floatPlain{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}}.features-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(1.25rem,2.5vw,1.75rem)}.feature-wrap{display:flex}.feature{width:100%;background:var(--card);border-radius:22px;padding:1.8rem 1.6rem 1.9rem;box-shadow:var(--shadow-soft)}.feature-wrap:nth-child(2) .feature{transform:rotate(.7deg)}.feature-wrap:nth-child(3) .feature{transform:rotate(-.6deg)}.ficon{width:50px;height:50px;color:var(--ink);margin-bottom:.9rem}.feature h3{font-size:1.8rem}.feature p{margin-top:.5rem;color:var(--pencil);font-size:1.1rem}.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(1.5rem,4vw,3rem)}.step .step-num{font-family:var(--font-display);font-weight:700;font-size:3.2rem;line-height:1;display:inline-flex;align-items:center;gap:.4ch;color:var(--ink)}.step .circ{width:15px;height:15px;color:var(--muted)}.step h3{font-size:1.55rem;margin-top:.5rem}.step p{color:var(--pencil);margin-top:.35rem;font-size:1.08rem}.pricing .container{max-width:620px}.price-card{background:var(--card);border-radius:26px;padding:clamp(1.6rem,4vw,2.5rem);box-shadow:var(--shadow)}.pc-title{font-family:var(--font-display);font-size:2.2rem;text-align:center}.pc-sub{text-align:center;color:var(--pencil);margin-top:.2rem}.plan-row{display:flex;align-items:center;justify-content:space-between;gap:.75rem 1rem;flex-wrap:wrap;padding:1rem 1.2rem;border-radius:16px;margin-top:1.1rem}.pr-price{font-family:var(--font-display);font-weight:700;font-size:1.9rem}.pr-per{font-family:var(--font-hand);color:var(--muted);font-size:1rem;margin-left:.4ch}.pr-note{font-family:var(--font-hand);color:var(--pencil);font-size:.95rem;margin-top:.1rem}.badge{font-family:var(--font-display);font-size:1.05rem;line-height:1;padding:.4rem .8rem;border-radius:999px;background:var(--marker);color:var(--marker-text);white-space:nowrap}.pc-cta{margin-top:1.5rem;display:flex;justify-content:center}.fine{text-align:center;color:var(--muted);font-size:.92rem;margin-top:1.4rem;line-height:1.5}.closer{text-align:center}.closer .container{max-width:720px;display:flex;flex-direction:column;align-items:center}.closer h2{font-size:clamp(2.7rem,7vw,5rem)}.closer p{color:var(--pencil);margin-top:1.1rem;font-size:1.22rem}.closer .btn{margin-top:1.9rem}.site-footer{border-top:1.5px solid var(--hairline);padding-block:3rem;padding-bottom:calc(3rem + env(safe-area-inset-bottom))}.site-footer .container{display:flex;flex-wrap:wrap;gap:1.5rem 3rem;align-items:flex-start;justify-content:space-between}.footer-brand{max-width:30ch}.footer-brand .brand{margin-bottom:.5rem}.footer-brand .lock-mark{width:30px;height:30px}.footer-brand p{color:var(--muted);font-size:1rem}.footer-cols{display:flex;gap:clamp(1.75rem,6vw,4rem);flex-wrap:wrap}.footer-col h4{font-family:var(--font-display);font-weight:700;font-size:1.4rem;margin-bottom:.4rem}.footer-col a{display:block;color:var(--pencil);padding:.22rem 0;font-size:1.05rem;transition:color .2s ease}.footer-col a:hover{color:var(--ink)}.footer-bottom{margin-top:2.5rem;color:var(--muted);font-size:.92rem}.footer-bottom .container{display:flex;justify-content:space-between;gap:1rem;flex-wrap:wrap}.legal{padding-block:clamp(2rem,6vw,4rem) clamp(3.5rem,9vw,7rem)}.legal .container{max-width:760px}.legal-back{color:var(--pencil);display:inline-flex;align-items:center;gap:.5ch;margin-bottom:1.5rem}.legal-back:hover{color:var(--ink)}.legal h1{font-size:clamp(2.5rem,7vw,4rem)}.legal .effective{color:var(--muted);margin:-.8rem 0 .5rem}.legal h2{font-size:clamp(1.7rem,4vw,2.4rem);margin-top:2.4rem}.legal h3{font-size:1.45rem;margin-top:1.6rem}.legal p,.legal li{color:var(--pencil);font-size:1.12rem;line-height:1.75}.legal p{margin-top:.9rem}.legal ul{margin-top:.8rem;padding-left:0;list-style:none}.legal li{position:relative;padding-left:1.7rem;margin-top:.5rem}.legal li:before{content:"";position:absolute;left:0;top:.7em;width:9px;height:9px;border:2px solid var(--ink);border-radius:50%;transform:rotate(8deg)}.legal strong{color:var(--ink);font-weight:400;border-bottom:2px solid var(--hairline)}.legal a:not(.legal-back){color:var(--ink);border-bottom:2px solid var(--ink)}.legal .toc{margin:1.5rem 0 2.5rem;padding:1.25rem 1.5rem;border-radius:16px}.legal .toc h4{font-family:var(--font-display);font-size:1.4rem;margin-bottom:.4rem}.legal .toc ol{padding-left:1.3rem}.legal .toc li{padding-left:.3rem;margin-top:.3rem}.legal .toc li:before{display:none}.legal .toc a{color:var(--pencil);border:none}.legal .toc a:hover{color:var(--ink)}@media (prefers-reduced-motion: no-preference){.reveal{opacity:0;transform:translateY(18px)}.reveal.in{opacity:1;transform:none;transition:opacity .7s ease,transform .7s cubic-bezier(.16,1,.3,1)}.reveal.in[data-d="1"]{transition-delay:.08s}.reveal.in[data-d="2"]{transition-delay:.16s}.reveal.in[data-d="3"]{transition-delay:.24s}.reveal.in[data-d="4"]{transition-delay:.32s}.draw path{stroke-dasharray:var(--len, 420);stroke-dashoffset:var(--len, 420)}.draw.in path{animation:draw .9s ease .15s forwards}@keyframes draw{to{stroke-dashoffset:0}}.habit-card{animation:floaty 7s ease-in-out infinite}@keyframes floaty{0%,to{transform:rotate(-2deg) translateY(0)}50%{transform:rotate(-2deg) translateY(-10px)}}}.skip-link{position:absolute;left:.5rem;top:-3.5rem;z-index:100;background:var(--marker);color:var(--marker-text);padding:.6rem 1rem;border-radius:10px;transition:top .2s ease}.skip-link:focus{top:.5rem}@media (max-width: 900px){.hero .container{grid-template-columns:1fr;gap:2.75rem}.hero-copy{display:flex;flex-direction:column;align-items:center;text-align:center;width:100%}.hero-mark{align-items:center;text-align:center;width:100%}.hero .eyebrow,.tagline,.subtagline{text-align:center}.tagline,.subtagline{max-width:32ch}.hero-cta{justify-content:center}}@media (max-width: 880px){.features-grid{grid-template-columns:1fr;max-width:460px;margin-inline:auto}}@media (max-width: 820px){:root{--header-h: 60px}.nav-desktop{display:none!important}.hamburger{display:flex}.steps{grid-template-columns:1fr;max-width:460px;margin-inline:auto}.brand-name{font-size:1.65rem}}@media (max-width: 640px){body{font-size:1.08rem}.subtagline,.closer p{font-size:1.12rem}.streak .num{font-size:3.6rem}.footer-bottom .container{flex-direction:column;gap:.3rem}.btn--lg{width:100%;max-width:360px}.hero-cta{width:100%}.shots{grid-template-columns:1fr;max-width:320px}}@media (max-width: 380px){.habit-card{padding:1.3rem 1.2rem 1.6rem}.day-grid{gap:6px}}
