/*
 * Blackhawk Outfitters - Complete Stylesheet v2.0.1
 * Includes shared CSS + all page-specific CSS
 */

:root {
  --black:      #060C06;
  --dark:       #0A1A0A;
  --forest:     #112211;
  --mid:        #1C2E1C;
  --panel:      #162416;
  --gold:       #C9A941;
  --gold-light: #E2C46A;
  --gold-dim:   #8A7030;
  --white:      #F0EEE8;
  --gray-light: #B8B5AC;
  --gray-mid:   #6B6860;
  --gray-dark:  #2A342A;
  --font-display: 'Barlow Condensed', sans-serif;
  --font-body:    'Barlow', sans-serif;
  --font-ui:      'Rajdhani', sans-serif;
  --ease-out: cubic-bezier(0.16, 1, 0.3, 1);
}
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; }
body { background: var(--black); color: var(--white); font-family: var(--font-body); font-size: 16px; line-height: 1.6; overflow-x: hidden; }
a { color: inherit; text-decoration: none; }
img { display: block; max-width: 100%; }
::-webkit-scrollbar { width: 4px; }
::-webkit-scrollbar-track { background: var(--dark); }
::-webkit-scrollbar-thumb { background: var(--gold-dim); border-radius: 2px; }
.container { max-width: 1400px; margin: 0 auto; padding: 0 40px; }

.btn-primary { display: inline-flex; align-items: center; gap: 10px; padding: 14px 32px; background: var(--gold); color: var(--black); font-family: var(--font-display); font-size: 14px; font-weight: 700; letter-spacing: 2px; text-transform: uppercase; clip-path: polygon(0 0, calc(100% - 10px) 0, 100% 10px, 100% 100%, 10px 100%, 0 calc(100% - 10px)); transition: background 0.2s; }
.btn-primary svg { width: 16px; height: 16px; flex-shrink: 0; }
.btn-primary:hover { background: var(--gold-light); }
.btn-ghost { display: inline-flex; align-items: center; padding: 13px 32px; border: 1px solid rgba(201,169,65,0.4); color: var(--white); font-family: var(--font-display); font-size: 14px; font-weight: 600; letter-spacing: 2px; text-transform: uppercase; transition: border-color 0.2s, color 0.2s; }
.btn-ghost:hover { border-color: var(--gold); color: var(--gold); }

/* TOP BAR */
.topbar { background: var(--gold); color: var(--black); text-align: center; padding: 8px 40px; font-family: var(--font-ui); font-size: 12px; font-weight: 700; letter-spacing: 2px; text-transform: uppercase; }
.topbar a { color: var(--black); border-bottom: 1px solid rgba(0,0,0,0.3); }

/* HEADER */
.site-header { position: fixed; top: 0; left: 0; right: 0; z-index: 1000; }
.header-top { background: rgba(6,12,6,0.96); backdrop-filter: blur(20px); border-bottom: 1px solid rgba(201,169,65,0.15); }
.header-inner { display: flex; align-items: center; justify-content: space-between; padding: 0 40px; height: 72px; }
.logo { display: flex; align-items: center; gap: 14px; flex-shrink: 0; }
.logo-symbol { height: 112px; width: auto; object-fit: contain; flex-shrink: 0; filter: drop-shadow(0 2px 14px rgba(201,169,65,0.7)) drop-shadow(0 0 28px rgba(201,169,65,0.35)); background: transparent; }
.logo-text { display: flex; flex-direction: column; }
.logo-name { font-family: 'Barlow Condensed', sans-serif; font-size: 26px; font-weight: 800; letter-spacing: 4px; text-transform: uppercase; color: var(--white); line-height: 1; }
.logo-sub  { font-family: 'Rajdhani', sans-serif; font-size: 10px; font-weight: 600; letter-spacing: 3px; text-transform: uppercase; color: var(--gold); margin-top: 4px; white-space: nowrap; }
.main-nav { display: flex; align-items: center; gap: 4px; }
.main-nav a { font-family: var(--font-ui); font-size: 13px; font-weight: 600; letter-spacing: 2px; text-transform: uppercase; color: var(--gray-light); padding: 8px 16px; transition: color 0.2s; position: relative; }
.main-nav a::after { content: ''; position: absolute; bottom: 4px; left: 16px; right: 16px; height: 1px; background: var(--gold); transform: scaleX(0); transform-origin: left; transition: transform 0.3s var(--ease-out); }
.main-nav a:hover { color: var(--white); }
.main-nav a:hover::after, .main-nav a.active::after { transform: scaleX(1); }
.main-nav a.active { color: var(--gold); }
.header-actions { display: flex; align-items: center; gap: 8px; }
.header-actions button, .header-actions a { width: 40px; height: 40px; display: flex; align-items: center; justify-content: center; background: transparent; border: none; cursor: pointer; color: var(--gray-light); transition: color 0.2s, background 0.2s; border-radius: 2px; }
.header-actions button:hover, .header-actions a:hover { color: var(--gold); background: rgba(201,169,65,0.1); }
.cart-btn { position: relative; }
.cart-count { position: absolute; top: 4px; right: 4px; width: 16px; height: 16px; background: var(--gold); color: var(--black); font-family: var(--font-ui); font-size: 9px; font-weight: 700; border-radius: 50%; display: flex; align-items: center; justify-content: center; }
.header-cta { margin-left: 8px; padding: 9px 20px !important; width: auto !important; height: auto !important; background: var(--gold) !important; color: var(--black) !important; font-family: var(--font-ui) !important; font-size: 11px !important; font-weight: 700 !important; letter-spacing: 2px !important; text-transform: uppercase !important; border-radius: 1px !important; transition: background 0.2s !important; }
.header-cta:hover { background: var(--gold-light) !important; }

/* CATEGORY BAR */
.cat-bar { background: rgba(17,34,17,0.98); border-bottom: 1px solid rgba(201,169,65,0.1); }
.cat-bar-inner { display: flex; align-items: center; justify-content: center; padding: 0 40px; height: 44px; }
.cat-bar a { font-family: var(--font-ui); font-size: 11px; font-weight: 600; letter-spacing: 2px; text-transform: uppercase; color: var(--gray-mid); padding: 0 18px; height: 44px; display: flex; align-items: center; border-bottom: 2px solid transparent; transition: color 0.2s, border-color 0.2s; white-space: nowrap; }
.cat-bar a:hover { color: var(--white); border-bottom-color: var(--gold); }
.cat-bar a.featured { color: var(--gold); }

/* HERO */
.hero { position: relative; height: 100vh; min-height: 700px; display: flex; align-items: flex-end; overflow: hidden; padding-top: 152px; box-sizing: border-box; }
.hero-videos { position: absolute; inset: 0; z-index: 0; }
.hero-vid { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; object-position: center center; opacity: 0; transition: opacity 1.5s ease-in-out; }
.hero-vid.active { opacity: 1; }
.hero-overlay { position: absolute; inset: 0; z-index: 1; background: radial-gradient(ellipse at 100% 100%, rgba(6,12,6,0.85) 0%, rgba(6,12,6,0.4) 35%, transparent 60%), linear-gradient(to right, rgba(6,12,6,0.90) 0%, rgba(6,12,6,0.75) 30%, rgba(6,12,6,0.35) 55%, rgba(6,12,6,0.05) 100%), linear-gradient(to top, rgba(6,12,6,0.55) 0%, transparent 22%); }
.hero-content { position: relative; z-index: 3; padding: 0 80px 80px; max-width: 660px; }
.hero-tag { display: flex; align-items: center; gap: 12px; margin-bottom: 28px; opacity: 0; animation: fadeUp 0.8s var(--ease-out) 0.2s forwards; }
.hero-tag-line { width: 40px; height: 1px; background: var(--gold); }
.hero-tag-text { font-family: var(--font-ui); font-size: 11px; font-weight: 600; letter-spacing: 4px; text-transform: uppercase; color: var(--gold); }
.hero-tag-badge { margin-left: 8px; background: rgba(201,169,65,0.1); border: 1px solid rgba(201,169,65,0.3); padding: 4px 12px; font-family: var(--font-ui); font-size: 10px; font-weight: 600; letter-spacing: 2px; text-transform: uppercase; color: var(--gold); }
.hero-headline { font-family: var(--font-display); font-size: clamp(60px, 7.5vw, 110px); font-weight: 800; line-height: 0.9; letter-spacing: -1px; text-transform: uppercase; margin-bottom: 24px; opacity: 0; animation: fadeUp 0.8s var(--ease-out) 0.4s forwards; }
.hero-headline .line2 { display: block; -webkit-text-stroke: 1.5px var(--gold); color: transparent; }
.hero-headline .line3 { display: block; color: var(--white); }
.hero-sub { font-size: 16px; font-weight: 300; color: rgba(240,238,232,0.72); line-height: 1.6; max-width: 460px; margin-bottom: 36px; opacity: 0; animation: fadeUp 0.8s var(--ease-out) 0.6s forwards; }
.hero-actions { display: flex; align-items: center; gap: 20px; opacity: 0; animation: fadeUp 0.8s var(--ease-out) 0.8s forwards; }
.hero-stats { position: absolute; z-index: 3; right: 60px; bottom: 80px; display: flex; flex-direction: column; gap: 24px; opacity: 0; animation: fadeLeft 0.8s var(--ease-out) 1s forwards; }
.hero-stat { text-align: right; border-right: 2px solid var(--gold-dim); padding-right: 20px; }
.hero-stat-num { font-family: var(--font-display); font-size: 36px; font-weight: 800; color: var(--gold); line-height: 1; }
.hero-stat:last-child .hero-stat-num { font-size: 24px; }
.hero-stat-label { font-family: var(--font-ui); font-size: 10px; font-weight: 600; letter-spacing: 2px; text-transform: uppercase; color: var(--gray-mid); margin-top: 2px; }
.hero-indicators { position: absolute; z-index: 3; bottom: 36px; left: 80px; display: flex; gap: 8px; }
.hero-dot { width: 24px; height: 2px; background: rgba(255,255,255,0.25); cursor: pointer; transition: all 0.3s; }
.hero-dot.active { background: var(--gold); width: 48px; }
.scroll-indicator { position: absolute; z-index: 3; bottom: 28px; left: 50%; transform: translateX(-50%); display: flex; flex-direction: column; align-items: center; gap: 8px; opacity: 0; animation: fadeIn 1s var(--ease-out) 1.5s forwards; }
.scroll-line { width: 1px; height: 48px; background: linear-gradient(to bottom, var(--gold), transparent); animation: scrollPulse 2s ease-in-out infinite; }
@keyframes scrollPulse { 0%, 100% { opacity: 1; transform: scaleY(1); } 50% { opacity: 0.4; transform: scaleY(0.6); } }
.scroll-text { font-family: var(--font-ui); font-size: 9px; font-weight: 600; letter-spacing: 3px; text-transform: uppercase; color: var(--gray-mid); writing-mode: vertical-rl; transform: rotate(180deg); }

/* TRUST BAR */
.trust-bar { background: var(--gold); }
.trust-bar-inner { display: flex; align-items: stretch; }
.trust-item { display: flex; align-items: center; gap: 14px; padding: 18px 36px; flex: 1; border-right: 1px solid rgba(0,0,0,0.12); transition: background 0.2s; }
.trust-item:last-child { border-right: none; }
.trust-item:hover { background: rgba(0,0,0,0.06); }
.trust-icon { color: rgba(0,0,0,0.45); flex-shrink: 0; }
.trust-title { font-family: var(--font-display); font-size: 14px; font-weight: 700; letter-spacing: 1px; text-transform: uppercase; color: var(--black); line-height: 1; }
.trust-sub { font-family: var(--font-ui); font-size: 11px; font-weight: 500; color: rgba(0,0,0,0.5); margin-top: 2px; }

/* SECTION HEADER */
.section-header { margin-bottom: 56px; }
.section-header.centered { text-align: center; }
.section-tag { display: flex; align-items: center; gap: 12px; margin-bottom: 16px; }
.section-header.centered .section-tag { justify-content: center; }
.section-tag-line { width: 32px; height: 1px; background: var(--gold); }
.section-tag-text { font-family: var(--font-ui); font-size: 11px; font-weight: 600; letter-spacing: 4px; text-transform: uppercase; color: var(--gold); }
.section-title { font-family: var(--font-display); font-size: clamp(36px, 5vw, 60px); font-weight: 800; line-height: 0.95; text-transform: uppercase; letter-spacing: -0.5px; }
.section-sub { font-size: 15px; font-weight: 300; color: var(--gray-light); line-height: 1.7; max-width: 540px; margin-top: 16px; }
.section-header.centered .section-sub { margin: 16px auto 0; }

/* CATEGORY GRID */
.categories-section { padding: 100px 0; background: var(--dark); position: relative; overflow: hidden; }
.categories-section::before { content: 'SHOP'; position: absolute; top: 40px; right: 20px; font-family: var(--font-display); font-size: 220px; font-weight: 900; color: rgba(255,255,255,0.012); letter-spacing: -10px; pointer-events: none; user-select: none; }
.cat-grid { display: grid; grid-template-columns: repeat(4, 1fr); grid-template-rows: repeat(4, 260px); gap: 3px; margin-top: 60px; }
.cat-card-firearms    { grid-column: 1;     grid-row: 1 / 3; }
.cat-card-ammo        { grid-column: 2;     grid-row: 1; }
.cat-card-optics      { grid-column: 3 / 5; grid-row: 1; }
.cat-card-hunting     { grid-column: 2;     grid-row: 2; }
.cat-card-tactical    { grid-column: 3;     grid-row: 2; }
.cat-card-knives      { grid-column: 4;     grid-row: 2; }
.cat-card-firearm-acc { grid-column: 1 / 3; grid-row: 3; }
.cat-card-archery     { grid-column: 3;     grid-row: 3 / 5; }
.cat-card-lights      { grid-column: 4;     grid-row: 3; }
.cat-card-outdoors    { grid-column: 1;     grid-row: 4; }
.cat-card-reloading   { grid-column: 2;     grid-row: 4; }
.cat-card-apparel     { grid-column: 4;     grid-row: 4; }
.cat-card { position: relative; overflow: hidden; cursor: pointer; background: var(--forest); }
.cat-card-bg { position: absolute; inset: 0; background-size: cover; background-position: center; transition: transform 0.7s var(--ease-out); }
.cat-card:hover .cat-card-bg { transform: scale(1.06); }
.cat-card-firearms    .cat-card-bg { background-image: url('../images/processed/cat_firearms.jpg'); }
.cat-card-ammo        .cat-card-bg { background-image: url('../images/processed/cat_ammo.jpg'); }
.cat-card-optics      .cat-card-bg { background-image: url('../images/processed/cat_optics.jpg'); }
.cat-card-hunting     .cat-card-bg { background-image: url('../images/processed/cat_hunting.jpg'); }
.cat-card-tactical    .cat-card-bg { background-image: url('../images/processed/cat_tactical.jpg'); }
.cat-card-knives      .cat-card-bg { background-image: url('../images/processed/cat_knives.jpg'); }
.cat-card-firearm-acc .cat-card-bg { background-image: url('../images/processed/cat_firearm_acc.jpg'); }
.cat-card-archery     .cat-card-bg { background-image: url('../images/processed/cat_archery.jpg'); }
.cat-card-lights      .cat-card-bg { background-image: url('../images/processed/cat_lights.jpg'); }
.cat-card-outdoors    .cat-card-bg { background-image: url('../images/processed/cat_outdoors.jpg'); }
.cat-card-reloading   .cat-card-bg { background-image: url('../images/processed/cat_reloading.jpg'); }
.cat-card-apparel     .cat-card-bg { background-image: url('../images/processed/cat_apparel.jpg'); }
.cat-card-overlay { position: absolute; inset: 0; background: linear-gradient(to top, rgba(6,12,6,0.92) 0%, rgba(6,12,6,0.35) 50%, rgba(6,12,6,0.05) 100%); transition: background 0.4s; }
.cat-card:hover .cat-card-overlay { background: linear-gradient(to top, rgba(6,12,6,0.96) 0%, rgba(6,12,6,0.5) 50%, rgba(6,12,6,0.15) 100%); }
.cat-card-content { position: absolute; inset: 0; display: flex; flex-direction: column; justify-content: flex-end; padding: 24px; }
.cat-card-count { font-family: var(--font-ui); font-size: 10px; font-weight: 600; letter-spacing: 3px; text-transform: uppercase; color: var(--gold); opacity: 0; transform: translateY(8px); transition: opacity 0.3s, transform 0.3s; }
.cat-card:hover .cat-card-count { opacity: 1; transform: translateY(0); }
.cat-card-name { font-family: var(--font-display); font-size: clamp(18px, 2vw, 28px); font-weight: 800; text-transform: uppercase; letter-spacing: 1px; line-height: 1; margin-top: 4px; transition: color 0.2s; }
.cat-card:hover .cat-card-name { color: var(--gold-light); }
.cat-card-arrow { position: absolute; top: 20px; right: 20px; width: 36px; height: 36px; border: 1px solid rgba(201,169,65,0.4); display: flex; align-items: center; justify-content: center; color: var(--gold); opacity: 0; transform: translate(4px,-4px); transition: opacity 0.3s, transform 0.3s, background 0.2s; }
.cat-card:hover .cat-card-arrow { opacity: 1; transform: translate(0,0); background: var(--gold); color: var(--black); }

/* FEATURED PRODUCTS — Direction 3: 1 hero card + 4 satellites */
.featured-section { padding: 100px 0; background: var(--black); }
.section-header-row { display: flex; align-items: flex-end; justify-content: space-between; margin-bottom: 48px; }
.view-all { display: flex; align-items: center; gap: 8px; font-family: var(--font-ui); font-size: 12px; font-weight: 600; letter-spacing: 2px; text-transform: uppercase; color: var(--gold); border-bottom: 1px solid transparent; transition: border-color 0.2s; padding-bottom: 2px; }
.view-all:hover { border-bottom-color: var(--gold); }
.view-all svg { transition: transform 0.2s; }
.view-all:hover svg { transform: translateX(4px); }

/* Grid: hero (2fr, both rows) + 6 satellites (1fr each in cols 2-4, 2 rows) */
.fp-grid { display: grid; grid-template-columns: 2fr 1fr 1fr 1fr; grid-template-rows: auto auto; gap: 2px; }
.fp-card-hero      { grid-column: 1; grid-row: 1 / 3; border-left: 3px solid var(--gold); }
.fp-card-satellite { border-left: 2px solid var(--gold); }

.fp-card { position: relative; background: var(--forest); overflow: hidden; transition: transform 0.3s var(--ease-out), background 0.3s; display: flex; flex-direction: column; text-decoration: none; color: inherit; }
.fp-card:hover { transform: translateY(-2px); background: var(--mid); z-index: 1; }
.fp-card-hero { flex-direction: column; }

/* Image areas */
.fp-card-hero .fp-card-img      { flex: 1; min-height: 380px; background: var(--panel); position: relative; overflow: hidden; }
.fp-card-satellite .fp-card-img { height: 150px; background: var(--panel); position: relative; overflow: hidden; flex-shrink: 0; }
.fp-card-img img { width: 100%; height: 100%; object-fit: contain; padding: 24px; transition: transform 0.5s var(--ease-out); }
.fp-card-satellite .fp-card-img img { padding: 16px; }
.fp-card:hover .fp-card-img img { transform: scale(1.04); }

/* Body */
.fp-card-body                    { padding: 24px; display: flex; flex-direction: column; gap: 10px; flex: 1; }
.fp-card-satellite .fp-card-body { padding: 14px 16px; gap: 5px; }
/* Hero body: compact, image absorbs leftover height */
.fp-card-hero .fp-card-body      { flex: 0 0 auto; }
.fp-card-hero .fp-footer         { margin-top: 12px; }

/* Pill "Featured" — only on hero, top-left */
.fp-pill { position: absolute; top: 16px; left: 16px; z-index: 2; display: inline-flex; align-items: center; gap: 6px; padding: 6px 12px; background: var(--gold); color: var(--black); font-family: var(--font-ui); font-size: 10px; font-weight: 700; letter-spacing: 2px; text-transform: uppercase; }
.fp-pill svg { color: var(--black); flex-shrink: 0; }

/* Counter "01 / 05" — only on hero, top-right */
.fp-counter { position: absolute; top: 16px; right: 16px; z-index: 2; font-family: 'Courier New', monospace; font-size: 11px; font-weight: 600; letter-spacing: 1px; color: var(--gold); background: rgba(6,12,6,0.7); padding: 6px 10px; border: 1px solid rgba(201,169,65,0.3); }

/* Brand row — uppercase gold + star icon */
.fp-brand { display: inline-flex; align-items: center; gap: 6px; font-family: var(--font-ui); font-size: 10px; font-weight: 700; letter-spacing: 3px; text-transform: uppercase; color: var(--gold); }
.fp-brand svg { color: var(--gold); flex-shrink: 0; }
.fp-card-satellite .fp-brand { font-size: 9px; letter-spacing: 2px; gap: 5px; }

/* SKU — monospace */
.fp-sku { font-family: 'Courier New', monospace; font-size: 11px; color: var(--gray-mid); letter-spacing: 0.5px; }
.fp-card-satellite .fp-sku { font-size: 10px; }

/* Product name */
.fp-name { font-family: var(--font-display); font-size: 24px; font-weight: 800; line-height: 1.15; text-transform: uppercase; letter-spacing: -0.3px; color: var(--white); margin: 0; }
.fp-card-satellite .fp-name { font-size: 15px; line-height: 1.25; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }

/* Tagline (hero only) — italic */
.fp-tagline { font-family: var(--font-body); font-size: 13px; font-style: italic; color: var(--gray-light); line-height: 1.5; margin: 0; }

/* Specs (hero version: rows) */
.fp-specs { display: flex; flex-direction: column; gap: 6px; margin-top: 4px; padding-top: 10px; border-top: 1px solid rgba(201,169,65,0.12); }
.fp-spec-row { display: flex; justify-content: space-between; align-items: baseline; font-family: 'Courier New', monospace; font-size: 12px; }
.fp-spec-label { color: var(--gray-mid); text-transform: uppercase; letter-spacing: 1px; font-size: 10px; }
.fp-spec-value { color: var(--white); font-weight: 600; }

/* Specs (satellite version: inline, monospace line) */
.fp-specs-line { font-family: 'Courier New', monospace; font-size: 10px; color: var(--gray-light); letter-spacing: 0.3px; line-height: 1.4; }

/* Footer: price + stock */
.fp-footer { display: flex; align-items: flex-end; justify-content: space-between; gap: 12px; margin-top: auto; padding-top: 12px; }
.fp-card-satellite .fp-footer { flex-direction: column; align-items: stretch; gap: 4px; padding-top: 6px; }

.fp-price { font-family: 'Courier New', monospace; font-size: 22px; font-weight: 700; color: var(--gold); line-height: 1; }
.fp-card-satellite .fp-price { font-size: 16px; }
.fp-price .woocommerce-Price-amount,
.fp-price .woocommerce-Price-currencySymbol { font-family: inherit; font-size: inherit; font-weight: inherit; color: inherit; }

/* Stock label */
.fp-stock { font-family: var(--font-ui); font-size: 10px; font-weight: 700; letter-spacing: 1.5px; text-transform: uppercase; padding: 4px 8px; border: 1px solid; display: inline-block; align-self: flex-end; }
.fp-card-satellite .fp-stock { align-self: flex-start; font-size: 9px; padding: 3px 6px; }
.fp-stock-in  { color: #5DCA5D; border-color: rgba(0,180,0,0.3); background: rgba(0,180,0,0.08); }
.fp-stock-low { color: var(--gold); border-color: rgba(201,169,65,0.4); background: rgba(201,169,65,0.08); }
.fp-stock-out { color: #D86060; border-color: rgba(220,80,80,0.3); background: rgba(220,80,80,0.08); }

/* Compliance badge — below footer when present */
.fp-compliance { display: inline-flex; align-items: center; gap: 6px; padding: 5px 10px; font-family: var(--font-ui); font-size: 10px; font-weight: 700; letter-spacing: 1.5px; text-transform: uppercase; border: 1px solid; margin-top: 8px; align-self: flex-start; }
.fp-card-satellite .fp-compliance { font-size: 9px; padding: 3px 7px; letter-spacing: 1px; }
.fp-compliance svg { flex-shrink: 0; }
.fp-comp-nfa    { color: #D86060; border-color: rgba(220,80,80,0.4); background: rgba(220,80,80,0.08); }
.fp-comp-hazmat { color: #D86060; border-color: rgba(220,80,80,0.4); background: rgba(220,80,80,0.08); }
.fp-comp-ffl    { color: var(--gold); border-color: rgba(201,169,65,0.4); background: rgba(201,169,65,0.08); }
.fp-comp-age    { color: var(--gold); border-color: rgba(201,169,65,0.4); background: rgba(201,169,65,0.08); }

/* Responsive */
@media (max-width: 1200px) {
  .fp-grid { grid-template-columns: 2fr 1fr 1fr; }
  .fp-card-satellite:nth-child(n+6) { display: none; }
}
@media (max-width: 1024px) {
  .fp-grid { grid-template-columns: 1fr 1fr; grid-template-rows: auto auto auto; }
  .fp-card-hero      { grid-column: 1 / 3; grid-row: 1; }
  .fp-card-satellite { grid-column: auto; grid-row: auto; }
  .fp-card-satellite:nth-child(n+6) { display: block; }
  .fp-card-hero .fp-card-img { min-height: 280px; }
}
@media (max-width: 600px) {
  .fp-grid { grid-template-columns: 1fr; }
  .fp-card-hero, .fp-card-satellite { grid-column: 1; }
  .fp-card-hero .fp-card-img { min-height: 220px; }
  .fp-name { font-size: 20px; }
}

/* BRANDS */
.brands-section { padding: 72px 0; background: var(--forest); border-top: 1px solid rgba(201,169,65,0.1); border-bottom: 1px solid rgba(201,169,65,0.1); overflow: hidden; }
.brands-label { text-align: center; font-family: var(--font-ui); font-size: 10px; font-weight: 600; letter-spacing: 4px; text-transform: uppercase; color: var(--gray-mid); margin-bottom: 36px; }
.brands-track-wrapper { overflow: hidden; position: relative; }
.brands-track-wrapper::before, .brands-track-wrapper::after { content: ''; position: absolute; top: 0; bottom: 0; width: 120px; z-index: 2; }
.brands-track-wrapper::before { left: 0;  background: linear-gradient(to right, var(--forest), transparent); }
.brands-track-wrapper::after  { right: 0; background: linear-gradient(to left,  var(--forest), transparent); }
.brands-track { display: flex; gap: 60px; align-items: center; animation: brandScroll 30s linear infinite; width: max-content; }
@keyframes brandScroll { 0% { transform: translateX(0); } 100% { transform: translateX(-50%); } }
.brand-item { font-family: var(--font-display); font-size: 22px; font-weight: 800; letter-spacing: 4px; text-transform: uppercase; color: var(--gray-dark); transition: color 0.3s; white-space: nowrap; cursor: pointer; flex-shrink: 0; }
.brand-item:hover { color: var(--gold); }

/* LIFESTYLE */
.lifestyle-section { position: relative; overflow: hidden; height: 520px; display: flex; align-items: center; }
.lifestyle-bg { position: absolute; inset: 0; background: url('https://images.unsplash.com/photo-1508193638397-1c4234db14d8?w=1800&q=80') center/cover no-repeat; }
.lifestyle-overlay { position: absolute; inset: 0; background: linear-gradient(90deg, rgba(6,12,6,0.96) 35%, rgba(6,12,6,0.6) 65%, rgba(6,12,6,0.15) 100%); }
.lifestyle-content { position: relative; z-index: 1; padding: 0 80px; max-width: 620px; }
.lifestyle-content .section-title { font-size: clamp(44px, 5.5vw, 72px); }
.lifestyle-content p { font-size: 16px; font-weight: 300; color: var(--gray-light); line-height: 1.7; margin: 20px 0 36px; }

/* FEATURES */
.features-section { padding: 100px 0; background: var(--dark); }
.features-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 3px; }
.feature-card { background: var(--forest); padding: 48px 40px; position: relative; overflow: hidden; transition: background 0.3s; }
.feature-card::before { content: ''; position: absolute; top: 0; left: 0; width: 3px; height: 0; background: var(--gold); transition: height 0.4s var(--ease-out); }
.feature-card:hover::before { height: 100%; }
.feature-card:hover { background: var(--mid); }
.feature-num { font-family: var(--font-display); font-size: 60px; font-weight: 900; color: rgba(201,169,65,0.08); line-height: 1; margin-bottom: 20px; }
.feature-icon { width: 48px; height: 48px; background: rgba(201,169,65,0.1); border: 1px solid rgba(201,169,65,0.2); display: flex; align-items: center; justify-content: center; color: var(--gold); margin-bottom: 20px; }
.feature-title { font-family: var(--font-display); font-size: 22px; font-weight: 700; text-transform: uppercase; letter-spacing: 1px; margin-bottom: 12px; }
.feature-desc  { font-size: 14px; font-weight: 300; color: var(--gray-light); line-height: 1.7; }

/* ── FFL BAND ──────────────────────────────────────────────────────────────── */
.ffl-band { padding: 60px 0; background: linear-gradient(135deg, var(--forest) 0%, var(--dark) 100%); border-top: 1px solid rgba(201,169,65,0.2); border-bottom: 1px solid rgba(201,169,65,0.2); }
.ffl-band-inner { display: flex; align-items: center; gap: 60px; }
.ffl-seal { flex-shrink: 0; width: 130px; height: 130px; }
.ffl-seal svg { width: 100%; height: 100%; }
.ffl-content { flex: 1; }
.ffl-title { font-family: var(--font-display); font-size: 28px; font-weight: 800; text-transform: uppercase; letter-spacing: 2px; margin-bottom: 12px; }
.ffl-desc  { font-size: 14px; font-weight: 300; color: var(--gray-light); line-height: 1.7; max-width: 600px; }
.ffl-cta   { flex-shrink: 0; }

/* ── FOOTER ────────────────────────────────────────────────────────────────── */
.site-footer { background: var(--black); border-top: 1px solid rgba(201,169,65,0.15); }
.footer-top  { padding: 80px 0 60px; }
.footer-grid { display: grid; grid-template-columns: 2fr 1fr 1fr 1fr 1.5fr; gap: 60px; }

/* Footer brand col — full logo IMAGE (opt3_gold.png with white bg stripped via mix-blend-mode) */
.footer-brand { }
.footer-brand p { font-size: 14px; font-weight: 300; color: var(--gray-mid); line-height: 1.8; max-width: 300px; margin: 20px 0 24px; }
.footer-logo-img {
  /* opt3_gold.png has a dark navy background — multiply blend removes it on dark bg */
  width: 220px;
  height: auto;
  display: block;
  filter: drop-shadow(0 2px 12px rgba(201,169,65,0.3));
  /* transparent PNG — no blend-mode needed */
}

.footer-social { display: flex; gap: 8px; }
.footer-social a { width: 36px; height: 36px; border: 1px solid var(--gray-dark); display: flex; align-items: center; justify-content: center; color: var(--gray-mid); transition: border-color 0.2s, color 0.2s, background 0.2s; }
.footer-social a:hover { border-color: var(--gold); color: var(--gold); background: rgba(201,169,65,0.08); }
.footer-col h4 { font-family: var(--font-display); font-size: 16px; font-weight: 700; text-transform: uppercase; letter-spacing: 2px; margin-bottom: 20px; color: var(--white); position: relative; padding-bottom: 12px; }
.footer-col h4::after { content: ''; position: absolute; bottom: 0; left: 0; width: 24px; height: 2px; background: var(--gold); }
.footer-col ul { list-style: none; }
.footer-col ul li { margin-bottom: 10px; }
.footer-col ul li a { font-size: 13px; color: var(--gray-mid); transition: color 0.2s; }
.footer-col ul li a:hover { color: var(--gold); }
.footer-newsletter p { font-size: 13px; font-weight: 300; color: var(--gray-mid); line-height: 1.7; margin-bottom: 20px; }
.newsletter-form { display: flex; flex-direction: column; gap: 10px; }
.newsletter-form input { padding: 12px 16px; background: var(--forest); border: 1px solid var(--gray-dark); color: var(--white); font-family: var(--font-body); font-size: 13px; outline: none; transition: border-color 0.2s; }
.newsletter-form input:focus { border-color: var(--gold); }
.newsletter-form input::placeholder { color: var(--gray-mid); }
.newsletter-form button { padding: 12px; background: var(--gold); color: var(--black); font-family: var(--font-display); font-size: 13px; font-weight: 700; letter-spacing: 2px; text-transform: uppercase; border: none; cursor: pointer; transition: background 0.2s; }
.newsletter-form button:hover { background: var(--gold-light); }
.footer-bottom { padding: 24px 0; border-top: 1px solid rgba(255,255,255,0.05); display: flex; align-items: center; justify-content: space-between; }
.footer-copyright { font-family: var(--font-ui); font-size: 11px; color: var(--gray-mid); letter-spacing: 1px; }
.footer-ffl { font-family: var(--font-ui); font-size: 11px; font-weight: 700; color: var(--gold); letter-spacing: 2px; text-transform: uppercase; }
.footer-links-bottom { display: flex; gap: 24px; }
.footer-links-bottom a { font-family: var(--font-ui); font-size: 11px; color: var(--gray-mid); letter-spacing: 1px; transition: color 0.2s; }
.footer-links-bottom a:hover { color: var(--gold); }

/* ANIMATIONS */
@keyframes fadeUp   { from { opacity: 0; transform: translateY(24px); } to { opacity: 1; transform: translateY(0); } }
@keyframes fadeLeft { from { opacity: 0; transform: translateX(24px); } to { opacity: 1; transform: translateX(0); } }
@keyframes fadeIn   { from { opacity: 0; } to { opacity: 1; } }
.reveal { opacity: 0; transform: translateY(32px); transition: opacity 0.7s var(--ease-out), transform 0.7s var(--ease-out); }
.reveal.visible { opacity: 1; transform: translateY(0); }
.reveal-delay-1 { transition-delay: 0.1s; }
.reveal-delay-2 { transition-delay: 0.2s; }
.reveal-delay-3 { transition-delay: 0.3s; }
/* ══ about.html ══ */
.stats-strip{background:var(--gold);padding:48px 0}
.stats-inner{display:grid;grid-template-columns:repeat(4,1fr);gap:0}
.stat-item{text-align:center;border-right:1px solid rgba(0,0,0,.12);padding:0 20px}
.stat-item:last-child{border-right:none}
.stat-num{font-family:var(--font-display);font-size:56px;font-weight:900;color:var(--black);line-height:1}
.stat-label{font-family:var(--font-ui);font-size:12px;font-weight:700;letter-spacing:3px;text-transform:uppercase;color:rgba(0,0,0,.55);margin-top:4px}
.story-section{padding:100px 0;background:var(--dark)}
.story-grid{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center}
.story-img{position:relative;overflow:hidden}
.story-img img{width:100%;height:480px;object-fit:cover;display:block}
.story-img::before{content:'';position:absolute;top:20px;left:-20px;right:20px;bottom:-20px;border:2px solid rgba(201,169,65,.2);z-index:0}
.story-img img{position:relative;z-index:1}
.story-text .section-title{margin-bottom:24px}
.story-text p{font-size:15px;color:var(--gray-light);line-height:1.8;margin-bottom:16px}
.story-fact{display:flex;align-items:flex-start;gap:16px;padding:20px 0;border-bottom:1px solid var(--gray-dark)}
.story-fact-icon{width:40px;height:40px;background:rgba(201,169,65,.1);border:1px solid rgba(201,169,65,.2);display:flex;align-items:center;justify-content:center;color:var(--gold);flex-shrink:0;margin-top:2px}
.story-fact-title{font-family:var(--font-ui);font-size:14px;font-weight:700;letter-spacing:1px;text-transform:uppercase;margin-bottom:4px}
.story-fact-desc{font-size:13px;color:var(--gray-mid);line-height:1.5}
.mission-section{padding:80px 0;background:var(--black);position:relative;overflow:hidden}
.mission-quote-bg{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-family:var(--font-display);font-size:320px;font-weight:900;color:rgba(201,169,65,.03);line-height:1;pointer-events:none;user-select:none;white-space:nowrap}
.mission-content{position:relative;z-index:1;max-width:800px;margin:0 auto;text-align:center}
.mission-line{width:60px;height:3px;background:var(--gold);margin:0 auto 32px}
.mission-text{font-family:var(--font-display);font-size:clamp(28px,4vw,48px);font-weight:700;line-height:1.1;letter-spacing:.5px}
.mission-attr{font-family:var(--font-ui);font-size:12px;font-weight:600;letter-spacing:3px;text-transform:uppercase;color:var(--gold);margin-top:24px}
.ffl-info-section{padding:80px 0;background:var(--forest)}
.ffl-info-grid{display:grid;grid-template-columns:1fr 1fr;gap:40px;align-items:start}
.ffl-card{padding:32px;background:rgba(6,12,6,.4);border:1px solid rgba(201,169,65,.15)}
.ffl-card h3{font-family:var(--font-display);font-size:20px;font-weight:700;text-transform:uppercase;letter-spacing:1px;margin-bottom:16px;color:var(--gold)}
.ffl-card p{font-size:14px;color:var(--gray-light);line-height:1.7;margin-bottom:8px}
.ffl-card strong{color:var(--white)}

/* ══ contact.html ══ */
.contact-section{padding:100px 0;background:var(--dark)}
.contact-grid{display:grid;grid-template-columns:1.2fr 1fr;gap:80px;align-items:start}
.contact-form-wrap{background:var(--forest);padding:48px;border:1px solid rgba(201,169,65,.1)}
.contact-form-title{font-family:var(--font-display);font-size:28px;font-weight:800;text-transform:uppercase;letter-spacing:1px;margin-bottom:8px}
.contact-form-sub{font-size:14px;color:var(--gray-mid);margin-bottom:32px;padding-bottom:24px;border-bottom:1px solid var(--gray-dark)}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:16px}
.form-group{margin-bottom:16px}
.form-group label{display:block;font-family:var(--font-ui);font-size:11px;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:var(--gray-light);margin-bottom:8px}
.form-group input,.form-group select,.form-group textarea{width:100%;padding:12px 16px;background:var(--dark);border:1px solid var(--gray-dark);color:var(--white);font-family:var(--font-body);font-size:14px;outline:none;transition:border-color .2s;-webkit-appearance:none}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--gold)}
.form-group input::placeholder,.form-group textarea::placeholder{color:var(--gray-mid)}
.form-group textarea{resize:vertical;min-height:120px}
.form-submit{width:100%;padding:16px;background:var(--gold);color:var(--black);font-family:var(--font-display);font-size:15px;font-weight:700;letter-spacing:2px;text-transform:uppercase;border:none;cursor:pointer;transition:background .2s;clip-path:polygon(0 0,calc(100% - 10px) 0,100% 10px,100% 100%,10px 100%,0 calc(100% - 10px))}
.form-submit:hover{background:var(--gold-light)}
.contact-info-col{}
.info-card{padding:28px 32px;background:var(--forest);border:1px solid rgba(201,169,65,.1);border-left:4px solid var(--gold);margin-bottom:16px}
.info-card:first-child{border-left-color:var(--gold)}
.info-card-icon{width:44px;height:44px;background:rgba(201,169,65,.1);border:1px solid rgba(201,169,65,.2);display:flex;align-items:center;justify-content:center;color:var(--gold);margin-bottom:16px}
.info-card h4{font-family:var(--font-display);font-size:16px;font-weight:700;text-transform:uppercase;letter-spacing:1px;margin-bottom:8px}
.info-card p,.info-card a{font-size:14px;color:var(--gray-light);line-height:1.6}
.info-card a:hover{color:var(--gold)}
.hours-grid{display:grid;grid-template-columns:1fr auto;gap:4px 24px;font-size:13px;color:var(--gray-mid)}
.hours-grid span:nth-child(odd){color:var(--gray-light)}

/* ══ ffl-transfer.html ══ */
.process-section{padding:100px 0;background:var(--dark)}
.process-steps{display:grid;grid-template-columns:repeat(5,1fr);gap:0;position:relative;margin-top:60px}
.process-steps::before{content:'';position:absolute;top:40px;left:10%;right:10%;height:2px;background:linear-gradient(to right,var(--gold-dim),var(--gold),var(--gold-dim));z-index:0}
.process-step{position:relative;z-index:1;text-align:center;padding:0 12px}
.step-circle{width:80px;height:80px;border-radius:50%;border:2px solid var(--gold);background:var(--dark);display:flex;align-items:center;justify-content:center;margin:0 auto 20px;font-family:var(--font-display);font-size:28px;font-weight:900;color:var(--gold);transition:background .3s,color .3s}
.process-step:hover .step-circle{background:var(--gold);color:var(--black)}
.step-title{font-family:var(--font-display);font-size:16px;font-weight:700;text-transform:uppercase;letter-spacing:1px;margin-bottom:10px}
.step-desc{font-size:13px;color:var(--gray-mid);line-height:1.6}
.transfer-details{padding:80px 0;background:var(--black)}
.details-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:3px;margin-top:48px}
.detail-card{padding:40px 32px;background:var(--forest)}
.detail-card h3{font-family:var(--font-display);font-size:18px;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:var(--gold);margin-bottom:16px}
.detail-card p,.detail-card li{font-size:14px;color:var(--gray-light);line-height:1.7}
.ffl-contact-box{padding:40px;background:var(--forest);border:1px solid rgba(201,169,65,.2);margin-top:60px}
.ffl-contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:40px;align-items:center}

/* ══ faq.html ══ */
.faq-section{padding:100px 0;background:var(--dark)}
.faq-tabs{display:flex;gap:4px;margin-bottom:48px;flex-wrap:wrap}
.faq-tab{padding:10px 24px;font-family:var(--font-ui);font-size:12px;font-weight:600;letter-spacing:2px;text-transform:uppercase;background:transparent;border:1px solid var(--gray-dark);color:var(--gray-mid);cursor:pointer;transition:all .2s}
.faq-tab.active,.faq-tab:hover{background:var(--gold);color:var(--black);border-color:var(--gold)}
.faq-panel{display:none}
.faq-panel.active{display:block}
.faq-item{border:1px solid var(--gray-dark);margin-bottom:4px;background:var(--forest);transition:border-color .2s}
.faq-item.open{border-color:rgba(201,169,65,.3)}
.faq-q{padding:20px 24px;display:flex;align-items:center;justify-content:space-between;cursor:pointer;font-family:var(--font-ui);font-size:15px;font-weight:600;letter-spacing:.5px}
.faq-icon{width:24px;height:24px;border:1px solid var(--gray-dark);display:flex;align-items:center;justify-content:center;color:var(--gold);flex-shrink:0;margin-left:16px;transition:transform .3s,background .2s}
.faq-item.open .faq-icon{transform:rotate(45deg);background:var(--gold);border-color:var(--gold);color:var(--black)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .4s ease,padding .3s}
.faq-item.open .faq-a{max-height:500px;padding-bottom:4px}
.faq-a-inner{padding:0 24px 24px;font-size:14px;color:var(--gray-light);line-height:1.8;border-top:1px solid var(--gray-dark)}

/* ══ b2b.html ══ */
/* B2B HERO OVERRIDE — darker, more tactical */
.page-hero { height: 52vh; min-height: 420px; }

/* TIERS */
.tiers-section { padding: 100px 0; background: var(--dark); }
.tiers-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 3px; margin-top: 56px; }
.tier-card { background: var(--forest); padding: 48px 40px; position: relative; overflow: hidden; transition: background .3s; border-top: 3px solid var(--gray-dark); }
.tier-card.featured { border-top-color: var(--gold); background: var(--mid); }
.tier-badge { font-family: var(--font-ui); font-size: 10px; font-weight: 700; letter-spacing: 3px; text-transform: uppercase; color: var(--gold); margin-bottom: 12px; }
.tier-card.featured .tier-badge { color: var(--gold-light); }
.tier-name { font-family: var(--font-display); font-size: 32px; font-weight: 900; text-transform: uppercase; letter-spacing: 1px; margin-bottom: 8px; }
.tier-desc { font-size: 14px; color: var(--gray-mid); margin-bottom: 28px; line-height: 1.6; }
.tier-list { list-style: none; margin-bottom: 36px; }
.tier-list li { display: flex; align-items: flex-start; gap: 12px; padding: 8px 0; border-bottom: 1px solid rgba(255,255,255,.05); font-size: 14px; color: var(--gray-light); line-height: 1.5; }
.tier-list li::before { content: ''; width: 6px; height: 6px; background: var(--gold); border-radius: 50%; flex-shrink: 0; margin-top: 6px; }
.tier-card.featured .tier-list li { color: var(--white); }
.tier-cta { display: block; padding: 14px 28px; text-align: center; font-family: var(--font-display); font-size: 14px; font-weight: 700; letter-spacing: 2px; text-transform: uppercase; background: var(--gold); color: var(--black); clip-path: polygon(0 0, calc(100% - 8px) 0, 100% 8px, 100% 100%, 8px 100%, 0 calc(100% - 8px)); transition: background .2s; }
.tier-cta:hover { background: var(--gold-light); }
.tier-cta.ghost { background: transparent; border: 1px solid rgba(201,169,65,.4); color: var(--white); clip-path: none; }
.tier-cta.ghost:hover { border-color: var(--gold); color: var(--gold); }

/* WHO WE SERVE */
.serve-section { padding: 100px 0; background: var(--black); }
.serve-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 3px; margin-top: 56px; }
.serve-card { background: var(--forest); padding: 36px 28px; position: relative; overflow: hidden; transition: background .3s; }
.serve-card::before { content: ''; position: absolute; top: 0; left: 0; width: 3px; height: 0; background: var(--gold); transition: height .4s var(--ease-out); }
.serve-card:hover::before { height: 100%; }
.serve-card:hover { background: var(--mid); }
.serve-icon { width: 52px; height: 52px; background: rgba(201,169,65,.1); border: 1px solid rgba(201,169,65,.2); display: flex; align-items: center; justify-content: center; color: var(--gold); margin-bottom: 20px; }
.serve-title { font-family: var(--font-display); font-size: 20px; font-weight: 700; text-transform: uppercase; letter-spacing: 1px; margin-bottom: 12px; }
.serve-desc { font-size: 13px; color: var(--gray-mid); line-height: 1.7; }

/* PROCESS */
.process-section { padding: 100px 0; background: var(--dark); }
.process-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 3px; margin-top: 56px; }
.process-item { padding: 40px 32px; background: var(--forest); text-align: center; }
.process-num { font-family: var(--font-display); font-size: 72px; font-weight: 900; color: rgba(201,169,65,.08); line-height: 1; margin-bottom: 16px; }
.process-title { font-family: var(--font-display); font-size: 18px; font-weight: 700; text-transform: uppercase; letter-spacing: 1px; margin-bottom: 12px; }
.process-desc { font-size: 13px; color: var(--gray-mid); line-height: 1.7; }

/* SPECS TABLE */
.specs-section { padding: 80px 0; background: var(--forest); }
.specs-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 40px; margin-top: 48px; }
.spec-table { background: rgba(6,12,6,.4); border: 1px solid rgba(201,169,65,.12); }
.spec-table-title { background: rgba(201,169,65,.1); padding: 16px 24px; font-family: var(--font-display); font-size: 16px; font-weight: 700; text-transform: uppercase; letter-spacing: 1px; color: var(--gold); border-bottom: 1px solid rgba(201,169,65,.2); }
.spec-row { display: flex; justify-content: space-between; padding: 12px 24px; border-bottom: 1px solid rgba(255,255,255,.04); font-size: 13px; }
.spec-row:last-child { border-bottom: none; }
.spec-label { color: var(--gray-mid); }
.spec-value { color: var(--white); font-weight: 600; }
.spec-value.gold { color: var(--gold); }

/* QUOTE FORM */
.quote-section { padding: 100px 0; background: var(--black); }
.quote-grid { display: grid; grid-template-columns: 1.4fr 1fr; gap: 80px; align-items: start; }
.quote-form-wrap { background: var(--forest); padding: 48px; border: 1px solid rgba(201,169,65,.12); }
.quote-form-title { font-family: var(--font-display); font-size: 28px; font-weight: 800; text-transform: uppercase; letter-spacing: 1px; margin-bottom: 8px; }
.quote-form-sub { font-size: 14px; color: var(--gray-mid); margin-bottom: 32px; padding-bottom: 24px; border-bottom: 1px solid var(--gray-dark); }
.form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; margin-bottom: 0; }
.form-group { margin-bottom: 16px; }
.form-group label { display: block; font-family: var(--font-ui); font-size: 11px; font-weight: 700; letter-spacing: 2px; text-transform: uppercase; color: var(--gray-light); margin-bottom: 8px; }
.form-group input, .form-group select, .form-group textarea { width: 100%; padding: 12px 16px; background: var(--dark); border: 1px solid var(--gray-dark); color: var(--white); font-family: var(--font-body); font-size: 14px; outline: none; transition: border-color .2s; -webkit-appearance: none; }
.form-group input:focus, .form-group select:focus, .form-group textarea:focus { border-color: var(--gold); }
.form-group input::placeholder, .form-group textarea::placeholder { color: var(--gray-mid); }
.form-group textarea { resize: vertical; min-height: 120px; }
.form-submit { width: 100%; padding: 16px; background: var(--gold); color: var(--black); font-family: var(--font-display); font-size: 15px; font-weight: 700; letter-spacing: 2px; text-transform: uppercase; border: none; cursor: pointer; transition: background .2s; clip-path: polygon(0 0, calc(100% - 10px) 0, 100% 10px, 100% 100%, 10px 100%, 0 calc(100% - 10px)); }
.form-submit:hover { background: var(--gold-light); }
.quote-info { }
.info-block { padding: 28px 32px; background: var(--forest); border: 1px solid rgba(201,169,65,.1); border-left: 4px solid var(--gold); margin-bottom: 16px; }
.info-block h4 { font-family: var(--font-display); font-size: 16px; font-weight: 700; text-transform: uppercase; letter-spacing: 1px; margin-bottom: 8px; }
.info-block p, .info-block a { font-size: 14px; color: var(--gray-light); line-height: 1.7; }
.info-block a:hover { color: var(--gold); }
/* ── WooCommerce Base ───────────────────────────────────────────────────── */
.woocommerce-page .site-main { background: var(--dark); min-height: 60vh; padding: 80px 0; }
.woocommerce-page .container { max-width: 1400px; margin: 0 auto; padding: 0 40px; }
.woocommerce ul.products { display: grid; grid-template-columns: repeat(4,1fr); gap: 2px; list-style: none; padding: 0; margin: 0; }
.woocommerce ul.products li.product { background: var(--forest); transition: transform .3s var(--ease-out); }
.woocommerce ul.products li.product:hover { transform: translateY(-4px); }
.woocommerce ul.products li.product a img { width: 100%; aspect-ratio: 1; object-fit: contain; padding: 20px; background: var(--panel); display: block; }
.woocommerce ul.products li.product .woocommerce-loop-product__title { font-family: var(--font-ui); font-size: 14px; font-weight: 600; color: var(--white); padding: 12px 16px 4px; line-height: 1.3; }
.woocommerce ul.products li.product .price { font-family: var(--font-display); font-size: 20px; font-weight: 700; color: var(--gold); padding: 0 16px 16px; display: block; }
.woocommerce ul.products li.product .button { margin: 0 16px 16px; background: var(--gold); color: var(--black); font-family: var(--font-display); font-size: 12px; font-weight: 700; letter-spacing: 2px; text-transform: uppercase; padding: 8px 16px; border: none; cursor: pointer; display: block; text-align: center; transition: background .2s; }
.woocommerce ul.products li.product .button:hover { background: var(--gold-light); }
.woocommerce .woocommerce-ordering, .woocommerce .woocommerce-result-count { font-family: var(--font-ui); color: var(--gray-light); margin-bottom: 24px; }
.woocommerce .woocommerce-ordering select { background: var(--forest); border: 1px solid var(--gray-dark); color: var(--white); padding: 8px 12px; font-family: var(--font-ui); }
.woocommerce nav.woocommerce-pagination { margin-top: 48px; text-align: center; }
.woocommerce nav.woocommerce-pagination ul { display: inline-flex; gap: 4px; list-style: none; padding: 0; }
.woocommerce nav.woocommerce-pagination ul li a,
.woocommerce nav.woocommerce-pagination ul li span { padding: 8px 14px; background: var(--forest); color: var(--gray-light); font-family: var(--font-ui); font-size: 13px; border: 1px solid var(--gray-dark); transition: all .2s; }
.woocommerce nav.woocommerce-pagination ul li a:hover,
.woocommerce nav.woocommerce-pagination ul li span.current { background: var(--gold); color: var(--black); border-color: var(--gold); }
.woocommerce div.product { padding: 60px 0; }
.woocommerce div.product .product_title { font-family: var(--font-display); font-size: clamp(28px,4vw,52px); font-weight: 800; text-transform: uppercase; letter-spacing: -0.5px; color: var(--white); margin-bottom: 16px; }
.woocommerce div.product p.price { font-family: var(--font-display); font-size: 36px; font-weight: 700; color: var(--gold); margin: 16px 0 24px; }
.woocommerce div.product .woocommerce-product-details__short-description { font-size: 15px; color: var(--gray-light); line-height: 1.7; margin-bottom: 24px; }
.woocommerce div.product form.cart .button { background: var(--gold); color: var(--black); font-family: var(--font-display); font-size: 14px; font-weight: 700; letter-spacing: 2px; text-transform: uppercase; padding: 14px 32px; border: none; cursor: pointer; clip-path: polygon(0 0,calc(100% - 10px) 0,100% 10px,100% 100%,10px 100%,0 calc(100% - 10px)); transition: background .2s; }
.woocommerce div.product form.cart .button:hover { background: var(--gold-light); }
.woocommerce div.product form.cart .quantity input { background: var(--forest); border: 1px solid var(--gray-dark); color: var(--white); padding: 12px; width: 70px; font-size: 16px; text-align: center; }
.woocommerce .woocommerce-tabs { margin-top: 48px; }
.woocommerce .woocommerce-tabs ul.tabs { border-bottom: 1px solid var(--gray-dark); list-style: none; padding: 0; display: flex; gap: 4px; margin: 0 0 32px; }
.woocommerce .woocommerce-tabs ul.tabs li { background: transparent; border: 1px solid var(--gray-dark); }
.woocommerce .woocommerce-tabs ul.tabs li a { font-family: var(--font-ui); font-size: 12px; font-weight: 600; letter-spacing: 2px; text-transform: uppercase; color: var(--gray-mid); padding: 10px 20px; display: block; transition: all .2s; }
.woocommerce .woocommerce-tabs ul.tabs li.active a,
.woocommerce .woocommerce-tabs ul.tabs li a:hover { color: var(--black); background: var(--gold); border-color: var(--gold); }
.woocommerce .woocommerce-tabs .panel { background: var(--forest); padding: 32px; color: var(--gray-light); font-size: 14px; line-height: 1.7; }
.woocommerce-message, .woocommerce-info, .woocommerce-error { background: var(--forest); border-left: 4px solid var(--gold); color: var(--white); padding: 16px 20px; font-family: var(--font-ui); font-size: 14px; margin-bottom: 24px; list-style: none; }
.woocommerce-error { border-left-color: #e55; }

/* ══ GAP FIXES — from audit_css.py ══ */

/* ══ Missing from about.html ══ */
.breadcrumb{display:flex;align-items:center;gap:8px;font-family:var(--font-ui);font-size:11px;font-weight:600;letter-spacing:2px;text-transform:uppercase;color:var(--gray-mid);margin-bottom:20px}
.breadcrumb a{transition:color .2s}
.breadcrumb a:hover{color:var(--gold)}
.breadcrumb-sep{color:var(--gold-dim)}
.pol-list{list-style:none;margin-bottom:16px}
.pol-list li{padding:8px 0 8px 20px;border-left:2px solid var(--gold-dim);font-size:14px;color:var(--gray-light);line-height:1.6;margin-bottom:4px;position:relative}
/* FEATURE CARDS (shared) */
.feats-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:3px}
.feat-card{background:var(--forest);padding:48px 40px;position:relative;overflow:hidden;transition:background .3s}
.feat-card::before{content:'';position:absolute;top:0;left:0;width:3px;height:0;background:var(--gold);transition:height .4s var(--ease-out)}
.feat-card:hover::before{height:100%}
.feat-card:hover{background:var(--mid)}
.feat-num{font-family:var(--font-display);font-size:60px;font-weight:900;color:rgba(201,169,65,.08);line-height:1;margin-bottom:20px}
.feat-icon{width:48px;height:48px;background:rgba(201,169,65,.1);border:1px solid rgba(201,169,65,.2);display:flex;align-items:center;justify-content:center;color:var(--gold);margin-bottom:20px}
.feat-title{font-family:var(--font-display);font-size:20px;font-weight:700;text-transform:uppercase;letter-spacing:1px;margin-bottom:12px}
.feat-desc{font-size:14px;font-weight:300;color:var(--gray-light);line-height:1.7}
/* CTA BAND */
.cta-band{padding:80px 0;background:linear-gradient(135deg,var(--forest) 0%,var(--dark) 100%);border-top:1px solid rgba(201,169,65,.2);border-bottom:1px solid rgba(201,169,65,.2)}
.cta-band-inner{text-align:center}
.cta-band-label{font-family:var(--font-ui);font-size:11px;font-weight:600;letter-spacing:4px;text-transform:uppercase;color:var(--gold);margin-bottom:16px}
.cta-band-title{font-family:var(--font-display);font-size:clamp(36px,4vw,52px);font-weight:800;text-transform:uppercase;line-height:.95;margin-bottom:24px}
.cta-band-sub{font-size:15px;font-weight:300;color:var(--gray-light);max-width:480px;margin:0 auto 36px}
.cta-band-actions{display:flex;align-items:center;justify-content:center;gap:20px}
/* FFL BAND (mini) */
.ffl-mini{padding:40px 0;background:var(--forest);border-top:1px solid rgba(201,169,65,.1)}
.ffl-mini-inner{display:flex;align-items:center;gap:24px}
.ffl-mini-seal{flex-shrink:0;width:80px;height:80px}
.ffl-mini-content h4{font-family:var(--font-display);font-size:18px;font-weight:700;text-transform:uppercase;letter-spacing:1px;margin-bottom:4px}
.ffl-mini-content p{font-size:13px;color:var(--gray-mid)}

/* ══ Missing from shipping.html ══ */
/* POLICY LAYOUT */
.policy-wrap{display:grid;grid-template-columns:280px 1fr;gap:64px;padding:80px 0 120px;align-items:start}
.policy-toc{position:sticky;top:140px}
.toc-label{font-family:var(--font-ui);font-size:10px;font-weight:700;letter-spacing:3px;text-transform:uppercase;color:var(--gold);margin-bottom:16px}
.toc-list{list-style:none}
.toc-list li a{display:block;padding:8px 0 8px 16px;font-family:var(--font-ui);font-size:12px;font-weight:600;letter-spacing:1px;color:var(--gray-mid);border-left:2px solid var(--gray-dark);transition:color .2s,border-color .2s}
.toc-list li a:hover,.toc-list li a.active{color:var(--gold);border-left-color:var(--gold)}
.toc-footer{margin-top:32px;padding:20px;background:rgba(201,169,65,.06);border:1px solid rgba(201,169,65,.15)}
.toc-footer-label{font-family:var(--font-ui);font-size:10px;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:var(--gold);margin-bottom:8px}
.toc-footer p{font-size:12px;color:var(--gray-mid);line-height:1.6}
.toc-footer a{color:var(--gold)}
.policy-body{min-width:0}
.pol-section{margin-bottom:56px;scroll-margin-top:160px}
.pol-title{font-family:var(--font-display);font-size:26px;font-weight:800;text-transform:uppercase;letter-spacing:1px;margin-bottom:8px}
.pol-bar{width:40px;height:3px;background:var(--gold);margin-bottom:24px}
.pol-body p{font-size:15px;color:var(--gray-light);line-height:1.8;margin-bottom:16px}
.pol-body h4{font-family:var(--font-display);font-size:16px;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:var(--white);margin:24px 0 10px}
.pol-callout{background:rgba(201,169,65,.08);border:1px solid rgba(201,169,65,.2);border-left:4px solid var(--gold);padding:20px 24px;margin:20px 0}
.pol-callout p{font-size:14px;color:var(--white);margin:0;line-height:1.7}
.pol-ref-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-top:20px}
.pol-ref-card{padding:16px 20px;background:var(--forest);border:1px solid var(--gray-dark)}
.pol-ref-card-title{font-family:var(--font-ui);font-size:12px;font-weight:700;letter-spacing:1px;text-transform:uppercase;color:var(--gold);margin-bottom:4px}
.pol-ref-card p{font-size:13px;color:var(--gray-mid);margin:0}
.pol-updated{font-family:var(--font-ui);font-size:11px;font-weight:600;letter-spacing:2px;text-transform:uppercase;color:var(--gray-mid);margin-bottom:40px;padding-bottom:24px;border-bottom:1px solid var(--gray-dark)}

/* ══ FINAL GAPS FIX ══ */

/* .page-hero* (hero section for inner pages) */
/* PAGE HERO */
.page-hero{position:relative;height:44vh;min-height:360px;display:flex;align-items:flex-end;margin-top:116px;overflow:hidden}
.page-hero-bg{position:absolute;inset:0;background-size:cover;background-position:center;transform:scale(1.05);transition:transform 8s ease-out}
.page-hero-overlay{position:absolute;inset:0;background:linear-gradient(to right,rgba(6,12,6,.92) 35%,rgba(6,12,6,.6) 65%,rgba(6,12,6,.25) 100%),linear-gradient(to top,rgba(6,12,6,.6) 0%,transparent 50%)}
.page-hero-content{position:relative;z-index:1;padding:0 80px 56px}
.page-title-group{display:flex;align-items:center;gap:20px}
.page-gold-bar{width:4px;height:64px;background:var(--gold);flex-shrink:0}
.page-title{font-family:var(--font-display);font-size:clamp(48px,6vw,80px);font-weight:900;text-transform:uppercase;letter-spacing:-1px;line-height:.95}
.page-title .outline{-webkit-text-stroke:1.5px var(--gold);color:transparent}
.page-sub{font-size:15px;font-weight:300;color:rgba(240,238,232,.7);max-width:500px;margin-top:14px}


/* ── WordPress Admin Bar ────────────────────────────────────────────────── */
.admin-bar .site-header { top: 32px; }
.admin-bar .hero        { padding-top: 184px; }
.admin-bar .page-hero   { margin-top: 148px; }
@media screen and (max-width: 782px) {
  .admin-bar .site-header { top: 46px; }
  .admin-bar .hero        { padding-top: 198px; }
  .admin-bar .page-hero   { margin-top: 162px; }
}

/* .trust-text wrapper */
.trust-text{display:flex;flex-direction:column}
