:root {
  --ink: #17233d;
  --paper: #f5eddd;
  --paper-deep: #ded2bd;
  --accent: #a62534;
  --gold: #c7a052;
  --surface: #fffaf0;
  --line: rgba(23, 35, 61, .2);
  --display: "Arial Black", "Franklin Gothic Heavy", Arial, sans-serif;
  --body: "Segoe UI", Arial, sans-serif;
  --serif: Georgia, "Times New Roman", serif;
  --radius: 2px;
  --shadow: 8px 8px 0 var(--ink);
}

body[data-theme="boutique"] {
  --ink: #201c1b;
  --paper: #f6f0e9;
  --paper-deep: #d9c8bd;
  --accent: #a96d73;
  --gold: #b38b72;
  --surface: #fffaf7;
  --line: rgba(32, 28, 27, .16);
  --display: Georgia, "Times New Roman", serif;
  --radius: 18px;
  --shadow: 0 22px 55px rgba(55, 36, 32, .14);
}

body[data-theme="garage"] {
  --ink: #111111;
  --paper: #ded9ce;
  --paper-deep: #99948b;
  --accent: #c72f23;
  --gold: #d6b15c;
  --surface: #eee9de;
  --line: rgba(17, 17, 17, .28);
  --display: Impact, "Arial Black", sans-serif;
  --radius: 0;
  --shadow: 9px 9px 0 var(--accent);
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body { margin: 0; background: var(--paper); color: var(--ink); font-family: var(--body); line-height: 1.5; transition: background .25s, color .25s; }
img { display: block; max-width: 100%; }
a { color: inherit; text-decoration: none; }
button, input { font: inherit; }
h1, h2, h3, p { margin-top: 0; }
.sr-only { position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px; overflow: hidden; clip: rect(0,0,0,0); white-space: nowrap; border: 0; }
.skip-link { position: fixed; left: 1rem; top: -5rem; z-index: 100; background: var(--surface); padding: .8rem 1rem; border: 2px solid var(--ink); }
.skip-link:focus { top: 1rem; }

.announcement { padding: .55rem 1rem; background: var(--ink); color: var(--paper); text-align: center; font-size: .68rem; font-weight: 800; letter-spacing: .15em; }
.site-header { min-height: 80px; display: flex; align-items: center; justify-content: space-between; padding: 1rem clamp(1rem, 4vw, 4rem); border-bottom: 1px solid var(--line); background: color-mix(in srgb, var(--paper) 92%, transparent); position: sticky; top: 0; z-index: 50; backdrop-filter: blur(14px); }
.brand { display: flex; align-items: center; gap: .75rem; }
.brand-mark { width: 42px; height: 42px; display: grid; place-items: center; border: 2px solid var(--ink); border-radius: 50%; font-family: var(--serif); font-weight: 700; font-size: .75rem; }
.brand-name { font-family: var(--display); font-size: 1.15rem; font-weight: 900; letter-spacing: -.05em; }
.brand-name i { color: var(--accent); font-family: var(--serif); }
.site-nav { display: flex; align-items: center; gap: clamp(1rem, 3vw, 2.25rem); font-size: .82rem; font-weight: 700; }
.site-nav a:not(.nav-cta):hover { color: var(--accent); }
.nav-cta { padding: .7rem 1rem; border: 2px solid var(--ink); }
.nav-cta:hover { background: var(--ink); color: var(--paper); }
.menu-toggle { display: none; border: 1px solid var(--ink); background: transparent; padding: .5rem .75rem; font-weight: 700; }

.hero { min-height: 720px; display: grid; grid-template-columns: minmax(0, 1fr) minmax(350px, .9fr); overflow: hidden; border-bottom: 1px solid var(--line); }
.hero-copy { padding: clamp(4rem, 8vw, 8rem) clamp(1.25rem, 6vw, 7rem); display: flex; flex-direction: column; align-items: flex-start; justify-content: center; position: relative; z-index: 2; }
.eyebrow { margin-bottom: 1rem; color: var(--accent); font-size: .71rem; font-weight: 800; letter-spacing: .19em; text-transform: uppercase; }
.hero h1 { margin: 0 0 1rem; font-family: var(--display); font-size: clamp(4.2rem, 9vw, 9.8rem); font-weight: 900; line-height: .75; letter-spacing: -.09em; }
.hero h1 span { color: var(--accent); font-family: var(--serif); font-style: italic; font-weight: 700; }
.hero-lede { font-family: var(--serif); font-size: clamp(1.4rem, 2vw, 2rem); font-style: italic; }
.microcopy { margin: 1rem 0 0; color: color-mix(in srgb, var(--ink) 70%, transparent); font-size: .75rem; }
.button-row { display: flex; flex-wrap: wrap; gap: .75rem; margin-top: 1rem; }
.button { display: inline-flex; align-items: center; justify-content: center; min-height: 52px; padding: .85rem 1.35rem; border: 2px solid var(--ink); background: var(--ink); color: var(--paper); border-radius: var(--radius); font-size: .78rem; font-weight: 800; letter-spacing: .04em; text-align: center; transition: transform .18s, box-shadow .18s, background .18s; }
.button:hover { transform: translate(-2px, -2px); box-shadow: 4px 4px 0 var(--accent); }
.button-ghost { background: transparent; color: var(--ink); }
.button-light { background: var(--paper); color: var(--ink); border-color: var(--paper); }
.button-small { min-height: 42px; padding: .6rem 1rem; }
.button-wide { width: 100%; }
.hero-art { min-height: 600px; background: var(--accent); position: relative; display: grid; place-items: center; overflow: hidden; }
.hero-art img { position: relative; z-index: 2; width: min(78%, 560px); transform: rotate(3deg); box-shadow: 0 24px 60px rgba(0,0,0,.25); }
.sunburst { position: absolute; inset: -40%; background: repeating-conic-gradient(color-mix(in srgb, var(--paper) 15%, transparent) 0 8deg, transparent 8deg 16deg); }
.hero-seal { position: absolute; z-index: 3; right: 6%; bottom: 7%; width: 120px; aspect-ratio: 1; display: flex; flex-direction: column; align-items: center; justify-content: center; border: 3px solid var(--ink); outline: 3px solid var(--paper); outline-offset: -8px; border-radius: 50%; background: var(--gold); color: var(--ink); transform: rotate(-9deg); }
.hero-seal strong { font-family: var(--display); font-size: 1.4rem; }.hero-seal span { font-size: .65rem; font-weight: 900; letter-spacing: .1em; }.hero-seal small { font-size: .6rem; }
.theme-notice { display: flex; align-items: center; justify-content: center; gap: 1rem; padding: .7rem 1rem; background: var(--gold); color: var(--ink); font-size: .73rem; font-weight: 800; text-transform: uppercase; letter-spacing: .09em; }
.theme-notice a { text-decoration: underline; }

.marquee { overflow: hidden; padding: 1rem; background: var(--gold); color: var(--ink); border-block: 2px solid var(--ink); font-family: var(--display); font-size: clamp(.9rem, 2vw, 1.2rem); font-weight: 900; letter-spacing: .06em; white-space: nowrap; }
.marquee div { width: max-content; margin: auto; }.marquee span { margin: 0 1.5rem; color: var(--accent); }
.section { padding: clamp(4rem, 8vw, 8rem) clamp(1.25rem, 6vw, 7rem); }
.intro-section { display: grid; grid-template-columns: 1.15fr .85fr; gap: clamp(2rem, 8vw, 9rem); align-items: end; }
.intro-section h2, .section-heading h2, .recommendation h2 { margin-bottom: 0; font-family: var(--display); font-size: clamp(2.3rem, 4.8vw, 5.2rem); line-height: .95; letter-spacing: -.06em; }
.intro-section > div:last-child { font-size: 1.1rem; max-width: 600px; }
.text-link { display: inline-flex; gap: .65rem; align-items: center; padding-bottom: .2rem; border-bottom: 1px solid currentColor; font-size: .82rem; font-weight: 800; }
.text-link span { color: var(--accent); font-size: 1.2em; }
.collections-section { background: var(--ink); color: var(--paper); }
.collections-section .eyebrow { color: var(--gold); }
.section-heading { display: flex; align-items: flex-end; justify-content: space-between; gap: 2rem; margin-bottom: 3rem; }
.collections-section .button-ghost { color: var(--paper); border-color: var(--paper); }
.collection-grid { display: grid; grid-template-columns: repeat(3, 1fr); border-top: 1px solid currentColor; border-left: 1px solid currentColor; }
.collection-card { min-height: 210px; position: relative; display: flex; flex-direction: column; justify-content: space-between; padding: 1.5rem; border-right: 1px solid currentColor; border-bottom: 1px solid currentColor; transition: color .2s, background .2s; }
.collection-card:hover { background: var(--accent); color: var(--paper); }
.collection-card h3 { margin: .25rem 0 0; font-family: var(--display); font-size: clamp(1.45rem, 2.4vw, 2.4rem); line-height: 1; letter-spacing: -.04em; }
.collection-card p { margin: 0; max-width: 80%; opacity: .68; font-family: var(--serif); font-size: .85rem; font-style: italic; }
.collection-icon { width: 44px; height: 44px; display: grid; place-items: center; border: 1px solid currentColor; border-radius: 50%; font-size: 1.35rem; }
.collection-icon.large { width: 70px; height: 70px; margin: 0 auto 1.5rem; font-size: 2rem; }
.circle-arrow { position: absolute; right: 1.5rem; top: 1.5rem; font-size: 1.35rem; }
.product-section { background: var(--surface); }
.product-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: clamp(1rem, 2vw, 2rem); }
.product-image { position: relative; display: block; overflow: hidden; background: var(--paper-deep); border-radius: var(--radius); }
.product-image img { width: 100%; aspect-ratio: .88; object-fit: cover; transition: transform .45s; }
.product-image-baseball { background: #000; }
.product-image-baseball img { object-fit: contain; }
.product-card:hover .product-image img { transform: scale(1.035) rotate(1deg); }
.product-stamp { position: absolute; left: .8rem; bottom: .8rem; padding: .4rem .6rem; background: var(--surface); font-size: .62rem; font-weight: 800; letter-spacing: .08em; text-transform: uppercase; }
.product-card-copy { display: flex; align-items: flex-start; justify-content: space-between; gap: .5rem; margin-top: 1rem; }
.product-card-copy h3 { margin: 0; font-family: var(--display); font-size: 1rem; letter-spacing: -.03em; }.product-card-copy > span { font-size: .85rem; font-weight: 700; }
.product-category { margin: 0 0 .2rem; color: var(--accent); font-size: .65rem; font-weight: 800; text-transform: uppercase; letter-spacing: .1em; }
.product-card > .text-link { margin-top: .8rem; }

.signup-band { display: grid; grid-template-columns: 1fr 1fr; gap: 3rem; align-items: center; padding: clamp(3.5rem, 7vw, 7rem) clamp(1.25rem, 8vw, 10rem); background: var(--accent); color: var(--paper); }
.signup-band .eyebrow { color: var(--gold); }.signup-band h2 { margin-bottom: .7rem; font-family: var(--display); font-size: clamp(2.2rem, 4.5vw, 4.8rem); line-height: .95; letter-spacing: -.06em; }.signup-band p:last-child { max-width: 600px; }
.signup-form { display: flex; gap: .6rem; }.signup-form input { min-width: 0; flex: 1; min-height: 54px; padding: 0 1rem; border: 2px solid var(--paper); background: transparent; color: var(--paper); border-radius: var(--radius); }.signup-form input::placeholder { color: color-mix(in srgb, var(--paper) 65%, transparent); }

.page-hero { padding: clamp(5rem, 11vw, 11rem) 1.25rem; text-align: center; border-bottom: 1px solid var(--line); background: radial-gradient(circle at 50% 10%, var(--surface), var(--paper) 60%); }
.page-hero h1 { margin: 0 0 1.3rem; font-family: var(--display); font-size: clamp(4rem, 10vw, 9rem); line-height: .85; letter-spacing: -.08em; }.page-hero > p:last-child { max-width: 680px; margin: auto; font-family: var(--serif); font-size: clamp(1.1rem, 2vw, 1.5rem); font-style: italic; }
.collection-grid-all { color: var(--ink); grid-template-columns: repeat(3, 1fr); }
.result-bar { display: flex; justify-content: space-between; margin-bottom: 2rem; padding-bottom: 1rem; border-bottom: 1px solid var(--line); font-size: .75rem; font-weight: 800; text-transform: uppercase; letter-spacing: .1em; }.result-bar a { text-decoration: underline; }
.empty-state { grid-column: 1 / -1; padding: 5rem 1rem; text-align: center; }.empty-state h2 { font-family: var(--display); font-size: 2rem; }

.product-detail { display: grid; grid-template-columns: minmax(0, 1.1fr) minmax(330px, .9fr); gap: clamp(2.5rem, 7vw, 8rem); align-items: center; }
.detail-image { position: relative; background: var(--paper-deep); }.detail-image img { width: 100%; }.detail-note { position: absolute; right: 1rem; bottom: 1rem; padding: .45rem .6rem; background: var(--surface); font-size: .6rem; font-weight: 800; letter-spacing: .1em; }
.detail-image-baseball { background: #000; }
.detail-image-baseball img { object-fit: contain; }
.breadcrumbs { display: flex; gap: .45rem; margin-bottom: 2.5rem; color: color-mix(in srgb, var(--ink) 60%, transparent); font-size: .72rem; }.breadcrumbs a { text-decoration: underline; }
.detail-copy h1 { margin-bottom: 1rem; font-family: var(--display); font-size: clamp(3rem, 6vw, 6rem); line-height: .88; letter-spacing: -.07em; }.price { font-size: 1.25rem; font-weight: 800; }.price small { margin-left: .5rem; color: color-mix(in srgb, var(--ink) 55%, transparent); font-size: .7rem; font-weight: 500; }.description { font-family: var(--serif); font-size: 1.2rem; }.feature-list { margin: 2rem 0; padding: 1.5rem 0; list-style: none; border-block: 1px solid var(--line); }.feature-list li { padding: .3rem 0; }.feature-list li::before { content: "✓"; margin-right: .7rem; color: var(--accent); font-weight: 900; }.purchase-note { margin: .8rem 0 0; text-align: center; font-size: .7rem; color: color-mix(in srgb, var(--ink) 65%, transparent); }
.related { background: var(--surface); }.related .product-grid { grid-template-columns: repeat(3, 1fr); }

.about-hero h1 { font-size: clamp(3.8rem, 8vw, 8rem); }.story-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1px; background: var(--line); padding-top: 0; padding-bottom: 0; }.story-card { padding: clamp(2rem, 4vw, 4rem); background: var(--paper); }.story-card > span { color: var(--accent); font-family: var(--display); font-size: 3rem; font-weight: 900; }.story-card h2 { font-family: var(--display); line-height: 1; }.manifesto { padding: clamp(5rem, 10vw, 10rem) clamp(1.25rem, 10vw, 12rem); background: var(--ink); color: var(--paper); text-align: center; }.manifesto > p { color: var(--gold); font-size: .72rem; font-weight: 800; letter-spacing: .2em; }.manifesto h2 { max-width: 1100px; margin: 0 auto 2.5rem; font-family: var(--serif); font-size: clamp(2rem, 4.5vw, 4.8rem); font-style: italic; line-height: 1.1; }

.launch-page { min-height: 70vh; padding: clamp(3rem, 8vw, 8rem) 1.25rem; display: grid; place-items: center; background: var(--ink); }.launch-card { width: min(760px, 100%); padding: clamp(2rem, 6vw, 6rem); background: var(--paper); box-shadow: var(--shadow); text-align: center; }.launch-card h1 { margin: 0 0 1.5rem; font-family: var(--display); font-size: clamp(3.5rem, 9vw, 7.5rem); line-height: .8; letter-spacing: -.08em; }.launch-card > p:not(.eyebrow) { max-width: 520px; margin: 0 auto 2rem; font-family: var(--serif); font-size: 1.15rem; }.launch-card .signup-band { display: block; padding: 0; background: transparent; color: var(--ink); }.launch-card .signup-band > div { display: none; }.launch-card .signup-form input { border-color: var(--ink); color: var(--ink); }.launch-card .signup-form input::placeholder { color: #777; }.launch-card .button-light { background: var(--accent); color: var(--paper); border-color: var(--accent); }.launch-card > small { display: block; margin-top: 1rem; }.thank-you .giant-check { display: grid; place-items: center; width: 80px; height: 80px; margin: 0 auto 2rem; border-radius: 50%; background: var(--accent); color: var(--paper); font-size: 2.5rem; }.thank-you h1 { font-size: clamp(3rem, 7vw, 6rem); }

.style-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.5rem; }.style-card { overflow: hidden; border: 1px solid var(--line); background: var(--surface); transition: transform .2s, box-shadow .2s; }.style-card:hover { transform: translateY(-6px); box-shadow: var(--shadow); }.style-preview { aspect-ratio: 1; display: flex; flex-direction: column; align-items: center; justify-content: center; position: relative; text-align: center; }.style-preview > span { position: absolute; top: 1rem; left: 1rem; }.style-preview strong { font-size: clamp(2.5rem, 4vw, 4rem); line-height: .8; letter-spacing: -.08em; }.style-preview i { color: var(--accent); }.style-preview small { margin-top: 1.5rem; font-size: .55rem; font-weight: 800; letter-spacing: .2em; }.style-copy { padding: 1.5rem; }.style-copy > span { color: var(--accent); font-size: .65rem; font-weight: 900; text-transform: uppercase; letter-spacing: .1em; }.style-copy h2 { margin: .4rem 0 .7rem; }.style-copy b { font-size: .76rem; }.style-vintage .style-preview { background: #f5eddd; color: #17233d; font-family: "Arial Black", sans-serif; }.style-boutique .style-preview { background: #f6f0e9; color: #201c1b; font-family: Georgia, serif; }.style-boutique .style-preview i { color: #a96d73; }.style-garage .style-preview { background: #191919; color: #eee9de; font-family: Impact, sans-serif; }.style-garage .style-preview i { color: #c72f23; }.recommendation { max-width: 1000px; text-align: center; margin: auto; }.recommendation p:last-child { max-width: 720px; margin: 1.5rem auto 0; font-size: 1.08rem; }

.blog-list { max-width: 1200px; margin: auto; }.blog-card { display: grid; grid-template-columns: .9fr 1.1fr; border: 1px solid var(--line); background: var(--surface); }.blog-card-image { min-height: 520px; display: grid; place-items: center; padding: clamp(1.5rem, 4vw, 4rem); background: #050505; }.blog-card-image img { width: 100%; }.blog-card-copy { display: flex; flex-direction: column; justify-content: center; align-items: flex-start; padding: clamp(2rem, 5vw, 5rem); }.blog-card-copy h2 { margin-bottom: 1rem; font-family: var(--display); font-size: clamp(2.3rem, 4vw, 4.5rem); line-height: .95; letter-spacing: -.06em; }.blog-card-copy > p:not(.eyebrow) { max-width: 600px; font-family: var(--serif); font-size: 1.12rem; }.article-page { padding-bottom: 7rem; }.article-header { max-width: 1100px; margin: auto; padding: clamp(5rem, 10vw, 10rem) 1.25rem clamp(3rem, 6vw, 6rem); text-align: center; }.article-header h1 { margin: 0 auto 2rem; font-family: var(--display); font-size: clamp(3.2rem, 7.5vw, 7rem); line-height: .9; letter-spacing: -.07em; }.article-meta { display: flex; justify-content: center; gap: 1.5rem; color: color-mix(in srgb, var(--ink) 60%, transparent); font-size: .72rem; font-weight: 800; text-transform: uppercase; letter-spacing: .1em; }.article-hero { width: min(900px, calc(100% - 2.5rem)); margin: 0 auto clamp(4rem, 8vw, 8rem); padding: clamp(1rem, 4vw, 4rem); background: #050505; }.article-hero img { width: 100%; }.article-body { max-width: 760px; margin: auto; padding-inline: 1.25rem; }.article-lede { margin-bottom: 4rem; font-family: var(--serif); font-size: clamp(1.6rem, 3vw, 2.35rem); font-style: italic; line-height: 1.3; }.article-body section { margin-bottom: 3.5rem; }.article-body section h2 { margin-bottom: 1.25rem; font-family: var(--display); font-size: clamp(2rem, 4vw, 3.3rem); line-height: 1; letter-spacing: -.05em; }.article-body section p { font-size: 1.08rem; line-height: 1.8; }.article-cta { margin-top: 5rem; padding: clamp(2rem, 5vw, 4rem); background: var(--accent); color: var(--paper); text-align: center; }.article-cta .eyebrow { color: var(--gold); }.article-cta h2 { font-family: var(--display); font-size: clamp(2rem, 4vw, 3.5rem); line-height: 1; }

.site-footer { display: grid; grid-template-columns: 1fr 1fr; gap: 3rem; padding: 4rem clamp(1.25rem, 6vw, 7rem) 2rem; background: #0c1322; color: #f5eddd; }.footer-brand { font-family: var(--display); font-size: clamp(2rem, 4vw, 4rem); font-weight: 900; letter-spacing: -.07em; }.footer-links { display: grid; grid-template-columns: 1fr 1fr; gap: .8rem; align-content: start; }.footer-links a { font-size: .85rem; }.footer-links a:hover { color: var(--gold); }.fine-print { grid-column: 1 / -1; margin: 2rem 0 0; padding-top: 1.5rem; border-top: 1px solid rgba(255,255,255,.16); font-size: .65rem; opacity: .65; }

body[data-theme="boutique"] .hero h1, body[data-theme="boutique"] .brand-name { letter-spacing: -.045em; }
body[data-theme="boutique"] .hero-art { background: #c9a4a5; }
body[data-theme="boutique"] .hero-art img { transform: rotate(-2deg); border-radius: 50% 50% 10px 10px; }
body[data-theme="boutique"] .collection-card:hover { background: #a96d73; }
body[data-theme="boutique"] .marquee { border-width: 1px; }
body[data-theme="garage"] { background-image: radial-gradient(rgba(0,0,0,.06) 1px, transparent 1px); background-size: 4px 4px; }
body[data-theme="garage"] .hero-art { background: #222; }
body[data-theme="garage"] .hero-art img { filter: saturate(.7) contrast(1.12); transform: rotate(2deg); }
body .hero-art.flagship-hero { background: #080808; }
body .hero-art.flagship-hero img { width: min(88%, 650px); transform: none; border-radius: 0; box-shadow: none; filter: none; }
body[data-theme="garage"] .hero h1 { text-transform: uppercase; }
body[data-theme="garage"] .collection-card:hover { background: #c72f23; }

@media (max-width: 1000px) {
  .hero { grid-template-columns: 1fr 1fr; min-height: 640px; }.hero-copy { padding-inline: 2rem; }.hero h1 { font-size: clamp(4rem, 9vw, 6rem); }.hero-art { min-height: 560px; }
  .collection-grid { grid-template-columns: repeat(2, 1fr); }.product-grid { grid-template-columns: repeat(2, 1fr); }.style-grid { grid-template-columns: 1fr; }.style-card { display: grid; grid-template-columns: 1fr 1fr; }.style-preview { aspect-ratio: auto; min-height: 350px; }.style-copy { display: flex; flex-direction: column; justify-content: center; padding: 2.5rem; }
}

@media (max-width: 720px) {
  .announcement { font-size: .56rem; }.site-header { min-height: 68px; }.brand-mark { width: 36px; height: 36px; }.brand-name { font-size: 1rem; }.menu-toggle { display: block; }.site-nav { display: none; position: absolute; left: 0; right: 0; top: 100%; padding: 1.25rem; flex-direction: column; align-items: stretch; background: var(--paper); border-bottom: 2px solid var(--ink); box-shadow: 0 10px 25px rgba(0,0,0,.12); }.site-nav.open { display: flex; }.site-nav a { padding: .6rem; }.nav-cta { text-align: center; }
  .hero { display: flex; flex-direction: column; min-height: auto; }.hero-copy { min-height: 500px; padding: 4rem 1.25rem 3rem; }.hero h1 { font-size: clamp(4.2rem, 23vw, 7rem); }.hero-lede { font-size: 1.3rem; }.button-row { width: 100%; }.button-row .button { flex: 1; }.hero-art { min-height: 460px; }.hero-art img { width: 82%; }.hero-seal { width: 96px; }
  .section { padding: 4.5rem 1.25rem; }.intro-section, .signup-band, .product-detail { grid-template-columns: 1fr; }.intro-section { gap: 2rem; }.section-heading { align-items: flex-start; flex-direction: column; }.section-heading .button { width: 100%; }.collection-grid, .collection-grid-all { grid-template-columns: 1fr; }.collection-card { min-height: 165px; }.product-grid, .related .product-grid { grid-template-columns: repeat(2, 1fr); gap: 2rem .8rem; }.product-card-copy { display: block; }.product-card-copy > span { display: block; margin-top: .35rem; }.product-card > .text-link { font-size: .7rem; }
  .signup-band { gap: 1.5rem; }.signup-form { flex-direction: column; }.signup-form .button { width: 100%; }.page-hero { padding-block: 6rem; }.page-hero h1 { font-size: 4rem; }.product-detail { padding-top: 2rem; }.breadcrumbs { margin-bottom: 1.5rem; }.detail-copy h1 { font-size: 3.3rem; }.story-grid { grid-template-columns: 1fr; }.story-card { min-height: 280px; }.style-card { display: block; }.style-preview { min-height: 320px; }.launch-card { padding-block: 3.5rem; }.site-footer { grid-template-columns: 1fr; }.fine-print { grid-column: auto; }
  .blog-card { grid-template-columns: 1fr; }.blog-card-image { min-height: auto; }.article-header { padding-top: 5rem; }.article-header h1 { font-size: 3.3rem; }.article-meta { flex-direction: column; gap: .35rem; }.article-hero { margin-bottom: 4rem; }
}

@media (max-width: 400px) {
  .brand-name { font-size: .85rem; }.brand-mark { display: none; }.product-grid, .related .product-grid { grid-template-columns: 1fr; }.product-image img { aspect-ratio: 1; }.button-row { flex-direction: column; }.button-row .button { width: 100%; }
}

@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after { scroll-behavior: auto !important; transition-duration: .01ms !important; animation-duration: .01ms !important; animation-iteration-count: 1 !important; }
}

/* 2026 flagship elevation: photo-led, shop-first, baseball-rooted */
.announcement { background: #72232e; color: #fff; border-bottom: 1px solid rgba(255,255,255,.18); }
.site-header { min-height: 86px; background: rgba(10,10,10,.97); color: #fff; border-bottom-color: rgba(255,255,255,.12); }
.brand-mark { border-color: #fff; color: #fff; }
.brand-name { letter-spacing: .02em; }
.brand-name i { color: #d7aa55; font-family: var(--body); font-size: .52em; font-style: normal; letter-spacing: .12em; vertical-align: .28em; }
.site-nav a:not(.nav-cta):hover { color: #d7aa55; }
.nav-cta { background: #8e2634; border-color: #8e2634; color: #fff; }
.nav-cta:hover { background: #fff; color: #111; }

.home-hero { min-height: 690px; display: grid; grid-template-columns: minmax(420px, .84fr) minmax(460px, 1.16fr); position: relative; overflow: hidden; background: #090909; color: #fff; }
.home-hero-photo { grid-column: 2; grid-row: 1; min-height: 690px; background: #171717 url('/assets/proud-and-broke-baseball-dad-field.png') center 23% / cover no-repeat; position: relative; }
.home-hero-photo::after { content: ""; position: absolute; inset: 0; background: linear-gradient(90deg, #090909 0%, rgba(9,9,9,.68) 17%, rgba(9,9,9,.08) 54%, rgba(9,9,9,.12) 100%), linear-gradient(0deg, rgba(9,9,9,.36), transparent 44%); }
.home-hero-copy { grid-column: 1; grid-row: 1; z-index: 2; display: flex; flex-direction: column; align-items: flex-start; justify-content: center; padding: clamp(4rem, 7vw, 7.5rem) clamp(1.5rem, 5vw, 5.5rem); }
.home-hero-copy .eyebrow { color: #d7aa55; }
.home-hero h1 { margin: 0 0 1.25rem; font-family: var(--display); font-size: clamp(4.6rem, 8.5vw, 9rem); line-height: .76; letter-spacing: -.075em; }
.home-hero h1 span { display: inline-block; color: #c14a57; font-family: var(--body); font-size: .22em; letter-spacing: .18em; vertical-align: .62em; }
.home-hero .hero-lede { max-width: 600px; color: #fff; font-family: var(--serif); font-size: clamp(1.45rem, 2.3vw, 2.25rem); }
.home-hero-note { max-width: 540px; color: rgba(255,255,255,.75); }
.button-accent { background: #8e2634; border-color: #8e2634; color: #fff; }
.button-outline-light { background: transparent; border-color: #fff; color: #fff; }
.button-outline-light:hover { background: #fff; color: #111; box-shadow: 4px 4px 0 #8e2634; }

.shop-shortcuts { display: grid; grid-template-columns: repeat(3, 1fr); background: #8e2634; color: #fff; border-bottom: 1px solid rgba(255,255,255,.18); }
.shop-shortcuts a { min-height: 126px; display: grid; grid-template-columns: auto 1fr; grid-template-rows: 1fr 1fr; column-gap: 1rem; align-content: center; padding: 1.6rem clamp(1rem, 3vw, 3rem); border-right: 1px solid rgba(255,255,255,.25); transition: background .2s, color .2s; }
.shop-shortcuts a:last-child { border-right: 0; }
.shop-shortcuts a:hover { background: #fff; color: #111; }
.shop-shortcuts span { grid-row: 1 / 3; align-self: center; color: #e4bc70; font-family: var(--display); font-size: 2.3rem; }
.shop-shortcuts a:hover span { color: #8e2634; }
.shop-shortcuts strong { align-self: end; font-family: var(--display); font-size: clamp(1.2rem, 2vw, 1.8rem); text-transform: uppercase; }
.shop-shortcuts small { opacity: .75; font-size: .72rem; text-transform: uppercase; letter-spacing: .12em; }

.flagship-shop { background: #f4efe6; }
.flagship-shop .section-heading { align-items: flex-end; }
.section-intro { max-width: 620px; margin: 1rem 0 0; color: rgba(23,35,61,.7); font-family: var(--serif); font-size: 1.1rem; }
.product-grid-three { grid-template-columns: repeat(3, 1fr); }
.collection-product-grid { grid-template-columns: repeat(3, 1fr); }
.flagship-shop .product-card { padding-bottom: 1rem; }
.flagship-shop .product-image { background: #fff; border: 1px solid rgba(17,17,17,.08); }
.flagship-shop .product-image img { aspect-ratio: 1; object-fit: contain; }
.flagship-shop .product-card:nth-child(-n+2) .product-image { background: #050505; }
.flagship-shop .product-stamp { background: #8e2634; color: #fff; }
.flagship-shop .product-card-copy h3 { font-size: clamp(1rem, 1.5vw, 1.25rem); }
.product-card-actions { display: flex; align-items: center; justify-content: space-between; gap: .8rem; margin-top: 1rem; }
.product-card-actions .text-link { margin: 0; }
.card-buy { padding: .65rem .8rem; background: #111; color: #fff; font-size: .68rem; font-weight: 800; text-transform: uppercase; letter-spacing: .06em; }
.card-buy:hover { background: #8e2634; }

.flagship-story { display: grid; grid-template-columns: 1fr 1fr; background: #111; color: #fff; }
.flagship-story-art { min-height: 620px; display: grid; place-items: center; padding: clamp(2rem, 6vw, 6rem); background: #030303; }
.flagship-story-art img { width: min(100%, 620px); }
.flagship-story-copy { display: flex; flex-direction: column; align-items: flex-start; justify-content: center; padding: clamp(3.5rem, 8vw, 8rem); background: linear-gradient(135deg, #72232e, #9b2c3b); }
.flagship-story-copy .eyebrow { color: #e4bc70; }
.flagship-story-copy h2 { margin-bottom: 2rem; font-family: var(--display); font-size: clamp(2.8rem, 5vw, 5.8rem); line-height: .9; letter-spacing: -.06em; }
.flagship-story-copy p { max-width: 650px; font-size: 1.05rem; }
.text-link-light { color: #fff; }

.parent-blog-feature { display: grid; grid-template-columns: .88fr 1.12fr; align-items: stretch; padding-top: 0; padding-bottom: 0; background: #e3d8c5; }
.parent-blog-photo { min-height: 650px; overflow: hidden; }
.parent-blog-photo img { width: 100%; height: 100%; object-fit: cover; object-position: center 18%; }
.parent-blog-copy { display: flex; flex-direction: column; align-items: flex-start; justify-content: center; padding: clamp(3rem, 8vw, 8rem); }
.parent-blog-copy h2 { margin-bottom: 1.5rem; font-family: var(--display); font-size: clamp(3rem, 5.5vw, 6rem); line-height: .88; letter-spacing: -.07em; }
.parent-blog-copy > p:not(.eyebrow) { max-width: 620px; font-family: var(--serif); font-size: 1.18rem; }

.home-faq { background: #f7f3eb; }
.faq-list { max-width: 980px; margin: auto; border-top: 1px solid var(--ink); }
.faq-list details, .article-faq details { border-bottom: 1px solid var(--line); }
.faq-list summary, .article-faq summary { position: relative; padding: 1.5rem 3rem 1.5rem 0; cursor: pointer; list-style: none; font-family: var(--display); font-size: clamp(1.05rem, 2vw, 1.45rem); }
.faq-list summary::-webkit-details-marker, .article-faq summary::-webkit-details-marker { display: none; }
.faq-list summary::after, .article-faq summary::after { content: "+"; position: absolute; right: .25rem; color: #8e2634; font-size: 1.6rem; }
.faq-list details[open] summary::after, .article-faq details[open] summary::after { content: "−"; }
.faq-list details p, .article-faq details p { max-width: 760px; padding: 0 0 1.5rem; color: rgba(23,35,61,.76); }
.future-collections { background: #111; }

.detail-gallery { display: grid; grid-template-columns: 1fr 1fr; gap: .8rem; align-self: start; }
.detail-gallery figure { margin: 0; position: relative; overflow: hidden; background: #fff; border: 1px solid var(--line); }
.detail-gallery .detail-image-main { grid-column: 1 / -1; background: #050505; }
.detail-gallery img { width: 100%; height: 100%; aspect-ratio: 1; object-fit: contain; }
.detail-gallery figure:not(.detail-image-main) img { aspect-ratio: 1; object-fit: cover; }
.detail-copy { position: sticky; top: 130px; }

.quick-answer { margin: 0 0 4rem; padding: 1.8rem 2rem; border-left: 5px solid #8e2634; background: #ece3d4; }
.quick-answer strong { display: block; margin-bottom: .55rem; color: #8e2634; font-size: .72rem; text-transform: uppercase; letter-spacing: .14em; }
.quick-answer p { margin: 0; font-size: 1.05rem; line-height: 1.7; }
.article-faq { margin-top: 5rem; padding-top: 3rem; border-top: 4px solid var(--ink); }
.article-faq > h2 { font-family: var(--display); font-size: clamp(2.3rem, 4vw, 3.7rem); line-height: .95; }

@media (max-width: 900px) {
  .site-header { min-height: 72px; }
  .home-hero { grid-template-columns: minmax(330px, .9fr) minmax(340px, 1.1fr); min-height: 620px; }
  .home-hero-photo { min-height: 620px; }
  .home-hero-copy { padding-inline: 2rem; }
  .home-hero h1 { font-size: clamp(4.1rem, 9vw, 6.4rem); }
  .product-grid-three { grid-template-columns: repeat(3, 1fr); }
  .flagship-story-art { min-height: 520px; }
  .parent-blog-feature { grid-template-columns: 1fr 1fr; }
}

@media (max-width: 720px) {
  .site-header { background: #0a0a0a; }
  .menu-toggle { border-color: #fff; color: #fff; }
  .site-nav { background: #0a0a0a; color: #fff; border-bottom-color: #8e2634; }
  .home-hero { min-height: 710px; display: block; }
  .home-hero-photo { position: absolute; inset: 0; min-height: 710px; background-position: center 16%; }
  .home-hero-photo::after { background: linear-gradient(0deg, #090909 0%, rgba(9,9,9,.82) 35%, rgba(9,9,9,.18) 72%, rgba(9,9,9,.12) 100%); }
  .home-hero-copy { position: relative; min-height: 710px; justify-content: flex-end; padding: 4rem 1.25rem 3.5rem; }
  .home-hero h1 { font-size: clamp(4.2rem, 20vw, 6.2rem); }
  .home-hero .hero-lede { font-size: 1.35rem; }
  .home-hero-note { font-size: .9rem; }
  .shop-shortcuts { grid-template-columns: 1fr; }
  .shop-shortcuts a { min-height: 92px; border-right: 0; border-bottom: 1px solid rgba(255,255,255,.25); }
  .product-grid-three { grid-template-columns: 1fr; gap: 3rem; }
  .collection-product-grid { grid-template-columns: 1fr; }
  .flagship-shop .product-card-copy { display: flex; }
  .product-card-actions { align-items: stretch; flex-direction: column; }
  .card-buy { text-align: center; }
  .flagship-story { grid-template-columns: 1fr; }
  .flagship-story-art { min-height: auto; }
  .flagship-story-copy { padding: 4.5rem 1.25rem; }
  .parent-blog-feature { grid-template-columns: 1fr; padding-inline: 0; }
  .parent-blog-photo { min-height: 520px; }
  .parent-blog-copy { padding: 4.5rem 1.25rem; }
  .detail-gallery { gap: .4rem; }
  .detail-copy { position: static; }
}
