/* =========================================================
   WedgeMasters — shared stylesheet
   Upload this file to the SAME folder as the HTML pages.
   Design system: "green jacket" pine + milled-brass accent.
   ========================================================= */

@import url('https://fonts.googleapis.com/css2?family=Fraunces:opsz,wght@9..144,400;9..144,500;9..144,600;9..144,700&family=Hanken+Grotesk:wght@400;500;600;700&family=DM+Mono:wght@400;500&display=swap');

:root{
  --pine:        #14352a;   /* dominant brand green */
  --pine-deep:   #0e261d;   /* darker green for footer/contrast */
  --pine-soft:   #1d4636;   /* hover / panels on dark */
  --brass:       #c2a052;   /* the single bold accent */
  --brass-bright:#d6b667;
  --bone:        #f5f2ea;   /* warm paper background */
  --bone-dim:    #ece7da;   /* subtle panels on light */
  --sand:        #e3d9c2;   /* soft block tone */
  --ink:         #1b1f1a;   /* body text on light */
  --ink-soft:    #46504310; /* hairlines */
  --muted:       #5d655c;   /* secondary text on light */
  --bone-muted:  #cdd3c8;   /* secondary text on dark */

  --display: 'Fraunces', Georgia, serif;
  --body:    'Hanken Grotesk', system-ui, -apple-system, sans-serif;
  --mono:    'DM Mono', ui-monospace, 'SFMono-Regular', monospace;

  --wrap: 1120px;
  --gap: clamp(1rem, 2.5vw, 2rem);
}

*{ box-sizing:border-box; }

html{ scroll-behavior:smooth; }

body{
  margin:0;
  font-family:var(--body);
  color:var(--ink);
  background:var(--bone);
  line-height:1.65;
  font-size:18px;
  -webkit-font-smoothing:antialiased;
}

img{ max-width:100%; display:block; }
a{ color:inherit; }

.wrap{ width:min(100% - 2.4rem, var(--wrap)); margin-inline:auto; }

/* ---------- type ---------- */
h1,h2,h3,h4{ font-family:var(--display); font-weight:600; line-height:1.08; margin:0 0 .5em; letter-spacing:-.01em; }
h1{ font-size:clamp(2.4rem, 5.2vw, 4.1rem); font-weight:600; }
h2{ font-size:clamp(1.8rem, 3.6vw, 2.7rem); }
h3{ font-size:clamp(1.3rem, 2.2vw, 1.6rem); }
p{ margin:0 0 1.1em; }

.eyebrow{
  font-family:var(--mono);
  font-size:.74rem;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:var(--brass);
  margin:0 0 1rem;
  display:inline-block;
}

/* loft-stamp badge — echoes the numbers milled on a wedge sole */
.stamp{
  font-family:var(--mono);
  font-size:.72rem;
  letter-spacing:.1em;
  color:var(--pine);
  border:1.5px solid var(--brass);
  border-radius:999px;
  padding:.32rem .8rem;
  display:inline-flex;
  align-items:center;
  gap:.45rem;
  background:transparent;
  white-space:nowrap;
}
.stamp--dark{ color:var(--bone); border-color:var(--brass); }

/* groove divider — thin milled lines */
.grooves{
  height:14px;
  width:100%;
  background:repeating-linear-gradient(
    to bottom,
    var(--brass) 0 1px,
    transparent 1px 4px
  );
  opacity:.5;
  margin:0;
}

/* ---------- header / nav ---------- */
.site-head{
  background:var(--pine);
  color:var(--bone);
  position:sticky;
  top:0;
  z-index:50;
  border-bottom:1px solid #ffffff14;
}
.nav{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:1rem;
  padding:.85rem 0;
}
.brand{
  font-family:var(--display);
  font-weight:600;
  font-size:1.4rem;
  letter-spacing:-.01em;
  text-decoration:none;
  color:var(--bone);
  display:inline-flex;
  align-items:center;
  gap:.55rem;
}
.brand .mark{ color:var(--brass); }
.nav-links{ display:flex; gap:1.6rem; align-items:center; list-style:none; margin:0; padding:0; }
.nav-links a{
  text-decoration:none;
  color:var(--bone-muted);
  font-size:.95rem;
  font-weight:500;
  padding:.3rem 0;
  border-bottom:2px solid transparent;
  transition:color .15s, border-color .15s;
}
.nav-links a:hover,
.nav-links a:focus-visible{ color:var(--bone); border-color:var(--brass); }
.nav-toggle{ display:none; background:none; border:0; color:var(--bone); font-size:1.5rem; cursor:pointer; }

/* ---------- buttons ---------- */
.btn{
  display:inline-flex;
  align-items:center;
  gap:.5rem;
  font-family:var(--body);
  font-weight:600;
  font-size:1rem;
  text-decoration:none;
  padding:.85rem 1.5rem;
  border-radius:2px;
  cursor:pointer;
  border:1.5px solid transparent;
  transition:transform .12s ease, background .15s, color .15s;
}
.btn:hover{ transform:translateY(-2px); }
.btn-primary{ background:var(--brass); color:var(--pine-deep); }
.btn-primary:hover{ background:var(--brass-bright); }
.btn-ghost{ background:transparent; color:var(--bone); border-color:#ffffff40; }
.btn-ghost:hover{ border-color:var(--brass); color:var(--bone); }
.btn-ink{ background:var(--pine); color:var(--bone); }
.btn-ink:hover{ background:var(--pine-soft); }

/* ---------- hero ---------- */
.hero{
  background:var(--pine);
  color:var(--bone);
  padding:clamp(3.5rem, 8vw, 6rem) 0 0;
  overflow:hidden;
}
.hero-grid{
  display:grid;
  grid-template-columns:1.15fr .85fr;
  gap:clamp(1.5rem, 4vw, 3rem);
  align-items:center;
}
.hero h1{ color:var(--bone); margin-bottom:1rem; }
.hero h1 em{ font-style:italic; color:var(--brass-bright); }
.hero-lead{
  font-size:1.18rem;
  color:var(--bone-muted);
  max-width:38ch;
  margin-bottom:1.8rem;
}
.hero-cta{ display:flex; flex-wrap:wrap; gap:.8rem; margin-bottom:2.2rem; }
.hero-meta{
  display:flex; gap:1.5rem; flex-wrap:wrap;
  padding-top:1.4rem; border-top:1px solid #ffffff1f;
  font-family:var(--mono); font-size:.78rem; color:var(--bone-muted);
  letter-spacing:.04em;
}
.hero-meta b{ color:var(--brass-bright); font-weight:500; display:block; font-size:1.5rem; font-family:var(--display); }
.hero-art{ align-self:end; }
.hero-art svg{ width:100%; height:auto; max-width:420px; margin-inline:auto; filter:drop-shadow(0 30px 40px rgba(0,0,0,.35)); }

/* ---------- generic section ---------- */
.section{ padding:clamp(3.5rem, 7vw, 5.5rem) 0; }
.section-head{ max-width:62ch; margin-bottom:2.6rem; }
.section-head p{ color:var(--muted); font-size:1.1rem; }
.section--sand{ background:var(--bone-dim); }

/* ---------- card grid ---------- */
.cards{ display:grid; grid-template-columns:repeat(auto-fit, minmax(280px,1fr)); gap:1.4rem; }
.card{
  background:#fff;
  border:1px solid #00000010;
  border-radius:4px;
  padding:1.6rem 1.5rem 1.7rem;
  display:flex; flex-direction:column;
  transition:transform .15s ease, box-shadow .2s;
}
.card:hover{ transform:translateY(-4px); box-shadow:0 18px 40px rgba(20,53,42,.12); }
.card .kicker{
  font-family:var(--mono); font-size:.72rem; letter-spacing:.12em;
  text-transform:uppercase; color:var(--brass); margin-bottom:.7rem;
}
.card h3{ margin-bottom:.5rem; }
.card p{ color:var(--muted); font-size:.98rem; flex:1; }
.card a.card-link{
  margin-top:1rem; text-decoration:none; font-weight:600; color:var(--pine);
  display:inline-flex; align-items:center; gap:.4rem; font-size:.95rem;
}
.card a.card-link:hover{ color:var(--brass); }
.card a.card-link::after{ content:"\2192"; transition:transform .15s; }
.card a.card-link:hover::after{ transform:translateX(4px); }

/* split feature row */
.split{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(1.5rem,4vw,3.5rem); align-items:center; }
.split .panel{
  background:var(--pine); color:var(--bone); border-radius:6px; padding:2.4rem;
}
.split .panel h2{ color:var(--bone); }
.split .panel p{ color:var(--bone-muted); }
.split-list{ list-style:none; margin:0 0 1.6rem; padding:0; }
.split-list li{ padding:.55rem 0; border-bottom:1px solid var(--ink-soft); display:flex; gap:.7rem; align-items:baseline; }
.split-list li::before{ content:attr(data-loft); font-family:var(--mono); color:var(--brass); font-size:.8rem; min-width:3.2rem; }

/* ---------- email capture ---------- */
.capture{
  background:var(--pine-deep); color:var(--bone);
  border-radius:6px; padding:clamp(2rem,5vw,3.4rem);
  text-align:center;
}
.capture h2{ color:var(--bone); }
.capture p{ color:var(--bone-muted); max-width:46ch; margin-inline:auto; }
.capture-form{ display:flex; gap:.6rem; justify-content:center; flex-wrap:wrap; margin-top:1.6rem; }
.capture-form input{
  font-family:var(--body); font-size:1rem; padding:.8rem 1rem;
  border:1.5px solid #ffffff33; background:#ffffff0d; color:var(--bone);
  border-radius:2px; min-width:min(320px, 80vw);
}
.capture-form input::placeholder{ color:#ffffff66; }
.capture-form input:focus{ outline:2px solid var(--brass); border-color:transparent; }
.capture small{ display:block; margin-top:.9rem; color:#ffffff66; font-family:var(--mono); font-size:.72rem; letter-spacing:.05em; }

/* ---------- article ---------- */
.article-head{ background:var(--pine); color:var(--bone); padding:clamp(3rem,6vw,4.5rem) 0 clamp(2.2rem,4vw,3rem); }
.article-head h1{ color:var(--bone); max-width:20ch; }
.article-head .dek{ color:var(--bone-muted); font-size:1.2rem; max-width:54ch; margin-top:.5rem; }
.byline{ font-family:var(--mono); font-size:.76rem; letter-spacing:.06em; color:var(--bone-muted); margin-top:1.6rem; display:flex; gap:1rem; flex-wrap:wrap; }
.byline span{ color:var(--brass-bright); }

.prose{ max-width:none; }
.article-body{ display:grid; grid-template-columns:minmax(0,1fr); gap:0; padding:clamp(2.5rem,5vw,3.5rem) 0; }
.prose{ max-width:68ch; margin-inline:auto; }
.prose h2{ margin-top:2.2em; }
.prose h3{ margin-top:1.6em; color:var(--pine); }
.prose p, .prose li{ font-size:1.08rem; }
.prose ul, .prose ol{ padding-left:1.2rem; margin:0 0 1.2em; }
.prose li{ margin-bottom:.45em; }
.prose strong{ color:var(--pine); }
.prose a{ color:var(--pine); text-decoration:underline; text-decoration-color:var(--brass); text-underline-offset:3px; }
.prose a:hover{ color:var(--brass); }
.prose blockquote{
  margin:1.8em 0; padding:1.1em 1.4em; border-left:3px solid var(--brass);
  background:var(--bone-dim); font-family:var(--display); font-size:1.2rem; font-style:italic; color:var(--pine);
}

/* recommendation block (affiliate) */
.pick{
  border:1px solid #00000014; border-top:4px solid var(--brass);
  border-radius:4px; background:#fff; padding:1.5rem 1.5rem 1.6rem; margin:1.6em 0;
}
.pick-top{ display:flex; justify-content:space-between; gap:1rem; align-items:flex-start; flex-wrap:wrap; }
.pick h3{ margin:0 0 .2rem; color:var(--ink); }
.pick .who{ font-family:var(--mono); font-size:.72rem; letter-spacing:.08em; text-transform:uppercase; color:var(--brass); }
.pick p{ font-size:1rem; color:var(--muted); margin:.7rem 0 1rem; }
.pick .btn{ font-size:.92rem; padding:.65rem 1.1rem; }
.placeholder{ background:#fff6df; border:1px dashed var(--brass); color:#7a5c12; font-family:var(--mono);
  font-size:.78rem; padding:.5rem .8rem; border-radius:3px; display:inline-block; }

.note{
  background:var(--bone-dim); border-left:3px solid var(--pine);
  padding:1rem 1.2rem; border-radius:0 4px 4px 0; margin:1.6em 0; font-size:1rem; color:var(--muted);
}
.note b{ color:var(--pine); }

/* table of contents */
.toc{ background:var(--bone-dim); border-radius:4px; padding:1.2rem 1.4rem; margin:0 0 2rem; }
.toc p{ font-family:var(--mono); font-size:.72rem; letter-spacing:.12em; text-transform:uppercase; color:var(--brass); margin:0 0 .6rem; }
.toc ol{ margin:0; padding-left:1.2rem; }
.toc a{ color:var(--pine); text-decoration:none; }
.toc a:hover{ color:var(--brass); text-decoration:underline; }

/* ---------- footer ---------- */
.site-foot{ background:var(--pine-deep); color:var(--bone-muted); padding:3rem 0 2rem; font-size:.92rem; }
.foot-grid{ display:grid; grid-template-columns:1.4fr 1fr 1fr; gap:2rem; margin-bottom:2rem; }
.foot-grid h4{ color:var(--bone); font-family:var(--mono); font-size:.74rem; letter-spacing:.14em; text-transform:uppercase; font-weight:500; margin-bottom:.9rem; }
.foot-grid a{ color:var(--bone-muted); text-decoration:none; display:block; padding:.25rem 0; }
.foot-grid a:hover{ color:var(--brass-bright); }
.foot-brand{ font-family:var(--display); font-size:1.5rem; color:var(--bone); margin-bottom:.5rem; }
.foot-disc{ font-size:.8rem; color:#ffffff55; border-top:1px solid #ffffff1f; padding-top:1.4rem; line-height:1.6; }

/* ---------- responsive ---------- */
@media (max-width: 820px){
  .hero-grid{ grid-template-columns:1fr; }
  .hero-art{ order:-1; max-width:300px; margin-inline:auto; }
  .split{ grid-template-columns:1fr; }
  .foot-grid{ grid-template-columns:1fr 1fr; }
  .nav-links{
    position:absolute; top:100%; left:0; right:0;
    background:var(--pine); flex-direction:column; gap:0;
    padding:.5rem 1.2rem 1rem; display:none;
    border-bottom:1px solid #ffffff14;
  }
  .nav-links.open{ display:flex; }
  .nav-links a{ padding:.7rem 0; width:100%; }
  .nav-toggle{ display:block; }
}
@media (max-width: 540px){
  .foot-grid{ grid-template-columns:1fr; }
  body{ font-size:17px; }
}

/* ---------- a11y ---------- */
a:focus-visible, button:focus-visible, input:focus-visible{ outline:2px solid var(--brass); outline-offset:2px; }
@media (prefers-reduced-motion: reduce){
  *{ animation:none !important; transition:none !important; scroll-behavior:auto !important; }
}
.skip{ position:absolute; left:-999px; }
.skip:focus{ left:1rem; top:.6rem; background:var(--brass); color:var(--pine-deep); padding:.5rem 1rem; border-radius:3px; z-index:100; }
