/* ==========================================================================
   Spent — marketing site design system
   Light only · mobile-first · SF Pro (native) + JetBrains Mono
   ========================================================================== */

:root{
  --bg:        #F6F1E8;
  --bg-2:      #EFE9DC;
  --card:      #FFFFFF;
  --ink:       #191917;
  --ink-soft:  #4b4a42;
  --muted:     #807b6e;
  --line:      #e4ddcd;
  --accent:    #AFCF0D;
  --accent-br: #BEE018;
  --accent-dk: #8fa90a;
  --coral:     #F0584F;
  --shadow-sm: 0 2px 10px rgba(25,25,23,.06);
  --shadow-md: 0 14px 34px rgba(25,25,23,.10);
  --shadow-lg: 0 30px 70px rgba(25,25,23,.16);
  --glow:      0 14px 40px rgba(175,207,13,.45);

  --sans: -apple-system, BlinkMacSystemFont, "SF Pro Display", "SF Pro Text", system-ui, "Segoe UI", Roboto, sans-serif;
  --mono: "JetBrains Mono", ui-monospace, SFMono-Regular, Menlo, monospace;

  --maxw: 1120px;
  --pad: 22px;
  --radius: 22px;
}

*{box-sizing:border-box;}
html{scroll-behavior:smooth;scroll-padding-top:80px;-webkit-text-size-adjust:100%;overflow-x:hidden;}
body{
  margin:0;padding-top:64px;background:var(--bg);color:var(--ink);
  font-family:var(--sans);line-height:1.5;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
  overflow-x:hidden;width:100%;
}
img{max-width:100%;display:block;}
a{color:inherit;text-decoration:none;}
button{font-family:inherit;}

.container{width:100%;max-width:var(--maxw);margin:0 auto;padding:0 var(--pad);}
.section{padding:72px 0;}
.section.tight{padding:48px 0;}
.center{text-align:center;}

/* ---------- type ---------- */
h1,h2,h3{margin:0;letter-spacing:-.03em;font-weight:800;line-height:1.02;}
h1{line-height:1.18;}
h2{line-height:1.18;}
h1{font-size:clamp(40px,11vw,76px);}
h2{font-size:clamp(30px,7vw,52px);}
h3{font-size:clamp(22px,5vw,30px);letter-spacing:-.02em;}
p{margin:0;}
.lead{font-size:clamp(17px,4.4vw,21px);color:var(--ink-soft);line-height:1.5;}
.kicker{
  font-family:var(--mono);font-size:12.5px;letter-spacing:.18em;text-transform:uppercase;
  color:var(--accent-dk);font-weight:700;display:inline-flex;gap:10px;align-items:center;
}
.kicker .num{color:var(--ink);}
.eyebrow{
  font-family:var(--mono);font-size:11.5px;letter-spacing:.2em;text-transform:uppercase;
  color:var(--muted);font-weight:600;
}
.hl{
  background:var(--accent);color:var(--ink);
  padding:0 .28em;border-radius:8px;box-decoration-break:clone;-webkit-box-decoration-break:clone;
}
.text-mute{color:var(--muted);}

/* ---------- buttons ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:9px;
  font-weight:700;font-size:16px;border-radius:999px;padding:15px 26px;cursor:pointer;
  border:1.5px solid transparent;transition:transform .14s ease, box-shadow .14s ease, background .14s ease;
  white-space:nowrap;
}
.btn:active{transform:translateY(1px);}
.btn-primary{background:var(--accent);color:var(--ink);box-shadow:var(--glow);}
.btn-primary:hover{filter:brightness(1.04);transform:translateY(-2px);}
.btn-ghost{background:transparent;color:var(--ink);border-color:var(--ink);}
.btn-ghost:hover{background:var(--ink);color:var(--bg);}
.btn-light{background:#fff;color:var(--ink);box-shadow:var(--shadow-sm);}
.btn-block{width:100%;}

/* App Store badge */
.appstore{
  display:inline-flex;align-items:center;gap:11px;background:var(--ink);color:#fff;
  border-radius:14px;padding:9px 18px 9px 16px;line-height:1;transition:transform .14s ease, box-shadow .14s ease;
}
.appstore:hover{transform:translateY(-2px);box-shadow:var(--shadow-md);}
.appstore svg{width:24px;height:24px;flex:none;fill:#fff;}
.appstore .as-txt{display:flex;flex-direction:column;gap:2px;text-align:left;}
.appstore .as-txt small{font-size:10px;letter-spacing:.02em;opacity:.85;font-weight:500;}
.appstore .as-txt b{font-size:18px;font-weight:700;letter-spacing:-.01em;}
.appstore.lg{padding:13px 24px 13px 20px;border-radius:16px;}
.appstore.lg svg{width:30px;height:30px;}
.appstore.lg .as-txt b{font-size:21px;}

/* ---------- header ---------- */
.site{
  position:fixed;top:0;left:0;right:0;z-index:60;
  background:color-mix(in srgb, var(--bg) 82%, transparent);
  backdrop-filter:saturate(140%) blur(14px);-webkit-backdrop-filter:saturate(140%) blur(14px);
  border-bottom:1px solid transparent;transition:border-color .2s ease, box-shadow .2s ease;
}
.site.scrolled{border-color:var(--line);box-shadow:0 6px 24px rgba(25,25,23,.05);}
.site .bar{display:flex;align-items:center;justify-content:space-between;height:64px;gap:14px;}
.logo{display:inline-flex;align-items:center;gap:10px;font-weight:800;font-size:21px;letter-spacing:-.02em;}
.logo-mark{
  width:32px;height:32px;border-radius:9px;background:var(--accent);color:var(--ink);
  display:grid;place-items:center;font-weight:900;font-size:21px;
  box-shadow:0 3px 8px rgba(175,207,13,.4);
  /* squircle-ish */
  -webkit-mask:radial-gradient(closest-side,#000 99%,transparent) ; mask:none;
  clip-path: path("M32 16 C32 4.5 27.5 0 16 0 C4.5 0 0 4.5 0 16 C0 27.5 4.5 32 16 32 C27.5 32 32 27.5 32 16 Z");
}
.nav-desktop{display:none;gap:26px;align-items:center;margin-left:auto;}
.nav-desktop a{font-size:15px;font-weight:600;color:var(--ink-soft);transition:color .15s;}
.nav-desktop a:hover{color:var(--ink);}
.bar-right{display:flex;align-items:center;gap:12px;}
.menu-btn{
  width:42px;height:42px;border-radius:12px;border:1.5px solid var(--line);background:#fff;
  display:grid;place-items:center;cursor:pointer;
}
.menu-btn span{display:block;width:18px;height:2px;background:var(--ink);position:relative;}
.menu-btn span::before,.menu-btn span::after{content:"";position:absolute;left:0;width:18px;height:2px;background:var(--ink);transition:.2s;}
.menu-btn span::before{top:-6px;}.menu-btn span::after{top:6px;}
.site.menu-open .menu-btn span{background:transparent;}
.site.menu-open .menu-btn span::before{top:0;transform:rotate(45deg);}
.site.menu-open .menu-btn span::after{top:0;transform:rotate(-45deg);}

.mobile-menu{
  overflow:hidden;max-height:0;transition:max-height .28s ease;
  background:var(--bg);border-bottom:1px solid var(--line);width:100%;
}
.site.menu-open .mobile-menu{max-height:340px;}
.mobile-menu .inner{padding:8px var(--pad) 20px;display:flex;flex-direction:column;}
.mobile-menu a{padding:14px 4px;font-size:18px;font-weight:600;border-bottom:1px solid var(--line);}
.mobile-menu a:last-child{border-bottom:none;}

/* compact appstore in header on tiny screens */
@media (max-width:380px){
  .appstore .as-txt small{display:none;}
  .appstore{padding:10px 14px;}
}

/* ---------- hero ---------- */
.hero{padding:48px 0 24px;position:relative;overflow:hidden;}
.hero .grid{display:grid;gap:34px;align-items:center;}
.hero h1{margin:14px 0 0;}
.hero .lead{margin-top:20px;max-width:30ch;}
.hero-cta{display:flex;flex-wrap:wrap;gap:12px;margin-top:28px;}
.trust{display:flex;flex-wrap:wrap;gap:8px 18px;margin-top:24px;}
.trust span{font-family:var(--mono);font-size:11.5px;letter-spacing:.04em;color:var(--muted);display:inline-flex;align-items:center;gap:7px;}
.trust span::before{content:"";width:7px;height:7px;border-radius:50%;background:var(--accent);}

/* phone image */
.phone{
  position:relative;max-width:300px;margin:0 auto;
}
.phone img{display:block;width:100%;}
@media (max-width:759px){
  #tap .phone{max-width:none;margin-left:calc(-1 * var(--pad));margin-right:calc(-1 * var(--pad));}
  #smart .phone, #budgets .phone{max-width:100%;}
}
.phone.float{animation:floaty 6s ease-in-out infinite;}

/* image slide-in when feature section reveals */
.feature .phone{
  transform:translateY(20px) scale(0.97);
  transition:transform .7s cubic-bezier(.22,.61,.36,1) .18s;
}
.feature.in .phone{transform:none;}
@keyframes floaty{0%,100%{transform:translateY(0);}50%{transform:translateY(-12px);}}
.hero-phones{position:relative;display:flex;justify-content:center;}

/* decorative blobs */
.blob{position:absolute;border-radius:50%;filter:blur(60px);opacity:.5;z-index:-1;}
.blob.lime{background:var(--accent);width:280px;height:280px;}
.blob.coral{background:var(--coral);width:200px;height:200px;opacity:.25;}

/* ---------- stat strip ---------- */
.stats{display:grid;grid-template-columns:repeat(2,1fr);gap:14px;}
.stat{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:22px;box-shadow:var(--shadow-sm);}
.stat .big{font-size:clamp(30px,8vw,42px);font-weight:800;letter-spacing:-.03em;}
.stat .lbl{font-family:var(--mono);font-size:11.5px;letter-spacing:.06em;color:var(--muted);text-transform:uppercase;margin-top:4px;}

/* ---------- feature rows ---------- */
.feature{padding:46px 0;border-top:1px solid var(--line);}
.feature .grid{display:grid;gap:28px;align-items:center;}
.feature h2{margin:14px 0 0;}
.feature .lead{margin-top:16px;}
.feature .mini-list{margin-top:20px;display:flex;flex-direction:column;gap:12px;}
.feature .mini-list li{display:flex;gap:11px;align-items:flex-start;font-size:15.5px;color:var(--ink-soft);list-style:none;}
.feature .mini-list li::before{content:"";flex:none;width:20px;height:20px;border-radius:7px;background:var(--accent);margin-top:1px;
  -webkit-mask:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><path fill='black' d='M9 16.2 4.8 12l-1.4 1.4L9 19 21 7l-1.4-1.4z'/></svg>") center/14px no-repeat;
        mask:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><path fill='black' d='M9 16.2 4.8 12l-1.4 1.4L9 19 21 7l-1.4-1.4z'/></svg>") center/14px no-repeat;}
.feature ul{padding:0;margin:0;}

/* ---------- more features grid ---------- */
.more-grid{display:grid;gap:2px;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;}
.mf-item{display:flex;align-items:flex-start;gap:16px;padding:20px 22px;background:var(--card);transition:background .15s;}
.mf-item:hover{background:var(--bg-2);}
.mf-ic{font-size:22px;color:var(--accent);flex:none;margin-top:1px;font-variation-settings:'FILL' 0,'wght' 300,'GRAD' 0,'opsz' 24;}
.mf-item strong{display:block;font-size:15.5px;font-weight:700;color:var(--ink);}
.mf-item p{margin:3px 0 0;font-size:14.5px;color:var(--ink-soft);line-height:1.5;}

/* ---------- cards / grid ---------- */
.cards{display:grid;gap:18px;}
.fcard{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:26px;box-shadow:var(--shadow-sm);transition:transform .16s, box-shadow .16s;}
.fcard:hover{transform:translateY(-3px);box-shadow:var(--shadow-md);}
.fcard .ic{width:46px;height:46px;border-radius:13px;background:var(--bg-2);display:grid;place-items:center;font-size:22px;margin-bottom:16px;border:1px solid var(--line);}
.fcard h3{font-size:21px;}
.fcard p{margin-top:9px;color:var(--ink-soft);font-size:15.5px;}

/* expandable learn-more (native details) */
.learn{margin-top:16px;border-top:1px dashed var(--line);padding-top:14px;}
details.learn{}
details.learn summary{
  list-style:none;cursor:pointer;display:inline-flex;align-items:center;gap:8px;
  font-weight:700;font-size:14.5px;color:var(--ink);font-family:var(--sans);
}
details.learn summary::-webkit-details-marker{display:none;}
details.learn summary .chev{width:16px;height:16px;transition:transform .2s;display:inline-block;}
details.learn[open] summary .chev{transform:rotate(180deg);}
details.learn .more{margin-top:14px;color:var(--ink-soft);font-size:15px;line-height:1.6;
  animation:expand .26s ease;}
details.learn .more p+p{margin-top:10px;}
@keyframes expand{from{opacity:0;transform:translateY(-6px);}to{opacity:1;transform:none;}}

/* ---------- band / CTA ---------- */
.band{background:var(--ink);color:#fff;border-radius:30px;padding:52px 30px;text-align:center;position:relative;overflow:hidden;}
.band h2{color:#fff;}
.band p{color:rgba(255,255,255,.72);margin-top:14px;}
.band .cta{margin-top:26px;display:flex;justify-content:center;flex-wrap:wrap;gap:12px;}
.band .glowdot{position:absolute;width:240px;height:240px;border-radius:50%;background:var(--accent);filter:blur(70px);opacity:.35;top:-60px;right:-40px;}

/* ---------- accordion / faq + legal ---------- */
.acc{background:var(--card);border:1px solid var(--line);border-radius:16px;margin-bottom:12px;overflow:hidden;box-shadow:var(--shadow-sm);}
.acc summary{list-style:none;cursor:pointer;padding:20px 22px;display:flex;justify-content:space-between;align-items:center;gap:16px;font-weight:700;font-size:17px;}
.acc summary::-webkit-details-marker{display:none;}
.acc summary .plus{flex:none;width:24px;height:24px;position:relative;}
.acc summary .plus::before,.acc summary .plus::after{content:"";position:absolute;background:var(--ink);border-radius:2px;transition:.22s;}
.acc summary .plus::before{top:11px;left:3px;width:18px;height:2px;}
.acc summary .plus::after{left:11px;top:3px;width:2px;height:18px;}
.acc[open] summary .plus::after{transform:rotate(90deg);opacity:0;}
.acc .body{padding:0 22px 22px;color:var(--ink-soft);font-size:15.5px;line-height:1.65;}
.acc .body p+p{margin-top:12px;}

/* ---------- legal / prose ---------- */
.prose{max-width:760px;margin:0 auto;}
.prose h2{font-size:clamp(24px,5vw,32px);margin:38px 0 14px;}
.prose h3{font-size:20px;margin:26px 0 10px;}
.prose p,.prose li{color:var(--ink-soft);font-size:16px;line-height:1.7;}
.prose p{margin:0 0 14px;}
.prose ul{padding-left:20px;margin:0 0 16px;}
.prose li{margin-bottom:8px;}
.prose .updated{font-family:var(--mono);font-size:12.5px;color:var(--muted);letter-spacing:.04em;}
.page-head{padding:48px 0 8px;}
.page-head h1{font-size:clamp(34px,9vw,60px);}
.page-head .lead{margin-top:16px;}

/* ---------- contact ---------- */
.contact-grid{display:grid;gap:18px;}
.field label{display:block;font-weight:600;font-size:14px;margin-bottom:7px;}
.field input,.field textarea{
  width:100%;border:1.5px solid var(--line);background:#fff;border-radius:14px;padding:14px 16px;
  font-family:var(--sans);font-size:16px;color:var(--ink);transition:border-color .15s, box-shadow .15s;
}
.field input:focus,.field textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 4px rgba(175,207,13,.2);}
.field textarea{min-height:140px;resize:vertical;}
.contact-card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:24px;box-shadow:var(--shadow-sm);}
.contact-card a{font-weight:700;color:var(--accent-dk);}

/* ---------- footer ---------- */
.site-footer{background:var(--ink);color:#cdc9bf;margin-top:40px;}
.site-footer .container{padding-top:54px;padding-bottom:30px;}
.foot-top{display:grid;gap:34px;}
.foot-brand .logo{color:#fff;}
.foot-brand p{color:rgba(255,255,255,.6);margin-top:14px;max-width:30ch;font-size:15px;}
.foot-brand .appstore{margin-top:20px;background:#fff;color:var(--ink);}
.foot-brand .appstore svg{fill:var(--ink);}
.foot-cols{display:grid;grid-template-columns:repeat(2,1fr);gap:26px;}
.foot-cols h4{font-family:var(--mono);font-size:11.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--accent);margin:0 0 14px;font-weight:700;}
.foot-cols a{display:block;color:rgba(255,255,255,.72);font-size:15px;padding:6px 0;}
.foot-cols a:hover{color:#fff;}
.foot-bottom{border-top:1px solid rgba(255,255,255,.12);margin-top:38px;padding-top:22px;display:flex;flex-wrap:wrap;gap:10px 20px;justify-content:space-between;align-items:center;}
.foot-bottom small{color:rgba(255,255,255,.5);font-size:13px;}
.foot-bottom .made{font-family:var(--mono);font-size:11.5px;letter-spacing:.04em;color:rgba(255,255,255,.45);}

/* ---------- reveal anim ---------- */
.reveal{opacity:0;transform:translateY(22px);transition:opacity .6s ease, transform .6s ease;}
.reveal.in{opacity:1;transform:none;}
@media (prefers-reduced-motion:reduce){
  .reveal{opacity:1;transform:none;transition:none;}
  .phone.float{animation:none;}
  html{scroll-behavior:auto;}
}

/* ==========================================================================
   Desktop / tablet
   ========================================================================== */
@media (min-width:760px){
  .section{padding:96px 0;}
  .nav-desktop{display:flex;}
  .menu-btn{display:none;}
  .hero{padding:64px 0 40px;}
  .hero .grid{grid-template-columns:1.05fr .95fr;gap:40px;}
  .hero .lead{font-size:21px;}
  .phone{max-width:330px;}
  .hero-cta{margin-top:32px;}
  .stats{grid-template-columns:repeat(4,1fr);}
  .feature .grid{grid-template-columns:1fr 1fr;gap:54px;}
  .more-grid{grid-template-columns:1fr 1fr;}
  .feature.flip .media{order:2;}
  .feature.flip .copy{order:1;}
  .cards.c3{grid-template-columns:repeat(3,1fr);}
  .cards.c2{grid-template-columns:repeat(2,1fr);}
  .foot-top{grid-template-columns:1.3fr 1fr;}
  .foot-cols{grid-template-columns:repeat(3,1fr);}
  .band{padding:72px 50px;}
  .contact-grid{grid-template-columns:1.4fr 1fr;align-items:start;}
}
@media (min-width:1000px){
  .hero h1{font-size:72px;}
}
