/* Fair Game Group — self-hosted clone (no Shopify) */
:root{
  --c-primary:#1a1a1a;
  --c-accent:#b63c29;
  --c-text:#222;
  --c-muted:#666;
  --c-bg:#fff;
  --c-soft:#f5f5f5;
  --c-border:#e5e5e5;
  --c-success:#2a8f47;
  --radius:4px;
  --shadow:0 2px 10px rgba(0,0,0,.08);
  --max-w:1280px;
  --font: 'Roboto', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
}
*{box-sizing:border-box;margin:0;padding:0}
html,body{font-family:var(--font);color:var(--c-text);background:var(--c-bg);line-height:1.5;font-size:15px}
a{color:inherit;text-decoration:none}
a:hover{color:var(--c-accent)}
img{max-width:100%;height:auto;display:block}
button{font-family:inherit;cursor:pointer;border:0;background:none}
input,select,textarea{font-family:inherit;font-size:inherit}

/* Layout */
.container{max-width:var(--max-w);margin:0 auto;padding:0 20px}

/* Header */
.top-bar{background:#000;color:#fff;font-size:14px;border-bottom:1px solid #222;overflow:hidden}
.top-bar-stage{position:relative;height:40px}
.tb-slide{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;gap:48px;flex-wrap:wrap;opacity:0;animation:tb-rotate 10s ease-in-out infinite}
.tb-slide-shipping{animation-delay:0s;font-weight:500;letter-spacing:.3px}
.tb-slide-contacts{animation-delay:5s}
.top-bar .tb-item{display:inline-flex;align-items:center;gap:8px;color:#fff;text-decoration:none;font-weight:400}
.top-bar a.tb-item:hover{color:var(--c-accent);text-decoration:none}
.top-bar .tb-icon{font-size:14px;opacity:.9}
@keyframes tb-rotate{
  0%   {opacity:0}
  4%   {opacity:1}
  46%  {opacity:1}
  50%  {opacity:0}
  100% {opacity:0}
}
@media (prefers-reduced-motion:reduce){
  .tb-slide{animation:none;opacity:1;position:static;display:flex}
  .tb-slide-contacts{display:none}
  .top-bar-stage{height:auto;padding:10px 0}
}
@media (max-width:700px){
  .top-bar{font-size:12px}
  .top-bar-stage{height:36px}
  .tb-slide{gap:14px}
  .top-bar .tb-item{gap:5px}
}
header.site-header{background:#fff;border-bottom:1px solid var(--c-border);position:sticky;top:0;z-index:100}
.header-inner{display:flex;align-items:center;justify-content:space-between;gap:24px;padding:12px 0}
.logo{display:flex;align-items:center;font-weight:700;font-size:22px;color:var(--c-primary)}
.logo img{max-height:60px;width:auto}
.header-search{flex:1;max-width:520px;position:relative}
.header-search input{width:100%;padding:10px 14px 10px 40px;border:1px solid var(--c-border);border-radius:999px;font-size:14px;background:var(--c-soft)}
.header-search::before{content:"🔍";position:absolute;left:14px;top:50%;transform:translateY(-50%);font-size:14px;opacity:.6}
.header-actions{display:flex;gap:16px;align-items:center;font-size:14px}
.header-actions a,.header-actions button{display:flex;align-items:center;gap:6px;font-weight:500}
.cart-count{background:var(--c-accent);color:#fff;border-radius:999px;padding:2px 8px;font-size:12px;font-weight:700;min-width:22px;text-align:center}

/* Primary nav */
nav.primary{background:#fff;border-bottom:1px solid var(--c-border)}
nav.primary ul{display:flex;list-style:none;flex-wrap:wrap;gap:2px;max-width:var(--max-w);margin:0 auto;padding:0 20px}
nav.primary li{position:relative}
nav.primary a{display:block;padding:14px 18px;font-size:14px;font-weight:600;text-transform:uppercase;letter-spacing:.3px}
nav.primary a:hover{background:var(--c-soft);color:var(--c-accent)}
nav.primary li:hover .submenu{display:block}
.submenu{display:none;position:absolute;top:100%;left:0;background:#fff;border:1px solid var(--c-border);box-shadow:var(--shadow);min-width:240px;padding:8px 0;z-index:50}
.submenu a{padding:8px 18px;font-size:13px;font-weight:400;text-transform:none;letter-spacing:0}

/* Hero */
.hero{position:relative;background:#222}
.hero img{width:100%;height:auto;opacity:.85}
.hero-overlay{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);text-align:center;color:#fff;width:90%;max-width:800px}
.hero-overlay h1{font-size:clamp(28px,5vw,54px);font-weight:800;text-transform:uppercase;letter-spacing:1px;margin-bottom:16px;text-shadow:2px 2px 8px rgba(0,0,0,.6)}
.hero-overlay p{font-size:18px;margin-bottom:24px;text-shadow:1px 1px 6px rgba(0,0,0,.6)}
.btn{display:inline-block;padding:12px 28px;background:var(--c-accent);color:#fff;font-weight:700;text-transform:uppercase;letter-spacing:.5px;border-radius:var(--radius);transition:transform .1s,background .2s;font-size:14px}
.btn:hover{background:#8e2d1e;color:#fff;transform:translateY(-1px)}
.btn:disabled{opacity:.5;cursor:not-allowed}

/* Accessibility: skip link + focus-visible */
.skip-link{position:absolute;left:-9999px;top:8px;background:var(--c-primary);color:#fff;padding:10px 16px;border-radius:4px;font-weight:700;z-index:9999}
.skip-link:focus{left:8px}
:focus-visible{outline:3px solid #ff9900;outline-offset:2px;border-radius:2px}
.btn:focus-visible,.cat-card:focus-visible,.product-card:focus-visible{outline:3px solid #ff9900;outline-offset:3px}
nav.primary li:focus-within .submenu{display:block}
.btn-outline{background:transparent;border:2px solid #fff;padding:10px 26px}
.btn-outline:hover{background:#fff;color:var(--c-primary)}
.btn-secondary{background:var(--c-primary)}
.btn-secondary:hover{background:#000}

/* Sections */
section.block{padding:48px 0}
section.block h2{font-size:28px;font-weight:800;text-transform:uppercase;text-align:center;margin-bottom:8px;letter-spacing:.5px}
section.block .sub{text-align:center;color:var(--c-muted);margin-bottom:32px}

/* Category/Brand grid */
.card-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:20px}
.card-grid.brands{grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}
.cat-card{background:#fff;border:1px solid var(--c-border);border-radius:var(--radius);overflow:hidden;transition:transform .15s,box-shadow .15s;display:block}
.cat-card:hover{transform:translateY(-3px);box-shadow:var(--shadow)}
.cat-card .thumb{aspect-ratio:4/3;background:var(--c-soft);display:flex;align-items:center;justify-content:center;overflow:hidden}
.cat-card .thumb img{width:100%;height:100%;object-fit:cover}
.cat-card .body{padding:14px;text-align:center}
.cat-card h3{font-size:15px;font-weight:700;text-transform:uppercase;color:var(--c-primary)}
.cat-card .count{font-size:12px;color:var(--c-muted);margin-top:4px}

/* Product grid */
.product-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:20px}
.product-card{background:#fff;border:1px solid var(--c-border);border-radius:var(--radius);overflow:hidden;transition:transform .15s,box-shadow .15s;display:flex;flex-direction:column}
.product-card:hover{transform:translateY(-2px);box-shadow:var(--shadow)}
.product-card .thumb{aspect-ratio:1/1;background:var(--c-soft);overflow:hidden}
.product-card .thumb img{width:100%;height:100%;object-fit:contain;padding:8px}
.product-card .body{padding:12px;flex:1;display:flex;flex-direction:column;gap:8px}
.product-card .vendor{font-size:11px;color:var(--c-muted);text-transform:uppercase;letter-spacing:.5px}
.product-card h3{font-size:14px;font-weight:600;line-height:1.3;flex:1;color:var(--c-primary)}
.product-card .price{font-size:16px;font-weight:700;color:var(--c-primary)}
.product-card .price .compare{color:var(--c-muted);text-decoration:line-through;font-weight:400;margin-left:6px;font-size:13px}
.product-card .price .badge{background:var(--c-accent);color:#fff;font-size:10px;padding:2px 6px;border-radius:2px;margin-left:8px;font-weight:700;vertical-align:middle}

/* Product page */
.pdp{display:grid;grid-template-columns:1.2fr 1fr;gap:48px;padding:32px 0}
.pdp-gallery{position:sticky;top:100px;align-self:start}
.pdp-gallery .main{aspect-ratio:1/1;background:var(--c-soft);border-radius:var(--radius);overflow:hidden;margin-bottom:12px}
.pdp-gallery .main img{width:100%;height:100%;object-fit:contain}
.pdp-thumbs{display:flex;gap:8px;flex-wrap:wrap}
.pdp-thumbs button{width:72px;height:72px;border:1px solid var(--c-border);border-radius:var(--radius);overflow:hidden;padding:0}
.pdp-thumbs button.active{border:2px solid var(--c-accent)}
.pdp-thumbs img{width:100%;height:100%;object-fit:contain}
.pdp-info .vendor{font-size:12px;color:var(--c-muted);text-transform:uppercase;letter-spacing:.8px;margin-bottom:8px}
.pdp-info h1{font-size:28px;font-weight:800;margin-bottom:16px;line-height:1.2;color:var(--c-primary)}
.pdp-price{font-size:26px;font-weight:800;margin-bottom:24px;color:var(--c-primary)}
.pdp-price .compare{color:var(--c-muted);text-decoration:line-through;font-weight:400;font-size:18px;margin-left:10px}
.pdp-options{margin:20px 0}
.pdp-options label{display:block;font-size:13px;font-weight:700;text-transform:uppercase;margin-bottom:8px;letter-spacing:.3px}
.pdp-options .variants{display:flex;flex-wrap:wrap;gap:8px}
.pdp-options .variant{padding:8px 14px;border:2px solid var(--c-border);border-radius:var(--radius);background:#fff;font-size:14px;transition:all .15s}
.pdp-options .variant:hover{border-color:var(--c-primary)}
.pdp-options .variant.active{border-color:var(--c-primary);background:var(--c-primary);color:#fff}
.pdp-options .variant:disabled{opacity:.4;cursor:not-allowed;text-decoration:line-through}
.pdp-qty{display:flex;align-items:center;gap:12px;margin:20px 0}
.pdp-qty input{width:70px;padding:10px;border:1px solid var(--c-border);border-radius:var(--radius);text-align:center;font-size:16px;font-weight:600}
.pdp-qty button{width:36px;height:36px;border:1px solid var(--c-border);border-radius:var(--radius);background:#fff;font-size:18px;font-weight:700}
.pdp-add{display:flex;gap:12px;margin-bottom:24px}
.pdp-add .btn{flex:1;padding:14px 24px;font-size:15px}
.pdp-desc{margin-top:32px;padding-top:24px;border-top:1px solid var(--c-border);line-height:1.7}
.pdp-desc h2{font-size:20px;margin-bottom:12px}
.pdp-desc p{margin-bottom:12px}
.pdp-desc ul{margin-left:20px;margin-bottom:12px}
.pdp-meta{margin-top:24px;padding-top:20px;border-top:1px solid var(--c-border);font-size:13px;color:var(--c-muted)}
.pdp-meta a{color:var(--c-accent)}

/* Breadcrumb */
.breadcrumb{font-size:13px;color:var(--c-muted);padding:16px 0}
.breadcrumb a:hover{color:var(--c-accent)}
.breadcrumb .sep{margin:0 8px;color:#ccc}

/* Filter bar (collection) */
.filter-bar{display:flex;justify-content:space-between;align-items:center;padding:16px 0;border-bottom:1px solid var(--c-border);margin-bottom:24px;flex-wrap:wrap;gap:16px}
.filter-bar .results{font-size:14px;color:var(--c-muted)}
.filter-bar select{padding:8px 12px;border:1px solid var(--c-border);border-radius:var(--radius);font-size:14px;background:#fff}
.collection-header{padding:32px 0;text-align:center;background:linear-gradient(135deg,var(--c-soft),#fff)}
.collection-header h1{font-size:36px;font-weight:800;text-transform:uppercase;letter-spacing:1px}
.collection-header p{color:var(--c-muted);margin-top:8px;max-width:700px;margin-left:auto;margin-right:auto}

/* Pagination */
.pagination{display:flex;justify-content:center;gap:6px;padding:32px 0;flex-wrap:wrap}
.pagination a,.pagination span{padding:8px 14px;border:1px solid var(--c-border);border-radius:var(--radius);font-size:14px;font-weight:600}
.pagination a:hover{background:var(--c-primary);color:#fff;border-color:var(--c-primary)}
.pagination .current{background:var(--c-primary);color:#fff;border-color:var(--c-primary)}

/* Footer */
footer.site-footer{background:var(--c-primary);color:#ccc;padding:48px 0 24px;margin-top:64px}
footer.site-footer a{color:#ccc}
footer.site-footer a:hover{color:#fff}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:40px;margin-bottom:32px}
.footer-grid h4{color:#fff;font-size:14px;text-transform:uppercase;letter-spacing:.5px;margin-bottom:14px;font-weight:700}
.footer-grid ul{list-style:none;display:flex;flex-direction:column;gap:8px}
.footer-grid ul a{font-size:13px}
.footer-brand p{font-size:13px;line-height:1.7;margin-bottom:12px}
.footer-brand .contact{font-size:13px;margin-top:16px}
.footer-brand .contact div{margin-bottom:4px}
.footer-bottom{border-top:1px solid #333;padding-top:20px;display:flex;justify-content:space-between;align-items:center;font-size:12px;color:#888;flex-wrap:wrap;gap:12px}

.visually-hidden{position:absolute !important;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
.cart-open{border:0;background:none;font:inherit;color:inherit;cursor:pointer;padding:0;display:flex;gap:6px;align-items:center;font-weight:500}
.breadcrumb .sep[aria-hidden="true"]{color:#bbb}

/* Cart drawer */
.cart-drawer{position:fixed;top:0;right:0;bottom:0;width:420px;max-width:90vw;background:#fff;box-shadow:-4px 0 20px rgba(0,0,0,.15);transform:translateX(100%);transition:transform .3s;z-index:1000;display:flex;flex-direction:column}
.cart-drawer.open{transform:translateX(0)}
.cart-drawer header{padding:20px;border-bottom:1px solid var(--c-border);display:flex;justify-content:space-between;align-items:center}
.cart-drawer header h3{font-size:18px;font-weight:800;text-transform:uppercase}
.cart-drawer header button{font-size:24px;line-height:1;color:var(--c-muted)}
.cart-items{flex:1;overflow-y:auto;padding:0 20px}
.cart-item{display:flex;gap:12px;padding:16px 0;border-bottom:1px solid var(--c-border)}
.cart-item img{width:60px;height:60px;object-fit:contain;background:var(--c-soft);border-radius:var(--radius)}
.cart-item .info{flex:1;font-size:13px}
.cart-item .info h4{font-size:14px;margin-bottom:4px}
.cart-item .rm{color:var(--c-accent);font-size:12px;margin-top:4px}
.cart-footer{padding:20px;border-top:1px solid var(--c-border)}
.cart-footer .total{display:flex;justify-content:space-between;font-weight:700;font-size:16px;margin-bottom:12px}
.cart-footer .btn{width:100%;display:block;text-align:center}
.cart-empty{padding:40px 20px;text-align:center;color:var(--c-muted)}
.overlay{position:fixed;inset:0;background:rgba(0,0,0,.4);z-index:999;display:none}
.overlay.open{display:block}

/* Page content */
.content-page{padding:40px 0;max-width:860px;margin:0 auto}
.content-page h1{font-size:32px;font-weight:800;margin-bottom:16px;text-transform:uppercase}
.content-page h2{font-size:22px;margin:24px 0 12px}
.content-page p{margin-bottom:12px;line-height:1.7}

/* Search results */
.search-page{padding:32px 0}
.search-page .meta{margin-bottom:16px;color:var(--c-muted);font-size:14px}

/* Responsive */
@media (max-width:900px){
  .pdp{grid-template-columns:1fr;gap:24px}
  .pdp-gallery{position:static}
  .footer-grid{grid-template-columns:1fr 1fr;gap:28px}
  nav.primary ul{overflow-x:auto;flex-wrap:nowrap}
  nav.primary a{white-space:nowrap;padding:12px 14px}
  .header-search{display:none}
}
@media (max-width:600px){
  .footer-grid{grid-template-columns:1fr}
  .header-inner{gap:12px}
  .logo{font-size:18px}
  .logo img{max-height:48px}
}
