/* ===================================================================
   Snapceipt site — shared design system (Warm Editorial)
   Used by: index.html, pricing.html, privacy.html, support.html
   =================================================================== */

:root{
  --cream:#FBF6F0; --cream2:#F4EADD; --ink:#211C18; --ink2:#6B6258; --ink3:#A99F93;
  --terra:#E8602C; --terra2:#C2461A; --teal:#0E7C72; --teal2:#0a5f57; --line:#EADFCE;
  --card:#fff; --income:#1F9D6B;
}
*{box-sizing:border-box;margin:0;}
html{scroll-behavior:smooth;}
body{background:var(--cream);color:var(--ink);font:17px/1.6 Inter,sans-serif;-webkit-font-smoothing:antialiased;}
a{color:inherit;}
img{max-width:100%;display:block;}

/* ---- containers + utilities ---- */
.wrap{max-width:1080px;margin:0 auto;padding:0 28px;}
.prose{max-width:820px;margin:0 auto;padding:0 28px;}
.fr{font-family:Fraunces,serif;}
.kicker{font-size:13px;letter-spacing:2px;text-transform:uppercase;color:var(--terra2);font-weight:600;}
.center{text-align:center;}

/* ---- nav ---- */
.nav{display:flex;align-items:center;gap:28px;padding:24px 0;position:sticky;top:0;
  background:rgba(251,246,240,.86);backdrop-filter:blur(10px);z-index:30;border-bottom:1px solid transparent;}
.nav.scrolled{border-bottom:1px solid var(--line);}
.logo{font-family:Fraunces;font-weight:600;font-size:23px;letter-spacing:-.3px;text-decoration:none;color:var(--ink);}
.logo b{color:var(--terra);}
.nav .links{margin-left:auto;display:flex;gap:26px;font-size:15px;color:var(--ink2);align-items:center;}
.nav .links a{color:var(--ink2);text-decoration:none;}
.nav .links a:hover{color:var(--ink);}
.navbadge{display:inline-flex;align-items:center;gap:8px;background:var(--ink);color:#fff !important;
  padding:9px 15px;border-radius:11px;text-decoration:none;font-weight:600;font-size:14px;}

/* ---- App Store badge + links/buttons ---- */
.badge{display:inline-flex;transition:transform .15s;text-decoration:none;}
.badge:hover{transform:translateY(-2px);}
.badge img{height:54px;width:auto;}
.ghost{color:var(--ink);font-weight:600;text-decoration:none;border-bottom:2px solid var(--terra);padding-bottom:2px;}
.ghost:hover{color:var(--terra2);}
.cta{display:flex;align-items:center;gap:22px;margin-top:32px;flex-wrap:wrap;}
:focus-visible{outline:3px solid var(--terra);outline-offset:2px;border-radius:6px;}

/* ---- footer ---- */
.footer{border-top:1px solid var(--line);margin-top:8px;}
.footer .inner{max-width:1080px;margin:0 auto;padding:40px 28px;color:var(--ink2);font-size:14px;
  display:flex;gap:24px;align-items:center;flex-wrap:wrap;}
.footer a{color:var(--ink2);text-decoration:none;}
.footer a:hover{color:var(--ink);}
.footer .sp{margin-left:auto;}

/* ---- section primitives ---- */
.sec{padding:64px 0;border-top:1px solid var(--line);}
.sec h2{font-family:Fraunces;font-weight:500;font-size:40px;letter-spacing:-.6px;margin-top:12px;}
.sec .intro{color:var(--ink2);margin-top:14px;max-width:34em;font-size:18px;}

/* ---- FAQ accordions (shared) ---- */
details{border-bottom:1px solid var(--line);padding:20px 0;}
summary{font-family:Fraunces;font-weight:600;font-size:19px;cursor:pointer;list-style:none;
  display:flex;justify-content:space-between;align-items:center;gap:18px;}
summary::-webkit-details-marker{display:none;}
summary:after{content:"+";color:var(--terra);font-size:24px;line-height:1;}
details[open] summary:after{content:"–";}
details p{color:var(--ink2);margin-top:12px;max-width:54em;}
details ul{margin-top:10px;padding-left:20px;color:var(--ink2);}
details li{margin-top:6px;}
.faqwrap{margin-top:30px;border-top:1px solid var(--line);}

/* ===================================================================
   LANDING (index.html)
   =================================================================== */
.hero{display:grid;grid-template-columns:1.05fr .95fr;gap:48px;align-items:center;padding:54px 0 40px;}
.hero .eyebrow{font-size:13px;letter-spacing:2px;text-transform:uppercase;color:var(--terra2);font-weight:600;}
h1{font-family:Fraunces;font-weight:500;font-size:60px;line-height:1.04;letter-spacing:-1.2px;margin-top:18px;}
h1 em{font-style:italic;color:var(--terra);}
.lede{font-size:19px;color:var(--ink2);margin-top:22px;max-width:30em;}
.tagline{margin-top:26px;font-family:Fraunces;font-style:italic;font-size:18px;color:var(--ink2);}

/* phone (app aesthetic) — shared by hero + demo */
.device{width:300px;height:610px;background:#fff;border-radius:46px;border:1px solid var(--line);
  box-shadow:0 44px 100px rgba(33,28,24,.20);padding:12px;position:relative;justify-self:center;}
.device:before{content:"";position:absolute;top:20px;left:50%;transform:translateX(-50%);
  width:110px;height:30px;border-radius:18px;background:#211C18;z-index:6;}
.app{height:100%;border-radius:34px;overflow:hidden;background:var(--cream);position:relative;font-family:'Hanken Grotesk',sans-serif;}
.num{font-family:'Schibsted Grotesk',sans-serif;font-variant-numeric:tabular-nums;}
.h-head{padding:46px 18px 0;}
.h-hi{font-size:13px;color:var(--ink2);} .h-name{font-family:'Schibsted Grotesk';font-weight:800;font-size:22px;margin-top:2px;}
.h-balance{margin:14px 18px 0;background:linear-gradient(150deg,var(--terra),var(--terra2));border-radius:22px;padding:18px;color:#fff;}
.h-balance .l{font-size:12px;opacity:.85;} .h-balance .v{font-family:'Schibsted Grotesk';font-weight:800;font-size:30px;margin-top:4px;}
.h-balance .sub{font-size:12px;opacity:.85;margin-top:6px;}
.h-sec{margin:18px 18px 0;font-size:13px;font-weight:700;color:var(--ink2);}
.h-row{margin:8px 18px 0;background:#fff;border:1px solid var(--line);border-radius:16px;padding:12px 14px;display:flex;align-items:center;gap:11px;}
.h-ic{width:36px;height:36px;border-radius:11px;background:var(--cream2);display:flex;align-items:center;justify-content:center;font-size:16px;flex:none;}
.h-row .m{font-size:14px;font-weight:600;} .h-row .d{font-size:11.5px;color:var(--ink3);}
.h-row .amt{margin-left:auto;font-family:'Schibsted Grotesk';font-weight:700;font-size:15px;}
.tabbar{position:absolute;left:14px;right:14px;bottom:16px;height:58px;border-radius:22px;
  background:rgba(255,255,255,.86);backdrop-filter:blur(14px);border:1px solid var(--line);
  box-shadow:0 12px 30px -12px rgba(33,28,24,.28);display:flex;align-items:center;justify-content:space-around;z-index:5;}
.tabbar .ti{font-size:9.5px;font-weight:700;color:var(--ink3);display:flex;flex-direction:column;align-items:center;gap:3px;}
.tabbar .ti .b{width:18px;height:18px;border-radius:6px;background:currentColor;opacity:.5;}
.tabbar .ti.on{color:var(--terra);} .tabbar .ti.on .b{opacity:1;}
.fab{width:54px;height:54px;border-radius:18px;margin-top:-24px;background:linear-gradient(150deg,var(--terra),var(--terra2));
  box-shadow:0 8px 20px -4px rgba(232,96,44,.6);display:flex;align-items:center;justify-content:center;color:#fff;font-size:24px;position:relative;}

/* reads strip */
.reads{display:flex;flex-wrap:wrap;gap:12px 26px;align-items:center;justify-content:center;padding:8px 0 56px;}
.reads .lbl{font-size:12px;letter-spacing:1.5px;text-transform:uppercase;color:var(--ink2);font-weight:600;}
.reads .chip{font-family:Fraunces;font-weight:600;font-size:17px;color:var(--ink);}
.reads .sep{color:var(--terra);}

/* auto-play demo */
.demoSec{padding:64px 0;border-top:1px solid var(--line);text-align:center;}
.demoSec h2{font-family:Fraunces;font-weight:500;font-size:40px;letter-spacing:-.6px;margin-top:12px;}
.demoSec .intro{color:var(--ink2);margin:14px auto 0;max-width:34em;font-size:18px;}
.demoStage{display:flex;align-items:center;justify-content:center;gap:54px;margin-top:46px;flex-wrap:wrap;}
.demoSteps{text-align:left;max-width:300px;}
.dStep{display:flex;gap:14px;align-items:flex-start;padding:16px;border-radius:16px;transition:.4s;opacity:.45;}
.dStep.on{opacity:1;background:#fff;box-shadow:0 12px 30px rgba(33,28,24,.07);}
.dStep .dn{width:34px;height:34px;border-radius:50%;flex:none;background:var(--cream2);color:var(--ink2);
  display:flex;align-items:center;justify-content:center;font-family:Fraunces;font-weight:600;transition:.4s;}
.dStep.on .dn{background:var(--terra);color:#fff;}
.dStep h4{font-family:Fraunces;font-weight:600;font-size:19px;} .dStep p{color:var(--ink2);font-size:14.5px;margin-top:3px;}
.scenes{position:absolute;inset:0;}
.scene{position:absolute;inset:0;opacity:0;transition:opacity .5s ease;pointer-events:none;}
.device[data-scene="0"] .s0,.device[data-scene="1"] .s1,.device[data-scene="2"] .s2,.device[data-scene="3"] .s3{opacity:1;}
.tapring{position:absolute;width:54px;height:54px;border-radius:18px;left:50%;transform:translateX(-50%);bottom:18px;border:3px solid var(--terra);opacity:0;}
.device[data-scene="0"] .tapring{animation:tap 2.4s ease-out 1s infinite;}
@keyframes tap{0%{opacity:.7;transform:translateX(-50%) scale(1);}70%{opacity:0;transform:translateX(-50%) scale(1.7);}100%{opacity:0;}}
.cam{position:absolute;inset:0;background:#1a1512;display:flex;align-items:center;justify-content:center;}
.receiptImg{width:160px;height:230px;background:#fff;border-radius:8px;padding:14px;transform:rotate(-2deg);box-shadow:0 20px 40px rgba(0,0,0,.5);}
.receiptImg .ln{height:6px;border-radius:3px;background:#e7ddd0;margin-bottom:8px;}
.receiptImg .ln.s{width:55%;} .receiptImg .ln.t{width:80%;height:10px;background:#cdbfad;}
.scanline{position:absolute;left:8%;right:8%;height:3px;background:linear-gradient(90deg,transparent,var(--terra),transparent);box-shadow:0 0 16px var(--terra);top:8%;opacity:0;}
.device[data-scene="1"] .scanline{animation:scan 1.6s ease-in-out .2s infinite;}
@keyframes scan{0%{top:10%;opacity:0;}15%{opacity:1;}85%{opacity:1;}100%{top:86%;opacity:0;}}
.camLabel{position:absolute;bottom:30px;left:0;right:0;text-align:center;color:#fff;font-size:13px;font-weight:600;opacity:.9;}
.camLabel .dots:after{content:"";animation:dots 1.4s steps(4,end) infinite;}
@keyframes dots{0%{content:"";}25%{content:".";}50%{content:"..";}75%{content:"...";}}
.ex{padding:54px 18px 0;}
.ex .top{font-family:'Schibsted Grotesk';font-weight:800;font-size:18px;margin-bottom:4px;}
.ex .topd{font-size:12px;color:var(--ink2);margin-bottom:14px;}
.exField{background:#fff;border:1px solid var(--line);border-radius:14px;padding:12px 14px;margin-bottom:9px;
  display:flex;justify-content:space-between;align-items:center;opacity:0;transform:translateY(8px);}
.exField .k{font-size:12px;color:var(--ink2);} .exField .v{font-family:'Schibsted Grotesk';font-weight:700;font-size:14px;}
.exField .chk{color:var(--income);font-weight:700;}
.device[data-scene="2"] .exField{animation:pop .4s ease forwards;}
.device[data-scene="2"] .exField:nth-child(2){animation-delay:.25s;}
.device[data-scene="2"] .exField:nth-child(3){animation-delay:.5s;}
.device[data-scene="2"] .exField:nth-child(4){animation-delay:.75s;}
.device[data-scene="2"] .exField:nth-child(5){animation-delay:1s;}
@keyframes pop{to{opacity:1;transform:translateY(0);}}
.gstpill{display:inline-block;background:#E2F1EE;color:var(--teal);font-size:10px;font-weight:700;padding:3px 8px;border-radius:999px;}
.ok{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:0 24px;text-align:center;background:var(--cream);}
.okc{width:84px;height:84px;border-radius:50%;background:var(--income);display:flex;align-items:center;justify-content:center;color:#fff;font-size:44px;transform:scale(0);}
.device[data-scene="3"] .okc{animation:popin .5s cubic-bezier(.2,1.3,.5,1) forwards;}
@keyframes popin{to{transform:scale(1);}}
.ok h3{font-family:'Schibsted Grotesk';font-weight:800;font-size:24px;margin-top:20px;}
.ok p{color:var(--ink2);font-size:14px;margin-top:8px;}
.okmini{background:#fff;border:1px solid var(--line);border-radius:14px;padding:12px 14px;margin-top:22px;width:100%;display:flex;align-items:center;gap:11px;text-align:left;}

/* how-it-works steps + features grid */
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:26px;margin-top:42px;}
.step .n{font-family:Fraunces;font-style:italic;font-size:46px;color:var(--terra);opacity:.5;line-height:1;}
.step h3{font-family:Fraunces;font-weight:600;font-size:21px;margin-top:8px;}
.step p{color:var(--ink2);margin-top:8px;font-size:15.5px;}
.grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:42px;}
.f{background:var(--card);border:1px solid var(--line);border-radius:20px;padding:28px;transition:transform .15s,box-shadow .15s;}
.f:hover{transform:translateY(-3px);box-shadow:0 16px 40px rgba(33,28,24,.08);}
.f .ic{width:48px;height:48px;border-radius:13px;background:#FCE9DF;display:flex;align-items:center;justify-content:center;font-size:24px;}
.f h3{font-family:Fraunces;font-weight:600;font-size:20px;margin-top:18px;}
.f p{color:var(--ink2);font-size:15px;margin-top:8px;}
.alsoline{margin-top:26px;color:var(--ink2);font-size:15.5px;text-align:center;}
.alsoline b{color:var(--ink);font-weight:600;}

/* pricing teaser (landing) */
.ptease{display:grid;grid-template-columns:1fr 1fr;gap:22px;margin-top:42px;}
.seePlans{text-align:center;margin-top:24px;}

/* trust band */
.band{background:var(--ink);color:#f3ede5;border-radius:26px;padding:46px;margin:8px 0;text-align:center;}
.band h2{font-family:Fraunces;font-weight:500;font-size:32px;color:#fff;}
.bullets{display:flex;flex-wrap:wrap;gap:14px 34px;justify-content:center;margin-top:24px;font-size:15.5px;}
.bullets b{color:#fff;}

/* final cta */
.final{text-align:center;padding:78px 0 64px;}
.final h2{font-family:Fraunces;font-weight:500;font-size:48px;letter-spacing:-1px;}
.final em{font-style:italic;color:var(--terra);}
.final .sub{color:var(--ink2);margin-top:16px;font-size:18px;}
.final .cta{justify-content:center;margin-top:30px;}

/* ===================================================================
   PLANS (landing teaser + pricing page)
   =================================================================== */
.plan{background:#fff;border:1px solid var(--line);border-radius:22px;padding:30px;}
.plan.pro{border:2px solid var(--terra);position:relative;}
.plan.pro:after{content:"Most popular";position:absolute;top:-12px;right:24px;background:var(--terra);color:#fff;
  font-size:11px;font-weight:700;padding:4px 12px;border-radius:999px;}
.plan .pname{font-family:Fraunces;font-weight:600;font-size:24px;}
.plan .ptag{color:var(--ink2);font-size:14px;margin-top:4px;}
.plan .price{font-family:'Schibsted Grotesk';font-weight:800;font-size:42px;margin-top:14px;letter-spacing:-1px;}
.plan .price small{font-size:16px;color:var(--ink2);font-weight:600;}
.plan .annual{font-size:13px;color:var(--teal);font-weight:600;margin-top:4px;}
.plan .pcta{display:block;text-align:center;margin-top:20px;padding:13px;border-radius:13px;font-weight:600;text-decoration:none;}
.plan .pcta.dark{background:var(--ink);color:#fff;} .plan .pcta.terra{background:var(--terra);color:#fff;}
.plan .badge{justify-content:center;margin-top:18px;}
.plan ul,.plist{list-style:none;margin-top:18px;display:flex;flex-direction:column;gap:10px;}
.plan li{font-size:14.5px;color:var(--ink2);padding-left:24px;position:relative;}
.plan li:before{content:"✓";position:absolute;left:0;color:var(--teal);font-weight:700;}

/* ===================================================================
   PRICING PAGE
   =================================================================== */
.priceHero{text-align:center;padding:56px 0 10px;}
.priceHero h1{font-size:48px;}
.priceHero .lede{margin:18px auto 0;max-width:34em;}
.plans{display:grid;grid-template-columns:1fr 1fr;gap:24px;margin:46px 0 10px;}
.plans .plan{padding:34px;border-radius:24px;}
.plans .plan.pro{box-shadow:0 24px 60px rgba(232,96,44,.12);}
.plans .plan.pro:after{left:34px;right:auto;top:-13px;padding:5px 13px;}
.plans .price{font-size:46px;}
.cmp{margin:64px 0 0;}
.cmp h2{font-family:Fraunces;font-weight:500;font-size:32px;text-align:center;letter-spacing:-.4px;}
table{width:100%;border-collapse:collapse;margin-top:30px;background:#fff;border:1px solid var(--line);border-radius:18px;overflow:hidden;}
th,td{text-align:left;padding:15px 20px;border-bottom:1px solid var(--line);font-size:14.5px;}
th{font-family:Fraunces;font-weight:600;font-size:15px;}
thead th:nth-child(2),thead th:nth-child(3),td:nth-child(2),td:nth-child(3){text-align:center;width:130px;}
thead th:nth-child(3){color:var(--terra2);}
tbody tr:last-child td{border-bottom:none;}
.yes{color:var(--teal);font-weight:700;} .no{color:var(--ink3);} .lim{color:var(--ink2);font-size:13px;}
.why{background:var(--ink);color:#f3ede5;border-radius:22px;padding:36px;margin:56px 0 0;text-align:center;}
.why h3{font-family:Fraunces;font-weight:500;font-size:24px;color:#fff;}
.why p{opacity:.9;margin:10px auto 0;max-width:46em;}
.faqSec{margin:56px 0 0;}
.faqSec h2{font-family:Fraunces;font-weight:500;font-size:30px;text-align:center;}
.faqSec details{max-width:760px;margin:0 auto;padding:18px 0;}
.faqSec summary{font-size:18px;}

/* ===================================================================
   PRIVACY PAGE
   =================================================================== */
.legalHead{padding-top:46px;}
.legalHead h1{font-size:44px;}
.meta{color:var(--ink3);font-size:14px;margin-top:14px;}
.prose h2{font-family:Fraunces;font-weight:600;font-size:24px;margin-top:44px;letter-spacing:-.3px;}
.prose h3{font-family:Fraunces;font-weight:600;font-size:17px;margin-top:22px;}
.prose p{margin-top:12px;color:var(--ink);} .prose p.sub{color:var(--ink2);}
.prose ul{margin-top:12px;padding-left:22px;} .prose li{margin-top:8px;}
.glance{background:#fff;border:1px solid var(--line);border-radius:20px;padding:26px 28px;margin-top:30px;}
.glance .gh{font-family:Fraunces;font-weight:600;font-size:18px;}
.glist{display:grid;grid-template-columns:1fr 1fr;gap:16px 26px;margin-top:16px;}
.gi{display:flex;gap:10px;align-items:flex-start;font-size:14.5px;}
.gi .ic{flex:none;} .gi .d{color:var(--ink2);}
.dtable{margin-top:14px;border:1px solid var(--line);border-radius:14px;overflow:hidden;background:#fff;}
.dtable .tr{display:grid;grid-template-columns:1fr 1.6fr;border-bottom:1px solid var(--line);}
.dtable .tr:last-child{border-bottom:none;}
.dtable .th{font-family:Fraunces;font-weight:600;background:var(--cream2);}
.dtable .c{padding:12px 16px;font-size:14.5px;} .dtable .c:first-child{border-right:1px solid var(--line);font-weight:600;}
.callout2{background:#FDEBE0;border:1px solid #f3d3c2;border-radius:14px;padding:16px 18px;margin-top:18px;font-size:14.5px;color:var(--ink2);}

/* ===================================================================
   SUPPORT PAGE
   =================================================================== */
.supHero{text-align:center;padding:52px 0 8px;}
.supHero h1{font-size:46px;}
.supHero .lede{margin:16px auto 0;max-width:32em;}
.contact{display:flex;gap:16px;justify-content:center;flex-wrap:wrap;margin-top:26px;}
.cbtn{display:inline-flex;align-items:center;gap:9px;background:var(--ink);color:#fff;padding:12px 20px;border-radius:13px;text-decoration:none;font-weight:600;}
.cbtn.alt{background:#fff;color:var(--ink);border:1px solid var(--line);}
.resp{color:var(--ink3);font-size:13.5px;margin-top:12px;}
.supH2{font-family:Fraunces;font-weight:500;font-size:30px;text-align:center;margin-top:60px;letter-spacing:-.4px;}
.topics{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:30px;}
.topic{background:#fff;border:1px solid var(--line);border-radius:18px;padding:22px;}
.topic .ic{font-size:24px;} .topic h3{font-family:Fraunces;font-weight:600;font-size:18px;margin-top:12px;}
.topic p{color:var(--ink2);font-size:14px;margin-top:6px;}
.info{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin-top:30px;}
.infocard{background:#fff;border:1px solid var(--line);border-radius:18px;padding:24px;}
.infocard h3{font-family:Fraunces;font-weight:600;font-size:18px;} .infocard p{color:var(--ink2);font-size:14.5px;margin-top:8px;}

/* ===================================================================
   RESPONSIVE
   =================================================================== */
@media(max-width:880px){
  .nav .links a:not(.navbadge){display:none;}
  .hero{grid-template-columns:1fr;} h1{font-size:44px;} .priceHero h1,.supHero h1,.legalHead h1{font-size:34px;}
  .final h2{font-size:36px;}
  .steps,.grid,.plans,.ptease,.info,.topics,.glist{grid-template-columns:1fr;}
  .demoStage{flex-direction:column;}
}

/* ===================================================================
   REDUCED MOTION
   =================================================================== */
@media (prefers-reduced-motion: reduce){
  *{animation-duration:.001ms !important;animation-iteration-count:1 !important;
    transition-duration:.001ms !important;scroll-behavior:auto !important;}
  .scene{transition:none;}
}
