/*
Theme Name: Fibitek
Theme URI: https://fibitek.shop
Author: Fibitek Team
Description: متجر كوزمتيك وملابس جزائري – تصميم عصري متجاوب مع ثيم حسب النيتش
Version: 2.0.0
Requires at least: 6.0
Requires PHP: 8.0
Tested up to: 6.5
License: GPL v2 or later
Text Domain: fibitek
Domain Path: /languages
Tags: ecommerce, woocommerce, rtl, arabic, cosmetics, fashion, responsive, custom-colors
*/

:root {
  --font: 'Cairo', 'Tahoma', 'Arial', sans-serif;
  --transition: all 0.25s ease;
  --radius: 12px;
  --radius-lg: 20px;
  --radius-xl: 28px;
  --shadow-sm: 0 1px 3px rgba(0,0,0,0.06);
  --shadow: 0 4px 14px rgba(0,0,0,0.08);
  --shadow-md: 0 8px 28px rgba(0,0,0,0.1);
  --shadow-lg: 0 20px 48px rgba(0,0,0,0.12);

  --primary: #8B5CF6;
  --primary-rgb: 139, 92, 246;
  --primary-dark: #7C3AED;
  --primary-light: #A78BFA;
  --primary-bg: rgba(139, 92, 246, 0.08);
  --secondary: #10B981;
  --accent: #EF4444;
  --gold: #F59E0B;
  --bg: #FAFAFA;
  --bg-alt: #F1F5F9;
  --bg-dark: #0F172A;
  --bg-darker: #020617;
  --card: #FFFFFF;
  --text: #1E293B;
  --text-light: #64748B;
  --text-muted: #94A3B8;
  --border: #E2E8F0;
}

/* ========== GENDER THEMES ========== */
.theme-women {
  --primary: #EC4899;
  --primary-rgb: 236, 72, 153;
  --primary-dark: #DB2777;
  --primary-light: #F472B6;
  --primary-bg: rgba(236, 72, 153, 0.08);
  --secondary: #10B981;
  --accent: #EF4444;
}

.theme-men {
  --primary: #2563EB;
  --primary-rgb: 37, 99, 235;
  --primary-dark: #1D4ED8;
  --primary-light: #60A5FA;
  --primary-bg: rgba(37, 99, 235, 0.08);
  --secondary: #059669;
  --accent: #DC2626;
}

/* Dark Mode */
[data-theme="dark"] {
  --bg: #0F0F0F;
  --bg-alt: #1A1A1A;
  --bg-dark: #000;
  --bg-darker: #000;
  --card: #1A1A1A;
  --text: #F1F5F9;
  --text-light: #94A3B8;
  --text-muted: #64748B;
  --border: #2D2D2D;
}

[data-theme="dark"] .theme-women {
  --primary: #F472B6;
  --primary-dark: #EC4899;
  --primary-light: #F9A8D4;
  --primary-bg: rgba(244, 114, 182, 0.12);
}

[data-theme="dark"] .theme-men {
  --primary: #60A5FA;
  --primary-dark: #3B82F6;
  --primary-light: #93C5FD;
  --primary-bg: rgba(96, 165, 250, 0.12);
}

/* ========== RESET & BASE ========== */
*, *::before, *::after { box-sizing: border-box; }
html { scroll-behavior: smooth; overflow-x: hidden; }
body {
  direction: rtl; font-family: var(--font) !important; font-size: 16px;
  line-height: 1.6; margin: 0; padding: 0; overflow-x: hidden;
  background: var(--bg); color: var(--text);
  -webkit-font-smoothing: antialiased;
}
img { max-width: 100%; height: auto; display: block; }
a { color: inherit; text-decoration: none; transition: var(--transition); }
h1, h2, h3, h4, h5, h6 { font-weight: 800 !important; line-height: 1.3; margin: 0 0 12px; font-size: revert; }
h1 { font-size: 2em; } h2 { font-size: 1.5em; } h3 { font-size: 1.25em; }
h4 { font-size: 1.1em; } h5 { font-size: 1em; } h6 { font-size: 0.9em; }
p { margin: 0 0 16px; color: var(--text-light); line-height: 1.7; }
ul, ol { padding-right: 20px; }
button { font-family: var(--font); cursor: pointer; }
input, textarea, select { font-family: var(--font); }
table { width: 100%; border-collapse: collapse; }
td, th { padding: 8px; text-align: right; border: 1px solid var(--border); }

/* ========== CONTAINER ========== */
.container, .fib-container {
  max-width: 1200px; margin: 0 auto; padding: 0 20px;
}
@media (max-width: 768px) {
  .container, .fib-container { padding: 0 16px; }
}
body { padding-top: 68px !important; }

/* ========== BUTTONS ========== */
.fib-btn {
  display: inline-flex; align-items: center; justify-content: center; gap: 6px;
  padding: 10px 22px; border-radius: 99px; font-weight: 700; font-size: 14px;
  font-family: var(--font); border: none; cursor: pointer;
  transition: var(--transition); text-decoration: none !important;
  line-height: 1; white-space: nowrap;
}
.fib-btn:hover { transform: translateY(-2px); }
.fib-btn-primary { background: var(--primary); color: #fff; }
.fib-btn-primary:hover { box-shadow: 0 8px 20px rgba(var(--primary-rgb), 0.35); }
.fib-btn-secondary { background: var(--secondary); color: #fff; }
.fib-btn-outline { background: transparent; border: 1.5px solid var(--border); color: var(--text); }
.fib-btn-outline:hover { border-color: var(--primary); color: var(--primary); }
.fib-btn-sm { padding: 7px 16px; font-size: 12px; }
.fib-btn-lg { padding: 14px 32px; font-size: 16px; }
.fib-btn-block { width: 100%; }

/* ========== TAILWIND-STYLE UTILITY CLASSES ========== */
.w-full { width: 100%; }
.h-full { height: 100%; }
.object-cover { object-fit: cover; }
.mx-auto { margin-left: auto; margin-right: auto; }
.px-4 { padding-left: 1rem; padding-right: 1rem; }
.py-8 { padding-top: 2rem; padding-bottom: 2rem; }
@media (min-width: 768px) {
  .md\:px-8 { padding-left: 2rem; padding-right: 2rem; }
}
.grid { display: grid; }
.grid-cols-1 { grid-template-columns: repeat(1, minmax(0, 1fr)); }
@media (min-width: 640px) {
  .sm\:grid-cols-2 { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (min-width: 768px) {
  .md\:grid-cols-3 { grid-template-columns: repeat(3, minmax(0, 1fr)); }
}
@media (min-width: 1024px) {
  .lg\:grid-cols-4 { grid-template-columns: repeat(4, minmax(0, 1fr)); }
}
.gap-6 { gap: 1.5rem; }

.flex { display: flex; }
.flex-col { flex-direction: column; }
.gap-3 { gap: 0.75rem; }

/* Search results product image (fallback) */
.product-search-img { width: 100%; height: 100%; object-fit: cover; }

/* Shortcut button classes for template parts */
.btn-primary {
  display: inline-flex; align-items: center; justify-content: center; gap: 6px;
  padding: 12px 28px; border-radius: 99px; font-weight: 800; font-size: 15px;
  font-family: var(--font); border: none; cursor: pointer;
  transition: var(--transition); text-decoration: none !important;
  background: var(--primary); color: #fff; white-space: nowrap;
}
.btn-primary:hover { transform: translateY(-2px); box-shadow: 0 8px 20px rgba(var(--primary-rgb), 0.35); }
.btn-outline {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 10px 24px; border-radius: 99px; font-weight: 700; font-size: 13px;
  font-family: var(--font); border: 1.5px solid var(--border);
  background: transparent; color: var(--text); transition: var(--transition);
  cursor: pointer; text-decoration: none !important;
}
.btn-outline:hover { border-color: var(--primary); color: var(--primary); }
.btn-banner {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 14px 32px; border-radius: 99px; font-size: 16px; font-weight: 800;
  font-family: var(--font); border: none; cursor: pointer;
  background: var(--primary); color: #fff !important; transition: var(--transition);
  text-decoration: none !important;
}
.btn-banner:hover { transform: translateY(-2px); box-shadow: 0 8px 24px rgba(var(--primary-rgb), 0.4); }
.btn-sm { padding: 8px 18px; font-size: 13px; }
.highlight { color: var(--primary); }

/* ========== HEADER ========== */
.main-header {
  position: fixed; top: 0; left: 0; right: 0; z-index: 1000;
  background: var(--card); border-bottom: 1px solid var(--border);
  height: 68px; transition: var(--transition);
}
.main-header.scrolled {
  backdrop-filter: blur(12px); background: var(--card);
  box-shadow: 0 4px 20px rgba(0,0,0,0.08);
}
.header-inner {
  max-width: 1200px; margin: 0 auto; padding: 0 20px;
  display: flex; align-items: center; justify-content: space-between;
  height: 68px; gap: 20px;
}

/* Logo */
.logo { font-size: 22px; font-weight: 900; display: flex; align-items: center; gap: 8px; flex-shrink: 0; }
.logo-accent { color: var(--primary); }
.logo-icon {
  width: 36px; height: 36px; background: var(--primary); color: #fff;
  border-radius: 10px; display: flex; align-items: center; justify-content: center;
  font-size: 18px; font-weight: 800;
}
.fib-logo-img { display: block; max-width: 160px; max-height: 50px; width: auto; height: auto; }
@media (max-width: 768px) {
  .fib-logo-img { max-width: 120px; max-height: 40px; }
  .logo { font-size: 18px; }
}

/* Desktop Nav */
.main-nav { display: flex; flex: 1; justify-content: center; gap: 4px; }
.nav-link {
  padding: 8px 14px; font-size: 14px; font-weight: 600; border-radius: 8px;
  color: var(--text); transition: var(--transition); white-space: nowrap;
}
.nav-link:hover { background: var(--primary-bg); color: var(--primary); }

/* Header Actions */
.header-actions { display: flex; align-items: center; gap: 6px; flex-shrink: 0; }
.header-btn {
  width: 38px; height: 38px; border-radius: 10px; border: none;
  background: transparent; color: var(--text); cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  transition: var(--transition); position: relative;
}
.header-btn:hover { background: var(--bg-alt); }

.cart-badge {
  position: absolute; top: 2px; right: 2px; min-width: 16px; height: 16px;
  border-radius: 8px; background: var(--accent); color: #fff;
  font-size: 9px; font-weight: 800; display: flex; align-items: center;
  justify-content: center; padding: 0 4px; line-height: 1;
}

.btn-header-cta {
  padding: 0 20px; height: 36px; border-radius: 99px; background: var(--primary);
  color: #fff !important; font-weight: 700; font-size: 13px;
  display: flex; align-items: center; gap: 6px;
  transition: var(--transition);
}
.btn-header-cta:hover { box-shadow: 0 6px 16px rgba(var(--primary-rgb), 0.3); transform: translateY(-1px); }

/* Mobile hamburger */
.mobile-menu-btn { display: none; width: 38px; height: 38px; background: none; border: none; cursor: pointer; padding: 10px; flex-direction: column; justify-content: space-between; }
.mobile-menu-btn span { display: block; width: 100%; height: 2.5px; background: var(--text); border-radius: 2px; transition: var(--transition); }
.mobile-menu-btn.open span:nth-child(1) { transform: translateY(8px) rotate(45deg); }
.mobile-menu-btn.open span:nth-child(2) { opacity: 0; }
.mobile-menu-btn.open span:nth-child(3) { transform: translateY(-8px) rotate(-45deg); }

/* Mobile panel */
.mobile-menu {
  display: none; position: fixed; top: 68px; left: 0; right: 0;
  background: var(--card); border-bottom: 1px solid var(--border);
  padding: 16px 20px 20px; z-index: 999; box-shadow: var(--shadow-md);
  animation: slideDown 0.25s ease; max-height: calc(100vh - 68px);
  overflow-y: auto;
}
.mobile-menu.open { display: flex; flex-direction: column; }
.mobile-menu-header {
  display: flex; align-items: center; justify-content: space-between;
  margin-bottom: 12px; padding-bottom: 10px;
  border-bottom: 1px solid var(--border);
}
.mobile-menu-title { font-weight: 800; font-size: 16px; }
.mobile-menu-close-btn {
  width: 32px; height: 32px; border-radius: 8px; border: none;
  background: var(--bg-alt); cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  color: var(--text); transition: var(--transition);
}
.mobile-menu-close-btn:hover { background: var(--primary-bg); color: var(--primary); }

/* Mobile menu actions grid */
.mobile-menu-actions {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 6px;
  margin-bottom: 12px;
}
.mm-action {
  display: flex; flex-direction: column; align-items: center; gap: 4px;
  padding: 12px 6px; border-radius: 12px; border: 1px solid var(--border);
  background: var(--bg); cursor: pointer; transition: var(--transition);
  font-family: var(--font); color: var(--text);
}
.mm-action:hover { border-color: var(--primary); background: var(--primary-bg); }
.mm-action-icon {
  width: 36px; height: 36px; border-radius: 50%; background: var(--card);
  display: flex; align-items: center; justify-content: center;
  color: var(--text); box-shadow: var(--shadow-sm);
  font-size: 13px; font-weight: 800;
}
.mm-action-label { font-size: 11px; font-weight: 600; color: var(--text-light); }
.mm-cart-count { font-size: 14px; font-weight: 800; color: var(--text); }
.mm-action-noclick { cursor: default; }
.mm-action-noclick:hover { border-color: var(--border); background: var(--bg); }
.mm-action-gender {
  display: flex; gap: 2px; margin-top: 2px;
}
.mm-action-gender .gender-opt {
  padding: 2px 6px; font-size: 14px;
}
.mm-divider {
  height: 1px; background: var(--border); margin: 4px 0 6px;
}
.mobile-menu-links a,
.mobile-menu-link {
  display: block; padding: 12px 16px; font-size: 15px; font-weight: 600;
  border-radius: 10px; transition: var(--transition);
}
.mobile-menu-links a:hover,
.mobile-menu-link:hover { background: var(--primary-bg); color: var(--primary); }
.mobile-cta-link { background: var(--primary); color: #fff !important; text-align: center; margin-top: 8px; }
@keyframes slideDown {
  from { opacity: 0; transform: translateY(-8px); }
  to { opacity: 1; transform: translateY(0); }
}

/* Hide native search clear button (which overlapped the custom close) */
input[type="search"]::-webkit-search-decoration,
input[type="search"]::-webkit-search-cancel-button,
input[type="search"]::-webkit-search-results-button,
input[type="search"]::-webkit-search-results-decoration { display: none; }
input[type="search"]::-ms-clear, input[type="search"]::-ms-reveal { display: none; }

/* ========== SEARCH OVERLAY ========== */
.search-overlay {
  position: fixed; inset: 0; z-index: 2000;
  background: rgba(0,0,0,0.5); opacity: 0; visibility: hidden;
  transition: opacity 0.3s ease, visibility 0.3s ease;
  display: flex; align-items: flex-start; justify-content: center;
  padding-top: 8vh;
  backdrop-filter: blur(6px); -webkit-backdrop-filter: blur(6px);
}
.search-overlay.open { opacity: 1; visibility: visible; }

.search-overlay-content {
  width: min(680px, 94vw); background: var(--card);
  border-radius: var(--radius-lg); box-shadow: 0 25px 60px rgba(0,0,0,0.25);
  padding: 20px 20px 0; position: relative;
  transform: translateY(20px) scale(0.96);
  transition: transform 0.35s cubic-bezier(0.34, 1.56, 0.64, 1);
}
.search-overlay.open .search-overlay-content {
  transform: translateY(0) scale(1);
}

.search-top {
  display: flex; justify-content: flex-end; margin-bottom: 4px;
}

.search-close {
  width: 36px; height: 36px; border-radius: 50%;
  border: none; background: var(--bg-alt);
  cursor: pointer; display: flex; align-items: center; justify-content: center;
  color: var(--text-light); transition: var(--transition);
}
.search-close:hover { background: var(--primary-bg); color: var(--primary); transform: rotate(90deg); }

#searchForm.fib-search-form { flex-direction: column; gap: 0; }
#searchForm .search-form {
  position: relative;
}
#searchForm .search-form input {
  width: 100%; padding: 14px 48px 14px 16px;
  border: 2px solid var(--border); border-radius: var(--radius) var(--radius) 0 0;
  font-size: 17px; font-family: var(--font); background: var(--bg);
  color: var(--text); transition: border-color 0.2s;
}
#searchForm .search-form input:focus {
  border-color: var(--primary); outline: none;
  box-shadow: 0 0 0 4px var(--primary-bg);
}
#searchForm .search-form-input-wrap { position: relative; flex: 1; }
#searchForm .search-form-input-wrap input { padding-left: 36px; }
#searchForm .search-clear {
  position: absolute; left: 8px; top: 50%; transform: translateY(-50%);
  width: 30px; height: 30px; border: none; border-radius: 50%;
  background: var(--bg-alt); color: var(--text-light); cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  transition: var(--transition);
}
#searchForm .search-clear:hover { background: var(--border); color: var(--text); }
#searchForm .search-form-icon {
  position: absolute; right: 18px; top: 50%; transform: translateY(-50%);
  color: var(--text-muted); pointer-events: none;
  display: flex; align-items: center;
}

#searchForm .search-footer {
  text-align: center; margin-top: 14px;
  font-size: 12px; color: var(--text-muted);
  letter-spacing: 0.3px;
}

/* Live search results */
#searchForm .search-results {
  margin-top: 4px; background: var(--card);
  border-radius: 0 0 var(--radius) var(--radius);
  border: 1px solid var(--border); border-top: 0;
  max-height: 440px; overflow-y: auto;
  display: none;
}
#searchForm .search-results.active { display: block; }
#searchForm .sr-item {
  display: flex; align-items: center; gap: 12px; padding: 10px 14px;
  cursor: pointer; transition: background 0.15s; border-bottom: 1px solid var(--border);
}
#searchForm .sr-item:last-child { border-bottom: 0; }
#searchForm .sr-item:hover, #searchForm .sr-item.hover { background: var(--primary-bg); }
#searchForm .sr-img-wrap { width: 48px; height: 48px; flex-shrink: 0; border-radius: 8px; overflow: hidden; }
#searchForm .sr-img-wrap img { width: 100%; height: 100%; object-fit: cover; }
#searchForm .sr-info { flex: 1; min-width: 0; display: flex; flex-direction: column; gap: 2px; }
#searchForm .sr-title { font-size: 13px; font-weight: 600; color: var(--text); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
#searchForm .sr-title mark { background: rgba(var(--primary-rgb, 99,102,241), 0.2); color: var(--text); padding: 0 2px; border-radius: 2px; }
#searchForm .sr-cat { font-size: 11px; color: var(--text-light); }
#searchForm .sr-price { font-size: 13px; font-weight: 700; color: var(--primary); }
#searchForm .sr-empty { padding: 24px; text-align: center; color: var(--text-light); font-size: 14px; }
#searchForm .sr-view-all { display: block; padding: 10px 14px; text-align: center; font-size: 13px; font-weight: 700; color: var(--primary); text-decoration: none; border-top: 1px solid var(--border); transition: var(--transition); }
#searchForm .sr-view-all:hover { background: var(--primary-bg); }

/* Search loading spinner */
#searchForm .search-results.is-loading { min-height: 70px; display: flex; align-items: center; justify-content: center; }
#searchForm .search-results.is-loading::after {
  content: ''; display: block; width: 28px; height: 28px;
  border: 3px solid var(--border); border-top-color: var(--primary);
  border-radius: 50%; animation: fibSpinner 0.6s linear infinite;
}
@keyframes fibSpinner { to { transform: rotate(360deg); } }
#searchForm .search-results.is-loading .sr-item,
#searchForm .search-results.is-loading .sr-view-all,
#searchForm .search-results.is-loading .sr-empty { display: none; }

/* ========== GENDER TOGGLE ========== */
.gender-toggle {
  display: flex; align-items: center; gap: 2px;
  background: var(--bg-alt); border-radius: 99px; padding: 2px;
  border: 1px solid var(--border);
}
.gender-opt {
  padding: 5px 10px; border-radius: 99px; font-size: 11px; font-weight: 600;
  border: none; background: transparent; color: var(--text-light);
  cursor: pointer; transition: var(--transition); font-family: var(--font);
}
.gender-opt.active { background: var(--primary); color: #fff; box-shadow: var(--shadow-sm); }

/* ========== HERO SECTION ========== */
.hero-section {
  background: var(--bg-alt); padding: 60px 0; position: relative;
  overflow: hidden;
}
.hero-section::before {
  content: ''; position: absolute; top: -50%; right: -30%;
  width: 60%; height: 200%;
  background: radial-gradient(circle, rgba(var(--primary-rgb), 0.06) 0%, transparent 70%);
  pointer-events: none;
}
.hero-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 48px; align-items: center; position: relative; z-index: 1; }
.hero-badge {
  display: inline-block; padding: 6px 16px; border-radius: 99px;
  background: var(--primary-bg); color: var(--primary); font-size: 13px;
  font-weight: 700; margin-bottom: 16px;
}
.hero-text h1 { font-size: 42px; font-weight: 900; line-height: 1.15; margin-bottom: 16px; }
.hero-highlight { color: var(--primary); }
.hero-text p { font-size: 16px; color: var(--text-light); max-width: 500px; margin-bottom: 28px; }
.hero-actions { display: flex; gap: 12px; flex-wrap: wrap; }

.hero-visual { display: flex; flex-direction: column; gap: 12px; }
.hero-card {
  display: flex; align-items: center; gap: 14px;
  padding: 18px 20px; border-radius: var(--radius-lg);
  background: var(--card); border: 1px solid var(--border);
  transition: var(--transition);
}
.hero-card:hover { transform: translateX(-4px); box-shadow: var(--shadow-md); }
.hero-card-icon { font-size: 28px; flex-shrink: 0; }
.hero-card-text strong { display: block; font-size: 14px; font-weight: 800; }
.hero-card-text span { font-size: 12px; color: var(--text-light); }

@media (max-width: 900px) {
  .hero-grid { grid-template-columns: 1fr; gap: 32px; }
  .hero-text h1 { font-size: 32px; }
  .hero-text p { max-width: 100%; }
}
@media (max-width: 480px) {
  .hero-section { padding: 40px 0; }
  .hero-text h1 { font-size: 26px; }
}

/* ========== BENEFITS BAR ========== */
.benefits-bar {
  background: var(--card); border-bottom: 1px solid var(--border);
  padding: 14px 0;
}
.benefits-inner {
  max-width: 1200px; margin: 0 auto; padding: 0 20px;
  display: grid; grid-template-columns: repeat(4, 1fr); gap: 12px;
}
.benefit-item {
  display: flex; align-items: center; gap: 10px;
  border-left: 1px solid var(--border); padding: 0 12px;
}
.benefit-item:last-child { border-left: none; }
.benefit-item .benefit-icon { font-size: 20px; flex-shrink: 0; }
.benefit-item strong { font-size: 13px; font-weight: 700; }
.benefit-item span { font-size: 11px; color: var(--text-light); }
@media (max-width: 768px) {
  .benefits-inner { grid-template-columns: repeat(2, 1fr); gap: 8px; }
  .benefit-item:nth-child(2) { border-left: none; }
  .benefit-item { padding: 8px; }
}

/* ========== SECTION HEADERS ========== */
.section-wrap { padding: 60px 0; }
.section-header { text-align: center; margin-bottom: 36px; }
.section-label {
  display: inline-block; font-size: 12px; font-weight: 700; text-transform: uppercase;
  letter-spacing: 1px; color: var(--primary); margin-bottom: 8px;
}
.section-title { font-size: 28px; font-weight: 900; margin-bottom: 8px; }
.section-subtitle { font-size: 15px; color: var(--text-light); max-width: 600px; margin: 0 auto; }
@media (max-width: 768px) {
  .section-wrap { padding: 40px 0; }
  .section-title { font-size: 22px; }
  .section-header { margin-bottom: 24px; }
}

/* ========== CATEGORY CARDS ========== */
.categories-section { background: var(--bg); }
.categories-grid {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px;
}
.category-card {
  display: flex; flex-direction: column; align-items: center; text-align: center;
  padding: 28px 16px; border-radius: var(--radius-lg);
  border: 1.5px solid var(--border); background: var(--card);
  transition: var(--transition); position: relative; overflow: hidden;
}
.category-card:hover {
  border-color: var(--primary); transform: translateY(-3px);
  box-shadow: 0 8px 24px rgba(var(--primary-rgb), 0.15);
  background: linear-gradient(135deg, var(--card), var(--primary-bg));
}
.category-card .cat-icon { font-size: 36px; margin-bottom: 12px; }
.category-card h3 { font-size: 16px; font-weight: 800; margin-bottom: 4px; }
.category-card p { font-size: 12px; color: var(--text-light); margin: 0; }
.category-card .badge-hot {
  position: absolute; top: 12px; left: 12px; background: var(--accent);
  color: #fff; font-size: 10px; font-weight: 800; padding: 3px 8px;
  border-radius: 99px;
}
@media (max-width: 768px) { .categories-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 480px) { .categories-grid { grid-template-columns: repeat(2, 1fr); gap: 12px; } }

/* ========== PRODUCT CARDS (Ecomus V1 Style) ========== */
.product-card {
  background: var(--card); overflow: hidden; transition: var(--transition);
  border: 1px solid var(--border); border-radius: 0;
  position: relative;
}
.product-card:hover {
  box-shadow: var(--shadow-md);
}

.product-inner { display: flex; flex-direction: column; height: 100%; }

.product-thumbnail {
  position: relative; overflow: hidden; background: var(--bg-alt);
  aspect-ratio: 3 / 4;
}
.product-thumbnail .woocommerce-loop-product__link {
  display: block; width: 100%; height: 100%;
}
.product-thumbnail img {
  width: 100%; height: 100%; object-fit: cover;
  transition: opacity 0.4s ease, transform 0.5s ease;
}
.product-thumbnail img.product-hover-image {
  position: absolute; top: 0; left: 0; opacity: 0;
}
.product-card:hover .product-thumbnail img.product-hover-image { opacity: 1; }
.product-card:hover .product-thumbnail img:first-child { opacity: 0; }
.product-card:hover .product-thumbnail img { transform: scale(1.03); }

.product-badges {
  position: absolute; top: 12px; left: 12px; z-index: 3;
  display: flex; flex-direction: column; gap: 4px; align-items: flex-start;
}
.product-badges .badge {
  display: inline-flex; padding: 3px 8px; font-size: 10px;
  font-weight: 700; line-height: 1.3; letter-spacing: 0.3px;
}
.badge.featured { background: var(--secondary); color: #fff; }
.badge.sale { background: var(--accent); color: #fff; }
.badge.outofstock { background: var(--text-muted); color: #fff; }

.product-featured-icons {
  position: absolute; bottom: 10px; left: 50%;
  transform: translateX(-50%) translateY(16px);
  z-index: 3; display: flex; align-items: center; justify-content: center;
  gap: 6px; opacity: 0;
  transition: transform 0.3s cubic-bezier(0.34, 1.56, 0.64, 1), opacity 0.25s ease;
}
.product-card:hover .product-featured-icons {
  transform: translateX(-50%) translateY(0);
  opacity: 1;
}
.product-featured-icons .ecomus-button,
.product-featured-icons .fib-wishlist-toggle {
  width: 32px; height: 32px; display: flex; align-items: center;
  justify-content: center; border-radius: 50%;
  background: #fff; color: #1a1a1a; border: none; cursor: pointer;
  transition: all 0.2s ease, transform 0.3s cubic-bezier(0.34, 1.56, 0.64, 1);
  box-shadow: 0 2px 8px rgba(0,0,0,0.12);
  transform: translateY(8px);
}
.product-card:hover .product-featured-icons .ecomus-button,
.product-card:hover .product-featured-icons .fib-wishlist-toggle {
  transform: translateY(0);
}
.product-card:hover .product-featured-icons .ecomus-button:nth-child(1),
.product-card:hover .product-featured-icons .fib-wishlist-toggle:nth-child(1) {
  transition-delay: 0.03s;
}
.product-card:hover .product-featured-icons .ecomus-button:nth-child(2),
.product-card:hover .product-featured-icons .fib-wishlist-toggle:nth-child(2) {
  transition-delay: 0.07s;
}
.product-card:hover .product-featured-icons .ecomus-button:nth-child(3),
.product-card:hover .product-featured-icons .fib-wishlist-toggle:nth-child(3) {
  transition-delay: 0.11s;
}
.product-featured-icons .ecomus-button:hover,
.product-featured-icons .fib-wishlist-toggle:hover {
  background: var(--primary); color: #fff;
  transform: translateY(0) scale(1.1) !important;
}
.product-featured-icons .ecomus-button svg {
  width: 15px; height: 15px;
}
.product-featured-icons .fib-wishlist-toggle.active { background: var(--accent); }
.product-featured-icons .fib-wishlist-toggle.active svg { fill: #fff; stroke: #fff; }
[data-theme="dark"] .product-featured-icons .ecomus-button,
[data-theme="dark"] .product-featured-icons .fib-wishlist-toggle {
  background: #2a2a2a; color: #ccc;
}
[data-theme="dark"] .product-featured-icons .ecomus-button:hover,
[data-theme="dark"] .product-featured-icons .fib-wishlist-toggle:hover {
  background: var(--primary); color: #fff;
}

.product-summary {
  padding: 10px 12px 14px; display: flex; flex-direction: column;
  flex: 1; gap: 3px; text-align: right;
}
.product--cat {
  font-size: 10px; font-weight: 600; text-transform: uppercase;
  letter-spacing: 0.5px; color: var(--primary); margin-bottom: 1px;
}
.product--cat a { color: var(--primary); }
.product--cat a:hover { text-decoration: underline; }
.product-summary .woocommerce-loop-product__title {
  font-size: 13px; font-weight: 600; line-height: 1.4; margin: 0;
  display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical;
  overflow: hidden; color: var(--text);
}
.product-summary .woocommerce-loop-product__title a { color: inherit; }
.product-summary .woocommerce-loop-product__title a:hover { color: var(--primary); }
.product-summary .price {
  direction: ltr; unicode-bidi: isolate; font-weight: 700; font-size: 14px;
  color: var(--text); margin: 1px 0;
}
.product-summary .price del { color: var(--text-muted); font-size: 11px; }
.product-summary .price ins { text-decoration: none; color: var(--accent); }
.product-summary .ecomus-rating { display: flex; align-items: center; gap: 6px; margin: 4px 0; direction: ltr; }
.product-summary .ecomus-rating .star-rating { display: inline-block; margin: 0; font-size: 12px; }
.product-summary .ecomus-rating .star-rating span::before { color: var(--gold); }
.product-summary .ecomus-rating .rating-count { font-size: 11px; color: var(--text-light); font-weight: 500; }

.product-card-attrs {
  display: flex; flex-wrap: wrap; gap: 3px; margin: 2px 0;
}
.product-card-attrs .attr-label {
  display: inline-flex; align-items: center; justify-content: center;
  padding: 1px 6px; border-radius: 3px; font-size: 10px; font-weight: 600;
  background: var(--bg-alt); color: var(--text-light); cursor: pointer;
  border: 1px solid var(--border); transition: var(--transition);
  line-height: 1.5; height: 22px; position: relative;
}
.product-card-attrs .attr-label:hover {
  border-color: var(--primary); color: var(--primary); background: var(--primary-bg);
}
.product-card-attrs .attr-label.active {
  background: var(--text); color: #fff; border-color: var(--text);
}
/* Color swatch */
.product-card-colors { display: flex; flex-wrap: wrap; gap: 4px; margin: 2px 0; }
.attr-color {
  display: inline-block; width: 22px; height: 22px; border-radius: 50%;
  border: 2px solid var(--border); cursor: pointer; transition: transform 0.15s, border-color 0.15s;
  background-size: cover; background-position: center;
}
.attr-color:hover { transform: scale(1.15); border-color: var(--primary); }
.attr-color.active { border-color: var(--text); box-shadow: 0 0 0 1.5px var(--bg), 0 0 0 2.5px var(--text); }
.attr-label.fib-cswatch {
  padding: 2px; border-radius: 50%; width: 22px; height: 22px;
  background: transparent !important; border-color: var(--border);
}
.attr-label.fib-cswatch:hover { border-color: var(--primary); }
.attr-label.fib-cswatch.active {
  border-color: var(--text); box-shadow: 0 0 0 1.5px var(--bg), 0 0 0 2.5px var(--text);
}
.fib-cswatch-dot {
  display: block; width: 14px; height: 14px; border-radius: 50%;
  background-size: cover; border: 1px solid rgba(0,0,0,0.1);
}
.fib-cswatch-name {
  position: absolute; bottom: calc(100% + 6px); left: 50%;
  transform: translateX(-50%);
  white-space: nowrap; font-size: 10px; font-weight: 700;
  background: var(--text); color: var(--bg); padding: 2px 8px;
  border-radius: 4px; opacity: 0; pointer-events: none;
  transition: opacity 0.2s ease, transform 0.2s ease;
}
.fib-cswatch-name::after {
  content: ''; position: absolute; top: 100%; left: 50%;
  transform: translateX(-50%);
  border: 4px solid transparent; border-top-color: var(--text);
}
.fib-cswatch-name.fib-show {
  opacity: 1; transform: translateX(-50%) translateY(-2px);
}

.em-button-add-to-cart-mobile {
  display: none; margin-top: 4px; padding: 6px 12px;
  background: var(--primary); color: #fff; border: none; border-radius: 6px;
  font-size: 11px; font-weight: 700; text-align: center; font-family: var(--font);
  cursor: pointer; transition: var(--transition); text-decoration: none;
}
.em-button-add-to-cart-mobile:hover { background: var(--primary-dark); }

@media (hover: none) {
  .product-featured-icons { opacity: 1; transform: translateX(-50%) translateY(0); }
  .product-featured-icons .ecomus-button,
  .product-featured-icons .fib-wishlist-toggle { transform: translateY(0); }
  .em-button-add-to-cart-mobile { display: block; }
  .product-summary { padding-bottom: 10px; }
}

/* ========== PRODUCT CAROUSEL ========== */
.product-carousel {
  display: flex; overflow-x: auto; gap: 16px; padding: 8px 0 16px;
  scroll-snap-type: x mandatory; cursor: grab;
  scrollbar-width: none; -ms-overflow-style: none;
  direction: ltr;
}
.product-carousel::-webkit-scrollbar { display: none; }
.product-carousel .product-card {
  flex: 0 0 calc(25% - 12px); scroll-snap-align: start;
  direction: rtl; min-width: 230px;
}
.product-carousel:active { cursor: grabbing; }
@media (max-width: 1024px) {
  .product-carousel .product-card { flex: 0 0 calc(50% - 8px); }
}
@media (max-width: 640px) {
  .product-carousel .product-card { flex: 0 0 78%; min-width: 200px; }
}

/* ========== PRODUCT GRID (archive) ========== */
.products-grid {
  display: grid; grid-template-columns: repeat(auto-fill, minmax(240px, 1fr));
  gap: 20px;
}
@media (max-width: 480px) {
  .products-grid { grid-template-columns: repeat(2, 1fr); gap: 12px; }
}

/* Product grid (fib-product-grid) refinements */
.fib-product-grid .product-card { margin-bottom: 0; }
.fib-product-grid .product-thumbnail { aspect-ratio: 3 / 4; }

/* Ecomus-style product grid */
.fib-product-grid.products {
  display: grid;
  grid-template-columns: repeat(var(--fib-columns, 4), 1fr);
  gap: 20px;
}
@media (max-width: 1024px) {
  .fib-product-grid.products { grid-template-columns: repeat(3, 1fr); }
}
@media (max-width: 768px) {
  .fib-product-grid.products { grid-template-columns: repeat(2, 1fr); gap: 12px; }
}
@media (max-width: 480px) {
  .fib-product-grid.products { grid-template-columns: repeat(2, 1fr); gap: 8px; }
}

/* Column chooser buttons */
.fib-column-btn.active { border-color: var(--primary) !important; background: var(--primary) !important; color: #fff !important; }
.fib-column-btn:hover { border-color: var(--primary); }

/* Breadcrumb */
.fib-breadcrumb a { color: var(--text-light); text-decoration: none; }
.fib-breadcrumb a:hover { color: var(--primary); }

/* WooCommerce star rating alignment */
.product-rating .star-rating { margin: 0; }
.product-rating .star-rating span::before { color: var(--gold); }

/* ========== MARKETING BANNER ========== */
.marketing-banner {
  background: linear-gradient(135deg, #1E293B 0%, #0F172A 100%);
  padding: 72px 0; position: relative; overflow: hidden;
}
.marketing-banner::before {
  content: ''; position: absolute; top: -50%; left: -50%;
  width: 100%; height: 100%;
  background: radial-gradient(circle, rgba(var(--primary-rgb), 0.08) 0%, transparent 70%);
  pointer-events: none;
}
.banner-inner {
  max-width: 1200px; margin: 0 auto; padding: 0 20px;
  display: grid; grid-template-columns: 1fr auto; gap: 48px;
  align-items: center; position: relative; z-index: 1;
}
.banner-inner h2 { font-size: 32px; font-weight: 900; color: #fff; margin-bottom: 12px; }
.banner-inner p { font-size: 16px; color: rgba(255,255,255,0.7); max-width: 540px; }
.banner-eyebrow {
  font-size: 13px; font-weight: 700; color: var(--primary-light);
  margin-bottom: 8px; text-transform: uppercase; letter-spacing: 1px;
}
.banner-checks { display: flex; flex-wrap: wrap; gap: 8px; margin: 20px 0; }
.banner-checks span {
  background: rgba(255,255,255,0.08); color: rgba(255,255,255,0.8);
  padding: 6px 14px; border-radius: 99px; font-size: 12px; font-weight: 600;
}
.btn-banner {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 14px 32px; border-radius: 99px; font-size: 16px; font-weight: 800;
  background: var(--primary); color: #fff !important; transition: var(--transition);
}
.btn-banner:hover { transform: translateY(-2px); box-shadow: 0 8px 24px rgba(var(--primary-rgb), 0.4); }

.savings-card {
  background: rgba(255,255,255,0.08); border: 1px solid rgba(255,255,255,0.15);
  border-radius: var(--radius-xl); padding: 36px; text-align: center;
  backdrop-filter: blur(8px); min-width: 200px;
}
.savings-card .savings-label { color: rgba(255,255,255,0.6); font-size: 13px; margin-bottom: 8px; }
.savings-card .savings-number { font-size: 56px; font-weight: 900; color: #fff; line-height: 1; }
.savings-card .savings-caption { color: rgba(255,255,255,0.5); font-size: 13px; margin-top: 8px; }

@media (max-width: 900px) {
  .banner-inner { grid-template-columns: 1fr; text-align: center; }
  .banner-inner p { margin: 0 auto; }
  .banner-checks { justify-content: center; }
  .savings-card { display: none; }
  .marketing-banner { padding: 48px 0; }
  .banner-inner h2 { font-size: 24px; }
}

/* ========== WHY US ========== */
.why-us { background: var(--card); }
.why-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; }
.why-card {
  padding: 28px; border: 1px solid var(--border);
  border-radius: var(--radius-lg); transition: var(--transition);
  background: var(--card);
}
.why-card:hover { border-color: var(--primary); box-shadow: 0 8px 24px rgba(var(--primary-rgb), 0.1); transform: translateY(-3px); }
.why-card .why-icon { font-size: 32px; margin-bottom: 12px; }
.why-card h3 { font-size: 16px; font-weight: 800; margin-bottom: 8px; }
.why-card p { font-size: 13px; margin: 0; }
@media (max-width: 1024px) { .why-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 640px) { .why-grid { grid-template-columns: 1fr; } }

/* ========== DELIVERY INFO ========== */
.delivery-section { background: var(--bg-alt); }
.delivery-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 48px; align-items: start; }
.delivery-info h2 { font-size: 26px; font-weight: 900; margin-bottom: 24px; }
.delivery-detail {
  display: flex; gap: 14px; padding: 16px 0; border-bottom: 1px solid var(--border);
}
.delivery-detail:last-child { border-bottom: none; }
.delivery-detail .delivery-detail-icon { font-size: 24px; flex-shrink: 0; }
.delivery-detail strong { display: block; font-size: 15px; margin-bottom: 2px; }
.delivery-detail p { font-size: 13px; margin: 0; }

.order-steps {
  background: var(--card); border-radius: var(--radius-xl);
  padding: 32px; border: 1px solid var(--border);
}
.order-steps h3 { font-size: 20px; font-weight: 900; margin-bottom: 24px; }
.step { display: flex; gap: 14px; margin-bottom: 20px; }
.step:last-child { margin-bottom: 0; }
.step-num {
  width: 36px; height: 36px; border-radius: 50%; background: var(--primary-bg);
  color: var(--primary); font-weight: 900; font-size: 14px;
  display: flex; align-items: center; justify-content: center; flex-shrink: 0;
}
.step-content strong { display: block; font-size: 14px; margin-bottom: 2px; }
.step-content p { font-size: 13px; margin: 0; }

.btn-outline {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 10px 24px; border-radius: 99px; font-weight: 700; font-size: 13px;
  border: 1.5px solid var(--border); color: var(--text); transition: var(--transition);
  margin-top: 16px;
}
.btn-outline:hover { border-color: var(--primary); color: var(--primary); }

@media (max-width: 900px) { .delivery-grid { grid-template-columns: 1fr; gap: 32px; } }

/* ========== CONTACT ========== */
.contact-section { background: var(--bg); }
.contact-grid { display: grid; grid-template-columns: 1fr 1.2fr; gap: 48px; }
.contact-info h2 { font-size: 26px; font-weight: 900; margin-bottom: 16px; }
.contact-item {
  display: flex; align-items: center; gap: 12px; padding: 14px 0;
  border-bottom: 1px solid var(--border);
}
.contact-item:last-child { border-bottom: none; }
.contact-item-icon { font-size: 20px; flex-shrink: 0; }
.contact-item a { font-weight: 600; color: var(--text); }
.contact-item a:hover { color: var(--primary); }

.contact-form-card {
  background: var(--card); border-radius: var(--radius-xl);
  padding: 36px; border: 1px solid var(--border);
}
.contact-form-card h3 { font-size: 20px; font-weight: 900; margin-bottom: 24px; }
.form-group { margin-bottom: 16px; }
.form-group label { display: block; font-size: 13px; font-weight: 600; margin-bottom: 6px; }
.form-group input, .form-group textarea, .form-group select {
  width: 100%; padding: 12px 16px; border-radius: var(--radius);
  border: 1.5px solid var(--border); font-size: 14px; font-family: var(--font);
  background: var(--bg); color: var(--text); transition: var(--transition);
}
.form-group input:focus, .form-group textarea:focus, .form-group select:focus {
  border-color: var(--primary); outline: none;
  box-shadow: 0 0 0 3px var(--primary-bg);
}
.form-group textarea { min-height: 100px; resize: vertical; }
.form-submit {
  width: 100%; padding: 14px; border-radius: var(--radius);
  background: var(--primary); color: #fff; border: none;
  font-size: 16px; font-weight: 800; font-family: var(--font);
  cursor: pointer; transition: var(--transition);
}
.form-submit:hover { transform: translateY(-2px); box-shadow: 0 8px 24px rgba(var(--primary-rgb), 0.3); }
.status-msg { font-size: 13px; text-align: center; margin-top: 12px !important; }

@media (max-width: 900px) { .contact-grid { grid-template-columns: 1fr; gap: 32px; } }
@media (max-width: 768px) { .contact-form-card { padding: 24px; } }

/* ========== FOOTER ========== */
.main-footer { background: var(--bg-dark); color: rgba(255,255,255,0.7); }
.footer-top {
  max-width: 1200px; margin: 0 auto; padding: 48px 20px;
  display: grid; grid-template-columns: 1.8fr 1fr 1fr 1fr; gap: 40px;
}
.footer-brand .logo { color: #fff; margin-bottom: 16px; }
.footer-brand p { font-size: 13px; color: rgba(255,255,255,0.5); line-height: 1.7; }
.footer-contact-list { display: flex; flex-direction: column; gap: 8px; margin-top: 16px; }
.footer-contact-list a, .footer-contact-list span {
  color: rgba(255,255,255,0.5); font-size: 13px;
  display: flex; align-items: center; gap: 8px;
}
.footer-contact-list a:hover { color: var(--primary-light); }

.footer-links-col h4 { color: #fff; font-size: 14px; font-weight: 800; margin-bottom: 16px; }
.footer-links-col ul { list-style: none; padding: 0; margin: 0; }
.footer-links-col li { margin-bottom: 8px; }
.footer-links-col a { color: rgba(255,255,255,0.5); font-size: 13px; transition: var(--transition); }
.footer-links-col a:hover { color: var(--primary-light); }
.footer-pay-badge {
  display: inline-block; padding: 6px 14px; border: 1px solid rgba(255,255,255,0.1);
  border-radius: 99px; font-size: 12px; color: rgba(255,255,255,0.6);
}

.footer-bottom {
  border-top: 1px solid rgba(255,255,255,0.07);
  padding: 20px; text-align: center;
}
.footer-bottom p { margin: 0; font-size: 13px; color: rgba(255,255,255,0.3); }

@media (max-width: 1024px) { .footer-top { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 640px) { .footer-top { grid-template-columns: 1fr; } }

/* ========== BACK TO TOP ========== */
.back-to-top {
  position: fixed; bottom: 24px; right: 24px; z-index: 99;
  width: 44px; height: 44px; border-radius: 50%; background: var(--primary);
  color: #fff; border: none; cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  box-shadow: var(--shadow-md); transition: var(--transition);
  opacity: 0; visibility: hidden; transform: translateY(12px);
}
.back-to-top.visible { opacity: 1; visibility: visible; transform: translateY(0); }
.back-to-top:hover { transform: translateY(-3px); box-shadow: var(--shadow-lg); }

/* ========== RESPONSIVE HEADER ========== */
@media (max-width: 900px) {
  .main-nav { display: none; }
  .mobile-menu-btn { display: flex; }
  .btn-header-cta { display: none; }
}
@media (max-width: 600px) {
  .header-actions { gap: 3px; }
  .header-btn { width: 34px; height: 34px; border-radius: 8px; }
  .header-btn svg { width: 16px; height: 16px; }
  .header-btn#headerShippingBtn,
  .header-btn#headerWishlistBtn,
  .header-btn#themeToggle,
  .header-actions .gender-toggle { display: none; }
  .mobile-menu { top: 68px; }
}
@media (max-width: 480px) {
  body { padding-top: 56px; }
  .main-header, .header-inner { height: 56px; }
  .header-inner { padding: 0 10px; gap: 10px; }
  .btn-header-cta { display: none; }
  .fib-logo-img { max-width: 90px; max-height: 32px; }
  .logo { font-size: 16px; gap: 6px; }
  .logo-icon { width: 30px; height: 30px; font-size: 14px; border-radius: 8px; }
  .header-actions { gap: 2px; }
  .header-btn { width: 32px; height: 32px; border-radius: 8px; }
  .header-btn svg { width: 15px; height: 15px; }
  .mobile-menu-btn { width: 32px; height: 32px; padding: 8px; }
  .mobile-menu-btn span { height: 2px; }
  .mobile-menu-btn.open span:nth-child(1) { transform: translateY(6.5px) rotate(45deg); }
  .mobile-menu-btn.open span:nth-child(3) { transform: translateY(-6.5px) rotate(-45deg); }
  .cart-badge { min-width: 14px; height: 14px; font-size: 8px; top: 1px; right: 1px; }
  .mobile-menu { top: 56px; max-height: calc(100vh - 56px); }
  .mobile-menu-actions { grid-template-columns: repeat(2, 1fr); }
}

/* ========== WOOCOMMERCE OVERRIDES ========== */
.woocommerce ul.products {
  display: grid; grid-template-columns: repeat(auto-fill, minmax(240px, 1fr));
  gap: 20px; padding: 0; margin: 0; list-style: none;
}
.woocommerce ul.products li.product { float: none; width: auto !important; margin: 0 !important; padding: 0; }
@media (max-width: 480px) {
  .woocommerce ul.products { grid-template-columns: repeat(2, 1fr); gap: 12px; }
}

.woocommerce .woocommerce-ordering select {
  padding: 10px 14px; border: 1.5px solid var(--border); border-radius: var(--radius);
  font-size: 13px; font-family: var(--font); background: var(--card); color: var(--text);
}
.woocommerce .woocommerce-result-count { font-size: 13px; color: var(--text-light); }

.woocommerce nav.woocommerce-pagination {
  margin-top: 40px;
}
.woocommerce nav.woocommerce-pagination ul {
  display: flex; justify-content: center; gap: 8px; border: none; margin: 0; padding: 0;
}
.woocommerce nav.woocommerce-pagination ul li { border: none; margin: 0; float: none; }
.woocommerce nav.woocommerce-pagination ul li a,
.woocommerce nav.woocommerce-pagination ul li span {
  display: flex; align-items: center; justify-content: center;
  min-width: 40px; height: 40px; border-radius: 10px;
  border: 1.5px solid var(--border); background: var(--card);
  color: var(--text); font-weight: 600; font-size: 13px; padding: 0 12px;
}
.woocommerce nav.woocommerce-pagination ul li a:hover { border-color: var(--primary); color: var(--primary); }
.woocommerce nav.woocommerce-pagination ul li span.current {
  background: var(--primary); color: #fff; border-color: var(--primary);
}

/* Notices */
.woocommerce-error, .woocommerce-message, .woocommerce-info {
  border-radius: var(--radius) !important; border: none !important;
  padding: 12px 44px 12px 16px !important; font-size: 13px !important;
  margin-bottom: 12px !important;
}

/* ========== SINGLE PRODUCT ========== */
.fib-single-wrapper { max-width: 1200px; margin: 0 auto; padding: 24px 20px; }
.fib-single-grid {
  display: grid; grid-template-columns: 1fr 1fr; gap: 40px;
}
.fib-single-gallery { position: sticky; top: 88px; align-self: start; }
.fib-single-summary { display: flex; flex-direction: column; gap: 16px; }
.fib-single-summary h1 { font-size: 26px; margin: 0; }
.fib-single-summary .price { font-size: 28px; font-weight: 900; color: var(--secondary); }
.fib-single-summary .stock-badge {
  display: inline-block; padding: 4px 10px; border-radius: 6px;
  font-size: 12px; font-weight: 700;
}
.stock-badge.in-stock { background: #D1FAE5; color: #059669; }
.stock-badge.out-of-stock { background: #FEE2E2; color: #DC2626; }
.stock-badge.on-backorder { background: #FEF3C7; color: #D97706; }
.stock-delivery { font-size: 12px; color: var(--text-light); }

.fib-rating { display: flex; align-items: center; gap: 6px; flex-wrap: wrap; margin: 2px 0; }
.fib-stars { display: flex; gap: 2px; direction: ltr; font-size: 14px; line-height: 1; }
.fib-stars .star-full { color: #f59e0b; }
.fib-stars .star-half { color: #f59e0b; position: relative; }
.fib-stars .star-half::after { content: '\2605'; position: absolute; right: 0; top: 0; width: 50%; overflow: hidden; color: #f59e0b; }
.fib-stars .star-empty { color: #d1d5db; }
.fib-rating-text { font-size: 13px; font-weight: 700; color: var(--text); direction: ltr; line-height: 1; }
.fib-rating-sep { color: var(--border); font-size: 14px; }
.fib-rating-link { font-size: 13px; color: var(--primary); text-decoration: none; font-weight: 600; }
.fib-rating-link:hover { text-decoration: underline; }
.fib-rating .rating-count { font-size: 12px; color: var(--text-light); font-weight: 500; direction: rtl; }
.fib-rating-0 { font-size: 12px; color: var(--text-light); font-weight: 500; }
.fib-single-summary .product_meta { font-size: 13px; color: var(--text-light); }
.fib-single-summary .fib-stars { font-size: 20px; }
.fib-single-cat {
  font-size: 12px; font-weight: 700; color: var(--primary);
  text-transform: uppercase; letter-spacing: 0.5px; margin-bottom: 4px;
}
.fib-single-desc {
  font-size: 14px; color: var(--text-light); line-height: 1.7;
}
.fib-single-tabs { margin-top: 40px; }

/* Gallery */
.woocommerce-product-gallery { overflow: hidden; border-radius: var(--radius); }
.woocommerce-product-gallery ol.flex-control-nav {
  direction: ltr; margin: 8px 0 0 !important; padding: 0 !important;
  display: flex; gap: 6px; justify-content: center;
}
.woocommerce-product-gallery ol.flex-control-nav li {
  display: inline-block; width: 60px !important; height: 60px !important;
  margin: 0 !important; border: 2px solid transparent; border-radius: 8px;
  overflow: hidden; transition: border-color 0.2s;
}
.woocommerce-product-gallery ol.flex-control-nav li img {
  width: 100%; height: 100%; object-fit: cover;
  opacity: 0.6; cursor: pointer;
}
.woocommerce-product-gallery ol.flex-control-nav li.flex-active { border-color: var(--primary); }
.woocommerce-product-gallery ol.flex-control-nav li.flex-active img,
.woocommerce-product-gallery ol.flex-control-nav li img:hover { opacity: 1; }
.woocommerce-product-gallery__trigger { left: 12px !important; right: auto !important; }

/* Quantity & Cart */
.fib-cart-area form.cart { display: flex; flex-wrap: wrap; align-items: center; gap: 10px; }
.fib-cart-area .quantity {
  display: inline-flex; align-items: center; border: 1.5px solid var(--border);
  border-radius: 10px; overflow: hidden; background: var(--card);
}
.fib-cart-area .single_add_to_cart_button {
  flex: 1; min-width: 160px; height: 48px; padding: 0 24px;
  border: none; border-radius: 10px; font-size: 14px; font-weight: 800;
  font-family: var(--font); cursor: pointer; background: var(--primary);
  color: #fff; transition: var(--transition);
}
.fib-cart-area .single_add_to_cart_button:hover { transform: translateY(-1px); box-shadow: 0 8px 20px rgba(var(--primary-rgb), 0.3); }

/* Trust badges */
.fib-trust-badges {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 8px;
  padding: 16px; background: var(--bg-alt); border-radius: var(--radius);
  border: 1px solid var(--border); text-align: center;
}
.fib-trust-badges .trust-item { text-align: center; }
.fib-trust-badges .trust-item svg { display: block; margin: 0 auto 6px; }
.fib-trust-badges .trust-item span { font-size: 11px; color: var(--text-light); }

/* Tabs */
.woocommerce div.product .woocommerce-tabs { margin-top: 48px; }
.woocommerce div.product .woocommerce-tabs ul.tabs {
  padding: 0; margin: 0 0 20px; display: flex; gap: 4px;
}
.woocommerce div.product .woocommerce-tabs ul.tabs li {
  border: none; background: transparent; padding: 0; margin: 0;
}
.woocommerce div.product .woocommerce-tabs ul.tabs li a {
  font-weight: 700; padding: 10px 20px; border-radius: 10px 10px 0 0;
  color: var(--text-light); background: transparent; font-size: 14px;
}
.woocommerce div.product .woocommerce-tabs ul.tabs li.active a {
  background: var(--bg-alt); color: var(--primary);
}
.woocommerce div.product .woocommerce-tabs ul.tabs::before,
.woocommerce div.product .woocommerce-tabs ul.tabs::after { display: none; }

@media (max-width: 768px) {
  .fib-single-grid { grid-template-columns: 1fr; gap: 24px; }
  .fib-single-gallery { position: static; }
}



/* ========== MOBILE STICKY BUY BAR ========== */
.fib-sticky-buy {
  display: none; position: fixed; bottom: 0; left: 0; right: 0;
  background: var(--card); border-top: 1px solid var(--border);
  padding: 10px 16px; z-index: 50; box-shadow: 0 -4px 20px rgba(0,0,0,0.08);
}
@media (max-width: 767px) {
  .fib-sticky-buy { display: block !important; }
  body.single-product { padding-bottom: 72px; }
}

/* ========== CHECKOUT ========== */
.fib-checkout-grid {
  max-width: 1120px; margin: 0 auto; padding: 20px;
  display: flex; flex-direction: column; gap: 20px;
}
@media (min-width: 768px) {
  .fib-checkout-grid {
    flex-direction: row; padding: 24px;
    gap: 32px;
  }
  .fib-checkout-fields { flex: 1.2; min-width: 0; }
  .fib-checkout-summary { flex: 0.8; min-width: 0; }
}

.fib-section-card {
  background: var(--card); border: 1px solid var(--border);
  border-radius: var(--radius); padding: 24px; margin-bottom: 16px;
}
.fib-section-title {
  font-size: 18px; font-weight: 800; margin-bottom: 20px;
  padding-bottom: 12px; border-bottom: 1px solid var(--border);
}

.fib-checkout .form-row { margin-bottom: 16px; }
.fib-checkout .form-row label {
  display: block; font-size: 13px; font-weight: 600; margin-bottom: 4px;
}
.fib-checkout .form-row input,
.fib-checkout .form-row textarea,
.fib-checkout .form-row select {
  width: 100%; padding: 11px 14px; font-size: 14px;
  font-family: var(--font); border: 1.5px solid var(--border);
  border-radius: 10px; background: var(--card); color: var(--text);
  transition: var(--transition);
}
.fib-checkout .form-row input:focus,
.fib-checkout .form-row textarea:focus,
.fib-checkout .form-row select:focus {
  border-color: var(--primary); outline: none;
  box-shadow: 0 0 0 3px var(--primary-bg);
}

/* Shipping radio cards */
.fib-shipping-toggle, .fib-payment-toggle {
  display: flex; flex-direction: column; gap: 10px;
}
.fib-radio-card {
  display: flex; align-items: center; gap: 12px;
  padding: 14px 16px; border: 1.5px solid var(--border);
  border-radius: var(--radius); cursor: pointer; transition: var(--transition);
}
.fib-radio-card:has(input:checked) {
  border-color: var(--primary); background: var(--primary-bg);
}
.fib-radio-card input[type="radio"] { accent-color: var(--primary); }
.fib-radio-content { display: flex; flex-direction: column; gap: 2px; }
.fib-radio-title { font-weight: 700; font-size: 14px; }
.fib-radio-desc { font-size: 12px; color: var(--text-light); }

/* Sticky checkout button */
.fib-checkout-sticky {
  display: none;
}
@media (max-width: 767px) {
  .fib-checkout-sticky {
    display: block; position: fixed; bottom: 0; left: 0; right: 0;
    z-index: 1000; background: var(--card);
    border-top: 1px solid var(--border); padding: 12px 16px;
    box-shadow: 0 -4px 20px rgba(0,0,0,0.08);
  }
  body.fibitek-checkout { padding-bottom: 72px; }
}

.fib-sticky-inner {
  max-width: 1120px; margin: 0 auto;
  display: flex; align-items: center; gap: 16px;
}
.fib-sticky-price {
  font-size: 20px; font-weight: 800; color: var(--primary);
  direction: ltr; flex-shrink: 0;
}
.fib-sticky-total { display: flex; flex-direction: column; line-height: 1.2; flex-shrink: 0; }
.fib-sticky-label { font-size: 11px; color: var(--text-light); font-weight: 500; }
.fib-sticky-amount { font-size: 18px; font-weight: 800; color: var(--primary); direction: ltr; }
.fib-place-order {
  flex: 1; text-align: center; background: var(--primary) !important;
  color: #fff !important; border: none !important; border-radius: 10px !important;
  padding: 14px 24px !important; font-size: 15px !important;
  font-weight: 800 !important; font-family: var(--font) !important;
  cursor: pointer; transition: var(--transition);
}
.fib-place-order:hover { transform: translateY(-1px); box-shadow: 0 8px 20px rgba(var(--primary-rgb), 0.3); }

/* ========== CUSTOM CART PAGE (fib-cart-*) ========== */
.fib-cart-page { max-width: 1280px; margin: 0 auto; padding: 40px 24px; }
.fib-cart-empty { text-align: center; padding: 80px 20px; }
.fib-cart-empty svg { margin-bottom: 16px; opacity: 0.4; }
.fib-cart-empty h2 { font-size: 24px; font-weight: 800; margin: 0 0 8px; }
.fib-cart-empty p { color: var(--text-light); font-size: 14px; margin: 0 0 24px; }
.fib-cart-layout { display: grid; grid-template-columns: 360px 1fr; gap: 24px; align-items: start; }
.fib-cart-header { display: flex; align-items: baseline; gap: 12px; margin-bottom: 20px; }
.fib-cart-title { font-size: 28px; font-weight: 900; margin: 0; }
.fib-cart-count { font-size: 14px; color: var(--text-light); font-weight: 600; }
/* Cart table */
.fib-cart-table-wrap {
  overflow-x: auto; border-radius: var(--radius-lg);
  border: 1px solid var(--border); background: var(--card);
}
.fib-cart-table { width: 100%; border-collapse: collapse; font-size: 14px; }
.fib-cart-table thead { background: var(--bg-alt); }
.fib-cart-table th {
  padding: 14px 16px; font-size: 12px; font-weight: 800; text-transform: uppercase;
  letter-spacing: 0.5px; color: var(--text-light); border-bottom: 1px solid var(--border);
  text-align: center;
}
.fib-cart-table td { padding: 16px; border-bottom: 1px solid var(--border); vertical-align: middle; }
.fib-cart-table tbody tr:last-child td { border-bottom: none; }
.fib-cart-table tbody tr:hover { background: var(--bg-alt); }
.fib-cth-thumb { width: 80px; }
.fib-cth-desc { min-width: 200px; }
.fib-cth-qty { width: 140px; text-align: center; }
.fib-cth-subtotal { width: 120px; text-align: center; }
.fib-cth-remove { width: 40px; }
.fib-ctd-thumb img { width: 64px; height: 64px; border-radius: 8px; object-fit: cover; }
.fib-ctd-name { font-weight: 700; color: var(--text); text-decoration: none; display: block; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.fib-ctd-name:hover { color: var(--primary); }
.fib-ctd-attrs { display: flex; flex-wrap: wrap; gap: 4px; margin-bottom: 6px; }
.fib-ctd-attr { font-size: 12px; color: var(--text-light); background: var(--bg-alt); padding: 2px 8px; border-radius: 4px; }
.fib-ctd-attr strong { color: var(--text); }
.fib-ctd-stock { display: inline-block; font-size: 12px; font-weight: 700; padding: 2px 10px; border-radius: 20px; }
.fib-instock { background: #dcfce7; color: #166534; }
.fib-outofstock { background: #fef2f2; color: #dc2626; }
.fib-onbackorder { background: #fef9c3; color: #854d0e; }
.fib-ctd-qty { text-align: center; }
.fib-ctd-qty-inner {
  display: inline-flex; align-items: center; border: 1.5px solid var(--border);
  border-radius: 8px; overflow: hidden;
}
.fib-ci-qty-btn {
  width: 32px; height: 32px; border: none; background: var(--bg-alt);
  cursor: pointer; font-size: 16px; font-weight: 700; color: var(--text);
  transition: var(--transition); display: flex; align-items: center; justify-content: center;
}
.fib-ci-qty-btn:hover { background: var(--primary-bg); color: var(--primary); }
.fib-ci-qty-input {
  width: 40px; height: 32px; border: none; text-align: center;
  font-weight: 700; font-size: 14px; background: var(--bg); color: var(--text);
  font-family: var(--font);
}
.fib-ctd-subtotal { text-align: end; }
.fib-ctd-subtotal-val { font-weight: 800; font-size: 15px; direction: ltr; }
.fib-ctd-remove { text-align: center; }
.fib-ci-remove {
  width: 32px; height: 32px; display: inline-flex; align-items: center; justify-content: center;
  border-radius: 50%; background: var(--bg-alt); color: var(--text-light);
  text-decoration: none; transition: var(--transition);
}
.fib-ci-remove:hover { background: var(--accent); color: #fff; }
.fib-cart-item-removing { opacity: 0.4; pointer-events: none; transition: opacity 0.3s; }
.fib-cart-item-error { border-color: var(--accent) !important; background: #fff0f0; }

/* Cart sidebar */
.fib-cart-sidebar { position: sticky; top: 100px; }
.fib-cart-card {
  background: var(--card); border: 1px solid var(--border);
  border-radius: var(--radius-lg); padding: 24px;
}
.fib-cart-card-head {
  display: flex; align-items: center; gap: 8px; font-size: 16px;
  font-weight: 800; margin-bottom: 16px;
}
.fib-cart-card-head svg { color: var(--primary); flex-shrink: 0; }
.fib-cart-coupon { margin-bottom: 16px; }
.fib-cart-coupon-row { display: flex; gap: 8px; }
.fib-cart-coupon-row input {
  flex: 1; padding: 10px 14px; border: 1.5px solid var(--border);
  border-radius: 8px; font-size: 14px; font-family: var(--font);
  background: var(--bg); color: var(--text);
}
.fib-cart-coupon-row button {
  padding: 10px 20px; border: none; border-radius: 8px;
  background: var(--primary); color: #fff; font-weight: 700; font-size: 13px;
  cursor: pointer; font-family: var(--font); transition: var(--transition);
  white-space: nowrap;
}
.fib-cart-coupon-row button:hover { background: var(--primary-dark); }
.fib-cart-coupon-msg { font-size: 12px; margin-top: 6px; min-height: 18px; }
.fib-cart-totals { margin-bottom: 20px; }
.fib-cart-total-row { display: flex; justify-content: space-between; align-items: center; padding: 8px 0; font-size: 14px; }
.fib-cart-total-row .fib-ct-label { color: var(--text-light); font-weight: 600; }
.fib-cart-total-row .fib-ct-value { font-weight: 700; direction: ltr; }
.fib-cart-total-row .fib-ct-ship { font-weight: 400; color: var(--text-light); font-size: 12px; }
.fib-cart-divider { height: 1px; background: var(--border); margin: 4px 0; }
.fib-cart-total-final { font-size: 18px; }
.fib-cart-total-final .fib-ct-label { color: var(--text); font-weight: 800; }
.fib-cart-total-final .fib-ct-value { color: var(--primary); font-size: 20px; }
.fib-cart-btn-primary {
  display: flex; align-items: center; justify-content: center; gap: 8px;
  width: 100%; padding: 14px; border-radius: 10px;
  background: var(--primary); color: #fff; font-weight: 800; font-size: 15px;
  text-decoration: none; transition: var(--transition); border: none; cursor: pointer;
  font-family: var(--font);
}
.fib-cart-btn-primary:hover { transform: translateY(-1px); box-shadow: 0 8px 20px rgba(var(--primary-rgb), 0.3); }
.fib-cart-checkout-btn { margin-bottom: 12px; }
.fib-cart-continue {
  display: flex; align-items: center; justify-content: center; gap: 6px;
  font-size: 13px; font-weight: 600; color: var(--text-light); text-decoration: none;
  transition: var(--transition);
}
.fib-cart-continue:hover { color: var(--primary); }
.fib-cart-info { margin-top: 16px; display: flex; flex-direction: column; gap: 12px; }
.fib-cart-info-item { display: flex; align-items: center; gap: 10px; font-size: 13px; }
.fib-cart-info-item strong { display: block; font-size: 13px; }
.fib-cart-info-item span { font-size: 12px; color: var(--text-light); }

@media (max-width: 1024px) {
  .fib-cart-layout { grid-template-columns: 1fr; }
  .fib-cart-sidebar { position: static; }
}
@media (max-width: 768px) {
  .fib-cart-layout { grid-template-columns: 1fr; }
  .fib-cart-table thead { display: none; }
  .fib-cart-table tr { display: flex; flex-wrap: wrap; padding: 12px; gap: 8px; align-items: center; border-bottom: 1px solid var(--border); }
  .fib-cart-table td { display: flex; align-items: center; gap: 6px; padding: 0; border: none; }
  .fib-cart-table td::before { content: attr(data-label); font-size: 12px; font-weight: 600; color: var(--text-light); white-space: nowrap; }
  .fib-ctd-thumb { order: 0; }
  .fib-ctd-thumb img { width: 56px; height: 56px; }
  .fib-ctd-desc { flex: 1; order: 1; flex-direction: column; align-items: flex-start; }
  .fib-ctd-desc::before { display: none; }
  .fib-ctd-qty { order: 2; width: 100%; justify-content: center; padding-top: 4px; }
  .fib-ctd-qty::before { display: none; }
  .fib-ctd-subtotal { order: 3; }
  .fib-ctd-remove { order: 4; margin-inline-start: auto; }
  .fib-cart-sidebar { position: static; }
  .fib-cart-page { padding: 16px 12px; }
  .fib-cart-title { font-size: 22px; }
  .fib-cart-header { flex-wrap: wrap; }
}

/* ========== MINI-CART DRAWER ========== */
body.drawer-open { overflow: hidden; }
.cart-drawer-overlay {
  position: fixed; inset: 0; background: rgba(0,0,0,0.4);
  z-index: 200; opacity: 0; visibility: hidden; transition: var(--transition);
}
.cart-drawer-overlay.open, .cart-drawer-overlay.show { opacity: 1; visibility: visible; }

.cart-drawer {
  position: fixed; top: 0; left: 0; right: auto; bottom: 0;
  width: 380px; max-width: 85vw; background: var(--card);
  z-index: 201; transform: translateX(-100%);
  visibility: hidden;
  transition: transform 0.3s cubic-bezier(0.4, 0, 0.2, 1), visibility 0.3s;
  display: flex; flex-direction: column; box-shadow: 4px 0 24px rgba(0,0,0,0.12);
  overflow: hidden;
}
.cart-drawer.open { transform: translateX(0); visibility: visible; }
.cart-drawer-header {
  display: flex; align-items: center; justify-content: space-between;
  padding: 20px 16px; border-bottom: 1px solid var(--border);
}
.cart-drawer-header h3 { margin: 0; font-size: 18px; font-weight: 800; }
.cart-drawer-close {
  width: 36px; height: 36px; border-radius: 10px; border: none;
  background: var(--bg-alt); cursor: pointer; display: flex;
  align-items: center; justify-content: center; color: var(--text);
  transition: var(--transition);
}
.cart-drawer-close:hover { background: var(--primary-bg); }
.cart-drawer-items { flex: 1; overflow-y: auto; padding: 16px; }
.cart-drawer-footer {
  border-top: 1px solid var(--border); padding: 16px;
}
.cart-drawer-total-row {
  display: flex; justify-content: space-between; margin-bottom: 12px;
  font-weight: 800; font-size: 16px;
}
.cart-drawer-total-row .drawer-total { direction: ltr; }
.cart-drawer-checkout {
  display: block; text-align: center; padding: 14px;
  background: var(--primary); color: #fff; border-radius: 10px;
  font-weight: 800; font-size: 15px; transition: var(--transition);
}
.cart-drawer-checkout:hover { transform: translateY(-1px); box-shadow: 0 8px 20px rgba(var(--primary-rgb), 0.3); }
.cart-drawer-cart-link {
  display: block; text-align: center; padding: 10px;
  margin-top: 8px; font-size: 13px; color: var(--text-light);
}

/* ========== Cart Drawer Items ========== */
.drawer-item {
  display: flex; gap: 12px; padding: 14px 0; border-bottom: 1px solid var(--border);
  position: relative; transition: opacity 0.2s;
}
.drawer-item.drawer-item-loading { opacity: 0.5; pointer-events: none; }
.drawer-item-img-wrap { width: 68px; height: 68px; border-radius: 10px; overflow: hidden; flex-shrink: 0; background: var(--bg-alt); }
.drawer-item-img-wrap img { width: 100%; height: 100%; object-fit: cover; display: block; }
.drawer-item-body { flex: 1; min-width: 0; display: flex; flex-direction: column; gap: 4px; }
.drawer-item-name { font-size: 13px; font-weight: 700; color: var(--text); text-decoration: none; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.drawer-item-name:hover { color: var(--primary); }

/* Attribute chips — clickable for inline editing */
.drawer-item-attrs { display: flex; flex-wrap: wrap; gap: 4px; }
.drawer-attr-chip {
  display: inline-flex; align-items: center; gap: 4px;
  padding: 2px 8px; background: var(--bg-alt); border: 1px solid var(--border);
  border-radius: 5px; font-size: 10px; font-weight: 600; color: var(--text-light);
  cursor: pointer; transition: all 0.15s; font-family: var(--font); line-height: 1.6;
}
.drawer-attr-chip:hover { border-color: var(--primary); color: var(--primary); background: var(--primary-bg); }
.drawer-attr-static {
  display: inline-flex; padding: 2px 8px; background: var(--bg-alt);
  border-radius: 5px; font-size: 10px; font-weight: 600; color: var(--text-light);
}

/* Inline attribute options (hidden by default, shown on chip click) */
.drawer-attr-options { margin: 4px 0 2px; }
.drawer-attr-options-inner { display: flex; flex-wrap: wrap; gap: 4px; padding: 8px; background: var(--bg-alt); border-radius: 8px; border: 1px solid var(--border); }
.drawer-attr-option {
  display: inline-flex; align-items: center; padding: 4px 12px;
  border: 1px solid var(--border); border-radius: 6px; background: var(--card);
  font-size: 11px; font-weight: 600; color: var(--text); cursor: pointer;
  transition: all 0.15s; font-family: var(--font); line-height: 1.5;
}
.drawer-attr-option:hover { border-color: var(--primary); color: var(--primary); background: var(--primary-bg); }
.drawer-attr-option.active { background: var(--primary); color: #fff; border-color: var(--primary); }

/* Qty controls */
.drawer-item-bottom { display: flex; align-items: center; justify-content: space-between; gap: 8px; margin-top: 2px; }
.drawer-qty-wrap { display: inline-flex; align-items: center; border: 1px solid var(--border); border-radius: 8px; overflow: hidden; background: var(--bg); }
.drawer-qty-wrap button {
  width: 28px; height: 28px; border: none; background: var(--bg-alt);
  cursor: pointer; font-size: 15px; line-height: 1; font-weight: 700;
  display: flex; align-items: center; justify-content: center;
  padding: 0; color: var(--text); transition: background 0.15s, color 0.15s;
  font-family: var(--font);
}
.drawer-qty-wrap button:hover { background: var(--primary); color: #fff; }
.drawer-qty-input {
  width: 32px; height: 28px; border: none; text-align: center; font-weight: 700;
  font-size: 13px; background: transparent; color: var(--text);
  font-family: var(--font); outline: none; padding: 0;
  -moz-appearance: textfield;
}
.drawer-qty-input::-webkit-inner-spin-button,
.drawer-qty-input::-webkit-outer-spin-button { -webkit-appearance: none; margin: 0; }
.drawer-qty-input:focus { background: var(--bg-alt); }

.drawer-item-price { font-weight: 700; font-size: 13px; direction: ltr; white-space: nowrap; }

.drawer-remove {
  background: none; border: none; padding: 4px; cursor: pointer;
  color: var(--text-light); font-size: 18px; line-height: 1;
  flex-shrink: 0; align-self: flex-start; transition: color 0.2s, opacity 0.2s;
  opacity: 0.3;
}
.drawer-item:hover .drawer-remove { opacity: 1; }
.drawer-remove:hover { color: var(--accent); }

.drawer-empty { text-align: center; padding: 48px 0; color: var(--text-light); font-size: 14px; }
.drawer-empty p { margin: 0; }

/* ========== WISHLIST ========== */
.header-wishlist-wrap { position: relative; display: inline-flex; }
.header-wishlist-dropdown {
  position: fixed; top: 0; right: 0; width: 380px; max-width: 90vw;
  height: 100%; background: var(--card); z-index: 1200;
  box-shadow: -8px 0 32px rgba(0,0,0,0.1);
  transform: translateX(100%); transition: transform 0.3s ease;
  display: flex; flex-direction: column;
}
.header-wishlist-dropdown.open { transform: translateX(0); }
.header-wishlist-header {
  display: flex; align-items: center; justify-content: space-between;
  padding: 16px 20px; border-bottom: 1px solid var(--border);
}
.header-wishlist-header h4 { margin: 0; font-size: 16px; font-weight: 800; }
.header-wishlist-close {
  background: none; border: 0; font-size: 28px; cursor: pointer;
  color: var(--text-light); line-height: 1; padding: 0 4px;
}
.header-wishlist-overlay {
  position: fixed; top: 0; left: 0; width: 100%; height: 100%;
  background: rgba(0,0,0,0.3); z-index: 1199; display: none;
}
.header-wishlist-overlay.show { display: block; }
.header-wishlist-body { flex: 1; overflow-y: auto; padding: 12px 16px; }
.wishlist-empty { padding: 24px; text-align: center; color: var(--text-light); font-size: 14px; }
.wishlist-item {
  display: flex; align-items: center; gap: 12px;
  padding: 10px 0; border-bottom: 1px solid var(--border);
}
.wishlist-item:last-child { border-bottom: 0; }
.wishlist-item-img { width: 56px; height: 56px; flex-shrink: 0; border-radius: 8px; overflow: hidden; }
.wishlist-item-img img { width: 100%; height: 100%; object-fit: cover; }
.wishlist-item-info { flex: 1; min-width: 0; }
.wishlist-item-name { display: block; font-size: 13px; font-weight: 600; color: var(--text); margin-bottom: 4px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.wishlist-item-price { font-size: 13px; color: var(--primary); font-weight: 700; }
.wishlist-item-remove {
  background: none; border: 0; font-size: 20px; cursor: pointer;
  color: var(--text-light); padding: 4px; line-height: 1;
}
.wishlist-item-remove:hover { color: var(--accent); }

/* Wishlist heart button */
.fib-wishlist-toggle {
  background: none; border: 0; cursor: pointer; padding: 4px;
  display: inline-flex; align-items: center; color: var(--text-light);
  transition: color 0.2s, transform 0.2s;
}
.fib-wishlist-toggle:hover { color: var(--accent); transform: scale(1.1); }
.fib-wishlist-toggle.active svg { fill: var(--accent); stroke: var(--accent); }
.fib-wishlist-single {
  vertical-align: middle; margin-right: 8px;
}
/* ========== FILTER SIDEBAR PANEL (Ecomus-style) ========== */
.filter-panel {
  --panel-width: 410px;
  position: fixed; top: 0; left: 0; width: 100%; height: 100%;
  z-index: 1100; display: none;
}
.filter-panel.open { display: block; }
.filter-panel .panel__backdrop {
  position: absolute; top: 0; left: 0; width: 100%; height: 100%;
  background: rgba(0,0,0,0.2); cursor: pointer;
}
.filter-panel .panel__container {
  position: absolute; left: 0; top: 0; height: 100%;
  max-width: var(--panel-width); width: 100%;
  background: var(--card); box-shadow: 4px 0 24px rgba(0,0,0,0.12);
  transform: translateX(-100%); transition: transform 0.3s;
  display: flex; flex-direction: column;
}
.filter-panel.open .panel__container { transform: none; }
.filter-panel .panel__button-close {
  position: absolute; left: 20px; top: 22px; z-index: 1;
  background: var(--bg-alt); border: none; border-radius: 8px;
  width: 36px; height: 36px; cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  color: var(--text); transition: var(--transition);
}
.filter-panel .panel__button-close:hover { background: var(--primary-bg); }
.filter-panel .panel__header {
  padding: 18px 30px; margin: 0; font-size: 16px; font-weight: 700;
  color: var(--text); position: relative;
  display: flex; align-items: center; gap: 8px;
}
.filter-panel .panel__header:after {
  content: ""; position: absolute; bottom: 0; left: 0; right: 0;
  height: 1px; background: var(--border);
}
.filter-panel .panel__content {
  flex: 1; overflow-y: auto; padding: 20px;
}
.filter-panel .filter-widget-title {
  font-size: 14px; font-weight: 700; margin: 0 0 12px;
  padding-bottom: 8px; border-bottom: 1px solid var(--border);
}
.filter-panel .fib-filter-widget {
  margin-bottom: 20px; padding-bottom: 20px;
  border-bottom: 1px solid var(--border);
}
.filter-panel .fib-filter-widget:last-child { border-bottom: none; }

/* WooCommerce filter widget styles */
.filter-panel .widget_price_filter .price_slider_wrapper .price_slider {
  background: var(--border); height: 4px; border-radius: 2px; margin: 20px 0;
  position: relative;
}
.filter-panel .widget_price_filter .price_slider_wrapper .price_slider .ui-slider-range {
  position: absolute; height: 4px; background: var(--primary); border-radius: 2px;
}
.filter-panel .widget_price_filter .price_slider_wrapper .price_slider .ui-slider-handle {
  position: absolute; top: -6px; width: 16px; height: 16px;
  background: var(--primary); border: 2px solid #fff; border-radius: 50%;
  cursor: pointer; box-shadow: 0 1px 4px rgba(0,0,0,0.15); margin-left: -8px;
}
.filter-panel .widget_price_filter .price_slider_amount {
  display: flex; align-items: center; justify-content: space-between; gap: 8px;
}
.filter-panel .widget_price_filter .price_slider_amount .button {
  background: var(--primary); color: #fff; border: none; border-radius: 6px;
  padding: 6px 14px; font-size: 12px; font-weight: 700; cursor: pointer;
  font-family: var(--font); transition: var(--transition);
}
.filter-panel .widget_price_filter .price_slider_amount .button:hover { background: var(--primary-dark); }
.filter-panel .widget_price_filter .price_slider_amount .price_label {
  font-size: 13px; font-weight: 600; color: var(--text);
}

.filter-panel .widget_product_categories .product-categories {
  list-style: none; padding: 0; margin: 0;
}
.filter-panel .widget_product_categories .product-categories li {
  padding: 6px 0; font-size: 13px; border-bottom: 1px solid var(--border);
}
.filter-panel .widget_product_categories .product-categories li:last-child { border-bottom: none; }
.filter-panel .widget_product_categories .product-categories a {
  color: var(--text); text-decoration: none; display: flex; align-items: center; gap: 6px;
}
.filter-panel .widget_product_categories .product-categories a:hover { color: var(--primary); }
.filter-panel .widget_product_categories .product-categories .count {
  font-size: 11px; color: var(--text-light); margin-right: auto;
}

.filter-panel .widget_layered_nav ul {
  list-style: none; padding: 0; margin: 0;
}
.filter-panel .widget_layered_nav ul li {
  padding: 5px 0; font-size: 13px; display: flex; align-items: center; gap: 6px;
}
.filter-panel .widget_layered_nav ul li a { color: var(--text); text-decoration: none; }
.filter-panel .widget_layered_nav ul li a:hover { color: var(--primary); }
.filter-panel .widget_layered_nav ul li .count { font-size: 11px; color: var(--text-light); margin-right: auto; }
.filter-panel .widget_layered_nav ul li.chosen a { color: var(--primary); font-weight: 700; }

/* Filter toggle button */
.fib-filter-toggle:hover {
  background: var(--primary); color: #fff; border-color: var(--primary);
}
.fib-filter-toggle:hover svg { stroke: #fff; }

@media (max-width: 767px) {
  .filter-panel .panel__container { --panel-width: 90%; }
  .filter-panel .panel__header { padding: 14px 20px; }
  .filter-panel .panel__content { padding: 14px; }
  .filter-panel .panel__button-close { left: 14px; top: 14px; }
}

/* ========== WIDGETS ========== */
.fib-widget {
  margin-bottom: 24px; padding: 20px; border: 1px solid var(--border);
  border-radius: var(--radius); background: var(--card);
}
.fib-widget .widget-title {
  font-size: 16px; font-weight: 800; margin-bottom: 16px;
  padding-bottom: 8px; border-bottom: 2px solid var(--primary);
}
.fib-widget ul { list-style: none; padding: 0; margin: 0; }
.fib-widget ul li { padding: 8px 0; border-bottom: 1px solid var(--border); }
.fib-widget ul li:last-child { border-bottom: none; }
.fib-widget ul li a:hover { color: var(--primary); }

/* ========== BLOG POSTS ========== */
.fib-post-card {
  border: 1px solid var(--border); border-radius: var(--radius-lg);
  overflow: hidden; background: var(--card); transition: var(--transition);
}
.fib-post-card:hover { box-shadow: var(--shadow); }
.fib-post-card .post-thumb { width: 100%; height: 200px; object-fit: cover; }
.fib-post-card .post-body { padding: 20px; }
.fib-post-card h2 { font-size: 18px; }
.fib-post-card .post-meta { font-size: 13px; color: var(--text-light); margin-bottom: 12px; }

/* ========== COMMENTS ========== */
.fib-comments { margin-top: 32px; }
.fib-comment {
  padding: 16px; border: 1px solid var(--border);
  border-radius: var(--radius); margin-bottom: 16px;
}
.fib-comment-author { font-weight: 700; font-size: 14px; }
.fib-comment-meta { font-size: 12px; color: var(--text-light); }
.fib-comment-body { margin-top: 8px; font-size: 14px; }

/* ========== BLOG LAYOUT ========== */
.blog-layout { display: grid; grid-template-columns: 1fr 300px; gap: 40px; }
.blog-main { min-width: 0; }
.blog-sidebar { min-width: 0; }
.blog-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 20px; }
.archive-title { font-size: 28px; font-weight: 900; margin-bottom: 8px; }
.archive-desc { font-size: 14px; color: var(--text-light); margin-bottom: 24px; }
.pagination-wrap { margin-top: 32px; }
.pagination-wrap .page-numbers {
  display: inline-flex; align-items: center; justify-content: center;
  min-width: 40px; height: 40px; border-radius: 10px;
  border: 1.5px solid var(--border); background: var(--card);
  color: var(--text); font-weight: 600; font-size: 13px; padding: 0 12px;
  margin: 0 2px; text-decoration: none; transition: var(--transition);
}
.pagination-wrap .page-numbers:hover { border-color: var(--primary); color: var(--primary); }
.pagination-wrap .page-numbers.current { background: var(--primary); color: #fff; border-color: var(--primary); }
.empty-state { text-align: center; padding: 48px 0; color: var(--text-light); }
/* ========== SEARCH RESULTS PAGE ========== */
.form-input { font-family: var(--font); }
@media (max-width: 768px) {
  .blog-layout { grid-template-columns: 1fr; }
  .blog-grid { grid-template-columns: 1fr; }
}

/* ========== SINGLE / PAGE ========== */
.single-thumb { margin-bottom: 16px; border-radius: var(--radius-lg); overflow: hidden; }
.single-thumb img { width: 100%; height: auto; }
.single-title { font-size: 32px; font-weight: 900; margin-bottom: 16px; }
.single-meta { font-size: 13px; color: var(--text-light); margin-bottom: 24px; }
.single-meta span { margin: 0 2px; }
.entry-content { font-size: 16px; line-height: 1.8; }
.entry-content p { margin-bottom: 16px; }
.entry-content img { max-width: 100%; height: auto; border-radius: var(--radius); margin: 16px 0; }
.page-links { margin-top: 24px; font-size: 14px; font-weight: 600; }
.post-navigation { margin-top: 32px; display: flex; justify-content: space-between; gap: 16px; }
.post-navigation .nav-label { font-size: 12px; color: var(--text-light); }
.post-navigation .nav-title { font-weight: 700; font-size: 14px; }

/* ========== 404 ========== */
.error-404-num { font-size: 96px; font-weight: 900; color: var(--primary); margin-bottom: 8px; line-height: 1; }
.error-404-title { font-size: 28px; font-weight: 800; margin-bottom: 12px; }
.error-404-desc { font-size: 15px; color: var(--text-light); margin-bottom: 24px; max-width: 500px; margin-left: auto; margin-right: auto; }

/* ========== SEARCH FORM ========== */
.fib-search-form { display: flex; gap: 8px; }
.fib-search-input {
  flex: 1; padding: 10px 16px; border: 1.5px solid var(--border);
  border-radius: 10px; font-size: 14px; font-family: var(--font);
  background: var(--card); color: var(--text); transition: var(--transition);
}
.fib-search-input:focus { border-color: var(--primary); outline: none; box-shadow: 0 0 0 3px var(--primary-bg); }
.fib-search-btn {
  padding: 10px 20px; border: none; border-radius: 10px;
  background: var(--primary); color: #fff; font-size: 14px;
  font-weight: 700; font-family: var(--font); cursor: pointer;
  transition: var(--transition);
}
.fib-search-btn:hover { transform: translateY(-1px); box-shadow: 0 6px 16px rgba(var(--primary-rgb), 0.3); }

/* ========== PRINT & REDUCED MOTION ========== */
@media print {
  .main-header, .main-footer, .fib-sticky-buy, .fib-checkout-sticky, .back-to-top { display: none !important; }
  body { background: #fff !important; color: #000 !important; }
}
/* ========== ORDER SUMMARY (collapsible) ========== */
.fib-order-item {
  display: flex; align-items: center; gap: 12px;
}
.fib-order-item-img {
  width: 60px; height: 60px; flex-shrink: 0; border-radius: 8px;
  overflow: hidden; background: var(--bg-alt);
}
.fib-order-item-info { flex: 1; min-width: 0; }
.fib-order-item-name {
  font-size: 14px; font-weight: 600; color: var(--text);
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.fib-order-item-price { font-size: 13px; color: var(--text-light); margin-top: 2px; }
.fib-order-qty {
  display: flex; align-items: center; gap: 0; flex-shrink: 0;
  border: 1px solid var(--border); border-radius: 8px; overflow: hidden;
}
.fib-qty-btn {
  width: 34px; height: 34px; border: none; background: var(--bg-alt);
  color: var(--text); font-size: 16px; cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  font-family: var(--font); transition: var(--transition);
}
.fib-qty-btn:hover { background: var(--primary); color: #fff; }
.fib-qty-input {
  width: 40px; height: 34px; border: none; border-left: 1px solid var(--border);
  border-right: 1px solid var(--border); text-align: center; font-size: 14px;
  font-weight: 700; background: var(--card); color: var(--text);
  font-family: var(--font); -moz-appearance: textfield;
}
.fib-qty-input::-webkit-inner-spin-button,
.fib-qty-input::-webkit-outer-spin-button { -webkit-appearance: none; margin: 0; }
.fib-order-divider {
  height: 1px; background: var(--border); margin: 12px 0;
}
.fib-order-row {
  display: flex; justify-content: space-between; align-items: center;
  font-size: 14px; color: var(--text); padding: 4px 0;
}
.fib-order-total { font-size: 16px; font-weight: 800; color: var(--primary); padding-top: 4px; }

/* ========== CHECKOUT REFINEMENTS ========== */
.fib-checkout-card {
  background: var(--card); border: 1px solid var(--border);
  border-radius: var(--radius); padding: 24px; margin-bottom: 16px;
  box-shadow: var(--shadow-sm);
}
.fib-checkout-card-title {
  font-size: 18px; font-weight: 800; margin-bottom: 20px;
  padding-bottom: 12px; border-bottom: 1px solid var(--border);
  display: flex; align-items: center; gap: 10px;
}
.fib-checkout-card-title svg { flex-shrink: 0; }

/* Payment method cards */
.fib-payment-card {
  display: flex; align-items: center; gap: 12px;
  padding: 14px 16px; border: 1.5px solid var(--border);
  border-radius: var(--radius); cursor: pointer; transition: var(--transition);
}
.fib-payment-card:has(input:checked) {
  border-color: var(--primary); background: var(--primary-bg);
}
.fib-payment-card input[type="radio"] { accent-color: var(--primary); }
.fib-pay-icon { font-size: 24px; flex-shrink: 0; }

/* Payment info (bank details) */
.fib-payment-info {
  margin-top: 12px; padding: 16px;
  background: var(--bg-alt); border: 1px solid var(--border);
  border-radius: var(--radius); display: none;
}
.fib-payment-info.visible { display: block; }

/* Upload area */
.fib-upload-area {
  border: 2px dashed var(--border); border-radius: var(--radius);
  padding: 20px; text-align: center; cursor: pointer;
  transition: var(--transition); background: var(--card);
}
.fib-upload-area:hover { border-color: var(--primary); background: var(--primary-bg); }

/* Order review table */
#order_review .shop_table { border: none; margin: 0; }
#order_review .shop_table thead { display: none; }
#order_review .shop_table td,
#order_review .shop_table th { border: none; padding: 10px 0; font-size: 14px; }
#order_review .shop_table tr.cart_item td { border-bottom: 1px solid var(--border); }
#order_review .shop_table .product-total { text-align: left; direction: ltr; }
#order_review .shop_table tr.order-total td,
#order_review .shop_table tr.order-total th {
  font-size: 16px; font-weight: 800; color: var(--primary);
  border-top: 2px solid var(--border); padding-top: 14px;
}
#order_review .shop_table tr.cart-subtotal td,
#order_review .shop_table tr.cart-subtotal th { font-size: 14px; }
#order_review .shop_table tr.shipping td { font-size: 13px; }
#order_review .shop_table .amount { direction: ltr; font-weight: 700; }

/* Delivery info grid (right column) */
.fib-info-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.fib-info-card {
  padding: 16px; background: var(--bg-alt); border: 1px solid var(--border);
  border-radius: var(--radius); text-align: center;
}
.fib-info-card .fib-info-icon { font-size: 24px; margin-bottom: 6px; display: block; }
.fib-info-card h4 { font-size: 13px; font-weight: 800; margin: 0 0 2px; }
.fib-info-card p { font-size: 11px; color: var(--text-light); margin: 0; }

/* ========== PRODUCT GRID (archive) ========== */
.fib-product-grid {
  display: grid; grid-template-columns: repeat(var(--fib-columns, 4), 1fr);
  gap: 20px; padding: 0; margin: 0; list-style: none;
}
@media (max-width: 1024px) { .fib-product-grid { grid-template-columns: repeat(3, 1fr); } }
@media (max-width: 768px) { .fib-product-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 480px) { .fib-product-grid { grid-template-columns: repeat(2, 1fr); gap: 12px; } }

/* ========== COLUMN CHOOSER ========== */
.fib-column-bar {
  display: flex; align-items: center; gap: 6px;
  padding: 8px 0; margin-top: -8px;
}
.fib-column-bar-label { font-size: 12px; color: var(--text-light); font-weight: 600; margin-left: 4px; }
.fib-column-btn {
  width: 32px; height: 32px; border-radius: 8px;
  border: 1.5px solid var(--border); background: var(--card);
  color: var(--text-light); cursor: pointer; display: flex;
  align-items: center; justify-content: center; font-size: 12px;
  font-weight: 700; font-family: var(--font); transition: var(--transition);
  line-height: 1;
}
.fib-column-btn:hover { border-color: var(--primary); color: var(--primary); }
.fib-column-btn.active {
  background: var(--primary); border-color: var(--primary); color: #fff;
}

/* ========== PRODUCT CARD REFINEMENTS ========== */
.btn-quick-order {
  display: inline-flex; align-items: center; justify-content: center; gap: 4px;
  padding: 0 12px; height: 34px; border-radius: var(--radius);
  background: var(--primary); color: #fff; border: none; cursor: pointer;
  font-size: 11px; font-weight: 700; font-family: var(--font);
  transition: var(--transition); text-decoration: none; line-height: 1;
}
.btn-quick-order:hover { background: var(--primary-dark); transform: translateY(-1px); }

/* Responsive checkout refinements */
@media (max-width: 767px) {
  .fib-info-grid { grid-template-columns: 1fr 1fr; gap: 8px; }
  .fib-info-card { padding: 12px; }
  .fib-checkout-card { padding: 16px; }
}

@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after { transition-duration: 0.01ms !important; animation-duration: 0.01ms !important; scroll-behavior: auto !important; }
}

/* ========== PRODUCT ATTRIBUTE SWATCHES (Ecomus-style) ========== */
.product-attributes {
  display: flex; flex-wrap: wrap; gap: 4px; margin: 6px 0 2px;
}
.product-attributes .attr-label {
  font-weight: 600; color: var(--text-light);
  min-width: 28px; height: 26px; padding: 0 8px;
  display: flex; align-items: center; justify-content: center;
  border: 1px solid var(--border); border-radius: 4px;
  cursor: pointer; transition: var(--transition); background: var(--card);
  font-family: var(--font); font-size: 10px; position: relative;
}
.product-attributes .attr-label:hover { border-color: var(--primary); color: var(--primary); }
.product-attributes .attr-label.active { background: var(--text); color: #fff; border-color: var(--text); }
.product-attributes .attr-label.fib-cswatch {
  width: 26px; height: 26px; padding: 2px; border-radius: 50%;
  background: transparent !important;
}
.product-attributes .attr-label.fib-cswatch.active {
  border-color: var(--text); box-shadow: 0 0 0 2px var(--card), 0 0 0 3px var(--text);
}

/* ========== QUICK ATTRIBUTE SELECTOR MODAL ========== */
.attr-modal-overlay {
  position: fixed; inset: 0; background: rgba(0,0,0,0.5);
  z-index: 500; opacity: 0; visibility: hidden; transition: var(--transition);
}
.attr-modal-overlay.open { opacity: 1; visibility: visible; }
.attr-modal {
  position: fixed; top: 50%; left: 50%; transform: translate(-50%,-50%) scale(0.9);
  width: 360px; max-width: 90vw; max-height: 85vh; overflow-y: auto;
  background: var(--card); border-radius: var(--radius-lg);
  z-index: 501; opacity: 0; visibility: hidden;
  transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
  box-shadow: var(--shadow-lg);
}
.attr-modal.open { opacity: 1; visibility: visible; transform: translate(-50%,-50%) scale(1); }
.attr-modal-header {
  display: flex; align-items: center; justify-content: space-between;
  padding: 16px 20px; border-bottom: 1px solid var(--border);
}
.attr-modal-header h3 { font-size: 16px; font-weight: 800; margin: 0; }
.attr-modal-close {
  width: 32px; height: 32px; border-radius: 8px; border: none;
  background: var(--bg-alt); cursor: pointer; display: flex;
  align-items: center; justify-content: center; transition: var(--transition);
}
.attr-modal-close:hover { background: var(--primary-bg); }
.attr-modal-body { padding: 20px; }
.attr-modal-body .product-attributes { gap: 6px; }
.attr-modal-body .product-attributes .attr-label {
  min-width: 36px; height: 34px; font-size: 12px; padding: 0 12px;
}
.attr-modal-body .attr-label.fib-cswatch {
  width: 34px; height: 34px; padding: 3px;
}
.attr-modal-body .fib-cswatch-dot {
  width: 26px; height: 26px;
}
.attr-modal-footer {
  padding: 16px 20px; border-top: 1px solid var(--border);
  display: flex; gap: 8px;
}
.attr-modal-add-cart {
  flex: 1; padding: 12px; border: none; border-radius: var(--radius);
  background: var(--primary); color: #fff; font-size: 14px; font-weight: 700;
  font-family: var(--font); cursor: pointer; transition: var(--transition);
}
.attr-modal-add-cart:hover { background: var(--primary-dark); }
.attr-modal-add-cart:disabled { opacity: 0.5; cursor: not-allowed; }
.attr-modal-price {
  display: block; text-align: center; font-size: 18px; font-weight: 800;
  color: var(--primary); margin-bottom: 12px; direction: ltr;
}

/* ========== EXPRESS ORDER FORM ON PRODUCT PAGE ========== */
.fib-express-order {
  padding: 16px; border: 2px solid var(--primary);
  border-radius: var(--radius-lg); background: var(--primary-bg);
}
.fib-express-heading {
  display: flex; align-items: center; gap: 8px;
  font-size: 17px; font-weight: 800; color: var(--primary);
  margin-bottom: 12px;
}
.fib-express-body { display: flex; flex-direction: column; gap: 10px; }
.fib-field label {
  display: block; font-size: 13px; font-weight: 700; margin-bottom: 3px;
  color: var(--text);
}
.fib-field input,
.fib-field select,
.fib-field textarea {
  width: 100%; padding: 11px 14px; font-size: 14px; font-family: var(--font);
  border: 2px solid var(--border); border-radius: 10px;
  background: var(--card); color: var(--text); transition: var(--transition);
  box-sizing: border-box;
}
.fib-field input:focus,
.fib-field select:focus,
.fib-field textarea:focus {
  border-color: var(--primary); outline: none;
  box-shadow: 0 0 0 3px var(--primary-bg);
}
.fib-field input::placeholder,
.fib-field textarea::placeholder { color: var(--text-muted); font-size: 13px; }
.fib-field textarea { resize: vertical; min-height: 50px; }
.fib-field-row {
  display: grid; grid-template-columns: 1fr 1fr; gap: 10px;
}
@media (max-width: 480px) {
  .fib-field-row { grid-template-columns: 1fr; }
}

/* Commune search with autocomplete dropdown */
.fib-commune-wrap { position: relative; }
.fib-commune-dropdown {
  display: none; position: absolute; top: 100%; left: 0; right: 0;
  z-index: 100; background: var(--card); border: 1px solid var(--border);
  border-radius: 10px; box-shadow: 0 8px 24px rgba(0,0,0,0.12);
  max-height: 200px; overflow-y: auto; margin-top: 2px;
}
.fib-cm-item {
  padding: 10px 14px; font-size: 14px; cursor: pointer;
  color: var(--text); transition: background 0.15s;
}
.fib-cm-item:hover,
.fib-cm-item.hover { background: var(--primary-bg); color: var(--primary); }
.fib-cm-ascii { font-size: 12px; color: var(--text-light); direction: ltr; display: inline-block; }
.fib-saved-notice,
.fib-addr-notice { background: var(--primary-bg); border: 1px solid var(--primary); border-radius: 10px; padding: 10px 14px; margin-bottom: 14px; font-size: 13px; display: flex; align-items: center; gap: 8px; }
.fib-addr-notice svg { flex-shrink: 0; }
.fib-addr-clear { background: none; border: 0; color: var(--accent); cursor: pointer; font-size: 12px; font-weight: 700; padding: 4px 10px; border-radius: 6px; transition: all 0.15s; white-space: nowrap; }
.fib-addr-clear:hover { background: var(--accent-bg); }
.fib-cm-empty {
  padding: 12px 14px; font-size: 13px; color: var(--text-light);
  text-align: center;
}

/* Delivery method radios */
.fib-delivery-toggle {
  display: flex; gap: 6px; margin: 0;
}
.fib-radio-mini {
  flex: 1; cursor: pointer;
}
.fib-radio-mini input { display: none; }
.fib-radio-mini-label {
  display: flex; align-items: center; justify-content: center; gap: 4px;
  padding: 10px 12px; border: 2px solid var(--border); border-radius: 10px;
  font-size: 13px; font-weight: 600; color: var(--text); transition: var(--transition);
  background: var(--card); text-align: center;
}
.fib-radio-mini input:checked + .fib-radio-mini-label {
  border-color: var(--primary); background: var(--primary-bg); color: var(--primary);
}
.fib-rate-label { font-size: 12px; font-weight: 800; color: var(--primary); margin-inline-start: 4px; }

/* Attributes + Qty group inside express form */
.fib-express-attrs-qty { margin: 2px 0; }
.fib-express-attrs { display: flex; flex-wrap: wrap; gap: 6px; }
.fib-attr-group { margin-bottom: 8px; }
.fib-attr-label {
  display: block; font-size: 13px; font-weight: 700; margin-bottom: 4px;
  color: var(--text);
}
.fib-attr-chip {
  padding: 8px 14px; border: 2px solid var(--border); border-radius: 8px;
  font-size: 13px; font-weight: 600; cursor: pointer; transition: var(--transition);
  background: var(--card); color: var(--text); user-select: none;
}
.fib-attr-chip:hover { border-color: var(--primary); }
.fib-attr-chip.active { border-color: var(--primary); background: var(--primary); color: #fff; }

/* Express quantity inline */
.fib-express-qty {
  display: flex; align-items: center; gap: 6px; margin-top: 4px;
}
.fib-express-qty .fib-qty-input {
  width: 52px; text-align: center; padding: 6px; border: 2px solid var(--border);
  border-radius: 8px; font-size: 15px; font-weight: 700; background: var(--card);
  color: var(--text); font-family: var(--font);
}
.fib-qty-btn {
  width: 30px; height: 30px; border: 2px solid var(--border); border-radius: 8px;
  background: var(--card); color: var(--text); font-size: 16px; font-weight: 700;
  cursor: pointer; display: flex; align-items: center; justify-content: center;
  transition: var(--transition); font-family: var(--font);
}
.fib-qty-btn:hover { border-color: var(--primary); color: var(--primary); }

/* Order summary inside express form */
.fib-express-summary {
  padding: 12px; background: var(--card);
  border: 1px solid var(--border); border-radius: var(--radius);
}
.fib-es-row {
  display: flex; justify-content: space-between; align-items: center;
  padding: 4px 0; font-size: 13px;
}
.fib-es-label { color: var(--text-light); font-weight: 500; }
.fib-es-value { color: var(--text); font-weight: 700; direction: ltr; text-align: right; }
.fib-es-name { direction: rtl; text-align: left; font-weight: 600; font-size: 13px; max-width: 60%; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.fib-es-del { font-size: 13px; color: var(--primary); }
.fib-es-sub .fib-es-value { font-size: 14px; }
.fib-es-total { font-size: 14px; }
.fib-es-total .fib-es-label { font-weight: 700; color: var(--text); }
.fib-es-total .fib-es-value { font-size: 16px; color: var(--primary); }
.fib-es-divider { height: 1px; background: var(--border); margin: 4px 0; }

/* Order button */
.fib-btn-order {
  width: 100%; padding: 14px 20px;
  border: none; border-radius: 12px; background: var(--primary);
  color: #fff; font-size: 16px; font-weight: 800; font-family: var(--font);
  cursor: pointer; transition: var(--transition);
  display: flex; align-items: center; justify-content: center; gap: 8px;
  line-height: 1.2;
}
.fib-btn-order:hover {
  transform: translateY(-1px);
  box-shadow: 0 4px 16px rgba(var(--primary-rgb), 0.3);
}
.fib-btn-order:active { transform: translateY(0); }
.fib-btn-order:disabled { opacity: 0.6; cursor: not-allowed; transform: none; }
.fib-express-note {
  text-align: center; font-size: 12px; color: var(--text-light);
  margin: 6px 0 0 0;
}

/* Large touch-friendly radios for method selection */
.fib-radio-card,
.fib-payment-card {
  padding: 16px 20px; border-radius: var(--radius);
}
.fib-radio-title { font-size: 15px; }
.fib-radio-desc { font-size: 13px; }

/* Bigger checkout inputs for elderly/children */
.fib-checkout .form-row input,
.fib-checkout .form-row textarea,
.fib-checkout .form-row select,
.fib-checkout-card input,
.fib-checkout-card select,
.fib-checkout-card textarea {
  padding: 14px 16px; font-size: 16px; border-radius: 12px;
}

/* Accessible placeholder contrast */
input::placeholder, textarea::placeholder { color: var(--text-muted); opacity: 1; }

/* ========== OFF-CANVAS MOBILE SIDEBAR ========== */
@media (max-width: 768px) {
  .mobile-menu {
    position: fixed; top: 0; left: auto; right: 0; bottom: 0;
    width: 280px; max-width: 80vw; padding: 20px; z-index: 301;
    border-bottom: none; box-shadow: -4px 0 24px rgba(0,0,0,0.15);
    display: flex; flex-direction: column; gap: 4px;
    transform: translateX(100%); transition: transform 0.3s cubic-bezier(0.4, 0, 0.2, 1);
    animation: none;
    background: var(--card);
    max-height: 100vh;
  }
  body.menu-open .mobile-menu { display: flex; }
  .mobile-menu.open { transform: translateX(0); }
  .mobile-menu-links a,
  .mobile-menu-link { font-size: 15px; padding: 14px 16px; }
  .mobile-cta-link { margin-top: auto; }
  .mobile-menu-actions { grid-template-columns: repeat(2, 1fr); gap: 5px; }
  .mm-action { padding: 10px 4px; }

  /* Overlay for mobile menu */
  .mobile-menu-overlay {
    position: fixed; inset: 0; background: rgba(0,0,0,0.4);
    z-index: 300; opacity: 0; visibility: hidden; transition: var(--transition);
  }
  body.menu-open .mobile-menu-overlay { opacity: 1; visibility: visible; }
}

/* ========== CHECKOUT PAGE (Professional redesign) ========== */
.fib-co-layout {
  display: grid; grid-template-columns: 1fr 380px; gap: 24px;
  align-items: start; max-width: 1100px; margin: 0 auto; padding: 0 16px;
}
@media (max-width: 900px) { .fib-co-layout { grid-template-columns: 1fr; } }

/* Single-column checkout (express form style) */
.fib-co-stack {
  max-width: 720px; margin: 0 auto; padding: 0 16px;
  display: flex; flex-direction: column; gap: 16px;
}

.fib-co-card {
  background: var(--card); border-radius: var(--radius-lg);
  border: 1px solid var(--border); overflow: visible;
  box-shadow: 0 1px 3px rgba(0,0,0,0.04);
}
.fib-co-card-head {
  display: flex; align-items: center; gap: 8px;
  padding: 14px 20px; border-bottom: 1px solid var(--border);
  font-size: 15px; font-weight: 700; color: var(--text);
}
.fib-co-card-head svg { flex-shrink: 0; color: var(--primary); }
.fib-co-card-body { padding: 20px; }
.fib-co-card-body:last-child { padding-bottom: 20px; }

.fib-co-row { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
@media (max-width: 500px) { .fib-co-row { grid-template-columns: 1fr; } }

.fib-co-field { margin-bottom: 14px; }
.fib-co-field:last-child { margin-bottom: 0; }
.fib-co-field label {
  display: block; font-size: 13px; font-weight: 600; color: var(--text);
  margin-bottom: 5px;
}
.fib-co-field label span { color: var(--accent); }
.fib-co-field input,
.fib-co-field select,
.fib-co-field textarea {
  width: 100%; padding: 12px 14px; border: 1.5px solid var(--border);
  border-radius: 10px; font-size: 15px; font-family: var(--font);
  background: var(--bg); color: var(--text); transition: var(--transition);
}
.fib-co-field input:focus,
.fib-co-field select:focus,
.fib-co-field textarea:focus {
  border-color: var(--primary); outline: none; box-shadow: 0 0 0 3px var(--primary-bg);
}
.fib-co-field textarea { resize: vertical; min-height: 60px; }

/* Commune search */
.fib-co-commune-wrap { position: relative; }
.fib-co-commune-dd {
  position: absolute; top: 100%; left: 0; right: 0; z-index: 50;
  background: var(--card); border: 1px solid var(--border);
  border-radius: 10px; box-shadow: var(--shadow-lg);
  max-height: 220px; overflow-y: auto; display: none; margin-top: 4px;
}
.fib-co-cm-item {
  padding: 10px 14px; cursor: pointer; font-size: 14px;
  transition: background 0.12s;
}
.fib-co-cm-item:hover,
.fib-co-cm-item.hover { background: var(--primary-bg); }
.fib-co-cm-empty { padding: 14px; text-align: center; font-size: 13px; color: var(--text-light); }

/* Delivery / Payment radios */
.fib-co-delivery,
.fib-co-pay { display: flex; flex-direction: column; gap: 10px; }
.fib-co-radio {
  display: flex; align-items: center; gap: 12px;
  padding: 14px 16px; border: 1.5px solid var(--border);
  border-radius: 12px; cursor: pointer; transition: var(--transition);
}
.fib-co-radio:hover { border-color: var(--primary); }
.fib-co-radio input[type="radio"] { accent-color: var(--primary); width: auto; flex-shrink: 0; }
.fib-co-radio-content { flex: 1; min-width: 0; }
.fib-co-radio-title { display: block; font-size: 14px; font-weight: 700; color: var(--text); }
.fib-co-radio-sub { font-size: 12px; color: var(--text-light); margin-top: 2px; }
.fib-co-radio-rate {
  font-size: 14px; font-weight: 800; color: var(--primary);
  white-space: nowrap; direction: ltr;
}
.fib-co-radio-icon { font-size: 22px; flex-shrink: 0; }
.fib-co-ship-cost {
  margin-left: auto; font-size: 14px; font-weight: 800; color: var(--primary);
  direction: ltr; background: var(--primary-bg); padding: 4px 12px;
  border-radius: 20px;
}

/* Payment info */
.fib-co-pay { display: flex; flex-direction: column; gap: 10px; }

/* Summary items (compact card style) */
.fib-co-summary { padding: 0; }
.fib-co-items { display: flex; flex-direction: column; gap: 10px; margin-bottom: 16px; }
.fib-co-item {
  display: flex; gap: 12px; align-items: center;
  padding: 12px; background: var(--bg-alt); border-radius: 10px;
}
.fib-co-item-thumb { flex-shrink: 0; }
.fib-co-item-thumb img { width: 48px; height: 48px; border-radius: 8px; object-fit: cover; }
.fib-co-item-body { flex: 1; min-width: 0; }
.fib-co-item-name { font-size: 13px; font-weight: 600; margin-bottom: 4px; }
.fib-co-item-name a { color: var(--text); text-decoration: none; }
.fib-co-item-name a:hover { color: var(--primary); }
.fib-co-item-name .variation { font-size: 12px; color: var(--text-light); font-weight: 400; display: inline; }
.fib-co-item-name .variation dt, .fib-co-item-name .variation dd { display: inline; margin: 0; }
.fib-co-item-meta { display: flex; align-items: center; gap: 8px; }
.fib-co-item-qty {
  font-size: 12px; color: var(--text-light); background: var(--bg);
  padding: 1px 8px; border-radius: 4px; font-weight: 600;
}
.fib-co-item-price { font-size: 13px; font-weight: 700; direction: ltr; }

/* Totals (compact) */
.fib-co-totals { border-top: 1px solid var(--border); padding-top: 12px; }
.fib-co-total-row {
  display: flex; justify-content: space-between; align-items: center;
  padding: 5px 0; font-size: 14px;
}
.fib-co-total-label { color: var(--text-light); font-weight: 600; }
.fib-co-total-value { font-weight: 700; direction: ltr; }
.fib-co-total-discount .fib-co-total-value { color: var(--accent); }
.fib-co-total-ship .fib-co-total-label { color: var(--text); font-weight: 700; }
.fib-co-total-ship .fib-co-total-value { color: var(--primary); font-weight: 800; }
.fib-co-total-final { padding: 8px 0 0; margin-top: 4px; border-top: 2px solid var(--border); }
.fib-co-total-final .fib-co-total-label { color: var(--text); font-size: 15px; font-weight: 800; }
.fib-co-total-final .fib-co-total-value { color: var(--primary); font-size: 18px; }

/* Coupon */
.fib-co-coupon { padding: 16px; border-top: 1px solid var(--border); }
.fib-co-coupon-row { display: flex; gap: 8px; }
.fib-co-coupon-row input {
  flex: 1; height: 40px; padding: 0 12px; border: 1px solid var(--border);
  border-radius: 8px; font-size: 14px; font-family: var(--font); outline: none;
  background: var(--bg); color: var(--text);
}
.fib-co-coupon-row input:focus { border-color: var(--primary); }
.fib-co-coupon-btn {
  height: 40px; padding: 0 16px; border: none; border-radius: 8px;
  background: var(--primary); color: #fff; font-weight: 700; font-size: 13px;
  cursor: pointer; transition: var(--transition); white-space: nowrap;
  font-family: var(--font);
}
.fib-co-coupon-btn:hover { opacity: 0.85; }
.fib-co-coupon-btn:disabled { opacity: 0.5; cursor: default; }
.fib-co-coupon-msg { margin-top: 8px; font-size: 13px; font-weight: 600; }

/* Submit button */
.fib-co-stack .fib-co-submit { margin-top: 0; }
.fib-co-submit {
  display: flex; align-items: center; justify-content: center; gap: 8px;
  width: 100%; max-width: 720px; margin: 0 auto; padding: 14px 20px;
  background: var(--primary); color: #fff; border: none;
  border-radius: 12px; font-size: 16px; font-weight: 800;
  cursor: pointer; font-family: var(--font); transition: var(--transition);
}
.fib-co-submit:hover { background: var(--primary-dark); transform: translateY(-1px); box-shadow: 0 6px 20px rgba(var(--primary-rgb), 0.25); }

/* Checkout info cards (below payment) */
.fib-co-info { display: flex; flex-direction: column; gap: 8px; }
.fib-co-info-item {
  display: flex; align-items: center; gap: 10px;
  padding: 10px 14px; background: var(--bg-alt); border-radius: 10px;
}
.fib-co-info-item svg { flex-shrink: 0; }
.fib-co-info-text { display: flex; flex-direction: column; gap: 1px; }
.fib-co-info-text strong { font-size: 13px; font-weight: 700; }
.fib-co-info-text span { font-size: 11px; color: var(--text-light); }

/* Mobile checkout responsiveness */
@media (max-width: 500px) {
  .fib-co-stack { padding: 0 12px; }
  .fib-co-card-body { padding: 14px; }
  .fib-co-card-head { padding: 12px 14px; font-size: 14px; }
  .fib-co-bank-grid { grid-template-columns: 1fr; }
}

/* Mobile sticky */
.fib-co-sticky {
  display: none; position: fixed; bottom: 0; left: 0; right: 0;
  background: var(--card); border-top: 1px solid var(--border);
  padding: 12px 16px; z-index: 100; box-shadow: 0 -4px 20px rgba(0,0,0,0.08);
}
.fib-co-sticky-inner { display: flex; align-items: center; gap: 12px; max-width: 1100px; margin: 0 auto; }
.fib-co-sticky-info { flex: 1; }
.fib-co-sticky-label { font-size: 12px; color: var(--text-light); display: block; }
.fib-co-sticky-total { font-size: 18px; font-weight: 800; color: var(--primary); }
.fib-co-sticky-btn {
  padding: 12px 24px; background: var(--primary); color: #fff; border: none;
  border-radius: 10px; font-size: 15px; font-weight: 700; cursor: pointer;
  font-family: var(--font); transition: var(--transition);
}
.fib-co-sticky-btn:hover { background: var(--primary-dark); }
@media (max-width: 768px) { .fib-co-sticky { display: block; } .fib-co-submit { display: none; } }

/* Notice */
.fibco-notice {
  display: flex; align-items: center; gap: 10px;
  padding: 12px 16px; margin-bottom: 20px;
  background: var(--primary-bg); border: 1px solid var(--primary);
  border-radius: 12px; font-size: 14px; font-weight: 600;
}
.fibco-notice svg { flex-shrink: 0; }

/* Error */
.fibco-error { border-color: var(--accent) !important; }
.fibco-phone-error {
  display: block; color: var(--accent); font-size: 12px;
  margin-top: 4px;
}

/* ========== SHIPPING ADDRESS MODAL ========== */
.ship-modal-overlay {
  position: fixed; inset: 0; background: rgba(0,0,0,0.5);
  z-index: 600; opacity: 0; visibility: hidden; transition: var(--transition);
}
.ship-modal-overlay.open { opacity: 1; visibility: visible; }
.ship-modal {
  position: fixed; top: 50%; left: 50%; transform: translate(-50%,-50%) scale(0.9);
  width: 420px; max-width: 92vw; max-height: 90vh; overflow-y: auto;
  background: var(--card); border-radius: var(--radius-lg);
  z-index: 601; opacity: 0; visibility: hidden;
  transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
  box-shadow: var(--shadow-lg);
}
.ship-modal.open { opacity: 1; visibility: visible; transform: translate(-50%,-50%) scale(1); }
.ship-modal-header {
  display: flex; align-items: center; justify-content: space-between;
  padding: 16px 20px; border-bottom: 1px solid var(--border);
}
.ship-modal-header h3 { font-size: 16px; font-weight: 800; margin: 0; }
.ship-modal-close {
  width: 32px; height: 32px; border-radius: 8px; border: none;
  background: var(--bg-alt); cursor: pointer; display: flex;
  align-items: center; justify-content: center; transition: var(--transition);
}
.ship-modal-close:hover { background: var(--primary-bg); }
.ship-modal-body { padding: 20px; }
.ship-field { margin-bottom: 14px; }
.ship-field label {
  font-size: 13px; font-weight: 600; color: var(--text);
  display: block; margin-bottom: 4px;
}
.ship-field input,
.ship-field select,
.ship-field textarea {
  width: 100%; padding: 10px 12px; border: 1.5px solid var(--border);
  border-radius: 8px; font-size: 14px; background: var(--card);
  color: var(--text); font-family: var(--font); transition: var(--transition);
}
.ship-field input:focus,
.ship-field select:focus,
.ship-field textarea:focus {
  border-color: var(--primary); outline: none; box-shadow: 0 0 0 3px var(--primary-bg);
}
.ship-delivery-type {
  display: flex; gap: 12px;
}
.ship-radio {
  flex: 1; display: flex; align-items: center; gap: 6px;
  padding: 10px 14px; border: 1.5px solid var(--border);
  border-radius: var(--radius); cursor: pointer; transition: var(--transition);
}
.ship-radio:hover { border-color: var(--primary); }
.ship-radio input[type="radio"] { accent-color: var(--primary); width: auto; }
.ship-radio span { font-size: 13px; font-weight: 600; }
.ship-rate {
  font-size: 12px; font-weight: 700; color: var(--primary);
  display: block; margin-top: 2px;
}
.ship-cost-display {
  display: flex; align-items: center; gap: 8px; padding: 10px 14px;
  margin-top: 8px; background: var(--primary-bg); border-radius: var(--radius);
  border: 1px solid var(--primary); font-size: 14px; font-weight: 600; color: var(--text);
}
.ship-cost-display span:last-child { font-weight: 800; color: var(--primary); }
.ship-modal-footer {
  padding: 16px 20px; border-top: 1px solid var(--border);
}
.ship-btn-save {
  width: 100%; padding: 12px; border: none; border-radius: var(--radius);
  background: var(--primary); color: #fff; font-size: 15px; font-weight: 700;
  font-family: var(--font); cursor: pointer; transition: var(--transition);
}
.ship-btn-save:hover { background: var(--primary-dark); }

/* ─── Loading Screen ─── */
#fibLoadingOverlay {
  position: fixed; inset: 0; z-index: 999999;
  background: var(--bg); display: flex; align-items: center;
  justify-content: center; transition: opacity 0.5s ease, visibility 0.5s ease;
}
#fibLoadingOverlay.fib-hidden {
  opacity: 0; visibility: hidden; pointer-events: none;
}
.fib-loader-inner {
  text-align: center;
}
.fib-loader-svg {
  width: 220px; height: auto;
}
.fib-loader-text {
  stroke-dasharray: 400; stroke-dashoffset: 400;
  animation: fibDrawText 2s ease forwards;
}
@keyframes fibDrawText {
  0% { stroke-dashoffset: 400; }
  80% { stroke-dashoffset: 0; fill: transparent; }
  100% { stroke-dashoffset: 0; fill: url(#lg1); }
}
.fib-loader-dots {
  margin-top: 24px; display: flex; align-items: center;
  justify-content: center; gap: 8px;
}
.fib-loader-dots span {
  width: 8px; height: 8px; border-radius: 50%; background: var(--primary);
  animation: fibBounce 0.6s ease infinite alternate;
}
.fib-loader-dots span:nth-child(2) { animation-delay: 0.2s; }
.fib-loader-dots span:nth-child(3) { animation-delay: 0.4s; }
@keyframes fibBounce {
  0% { transform: translateY(0); opacity: 0.3; }
  100% { transform: translateY(-12px); opacity: 1; }
}

html { scroll-padding-top: 100px; }

/* ========== THANK YOU PAGE ========== */
.fib-thankyou-wrap {
  max-width: 680px; margin: 0 auto; padding: 80px 16px 48px; text-align: center;
  min-height: calc(100vh - 68px);
  box-sizing: border-box;
}
.fib-thankyou-card {
  background: var(--card); border: 1px solid var(--border);
  border-radius: var(--radius-lg); padding: 40px 24px;
  box-shadow: 0 8px 32px rgba(0,0,0,0.06);
}
.fib-thankyou-icon { margin-bottom: 16px; }
.fib-thankyou-title {
  font-size: 28px; font-weight: 900; color: var(--text);
  margin: 0 0 8px;
}
.fib-thankyou-sub { font-size: 16px; color: var(--text); margin: 0 0 8px; }
.fib-thankyou-msg {
  font-size: 15px; color: var(--text-light);
  background: var(--primary-bg); padding: 12px 16px;
  border-radius: 12px; margin: 16px 0;
}
.fib-thankyou-details {
  text-align: right; margin: 24px 0;
  border-top: 1px solid var(--border); padding-top: 16px;
}
.fib-thankyou-row {
  display: flex; justify-content: space-between; align-items: center;
  padding: 8px 0; font-size: 14px;
}
.fib-thankyou-label { color: var(--text-light); font-weight: 500; }
.fib-thankyou-value { color: var(--text); font-weight: 700; }
.fib-status-pending { color: var(--primary); }
.fib-thankyou-footer-msg { font-size: 13px; color: var(--text-light); margin-top: 20px; }
.fib-thankyou-related { margin-top: 48px; text-align: center; }
.fib-related-heading { font-size: 20px; font-weight: 800; color: var(--text); margin-bottom: 24px; }

/* Thank you products table */
.fib-ty-table-wrap { overflow-x: auto; margin: 20px 0; text-align: start; }
.fib-ty-table { width: 100%; border-collapse: collapse; font-size: 13px; }
.fib-ty-table thead { background: var(--bg-alt); }
.fib-ty-table th {
  padding: 10px 12px; font-size: 11px; font-weight: 800; text-transform: uppercase;
  letter-spacing: 0.3px; color: var(--text-light); border-bottom: 1px solid var(--border);
  text-align: center;
}
.fib-ty-table td {
  padding: 12px; border-bottom: 1px solid var(--border); vertical-align: middle;
  text-align: center;
}
.fib-ty-table tbody tr:last-child td { border-bottom: none; }
.fib-ty-th-prod { text-align: start; }
.fib-ty-td-prod { display: flex; align-items: center; gap: 10px; text-align: start; }
.fib-ty-thumb { flex-shrink: 0; }
.fib-ty-thumb img { width: 48px; height: 48px; border-radius: 6px; object-fit: cover; }
.fib-ty-name { font-weight: 700; color: var(--text); font-size: 13px; }
.fib-ty-td-attr { font-size: 12px; color: var(--text-light); }
.fib-ty-td-qty { font-weight: 800; }
.fib-ty-td-price,
.fib-ty-td-total { font-weight: 700; direction: ltr; }
.fib-ty-totals { border-top: 1px solid var(--border); padding-top: 12px; margin-top: 4px; }
.fib-ty-total-row {
  display: flex; justify-content: space-between; align-items: center;
  padding: 6px 0; font-size: 14px;
}
.fib-ty-total-label { color: var(--text-light); font-weight: 500; }
.fib-ty-total-value { font-weight: 700; direction: ltr; }
.fib-ty-total-final { border-top: 2px solid var(--border); padding-top: 10px; margin-top: 4px; }
.fib-ty-total-final .fib-ty-total-label { color: var(--text); font-size: 16px; font-weight: 800; }
.fib-ty-total-final .fib-ty-total-value { color: var(--primary); font-size: 18px; font-weight: 900; }
@media (max-width: 600px) {
  .fib-ty-table thead { display: none; }
  .fib-ty-table tr { display: flex; flex-wrap: wrap; padding: 12px; gap: 6px; align-items: center; border-bottom: 1px solid var(--border); }
  .fib-ty-table td { display: flex; align-items: center; gap: 6px; padding: 2px 0; border: none; width: 100%; }
  .fib-ty-table td::before { content: attr(data-label); font-size: 11px; font-weight: 600; color: var(--text-light); white-space: nowrap; min-width: 50px; }
  .fib-ty-td-prod { order: 0; width: 100%; }
  .fib-ty-td-attr { order: 1; font-size: 12px; }
  .fib-ty-td-qty { order: 2; }
  .fib-ty-td-price { order: 3; }
  .fib-ty-td-total { order: 4; }
}

@media (max-width: 480px) {
  .fib-thankyou-card { padding: 24px 16px; }
  .fib-thankyou-title { font-size: 22px; }
}

/* ========== SINGLE PRODUCT TABS & REVIEWS ========== */
.fib-single-tabs {
  max-width: 1100px; margin: 48px auto 0; padding: 0 16px;
}
.fib-single-tabs .woocommerce-tabs { border: 1px solid var(--border); border-radius: var(--radius-lg); overflow: hidden; background: var(--card); }
.fib-single-tabs .wc-tabs {
  display: flex; list-style: none; margin: 0; padding: 0;
  border-bottom: 1px solid var(--border); background: var(--bg-alt);
}
.fib-single-tabs .wc-tabs li { margin: 0; }
.fib-single-tabs .wc-tabs li a {
  display: block; padding: 14px 24px; font-size: 14px; font-weight: 700;
  color: var(--text-light); text-decoration: none; border-bottom: 2px solid transparent;
  transition: var(--transition);
}
.fib-single-tabs .wc-tabs li.active a,
.fib-single-tabs .wc-tabs li a:hover { color: var(--primary); border-bottom-color: var(--primary); }
.fib-single-tabs .wc-tabs li.active a { background: var(--card); }
.fib-single-tabs .panel { padding: 24px; }
.fib-single-tabs .panel h2 { font-size: 20px; font-weight: 800; margin: 0 0 16px; }
.fib-single-tabs #reviews .commentlist { list-style: none; margin: 0; padding: 0; }

/* ===== Reviews Wrap ===== */
.fib-reviews-wrap { display: flex; flex-direction: column; gap: 28px; }

/* ===== Rating Summary Card ===== */
.fib-rs-card {
  display: flex; gap: 32px; padding: 24px;
  background: var(--card); border: 1px solid var(--border);
  border-radius: var(--radius); align-items: center;
}
.fib-rs-overview { text-align: center; flex-shrink: 0; min-width: 100px; }
.fib-rs-big { font-size: 42px; font-weight: 900; color: var(--text); line-height: 1; }
.fib-rs-stars { display: flex; gap: 3px; justify-content: center; margin: 6px 0 4px; direction: ltr; }
.fib-rs-count { font-size: 13px; color: var(--text-light); font-weight: 600; }
.fib-rs-bars { flex: 1; display: flex; flex-direction: column; gap: 5px; }
.fib-rs-bar-row { display: flex; align-items: center; gap: 8px; }
.fib-rs-bar-label { font-size: 13px; font-weight: 700; color: var(--text); min-width: 14px; text-align: center; }
.fib-rs-bar-track { flex: 1; height: 8px; background: var(--bg-alt); border-radius: 99px; overflow: hidden; }
.fib-rs-bar-fill { display: block; height: 100%; background: #f59e0b; border-radius: 99px; transition: width 0.3s; }
.fib-rs-bar-count { font-size: 12px; color: var(--text-light); min-width: 20px; text-align: left; }

/* ===== Review Cards ===== */
.fib-commentlist { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 16px; }
.fib-review-card { list-style: none; }
.fib-review-inner {
  display: flex; gap: 14px; padding: 18px;
  background: var(--card); border: 1px solid var(--border);
  border-radius: var(--radius); transition: box-shadow 0.2s;
}
.fib-review-inner:hover { box-shadow: 0 2px 8px rgba(0,0,0,0.04); }
.fib-review-avatar { flex-shrink: 0; }
.fib-review-avatar-img { width: 48px; height: 48px; border-radius: 50%; object-fit: cover; }
.fib-review-body { flex: 1; min-width: 0; }
.fib-review-meta { display: flex; align-items: center; gap: 10px; flex-wrap: wrap; margin-bottom: 4px; }
.fib-review-author { font-size: 14px; font-weight: 700; color: var(--text); }
.fib-review-date { font-size: 12px; color: var(--text-light); }
.fib-review-star-row { display: flex; gap: 2px; direction: ltr; margin-bottom: 6px; }
.fib-review-text { font-size: 14px; color: var(--text); line-height: 1.7; }
.fib-reviews-empty {
  text-align: center; padding: 40px 20px; color: var(--text-light);
}
.fib-reviews-empty p { margin: 12px 0 0; font-size: 15px; }

/* ===== Review Form ===== */
.fib-review-form-wrap {
  background: var(--card); border: 1px solid var(--border);
  border-radius: var(--radius); padding: 24px;
}
.fib-review-form-title {
  font-size: 18px; font-weight: 800; color: var(--text);
  margin: 0 0 20px; padding-bottom: 14px;
  border-bottom: 2px solid var(--border);
}
.fib-review-form-inner { display: flex; flex-direction: column; gap: 16px; }
.fib-rf-row { display: flex; gap: 14px; }
.fib-rf-field { flex: 1; }
.fib-rf-field-full { flex: none; width: 100%; }
.fib-rf-field label {
  display: block; font-size: 13px; font-weight: 700; color: var(--text);
  margin-bottom: 6px;
}
.fib-rf-field label .required { color: #dc2626; }
.fib-rf-field input[type="text"],
.fib-rf-field input[type="email"],
.fib-rf-field textarea {
  width: 100%; padding: 12px 16px; border: 1.5px solid var(--border);
  border-radius: 10px; font-family: var(--font); font-size: 14px;
  background: var(--bg); color: var(--text); transition: border-color 0.2s;
}
.fib-rf-field input:focus,
.fib-rf-field textarea:focus { border-color: var(--primary); outline: none; }
.fib-rf-field textarea { resize: vertical; }

/* Star Selector */
.fib-rf-star-select { display: flex; flex-direction: row-reverse; justify-content: flex-end; gap: 4px; direction: ltr; }
.fib-rf-star-select input { display: none; }
.fib-rf-star-select label { cursor: pointer; padding: 2px; margin: 0; transition: transform 0.15s; }
.fib-rf-star-select label svg { display: block; transition: fill 0.15s, stroke 0.15s; }
/* Checked state */
.fib-rf-star-select input:checked + label svg,
.fib-rf-star-select input:checked + label ~ label svg { fill: #f59e0b; stroke: #f59e0b; }
/* Hover state */
.fib-rf-star-select label:hover svg,
.fib-rf-star-select label:hover ~ label svg { fill: #f59e0b; stroke: #f59e0b; }
.fib-rf-star-select label:hover { transform: scale(1.15); }

/* Submit */
.fib-rf-submit { margin-top: 4px; }
.fib-rf-btn {
  padding: 14px 32px; background: var(--primary); color: #fff; border: none;
  border-radius: 10px; font-weight: 700; cursor: pointer; font-family: var(--font);
  font-size: 14px; transition: background 0.2s, transform 0.15s;
}
.fib-rf-btn:hover { background: var(--primary-dark); transform: translateY(-1px); }
.fib-rf-btn:active { transform: translateY(0); }
.fib-rf-must-login { text-align: center; padding: 16px; background: var(--bg-alt); border-radius: 10px; }
.fib-rf-must-login p { margin: 0; font-size: 14px; }
.fib-rf-must-login a { color: var(--primary); font-weight: 700; }

/* Reviews Pagination */
.fib-reviews-pagination { display: flex; justify-content: center; margin-top: 12px; }
.fib-reviews-pagination .page-numbers { display: flex; gap: 6px; list-style: none; margin: 0; padding: 0; }
.fib-reviews-pagination .page-numbers li a,
.fib-reviews-pagination .page-numbers li span {
  display: flex; align-items: center; justify-content: center;
  min-width: 34px; height: 34px; border-radius: 8px;
  font-size: 13px; font-weight: 600; text-decoration: none;
  background: var(--bg-alt); color: var(--text); border: 1px solid var(--border);
}
.fib-reviews-pagination .page-numbers li span.current {
  background: var(--primary); color: #fff; border-color: var(--primary);
}
.fib-reviews-pagination .page-numbers li a:hover { border-color: var(--primary); }

/* Responsive */
@media (max-width: 600px) {
  .fib-rs-card { flex-direction: column; gap: 16px; }
  .fib-rf-row { flex-direction: column; gap: 0; }
  .fib-review-inner { flex-direction: column; align-items: flex-start; }
  .fib-review-avatar { align-self: flex-start; }
}

/* Custom Add to Cart (single product) */
.fib-custom-atc {
  display: flex; align-items: center; gap: 10px;
  margin: 16px 0;
}
.fib-custom-atc-qty {
  display: flex; align-items: center; gap: 0;
  border: 1px solid var(--border); border-radius: 10px; overflow: hidden;
  flex-shrink: 0;
}
.fib-custom-atc-qty .fib-atc-qty-btn {
  width: 36px; height: 40px; border: none; background: var(--bg-alt);
  color: var(--text); font-size: 18px; cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  font-family: var(--font); transition: var(--transition);
}
.fib-custom-atc-qty .fib-atc-qty-btn:hover { background: var(--primary); color: #fff; }
.fib-custom-atc-qty .fib-qty-input {
  width: 44px; height: 40px; border: none; border-left: 1px solid var(--border);
  border-right: 1px solid var(--border); text-align: center; font-size: 15px;
  font-weight: 700; background: var(--card); color: var(--text);
  font-family: var(--font); -moz-appearance: textfield;
}
.fib-custom-atc-qty .fib-qty-input::-webkit-inner-spin-button,
.fib-custom-atc-qty .fib-qty-input::-webkit-outer-spin-button { -webkit-appearance: none; margin: 0; }
.fib-btn-cart {
  flex: 1; padding: 0 20px; height: 42px;
  border: none; border-radius: 10px; background: var(--primary);
  color: #fff; font-size: 15px; font-weight: 800; font-family: var(--font);
  cursor: pointer; transition: var(--transition);
  display: inline-flex; align-items: center; justify-content: center; gap: 8px;
  white-space: nowrap;
}
.fib-btn-cart:hover {
  transform: translateY(-1px);
  box-shadow: 0 4px 16px rgba(var(--primary-rgb), 0.3);
}
.fib-btn-cart:active { transform: translateY(0); }
.fib-btn-cart:disabled { opacity: 0.6; cursor: not-allowed; transform: none; }
