/* ================================
   BOMBER PATCHES — PRODUCT CARD FIX
   Mobile + Desktop (WooCommerce)
   Paste at VERY BOTTOM of CSS
================================ */

/* Reset weird floats/widths from Woo default/theme */
.woocommerce ul.products,
.woocommerce-page ul.products {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid !important;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 18px;
  align-items: stretch;
}

/* Desktop / Laptop */
@media (min-width: 1025px) {
  .woocommerce ul.products,
  .woocommerce-page ul.products {
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }
}

/* Tablet */
@media (min-width: 769px) and (max-width: 1024px) {
  .woocommerce ul.products,
  .woocommerce-page ul.products {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

/* Mobile */
@media (max-width: 768px) {
  .woocommerce ul.products,
  .woocommerce-page ul.products {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 14px;
  }
}

/* Small phones */
@media (max-width: 420px) {
  .woocommerce ul.products,
  .woocommerce-page ul.products {
    grid-template-columns: 1fr;
  }
}

/* Force each product to behave like a card */
.woocommerce ul.products li.product,
.woocommerce-page ul.products li.product {
  float: none !important;
  width: auto !important;
  margin: 0 !important;

  display: flex;
  flex-direction: column;
  justify-content: space-between;

  border: 1px solid rgba(255,255,255,0.10);
  border-radius: 18px;
  padding: 14px;
  background: radial-gradient(circle at top, rgba(14,33,56,0.95) 0, rgba(2,8,21,0.98) 60%);
  box-shadow: 0 18px 48px rgba(0,0,0,0.35);
  overflow: hidden;

  min-width: 0; /* prevents skinny column bug */
}

/* Product image */
.woocommerce ul.products li.product a img,
.woocommerce-page ul.products li.product a img {
  width: 100% !important;
  height: auto !important;
  border-radius: 14px;
  margin: 0 0 12px !important;
  display: block;
}

/* Title: prevent “one word per line” */
.woocommerce ul.products li.product .woocommerce-loop-product__title,
.woocommerce-page ul.products li.product .woocommerce-loop-product__title {
  font-size: 0.95rem;
  line-height: 1.35;
  margin: 0 0 10px;
  color: #e6ebf5;

  display: -webkit-box;
  -webkit-line-clamp: 2;         /* limits to 2 lines */
  -webkit-box-orient: vertical;
  overflow: hidden;

  word-break: normal;
  overflow-wrap: anywhere;       /* breaks long tokens safely */
}

/* Price */
.woocommerce ul.products li.product .price,
.woocommerce-page ul.products li.product .price {
  margin: 0 0 12px;
  font-weight: 800;
  color: #f5b700;
}

/* Button: full width + centered */
.woocommerce ul.products li.product .button,
.woocommerce-page ul.products li.product .button,
.woocommerce ul.products li.product a.button,
.woocommerce-page ul.products li.product a.button {
  width: 100%;
  text-align: center;
  margin-top: auto;

  padding: 12px 14px;
  border-radius: 12px;

  background: linear-gradient(135deg, #4f8edb, #0033a0);
  color: #fff !important;
  border: 0 !important;

  font-weight: 800;
  letter-spacing: 0.06em;
  text-transform: uppercase;
}

/* Remove default Woo button weirdness */
.woocommerce ul.products li.product .added_to_cart,
.woocommerce-page ul.products li.product .added_to_cart {
  display: block;
  margin-top: 10px;
  text-align: center;
  color: #c7d0e2;
}

/* Make sure nothing forces tiny widths */
.woocommerce ul.products li.product *,
.woocommerce-page ul.products li.product * {
  min-width: 0;
}

/* ================================
   WOOCOMMERCE PRODUCT GRID + CARDS
   Fixes: skinny cards, ugly wrapping,
   button breaking, weird laptop layout
================================== */

/* Make the product grid a real grid (not flex) */
.woocommerce ul.products,
.woocommerce-page ul.products {
  display: grid !important;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 22px !important;
  margin: 0 !important;
  padding: 0 !important;
  align-items: stretch;
}

/* Tablet */
@media (max-width: 1024px) {
  .woocommerce ul.products,
  .woocommerce-page ul.products {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

/* Mobile */
@media (max-width: 768px) {
  .woocommerce ul.products,
  .woocommerce-page ul.products {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 14px !important;
    padding: 0 10px !important;
  }
}

/* Tiny phones */
@media (max-width: 420px) {
  .woocommerce ul.products,
  .woocommerce-page ul.products {
    grid-template-columns: 1fr;
  }
}

/* Product card */
.woocommerce ul.products li.product,
.woocommerce-page ul.products li.product {
  float: none !important;
  width: auto !important;
  max-width: none !important;
  margin: 0 !important;

  background: radial-gradient(circle at top, #0e2138 0, #020815 68%);
  border: 1px solid rgba(31,43,60,.95);
  border-radius: 18px;
  box-shadow: 0 18px 50px rgba(0,0,0,.45);
  padding: 14px !important;

  display: flex;
  flex-direction: column;
  min-height: 100%;
  overflow: hidden;
}

/* Image area */
.woocommerce ul.products li.product a img,
.woocommerce-page ul.products li.product a img {
  width: 100% !important;
  height: auto !important;
  aspect-ratio: 1 / 1;
  object-fit: cover;
  border-radius: 14px;
  margin: 0 0 12px !important;
  background: rgba(255,255,255,.06);
}

/* Title: clamp so it doesn’t become a tall skinny column */
.woocommerce ul.products li.product .woocommerce-loop-product__title,
.woocommerce-page ul.products li.product .woocommerce-loop-product__title {
  color: #eaf0ff !important;
  font-weight: 800 !important;
  letter-spacing: .02em;
  margin: 0 0 8px !important;

  font-size: 0.98rem !important;
  line-height: 1.25 !important;

  display: -webkit-box;
  -webkit-line-clamp: 2;       /* 2 lines max */
  -webkit-box-orient: vertical;
  overflow: hidden;
  text-overflow: ellipsis;
}

/* Price */
.woocommerce ul.products li.product .price,
.woocommerce-page ul.products li.product .price {
  color: #f5b700 !important;
  font-weight: 900 !important;
  margin-top: auto;            /* pushes price + button to bottom */
  margin-bottom: 10px !important;
  font-size: 1.05rem !important;
}

/* “Add to cart” button: stop breaking into 3 lines */
.woocommerce ul.products li.product a.button,
.woocommerce-page ul.products li.product a.button,
.woocommerce ul.products li.product .added_to_cart,
.woocommerce-page ul.products li.product .added_to_cart {
  display: inline-flex !important;
  align-items: center;
  justify-content: center;
  width: 100% !important;

  padding: 12px 14px !important;
  border-radius: 999px !important;
  border: 1px solid rgba(79,142,219,.45) !important;

  background: linear-gradient(135deg, #4f8edb, #0033a0) !important;
  color: #fff !important;

  font-weight: 800 !important;
  letter-spacing: .08em;
  text-transform: uppercase;

  white-space: nowrap !important;   /* key line-break fix */
  line-height: 1 !important;
  margin-top: 0 !important;
}

/* Hover */
.woocommerce ul.products li.product a.button:hover,
.woocommerce-page ul.products li.product a.button:hover {
  transform: translateY(-1px);
  box-shadow: 0 10px 22px rgba(31,79,216,.35);
}

/* Center content a bit cleaner */
.woocommerce ul.products li.product,
.woocommerce-page ul.products li.product {
  text-align: left !important;
}

/* Fix the star rating spacing if it appears */
.woocommerce ul.products li.product .star-rating {
  margin: 0 0 10px !important;
}

/* If something is forcing product grid into flex elsewhere, this helps */
.woocommerce ul.products::before,
.woocommerce ul.products::after {
  display: none !important;
  content: none !important;
}

/* ==============================
   PRODUCT CARD FIX (Shop + Home)
   ============================== */

/* Make the grid consistent everywhere */
.woocommerce ul.products,
.woocommerce-page ul.products {
  display: grid !important;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 18px !important;
  margin: 0 !important;
  padding: 0 !important;
}

@media (max-width: 1024px) {
  .woocommerce ul.products,
  .woocommerce-page ul.products {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 640px) {
  .woocommerce ul.products,
  .woocommerce-page ul.products {
    grid-template-columns: 1fr;
  }
}

/* Card */
.woocommerce ul.products li.product,
.woocommerce-page ul.products li.product {
  list-style: none !important;
  float: none !important;
  width: auto !important;
  margin: 0 !important;

  border: 1px solid rgba(255,255,255,0.10);
  border-radius: 18px;
  padding: 14px 14px 16px;
  background: radial-gradient(circle at top, rgba(14,33,56,0.9) 0%, rgba(2,8,21,0.95) 60%);
  box-shadow: 0 18px 45px rgba(0,0,0,0.45);

  display: flex;
  flex-direction: column;
  align-items: stretch;
  min-height: 100%;
}

/* Image */
.woocommerce ul.products li.product a img,
.woocommerce-page ul.products li.product a img {
  width: 100% !important;
  height: auto !important;
  border-radius: 14px;
  margin: 0 0 12px !important;
}

/* Title: stop the “super tall” stacking */
.woocommerce ul.products li.product .woocommerce-loop-product__title,
.woocommerce-page ul.products li.product .woocommerce-loop-product__title {
  font-size: 0.95rem !important;
  line-height: 1.35 !important;
  margin: 0 0 10px !important;

  display: -webkit-box;
  -webkit-line-clamp: 3;         /* show up to 3 lines */
  -webkit-box-orient: vertical;
  overflow: hidden;
  min-height: calc(1.35em * 3);  /* keeps cards even height */
}

/* Price */
.woocommerce ul.products li.product .price,
.woocommerce-page ul.products li.product .price {
  margin-top: auto !important; /* pushes price/button toward bottom */
  font-weight: 800;
  font-size: 1rem;
}

/* Button */
.woocommerce ul.products li.product a.button,
.woocommerce-page ul.products li.product a.button {
  margin-top: 10px !important;
  width: 100% !important;
  text-align: center !important;

  border-radius: 999px !important;
  padding: 12px 14px !important;
  font-weight: 800 !important;
  letter-spacing: 0.08em;

  background: linear-gradient(135deg, #4f8edb, #0033a0) !important;
  color: #fff !important;
  border: none !important;
}

/* Fix the “Add to cart” text breaking into a skinny vertical pill */
.woocommerce ul.products li.product a.button,
.woocommerce-page ul.products li.product a.button {
  white-space: nowrap !important;
}

/* Optional: nicer hover */
@media (hover:hover) {
  .woocommerce ul.products li.product:hover,
  .woocommerce-page ul.products li.product:hover {
    transform: translateY(-2px);
    transition: 0.18s ease;
  }
}

/* Remove sad face icon on empty cart */
.woocommerce-cart .cart-empty:before,
.woocommerce-cart .cart-empty img,
.woocommerce-cart .cart-empty svg,
.woocommerce-cart .cart-empty .icon,
.woocommerce-cart .cart-empty .emoji,
.woocommerce-cart .cart-empty .sad-face {
  display: none !important;
}

/* Hide the "New in store" section on cart page */
.woocommerce-cart h2,
.woocommerce-cart .new-in-store,
.woocommerce-cart .empty-cart-upsells,
.woocommerce-cart .cart-empty-products,
.woocommerce-cart .products {
  display: none !important;
}

/* =========================
   HEADER SEARCH ICON + PANEL
   ========================= */

.header-actions {
  display: flex;
  align-items: center;
  gap: 10px;
}

.header-search-toggle {
  width: 42px;
  height: 42px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,0.10);
  background: rgba(255,255,255,0.06);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: transform .18s ease, background .18s ease, border-color .18s ease;
}

.header-search-toggle svg {
  width: 20px;
  height: 20px;
  fill: #e7edf7;
  opacity: 0.95;
}

.header-search-toggle:hover {
  transform: translateY(-1px);
  background: rgba(255,255,255,0.10);
  border-color: rgba(255,255,255,0.18);
}

/* Slide-down panel */
.header-search-panel {
  position: absolute;
  left: 0;
  right: 0;
  top: 100%;
  z-index: 9999;
  background: rgba(6, 11, 23, 0.98);
  border-bottom: 1px solid rgba(255,255,255,0.08);
  backdrop-filter: blur(10px);
  transform: translateY(-8px);
  opacity: 0;
  pointer-events: none;
  transition: transform .18s ease, opacity .18s ease;
}

.header-search-panel.open {
  transform: translateY(0);
  opacity: 1;
  pointer-events: auto;
}

.header-search-panel-inner {
  max-width: 1200px;
  margin: 0 auto;
  padding: 14px 16px;
  display: flex;
  align-items: center;
  gap: 10px;
}

/* Style the Woo search form */
.header-search-panel form {
  flex: 1;
  display: flex;
  align-items: center;
  gap: 10px;
}

.header-search-panel input[type="search"],
.header-search-panel input[name="s"] {
  width: 100%;
  padding: 12px 14px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,0.12);
  background: rgba(255,255,255,0.06);
  color: #ffffff;
  font-size: 16px; /* prevents mobile zoom */
  outline: none;
}

.header-search-panel input::placeholder {
  color: rgba(255,255,255,0.55);
}

.header-search-panel button,
.header-search-panel input[type="submit"] {
  border-radius: 999px;
  padding: 12px 14px;
}

/* Optional: hide the “Search” submit if you want icon-only vibe */
.header-search-panel input[type="submit"] {
  display: none;
}

.header-search-close {
  width: 42px;
  height: 42px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,0.10);
  background: rgba(255,255,255,0.06);
  color: #fff;
  cursor: pointer;
}

/* Mobile spacing */
@media (max-width: 768px) {
  .header-search-panel-inner {
    padding: 12px 12px;
  }

  .header-search-toggle,
  .header-search-close {
    width: 40px;
    height: 40px;
  }
}

/* stop background scroll when overlays open */
html.no-scroll, html.no-scroll body {
  overflow: hidden;
}

/* --- Header Actions (magnifier button) --- */
.header-actions{
  display:flex;
  align-items:center;
  gap:.6rem;
}

.header-search-toggle{
  width:42px;
  height:42px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.06);
  display:flex;
  align-items:center;
  justify-content:center;
  cursor:pointer;
  transition: transform .15s ease, background .15s ease, border-color .15s ease;
}

.header-search-toggle:hover{
  transform: translateY(-1px);
  background: rgba(255,255,255,.10);
  border-color: rgba(255,255,255,.18);
}

.header-search-toggle svg{
  width:20px;
  height:20px;
  fill:#e8edf7;
}

/* --- Search overlay panel --- */
.header-search-panel{
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,.55);
  z-index: 9999;
  display:flex;
  align-items:flex-start;
  justify-content:center;
  padding: 90px 16px 24px;
}

.header-search-panel-inner{
  width: min(720px, 100%);
  background: rgba(7, 14, 27, 0.98);
  border: 1px solid rgba(255,255,255,.10);
  border-radius: 16px;
  box-shadow: 0 22px 70px rgba(0,0,0,.65);
  padding: 16px;
  position: relative;
}

/* Make Woo search form look clean */
.header-search-panel form{
  display:flex;
  gap:10px;
  align-items:center;
}

.header-search-panel input[type="search"]{
  width:100%;
  height:44px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.14);
  background: rgba(255,255,255,.08);
  color:#fff;
  padding: 0 16px;
  font-size:16px;
}

.header-search-panel input[type="search"]::placeholder{
  color: rgba(255,255,255,.55);
}

.header-search-panel button[type="submit"],
.header-search-panel input[type="submit"]{
  height:44px;
  border-radius: 999px;
  border: 0;
  padding: 0 16px;
  font-weight: 700;
  cursor:pointer;
}

/* Close button */
.header-search-close{
  position:absolute;
  top: 10px;
  right: 12px;
  width: 38px;
  height: 38px;
  border-radius: 12px;
  border:1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.06);
  color:#fff;
  cursor:pointer;
}

/* --- Mobile drawer show/hide --- */
.mobile-drawer{
  position: fixed;
  inset: 0;
  z-index: 9998;
  pointer-events: none;
  opacity: 0;
  transition: opacity .18s ease;
}

.mobile-drawer.is-open{
  pointer-events: auto;
  opacity: 1;
}

.mobile-drawer__backdrop{
  position:absolute;
  inset:0;
  background: rgba(0,0,0,.55);
}

.mobile-drawer__panel{
  position:absolute;
  top:0;
  right:0;
  width: min(360px, 92vw);
  height: 100%;
  background: rgba(7, 14, 27, 0.98);
  border-left: 1px solid rgba(255,255,255,.10);
  box-shadow: -22px 0 70px rgba(0,0,0,.65);
  transform: translateX(12px);
  transition: transform .18s ease;
  padding: 14px;
}

.mobile-drawer.is-open .mobile-drawer__panel{
  transform: translateX(0);
}

/* Lock background scroll when mobile menu is open */
html.nav-locked, body.nav-locked { overflow: hidden; }

/* Mobile drawer open state */
.mobile-drawer { display:none; }
.mobile-drawer.is-open { display:block; }

/* Nice empty cart message styling */
.bp-empty-cart-msg{
  margin: 0;
  padding: 14px 16px;
  border-radius: 14px;
  border: 1px solid rgba(255,255,255,0.12);
  background: rgba(255,255,255,0.06);
  color: #e9eefc;
  font-weight: 700;
  text-align: center;
}