
:root {
  --bg: #F4F1EA;
  --surface: #FBF9F4;
  --surface-2: #F0EBE0;
  --surface-3: #E8E1D2;
  --ink: #2A241C;
  --ink-soft: #4A4236;
  --muted: #7A7060;
  --muted-2: #A89E8C;
  --gold: #B08D3C;
  --gold-deep: #8A6E2E;
  --line: #E2DBCC;
  --dark: #1a1712;
  --display: 'Fraunces', Georgia, serif;
  --body: 'Outfit', -apple-system, sans-serif;
  --radius: 14px;
  --radius-sm: 10px;
}
* { margin: 0; padding: 0; box-sizing: border-box; }
/* ── Global rounded-corner system (high-tech look) ── */
.hood-card, .slide-card, .testi-card,
.hp-stage, .hp-3d-canvas-wrap, .hp-photo-pane, .hp-video-pane,
.hp-gallery-main, .hero-visual,
.cart-item-img, .hp-faq, .partner-card, .qs-card,
.field-input, .hp-finish-select, .hp-size-opt, .hp-add,
.btn, .hp-fixed-size, .tl-btn, .tl-input, .tl-modal,
.partner-form-card, .contact-form-card,
.pf-field input, .pf-field textarea,
.hp-thumb { border-radius: var(--radius); }
.hp-thumb, .cart-item-img, .hp-size-opt, .field-input, .hp-finish-select,
.pf-field input, .pf-field textarea, .tl-input, .hp-fixed-size,
.hp-faq-media img, .faqp-media img { border-radius: var(--radius-sm); }
input, textarea, select, button { border-radius: var(--radius-sm); }
img { border-radius: var(--radius-sm); }
html { scroll-behavior: smooth; zoom: 0.85; }
body { background: var(--bg); color: var(--ink); font-family: var(--body); font-weight: 300; line-height: 1.6; -webkit-font-smoothing: antialiased; overflow-x: hidden; display: flex; flex-direction: column; min-height: 117.65vh; }
a { color: inherit; text-decoration: none; }
img { max-width: 100%; display: block; }

/* PROMO BANNER */
.promo-bar { background: var(--gold); color: #fff; text-align: center; padding: 18px 16px; font-size: 13px; letter-spacing: 0.4px; font-weight: 400; position: relative; z-index: 200; }
.promo-bar strong { font-weight: 600; margin-left: 6px; border: 1px dashed rgba(255,255,255,0.5); padding: 2px 8px; border-radius: 3px; }

/* HEADER */
.site-header { position: sticky; top: 0; z-index: 150; background: rgba(244,241,234,0.85); backdrop-filter: blur(12px); border-bottom: 1px solid var(--line); }
.header-inner { max-width: 100%; margin: 0 auto; padding: clamp(16px, 1.6vw, 28px) clamp(24px, 4vw, 80px); display: flex; align-items: center; justify-content: space-between; }
.logo { font-family: var(--display); color: var(--ink); display: inline-flex; align-items: center; gap: 12px; cursor: pointer; transition: opacity 0.2s; text-decoration: none; }
.logo:hover { opacity: 0.7; }
.logo-lockup { display: inline-flex; flex-direction: column; line-height: 1.1; }
.logo-name { font-family: var(--display); font-size: clamp(22px, 1.9vw, 34px); font-weight: 600; letter-spacing: -0.5px; color: var(--ink); }
.logo-desc { font-family: var(--display); font-style: italic; color: var(--gold); font-size: clamp(11px, 0.85vw, 15px); letter-spacing: 0.2px; margin-top: 1px; }
.logo-name { color: var(--ink) !important; }
.logo-mark { display: none; width: 110px; height: 46px; background-size: contain; background-repeat: no-repeat; background-position: left center; flex-shrink: 0; }
.logo-mark.show { display: inline-block; }
.footer-logo-mark { display: none; width: 100px; height: 42px; background-size: contain; background-repeat: no-repeat; background-position: left center; flex-shrink: 0; vertical-align: middle; margin-right: 12px; }
.footer-logo-mark.show { display: inline-block; }
.nav { display: flex; gap: clamp(24px, 2.4vw, 48px); }
.nav a { font-size: clamp(13px, 1.05vw, 18px); letter-spacing: 1px; text-transform: uppercase; font-weight: 400; color: var(--ink-soft); transition: color 0.2s; position: relative; }
.nav a::after { content: ''; position: absolute; left: 0; bottom: -4px; width: 0; height: 1px; background: var(--gold); transition: width 0.25s; }
.nav a:hover { color: var(--gold); }
.nav a:hover::after { width: 100%; }
.header-cart { font-size: clamp(13px, 0.85vw, 15px); letter-spacing: 1px; text-transform: uppercase; color: var(--ink-soft); display: flex; align-items: center; gap: 6px; }
.header-actions { display: flex; align-items: center; gap: clamp(16px, 1.5vw, 28px); }
.header-account { background: none; border: none; cursor: pointer; color: var(--ink-soft); display: flex; align-items: center; padding: 0; transition: color 0.2s; }
.header-account:hover { color: var(--gold); }
.menu-toggle { display: none; background: none; border: none; cursor: pointer; font-size: 22px; color: var(--ink); }
.mobile-nav { position: fixed; top: 0; left: 0; height: 100%; width: 290px; max-width: 84vw; background: var(--surface); z-index: 320; transform: translateX(-100%); transition: transform 0.3s cubic-bezier(.4,0,.2,1); display: flex; flex-direction: column; padding: 76px 32px 32px; box-shadow: 10px 0 40px rgba(0,0,0,0.14); }
.mobile-nav.open { transform: translateX(0); }
.mobile-nav a { font-size: 15px; letter-spacing: 1px; text-transform: uppercase; color: var(--ink); padding: 16px 0; border-bottom: 1px solid var(--line); transition: color 0.2s; }
.mobile-nav a:hover { color: var(--gold); }
.mobile-nav .mobile-nav-account { margin-top: 18px; border-bottom: none; color: var(--gold-deep, var(--gold)); }
.mobile-nav-close { position: absolute; top: 24px; left: 28px; background: none; border: none; font-size: 30px; line-height: 1; color: var(--ink); cursor: pointer; padding: 0; }
.mobile-nav-overlay { position: fixed; inset: 0; background: rgba(0,0,0,0.4); opacity: 0; visibility: hidden; transition: opacity 0.3s; z-index: 315; }
.mobile-nav-overlay.open { opacity: 1; visibility: visible; }

/* HERO — split layout */
.hero-split { display: grid; grid-template-columns: 1fr 1fr; min-height: 620px; align-items: stretch; }
.hero-split-img { position: relative; overflow: hidden; background: linear-gradient(145deg, var(--surface-3), var(--surface-2)); }
.hero-split-img img { width: 100%; height: 100%; object-fit: cover; display: block; }
.hero-split-img .hero-visual-placeholder { width: 100%; height: 100%; min-height: 360px; display: flex; align-items: center; justify-content: center; color: var(--muted-2); font-size: 13px; letter-spacing: 1px; }
.hero-split-panel { background: var(--ink); color: var(--bg); display: flex; flex-direction: column; justify-content: center; padding: 56px clamp(36px, 5vw, 80px); }
.hero-split-panel .canada-badge { background: rgba(255,255,255,0.08); border: 1px solid rgba(255,255,255,0.18); margin-bottom: 28px; align-self: flex-start; }
.hero-split-panel .canada-badge span { color: rgba(255,255,255,0.85); }
.hero-split-panel h1 { font-family: var(--display); font-size: clamp(32px, 3.4vw, 52px); line-height: 1.1; font-weight: 500; letter-spacing: -1px; margin-bottom: 22px; color: #fff; }
.hero-split-panel h1 em { font-style: italic; color: var(--gold); }
.hero-split-panel p { font-size: 17px; color: rgba(255,255,255,0.72); max-width: 46ch; line-height: 1.7; margin-bottom: 34px; }
.hero-split-cta { display: flex; gap: 14px; flex-wrap: wrap; }
.btn-gold-solid { background: var(--gold); color: var(--ink); border: none; }
.btn-gold-solid:hover { background: #fff; }
.btn-ghost-light { background: transparent; color: #fff; border: 1px solid rgba(255,255,255,0.4); }
.btn-ghost-light:hover { background: #fff; color: var(--ink); }
/* HERO — steps strip */
.hero-steps { display: grid; grid-template-columns: repeat(3, 1fr); background: var(--ink); border-top: 1px solid rgba(255,255,255,0.12); }
.hero-step { display: flex; align-items: center; justify-content: center; gap: 14px; padding: 26px 20px; color: rgba(255,255,255,0.9); transition: background 0.2s; border-right: 1px solid rgba(255,255,255,0.12); }
.hero-step:last-child { border-right: none; }
.hero-step:hover { background: rgba(255,255,255,0.05); }
.hero-step-num { font-family: var(--display); font-size: 22px; color: var(--gold); font-style: italic; }
.hero-step-text { font-size: 15px; letter-spacing: 0.5px; }
@media (max-width: 860px){
  .hero-split { grid-template-columns: 1fr; }
  .hero-split-img { min-height: 0; }
  .hero-split-img img { height: auto; }
  .hero-steps { grid-template-columns: 1fr; }
  .hero-step { border-right: none; border-bottom: 1px solid rgba(255,255,255,0.12); justify-content: flex-start; padding-left: 36px; }
}
/* FEATURE — flipped split, warm taupe panel */
.feature-split { display: grid; grid-template-columns: 1fr 1fr; align-items: stretch; }
.feature-split-img { background-color: var(--surface-3); overflow: hidden; }
.feature-split-img img { width: 100%; height: auto; display: block; }
.feature-split-panel { background: #6f6358; color: #fff; display: flex; flex-direction: column; justify-content: center; padding: 56px clamp(36px, 5vw, 80px); overflow: auto; }
.feature-split-panel h2 { font-family: var(--display); font-size: clamp(28px, 3vw, 44px); line-height: 1.12; font-weight: 500; letter-spacing: -0.5px; margin-bottom: 20px; color: #fff; }
.feature-split-panel h2 em { font-style: italic; color: var(--gold); }
.feature-split-panel p { font-size: 17px; color: rgba(255,255,255,0.82); max-width: 48ch; line-height: 1.7; margin-bottom: 30px; }
.feature-split-panel .btn-gold-solid { align-self: flex-start; }
@media (max-width: 860px){
  .feature-split { grid-template-columns: 1fr; }
  .feature-split-panel { order: 2; }
  .feature-split-img { order: 1; }
  .feature-split-img img { height: auto; }
}
@media (max-width: 560px){
  .hero-split-panel, .feature-split-panel { padding: 40px 26px; }
  .hero-split-cta { gap: 10px; }
  .hero-split-cta .btn, .feature-split-panel .btn { width: 100%; text-align: center; justify-content: center; }
}
.canada-badge { display: inline-flex; align-items: center; gap: 9px; background: var(--surface); border: 1px solid var(--line); padding: 8px 18px; border-radius: 40px; margin-bottom: 32px; }
.canada-badge svg { border-radius: 2px; flex-shrink: 0; }
.canada-badge span { font-size: 12px; letter-spacing: 1.5px; text-transform: uppercase; color: var(--ink-soft); font-weight: 500; }
.hero h1 { font-family: var(--display); font-size: clamp(34px, 4.4vw, 60px); line-height: 1.08; font-weight: 500; letter-spacing: -1.5px; color: var(--ink); margin-bottom: 28px; max-width: 20ch; margin-left: auto; margin-right: auto; }
.hero h1 em { font-style: italic; color: var(--gold-deep); }
.hero p { font-size: 18px; color: var(--ink-soft); max-width: 540px; margin: 0 auto 38px; line-height: 1.7; }
.hero-cta { display: flex; gap: 16px; align-items: center; justify-content: center; margin-bottom: 64px; }
.btn { display: inline-block; font-family: var(--body); font-size: 13px; letter-spacing: 1.2px; text-transform: uppercase; font-weight: 500; padding: 15px 32px; cursor: pointer; border: none; transition: all 0.25s; }
.btn-primary { background: var(--ink); color: var(--bg); }
.btn-primary:hover { background: var(--gold); }
.btn-ghost { background: transparent; color: var(--ink); border: 1px solid var(--ink); }
.btn-ghost:hover { background: var(--ink); color: var(--bg); }
.hero-visual { position: relative; width: 100%; aspect-ratio: 16/9; background: linear-gradient(145deg, var(--surface-3), var(--surface-2)); overflow: hidden; }
.hero-visual img { width: 100%; height: 100%; object-fit: cover; }
.hero-visual-placeholder { width: 100%; height: 100%; display: flex; align-items: center; justify-content: center; color: var(--muted-2); font-size: 13px; letter-spacing: 1px; }

/* SECTION */
.section { max-width: 100%; margin: 0 auto; padding: 80px 40px; }
/* MOST POPULAR SLIDER */
.popular { padding: 60px 0 70px; overflow: hidden; }
.popular-head { text-align: center; margin-bottom: 40px; padding: 0 40px; }
.slider-viewport { overflow: hidden; cursor: grab; -webkit-user-select: none; user-select: none; }
.slider-viewport.dragging { cursor: grabbing; }
.slider-track { display: flex; gap: 24px; padding: 0 40px; width: max-content; }
.slider-track.animate { animation: slide-loop 60s linear infinite; }
.slider-viewport:hover .slider-track.animate, .slider-viewport.dragging .slider-track.animate { animation-play-state: paused; }
@keyframes slide-loop { from { transform: translateX(0); } to { transform: translateX(var(--slide-dist, -50%)); } }
.slide-card { flex: 0 0 300px; background: var(--surface); border: 1px solid var(--line); overflow: hidden; transition: transform 0.3s, box-shadow 0.3s; }
.slide-card:hover { transform: translateY(-5px); box-shadow: 0 18px 40px rgba(42,36,28,0.1); }
.slide-card-img { aspect-ratio: 4/3; background: var(--surface-3); background-size: cover; background-position: center; position: relative; }
.slide-card-img-ph { width:100%; height:100%; display:flex; align-items:center; justify-content:center; color:var(--muted-2); font-size:12px; letter-spacing:1px; }
.slide-card-sale { position:absolute; top:12px; left:12px; background:var(--gold); color:#fff; font-size:9px; font-weight:600; letter-spacing:1px; text-transform:uppercase; padding:4px 9px; }
.slide-card-body { padding: 20px; }
.slide-card-name { font-family: var(--display); font-size: 20px; font-weight: 500; color: var(--ink); margin-bottom: 5px; }
.slide-card-price { font-size: 14px; color: var(--muted); }
.slide-card-price .now { color: var(--ink); font-weight: 500; }
.slide-card-price .was { text-decoration: line-through; margin-right: 6px; color: var(--muted-2); }
.section-head { text-align: center; margin-bottom: 56px; }
.section-eyebrow { font-size: 12px; letter-spacing: 3px; text-transform: uppercase; color: var(--gold); font-weight: 500; margin-bottom: 14px; }
.section-title { font-family: var(--display); font-size: clamp(30px, 4vw, 46px); font-weight: 500; letter-spacing: -1px; color: var(--ink); }
.section-sub { font-size: 16px; color: var(--muted); max-width: 540px; margin: 16px auto 0; }

/* HOOD GRID */
.hood-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 30px; }
.hood-card { background: var(--surface); border: 1px solid var(--line); overflow: hidden; transition: transform 0.3s, box-shadow 0.3s; cursor: pointer; }
.hood-card:hover { transform: translateY(-5px); box-shadow: 0 18px 40px rgba(42,36,28,0.1); }
.hood-card-img { aspect-ratio: 4/3; background: var(--surface-3); background-size: cover; background-position: center; position: relative; }
.hood-card-img-placeholder { width: 100%; height: 100%; display: flex; align-items: center; justify-content: center; color: var(--muted-2); font-size: 12px; letter-spacing: 1px; }
.hood-card-sale { position: absolute; top: 14px; left: 14px; background: var(--gold); color: #fff; font-size: 10px; font-weight: 600; letter-spacing: 1px; text-transform: uppercase; padding: 5px 11px; }
.hood-card-body { padding: 24px; }
.hood-card-name { font-family: var(--display); font-size: 22px; font-weight: 500; color: var(--ink); margin-bottom: 6px; }
.hood-card-desc { font-size: 14px; color: var(--muted); margin-bottom: 16px; line-height: 1.6; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }
.hood-card-foot { display: flex; align-items: center; justify-content: space-between; }
.hood-card-price { font-size: 16px; color: var(--ink); font-weight: 500; }
.hood-card-price .from { font-size: 12px; color: var(--muted); font-weight: 300; margin-right: 4px; }
.hood-card-price .was { text-decoration: line-through; color: var(--muted-2); margin-right: 8px; font-weight: 300; }
.hood-card-arrow { font-size: 18px; color: var(--gold); transition: transform 0.2s; }
.hood-card:hover .hood-card-arrow { transform: translateX(4px); }

/* STORY STRIP */
.story { background: var(--dark); color: var(--surface); }
.story-inner { max-width: 100%; margin: 0 auto; padding: 90px 40px; display: grid; grid-template-columns: repeat(3, 1fr); gap: 50px; }
.story-item-num { font-family: var(--display); font-size: 15px; color: var(--gold); margin-bottom: 18px; font-style: italic; }
.story-item h3 { font-family: var(--display); font-size: 24px; font-weight: 500; color: #fff; margin-bottom: 12px; }
.story-item p { font-size: 15px; color: rgba(232,225,210,0.7); line-height: 1.7; }

/* TESTIMONIALS */
.testi-section { background: var(--surface-2); }
.testi-row { display: grid; grid-template-columns: repeat(3, 1fr); gap: 28px; }
.testi-card { background: var(--surface); padding: 32px; border: 1px solid var(--line); }
.testi-stars { color: var(--gold); font-size: 15px; letter-spacing: 3px; margin-bottom: 18px; }
.testi-quote { font-family: var(--display); font-size: 19px; line-height: 1.5; color: var(--ink); font-style: italic; margin-bottom: 20px; }
.testi-author { font-size: 13px; letter-spacing: 0.5px; color: var(--muted); font-weight: 400; }
.testi-author strong { color: var(--ink); font-weight: 600; display: block; }

/* FOOTER */
.site-footer { background: #E7DFCE; color: var(--ink-soft); padding: 30px clamp(24px, 4vw, 80px) 18px; border-top: 1px solid var(--line); margin-top: auto; }
.footer-inner { max-width: 100%; margin: 0 auto; }
.footer-row { display: grid; grid-template-columns: 1fr auto 1fr; align-items: center; gap: 24px; margin-bottom: 16px; }
.footer-brand-name { font-family: var(--display); font-size: clamp(22px, 1.9vw, 34px); font-weight: 600; color: var(--ink); display: inline-flex; align-items: center; justify-self: start; }
.footer-lockup { display: inline-flex; flex-direction: column; line-height: 1.1; }
.footer-brand-main { font-family: var(--display); font-size: clamp(22px, 1.9vw, 34px); font-weight: 600; color: var(--ink); }
.footer-brand-desc { font-family: var(--display); font-style: italic; color: var(--gold-deep, var(--gold)); font-size: clamp(11px, 0.85vw, 15px); letter-spacing: 0.2px; margin-top: 1px; }
.footer-links { display: flex; flex-wrap: wrap; justify-content: center; gap: 8px 26px; }
.footer-links a { font-size: clamp(12px, 1.0vw, 17px); letter-spacing: 1px; text-transform: uppercase; color: var(--ink-soft); transition: color 0.2s; }
.footer-links a:hover { color: var(--gold); }
.footer-socials { display: flex; gap: 18px; justify-self: end; }
.footer-socials a { color: var(--gold); display: inline-flex; transition: transform 0.2s; }
.footer-socials a:hover { transform: translateY(-2px); }
.footer-meta { display: flex; flex-wrap: wrap; justify-content: center; gap: 6px 18px; font-size: 12px; color: var(--muted); margin-bottom: 14px; }
.footer-meta span:empty { display: none; }
.footer-copy-row { display: flex; justify-content: center; align-items: center; gap: 6px 20px; flex-wrap: wrap; font-size: 11px; color: var(--muted); border-top: 1px solid var(--line); padding-top: 14px; }
.footer-copy-row a { color: var(--muted); }
.footer-logo-mark.show + span,
.footer-brand-name .footer-logo-mark.show { vertical-align: middle; }

/* INDIVIDUAL HOOD PAGE */
.hp-wrap { max-width: 100%; margin: 0 auto; padding: 30px 40px 80px; }
.hp-breadcrumb { font-size: 13px; color: var(--muted); margin-bottom: 30px; letter-spacing: 0.3px; }
.hp-breadcrumb a { color: var(--muted); }
.hp-breadcrumb a:hover { color: var(--gold); }
.hp-top { display: grid; grid-template-columns: 1fr 1fr; gap: 56px; align-items: start; }
.hp-gallery-main { aspect-ratio: 4/3; background: var(--surface-3); background-size: cover; background-position: center; margin-bottom: 14px; position: relative; overflow: hidden; }
.hp-gallery-main-ph { width:100%; height:100%; display:flex; align-items:center; justify-content:center; color:var(--muted-2); font-size:13px; letter-spacing:1px; }
.hp-stage { position: relative; aspect-ratio: 4/3; margin-bottom: 14px; overflow: hidden; background: var(--bg); }
.hp-3d-canvas-wrap { display: none; position: absolute; inset: 0; background: #14110E; }
.hp-3d-canvas-wrap.active { display: block; }
.hp-3d-canvas-wrap, .hp-photo-pane, .hp-video-pane { border-radius: 0 !important; }
.hp-3d-canvas-wrap canvas { width: 100%; height: 100%; display: block; cursor: grab; }
.hp-3d-canvas-wrap canvas:active { cursor: grabbing; }
.hp-photo-pane { display: none; position: absolute; inset: 0; background-size: cover; background-position: center; background-color: var(--surface-3); }
.hp-photo-pane.active { display: block; }
.hp-video-pane { display: none; position: absolute; inset: 0; background: #000; }
.hp-video-pane.active { display: block; }
.hp-video-pane iframe { width: 100%; height: 100%; border: 0; display: block; }
.hp-thumb-video { position: relative; }
.hp-thumb-play { position: absolute; inset: 0; display: flex; align-items: center; justify-content: center; color: #fff; font-size: 20px; text-shadow: 0 2px 6px rgba(0,0,0,0.7); pointer-events: none; }
.hp-photo-pane.active { display: block; }
.hp-3d-hint { position: absolute; bottom: 12px; left: 0; right: 0; text-align: center; color: rgba(255,255,255,0.5); font-size: 11px; letter-spacing: 1px; pointer-events: none; z-index: 3; }
.hp-3d-nomodel { display: none; position: absolute; inset: 0; z-index: 5; background: #14110E; align-items: center; justify-content: center; }
.hp-3d-nomodel-inner { text-align: center; color: var(--gold); display: flex; flex-direction: column; align-items: center; gap: 12px; font-size: 30px; }
.hp-3d-nomodel-inner span { color: rgba(255,255,255,0.7); font-size: 14px; letter-spacing: 1px; max-width: 220px; line-height: 1.5; }
.hp-arrow { position: absolute; top: 50%; transform: translateY(-50%); z-index: 4; width: 42px; height: 42px; border-radius: 50%; border: none; background: rgba(251,249,244,0.9); color: var(--ink); font-size: 24px; line-height: 1; cursor: pointer; display: flex; align-items: center; justify-content: center; transition: background 0.2s; box-shadow: 0 2px 10px rgba(0,0,0,0.15); }
.hp-arrow:hover { background: var(--gold); color: #fff; }
.hp-arrow-prev { left: 14px; }
.hp-arrow-next { right: 14px; }
.hp-thumbs { display: flex; gap: 10px; flex-wrap: wrap; }
.hp-thumb { width: 76px; height: 76px; background-size: cover; background-position: center; background-color: var(--surface-3); cursor: pointer; border: 2px solid transparent; transition: border-color 0.2s; }
.hp-thumb.active { border-color: var(--gold); }
.hp-thumb-3d { background: #14110E; display: flex; align-items: center; justify-content: center; }
.hp-thumb-3d-label { color: var(--gold); font-size: 12px; letter-spacing: 1px; font-weight: 500; }
.hp-info { padding-top: 4px; }
.hp-eyebrow { font-size: 12px; letter-spacing: 3px; text-transform: uppercase; color: var(--gold); font-weight: 500; margin-bottom: 14px; }
.hp-title { font-family: var(--display); font-size: clamp(34px, 5vw, 52px); font-weight: 500; letter-spacing: -1px; line-height: 1.05; color: var(--ink); margin-bottom: 18px; }
.hp-desc { font-size: 16px; color: var(--ink-soft); line-height: 1.7; margin-bottom: 30px; }
.hp-desc-link { color: var(--gold); text-decoration: underline; word-break: break-all; }
.hp-desc-link:hover { opacity: 0.8; }
.hp-price-block { padding: 24px 0; border-top: 1px solid var(--line); border-bottom: 1px solid var(--line); margin-bottom: 30px; }
.hp-price-label { font-size: 11px; letter-spacing: 2px; text-transform: uppercase; color: var(--muted); margin-bottom: 8px; }
.hp-price { font-family: var(--display); font-size: 38px; font-weight: 500; color: var(--ink); }
.hp-price .was { font-size: 24px; text-decoration: line-through; color: var(--muted-2); margin-right: 14px; }
.hp-price .sale-tag { display: inline-block; background: var(--gold); color: #fff; font-family: var(--body); font-size: 11px; font-weight: 600; letter-spacing: 1px; text-transform: uppercase; padding: 4px 10px; margin-left: 12px; vertical-align: middle; }
.hp-price-hint { font-size: 13px; color: var(--muted); margin-top: 8px; }
.hp-selector-label { font-size: 11px; letter-spacing: 2px; text-transform: uppercase; color: var(--muted); margin-bottom: 12px; }
.hp-size-row { margin-bottom: 24px; }
.hp-size-opts { display: flex; flex-wrap: wrap; gap: 10px; }
.hp-size-opt { min-width: 56px; text-align: center; padding: 12px 16px; border: 1px solid var(--line); background: var(--surface); font-size: 15px; color: var(--ink); cursor: pointer; transition: all 0.18s; }
.hp-finish-select { width: 100%; max-width: 340px; padding: 12px 14px; border: 1px solid var(--line); background: var(--surface); font-size: 15px; color: var(--ink); font-family: inherit; cursor: pointer; border-radius: var(--radius-sm); appearance: none; -webkit-appearance: none; background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath fill='%23999' d='M6 8L0 0h12z'/%3E%3C/svg%3E"); background-repeat: no-repeat; background-position: right 14px center; padding-right: 36px; }
.hp-finish-select:focus { outline: none; border-color: var(--gold); }
.hp-size-opt:hover { border-color: var(--gold); }
.hp-size-opt.active { background: var(--ink); color: var(--bg); border-color: var(--ink); }
.hp-cta-row { display: flex; gap: 14px; align-items: center; margin-top: 8px; }
.hp-add { flex: 1; background: var(--ink); color: var(--bg); border: none; font-family: var(--body); font-size: 14px; letter-spacing: 1.2px; text-transform: uppercase; font-weight: 500; padding: 18px; cursor: pointer; transition: background 0.2s; }
.hp-add:hover { background: var(--gold); }
.hp-add:disabled { background: var(--surface-3); color: var(--muted-2); cursor: not-allowed; }
.hp-trust { display: flex; gap: 24px; margin-top: 28px; flex-wrap: wrap; }
.hp-trust-item { font-size: 13px; color: var(--muted); display: flex; align-items: center; gap: 8px; }
.hp-trust-item svg { color: var(--gold); flex-shrink: 0; }
/* hood page sub-sections */
.hp-section { max-width: 1000px; margin: 0 auto; padding: 60px 40px; }
.hp-section-title { font-family: var(--display); font-size: 30px; font-weight: 500; letter-spacing: -0.5px; color: var(--ink); margin-bottom: 32px; text-align: center; }
.hp-faq-item { border-bottom: 1px solid var(--line); }
.hp-faq-q { padding: 20px 0; font-size: 17px; font-weight: 500; color: var(--ink); cursor: pointer; display: flex; justify-content: space-between; align-items: center; gap: 16px; }
.hp-faq-q .chev { color: var(--gold); transition: transform 0.2s; flex-shrink: 0; }
.hp-faq-item.open .chev { transform: rotate(180deg); }
.hp-faq-a { max-height: 0; overflow: hidden; transition: max-height 0.3s, padding 0.3s; font-size: 15px; color: var(--ink-soft); line-height: 1.7; }
.hp-faq-item.open .hp-faq-a { max-height: 1200px; padding-bottom: 22px; }
.hp-faq-media { display: flex; gap: 10px; flex-wrap: wrap; margin-top: 14px; }
.hp-faq-media img, .hp-faq-media .vid { width: 130px; height: 90px; object-fit: cover; border-radius: 3px; }
.hp-faq-media .vid { position: relative; background: #14110E; display: flex; align-items: center; justify-content: center; }
.hp-faq-media .vid svg { color: #fff; }
.hp-testi-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 24px; }
.hp-testi { background: var(--surface); border: 1px solid var(--line); padding: 28px; }
.hp-testi .stars { color: var(--gold); letter-spacing: 3px; margin-bottom: 14px; }
.hp-testi .q { font-family: var(--display); font-style: italic; font-size: 18px; line-height: 1.5; color: var(--ink); margin-bottom: 16px; }
.hp-testi .a { font-size: 13px; color: var(--muted); }
.hp-testi .a strong { color: var(--ink); display: block; font-weight: 600; }

/* FAQ PAGE */
.faq-section { max-width: 960px; }
.faq-accordion { margin-top: 10px; }
.faqp-item { border-bottom: 1px solid var(--line); cursor: pointer; }
.faqp-q { padding: 22px 0; font-size: 17px; font-weight: 500; color: var(--ink); display: flex; justify-content: space-between; align-items: center; gap: 16px; }
.faqp-chev { color: var(--gold); transition: transform 0.25s; flex-shrink: 0; }
.faqp-item.open .faqp-chev { transform: rotate(180deg); }
.faqp-a { max-height: 0; overflow: hidden; transition: max-height 0.3s, padding 0.3s; font-size: 15px; color: var(--ink-soft); line-height: 1.7; }
.faqp-item.open .faqp-a { max-height: 1400px; padding-bottom: 24px; }
.faqp-media { display: flex; gap: 10px; flex-wrap: wrap; margin-top: 16px; }
.faqp-media img, .faqp-media .faqp-vid { width: 140px; height: 96px; object-fit: cover; border-radius: 3px; }
.faqp-media .faqp-vid { background: #14110E; display: flex; align-items: center; justify-content: center; color: #fff; }

/* QUICK SHIP STORE CARDS */
.qs-store-card-link { display: block; }
.hp-fixed-size { display: inline-block; padding: 12px 20px; border: 1px solid var(--ink); background: var(--ink); color: var(--bg); font-size: 15px; letter-spacing: 0.5px; }
.hp-qs-stock { margin-top: 14px; font-size: 13px; color: var(--gold-deep, var(--gold)); font-weight: 500; }
.qs-store-badge { position: absolute; bottom: 12px; left: 12px; background: rgba(26,23,18,0.82); color: #fff; font-size: 10px; font-weight: 600; letter-spacing: 0.5px; text-transform: uppercase; padding: 5px 11px; }
.qs-add-btn { background: var(--ink); color: var(--bg); border: none; font-family: var(--body); font-size: 11px; letter-spacing: 1px; text-transform: uppercase; font-weight: 500; padding: 9px 16px; cursor: pointer; transition: background 0.2s; }
.qs-add-btn:hover { background: var(--gold); }

/* TRUST BAND */
.trust { background: var(--surface-2); border-top: 1px solid var(--line); border-bottom: 1px solid var(--line); }
.page-empty { text-align: center; color: var(--muted); font-weight: 300; padding: 40px 20px 20px; font-size: 16px; }
.page-empty a { color: var(--gold); }
.section-title-link { color: inherit; transition: color 0.2s; }
.section-title-link:hover { color: var(--gold); }
.trust-inner { max-width: 100%; margin: 0 auto; padding: 36px 40px; display: grid; grid-template-columns: repeat(4, 1fr); gap: 30px; }
.trust-item { display: flex; align-items: center; gap: 14px; }
.trust-item svg { width: 32px; height: 32px; color: var(--gold); flex-shrink: 0; }
.trust-text { display: flex; flex-direction: column; }
.trust-text strong { font-size: 14px; color: var(--ink); font-weight: 600; letter-spacing: 0.2px; }
.trust-text span { font-size: 12px; color: var(--muted); }

/* TRADE PROFILE PAGE */
.profile-wrap { max-width: 760px; margin: 0 auto; padding: 60px 24px 100px; }
.profile-head { display: flex; justify-content: space-between; align-items: flex-start; gap: 20px; margin-bottom: 36px; }
.profile-eyebrow { font-size: 11px; letter-spacing: 2px; text-transform: uppercase; color: var(--gold-deep, var(--gold)); margin-bottom: 8px; }
.profile-title { font-family: var(--display); font-size: 34px; color: var(--ink); margin: 0 0 6px; }
.profile-sub { font-size: 13px; color: var(--muted); }
.profile-card { background: var(--surface); border: 1px solid var(--line); border-radius: var(--radius, 14px); padding: 26px; margin-bottom: 20px; }
.profile-card-title { font-size: 13px; letter-spacing: 1px; text-transform: uppercase; color: var(--ink); margin-bottom: 18px; font-weight: 500; }
.pf-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.pf-field { margin-bottom: 16px; }
.pf-field label { display: block; font-size: 12px; color: var(--muted); margin-bottom: 6px; }
.pf-field input { width: 100%; padding: 11px 13px; border: 1px solid var(--line); border-radius: var(--radius-sm, 10px); font-family: var(--body); font-size: 14px; color: var(--ink); background: var(--bg); box-sizing: border-box; }
.pf-field input:focus { outline: none; border-color: var(--gold); }
.profile-actions { display: flex; align-items: center; gap: 16px; margin-top: 28px; }
.pf-saved { font-size: 13px; color: var(--gold-deep, var(--gold)); }
.profile-note { margin-top: 26px; font-size: 12px; color: var(--muted); line-height: 1.6; padding: 16px; background: var(--surface); border-radius: var(--radius-sm, 10px); }
@media (max-width: 640px){ .pf-grid { grid-template-columns: 1fr; } .profile-head { flex-direction: column; } }
.cart-overlay { position: fixed; inset: 0; background: rgba(26,23,18,0.4); backdrop-filter: blur(2px); z-index: 300; opacity: 0; pointer-events: none; transition: opacity 0.25s; }
.cart-overlay.open { opacity: 1; pointer-events: auto; }
.cart-drawer { position: fixed; top: 0; right: 0; height: 100%; width: 420px; max-width: 90vw; background: var(--surface); z-index: 310; transform: translateX(100%); transition: transform 0.3s cubic-bezier(.4,0,.2,1); display: flex; flex-direction: column; box-shadow: -10px 0 40px rgba(0,0,0,0.12); }
.cart-drawer.open { transform: translateX(0); }
.cart-head { display: flex; align-items: center; justify-content: space-between; padding: 24px 28px; border-bottom: 1px solid var(--line); }
.cart-title { font-family: var(--display); font-size: 22px; font-weight: 500; color: var(--ink); }
.cart-close { background: none; border: none; font-size: 18px; color: var(--muted); cursor: pointer; }
.cart-close:hover { color: var(--ink); }
.cart-items { flex: 1; overflow-y: auto; padding: 12px 28px; }
.cart-empty { text-align: center; color: var(--muted-2); font-weight: 300; padding: 60px 20px; }
.cart-item { display: flex; gap: 16px; padding: 18px 0; border-bottom: 1px solid var(--line); }
.cart-item-img { width: 72px; height: 72px; background: var(--surface-3); background-size: cover; background-position: center; flex-shrink: 0; }
.cart-item-info { flex: 1; }
.cart-item-name { font-family: var(--display); font-size: 17px; color: var(--ink); margin-bottom: 3px; }
.cart-item-size { font-size: 12px; color: var(--muted); margin-bottom: 10px; }
.cart-item-controls { display: flex; align-items: center; gap: 12px; }
.cart-qty { display: flex; align-items: center; border: 1px solid var(--line); }
.cart-qty button { width: 28px; height: 28px; background: none; border: none; cursor: pointer; color: var(--ink); font-size: 15px; }
.cart-qty button:hover { background: var(--surface-2); }
.cart-qty span { width: 32px; text-align: center; font-size: 14px; }
.cart-item-remove { font-size: 12px; color: var(--muted); cursor: pointer; background: none; border: none; text-decoration: underline; }
.cart-item-remove:hover { color: var(--ink); }
.cart-item-price { font-size: 15px; color: var(--ink); font-weight: 500; white-space: nowrap; }
.cart-foot { padding: 22px 28px; border-top: 1px solid var(--line); }
.cart-subtotal { display: flex; justify-content: space-between; font-size: 17px; color: var(--ink); margin-bottom: 6px; }
.cart-subtotal span:last-child { font-weight: 600; }
.cart-note { font-size: 12px; color: var(--muted); margin-bottom: 16px; }
.cart-checkout { width: 100%; background: var(--ink); color: var(--bg); border: none; font-family: var(--body); font-size: 14px; letter-spacing: 1.2px; text-transform: uppercase; font-weight: 500; padding: 17px; cursor: pointer; transition: background 0.2s; }
.cart-checkout:hover { background: var(--gold); }

/* PARTNER + CONTACT FORMS */
.partner-wrap, .contact-wrap { display: grid; grid-template-columns: 1fr 1fr; gap: 56px; align-items: start; }
.partner-title, .contact-title { font-family: var(--display); font-size: clamp(30px,4vw,44px); font-weight: 500; letter-spacing: -1px; color: var(--ink); margin: 12px 0 18px; }
.partner-lead, .contact-lead { font-size: 16px; color: var(--ink-soft); line-height: 1.7; margin-bottom: 24px; }
.partner-benefits { list-style: none; }
.partner-benefits li { font-size: 15px; color: var(--ink-soft); padding: 10px 0 10px 30px; position: relative; border-bottom: 1px solid var(--line); }
.partner-benefits li::before { content: '✓'; position: absolute; left: 0; color: var(--gold); font-weight: 600; }
.partner-form-card, .contact-form-card { background: var(--surface); border: 1px solid var(--line); padding: 32px; }
.partner-form-title { font-family: var(--display); font-size: 22px; font-weight: 500; color: var(--ink); margin-bottom: 20px; }
.pf-field { margin-bottom: 16px; display: flex; flex-direction: column; }
.pf-field label { font-size: 11px; letter-spacing: 1.5px; text-transform: uppercase; color: var(--muted); margin-bottom: 7px; }
.pf-field input, .pf-field textarea { font-family: var(--body); font-size: 15px; color: var(--ink); background: var(--bg); border: 1px solid var(--line); padding: 12px 14px; outline: none; transition: border-color 0.2s; }
.pf-field input:focus, .pf-field textarea:focus { border-color: var(--gold); }
.pf-field textarea { min-height: 80px; resize: vertical; }
.pf-row { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
.pf-submit { width: 100%; background: var(--ink); color: var(--bg); border: none; font-family: var(--body); font-size: 14px; letter-spacing: 1.2px; text-transform: uppercase; font-weight: 500; padding: 16px; cursor: pointer; transition: background 0.2s; margin-top: 4px; }
.pf-submit:hover { background: var(--gold); }
.pf-note { font-size: 12px; color: var(--muted); margin-top: 12px; text-align: center; }
.contact-section { background: var(--surface-2); max-width: none; border-top: 1px solid var(--line); }
.contact-section .contact-wrap { max-width: 100%; margin: 0 auto; }
.contact-details { display: flex; flex-direction: column; gap: 14px; }
.contact-detail { display: flex; align-items: center; gap: 12px; font-size: 15px; color: var(--ink-soft); }
.contact-detail svg { width: 20px; height: 20px; color: var(--gold); flex-shrink: 0; }

/* TRADE LOGIN MODAL */
.tl-overlay { position: fixed; inset: 0; background: rgba(26,23,18,0.5); backdrop-filter: blur(3px); z-index: 400; opacity: 0; pointer-events: none; transition: opacity 0.25s; }
.tl-overlay.open { opacity: 1; pointer-events: auto; }
.tl-modal { position: fixed; top: 50%; left: 50%; transform: translate(-50%,-48%); width: 420px; max-width: 92vw; background: var(--surface); z-index: 410; padding: 40px 36px 32px; opacity: 0; pointer-events: none; transition: opacity 0.25s, transform 0.25s; text-align: center; box-shadow: 0 30px 80px rgba(0,0,0,0.25); }
.tl-modal.open { opacity: 1; pointer-events: auto; transform: translate(-50%,-50%); }
.tl-close { position: absolute; top: 16px; right: 18px; background: none; border: none; font-size: 17px; color: var(--muted); cursor: pointer; }
.tl-icon { width: 64px; height: 64px; border-radius: 50%; background: var(--surface-2); display: flex; align-items: center; justify-content: center; margin: 0 auto 20px; color: var(--gold); }
.tl-icon-success { background: var(--gold); color: #fff; }
.tl-title { font-family: var(--display); font-size: 26px; font-weight: 500; color: var(--ink); margin-bottom: 10px; }
.tl-sub { font-size: 14px; color: var(--muted); line-height: 1.6; margin-bottom: 22px; }
.tl-sub strong { color: var(--ink); }
.tl-input { width: 100%; font-family: var(--body); font-size: 16px; text-align: center; color: var(--ink); background: var(--bg); border: 1px solid var(--line); padding: 14px; outline: none; margin-bottom: 14px; }
.tl-input:focus { border-color: var(--gold); }
.tl-msg { font-size: 13.5px; line-height: 1.55; text-align: center; padding: 11px 14px; border-radius: var(--radius-sm); margin-bottom: 14px; }
.tl-msg.error { background: #FBEDE9; color: #9B3A2C; border: 1px solid #E8C9C0; }
.tl-msg.info { background: var(--surface-2); color: var(--ink-soft); border: 1px solid var(--line); }
.tl-msg a { color: var(--gold-deep, var(--gold)); text-decoration: underline; }
.tl-code { letter-spacing: 8px; font-size: 22px; font-weight: 500; }
.tl-btn { width: 100%; background: var(--ink); color: var(--bg); border: none; font-family: var(--body); font-size: 14px; letter-spacing: 1.2px; text-transform: uppercase; font-weight: 500; padding: 15px; cursor: pointer; transition: background 0.2s; }
.tl-btn:hover { background: var(--gold); }
.tl-foot { font-size: 13px; color: var(--muted); margin-top: 18px; }
.tl-foot a { color: var(--gold); }
.tl-discount { background: var(--gold-dim, #f3ecdb); border: 1px dashed var(--gold); padding: 18px; margin-bottom: 20px; font-size: 15px; color: var(--ink); }
.tl-discount strong { font-family: var(--display); font-size: 26px; color: var(--gold-deep); display: block; margin-top: 4px; }

@media (max-width: 900px) {
  .header-inner { padding: 16px 22px; position: relative; }
  .nav { display: none; }
  .menu-toggle { display: block; order: 1; margin: 0; }
  .logo { order: 2; position: absolute; left: 50%; transform: translateX(-50%); }
  .logo-lockup { align-items: center; }
  .logo-name { font-size: 21px; }
  .logo-desc { font-size: 9.5px; letter-spacing: 0.3px; }
  .header-actions { gap: 14px; order: 3; margin-left: auto; }
  .header-account-wrap { display: block; }
  .header-account-label { display: none !important; }
  .header-cart { white-space: nowrap; }
  .hero { padding: 40px 22px; }
  .hero-cta { flex-direction: column; }
  .section { padding: 56px 22px; }
  .hood-grid, .story-inner, .testi-row { grid-template-columns: 1fr; gap: 24px; }
  .trust-inner { grid-template-columns: 1fr 1fr; gap: 22px; padding: 30px 22px; }
  .partner-wrap, .contact-wrap { grid-template-columns: 1fr; gap: 32px; }
  .pf-row { grid-template-columns: 1fr; gap: 0; }
  .story-inner { padding: 60px 22px; }
  .footer-row { grid-template-columns: 1fr; gap: 16px; justify-items: center; }
  .footer-brand-name { justify-self: start; text-align: left; }
  .footer-brand-name .footer-lockup { align-items: flex-start; }
  .footer-socials { justify-self: center; }
  .footer-links { justify-content: center; }
  .footer-copy-row { flex-direction: column; gap: 8px; text-align: center; }
  .hp-wrap { padding: 20px 22px 60px; }
  .hp-top { grid-template-columns: 1fr; gap: 32px; }
  .hp-section { padding: 50px 22px; }
  .hp-testi-grid { grid-template-columns: 1fr; }
}

/* ============================================================
   GUIDES / GALLERY / ARTICLE CONTENT
   ============================================================ */
/* Index cards — guides */
.guide-card { display: block; text-decoration: none; background: var(--surface); border: 1px solid var(--line); overflow: hidden; transition: box-shadow 0.2s, transform 0.2s; }
.guide-card:hover { box-shadow: 0 18px 50px rgba(0,0,0,0.10); transform: translateY(-3px); }
.guide-card-img { aspect-ratio: 4/3; background-size: cover; background-position: center; background-color: var(--surface-3); }
.guide-card-body { padding: 22px 24px 24px; }
.guide-card-name { font-family: var(--display); font-size: 21px; font-weight: 500; color: var(--ink); margin-bottom: 8px; line-height: 1.25; }
.guide-card-snippet { font-size: 14px; color: var(--ink-soft); line-height: 1.6; margin-bottom: 14px; }
.guide-card-arrow { font-size: 12px; letter-spacing: 1px; text-transform: uppercase; color: var(--gold); font-weight: 500; }

/* Index cards — gallery */
.gallery-card { display: block; text-decoration: none; overflow: hidden; background: var(--surface); border: 1px solid var(--line); transition: box-shadow 0.2s, transform 0.2s; }
.gallery-card:hover { box-shadow: 0 18px 50px rgba(0,0,0,0.10); transform: translateY(-3px); }
.gallery-card-img { aspect-ratio: 4/3; background-size: cover; background-position: center; background-color: var(--surface-3); display: flex; align-items: center; justify-content: center; }
.gallery-card-body { padding: 16px 20px 20px; }
.gallery-card-name { font-family: var(--display); font-size: 18px; font-weight: 500; color: var(--ink); margin-bottom: 4px; }
.gallery-card-specs { font-size: 12px; color: var(--muted); letter-spacing: 0.3px; }

/* Article (single guide / project) */
.article-breadcrumb { font-size: 12px; color: var(--muted); margin-bottom: 22px; letter-spacing: 0.3px; }
.article-breadcrumb a { color: var(--muted); text-decoration: none; }
.article-breadcrumb a:hover { color: var(--gold); }
.article-title { font-family: var(--display); font-size: clamp(30px,4.5vw,48px); font-weight: 600; letter-spacing: -0.5px; color: var(--ink); line-height: 1.15; margin-bottom: 26px; }
.article-hero { display: block; width: 100%; height: auto; background-color: var(--surface-3); margin-bottom: 34px; }
.article-cta { margin: 36px 0 8px; }
.btn-see-hood { display: inline-block; background: var(--ink); color: var(--bg); font-family: var(--display); font-size: 16px; padding: 14px 30px; text-decoration: none; transition: background 0.2s; }
.btn-see-hood:hover { background: var(--gold); }
.article-body { font-size: 17px; line-height: 1.75; color: var(--ink-soft); }
.article-h2 { font-family: var(--display); font-size: clamp(24px,3vw,32px); font-weight: 500; color: var(--ink); margin: 40px 0 14px; letter-spacing: -0.3px; }
.article-h3 { font-family: var(--display); font-size: 22px; font-weight: 500; color: var(--ink); margin: 30px 0 10px; }
.article-p { margin: 0 0 20px; }
.article-ul, .article-ol { margin: 0 0 22px; padding-left: 24px; }
.article-ul li, .article-ol li { margin-bottom: 9px; line-height: 1.65; }
.article-quote { border-left: 3px solid var(--gold); padding: 6px 0 6px 22px; margin: 26px 0; font-family: var(--display); font-size: 21px; font-style: italic; color: var(--ink); }
.article-figure { margin: 30px 0; }
.article-figure img { width: 100%; height: auto; display: block; }
.article-figure figcaption { font-size: 13px; color: var(--muted); margin-top: 8px; text-align: center; }
.article-video { position: relative; width: 100%; aspect-ratio: 16/9; }
.article-video iframe { position: absolute; inset: 0; width: 100%; height: 100%; border: 0; }

/* Gallery project photos + specs */
.gallery-specs { display: flex; flex-wrap: wrap; gap: 28px; margin: 0 0 28px; padding: 18px 0; border-top: 1px solid var(--line); border-bottom: 1px solid var(--line); }
.gallery-specs dt { font-size: 11px; letter-spacing: 1px; text-transform: uppercase; color: var(--muted); margin-bottom: 3px; }
.gallery-specs dd { font-family: var(--display); font-size: 17px; color: var(--ink); margin: 0; }
.gallery-photos { display: grid; grid-template-columns: repeat(auto-fill,minmax(280px,1fr)); gap: 14px; margin: 30px 0; }
.gallery-photos img { width: 100%; height: 100%; object-fit: cover; display: block; }

/* Linked products block */
.article-products { margin-top: 56px; padding-top: 40px; border-top: 1px solid var(--line); }
.article-products-title { font-family: var(--display); font-size: 24px; font-weight: 500; color: var(--ink); margin-bottom: 20px; }
