/* The Stitchmail — website styles. Clean black-and-white, editorial and soft. */
:root{
  --paper:#faf9f5;      /* soft warm white */
  --ink:#2b2723;        /* soft charcoal, not hard black */
  --soft:#4d4740;       /* body ink */
  --grey:#8a8377;       /* furniture / captions */
  --hair:#d9d4c8;       /* hairline rules */
  --faint:#e7e3d9;      /* very light dividers */
  --slip:#f2efe7;       /* boxed panels */
  --display:"Cormorant Garamond", Georgia, serif;
  --body:"EB Garamond", Georgia, serif;
  --label:"Jost", "Helvetica Neue", Arial, sans-serif;
}
*{box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{
  margin:0; background:var(--paper); color:var(--ink);
  font-family:var(--body); font-size:20px; line-height:1.7;
  -webkit-font-smoothing:antialiased;
}
em{font-style:italic;}
a{color:var(--ink); text-decoration:underline; text-underline-offset:3px; text-decoration-thickness:.5px; text-decoration-color:var(--hair);}
a:hover{text-decoration-color:var(--ink);}

/* ---- masthead ---- */
.masthead{max-width:1080px; margin:0 auto; padding:30px 28px 0;}
.masthead-rule{
  display:flex; align-items:center; justify-content:space-between; gap:16px;
  font-family:var(--label); font-weight:400; font-size:11px; letter-spacing:.28em;
  text-transform:uppercase; color:var(--grey);
  border-top:1px solid var(--hair); border-bottom:1px solid var(--hair);
  padding:9px 2px;
}
.masthead-rule-top{border-bottom:0;}
.masthead-rule-top span:nth-child(2){letter-spacing:.16em; color:var(--soft); font-style:normal;}
.masthead-rule-bottom{border-top:0;}
.masthead-mark{color:var(--ink); font-size:12px; letter-spacing:0;}
.nameplate{
  display:block; text-align:center; font-family:var(--display); font-weight:500;
  color:var(--ink); text-decoration:none; line-height:1;
  font-size:clamp(48px, 10vw, 96px); letter-spacing:.04em; padding:26px 0 22px;
}
.nameplate:hover{text-decoration:none;}
.site-nav{
  display:flex; justify-content:center; flex-wrap:wrap; gap:32px; padding:0;
}
.site-nav a{
  font-family:var(--label); font-weight:400; font-size:11.5px; letter-spacing:.22em;
  text-transform:uppercase; color:var(--soft); text-decoration:none;
}
.site-nav a:hover{color:var(--ink);}

/* ---- buttons ---- */
.btn{display:inline-block; font-family:var(--label); font-weight:400; font-size:12px;
  letter-spacing:.22em; text-transform:uppercase; padding:14px 30px; border:1px solid var(--ink);
  border-radius:0; transition:.2s; text-decoration:none;}
.btn:hover{text-decoration:none;}
.btn-solid{background:var(--ink); color:var(--paper);}
.btn-solid:hover{background:transparent; color:var(--ink);}
.btn-line{background:transparent; color:var(--ink);}
.btn-line:hover{background:var(--ink); color:var(--paper);}
.btn-disabled{opacity:.4; pointer-events:none;}

/* ---- hero ---- */
.hero{max-width:1000px; margin:0 auto; padding:60px 28px 48px; text-align:center;}
.kicker{font-family:var(--label); font-weight:400; font-size:11px; letter-spacing:.34em;
  text-transform:uppercase; color:var(--grey); margin:0 0 20px;}
.hero-title{font-family:var(--display); font-weight:500; margin:0; line-height:1.06;
  font-size:clamp(42px, 6.4vw, 78px); letter-spacing:.005em;}
.hero-tag{font-family:var(--display); font-style:italic; font-weight:500; font-size:23px;
  color:var(--grey); margin:14px 0 0; letter-spacing:.01em;}
.hero-lede{font-size:21px; line-height:1.7; max-width:46ch; margin:24px auto 34px; color:var(--soft);}
.hero-cta{display:flex; gap:16px; justify-content:center; flex-wrap:wrap;}

/* CSS cross-stitch chart standing in for a product photo */
.hero-chart{margin:56px auto 0; width:max-content; max-width:100%;}
.chart-grid{border:1px solid var(--hair); background:#fff; padding:14px;
  box-shadow:0 18px 40px rgba(43,39,35,.10);}
.chart-row{display:flex;}
.chart-row i{width:22px; height:22px; border:1px solid var(--faint); display:block; position:relative;}
.chart-row i.x::before{content:"\2715"; position:absolute; inset:0; display:flex;
  align-items:center; justify-content:center; font-size:15px; color:var(--ink); font-family:var(--body);}
.hero-chart figcaption{font-family:var(--label); font-weight:300; font-size:11px;
  letter-spacing:.24em; text-transform:uppercase; color:var(--grey); margin-top:18px;}

/* ---- section furniture ---- */
.section-title{font-family:var(--display); font-weight:500; font-size:clamp(30px,4vw,46px);
  text-align:center; margin:0; letter-spacing:.01em;}
.section-lede{text-align:center; max-width:52ch; margin:14px auto 34px; color:var(--soft); font-size:19px;}

/* ---- what / in the envelope ---- */
.what{max-width:1040px; margin:24px auto; padding:52px 28px;
  border-top:1px solid var(--hair); border-bottom:1px solid var(--hair);}
.what-grid{display:grid; grid-template-columns:repeat(3,1fr); gap:0; margin-top:10px;}
.what-cell{padding:8px 34px; border-left:1px solid var(--faint);}
.what-cell:first-child{border-left:0;}
.what-num{font-family:var(--display); font-style:italic; font-weight:500; font-size:34px;
  line-height:1; margin-bottom:10px; color:var(--grey);}
.what-cell h3{font-family:var(--display); font-weight:600; font-size:26px; margin:0 0 8px; letter-spacing:.01em;}
.what-cell p{font-size:17.5px; line-height:1.65; margin:0; color:var(--soft);}
.what-foot{text-align:center; font-style:italic; color:var(--grey); font-size:17px; margin:34px auto 0; max-width:58ch;}

/* ---- pricing (three plans) ---- */
.pricing{max-width:1000px; margin:0 auto; padding:60px 28px;}
.price-grid{display:grid; grid-template-columns:repeat(3,1fr); gap:22px; margin-top:10px;}
.price-card{background:transparent; border:1px solid var(--hair); padding:38px 28px;
  text-align:center; position:relative; transition:.2s;}
.price-card:hover{border-color:var(--ink);}
.price-feature{border:1px solid var(--ink); background:var(--slip);}
.price-flag{position:absolute; top:-11px; left:50%; transform:translateX(-50%);
  background:var(--paper); color:var(--soft); border:1px solid var(--hair);
  font-family:var(--label); font-weight:400; font-size:10px; letter-spacing:.24em;
  text-transform:uppercase; padding:5px 14px; white-space:nowrap;}
.price-name{font-family:var(--label); font-weight:400; font-size:13px; letter-spacing:.24em;
  text-transform:uppercase; margin:0 0 12px; color:var(--soft);}
.price-amt{font-family:var(--display); font-size:56px; font-weight:500; margin:6px 0; line-height:1;}
.price-blurb{font-size:16.5px; color:var(--soft); min-height:4.6em; margin:12px 0 26px;}
.price-how{text-align:center; font-size:16.5px; line-height:1.65; color:var(--soft); max-width:56ch; margin:30px auto 0;}
.price-fine{text-align:center; font-family:var(--label); font-size:11px; letter-spacing:.16em;
  text-transform:uppercase; color:var(--grey); margin-top:12px;}
.price-terms{text-align:center; font-size:15.5px; line-height:1.65; color:var(--grey);
  max-width:54ch; margin:10px auto 0; font-style:italic;}

/* ---- gift note (reverse block) ---- */
.gift-note{background:var(--ink); color:var(--paper); margin:24px auto; max-width:1040px;}
.gift-inner{max-width:640px; margin:0 auto; padding:64px 28px; text-align:center;}
.gift-mark{font-size:24px; line-height:1; color:#cfc8ba;}
.gift-note h2{font-family:var(--display); font-weight:500; font-size:38px; margin:14px 0 14px; letter-spacing:.01em;}
.gift-note p{color:#ddd8cb; max-width:46ch; margin:0 auto 28px; font-size:19px;}
.gift-note .btn-line{color:var(--paper); border-color:var(--paper);}
.gift-note .btn-line:hover{background:var(--paper); color:var(--ink);}

/* ---- faq ---- */
.faq{max-width:820px; margin:0 auto; padding:60px 28px 24px;}
.faq-list{margin-top:28px;}
.faq-item{padding:24px 0; border-top:1px solid var(--faint);}
.faq-item:last-child{border-bottom:1px solid var(--faint);}
.faq-item h3{font-family:var(--display); font-weight:600; font-size:24px; margin:0 0 8px; letter-spacing:.01em;}
.faq-item p{font-size:17.5px; line-height:1.65; margin:0; color:var(--soft);}

/* ---- final cta ---- */
.final-cta{text-align:center; padding:60px 28px 24px;}
.final-line{font-family:var(--display); font-style:italic; font-weight:500; font-size:27px;
  color:var(--soft); margin:0 auto 26px; max-width:34ch; line-height:1.35;}

/* ---- thank-you page ---- */
.thanks{max-width:640px; margin:0 auto; padding:80px 28px 64px; text-align:center;}
.thanks .big{font-size:28px; line-height:1; color:var(--grey);}
.thanks-lede{font-size:21px; line-height:1.7; max-width:46ch; margin:16px auto 22px;}
.thanks-note{font-size:16.5px; color:var(--grey); margin:0 auto 30px; max-width:46ch;}

/* ---- prose pages (about / terms / privacy) ---- */
.prose-page{max-width:700px; margin:0 auto; padding:60px 28px 24px;}
.prose-page h1{font-family:var(--display); font-weight:500; font-size:clamp(38px,5vw,52px);
  line-height:1.08; margin:0 0 10px; letter-spacing:.01em;}
.prose-page .lede{font-family:var(--display); font-style:italic; font-weight:500; font-size:23px;
  color:var(--grey); margin:0 0 30px;}
.prose-page h2{font-family:var(--display); font-weight:600; font-size:28px; margin:36px 0 10px; letter-spacing:.01em;}
.prose-page p, .prose-page li{font-size:18.5px; line-height:1.75; color:var(--soft);}
.prose-page .tag{display:inline-block; font-family:var(--label); font-weight:400; font-size:10.5px;
  letter-spacing:.2em; text-transform:uppercase; border:1px solid var(--hair); padding:3px 10px;
  margin-right:6px; color:var(--soft);}

/* ---- footer ---- */
.site-foot{text-align:center; padding:56px 28px 64px; border-top:1px solid var(--hair);
  max-width:1080px; margin:48px auto 0;}
.foot-mark{font-size:16px; color:var(--grey);}
.foot-line{font-family:var(--display); font-weight:500; font-size:38px; margin:10px 0 18px; letter-spacing:.03em;}
.foot-nav{margin:0 0 18px;}
.foot-nav a{font-family:var(--label); font-weight:400; font-size:11px; letter-spacing:.2em;
  text-transform:uppercase; color:var(--soft); margin:0 12px; text-decoration:none;}
.foot-nav a:hover{color:var(--ink);}
.foot-fine{font-family:var(--label); font-size:11px; letter-spacing:.1em; color:var(--grey);}

/* ---- responsive ---- */
@media (max-width:820px){
  .what-grid{grid-template-columns:1fr;}
  .what-cell{border-left:0; border-top:1px solid var(--faint); padding:26px 0;}
  .what-cell:first-child{border-top:0; padding-top:8px;}
  .price-grid{grid-template-columns:1fr;}
  .masthead-rule span:nth-child(2){display:none;}
}
@media (max-width:480px){
  body{font-size:18px;}
  .site-nav{gap:18px;}
  .chart-row i{width:18px; height:18px;}
  .chart-row i.x::before{font-size:13px;}
}
