/* ============================================================
   HouseHum — design world
   Dials: terracotta/clay + cream + deep walnut · serif display +
   humanist sans body · "hum" sound-wave motif · generous radii ·
   slow-warm motion · ambient wash = late-afternoon window light.
   No emoji in chrome — hand-drawn SVG icons only.
   ============================================================ */

:root {
  /* Palette calibrated to HouseHum_Hero_Assets_v1 brand style guide (canon):
     Clay #C7664D · Terracotta #E07A5F · Cream #FBF6EF · Walnut #3B2B23 ·
     Sage #6D8F7A · Moss #A7B99A · Slate #425466 · Gold #D8B26E */
  --clay: #C7664D;
  --terracotta: #E07A5F;
  --clay-deep: #9F523E;   /* darkened kit clay — keeps AA on cream for buttons/links */
  --clay-tint: #F6DED4;
  --cream: #FBF6EF;
  --cream-bright: #FFFCF7;
  --sand: #ECDFCB;
  --walnut: #3B2B23;
  --walnut-soft: #6B5347;
  --gold: #D8B26E;
  --glow: #E8CB93;
  --sage: #6D8F7A;
  --moss: #6D8F7A;        /* kit Sage — done-state green */
  --moss-tint: #E6ECE2;   /* tint of kit Moss #A7B99A */
  --slate: #425466;
  --danger: #A8402F;
  --card: #FFFDF8;
  --line: #EADFCE;
  --radius: 20px;
  --radius-sm: 14px;
  --shadow: 0 10px 30px -18px rgba(59, 43, 35, 0.45);
  --ease: cubic-bezier(0.25, 0.8, 0.35, 1);
  --tempo: 340ms;
  /* Kit typography: Playfair Display (display) + Inter (body), with warm local fallbacks
     (zero-build + CSP font-src 'self' — no webfont requests; kit faces render when installed) */
  --font-display: "Playfair Display", "Iowan Old Style", "Palatino Linotype", Palatino, "Book Antiqua", Georgia, serif;
  --font-body: Inter, Seravek, "Avenir Next", Avenir, "Segoe UI", "Trebuchet MS", Verdana, sans-serif;
  /* late-afternoon window light — applied directly on shells, never a z-index -1 ::before */
  --ambient:
    linear-gradient(112deg, rgba(216, 178, 110, 0.18) 0%, rgba(216, 178, 110, 0) 34%),
    linear-gradient(292deg, rgba(199, 102, 77, 0.08) 0%, rgba(199, 102, 77, 0) 46%),
    radial-gradient(1200px 500px at 85% -5%, rgba(248, 230, 196, 0.55), rgba(248, 230, 196, 0) 60%),
    linear-gradient(#FBF6EF, #F4EADA);
}

* { box-sizing: border-box; }
[hidden] { display: none !important; }
html { -webkit-text-size-adjust: 100%; }
body {
  margin: 0;
  font-family: var(--font-body);
  color: var(--walnut);
  background: var(--cream);
  line-height: 1.55;
  font-size: 16px;
}
h1, h2, h3, .lock-title { font-family: var(--font-display); font-weight: 700; line-height: 1.15; margin: 0 0 10px; }
p { margin: 0 0 12px; }
a { color: var(--clay-deep); }
img { max-width: 100%; }
button { font-family: inherit; }

/* accessibility floor */
.skip { position: absolute; left: -999px; top: 0; background: var(--walnut); color: var(--cream-bright); padding: 10px 16px; border-radius: 0 0 12px 0; z-index: 100; }
.skip:focus { left: 0; }
.visually-hidden { position: absolute; width: 1px; height: 1px; overflow: hidden; clip: rect(0 0 0 0); white-space: nowrap; }
:focus-visible { outline: 3px solid var(--clay); outline-offset: 2px; border-radius: 6px; }
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after { animation-duration: 0.01ms !important; animation-iteration-count: 1 !important; transition-duration: 0.01ms !important; }
}

/* ---------- buttons ---------- */
.btn {
  display: inline-flex; align-items: center; justify-content: center; gap: 8px;
  border: none; cursor: pointer; text-decoration: none;
  background: var(--clay-deep); color: var(--cream-bright);
  font-weight: 700; font-size: 15px;
  padding: 11px 20px; border-radius: var(--radius-sm);
  transition: transform var(--tempo) var(--ease), box-shadow var(--tempo) var(--ease), background var(--tempo) var(--ease);
}
.btn:hover { transform: translateY(-1px); box-shadow: var(--shadow); }
.btn:active { transform: translateY(0); }
.btn-primary { background: var(--clay-deep); }
.btn-soft { background: var(--clay-tint); color: var(--clay-deep); }
.btn-ghost { background: transparent; color: var(--clay-deep); border: 2px solid var(--clay); }
.btn-quiet { background: transparent; color: var(--walnut-soft); font-weight: 600; }
.btn-lg { padding: 14px 26px; font-size: 17px; border-radius: 16px; }
.btn-sm { padding: 7px 12px; font-size: 13px; }
.btn-block { display: flex; width: 100%; }
.btn[disabled] { opacity: 0.5; cursor: not-allowed; }

.chip { display: inline-flex; align-items: center; padding: 3px 10px; border-radius: 999px; font-size: 12px; font-weight: 700; }
.chip-preview { background: var(--gold); color: var(--walnut); }

/* ============================================================
   LANDING
   ============================================================ */
#landing { background: var(--ambient); min-height: 100vh; }
.l-top { display: flex; align-items: center; justify-content: space-between; gap: 12px; padding: 18px clamp(16px, 5vw, 56px); }
.l-brand { display: flex; align-items: center; gap: 10px; }
.l-name { font-family: var(--font-display); font-size: 24px; font-weight: 700; }

.hero { display: flex; align-items: center; gap: 32px; padding: clamp(24px, 6vw, 72px) clamp(16px, 5vw, 56px); max-width: 1080px; margin: 0 auto; }
.hero-copy { flex: 1.4; }
.hero h1 { font-size: clamp(34px, 5.5vw, 56px); }
.hero h1 em { color: var(--clay-deep); font-style: italic; }
.hero-sub { font-size: clamp(16px, 2vw, 19px); color: var(--walnut-soft); max-width: 56ch; }
.hero-cta { display: flex; flex-wrap: wrap; gap: 12px; margin: 20px 0 10px; }
.hero-note { font-size: 14px; color: var(--walnut-soft); }
.hero-kick { font-size: 13px; font-weight: 800; letter-spacing: 0.14em; text-transform: uppercase; color: var(--slate); margin-bottom: 10px; }
.hero-art { flex: 1.15; display: flex; justify-content: center; min-width: 0; }
.hero-photo { width: 100%; height: auto; border-radius: var(--radius); box-shadow: 0 22px 44px -20px rgba(59, 43, 35, 0.5); border: 1px solid var(--line); animation: hum-bob 7s var(--ease) infinite alternate; }
@keyframes hum-bob { from { transform: translateY(0); } to { transform: translateY(-8px); } }
@media (max-width: 720px) { .hero { flex-direction: column-reverse; text-align: center; } .hero-cta { justify-content: center; } }
.l-photo { margin: 26px 0 0; }
.l-photo img { width: 100%; height: auto; border-radius: var(--radius); box-shadow: var(--shadow); border: 1px solid var(--line); }
.l-photo figcaption { font-size: 13px; color: var(--walnut-soft); margin-top: 8px; text-align: center; }

.hum-divider { color: var(--clay); opacity: 0.5; max-width: 720px; margin: 0 auto; padding: 0 24px; }
.hum-divider svg { width: 100%; height: 28px; display: block; }

.l-section { max-width: 920px; margin: 0 auto; padding: clamp(32px, 6vw, 64px) clamp(16px, 5vw, 40px); }
.l-section h2 { font-size: clamp(26px, 3.6vw, 36px); }
.l-lead { color: var(--walnut-soft); font-size: 17px; max-width: 68ch; }
.l-note { font-size: 14px; color: var(--walnut-soft); }
.l-alt { background: var(--cream-bright); border-radius: var(--radius); box-shadow: var(--shadow); margin: 24px auto; }
.l-cta { text-align: center; display: flex; flex-direction: column; align-items: center; gap: 8px; }

.feat-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(240px, 1fr)); gap: 18px; margin-top: 24px; }
.feat { background: var(--card); border: 1px solid var(--line); border-radius: var(--radius); padding: 22px; box-shadow: var(--shadow); }
.feat h3 { font-size: 20px; margin-top: 10px; }
.feat p { color: var(--walnut-soft); font-size: 15px; margin: 0; }
.feat-icon svg, .ti svg { display: block; }
.feat-icon { width: 44px; height: 44px; color: var(--clay-deep); }

.steps { list-style: none; margin: 24px 0 0; padding: 0; display: grid; gap: 16px; }
.steps li { display: flex; gap: 16px; align-items: flex-start; }
.step-n { flex: none; width: 40px; height: 40px; border-radius: 999px; background: var(--clay); color: var(--cream-bright); font-weight: 800; display: flex; align-items: center; justify-content: center; font-size: 18px; }
.steps h3 { margin-bottom: 2px; font-size: 19px; }
.steps p { color: var(--walnut-soft); margin: 0; }

.kb-stats { display: flex; flex-wrap: wrap; gap: 10px; margin: 18px 0 10px; }
.kb-stat { background: var(--card); border: 1px solid var(--line); border-radius: var(--radius-sm); padding: 10px 16px; text-align: center; }
.kb-stat b { display: block; font-size: 22px; font-family: var(--font-display); color: var(--clay-deep); }
.kb-stat span { font-size: 12.5px; color: var(--walnut-soft); }

.price-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(240px, 1fr)); gap: 18px; margin: 24px 0 12px; }
.price { background: var(--card); border: 1px solid var(--line); border-radius: var(--radius); padding: 24px; box-shadow: var(--shadow); display: flex; flex-direction: column; }
.price.featured { border: 2px solid var(--clay); }
.price h3 { font-size: 21px; }
.price .amt { font-family: var(--font-display); font-size: 34px; color: var(--clay-deep); }
.price .cad { font-size: 13px; color: var(--walnut-soft); margin-bottom: 12px; }
.price ul { margin: 0 0 16px; padding-left: 18px; color: var(--walnut-soft); font-size: 14.5px; flex: 1; }
.price li { margin-bottom: 6px; }

.trust-chips { list-style: none; display: flex; flex-wrap: wrap; gap: 8px; padding: 0; margin: 4px 0 12px; }
.trust-chips li { display: inline-flex; align-items: center; gap: 7px; background: var(--cream-bright); border: 1px solid var(--line); border-radius: 999px; padding: 6px 13px; font-size: 13.5px; font-weight: 700; color: var(--walnut-soft); }
.trust-chips svg { color: var(--clay-deep); flex: none; }
@media (max-width: 720px) { .trust-chips { justify-content: center; } }

.faq { display: grid; gap: 10px; margin-top: 22px; }
.faq details { background: var(--card); border: 1px solid var(--line); border-radius: var(--radius-sm); box-shadow: var(--shadow); overflow: hidden; }
.faq summary { cursor: pointer; font-weight: 700; font-size: 16px; padding: 15px 18px; list-style: none; display: flex; align-items: center; justify-content: space-between; gap: 12px; }
.faq summary::-webkit-details-marker { display: none; }
.faq summary::after { content: "+"; font-family: var(--font-display); font-size: 24px; line-height: 1; color: var(--clay-deep); flex: none; }
.faq details[open] summary::after { content: "\2013"; }
.faq details p { color: var(--walnut-soft); font-size: 15px; margin: 0; padding: 0 18px 16px; }

.l-foot { text-align: center; padding: 28px 16px 44px; color: var(--walnut-soft); }
.l-fine { font-size: 12.5px; max-width: 60ch; margin: 6px auto 0; }

/* ============================================================
   LOCK WALL
   ============================================================ */
.lockwall { position: fixed; inset: 0; background: var(--ambient); display: flex; align-items: center; justify-content: center; padding: 20px; z-index: 50; }
.lockcard { background: var(--card); border-radius: var(--radius); box-shadow: var(--shadow); padding: 36px 28px; max-width: 380px; width: 100%; text-align: center; }
.lock-title { font-size: 30px; }
.lock-sub { color: var(--walnut-soft); font-size: 15px; }
.lockcard input { width: 100%; padding: 12px 14px; font-size: 16px; border: 2px solid var(--line); border-radius: var(--radius-sm); margin-bottom: 10px; background: var(--cream-bright); color: var(--walnut); }
.lock-err { color: var(--danger); font-size: 14px; font-weight: 700; }

/* ============================================================
   APP SHELL
   ============================================================ */
.app { min-height: 100vh; display: flex; flex-direction: column; background: var(--ambient); background-attachment: fixed; }
.topbar { display: flex; align-items: center; justify-content: space-between; padding: 12px clamp(14px, 4vw, 28px); position: sticky; top: 0; z-index: 20; background: rgba(250, 243, 231, 0.9); backdrop-filter: blur(8px); border-bottom: 1px solid var(--line); }
.topbar-brand { display: flex; align-items: center; gap: 9px; background: none; border: none; cursor: pointer; font-family: var(--font-display); font-size: 20px; font-weight: 700; color: var(--walnut); }
.topbar-menu { background: none; border: none; cursor: pointer; color: var(--walnut); padding: 8px; border-radius: 10px; }
.menu { position: fixed; top: 58px; right: 12px; z-index: 30; background: var(--card); border: 1px solid var(--line); border-radius: var(--radius-sm); box-shadow: var(--shadow); display: flex; flex-direction: column; min-width: 220px; overflow: hidden; }
.menu button, .menu a { text-align: left; padding: 13px 18px; background: none; border: none; border-bottom: 1px solid var(--line); font-size: 15px; color: var(--walnut); cursor: pointer; text-decoration: none; }
.menu :last-child { border-bottom: none; }
.menu button:hover, .menu a:hover { background: var(--clay-tint); }

.screen { flex: 1; width: 100%; max-width: 640px; margin: 0 auto; padding: 18px clamp(14px, 4vw, 24px) 110px; }
.tabbar { position: fixed; bottom: 0; left: 0; right: 0; z-index: 20; display: flex; justify-content: space-around; background: rgba(255, 253, 247, 0.96); backdrop-filter: blur(8px); border-top: 1px solid var(--line); padding: 6px 4px calc(8px + env(safe-area-inset-bottom)); }
.tab { flex: 1; max-width: 128px; display: flex; flex-direction: column; align-items: center; gap: 2px; background: none; border: none; cursor: pointer; font-size: 11.5px; font-weight: 700; color: var(--walnut-soft); padding: 6px 2px; border-radius: 12px; transition: color var(--tempo) var(--ease); }
.tab .ti { width: 24px; height: 24px; color: currentColor; }
.tab.active { color: var(--clay-deep); }

/* ---------- shared app pieces ---------- */
.card { background: var(--card); border: 1px solid var(--line); border-radius: var(--radius); padding: 18px; box-shadow: var(--shadow); margin-bottom: 14px; }
.card h3 { font-size: 19px; }
.section-label { font-size: 12.5px; font-weight: 800; letter-spacing: 0.08em; text-transform: uppercase; color: var(--walnut-soft); margin: 18px 0 8px; }
.muted { color: var(--walnut-soft); }
.note { font-size: 13.5px; color: var(--walnut-soft); }
.center { text-align: center; }
.row { display: flex; align-items: center; gap: 12px; }
.spacer { flex: 1; }
.stack { display: flex; flex-direction: column; gap: 10px; }

.field { margin-bottom: 12px; }
.field label { display: block; font-size: 13.5px; font-weight: 700; margin-bottom: 5px; color: var(--walnut); }
.field input, .field select, .field textarea {
  width: 100%; padding: 11px 12px; font-size: 15px; font-family: inherit;
  border: 2px solid var(--line); border-radius: var(--radius-sm);
  background: var(--cream-bright); color: var(--walnut);
}
.field input:focus, .field select:focus, .field textarea:focus { border-color: var(--clay); outline: none; }

/* grade + tier badges */
.badge { display: inline-flex; align-items: center; justify-content: center; min-width: 22px; height: 22px; padding: 0 7px; border-radius: 8px; font-size: 12px; font-weight: 800; }
.badge-A { background: var(--moss-tint); color: #435231; }
.badge-B { background: #EDE3C8; color: #6d5716; }
.badge-C { background: var(--clay-tint); color: var(--clay-deep); }
.badge-D { background: #EFE0DC; color: var(--danger); }
.badge-domain { background: var(--sand); color: var(--walnut); font-weight: 700; border-radius: 999px; height: auto; padding: 3px 10px; }

/* hero greeting + hum meter */
.hero-app { background: linear-gradient(120deg, var(--clay-tint), var(--cream-bright) 70%); border: 1px solid var(--line); border-radius: var(--radius); padding: 20px; margin-bottom: 14px; }
.hero-app h2 { font-size: 24px; margin-bottom: 4px; }
.hummeter { display: flex; align-items: center; gap: 16px; }
.humwave { flex: none; }
.humwave .bar { fill: var(--clay); }
.humwave .bar.dim { fill: var(--sand); }
.hummeter .hm-label { font-weight: 800; font-size: 17px; font-family: var(--font-display); }
.hummeter .hm-line { font-size: 13.5px; color: var(--walnut-soft); }
.hm-score { font-family: var(--font-display); font-size: 30px; color: var(--clay-deep); font-weight: 700; }

/* task rows */
.task { display: flex; gap: 12px; align-items: flex-start; background: var(--card); border: 1px solid var(--line); border-radius: var(--radius); padding: 14px 16px; margin-bottom: 10px; transition: opacity var(--tempo) var(--ease); }
.task.done { opacity: 0.62; }
.task .check { flex: none; width: 28px; height: 28px; margin-top: 2px; border-radius: 10px; border: 2.5px solid var(--clay); background: var(--cream-bright); cursor: pointer; color: var(--cream-bright); display: flex; align-items: center; justify-content: center; transition: background var(--tempo) var(--ease); }
.task .check.on { background: var(--moss); border-color: var(--moss); }
.task .tt { font-weight: 700; }
.task.done .tt { text-decoration: line-through; text-decoration-thickness: 1.5px; }
.task .tmeta { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 5px; align-items: center; }
.pill { display: inline-flex; align-items: center; gap: 4px; background: var(--cream); border: 1px solid var(--line); border-radius: 999px; padding: 2px 9px; font-size: 12px; font-weight: 700; color: var(--walnut-soft); }
.twhy { font-size: 13px; color: var(--walnut-soft); margin-top: 4px; }

/* systems */
.sys-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; }
@media (max-width: 420px) { .sys-grid { grid-template-columns: 1fr; } }
.sys { text-align: left; background: var(--card); border: 1px solid var(--line); border-radius: var(--radius); padding: 14px; cursor: pointer; transition: transform var(--tempo) var(--ease), box-shadow var(--tempo) var(--ease); }
.sys:hover { transform: translateY(-2px); box-shadow: var(--shadow); }
.sys .si { width: 30px; height: 30px; color: var(--clay-deep); margin-bottom: 6px; }
.sys .sn { font-weight: 800; }
.sys .sd { font-size: 12.5px; color: var(--walnut-soft); margin-top: 2px; }
.spec { display: flex; justify-content: space-between; gap: 10px; font-size: 14px; padding: 6px 0; border-bottom: 1px dashed var(--line); }
.spec b { font-weight: 700; }
.spec:last-child { border-bottom: none; }
.agebar { height: 8px; border-radius: 999px; background: var(--sand); overflow: hidden; margin-top: 6px; }
.agebar i { display: block; height: 100%; border-radius: 999px; background: var(--clay); }

/* opt rows (onboarding + pickers) */
.opt { display: flex; align-items: center; gap: 12px; width: 100%; text-align: left; background: var(--card); border: 2px solid var(--line); border-radius: var(--radius-sm); padding: 13px 14px; cursor: pointer; transition: border-color var(--tempo) var(--ease); }
.opt:hover { border-color: var(--clay); }
.opt.sel { border-color: var(--clay-deep); background: var(--clay-tint); }
.opt .on { font-weight: 800; }
.opt .oh { font-size: 13px; color: var(--walnut-soft); }

/* log timeline */
.logrow { display: flex; gap: 12px; background: var(--card); border: 1px solid var(--line); border-radius: var(--radius); padding: 13px 15px; margin-bottom: 10px; }
.logdot { flex: none; width: 12px; height: 12px; border-radius: 999px; background: var(--clay); margin-top: 6px; }
.logrow .lt { font-weight: 800; }
.logrow .ld { font-size: 13px; color: var(--walnut-soft); }

/* coach chat */
.chat { display: flex; flex-direction: column; gap: 10px; margin: 12px 0; }
.bubble { max-width: 88%; padding: 12px 15px; border-radius: var(--radius); font-size: 15px; }
.bubble.me { align-self: flex-end; background: var(--clay-deep); color: var(--cream-bright); border-bottom-right-radius: 6px; }
.bubble.coach { align-self: flex-start; background: var(--card); border: 1px solid var(--line); border-bottom-left-radius: 6px; }
.bubble .src { display: block; margin-top: 8px; font-size: 12.5px; color: var(--walnut-soft); border-top: 1px dashed var(--line); padding-top: 7px; }
.safetybox { background: #F7E5DE; border: 2px solid var(--danger); border-radius: var(--radius); padding: 14px 16px; font-size: 15px; }
.boundarybox { background: var(--sand); border-radius: var(--radius); padding: 13px 15px; font-size: 14.5px; }
.coachbar { display: flex; gap: 8px; position: sticky; bottom: 96px; }
.coachbar input { flex: 1; padding: 12px 14px; font-size: 15px; border: 2px solid var(--line); border-radius: 999px; background: var(--card); color: var(--walnut); }
.coachbar .send { flex: none; width: 46px; height: 46px; border-radius: 999px; border: none; background: var(--clay-deep); color: var(--cream-bright); cursor: pointer; display: flex; align-items: center; justify-content: center; }
.chips { display: flex; flex-wrap: wrap; gap: 8px; margin: 10px 0; }
.chipbtn { background: var(--card); border: 1.5px solid var(--line); border-radius: 999px; padding: 7px 13px; font-size: 13px; cursor: pointer; color: var(--walnut); font-weight: 600; }
.chipbtn:hover, .chipbtn.active { border-color: var(--clay-deep); color: var(--clay-deep); }

/* learn / kb browser */
.kbcard { background: var(--card); border: 1px solid var(--line); border-radius: var(--radius); padding: 15px 17px; margin-bottom: 10px; }
.kbcard .kbt { font-weight: 800; margin-bottom: 4px; }
.kbcard .kbc { font-size: 14.5px; color: var(--walnut-soft); }
.kbcard .kbm { display: flex; flex-wrap: wrap; gap: 7px; margin-top: 9px; align-items: center; }
.search { width: 100%; padding: 11px 14px; font-size: 15px; border: 2px solid var(--line); border-radius: 999px; background: var(--card); color: var(--walnut); margin-bottom: 10px; }
.empty { text-align: center; color: var(--walnut-soft); padding: 26px 10px; }

/* onboarding overlay */
.ob { position: fixed; inset: 0; z-index: 40; background: var(--ambient); overflow-y: auto; padding: 26px 18px 40px; }
.ob-body { max-width: 480px; margin: 0 auto; }
.ob-prog { display: flex; gap: 6px; justify-content: center; margin-bottom: 24px; }
.ob-prog i { width: 34px; height: 6px; border-radius: 999px; background: var(--sand); }
.ob-prog i.on { background: var(--clay); }
.ob h2 { font-size: 27px; }
.ob .lead { color: var(--walnut-soft); font-size: 16px; }
.ob-foot { display: flex; gap: 10px; margin-top: 20px; }

/* celebration — the hum pulse */
.celebrate { position: fixed; inset: 0; z-index: 60; pointer-events: none; display: flex; align-items: center; justify-content: center; }
.confetti { position: absolute; top: -12px; width: 9px; height: 13px; border-radius: 3px; animation: fall linear forwards; }
@keyframes fall { to { transform: translateY(105vh) rotate(340deg); } }
.pop { background: var(--card); border-radius: var(--radius); box-shadow: var(--shadow); padding: 22px 30px; text-align: center; animation: pop-in 380ms var(--ease); }
@keyframes pop-in { from { transform: scale(0.85); opacity: 0; } to { transform: scale(1); opacity: 1; } }
.pop .ctext { font-weight: 800; font-family: var(--font-display); font-size: 18px; margin-top: 8px; }
.humring { width: 54px; height: 54px; margin: 0 auto; color: var(--clay); animation: hum-ring 900ms var(--ease); }
@keyframes hum-ring { from { transform: scale(0.6); opacity: 0.4; } 60% { transform: scale(1.12); } to { transform: scale(1); opacity: 1; } }

/* modal */
.modal { position: fixed; inset: 0; z-index: 55; display: flex; align-items: flex-end; justify-content: center; }
@media (min-width: 560px) { .modal { align-items: center; } }
.modal-backdrop { position: absolute; inset: 0; background: rgba(62, 44, 34, 0.45); }
.modal-card { position: relative; background: var(--cream-bright); border-radius: var(--radius) var(--radius) 0 0; padding: 24px 20px 30px; width: 100%; max-width: 560px; max-height: 86vh; overflow-y: auto; }
@media (min-width: 560px) { .modal-card { border-radius: var(--radius); } }
.modal-close { position: absolute; top: 12px; right: 12px; width: 34px; height: 34px; border-radius: 999px; border: none; background: var(--sand); color: var(--walnut); font-size: 16px; font-weight: 800; cursor: pointer; }

/* ---------- A4T audience layer: founder note, capture, cross-sell ---------- */
.privacy-badge { display: inline-flex; align-items: center; gap: 7px; margin-top: 14px; padding: 7px 13px; border-radius: 999px; background: var(--clay-tint); color: var(--clay-deep); font-size: 13px; font-weight: 700; }
.privacy-badge svg { color: var(--clay-deep); }

.founder .founder-card { max-width: 640px; margin: 0 auto; background: var(--cream-bright); border: 1px solid var(--line); border-left: 4px solid var(--clay); border-radius: var(--radius); box-shadow: var(--shadow); padding: 26px 28px; }
.founder .founder-card h2 { margin-top: 0; }
.founder .founder-card p { color: var(--walnut-soft); font-size: 16px; line-height: 1.6; margin: 0 0 12px; }
.founder .founder-card em { color: var(--clay-deep); font-style: italic; }
.founder-sign { font-family: var(--font-display); font-style: italic; color: var(--walnut) !important; }

.capture .capture-form { max-width: 640px; margin: 18px auto 0; text-align: left; }
.capture .cap-row { display: grid; grid-template-columns: repeat(3, 1fr); gap: 12px; }
@media (max-width: 560px) { .capture .cap-row { grid-template-columns: 1fr; } }
.cap-preview { background: var(--sand); border-radius: var(--radius-sm); padding: 14px 16px; margin: 4px 0 14px; }
.cap-preview-label { margin: 0 0 6px; font-weight: 800; font-size: 14px; color: var(--walnut); }
.cap-preview ul { margin: 0; padding-left: 20px; color: var(--walnut-soft); font-size: 14.5px; }
.cap-preview li { margin-bottom: 4px; }
.consent { border: 0; padding: 0; margin: 4px 0 14px; }
.consent-row { display: flex; gap: 10px; align-items: flex-start; font-size: 14px; color: var(--walnut-soft); margin-bottom: 9px; line-height: 1.45; cursor: pointer; }
.consent-row input { width: auto; margin-top: 3px; flex: none; accent-color: var(--clay-deep); }
.capture .btn-lg { width: 100%; }
.cap-fine { font-size: 12.5px; color: var(--walnut-soft); margin: 10px 0 0; }
.cap-status { font-size: 14px; margin: 10px 0 0; min-height: 1px; }
.cap-status.ok { color: #435231; font-weight: 700; }
.cap-status.err { color: var(--danger); font-weight: 700; }

.crosssell-mount { max-width: 640px; margin: 0 auto 24px; }
.a4t-crosssell { text-align: left; }
.a4t-crosssell__label { font-size: 12.5px; font-weight: 800; letter-spacing: 0.04em; text-transform: uppercase; color: var(--walnut-soft); margin: 0 0 10px; text-align: center; }
.a4t-crosssell__card { display: block; text-decoration: none; background: var(--cream-bright); border: 1px solid var(--line); border-radius: var(--radius-sm); padding: 14px 16px; margin-bottom: 10px; transition: border-color var(--tempo) var(--ease), transform var(--tempo) var(--ease); }
.a4t-crosssell__card:hover { border-color: var(--clay); transform: translateY(-1px); }
.a4t-crosssell__name { display: block; font-family: var(--font-display); font-weight: 700; font-size: 17px; color: var(--clay-deep); }
.a4t-crosssell__tag { display: block; font-size: 13.5px; color: var(--walnut-soft); margin-top: 2px; }

/* ---------- print: only the home record sheet ---------- */
.printsheet { display: none; }
@media print {
  body > * { display: none !important; }
  body { background: #fff; color: #000; }
  .printsheet { display: block !important; font-family: Georgia, serif; padding: 0; }
  .printsheet h1 { font-size: 24pt; margin-bottom: 2pt; }
  .printsheet h2 { font-size: 14pt; border-bottom: 1.5pt solid #000; padding-bottom: 3pt; margin: 18pt 0 8pt; }
  .printsheet table { width: 100%; border-collapse: collapse; font-size: 10.5pt; }
  .printsheet th, .printsheet td { text-align: left; padding: 4pt 6pt; border-bottom: 0.5pt solid #999; vertical-align: top; }
  .printsheet .ps-meta { color: #444; font-size: 10pt; }
}
