/* ==========================================================================
   SetStreak — marketing & auth styles
   Shares the visual language of the app: warm sunrise gradient, soft cards,
   22px radii, heavy rounded type on a cream background.
   ========================================================================== */

:root{
  --ink:#2B1B2E;
  --muted:#7E6A77;
  --link:#E63E68;
  --line:#F0E6EA;
  --card:#FFFFFF;
  --bg1:#FFF6F4;
  --bg2:#FFEFF3;
  --rasp:#FF4E78;
  --tang:#FF8A3D;
  --gold:#FFC24B;
  --grad:linear-gradient(120deg,#FF4E78 0%,#FF7A4D 60%,#FF8A3D 100%);
  --grad-soft:linear-gradient(120deg,#FFE3EA,#FFEAD9);
  --shadow:0 10px 30px -12px rgba(255,78,120,.35);
  --shadow-soft:0 6px 20px -10px rgba(43,27,46,.25);
  --r:22px;
}

*{box-sizing:border-box;-webkit-tap-highlight-color:transparent;}
html{scroll-behavior:smooth;}
html,body{margin:0;padding:0;}
body{
  font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,system-ui,sans-serif;
  color:var(--ink);
  background:
    radial-gradient(120% 80% at 100% 0%, var(--bg2) 0%, transparent 55%),
    radial-gradient(120% 80% at 0% 0%, #FFF0E8 0%, transparent 50%),
    var(--bg1);
  background-attachment:fixed;
  -webkit-font-smoothing:antialiased;
  min-height:100vh;
  min-height:100dvh;
  line-height:1.55;
}
img{max-width:100%;}
a{color:var(--link);text-decoration:none;font-weight:650;}
a:hover{text-decoration:underline;}
button{font-family:inherit;cursor:pointer;}
input{font-family:inherit;}

/* Visible focus everywhere */
a:focus-visible,button:focus-visible,input:focus-visible{
  outline:3px solid var(--rasp);
  outline-offset:2px;
  border-radius:8px;
}

/* ---------- Wordmark ---------- */
.wordmark{
  font-size:22px;font-weight:850;letter-spacing:-.5px;line-height:1;
  background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent;
  display:inline-block;text-decoration:none;
}
.wordmark:hover{text-decoration:none;}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  border:none;border-radius:999px;font-weight:800;font-size:15px;letter-spacing:.1px;
  padding:13px 26px;text-decoration:none;transition:transform .12s ease,box-shadow .12s ease;
  cursor:pointer;
}
.btn:hover{text-decoration:none;}
.btn-primary{
  background:var(--grad);color:#fff;box-shadow:var(--shadow);
}
.btn-primary:hover{transform:translateY(-1px);box-shadow:0 14px 34px -12px rgba(255,78,120,.45);}
.btn-primary:active{transform:translateY(0) scale(.98);}
.btn-primary:disabled{opacity:.6;cursor:wait;transform:none;}
.btn-ghost{
  background:var(--card);color:var(--ink);box-shadow:var(--shadow-soft);
}
.btn-ghost:hover{transform:translateY(-1px);}
.btn-lg{padding:16px 34px;font-size:17px;}
.btn-block{width:100%;}

/* ==========================================================================
   LANDING PAGE
   ========================================================================== */

.shell{max-width:1080px;margin:0 auto;padding:0 20px;}

/* ---------- Header ---------- */
.site-header{
  position:sticky;top:0;z-index:50;
  backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);
  background:rgba(255,246,244,.82);
  border-bottom:1px solid rgba(240,230,234,.7);
}
.site-header .shell{
  display:flex;align-items:center;justify-content:space-between;gap:12px;
  padding-top:14px;padding-bottom:14px;
}
.header-actions{display:flex;align-items:center;gap:10px;}
.header-actions .btn{padding:10px 20px;font-size:14px;}

/* ---------- Hero ---------- */
.hero{padding:56px 0 30px;}
.hero .shell{
  display:grid;grid-template-columns:1fr;gap:44px;align-items:center;
}
.eyebrow{
  display:inline-block;font-size:12px;font-weight:800;letter-spacing:1.6px;
  text-transform:uppercase;color:var(--rasp);
  background:var(--grad-soft);border-radius:999px;padding:7px 14px;margin-bottom:18px;
}
.hero h1{
  font-size:clamp(38px,7vw,58px);font-weight:850;letter-spacing:-1.6px;line-height:1.04;
  margin:0 0 16px;
}
.hero h1 .grad{
  background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent;
}
.hero .sub{
  font-size:18px;color:var(--muted);font-weight:550;max-width:46ch;margin:0 0 26px;
}
.hero-cta{display:flex;align-items:center;flex-wrap:wrap;gap:14px;}
.free-note{font-size:14px;font-weight:700;color:var(--muted);}
.free-note strong{color:var(--ink);}

/* ---------- Phone mockup (pure CSS) ---------- */
.hero-visual{display:flex;justify-content:center;}
.phone{
  width:min(340px,88vw);
  background:var(--ink);
  border-radius:44px;
  padding:12px;
  box-shadow:0 30px 60px -22px rgba(43,27,46,.5), var(--shadow);
  transform:rotate(0deg);
}
.phone-screen{
  background:
    radial-gradient(120% 70% at 100% 0%, var(--bg2) 0%, transparent 55%),
    var(--bg1);
  border-radius:34px;
  padding:22px 16px 24px;
  overflow:hidden;
}
.phone-notch{
  width:104px;height:22px;background:var(--ink);border-radius:999px;
  margin:-10px auto 14px;
}
.ph-hello{font-size:11px;color:var(--muted);font-weight:700;letter-spacing:.3px;}
.ph-name{
  font-size:22px;font-weight:850;letter-spacing:-.5px;line-height:1.05;margin:1px 0 14px;
  background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent;
  display:inline-block;
}
.ph-stats{display:flex;gap:8px;margin-bottom:16px;}
.ph-stat{
  flex:1;background:var(--card);border-radius:14px;padding:10px 10px 9px;box-shadow:var(--shadow-soft);
}
.ph-stat .num{font-size:19px;font-weight:850;letter-spacing:-.4px;line-height:1;}
.ph-stat.fire .num{color:var(--tang);}
.ph-stat .lbl{font-size:9.5px;color:var(--muted);font-weight:700;margin-top:4px;letter-spacing:.2px;}
.ph-section{
  font-size:10px;font-weight:800;color:var(--muted);text-transform:uppercase;
  letter-spacing:1.3px;margin:0 2px 9px;
}
.ph-day{
  background:var(--card);border-radius:17px;padding:12px 13px;box-shadow:var(--shadow-soft);
  margin-bottom:9px;display:flex;align-items:center;gap:11px;position:relative;overflow:hidden;
}
.ph-day .badge{
  width:38px;height:38px;border-radius:12px;flex:0 0 auto;
  display:flex;align-items:center;justify-content:center;font-size:18px;
  background:var(--grad-soft);
}
.ph-day.done .badge{background:var(--grad);color:#fff;}
.ph-day .meta{flex:1;min-width:0;}
.ph-day .dname{font-size:13.5px;font-weight:800;letter-spacing:-.2px;}
.ph-day .dsub{font-size:10.5px;color:var(--muted);font-weight:650;margin-top:2px;}
.ph-day .chev{color:#E7C9D2;font-size:18px;font-weight:700;flex:0 0 auto;}
.ph-day .donetag{
  position:absolute;top:0;right:0;background:var(--grad);color:#fff;font-size:8px;font-weight:800;
  letter-spacing:.5px;padding:4px 9px;border-bottom-left-radius:10px;text-transform:uppercase;
}

/* ---------- Sections ---------- */
.section{padding:60px 0;}
.section-kicker{
  font-size:12px;font-weight:800;letter-spacing:1.6px;text-transform:uppercase;
  color:var(--rasp);margin:0 0 8px;text-align:center;
}
.section-title{
  font-size:clamp(28px,4.6vw,38px);font-weight:850;letter-spacing:-1px;line-height:1.1;
  margin:0 0 14px;text-align:center;
}
.section-sub{
  font-size:16.5px;color:var(--muted);font-weight:550;text-align:center;
  max-width:54ch;margin:0 auto 40px;
}

/* ---------- Features ---------- */
.features{display:grid;grid-template-columns:1fr;gap:18px;}
.feature{
  background:var(--card);border-radius:var(--r);padding:28px 26px;box-shadow:var(--shadow-soft);
  position:relative;overflow:hidden;
}
.feature::before{
  content:"";position:absolute;inset:0 auto 0 0;width:5px;background:var(--grad);
  border-radius:0 4px 4px 0;
}
.feature .icon{
  width:52px;height:52px;border-radius:16px;background:var(--grad-soft);
  display:flex;align-items:center;justify-content:center;font-size:25px;margin-bottom:16px;
}
.feature h3{font-size:20px;font-weight:800;letter-spacing:-.4px;margin:0 0 8px;}
.feature p{font-size:15px;color:var(--muted);font-weight:550;margin:0;}

/* ---------- Extras chips ---------- */
.chips{
  display:flex;flex-wrap:wrap;justify-content:center;gap:10px;margin-top:32px;
}
.chip{
  background:var(--card);border:1px solid var(--line);border-radius:999px;
  padding:9px 18px;font-size:13.5px;font-weight:750;color:var(--ink);
  box-shadow:var(--shadow-soft);
}

/* ---------- How it works ---------- */
.steps{display:grid;grid-template-columns:1fr;gap:18px;counter-reset:step;}
.step{
  background:var(--grad-soft);border-radius:var(--r);padding:26px 24px;text-align:left;
}
.step .n{
  width:42px;height:42px;border-radius:999px;background:var(--grad);color:#fff;
  display:flex;align-items:center;justify-content:center;
  font-size:18px;font-weight:850;margin-bottom:14px;box-shadow:var(--shadow);
}
.step h3{font-size:18px;font-weight:800;letter-spacing:-.3px;margin:0 0 6px;}
.step p{font-size:14.5px;color:#7A6573;font-weight:600;margin:0;}

/* ---------- Final CTA ---------- */
.cta-final{padding:30px 0 80px;}
.cta-card{
  background:var(--grad);border-radius:28px;padding:54px 28px;text-align:center;
  box-shadow:var(--shadow);color:#fff;position:relative;overflow:hidden;
}
.cta-card::after{
  content:"";position:absolute;width:340px;height:340px;border-radius:50%;
  background:rgba(255,255,255,.12);top:-170px;right:-110px;pointer-events:none;
}
.cta-card h2{
  font-size:clamp(28px,5vw,40px);font-weight:850;letter-spacing:-1px;line-height:1.08;margin:0 0 10px;
}
.cta-card p{font-size:16.5px;font-weight:600;opacity:.92;margin:0 0 26px;}
.btn-inverse{
  background:#fff;color:var(--rasp);box-shadow:0 12px 30px -10px rgba(43,27,46,.35);
}
.btn-inverse:hover{transform:translateY(-1px);}

/* ---------- Footer ---------- */
.site-footer{
  border-top:1px solid var(--line);padding:30px 0 44px;
}
.site-footer .shell{
  display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:14px;
}
.foot-brand{font-size:13.5px;color:var(--muted);font-weight:650;}
.foot-links{display:flex;gap:20px;}
.foot-links a{font-size:13.5px;color:var(--muted);font-weight:700;}
.foot-links a:hover{color:var(--link);}

/* ---------- Desktop ---------- */
@media (min-width:840px){
  .hero{padding:84px 0 50px;}
  .hero .shell{grid-template-columns:1.05fr .95fr;gap:40px;}
  .hero-copy{padding-right:8px;}
  .phone{transform:rotate(2.5deg);}
  .features{grid-template-columns:repeat(3,1fr);}
  .steps{grid-template-columns:repeat(3,1fr);}
  .section{padding:76px 0;}
}

/* ==========================================================================
   AUTH PAGES (signup / login / forgot / reset / verify)
   ========================================================================== */

.auth-body{
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  padding:max(20px,env(safe-area-inset-top)) 18px calc(40px + env(safe-area-inset-bottom));
}
.auth-wrap{width:100%;max-width:420px;}
.auth-brand{text-align:center;margin-bottom:22px;}
.auth-brand .wordmark{font-size:28px;}
.auth-card{
  background:var(--card);border-radius:var(--r);box-shadow:var(--shadow-soft);
  padding:30px 26px 28px;
}
.auth-card h1{font-size:23px;font-weight:850;letter-spacing:-.5px;margin:0 0 6px;}
.auth-card .lead{font-size:14.5px;color:var(--muted);font-weight:600;margin:0 0 22px;}

.field{margin-bottom:16px;}
.field label{
  display:block;font-size:12.5px;font-weight:800;letter-spacing:.4px;
  text-transform:uppercase;color:var(--muted);margin-bottom:7px;
}
.field input{
  width:100%;border:2px solid var(--line);border-radius:14px;background:#FFFDFC;
  padding:13px 15px;font-size:16px;color:var(--ink);font-weight:600;
  transition:border-color .12s ease;
}
.field input::placeholder{color:#C9BAC3;font-weight:500;}
.field input:focus{outline:none;border-color:var(--rasp);}
.field .hint{font-size:12.5px;color:var(--muted);font-weight:600;margin-top:6px;}

.form-error{
  display:none;background:#FFECEF;border:1px solid #FFD2DB;color:#C8244D;
  border-radius:14px;padding:12px 15px;font-size:14px;font-weight:650;margin-bottom:16px;
}
.form-error.show{display:block;}
.form-error a{color:#C8244D;text-decoration:underline;}

.form-success{
  display:none;background:#EAF8EF;border:1px solid #CDEDD8;color:#1E7A43;
  border-radius:14px;padding:12px 15px;font-size:14px;font-weight:650;margin-bottom:16px;
}
.form-success.show{display:block;}

.auth-alt{
  text-align:center;font-size:14px;color:var(--muted);font-weight:650;margin:20px 0 0;
}
.auth-foot{
  text-align:center;font-size:12.5px;color:var(--muted);font-weight:600;margin-top:24px;
}
.auth-foot a{color:var(--muted);text-decoration:underline;}

/* Status pages (verify) */
.status-icon{
  width:64px;height:64px;border-radius:999px;display:flex;align-items:center;justify-content:center;
  font-size:30px;margin:0 auto 16px;
}
.status-icon.ok{background:var(--grad);color:#fff;box-shadow:var(--shadow);}
.status-icon.fail{background:#FFECEF;color:#C8244D;}
.status-center{text-align:center;}
.status-center h1{margin-bottom:8px;}
.status-center .lead{margin-bottom:24px;}

/* ==========================================================================
   LEGAL PAGES (privacy / terms)
   ========================================================================== */

.legal-main{max-width:720px;margin:0 auto;padding:40px 20px 80px;}
.legal-main h1{font-size:34px;font-weight:850;letter-spacing:-.8px;margin:0 0 4px;}
.legal-main .updated{font-size:13.5px;color:var(--muted);font-weight:650;margin:0 0 22px;}
.legal-note{
  background:var(--grad-soft);border-radius:16px;padding:14px 18px;
  font-size:14px;font-weight:650;color:#7A6573;margin-bottom:30px;
}
.legal-main h2{font-size:20px;font-weight:800;letter-spacing:-.3px;margin:34px 0 10px;}
.legal-main h3{font-size:16px;font-weight:750;letter-spacing:-.2px;margin:20px 0 6px;color:#2B1B2E;}
.legal-main p,.legal-main li{font-size:15.5px;color:#5E4B58;font-weight:500;line-height:1.6;}
.legal-main ul{padding-left:22px;}
.legal-main address{font-style:normal;}
.legal-toc{background:#FFFFFF;border:1px solid #F0E6EA;border-radius:14px;padding:14px 18px 14px 38px;margin:0 0 30px;}
.legal-toc li{margin:3px 0;font-weight:650;}

/* ---------- Motion preferences ---------- */
@media (prefers-reduced-motion:reduce){
  html{scroll-behavior:auto;}
  *,*::before,*::after{
    animation-duration:.01ms !important;
    animation-iteration-count:1 !important;
    transition-duration:.01ms !important;
  }
}
