/*
Theme Name: Kentucky Ballistic
Description: Military olive and forest green theme for Kentucky Ballistic firearms store
Version: 1.0
*/
:root{
  --green:#2d4a1e;
  --dark-green:#1a2e0f;
  --forest:#3a5c28;
  --olive:#6b7c3f;
  --tan:#c4a26a;
  --brown:#7a5c38;
  --black:#0a0a0a;
  --dark:#111;
  --card:#161f0f;
  --card2:#1a2410;
  --border:#2a3a1a;
  --light:#eee8d8;
  --grey:#8a9070;
  --gold:#c9a227;
  --orange:#d4720a;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
body{font-family:'Segoe UI',system-ui,sans-serif;background:var(--black);color:var(--light);line-height:1.6}
a{color:var(--tan);text-decoration:none}
a:hover{color:var(--gold)}
img{max-width:100%;display:block}

/* HEADER */
.kb-header{position:sticky;top:0;z-index:1000;background:rgba(10,10,10,.97);
  border-bottom:3px solid var(--olive);padding:0 2rem;display:flex;align-items:center;gap:2rem;height:68px}
.kb-logo{font-size:1.25rem;font-weight:900;letter-spacing:.06em;color:#fff;text-transform:uppercase;
  display:flex;align-items:center;gap:.6rem;white-space:nowrap}
.kb-logo-icon{font-size:1.6rem}
.kb-logo span{color:var(--tan)}
.kb-nav{display:flex;align-items:center;gap:1.5rem;list-style:none;margin-left:auto}
.kb-nav a{color:var(--light);font-size:.88rem;font-weight:700;text-transform:uppercase;letter-spacing:.09em;
  padding:.4rem 0;border-bottom:2px solid transparent;transition:.2s}
.kb-nav a:hover{color:var(--tan);border-bottom-color:var(--olive)}
.kb-nav-cta{background:var(--forest);color:var(--tan)!important;padding:.45rem 1.3rem!important;
  border-radius:2px;border:1px solid var(--olive)!important;border-bottom-color:var(--olive)!important}
.kb-nav-cta:hover{background:var(--olive)!important;color:#fff!important}
.kb-hamburger{display:none;background:none;border:none;cursor:pointer;padding:.4rem;margin-left:auto}
.kb-hamburger span{display:block;width:24px;height:2px;background:var(--light);margin:5px 0}
/* Dropdown */
.kb-nav li{position:relative}
.kb-dropdown{display:none;position:absolute;top:100%;left:0;background:#111;
  border:1px solid var(--border);border-top:2px solid var(--olive);min-width:200px;z-index:200}
.kb-dropdown a{display:block;padding:.7rem 1.2rem;color:var(--light)!important;font-size:.85rem;
  border-bottom:1px solid var(--border);border-bottom-color:var(--border)!important}
.kb-dropdown a:last-child{border-bottom:none!important}
.kb-dropdown a:hover{background:var(--forest);color:var(--tan)!important}
.kb-nav li:hover .kb-dropdown{display:block}

/* HERO */
.kb-hero{position:relative;min-height:540px;display:flex;align-items:center;
  background:var(--dark-green);overflow:hidden}
.kb-hero-bg{position:absolute;inset:0;background-size:cover;background-position:center;
  filter:brightness(.28);z-index:0}
.kb-hero-content{position:relative;z-index:1;padding:3rem 3rem;max-width:760px}
.kb-hero h1{font-size:clamp(2rem,5vw,3.2rem);font-weight:900;text-transform:uppercase;letter-spacing:.05em;
  color:#fff;line-height:1.1;text-shadow:0 2px 12px rgba(0,0,0,.9)}
.kb-hero h1 em{font-style:normal;color:var(--tan)}
.kb-hero p{font-size:1.1rem;color:var(--light);opacity:.9;margin:1.2rem 0 2rem;max-width:560px}
.kb-hero-btns{display:flex;gap:1rem;flex-wrap:wrap}

/* BUTTONS */
.btn{display:inline-block;padding:.75rem 2rem;font-weight:800;font-size:.9rem;text-transform:uppercase;
  letter-spacing:.07em;border-radius:2px;cursor:pointer;transition:.2s;border:2px solid transparent}
.btn-olive{background:var(--olive);color:#fff;border-color:var(--olive)}
.btn-olive:hover{background:var(--forest);border-color:var(--forest);color:#fff}
.btn-tan{background:var(--tan);color:var(--dark-green);border-color:var(--tan)}
.btn-tan:hover{background:var(--gold);border-color:var(--gold);color:var(--dark-green)}
.btn-outline{background:transparent;border-color:var(--tan);color:var(--tan)}
.btn-outline:hover{background:var(--tan);color:var(--dark-green)}

/* CAMO STRIP */
.kb-camo{height:8px;background:repeating-linear-gradient(90deg,
  var(--dark-green) 0px,var(--dark-green) 40px,
  var(--green) 40px,var(--green) 80px,
  var(--olive) 80px,var(--olive) 110px,
  var(--brown) 110px,var(--brown) 140px,
  var(--dark-green) 140px,var(--dark-green) 190px,
  var(--forest) 190px,var(--forest) 220px)}

/* STATS */
.kb-stats{background:var(--dark-green);border-bottom:1px solid var(--border);
  padding:1.2rem 2rem;display:flex;justify-content:center;gap:3rem;flex-wrap:wrap}
.kb-stat{text-align:center;color:var(--light)}
.kb-stat strong{display:block;font-size:1.6rem;font-weight:900;color:var(--tan)}
.kb-stat span{font-size:.78rem;text-transform:uppercase;letter-spacing:.1em;color:var(--grey)}

/* SECTIONS */
.kb-wrap{max-width:1280px;margin:0 auto;padding:0 2rem}
.kb-section{padding:4rem 2rem}
.kb-section-dark{background:var(--dark-green);padding:4rem 2rem}
.kb-title{font-size:1.7rem;font-weight:900;text-transform:uppercase;letter-spacing:.04em;color:#fff;margin-bottom:.4rem}
.kb-title em{font-style:normal;color:var(--tan)}
.kb-divider{width:50px;height:3px;background:var(--olive);margin:.6rem 0 2rem}

/* CATEGORY GRID */
.kb-cats{display:grid;grid-template-columns:repeat(auto-fill,minmax(170px,1fr));gap:1rem;margin-top:2rem}
.kb-cat{position:relative;border-radius:3px;overflow:hidden;aspect-ratio:1;cursor:pointer;
  border:1px solid var(--border);transition:.2s}
.kb-cat:hover{border-color:var(--olive);transform:translateY(-3px)}
.kb-cat-bg{position:absolute;inset:0;background-size:cover;background-position:center;
  filter:brightness(.4);transition:.3s}
.kb-cat:hover .kb-cat-bg{filter:brightness(.25)}
.kb-cat-label{position:absolute;bottom:0;left:0;right:0;padding:.8rem;
  background:linear-gradient(transparent,rgba(0,0,0,.9));color:var(--tan);
  font-weight:800;font-size:.88rem;text-transform:uppercase;letter-spacing:.06em}

/* PRODUCT CARDS */
.kb-products{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:1.5rem}
.kb-product{background:var(--card);border:1px solid var(--border);border-radius:3px;
  overflow:hidden;transition:.2s;display:flex;flex-direction:column}
.kb-product:hover{border-color:var(--olive);box-shadow:0 4px 20px rgba(107,124,63,.2)}
.kb-product-img{aspect-ratio:4/3;overflow:hidden;background:var(--card2)}
.kb-product-img img{width:100%;height:100%;object-fit:cover;transition:.3s}
.kb-product:hover .kb-product-img img{transform:scale(1.04)}
.kb-product-body{padding:1rem;flex:1;display:flex;flex-direction:column}
.kb-product-cat{font-size:.7rem;color:var(--olive);text-transform:uppercase;letter-spacing:.1em;margin-bottom:.3rem}
.kb-product-name{font-weight:700;color:#fff;font-size:.93rem;margin-bottom:.5rem;flex:1}
.kb-product-price{font-size:1.1rem;font-weight:900;color:var(--tan);margin-bottom:1rem}
.kb-product-btn{display:block;text-align:center;background:var(--olive);color:#fff;padding:.55rem;
  font-weight:700;font-size:.82rem;text-transform:uppercase;letter-spacing:.07em;border-radius:2px;transition:.2s}
.kb-product-btn:hover{background:var(--forest);color:var(--tan)}

/* WHY US */
.kb-why{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:1.5rem;margin-top:2rem}
.kb-why-card{background:var(--card);border:1px solid var(--border);border-left:3px solid var(--olive);
  padding:1.5rem;border-radius:3px}
.kb-why-icon{font-size:2rem;margin-bottom:.7rem}
.kb-why-card h3{font-size:.95rem;font-weight:800;text-transform:uppercase;color:var(--tan);margin-bottom:.4rem}
.kb-why-card p{font-size:.85rem;color:var(--grey)}

/* BRANDS */
.kb-brands{display:flex;flex-wrap:wrap;gap:1rem;margin-top:2rem}
.kb-brand{background:var(--card);border:1px solid var(--border);padding:.6rem 1.2rem;border-radius:2px;
  font-weight:800;font-size:.82rem;text-transform:uppercase;letter-spacing:.1em;color:var(--grey);transition:.2s}
.kb-brand:hover{border-color:var(--olive);color:var(--tan)}

/* CTA */
.kb-cta{background:var(--dark-green);border-top:3px solid var(--olive);border-bottom:3px solid var(--olive);
  padding:3.5rem 2rem;text-align:center}
.kb-cta h2{font-size:2rem;font-weight:900;text-transform:uppercase;letter-spacing:.04em;color:#fff}
.kb-cta h2 em{font-style:normal;color:var(--tan)}
.kb-cta p{color:var(--grey);margin:1rem auto 2rem;max-width:540px}

/* FOOTER */
.kb-footer{background:#080e05;border-top:2px solid var(--border);padding:3rem 2rem 1.5rem}
.kb-footer-grid{max-width:1280px;margin:0 auto;display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:2rem}
.kb-footer-brand p{color:var(--grey);font-size:.86rem;margin:.8rem 0 1.2rem;max-width:260px}
.kb-footer h4{font-size:.78rem;font-weight:800;text-transform:uppercase;letter-spacing:.12em;
  color:var(--olive);margin-bottom:1rem}
.kb-footer ul{list-style:none}
.kb-footer ul li{margin-bottom:.5rem}
.kb-footer ul a{color:var(--grey);font-size:.86rem;transition:.2s}
.kb-footer ul a:hover{color:var(--tan)}
.kb-footer-bottom{max-width:1280px;margin:2rem auto 0;padding-top:1.5rem;
  border-top:1px solid var(--border);display:flex;justify-content:space-between;
  align-items:center;flex-wrap:wrap;gap:1rem;font-size:.78rem;color:var(--grey)}
.kb-ffl{background:var(--card);border:1px solid var(--border);border-left:3px solid var(--tan);
  padding:.4rem .8rem;border-radius:2px;font-size:.73rem;font-weight:800;color:var(--tan);
  text-transform:uppercase;letter-spacing:.08em}

/* WC OVERRIDES */
.woocommerce .products .product{background:var(--card)!important;border:1px solid var(--border)!important;border-radius:3px!important}
.woocommerce .products .product:hover{border-color:var(--olive)!important}
.woocommerce .products .product .woocommerce-loop-product__title{color:#fff!important;font-weight:700!important}
.woocommerce .products .product .price{color:var(--tan)!important;font-weight:900!important}
.woocommerce .products .product .button{background:var(--olive)!important;color:#fff!important;
  text-transform:uppercase!important;font-weight:700!important;border-radius:2px!important;border:none!important}
.woocommerce .products .product .button:hover{background:var(--forest)!important}
.woocommerce div.product .product_title{color:#fff!important;font-weight:800!important}
.woocommerce div.product p.price,.woocommerce div.product span.price{color:var(--tan)!important;font-size:1.5rem!important;font-weight:900!important}
.woocommerce #respond input#submit,.woocommerce a.button,.woocommerce button.button,.woocommerce input.button{background:var(--olive)!important;color:#fff!important;border-radius:2px!important;font-weight:700!important;text-transform:uppercase!important}
.woocommerce #respond input#submit:hover,.woocommerce a.button:hover,.woocommerce button.button:hover,.woocommerce input.button:hover{background:var(--forest)!important}
.woocommerce form .form-row input.input-text,.woocommerce form .form-row textarea{background:var(--card)!important;border-color:var(--border)!important;color:var(--light)!important;border-radius:2px!important}
.woocommerce table.shop_table{background:var(--card)!important;border:1px solid var(--border)!important;color:var(--light)!important}
.woocommerce table.shop_table th{background:var(--dark-green)!important;color:var(--tan)!important}
.woocommerce table.shop_table td{border-top-color:var(--border)!important}
.woocommerce-message,.woocommerce-error,.woocommerce-info{background:var(--card)!important;border-top-color:var(--olive)!important;color:var(--light)!important}
.woocommerce .cart-collaterals .cart_totals,.woocommerce-page .cart-collaterals .cart_totals{background:var(--card)!important;border:1px solid var(--border)!important;padding:1.5rem!important}

/* SHOP */
.kb-shop-wrap{max-width:1280px;margin:0 auto;padding:2rem;display:grid;grid-template-columns:240px 1fr;gap:2rem}
.kb-sidebar{background:var(--card);border:1px solid var(--border);border-radius:3px;padding:1.5rem;align-self:start}
.kb-sidebar h3{font-size:.82rem;font-weight:800;text-transform:uppercase;letter-spacing:.1em;
  color:var(--olive);margin-bottom:1rem;padding-bottom:.5rem;border-bottom:1px solid var(--border)}

@media(max-width:768px){
  .kb-nav{display:none;flex-direction:column;position:absolute;top:68px;left:0;right:0;
    background:#0a0a0a;border-top:1px solid var(--border);padding:1rem;gap:.5rem}
  .kb-nav.open{display:flex}
  .kb-hamburger{display:block}
  .kb-footer-grid{grid-template-columns:1fr}
  .kb-shop-wrap{grid-template-columns:1fr}
  .kb-sidebar{display:none}
}
