:root{
  --linen:#F7F4EF; --cream:#FBF9F5; --ink:#2B2622; --cherry:#C8485B;
  --cherry-d:#A93645; --sage:#7C8C7A; --line:#E7E0D6; --muted:#8a8178;
}
*{box-sizing:border-box}
body{margin:0;background:var(--linen);color:var(--ink);
  font-family:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;line-height:1.55}
h1,h2,h3,h4,.serif{font-family:'Fraunces',Georgia,serif;font-weight:600;letter-spacing:-.01em}
a{color:var(--cherry-d);text-decoration:none}
a:hover{text-decoration:underline}
.muted{color:var(--muted)}
main{max-width:760px;margin:0 auto;padding:0 20px 60px}
em{font-style:italic;color:var(--cherry)}

/* top bar */
.topbar{display:flex;align-items:baseline;gap:12px;justify-content:center;padding:22px;border-bottom:1px solid var(--line);background:var(--cream)}
.brand{font-family:'Fraunces',serif;font-size:22px;font-weight:700;color:var(--cherry);text-decoration:none}
.brand-sub{color:var(--muted);font-size:14px;letter-spacing:.08em;text-transform:uppercase}

/* buttons */
.btn{display:inline-block;background:var(--cherry);color:#fff;border:none;border-radius:999px;
  padding:13px 26px;font-size:15px;font-weight:600;cursor:pointer;text-decoration:none;transition:.15s}
.btn:hover{background:var(--cherry-d);text-decoration:none}
.btn-lg{padding:16px 34px;font-size:17px}
.btn-sm{padding:9px 16px;font-size:13.5px}
.btn-secondary{background:#fff;color:var(--ink);border:1.5px solid var(--line)}
.btn-secondary:hover{background:var(--cream)}

/* flash */
.flash{margin:16px 0;padding:12px 16px;border-radius:12px;font-size:14.5px}
.flash-success{background:#eef5ee;color:#2f5d3a}
.flash-error{background:#fdecec;color:#9b2c2c}

/* hero */
.hero{display:grid;grid-template-columns:1.1fr .9fr;gap:36px;align-items:center;padding:48px 0}
.eyebrow{text-transform:uppercase;letter-spacing:.12em;font-size:13px;color:var(--sage);font-weight:600;margin:0 0 12px}
.hero h1{font-size:46px;line-height:1.08;margin:0 0 18px}
.lede{font-size:18px;color:#5b534b;margin:0 0 26px}
.microcopy{font-size:13px;color:var(--muted);margin-top:12px}
.hero-card .demo-card,.demo-card{background:var(--cream);border:1px solid var(--line);border-radius:22px;
  padding:30px;text-align:center;box-shadow:0 18px 40px -28px rgba(43,38,34,.5)}
.demo-eyebrow,.demo-brand{font-family:'Fraunces',serif;color:var(--sage);letter-spacing:.18em;font-size:13px;margin:0}
.demo-card h3{font-size:28px;margin:14px 0 4px}
.demo-sub{color:var(--cherry);font-style:italic;font-family:'Fraunces',serif;margin:0 0 16px}
.demo-count{margin:14px 0 18px;color:var(--ink)}

/* progress bar */
.bar{background:#EAE3D8;border-radius:999px;overflow:hidden;height:14px;width:100%}
.bar span{display:block;height:100%;background:var(--cherry);border-radius:999px;transition:width .5s ease}
.bar-lg{height:22px}
.bar-sm{height:10px;margin:6px 0 14px}

/* features */
.features{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;padding:20px 0 10px}
.feature{background:var(--cream);border:1px solid var(--line);border-radius:18px;padding:24px}
.feature .fic{display:inline-grid;place-items:center;width:42px;height:42px;border-radius:12px;
  background:#f3e7e9;color:var(--cherry);font-size:20px;margin-bottom:12px}
.feature h4{margin:0 0 8px;font-size:18px}
.feature p{margin:0;font-size:14.5px;color:#5b534b}

.cta-band{text-align:center;background:var(--cream);border:1px solid var(--line);border-radius:24px;padding:40px;margin:40px 0}
.cta-band h2{font-size:30px;margin:0 0 16px}

/* forms */
.form-wrap{max-width:560px;margin:40px auto}
.form-title{font-size:34px;margin:0 0 8px}
.form-sub{color:#5b534b;margin:0 0 26px}
.card-form,.settings-card form{display:flex;flex-direction:column;gap:8px}
.card-form label,.settings-card label{font-weight:600;font-size:14.5px;margin-top:14px}
input[type=text],input[type=email],input[type=date],input[type=password],select{
  font:inherit;padding:12px 14px;border:1.5px solid var(--line);border-radius:12px;background:#fff;width:100%}
input:focus,select:focus{outline:none;border-color:var(--cherry)}
.seg-grid{display:grid;gap:10px;margin-top:6px}
.seg{display:flex;align-items:center;gap:12px;border:1.5px solid var(--line);border-radius:14px;padding:14px 16px;cursor:pointer;font-weight:500}
.seg:has(input:checked){border-color:var(--cherry);background:#fcf1f3}
.seg input{accent-color:var(--cherry)}
.card-form .btn{margin-top:20px}

/* progress hero (journey/share) */
.progress-hero{text-align:center;padding:40px 0 24px}
.big-pct{font-family:'Fraunces',serif;font-size:84px;font-weight:700;line-height:1;color:var(--cherry)}
.big-pct span{font-size:38px;color:var(--ink)}
.milestone-label{font-family:'Fraunces',serif;font-style:italic;font-size:24px;margin:6px 0 18px}
.count-line{color:#5b534b;margin:14px 0 0}
.share-row{display:flex;gap:10px;justify-content:center;flex-wrap:wrap;margin-top:22px}
.gift-chip{display:inline-flex;align-items:center;padding:8px 14px;background:#f3e7e9;border-radius:999px;font-size:13.5px;color:var(--cherry-d)}

.milestone-banner{background:#fcf1f3;border:1px solid #efd4d9;border-radius:16px;padding:16px 18px;margin:8px 0 24px;font-size:14.5px}
.milestone-banner a{font-weight:600;white-space:nowrap}

/* stages + checklist */
.stage{background:var(--cream);border:1px solid var(--line);border-radius:20px;padding:22px 24px;margin:18px 0}
.stage-head{display:flex;justify-content:space-between;align-items:flex-start}
.stage-head h2{margin:0;font-size:22px}
.stage-pct{font-family:'Fraunces',serif;font-weight:700;color:var(--sage)}
.checklist{list-style:none;margin:6px 0 0;padding:0}
.check-item{display:flex;gap:14px;padding:14px 0;border-top:1px solid var(--line)}
.check-item:first-child{border-top:none}
.check-btn{background:none;border:none;cursor:pointer;padding:0;margin-top:2px}
.box{display:grid;place-items:center;width:26px;height:26px;border:2px solid var(--cherry);border-radius:8px;color:#fff;font-size:15px;background:#fff;transition:.15s}
.is-done .box{background:var(--cherry)}
.is-done .check-title{text-decoration:line-through;color:var(--muted)}
.check-title{font-weight:600;font-size:15.5px;display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.check-desc{margin:4px 0 0;font-size:14px;color:#5b534b}
.badge-safe{font-size:11.5px;font-weight:600;color:#3f6f4a;background:#e8f2e9;border-radius:999px;padding:2px 9px;white-space:nowrap}
.shop-link{display:inline-block;margin-top:8px;font-weight:600;font-size:14px}

.kit-card{display:flex;justify-content:space-between;align-items:center;gap:16px;margin-top:16px;
  background:#fcf1f3;border:1px solid #efd4d9;border-radius:16px;padding:18px;text-decoration:none;color:var(--ink)}
.kit-card:hover{text-decoration:none;background:#fae9ec}
.kit-img{width:76px;height:76px;object-fit:cover;border-radius:12px;flex:0 0 auto;background:#fff}
.kit-text{flex:1}
.kit-eyebrow{display:block;font-size:12px;letter-spacing:.1em;text-transform:uppercase;color:var(--cherry);font-weight:600}
.kit-card strong{font-family:'Fraunces',serif;font-size:18px}
.kit-card p{margin:4px 0 0;font-size:14px;color:#5b534b}
.kit-price{font-family:'Fraunces',serif;font-weight:700;color:var(--cherry);white-space:nowrap}

/* settings */
.settings-card{background:var(--cream);border:1px solid var(--line);border-radius:20px;padding:22px 24px;margin:24px 0}
.inline-check{display:flex;align-items:center;gap:10px;font-weight:500;margin-top:14px}
.inline-check input{width:auto;accent-color:var(--cherry)}
.save-note{font-size:13px;margin-top:14px}

/* gifts */
.gift-section{margin:30px 0}
.gift-grid{display:grid;gap:14px}
.gift-item{background:var(--cream);border:1px solid var(--line);border-radius:16px;padding:18px}
.gift-info strong{font-size:16px}
.gift-price{font-family:'Fraunces',serif;font-weight:700;color:var(--cherry);margin-left:8px}
.gift-claim summary{display:inline-block;margin-top:12px;list-style:none}
.gift-claim summary::-webkit-details-marker{display:none}
.gift-claim form{display:flex;flex-direction:column;gap:8px;margin-top:12px}

/* share card page */
.card-preview img{width:100%;border-radius:18px;border:1px solid var(--line);box-shadow:0 18px 40px -28px rgba(43,38,34,.5)}
.share-buttons{display:flex;gap:10px;flex-wrap:wrap;justify-content:center;margin:22px 0}

/* admin */
.stat-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:12px;margin:20px 0}
.stat{background:var(--cream);border:1px solid var(--line);border-radius:14px;padding:16px;text-align:center;font-size:13px;color:var(--muted)}
.stat span{display:block;font-family:'Fraunces',serif;font-size:26px;font-weight:700;color:var(--ink)}
.admin-table{width:100%;border-collapse:collapse;background:#fff;border-radius:12px;overflow:hidden;font-size:14px}
.admin-table th{background:var(--ink);color:#fff;text-align:left;padding:10px 12px;font-weight:500}
.admin-table td{padding:10px 12px;border-bottom:1px solid var(--line)}

/* footer */
.footer{text-align:center;padding:36px 20px;border-top:1px solid var(--line);background:var(--cream);margin-top:40px}
.footer p{margin:4px 0;font-family:'Fraunces',serif;color:var(--sage);letter-spacing:.12em}
.footer .muted{font-family:'Inter',sans-serif;letter-spacing:0;font-size:13px}

@media(max-width:680px){
  .hero{grid-template-columns:1fr;gap:24px}.hero h1{font-size:36px}
  .features{grid-template-columns:1fr}.stat-grid{grid-template-columns:repeat(2,1fr)}
  .big-pct{font-size:66px}
}
