/* The Sporting Shop — clean apparel & outdoor-goods landing site.
   Editorial system shared across home + category pages.
   Palette LOCKED: oxblood #8f2418 · ink #1c1a17 · paper #faf6ed · bone #f4ede0 · gold #c9a159 */

/* ---- self-hosted fonts (no external font CDN) ---- */
@font-face{ font-family:"Playfair Display"; src:url("fonts/playfair-display-var-latin.woff2") format("woff2"); font-weight:400 900; font-style:normal; font-display:swap; }
@font-face{ font-family:"Playfair Display"; src:url("fonts/playfair-display-italic-var-latin.woff2") format("woff2"); font-weight:400 900; font-style:italic; font-display:swap; }
@font-face{ font-family:"Cormorant Garamond"; src:url("fonts/cormorant-garamond-var-latin.woff2") format("woff2"); font-weight:300 700; font-style:normal; font-display:swap; }
@font-face{ font-family:"Cormorant Garamond"; src:url("fonts/cormorant-garamond-italic-var-latin.woff2") format("woff2"); font-weight:300 700; font-style:italic; font-display:swap; }
@font-face{ font-family:"Montserrat"; src:url("fonts/montserrat-var-latin.woff2") format("woff2"); font-weight:300 800; font-style:normal; font-display:swap; }
@font-face{ font-family:"JetBrains Mono"; src:url("fonts/jetbrains-mono-var-latin.woff2") format("woff2"); font-weight:400 700; font-style:normal; font-display:swap; }

:root{
  --ox:#8f2418; --ink:#1c1a17; --paper:#faf6ed; --bone:#f4ede0; --gold:#c9a159;
  --quiet:#6b6357; --line:#e3d8c2;
  --display:"Playfair Display",Georgia,serif;
  --serif:"Cormorant Garamond",Georgia,serif;
  --sans:"Montserrat",-apple-system,system-ui,sans-serif;
  --mono:"JetBrains Mono",ui-monospace,monospace;
  --wrap:1200px;
}

*{ box-sizing:border-box; }
html{ scroll-behavior:smooth; }
body{
  margin:0; background:var(--paper); color:var(--ink);
  font-family:var(--sans); font-size:16px; line-height:1.6;
  -webkit-font-smoothing:antialiased;
}
img{ display:block; max-width:100%; }
a{ color:var(--ox); text-decoration:none; }
a:hover,a:focus{ color:var(--ink); }
.wrap{ max-width:var(--wrap); margin:0 auto; padding:0 28px; }

/* ---- shared eyebrow / headings ---- */
.eyebrow{ font:600 11px/1 var(--mono); letter-spacing:.22em; text-transform:uppercase; color:var(--ox); margin:0 0 14px; }
.eyebrow.on-dark{ color:var(--gold); }
h1,h2,h3{ font-family:var(--display); font-weight:600; line-height:1.05; margin:0; }

/* ---- top bar ---- */
.topbar{ background:var(--ink); color:var(--paper); font:600 10.5px/1 var(--mono); letter-spacing:.14em; text-transform:uppercase; }
.topbar .wrap{ display:flex; justify-content:center; gap:26px; padding:9px 28px; flex-wrap:wrap; }
.topbar span{ opacity:.82; }
.topbar .sep{ color:var(--gold); opacity:1; }

/* ---- header / nav ---- */
.site-head{ position:sticky; top:0; z-index:30; background:var(--paper); border-bottom:1px solid var(--line); }
.site-head .wrap{ display:flex; align-items:center; gap:30px; padding:18px 28px; }
.brand{ display:flex; align-items:center; gap:13px; }
.brand img{ width:42px; height:42px; }
.brand b{ font-family:var(--display); font-size:21px; font-weight:600; letter-spacing:.01em; color:var(--ink); display:block; line-height:1; }
.brand small{ font:600 8.5px/1 var(--mono); letter-spacing:.2em; text-transform:uppercase; color:var(--quiet); display:block; margin-top:5px; }
.nav{ display:flex; gap:26px; margin-left:auto; align-items:center; }
.nav a{ font:600 12px/1 var(--mono); letter-spacing:.1em; text-transform:uppercase; color:var(--ink); padding:6px 0; border-bottom:2px solid transparent; }
.nav a:hover,.nav a:focus,.nav a.is-active{ color:var(--ox); border-bottom-color:var(--gold); }
.nav .cta{ background:var(--ox); color:var(--paper); border:0; padding:11px 18px; border-radius:2px; letter-spacing:.08em; }
.nav .cta:hover,.nav .cta:focus{ background:var(--ink); color:var(--paper); border-bottom-color:transparent; }

/* ---- hero ---- */
.hero{ position:relative; background:var(--ink); color:var(--paper); overflow:hidden; }
.hero .wrap{ position:relative; z-index:2; padding:96px 28px 104px; max-width:var(--wrap); }
.hero__art{ position:absolute; inset:0; z-index:0;
  background:
    radial-gradient(120% 90% at 78% 30%, rgba(143,36,24,.34), transparent 60%),
    linear-gradient(120deg,#1c1a17 0%, #241f1a 55%, #2f2820 100%);
}
.hero__ram{ position:absolute; right:-60px; bottom:-70px; width:440px; opacity:.12; z-index:1; pointer-events:none; }
.hero h1{ font-size:clamp(40px,6.4vw,78px); max-width:14ch; }
.hero h1 em{ font-style:italic; color:var(--gold); }
.hero p{ font-family:var(--serif); font-size:clamp(19px,2.3vw,25px); line-height:1.45; max-width:46ch; margin:22px 0 32px; color:rgba(250,246,237,.9); }
.hero__btns{ display:flex; gap:14px; flex-wrap:wrap; }
.btn{ display:inline-flex; align-items:center; gap:9px; font:600 12px/1 var(--mono); letter-spacing:.1em; text-transform:uppercase; padding:15px 24px; border-radius:2px; border:1px solid transparent; transition:.15s; }
.btn--gold{ background:var(--gold); color:var(--ink); }
.btn--gold:hover,.btn--gold:focus{ background:#bb9043; color:var(--ink); }
.btn--ghost{ background:transparent; color:var(--paper); border-color:rgba(250,246,237,.4); }
.btn--ghost:hover,.btn--ghost:focus{ border-color:var(--gold); color:var(--gold); }
.btn--ox{ background:var(--ox); color:var(--paper); }
.btn--ox:hover,.btn--ox:focus{ background:var(--ink); color:var(--paper); }

/* ---- section frame ---- */
.section{ padding:78px 0; }
.section--bone{ background:var(--bone); }
.section__head{ display:flex; align-items:flex-end; justify-content:space-between; gap:24px; margin-bottom:38px; flex-wrap:wrap; }
.section__head h2{ font-size:clamp(28px,3.6vw,42px); }
.section__head p{ margin:8px 0 0; color:var(--quiet); font-family:var(--serif); font-size:19px; max-width:48ch; }
.seeall{ font:600 11px/1 var(--mono); letter-spacing:.12em; text-transform:uppercase; color:var(--ox); white-space:nowrap; border-bottom:2px solid var(--gold); padding-bottom:6px; }
.seeall:hover,.seeall:focus{ color:var(--ink); }

/* ---- category grid ---- */
.cat-grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:18px; }
.cat-grid--2{ grid-template-columns:repeat(2,1fr); }
.cat-card{ position:relative; display:block; border:1px solid var(--line); border-radius:3px; overflow:hidden; background:#fff; transition:.18s; }
.cat-card:hover{ transform:translateY(-3px); box-shadow:0 14px 30px -18px rgba(28,26,23,.55); border-color:var(--gold); }
.cat-card__ph{ aspect-ratio:4/5; background:var(--bone); position:relative; overflow:hidden; }
.cat-card__ph::after{ content:attr(data-ph); position:absolute; inset:0; display:flex; align-items:center; justify-content:center; text-align:center; padding:20px; font:600 9.5px/1.5 var(--mono); letter-spacing:.12em; text-transform:uppercase; color:#b3a994; }
.cat-card__body{ padding:18px 18px 20px; display:flex; align-items:center; justify-content:space-between; gap:10px; }
.cat-card__body b{ font-family:var(--display); font-size:19px; font-weight:600; color:var(--ink); }
.cat-card__body .arr{ color:var(--ox); font-size:18px; transition:.18s; }
.cat-card:hover .arr{ transform:translateX(4px); }

/* product card */
.prod-grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:20px; }
.prod{ background:#fff; border:1px solid var(--line); border-radius:3px; overflow:hidden; display:flex; flex-direction:column; transition:.18s; }
.prod:hover{ transform:translateY(-3px); box-shadow:0 14px 30px -18px rgba(28,26,23,.5); border-color:var(--gold); }
.prod__ph{ aspect-ratio:1/1; background:var(--bone); position:relative; }
.prod__ph::after{ content:attr(data-ph); position:absolute; inset:0; display:flex; align-items:center; justify-content:center; text-align:center; padding:16px; font:600 9px/1.5 var(--mono); letter-spacing:.1em; text-transform:uppercase; color:#b3a994; }
.prod__tag{ position:absolute; top:10px; left:10px; background:var(--ox); color:var(--paper); font:600 8.5px/1 var(--mono); letter-spacing:.1em; text-transform:uppercase; padding:5px 8px; border-radius:2px; }
.prod__body{ padding:15px 16px 18px; display:flex; flex-direction:column; gap:5px; flex:1; }
.prod__brand{ font:600 8.5px/1 var(--mono); letter-spacing:.14em; text-transform:uppercase; color:var(--quiet); }
.prod__name{ font-family:var(--display); font-size:16px; font-weight:600; color:var(--ink); line-height:1.2; }
.prod__price{ font-family:var(--serif); font-size:19px; color:var(--ox); margin-top:auto; padding-top:8px; }

/* ---- real-photo fill: drop on any .*__ph / .band__art to replace the striped placeholder ---- */
.has-img{ background-size:cover; background-position:center; }
.has-img::after{ display:none !important; }
.cat-card__ph.has-img::before, .band__art.has-img::before{ content:""; position:absolute; inset:0; background:linear-gradient(180deg,transparent 40%,rgba(28,26,23,.34)); }

/* ---- split / editorial band ---- */
.band{ display:grid; grid-template-columns:1.1fr 1fr; align-items:stretch; }
.band__art{ background:var(--bone); position:relative; min-height:380px; overflow:hidden; }
.band__art::after{ content:attr(data-ph); position:absolute; inset:0; display:flex; align-items:center; justify-content:center; text-align:center; padding:30px; font:600 10px/1.6 var(--mono); letter-spacing:.12em; text-transform:uppercase; color:#b3a994; }
.band__body{ padding:64px 56px; display:flex; flex-direction:column; justify-content:center; }
.band--ink{ background:var(--ink); color:var(--paper); }
.band--ink .band__body h2{ color:var(--paper); }
.band--ink .band__body p{ color:rgba(250,246,237,.85); }
.band__body h2{ font-size:clamp(28px,3.4vw,40px); max-width:16ch; }
.band__body p{ font-family:var(--serif); font-size:20px; line-height:1.5; color:var(--quiet); margin:18px 0 26px; max-width:42ch; }

/* ---- preserve cross-promo strip ---- */
.preserve{ background:linear-gradient(120deg,#1c1a17,#2a241d); color:var(--paper); }
.preserve .wrap{ padding:54px 28px; display:flex; align-items:center; gap:40px; flex-wrap:wrap; }
.preserve__txt{ flex:1 1 360px; }
.preserve__txt h3{ font-size:clamp(24px,3vw,34px); color:var(--paper); }
.preserve__txt p{ font-family:var(--serif); font-size:19px; color:rgba(250,246,237,.82); margin:12px 0 0; max-width:52ch; }
.preserve__links{ display:flex; gap:12px; flex-wrap:wrap; }
.preserve__links a{ font:600 11px/1 var(--mono); letter-spacing:.1em; text-transform:uppercase; color:var(--paper); border:1px solid rgba(250,246,237,.32); padding:13px 17px; border-radius:2px; transition:.15s; }
.preserve__links a:hover,.preserve__links a:focus{ border-color:var(--gold); color:var(--gold); }

/* ---- subcategory deep-link chips (category pages) ---- */
.chips{ display:flex; flex-wrap:wrap; gap:10px; }
.chips a{ font:600 11px/1 var(--mono); letter-spacing:.08em; text-transform:uppercase; color:var(--ink); background:#fff; border:1px solid var(--line); padding:12px 16px; border-radius:2px; transition:.15s; }
.chips a:hover,.chips a:focus{ border-color:var(--gold); color:var(--ox); transform:translateY(-2px); }
.chips a .a{ color:var(--ox); margin-left:7px; }
/* shorter hero for interior pages */
.hero--sub .wrap{ padding:70px 28px 76px; }
.hero--sub h1{ font-size:clamp(34px,5vw,62px); }

/* ---- signup ---- */
.signup{ background:var(--ox); color:var(--paper); }
.signup .wrap{ padding:66px 28px; text-align:center; }
.signup h2{ font-size:clamp(28px,3.6vw,42px); color:var(--paper); max-width:18ch; margin:0 auto; }
.signup p{ font-family:var(--serif); font-size:20px; color:rgba(250,246,237,.9); margin:16px auto 28px; max-width:46ch; }
.signup form{ display:flex; gap:10px; justify-content:center; max-width:480px; margin:0 auto; flex-wrap:wrap; }
.signup input{ flex:1 1 240px; border:0; border-radius:2px; padding:15px 18px; font:15px/1 var(--sans); color:var(--ink); }
.signup button{ background:var(--gold); color:var(--ink); border:0; border-radius:2px; padding:15px 26px; font:600 12px/1 var(--mono); letter-spacing:.1em; text-transform:uppercase; cursor:pointer; }
.signup button:hover,.signup button:focus{ background:#e7c987; }

/* ---- footer ---- */
.site-foot{ background:var(--ink); color:rgba(250,246,237,.72); }
.site-foot .wrap{ padding:58px 28px 30px; }
.foot-grid{ display:grid; grid-template-columns:1.4fr 1fr 1fr 1fr; gap:34px; }
.site-foot .brand b{ color:var(--paper); }
.site-foot .brand small{ color:rgba(250,246,237,.55); }
.site-foot p.blurb{ font-family:var(--serif); font-size:17px; line-height:1.5; margin:16px 0 0; max-width:34ch; color:rgba(250,246,237,.7); }
.foot-col h4{ font:600 10px/1 var(--mono); letter-spacing:.16em; text-transform:uppercase; color:var(--gold); margin:0 0 16px; }
.foot-col a{ display:block; color:rgba(250,246,237,.72); font-size:14px; padding:5px 0; }
.foot-col a:hover,.foot-col a:focus{ color:var(--paper); }
.foot-bottom{ border-top:1px solid rgba(250,246,237,.14); margin-top:42px; padding-top:22px; display:flex; justify-content:space-between; gap:18px; flex-wrap:wrap; font:600 10.5px/1.5 var(--mono); letter-spacing:.06em; color:rgba(250,246,237,.5); }
.foot-bottom a{ color:rgba(250,246,237,.5); }
.foot-bottom a:hover{ color:var(--gold); }

/* ---- responsive ---- */
@media (max-width:980px){
  .cat-grid,.prod-grid{ grid-template-columns:repeat(2,1fr); }
  .band{ grid-template-columns:1fr; }
  .band__art{ min-height:260px; }
  .band__body{ padding:44px 32px; }
  .foot-grid{ grid-template-columns:1fr 1fr; gap:28px; }
}
@media (max-width:640px){
  .nav{ display:none; }
  .hero .wrap{ padding:64px 24px 72px; }
  .cat-grid,.prod-grid{ grid-template-columns:1fr 1fr; gap:12px; }
  .section{ padding:56px 0; }
  .foot-grid{ grid-template-columns:1fr; }
}
