:root {
  --paper: #F1EAE0;
  --paper2: #EDE5D9;
  --surface: #FCFAF6;
  --tint: #FBF5EC;
  --ink: #2B2621;
  --ink2: #6E655B;
  --ink3: #A99E8F;
  --hair: #E7DED0;
  --brand: #C0623A;
  --brand-press: #A9522F;
  --brand-tint: #F6E7DB;
  --ok: #3D7154;
  --warn: #A97A22;
  --err: #AE4329;
  --hero-bg: #DAD2C6;
}

@media (prefers-color-scheme: dark) {
  :root {
    --paper: #17130F;
    --paper2: #201B16;
    --surface: #241E18;
    --tint: #2A231C;
    --ink: #F2EBE0;
    --ink2: #AEA394;
    --ink3: #786E60;
    --hair: #342C24;
    --brand-tint: #3A2A1E;
    --ok: #74B98F;
    --warn: #DBAC50;
    --err: #DE7B5E;
    --hero-bg: #14100C;
  }
}

* { box-sizing: border-box; }
[hidden] { display: none !important; }
html, body { margin: 0; padding: 0; }
body {
  background: var(--paper);
  color: var(--ink);
  font-family: 'Hanken Grotesk', sans-serif;
  font-size: 17px;
  line-height: 1.55;
  -webkit-font-smoothing: antialiased;
}
.site { background: var(--paper); color: var(--ink); }

.page { max-width: 1040px; margin: 0 auto; padding: 0 24px; }
.sect { padding-top: 88px; padding-bottom: 88px; }
.sectline { border-top: 1px solid var(--hair); }

/* Type */
.lbl {
  font-family: 'Space Grotesk', sans-serif;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  font-size: 12px;
  color: var(--ink3);
}
.lblbrand { color: var(--brand); }
.wordmark { display: inline-flex; align-items: center; }
.wordmark[title] { cursor: help; }
.wordmark-logo { height: 28px; width: auto; display: block; }
.wordmark-logo-dark { display: none; }
@media (prefers-color-scheme: dark) {
  .wordmark-logo-light { display: none; }
  .wordmark-logo-dark { display: block; }
}
.h1 { font-weight: 800; letter-spacing: -0.02em; line-height: 1.05; font-size: clamp(40px, 7vw, 68px); margin: 0; }
.h2 { font-weight: 800; letter-spacing: -0.02em; line-height: 1.1; font-size: clamp(28px, 4vw, 38px); margin: 0; }
.sub { color: var(--ink2); font-size: clamp(17px, 2.2vw, 20px); max-width: 34em; margin: 0; }
.micro { font-size: 14px; color: var(--ink3); }

/* Components */
.card { background: var(--surface); border: 1px solid var(--hair); border-radius: 14px; }
.pill {
  font-family: 'Space Grotesk', sans-serif; font-weight: 600; text-transform: uppercase;
  letter-spacing: 0.08em; font-size: 10.5px; background: var(--brand-tint); color: var(--brand);
  border-radius: 999px; padding: 4px 10px;
}
.chip {
  font-family: 'Space Grotesk', sans-serif; font-weight: 600; text-transform: uppercase;
  letter-spacing: 0.08em; font-size: 10.5px; background: var(--tint); border: 1px solid var(--hair);
  color: var(--ink2); border-radius: 999px; padding: 4px 10px;
}
.faqbtn:focus-visible, .circle:focus-visible,
.footer-link:focus-visible { outline: 2px solid var(--brand); outline-offset: 2px; }

/* Header */
.header { min-height: 72px; display: flex; align-items: center; justify-content: space-between; gap: 12px; flex-wrap: wrap; }
@media (max-width: 480px) { .header .lbl { display: none; } }

/* Hero */
.hero { background: var(--hero-bg); border-bottom: 1px solid var(--hair); }
.hero-inner { padding-top: 72px; padding-bottom: 96px; display: flex; flex-direction: column; gap: 24px; }
.hero-row { display: flex; align-items: center; gap: 56px; }
.hero-copy { display: flex; flex-direction: column; gap: 24px; flex: 1; }
.brevo-embed { width: 100%; max-width: 540px; }
.brevo-iframe { display: block; width: 100%; max-width: 540px; height: 480px; border: none; }
.appstore-link { align-self: flex-start; display: inline-block; }
.micro-col { display: flex; flex-direction: column; gap: 4px; }
.hero-demo { display: flex; flex-direction: column; align-items: center; gap: 24px; width: 400px; max-width: 100%; min-height: 230px; flex-shrink: 0; }

@media (max-width: 760px) {
  .hero-row { flex-direction: column; align-items: flex-start; }
  .hero-demo { min-height: 0; align-self: center; }
}

/* Capture circle */
.circle {
  width: 120px; height: 120px; border-radius: 50%; background: var(--brand); border: none;
  cursor: pointer; position: relative; display: flex; align-items: center; justify-content: center;
  flex-shrink: 0;
}
.circle:hover { background: var(--brand-press); }
@keyframes breathe { 0%, 100% { box-shadow: 0 0 0 0 rgba(192,98,58,0.28); } 50% { box-shadow: 0 0 0 22px rgba(192,98,58,0); } }
.breathing { animation: breathe 3.6s ease-in-out infinite; }
@media (prefers-reduced-motion: reduce) { .breathing { animation: none; } }
.glyph { width: 34px; height: 34px; border-radius: 50%; border: 3px solid #FCFAF6; position: relative; }
.glyph::after { content: ''; position: absolute; left: 50%; top: 50%; transform: translate(-50%, -50%); width: 10px; height: 10px; border-radius: 50%; background: #FCFAF6; }

.speech { font-size: 18px; color: var(--ink2); font-style: normal; min-height: 28px; margin: 0; }
.caret { display: inline-block; width: 2px; height: 1.1em; background: var(--brand); vertical-align: text-bottom; margin-left: 2px; animation: blink 1s step-end infinite; }
@keyframes blink { 50% { opacity: 0; } }

.memcard { padding: 18px 20px; max-width: 380px; width: 100%; display: flex; flex-direction: column; gap: 10px; }
.memhead { font-weight: 700; font-size: 17px; letter-spacing: -0.01em; }
.pillrow { display: flex; gap: 8px; flex-wrap: wrap; }
.taskrow { border: 1px dashed var(--hair); border-radius: 10px; padding: 8px 12px; color: var(--ink3); font-size: 13.5px; display: flex; align-items: center; gap: 10px; }
.cbx { width: 16px; height: 16px; border: 1.5px dashed var(--ink3); border-radius: 5px; flex-shrink: 0; }

@keyframes popin { from { opacity: 0; transform: scale(.6); } to { opacity: 1; transform: scale(1); } }
.pop { animation: popin .35s ease both; }
@keyframes risein { from { opacity: 0; transform: translateY(10px); } to { opacity: 1; transform: none; } }
.memcard { animation: risein .4s ease both; }
@media (prefers-reduced-motion: reduce) { .pop, .memcard { animation: none; } }

/* Problem */
.problem { display: flex; flex-direction: column; gap: 16px; }
.problem-copy { color: var(--ink); font-size: clamp(20px, 2.8vw, 26px); line-height: 1.4; max-width: 30em; margin: 0; }

/* How it works */
.eyebrow-col { display: flex; flex-direction: column; gap: 12px; }
.sect { display: flex; flex-direction: column; gap: 40px; }
.steps { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; }
@media (max-width: 760px) { .steps { grid-template-columns: 1fr; } }
.step { padding: 24px; display: flex; flex-direction: column; gap: 16px; }
.stept { color: var(--ink2); font-size: 15.5px; margin: 0; }
.vig { background: var(--tint); border: 1px solid var(--hair); border-radius: 10px; min-height: 132px; padding: 14px; overflow: hidden; position: relative; display: flex; flex-direction: column; justify-content: center; gap: 10px; }
.vig-search { justify-content: flex-start; }
.vig-row { display: flex; align-items: center; gap: 10px; }
.fab { position: static; width: 34px; height: 34px; border-radius: 50%; background: var(--brand); flex-shrink: 0; }
.vrow { background: var(--surface); border: 1px solid var(--hair); border-radius: 8px; padding: 7px 10px; font-size: 12.5px; font-weight: 600; letter-spacing: -0.01em; }
.vrow-listening { flex: 1; border-style: dashed; color: var(--ink3); font-weight: 400; }
.vsub { font-size: 11px; color: var(--ink3); font-weight: 400; }
.chiprow { display: flex; gap: 8px; }
.vsearch {
  background: var(--surface); border: 1px solid var(--hair); border-radius: 999px; padding: 7px 12px;
  font-size: 12px; color: var(--ink2); width: 100%; font-family: 'Hanken Grotesk', sans-serif;
}
.vsearch::placeholder { color: var(--ink3); }
.vsearch:focus-visible { outline: 2px solid var(--brand); outline-offset: 1px; border-color: var(--brand); }
.search-results { display: flex; flex-direction: column; gap: 10px; }
.vrow-brief { border-radius: 12px; padding: 10px 12px; display: flex; align-items: center; gap: 10px; }
.vrow-brief-copy { flex: 1; }
.playbtn { width: 36px; height: 36px; border-radius: 50%; background: var(--brand-tint); flex-shrink: 0; position: relative; border: none; cursor: pointer; padding: 0; }
.playbtn::after { content: ''; position: absolute; left: 55%; top: 50%; transform: translate(-50%, -50%); border-left: 9px solid var(--brand); border-top: 6px solid transparent; border-bottom: 6px solid transparent; }
.playbtn-sm { width: 26px; height: 26px; }
.playbtn.playing { background: var(--brand); }
.playbtn.playing::after { border-left-color: #FCFAF6; }

.step:hover .fab { animation: breathe 1.8s ease-in-out infinite; }
.step:hover .vsearch { border-color: var(--brand); }
.step:hover .playbtn { background: var(--brand); }
.step:hover .playbtn::after { border-left-color: #FCFAF6; }
@media (prefers-reduced-motion: reduce) { .step:hover .fab { animation: none; } }

.briefcard { padding: 26px 28px; max-width: 560px; border-radius: 16px; display: flex; gap: 16px; align-items: center; }
.briefcard-copy { display: flex; flex-direction: column; gap: 8px; }
.brief-text { color: var(--ink2); margin: 0; }
.bsent { transition: color .4s; }
.bon { color: var(--ink); }
.bdim { color: var(--ink3); }

/* Tasks quietly */
.tasks-quiet { padding-top: 44px; padding-bottom: 44px; display: flex; align-items: center; gap: 16px; flex-wrap: wrap; }
.tasks-copy { margin: 0; color: var(--ink2); flex: 1; min-width: 260px; }

/* Look inside */
.phones { display: grid; grid-template-columns: repeat(3, 1fr); gap: 32px; max-width: 900px; }
@media (max-width: 760px) { .phones { grid-template-columns: 1fr; max-width: 220px; } }
.phone-col { display: flex; flex-direction: column; gap: 12px; }
.phone { background: var(--surface); border: 1px solid var(--hair); border-radius: 36px; padding: 10px; }
.phone-ratio { position: relative; width: 100%; padding-top: 216.45%; border-radius: 28px; overflow: hidden; }
.phone-shot { position: absolute; top: 0; left: 0; display: block; width: 100%; height: 100%; object-fit: cover; }
.pcap { font-family: 'Space Grotesk', sans-serif; font-weight: 600; text-transform: uppercase; letter-spacing: 0.1em; font-size: 9px; color: var(--ink3); text-align: center; }

/* Privacy ledger */
.privacy-section { background: var(--paper2); }
.ledger { border-top: 1px solid var(--hair); }
.lrow { display: grid; grid-template-columns: 180px 1fr; gap: 20px; padding: 18px 0; border-bottom: 1px solid var(--hair); }
.lrow .lbl { padding-top: 2px; }
@media (max-width: 560px) { .lrow { grid-template-columns: 1fr; gap: 4px; } }
.lval { color: var(--ink2); margin: 0; font-size: 16px; }
.privacy-closing { margin: 0; color: var(--ink2); }
.namecopy { color: var(--ink2); font-size: clamp(17px, 2.2vw, 20px); max-width: 38em; margin: 0; }
a.plink { color: var(--brand); text-decoration: none; font-weight: 600; cursor: pointer; background: none; border: none; font: inherit; padding: 0; }

/* Pricing */
.prices { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; max-width: 960px; }
@media (max-width: 780px) { .prices { grid-template-columns: 1fr; } }
.price { padding: 28px; display: flex; flex-direction: column; gap: 16px; }
.probtag { align-self: flex-start; }
.pnum { font-weight: 800; font-size: 34px; letter-spacing: -0.02em; }
.pnum-sub { font-size: 16px; font-weight: 500; color: var(--ink2); }
.pfeat { color: var(--ink2); font-size: 15.5px; margin: 0; padding: 0; list-style: none; }
.pfeat li { padding: 5px 0; border-bottom: 1px solid var(--hair); }
.pfeat li:last-child { border-bottom: none; }

/* FAQ */
.faq { max-width: 720px; width: 100%; }
.faqitem { border-bottom: 1px solid var(--hair); }
.faqbtn { width: 100%; background: none; border: none; font-family: 'Hanken Grotesk', sans-serif; font-weight: 600; font-size: 17px; color: var(--ink); text-align: left; padding: 18px 0; cursor: pointer; display: flex; justify-content: space-between; align-items: center; gap: 16px; }
.faqa { color: var(--ink2); margin: 0 0 18px; font-size: 16px; max-width: 38em; }
.plus { color: var(--ink3); font-size: 20px; font-weight: 400; flex-shrink: 0; }

/* Footer */
.foot { border-top: 1px solid var(--hair); padding: 36px 0; color: var(--ink3); font-size: 14px; }
.footer-top { display: flex; align-items: center; justify-content: space-between; flex-wrap: wrap; gap: 16px; }
.footer-nav { display: flex; gap: 24px; flex-wrap: wrap; }
.foot a, .footer-link { color: var(--ink2); text-decoration: none; }
.foot a:hover, .footer-link:hover { color: var(--brand); }
.footer-link { background: none; border: none; font: inherit; cursor: pointer; padding: 0; }
.footer-panel { padding-top: 24px; margin-top: 20px; border-top: 1px solid var(--hair); }
.footer-panel-title { font-family: 'Hanken Grotesk', sans-serif; font-weight: 700; font-size: 17px; color: var(--ink); margin: 0 0 10px; }
.footer-panel-text { color: var(--ink2); font-size: 14.5px; line-height: 1.6; max-width: 46em; margin: 0; }
