:root{
  --cream:#F6F4EC; --card:#FBFAF5; --ink:#1F2B31; --gold:#A8842B; --gold-deep:#7A611C;
  --grey:#6C7278; --line:#E4E0D6; --maxw:680px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0; background:var(--cream); color:var(--ink);
  font-family:'Inter',system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  font-size:1.0625rem; line-height:1.7; -webkit-font-smoothing:antialiased;
}
h1,h2,h3,.ser{font-family:'Fraunces',Georgia,'Times New Roman',serif;}
p{margin:0 0 1rem}
a{color:var(--ink); text-decoration:underline; text-underline-offset:2px; text-decoration-color:var(--gold);}
a:hover{color:var(--gold-deep);}
img,svg{display:block}

.wrap{max-width:var(--maxw); margin:0 auto; padding:0 24px;}
main{display:block}
.section{padding:56px 0; border-top:1px solid var(--line);}
.eyebrow{font-size:.8rem; letter-spacing:.09em; color:var(--grey); margin:0 0 12px;}
h1{font-size:clamp(2.1rem,5.2vw,3.25rem); font-weight:600; line-height:1.12; letter-spacing:-.01em; margin:0 0 18px;}
h1 em{font-style:italic; color:var(--ink);}
h2{font-size:clamp(1.45rem,3.4vw,2rem); font-weight:600; line-height:1.2; margin:0 0 14px;}
.lead{font-size:1.15rem; color:var(--ink);}
.muted{color:var(--grey);}

/* header */
.site-head{padding:22px 0;}
.logo{display:inline-flex; align-items:center; gap:12px; text-decoration:none; color:var(--ink);}
.logo:hover{color:var(--ink);}
.logo .wm{font-family:'Fraunces',serif; font-weight:600; font-size:1.5rem; letter-spacing:-.01em;}

/* hero */
.hero{padding:60px 0 52px;}
.tag{color:var(--gold-deep); font-weight:600; font-size:.95rem; letter-spacing:.02em; margin:0 0 16px;}

/* signup */
.signup{margin-top:28px; background:var(--card); border:1px solid var(--line); border-radius:14px; padding:24px;}
.signup h3{font-family:'Inter',sans-serif; font-size:1.05rem; font-weight:600; margin:0 0 6px;}
.signup p{color:var(--grey); font-size:.98rem; margin:0 0 16px;}
.field{display:flex; flex-direction:column; gap:6px; margin-bottom:14px;}
.field label{font-size:.85rem; color:var(--grey);}
.field input[type=email]{font:inherit; padding:13px 14px; border:1px solid var(--line); border-radius:10px; background:#fff; color:var(--ink);}
.field input[type=email]:focus{outline:2px solid var(--gold); outline-offset:1px; border-color:var(--gold);}
.consent{display:flex; gap:10px; align-items:flex-start; font-size:.88rem; color:var(--grey); margin-bottom:16px;}
.consent input{margin-top:4px; flex:none;}
.btn{font:inherit; font-weight:600; cursor:pointer; background:var(--ink); color:var(--cream); border:0; border-radius:10px; padding:13px 24px;}
.btn:hover{background:#2b3a42;}
.btn:focus-visible{outline:2px solid var(--gold); outline-offset:2px;}
.formnote{font-size:.82rem; color:var(--grey); margin-top:12px;}

/* points */
.points{list-style:none; padding:0; margin:22px 0 0; display:grid; gap:20px;}
.points li{padding-left:26px; position:relative;}
.points li::before{content:""; position:absolute; left:2px; top:.62em; width:9px; height:9px; background:var(--gold); border-radius:2px; transform:rotate(45deg);}
.points b{font-weight:600;}

/* about signature */
.sign{margin-top:18px; color:var(--grey); font-size:.95rem;}
.sign b{color:var(--ink); font-weight:600;}

/* closing cta */
.cta-close{text-align:center;}
.cta-close .btn{margin-top:8px; text-decoration:none; display:inline-block;}

/* footer */
.site-foot{border-top:1px solid var(--line); padding:34px 0 46px; color:var(--grey); font-size:.9rem;}
.site-foot a{color:var(--grey); text-decoration-color:var(--line);}
.site-foot a:hover{color:var(--gold-deep);}
.foot-row{display:flex; flex-wrap:wrap; gap:12px 26px; align-items:center; justify-content:space-between;}

/* legal page */
.legal h2{font-size:1.25rem; margin:34px 0 10px;}
.legal .todo{background:#FBF3DE; border:1px solid #E7D5A6; color:#7A611C; border-radius:8px; padding:2px 8px; font-size:.82rem; font-weight:600;}
.legal .note{background:var(--card); border:1px solid var(--line); border-radius:12px; padding:16px 18px; font-size:.95rem; color:var(--grey);}

/* a11y helpers */
.skip{position:absolute; left:-999px;}
.skip:focus{left:16px; top:16px; background:var(--ink); color:var(--cream); padding:8px 14px; border-radius:8px; z-index:10;}

@media (max-width:520px){
  body{font-size:1rem}
  .section{padding:44px 0;}
  .hero{padding:44px 0;}
  .foot-row{gap:10px 20px;}
}
@media (prefers-reduced-motion:reduce){
  html{scroll-behavior:auto;}
  *{transition:none!important; animation:none!important;}
}
