/* The Memory Hand-Off — marketing site styles */
:root {
  --ivory:#FBF4E8; --ivoryWarm:#F5E8D0; --cream:#FFFAF2;
  --gold:#C9930A; --yellow:#F5C842; --pink:#F0A0B8; --pinkDeep:#D9728A;
  --orange:#E87238; --orangeDeep:#C85820;
  --ink:#2C1A0E; --inkMed:#5A3A1C; --muted:#9C7A52;
  --line:rgba(44,26,14,.12); --faint:rgba(44,26,14,.06);
  --pf:'Playfair Display',Georgia,serif;
  --lr:'Lora',Georgia,serif;
  --dm:'DM Mono',ui-monospace,monospace;
}
* { box-sizing:border-box; margin:0; padding:0; }
html { scroll-behavior:smooth; }
body { background:var(--ivory); color:var(--ink); font-family:var(--lr); line-height:1.65;
  -webkit-font-smoothing:antialiased; }
a { color:inherit; text-decoration:none; }
img, svg { display:block; max-width:100%; }
.wrap { max-width:1080px; margin:0 auto; padding:0 24px; }
.pf { font-family:var(--pf); }
.pfi { font-family:var(--pf); font-style:italic; }
.dm { font-family:var(--dm); letter-spacing:.16em; text-transform:uppercase; }
.eyebrow { font-family:var(--dm); letter-spacing:.22em; text-transform:uppercase; font-size:12px; color:var(--orange); }

/* Buttons */
.btn { display:inline-block; font-family:var(--lr); font-weight:600; font-size:15px;
  padding:14px 26px; border-radius:999px; cursor:pointer; transition:transform .15s, box-shadow .15s; border:none; }
.btn-primary { background:linear-gradient(135deg,var(--orange),var(--pinkDeep)); color:#fff;
  box-shadow:0 8px 24px rgba(232,114,56,.35); }
.btn-primary:hover { transform:translateY(-2px); box-shadow:0 12px 30px rgba(232,114,56,.45); }
.btn-ghost { background:rgba(44,26,14,.06); color:var(--ink); }
.btn-ghost:hover { background:rgba(44,26,14,.1); }

/* Header */
header { position:sticky; top:0; z-index:50; background:rgba(251,244,232,.85);
  backdrop-filter:saturate(140%) blur(10px); border-bottom:1px solid var(--line); }
.nav { display:flex; align-items:center; justify-content:space-between; height:68px; }
.brand { display:flex; align-items:center; gap:10px; font-family:var(--dm); font-size:12px;
  letter-spacing:.2em; text-transform:uppercase; color:var(--muted); }
.brand strong { color:var(--ink); font-family:var(--pf); font-style:normal; font-size:19px;
  letter-spacing:0; text-transform:none; font-weight:700; }
.brand .wm-gold { color:var(--gold); }
.brand .wm-orange { color:var(--orange); }
.brand-block { display:flex; flex-direction:column; line-height:1.05; }
.brand-tagline { font-family:var(--lr); font-style:normal; font-weight:500; color:var(--gold);
  font-size:11px; letter-spacing:.04em; margin-top:3px; text-transform:none; }
.nav-links { display:flex; align-items:center; gap:28px; }
.nav-links a { color:var(--inkMed); font-size:15px; }
.nav-links a:hover { color:var(--orange); }
@media (max-width:760px){ .nav-links a:not(.btn){ display:none; } }

/* Hero */
.hero { position:relative; overflow:hidden;
  background:radial-gradient(1200px 500px at 80% -10%, rgba(245,200,66,.35), transparent 60%),
             radial-gradient(900px 500px at 0% 10%, rgba(240,160,184,.30), transparent 55%); }
.hero-grid { display:grid; grid-template-columns:1.05fr .95fr; gap:40px; align-items:center;
  padding:72px 0 80px; }
@media (max-width:860px){ .hero-grid{ grid-template-columns:1fr; text-align:center; padding:48px 0 56px; } }
.hero h1 { font-family:var(--pf); font-weight:700; font-size:clamp(34px,5.4vw,58px); line-height:1.08;
  margin:18px 0 18px; letter-spacing:-.01em; }
.hero h1 em { font-style:italic; color:var(--orange); }
.hero p.lead { font-size:18px; color:var(--inkMed); max-width:520px; margin-bottom:28px; }
@media (max-width:860px){ .hero p.lead{ margin-left:auto; margin-right:auto; } }
.hero-cta { display:flex; gap:14px; flex-wrap:wrap; }
@media (max-width:860px){ .hero-cta{ justify-content:center; } }
.hero-note { font-family:var(--dm); font-size:11px; color:var(--muted); margin-top:16px; }

/* Phone mockup */
.phone { width:300px; max-width:80vw; margin:0 auto; filter:drop-shadow(0 30px 60px rgba(44,26,14,.28)); }

/* Section scaffolding */
section { padding:84px 0; }
.section-head { text-align:center; max-width:680px; margin:0 auto 48px; }
.section-head h2 { font-family:var(--pf); font-weight:700; font-size:clamp(28px,3.6vw,40px);
  line-height:1.15; margin:12px 0 14px; }
.section-head p { font-size:17px; color:var(--inkMed); }

/* Steps */
.steps { display:grid; grid-template-columns:repeat(3,1fr); gap:24px; }
@media (max-width:780px){ .steps{ grid-template-columns:1fr; } }
.step { background:var(--cream); border:1px solid var(--line); border-radius:18px; padding:28px 24px; }
.step .num { font-family:var(--dm); font-size:11px; color:var(--orange); }
.step h3 { font-family:var(--pf); font-size:21px; margin:14px 0 8px; }
.step p { color:var(--muted); font-size:15px; }

/* Features */
.features { display:grid; grid-template-columns:repeat(3,1fr); gap:20px; }
@media (max-width:880px){ .features{ grid-template-columns:repeat(2,1fr); } }
@media (max-width:560px){ .features{ grid-template-columns:1fr; } }
.feature { background:var(--cream); border:1px solid var(--line); border-radius:16px; padding:24px; }
.feature .ic { width:46px; height:46px; border-radius:12px; display:flex; align-items:center; justify-content:center;
  background:rgba(232,114,56,.12); margin-bottom:14px; }
.feature h3 { font-family:var(--pf); font-size:19px; margin-bottom:6px; }
.feature p { color:var(--muted); font-size:14.5px; }

/* Arc band */
.band { background:linear-gradient(135deg,var(--gold),var(--yellow) 60%,var(--orange)); color:#fff; }
.band .section-head h2, .band .section-head p { color:#fff; }
.band .eyebrow { color:rgba(255,255,255,.85); }
.arc-note { max-width:640px; margin:8px auto 0; text-align:center; color:rgba(255,255,255,.92); font-size:16px; }

/* Pricing */
.plans { display:grid; grid-template-columns:repeat(3,1fr); gap:20px; align-items:stretch; }
@media (max-width:820px){ .plans{ grid-template-columns:1fr; max-width:440px; margin:0 auto; } }
.plan { background:var(--cream); border:1px solid var(--line); border-radius:18px; padding:28px 24px; display:flex; flex-direction:column; }
.plan.feature-plan { border:2px solid var(--orange); box-shadow:0 18px 40px rgba(232,114,56,.18); position:relative; }
.plan .badge { position:absolute; top:-12px; left:50%; transform:translateX(-50%);
  background:var(--orange); color:#fff; font-family:var(--dm); font-size:10px; padding:5px 12px; border-radius:999px; }
.plan h3 { font-family:var(--pf); font-size:22px; margin-bottom:6px; }
.plan .price { font-family:var(--pf); font-weight:700; font-size:38px; margin:6px 0 2px; }
.plan .price span { font-family:var(--lr); font-weight:400; font-size:15px; color:var(--muted); }
.plan .cadence { color:var(--muted); font-size:14px; margin-bottom:16px; }
.plan ul { list-style:none; margin:8px 0 22px; }
.plan li { color:var(--inkMed); font-size:15px; padding:7px 0 7px 26px; position:relative; }
.plan li::before { content:"✦"; color:var(--gold); position:absolute; left:0; top:7px; }
.plan .btn { margin-top:auto; text-align:center; }
.trial-note { text-align:center; color:var(--muted); font-size:13px; margin-top:18px; }

/* Promise */
.promise { background:linear-gradient(135deg,rgba(240,160,184,.18),rgba(245,200,66,.18)); }
.promise .inner { max-width:760px; margin:0 auto; text-align:center; }
.promise h2 { font-family:var(--pf); font-style:italic; font-size:clamp(26px,3.4vw,38px); margin-bottom:16px; }
.promise p { font-size:17px; color:var(--inkMed); }

/* FAQ */
.faq { max-width:760px; margin:0 auto; }
.faq details { border-bottom:1px solid var(--line); padding:18px 0; }
.faq summary { font-family:var(--pf); font-size:19px; cursor:pointer; list-style:none; display:flex; justify-content:space-between; gap:16px; }
.faq summary::-webkit-details-marker { display:none; }
.faq summary::after { content:"+"; color:var(--orange); font-family:var(--lr); }
.faq details[open] summary::after { content:"–"; }
.faq p { color:var(--muted); font-size:15.5px; margin-top:10px; }

/* CTA */
.cta { text-align:center; }
.cta h2 { font-family:var(--pf); font-weight:700; font-size:clamp(28px,4vw,44px); line-height:1.12; margin-bottom:14px; }
.cta p { color:var(--inkMed); font-size:18px; margin-bottom:26px; }

/* Footer */
footer.site { background:var(--ink); color:rgba(255,255,255,.7); padding:48px 0 36px; }
footer.site .cols { display:flex; justify-content:space-between; gap:24px; flex-wrap:wrap; }
footer.site .brand strong { color:#fff; }
footer.site a { color:rgba(255,255,255,.8); font-size:14px; }
footer.site a:hover { color:#fff; }
footer.site .links { display:flex; gap:22px; flex-wrap:wrap; }
footer.site .legal { margin-top:28px; font-size:12px; color:rgba(255,255,255,.5); }

/* Legal/doc pages */
.doc { max-width:740px; margin:0 auto; padding:56px 24px 90px; }
.doc h1 { font-family:var(--pf); font-size:32px; margin-bottom:4px; }
.doc h2 { font-family:var(--pf); font-size:21px; margin:32px 0 8px; }
.doc p, .doc li { color:var(--inkMed); font-size:16px; }
.doc ul { padding-left:22px; margin:8px 0; }
.doc .meta { color:var(--muted); font-size:14px; }
.doc hr { border:none; border-top:1px solid var(--line); margin:24px 0; }
.doc .card { background:var(--cream); border:1px solid var(--line); border-radius:14px; padding:18px 20px; margin:18px 0; }
.doc .q { font-weight:600; color:var(--ink); margin-top:20px; font-family:var(--pf); font-size:18px; }
.backlink { display:inline-block; margin-bottom:20px; font-family:var(--dm); font-size:11px; color:var(--orange); }
