/* =========================================================
   WRECK BEACH — shared visual system
   Hand-cut local-zine: sand & paper, ocean, golden-hour.
   Type: Anton (display) · Newsreader (body) · Space Mono
   (labels) · Caveat (hand). Mobile-first.
========================================================= */

:root{
  --sand:#EFE3CE; --paper:#F6EEDD; --sand-deep:#E4D4B8;
  --ocean:#1F6E8C; --ocean-deep:#11465A;
  --gold:#E0A458; --gold-bright:#E8B04B;
  --ink:#2A2320; --ink-soft:#5A4F46; --ink-faint:#8A7C6E;
  --stamp:#C0492F;
  --line:rgba(42,35,32,.16);

  --anton:"Anton", Impact, sans-serif;
  --serif:"Newsreader", Georgia, "Times New Roman", serif;
  --mono:"Space Mono", ui-monospace, "Courier New", monospace;
  --hand:"Caveat", "Segoe Script", cursive;

  --wrap:1180px;
  --r:14px;
}

*{ box-sizing:border-box; }
html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
body{
  margin:0; background:var(--sand); color:var(--ink);
  font-family:var(--serif); font-size:19px; line-height:1.6;
  font-optical-sizing:auto; text-rendering:optimizeLegibility;
  -webkit-font-smoothing:antialiased; overflow-x:hidden;
}

/* paper grain over everything */
body::before{
  content:""; position:fixed; inset:0; z-index:1; pointer-events:none;
  opacity:.06; mix-blend-mode:multiply;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='220' height='220'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.82' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

img{ max-width:100%; display:block; }
a{ color:var(--ocean); text-decoration-thickness:1.5px; text-underline-offset:3px; }
a:hover{ color:var(--ocean-deep); }

.wrap{ width:100%; max-width:var(--wrap); margin-inline:auto; padding-inline:20px; }
.skip-link{ position:absolute; left:-999px; }
.skip-link:focus{ left:12px; top:12px; z-index:100; background:var(--ink); color:var(--paper); padding:8px 14px; border-radius:6px; }

/* ---------- typography helpers ---------- */
h1,h2,h3{ margin:0; line-height:1.04; }
.display{ font-family:var(--anton); font-weight:400; letter-spacing:.005em; text-transform:uppercase; }
.eyebrow{ font-family:var(--mono); font-size:.72rem; letter-spacing:.16em; text-transform:uppercase; color:var(--stamp); margin:0; }
.mono{ font-family:var(--mono); letter-spacing:.04em; }
.hand{ font-family:var(--hand); color:var(--stamp); line-height:1; }
.lede{ font-size:1.18rem; line-height:1.55; color:var(--ink-soft); }
.measure{ max-width:62ch; }

/* ---------- buttons ---------- */
.btn{
  display:inline-flex; align-items:center; gap:8px; cursor:pointer;
  font-family:var(--mono); font-weight:700; font-size:.8rem;
  letter-spacing:.05em; text-transform:uppercase; text-decoration:none;
  padding:13px 22px; border-radius:40px; border:2px solid transparent;
  transition:transform .12s ease, background .15s ease, color .15s ease;
}
.btn:hover{ transform:translateY(-2px); }
.btn--ink{ background:var(--ink); color:var(--paper); }
.btn--ink:hover{ color:var(--paper); }
.btn--gold{ background:var(--gold); color:var(--ink); }
.btn--gold:hover{ background:var(--gold-bright); color:var(--ink); }
.btn--ocean{ background:var(--ocean); color:var(--paper); }
.btn--ghost{ background:transparent; border-color:currentColor; }

/* ---------- stamp ---------- */
.stamp{
  display:inline-block; border:2.5px solid var(--stamp); color:var(--stamp);
  padding:7px 13px; border-radius:3px; font-family:var(--mono); font-weight:700;
  font-size:.7rem; letter-spacing:.12em; text-transform:uppercase; line-height:1.3;
  text-align:center; opacity:.9; box-shadow:inset 0 0 0 2px rgba(255,255,255,.18);
}
.stamp--ocean{ border-color:var(--ocean); color:var(--ocean); }
.stamp--paper{ border-color:var(--paper); color:var(--paper); }

/* ---------- tape ---------- */
.tape{
  width:120px; height:26px; background:rgba(224,164,88,.42);
  border:1px solid rgba(224,164,88,.55); box-shadow:0 1px 3px rgba(0,0,0,.12);
}

/* ---------- image placeholders (swap for real <img>) ---------- */
.ph{
  position:relative; overflow:hidden; display:flex; align-items:center; justify-content:center;
  background:repeating-linear-gradient(48deg,#1F6E8C 0 13px,rgba(255,255,255,.10) 13px 26px);
  color:#EAF2F4;
}
.ph--sand{ background:repeating-linear-gradient(48deg,#E4D4B8 0 13px,rgba(42,35,32,.07) 13px 26px); color:#5A4F46; }
.ph--gold{ background:repeating-linear-gradient(48deg,#E0A458 0 13px,rgba(42,35,32,.10) 13px 26px); color:#3a2c14; }
.ph--ink{ background:repeating-linear-gradient(48deg,#2A2320 0 13px,rgba(255,255,255,.06) 13px 26px); color:#C9BBA6; }
.ph__label{
  font-family:var(--mono); font-size:.66rem; letter-spacing:.12em; text-transform:uppercase;
  background:rgba(0,0,0,.20); padding:6px 10px; border:1px dashed currentColor; border-radius:2px;
  text-align:center; max-width:80%;
}
/* polaroid framing for taped photos */
.snap{ border:9px solid #fff; box-shadow:0 14px 30px rgba(0,0,0,.2); background:#fff; }

/* ---------- wave divider ---------- */
.wave{ display:block; width:100%; height:42px; }

/* =========================================================
   HEADER / NAV
========================================================= */
.site-header{
  position:sticky; top:0; z-index:50;
  background:color-mix(in srgb, var(--sand) 88%, transparent);
  backdrop-filter:blur(8px); border-bottom:2px solid var(--line);
}
.site-header__inner{ display:flex; align-items:center; justify-content:space-between; gap:16px; padding-block:14px; }
.brand{ font-family:var(--anton); font-size:1.35rem; letter-spacing:.02em; text-transform:uppercase; color:var(--ink); text-decoration:none; white-space:nowrap; }
.brand .mark{ color:var(--ocean); }
.nav{ display:flex; align-items:center; gap:26px; }
.nav a{ font-family:var(--mono); font-size:.78rem; letter-spacing:.1em; text-transform:uppercase; color:var(--ink-soft); text-decoration:none; }
.nav a:hover, .nav a[aria-current="page"]{ color:var(--ocean); }
.nav__cta{ color:var(--ocean) !important; }
.nav-toggle{ display:none; background:var(--ink); color:var(--paper); border:none; border-radius:30px; padding:10px 16px; font-family:var(--mono); font-size:.72rem; letter-spacing:.1em; text-transform:uppercase; cursor:pointer; }

@media (max-width:780px){
  .nav{
    position:absolute; top:100%; left:0; right:0; flex-direction:column; align-items:flex-start; gap:0;
    background:var(--paper); border-bottom:2px solid var(--line); padding:8px 20px 16px;
    max-height:0; overflow:hidden; transition:max-height .25s ease, padding .25s ease; padding-block:0;
  }
  .nav.open{ max-height:340px; padding-block:8px 16px; }
  .nav a{ padding:12px 0; width:100%; border-bottom:1px solid var(--line); font-size:.9rem; }
  .nav a:last-child{ border-bottom:none; }
  .nav-toggle{ display:inline-block; }
}

/* =========================================================
   SECTIONS — shared rhythm
========================================================= */
.section{ position:relative; z-index:2; padding-block:clamp(56px,8vw,104px); }
.section--paper{ background:var(--paper); }
.section--ocean{ background:var(--ocean); color:var(--paper); }
.section--ink{ background:var(--ink); color:var(--paper); }
.section-head{ max-width:760px; margin-bottom:42px; }
.section-kicker{
  font-family:var(--mono); font-size:.74rem; letter-spacing:.16em; text-transform:uppercase;
  color:var(--ocean); display:inline-block; border-bottom:2px solid var(--ocean); padding-bottom:6px; margin-bottom:18px;
}
.section--ocean .section-kicker, .section--ink .section-kicker{ color:var(--gold); border-color:var(--gold); }
.section-title{ font-family:var(--anton); font-size:clamp(2.1rem,5.4vw,3.4rem); text-transform:uppercase; letter-spacing:.005em; }
.section-title .accent{ color:var(--ocean); }
.section--ocean .section-title .accent, .section--ink .section-title .accent{ color:var(--gold); }

/* =========================================================
   GUIDE TOPIC CARDS
========================================================= */
.topic-grid{ display:grid; grid-template-columns:repeat(auto-fill,minmax(280px,1fr)); gap:18px; }
.topic{
  display:flex; flex-direction:column; gap:8px; text-decoration:none; color:inherit;
  background:var(--paper); border:2px solid var(--line); border-radius:var(--r);
  padding:24px; transition:transform .14s ease, border-color .14s ease, box-shadow .14s ease;
}
.topic:hover{ transform:translateY(-3px); border-color:var(--ocean); box-shadow:0 14px 28px rgba(42,35,32,.12); }
.topic__num{ font-family:var(--mono); font-size:.74rem; letter-spacing:.12em; color:var(--stamp); }
.topic__title{ font-family:var(--anton); font-size:1.5rem; text-transform:uppercase; line-height:1; }
.topic__desc{ font-size:.98rem; color:var(--ink-soft); line-height:1.45; }
.topic__more{ margin-top:auto; font-family:var(--mono); font-size:.74rem; letter-spacing:.08em; text-transform:uppercase; color:var(--ocean); }

/* =========================================================
   PRODUCT CARDS
========================================================= */
.product-grid{ display:grid; grid-template-columns:repeat(auto-fill,minmax(260px,1fr)); gap:22px; }
.product{ display:flex; flex-direction:column; background:var(--paper); border:2px solid var(--line); border-radius:var(--r); overflow:hidden; transition:transform .14s ease, box-shadow .14s ease; }
.product:hover{ transform:translateY(-3px); box-shadow:0 16px 30px rgba(42,35,32,.14); }
.product__media{ position:relative; aspect-ratio:4/5; }
.product__media .ph{ position:absolute; inset:0; }
.product__tag{ position:absolute; top:12px; left:12px; z-index:2; }
.product__body{ padding:18px 18px 22px; display:flex; flex-direction:column; gap:10px; flex:1; }
.product__name{ font-family:var(--anton); font-size:1.3rem; text-transform:uppercase; line-height:1; }
.product__blurb{ font-size:.92rem; color:var(--ink-soft); line-height:1.45; flex:1; }
.product__row{ display:flex; align-items:center; justify-content:space-between; gap:12px; }
.product__price{ font-family:var(--mono); font-weight:700; font-size:1rem; color:var(--ink); }
/* Shopify Buy Button placeholder */
.buybtn-slot{
  border:2px dashed var(--ocean); border-radius:30px; padding:11px 16px;
  font-family:var(--mono); font-size:.66rem; letter-spacing:.08em; text-transform:uppercase;
  color:var(--ocean); text-align:center; background:rgba(31,110,140,.06); line-height:1.3;
}

/* =========================================================
   NEWSLETTER
========================================================= */
.signup-form{ display:flex; gap:10px; flex-wrap:wrap; max-width:520px; }
.signup-form input{
  flex:1; min-width:200px; font-family:var(--mono); font-size:.9rem; color:var(--ink);
  padding:14px 16px; border-radius:40px; border:2px solid var(--ink); background:var(--paper);
}
.signup-form input::placeholder{ color:var(--ink-faint); }
.signup-note{ font-family:var(--mono); font-size:.7rem; letter-spacing:.06em; text-transform:uppercase; opacity:.8; margin-top:14px; }

/* =========================================================
   FOOTER
========================================================= */
.site-footer{ position:relative; z-index:2; background:var(--ink); color:var(--paper); padding-block:56px 30px; }
.footer-grid{ display:grid; grid-template-columns:1.4fr 1fr 1fr 1fr; gap:34px; }
.footer-brand .display{ font-size:2rem; }
.footer-brand p{ color:#C9BBA6; font-size:.98rem; }
.footer-col h4{ font-family:var(--mono); font-size:.72rem; letter-spacing:.14em; text-transform:uppercase; color:var(--gold); margin:0 0 14px; }
.footer-col ul{ list-style:none; margin:0; padding:0; display:flex; flex-direction:column; gap:9px; }
.footer-col a{ color:#E6DCC8; text-decoration:none; font-size:.95rem; }
.footer-col a:hover{ color:var(--gold); }
.footer-bottom{ display:flex; flex-wrap:wrap; gap:12px; justify-content:space-between; align-items:center; margin-top:44px; padding-top:20px; border-top:1px solid rgba(255,255,255,.14); font-family:var(--mono); font-size:.7rem; letter-spacing:.06em; color:#A99C8A; }

@media (max-width:780px){
  .footer-grid{ grid-template-columns:1fr 1fr; }
}
@media (max-width:480px){
  .footer-grid{ grid-template-columns:1fr; }
}

/* =========================================================
   PROSE (guide article body)
========================================================= */
.prose{ max-width:68ch; }
.prose h2{ font-family:var(--anton); font-size:clamp(1.7rem,4vw,2.4rem); text-transform:uppercase; margin-top:0; }
.prose h3{ font-family:var(--serif); font-weight:600; font-size:1.4rem; margin:32px 0 8px; }
.prose p{ margin:0 0 18px; }
.prose ul,.prose ol{ margin:0 0 18px; padding-left:22px; }
.prose li{ margin-bottom:8px; }
.prose strong{ color:var(--ink); }
.callout{
  border-left:4px solid var(--gold); background:var(--paper);
  padding:18px 22px; border-radius:0 var(--r) var(--r) 0; margin:24px 0;
}
.callout .hand{ font-size:1.5rem; }

.visually-hidden{ position:absolute; width:1px; height:1px; overflow:hidden; clip:rect(0 0 0 0); }
