/*
Theme Name: Qurban Theme
Theme URI: https://qurban.com
Author: Qurban Dev Team
Author URI: https://qurban.com
Description: A premium, modern WordPress theme for charitable Qurbani donation platforms. Features elegant design, WooCommerce integration, and immersive user experience.
Version: 3.0.0
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: qurban-theme
Tags: charity, donation, woocommerce, premium, modern, responsive, rtl-support, accessibility-ready
*/

:root {
  --primary: #39B54A;
  --primary-dark: #2d9e3d;
  --primary-darker: #1a7a28;
  --primary-light: #5fd170;
  --primary-lighter: #a8e6b0;
  --primary-bg: #e8f8eb;

  --accent: #D80C72;
  --accent-hover: #b80a61;
  --accent-light: #f04a96;
  --accent-bg: #fde7f2;

  --rose: #e11d48;
  --blue: #3b82f6;
  --cream: #fefcf5;
  --light: #f7f9fc;

  --dark: #0f172a;
  --dark-soft: #1e293b;
  --text: #334155;
  --text-secondary: #64748b;
  --text-tertiary: #94a3b8;
  --border: #e2e8f0;
  --border-light: #f1f5f9;
  --white: #ffffff;

  --shadow-sm: 0 1px 2px rgba(0,0,0,.04);
  --shadow: 0 4px 6px -1px rgba(0,0,0,.06), 0 2px 4px -2px rgba(0,0,0,.04);
  --shadow-lg: 0 10px 15px -3px rgba(0,0,0,.08), 0 4px 6px -4px rgba(0,0,0,.04);
  --shadow-xl: 0 20px 25px -5px rgba(0,0,0,.1), 0 8px 10px -6px rgba(0,0,0,.04);
  --shadow-glow-green: 0 4px 20px rgba(57,181,74,.25);
  --shadow-glow-pink: 0 4px 20px rgba(216,12,114,.25);

  --radius-sm: 8px;
  --radius: 12px;
  --radius-lg: 16px;
  --radius-xl: 24px;
  --radius-full: 9999px;

  --ease: cubic-bezier(.4,0,.2,1);
  --ease-out: cubic-bezier(0,.55,.45,1);
  --ease-bounce: cubic-bezier(.22,1,.36,1);
  --transition: all .2s var(--ease);
  --transition-slow: all .4s var(--ease);

  --container: 1200px;
  --font-body: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  --font-heading: 'Playfair Display', Georgia, 'Times New Roman', serif;
  --header-h: 72px;
}

*,*::before,*::after { box-sizing:border-box; margin:0; padding:0; }
html { scroll-behavior:smooth; -webkit-text-size-adjust:100%; scroll-padding-top:calc(var(--header-h) + 20px); }
body {
  font-family:var(--font-body);
  font-size:16px;
  line-height:1.7;
  color:var(--text);
  background:var(--white);
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
}
::selection { background:var(--primary); color:white; }
img { max-width:100%; height:auto; display:block; }
a { color:var(--primary); text-decoration:none; transition:var(--transition); }
a:hover { color:var(--primary-dark); }
h1,h2,h3,h4,h5,h6 {
  font-family:var(--font-heading);
  font-weight:700;
  line-height:1.25;
  margin-bottom:.75rem;
  color:var(--dark);
}
h1 { font-size:clamp(2rem,4vw,3.2rem); }
h2 { font-size:clamp(1.5rem,3vw,2.2rem); }
h3 { font-size:1.35rem; }
h4 { font-size:1.1rem; }
p { margin-bottom:1rem; color:var(--text-secondary); }
ul,ol { margin-bottom:1rem; padding-left:1.5rem; }

.container,.q-container { width:100%; max-width:var(--container); margin:0 auto; padding:0 1.5rem; }

/* ── Header ── */
.site-header {
  position:fixed; top:0; left:0; width:100%;
  height:var(--header-h);
  background:rgba(255,255,255,.82);
  backdrop-filter:blur(20px) saturate(180%);
  -webkit-backdrop-filter:blur(20px) saturate(180%);
  z-index:1000;
  border-bottom:1px solid rgba(0,0,0,.04);
  transition:var(--transition);
}
.site-header.scrolled { box-shadow:0 1px 24px rgba(0,0,0,.06); }
.header-inner {
  display:flex; justify-content:space-between; align-items:center;
  height:var(--header-h);
}
.site-logo {
  display:flex; align-items:center; gap:.75rem;
  font-family:var(--font-heading);
  font-size:1.35rem; font-weight:700;
  color:var(--dark); text-decoration:none;
}
.site-logo:hover { color:var(--dark); }
.logo-icon {
  width:40px; height:40px;
  background:linear-gradient(135deg, var(--primary), var(--primary-light));
  border-radius:10px;
  display:flex; align-items:center; justify-content:center;
  color:white; font-weight:800; font-size:1.1rem;
  box-shadow:0 4px 12px rgba(57,181,74,.25);
}

.main-navigation ul {
  display:flex; list-style:none; gap:2rem; margin:0; padding:0;
}
.main-navigation a {
  color:var(--dark); font-weight:500; font-size:.9rem;
  padding:.4rem 0; position:relative; opacity:.75;
}
.main-navigation a::after {
  content:''; position:absolute; bottom:-2px; left:0;
  width:0; height:2px; background:var(--accent);
  border-radius:2px; transition:var(--transition);
}
.main-navigation a:hover { opacity:1; }
.main-navigation a:hover::after { width:100%; }
.main-navigation .current-menu-item a { opacity:1; color:var(--accent); }

.header-actions { display:flex; align-items:center; gap:.75rem; }
.cart-link {
  position:relative; color:var(--dark); font-size:1.15rem;
  padding:.5rem; border-radius:8px; transition:var(--transition);
}
.cart-link:hover { background:var(--light); color:var(--accent); }
.cart-count {
  position:absolute; top:0; right:0;
  min-width:18px; height:18px;
  background:var(--accent); color:white;
  font-size:.65rem; font-weight:700;
  border-radius:10px;
  display:flex; align-items:center; justify-content:center;
  padding:0 4px; line-height:1;
  box-shadow:0 2px 6px rgba(216,12,114,.3);
}

.menu-toggle {
  display:none; background:none; border:none;
  font-size:1.4rem; cursor:pointer; color:var(--dark);
  padding:.5rem; border-radius:8px; transition:var(--transition);
}
.menu-toggle:hover { background:var(--light); }

.mobile-overlay {
  display:none; position:fixed; inset:0;
  background:rgba(0,0,0,.4); backdrop-filter:blur(4px);
  z-index:998; opacity:0; transition:opacity .3s ease;
}
.mobile-overlay.active { display:block; opacity:1; }

/* ── Hero ── */
.hero {
  padding:calc(var(--header-h) + 40px) 0 0;
  background:linear-gradient(160deg, #0a4515 0%, #1d7a2e 35%, #2d9e3d 65%, #166d24 100%);
  color:white; position:relative; overflow:hidden; min-height:85vh;
  display:flex; align-items:center;
}
.hero::before {
  content:''; position:absolute; inset:0;
  background:
    radial-gradient(ellipse 600px 400px at 10% 30%, rgba(216,12,114,.08) 0%, transparent 70%),
    radial-gradient(ellipse 500px 500px at 85% 70%, rgba(57,181,74,.1) 0%, transparent 70%),
    radial-gradient(ellipse 300px 300px at 60% 20%, rgba(255,255,255,.04) 0%, transparent 70%);
  pointer-events:none;
}
.hero::after {
  content:''; position:absolute; bottom:0; left:0; width:100%;
  height:100px;
  background:linear-gradient(to top, var(--white), transparent);
  pointer-events:none; z-index:2;
}
.hero-inner {
  display:grid; grid-template-columns:1.1fr .9fr;
  gap:3rem; align-items:center; position:relative; z-index:2;
  width:100%;
}
.hero-content { position:relative; z-index:2; text-align:left; }
.hero h1 {
  font-size:clamp(2.4rem,5.5vw,4rem); font-weight:800;
  margin-bottom:1.2rem; line-height:1.08; color:white;
  letter-spacing:-.02em;
}
.hero p {
  font-size:1.15rem; margin-bottom:2.5rem; opacity:.85;
  max-width:520px; color:rgba(255,255,255,.9);
  line-height:1.7;
}
.hero-cta { display:flex; gap:1rem; flex-wrap:wrap; justify-content:flex-start; }

.trust-badges {
  display:flex; gap:1rem; margin-top:2.5rem;
  flex-wrap:wrap; font-size:.8rem;
}
.trust-badge {
  display:flex; align-items:center; gap:.5rem;
  background:rgba(255,255,255,.07);
  backdrop-filter:blur(12px);
  padding:.45rem 1.1rem; border-radius:50px;
  border:1px solid rgba(255,255,255,.1);
  transition:all .3s ease;
}
.trust-badge:hover { background:rgba(255,255,255,.12); transform:translateY(-1px); }

/* ── Hero Visual Panel ── */
.hero-visual {
  position:relative; z-index:2;
  display:flex; align-items:center; justify-content:center;
  min-height:400px;
}
.hero-visual-inner {
  position:relative; width:100%; max-width:450px;
  aspect-ratio:1;
}
.hero-card {
  background:rgba(255,255,255,.06);
  backdrop-filter:blur(16px);
  border-radius:24px;
  border:1px solid rgba(255,255,255,.1);
  padding:2rem;
  position:relative;
  box-shadow:0 25px 50px -12px rgba(0,0,0,.25);
}
.hero-card-header {
  display:flex; align-items:center; gap:.75rem;
  padding-bottom:1.25rem;
  border-bottom:1px solid rgba(255,255,255,.08);
  margin-bottom:1.25rem;
}
.hero-card-avatar {
  width:40px; height:40px; border-radius:50%;
  background:rgba(57,181,74,.3);
  display:flex; align-items:center; justify-content:center;
  font-size:1.1rem;
}
.hero-card-info { flex:1; }
.hero-card-info strong { display:block; font-size:.9rem; }
.hero-card-info span { font-size:.75rem; opacity:.6; }
.hero-card-amount { font-size:1.3rem; font-weight:700; color:var(--primary-light); }
.hero-card-item {
  display:flex; align-items:center; gap:.75rem;
  padding:.75rem 0;
  border-bottom:1px solid rgba(255,255,255,.05);
}
.hero-card-item:last-child { border-bottom:none; }
.hero-card-dot {
  width:8px; height:8px; border-radius:50%;
  flex-shrink:0;
}
.hero-card-dot.green { background:#39B54A; }
.hero-card-dot.pink { background:#D80C72; }
.hero-card-dot.blue { background:#3b82f6; }
.hero-card-label { flex:1; font-size:.82rem; opacity:.8; }
.hero-card-value { font-size:.82rem; font-weight:600; }

/* floating decorative rings */
.hero-ring {
  position:absolute; border-radius:50%;
  border:1px solid rgba(255,255,255,.06);
  pointer-events:none;
}
.hero-ring:nth-child(1) { width:520px; height:520px; top:-80px; right:-100px; }
.hero-ring:nth-child(2) { width:380px; height:380px; top:-40px; right:-60px; }
.hero-ring:nth-child(3) { width:650px; height:650px; top:-120px; right:-150px; border-color:rgba(57,181,74,.04); }

.hero-stats-mini {
  display:grid; grid-template-columns:repeat(3,1fr);
  gap:.75rem; margin-top:1.5rem;
}
.hero-stat-mini {
  text-align:center; padding:.75rem .5rem;
  border-radius:12px;
  background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.06);
}
.hero-stat-mini strong { display:block; font-size:1.2rem; color:var(--primary-light); }
.hero-stat-mini span { font-size:.7rem; opacity:.6; }

/* ── Buttons ── */
.btn {
  display:inline-flex; align-items:center; justify-content:center; gap:.5rem;
  padding:.85rem 2rem;
  background:var(--primary); color:white; border:none;
  border-radius:var(--radius-full); font-weight:600; font-size:.95rem;
  cursor:pointer; transition:all .3s var(--ease-bounce);
  text-decoration:none;
  box-shadow:0 4px 14px rgba(57,181,74,.3);
  white-space:nowrap; font-family:inherit;
}
.btn:hover {
  background:var(--primary-dark); color:white;
  transform:translateY(-3px);
  box-shadow:0 8px 25px rgba(57,181,74,.35);
}
.btn:active { transform:translateY(-1px); }
.btn-accent {
  background:linear-gradient(135deg, var(--accent), var(--accent-hover));
  box-shadow:0 4px 14px rgba(216,12,114,.35);
}
.btn-accent:hover {
  background:linear-gradient(135deg, var(--accent-hover), var(--accent));
  box-shadow:0 8px 25px rgba(216,12,114,.4);
}
.btn-outline {
  background:transparent; border:2px solid rgba(255,255,255,.5);
  color:white; box-shadow:none;
}
.btn-outline:hover { background:white; color:var(--primary); border-color:white; transform:translateY(-3px); }
.btn-outline-dark {
  background:transparent; border:2px solid var(--border);
  color:var(--text); box-shadow:none;
}
.btn-outline-dark:hover { border-color:var(--primary); color:var(--primary); background:var(--primary-bg); transform:translateY(-3px); }
.btn-sm { padding:.6rem 1.4rem; font-size:.85rem; }
.btn-lg { padding:1rem 2.5rem; font-size:1.05rem; }

/* ── Sections ── */
.section { padding:5rem 0; }
.section-bg { background:var(--light); }
.section-bg-alt { background:var(--cream); }
.section-dark { background:var(--dark); color:white; }
.section-title { font-size:clamp(1.6rem,3vw,2.2rem); font-weight:700; margin-bottom:.75rem; color:var(--dark); }
.section-subtitle { font-size:1.05rem; color:var(--text-secondary); max-width:600px; margin:0 auto 3rem; }
.text-center { text-align:center; }

/* ── Impact Dashboard ── */
.dashboard {
  background:linear-gradient(165deg, #0f5a1c 0%, var(--primary) 50%, var(--primary-dark) 100%);
  color:white; border-radius:var(--radius-xl);
  padding:3.5rem 2rem; margin:3rem 0; text-align:center;
  position:relative; overflow:hidden;
  box-shadow:0 20px 60px rgba(57,181,74,.2);
}
.dashboard::before {
  content:''; position:absolute; inset:0;
  background:
    radial-gradient(circle at 20% 30%, rgba(216,12,114,.08) 0%, transparent 50%),
    radial-gradient(circle at 80% 70%, rgba(57,181,74,.08) 0%, transparent 50%);
  pointer-events:none;
}
.dashboard h2 { color:white; font-size:1.8rem; margin-bottom:.5rem; font-family:var(--font-heading); }
.dashboard > p { color:rgba(255,255,255,.8); margin-bottom:2rem; }
.stats-grid { display:grid; grid-template-columns:repeat(auto-fit, minmax(150px,1fr)); gap:2rem; margin-top:2rem; position:relative; z-index:2; }
.stat-item { padding:1rem; }
.stat-value {
  font-size:clamp(2rem,4vw,3rem); font-weight:800; display:block;
  margin-bottom:.3rem;
  background:linear-gradient(135deg, var(--accent-light), white);
  -webkit-background-clip:text; -webkit-text-fill-color:transparent;
  background-clip:text; line-height:1.2;
}
.stat-label { opacity:.85; font-size:.9rem; letter-spacing:.02em; }

/* ── Category Tabs ── */
.category-tabs {
  display:flex; justify-content:center; flex-wrap:wrap;
  gap:.5rem; margin:2rem 0 3rem;
}
.tab-btn {
  padding:.75rem 1.5rem;
  border:2px solid var(--border); border-radius:var(--radius-full);
  background:var(--white); font-weight:600;
  color:var(--text-secondary); cursor:pointer;
  transition:all .3s var(--ease); font-size:.9rem;
  display:inline-flex; align-items:center; gap:.5rem;
  font-family:inherit;
}
.tab-btn:hover { border-color:var(--primary); color:var(--primary); background:var(--primary-bg); }
.tab-btn.active {
  background:var(--primary); border-color:var(--primary); color:white;
  box-shadow:0 4px 14px rgba(57,181,74,.3);
}

/* ── Product Grid ── */
.products-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:1.5rem; margin-top:2rem; }
.product-card {
  background:var(--white); border-radius:var(--radius-lg);
  overflow:hidden; transition:all .4s var(--ease-bounce);
  display:flex; flex-direction:column; position:relative;
  border:1px solid var(--border-light);
  box-shadow:var(--shadow-sm);
}
.product-card:hover { transform:translateY(-8px); box-shadow:var(--shadow-xl); }
.product-card.hidden { display:none; }
.product-image {
  height:200px;
  background:linear-gradient(135deg, var(--primary-bg), var(--primary-lighter));
  display:flex; align-items:center; justify-content:center;
  font-size:3rem; position:relative; overflow:hidden; color:var(--primary);
}
.product-card[data-category="aqeeqa"] .product-image { background:linear-gradient(135deg,#eff6ff,#bfdbfe); color:var(--blue); }
.product-card[data-category="nadir"] .product-image { background:linear-gradient(135deg,#fff7ed,#fed7aa); color:#ea580c; }
.product-card[data-category="sadaqa"] .product-image { background:linear-gradient(135deg,var(--accent-bg),#fbcfe8); color:var(--accent); }
.product-badge {
  position:absolute; top:1rem; right:1rem;
  background:linear-gradient(135deg, var(--accent), var(--accent-hover));
  color:white; padding:.3rem .9rem; border-radius:var(--radius-full);
  font-size:.7rem; font-weight:700; text-transform:uppercase;
  letter-spacing:.03em; z-index:2;
  box-shadow:0 2px 8px rgba(216,12,114,.3);
}
.product-badge.urgent { background:linear-gradient(135deg,#f43f5e,var(--rose)); box-shadow:0 2px 8px rgba(225,29,72,.3); }
.product-badge.premium { background:linear-gradient(135deg,#f59e0b,#d97706); box-shadow:0 2px 8px rgba(245,158,11,.3); }
.product-content { padding:1.5rem; flex-grow:1; display:flex; flex-direction:column; }
.product-title { font-family:var(--font-heading); font-size:1.2rem; font-weight:700; margin-bottom:.4rem; color:var(--dark); }
.product-id {
  font-size:.75rem; color:var(--text-secondary); font-weight:500;
  background:var(--light); padding:.15rem .6rem; border-radius:4px;
  display:inline-block; margin-bottom:.8rem; font-family:monospace;
}
.product-desc { color:var(--text-secondary); font-size:.9rem; margin:.5rem 0; flex-grow:1; line-height:1.55; }
.product-countries {
  font-size:.8rem; color:var(--text-secondary); margin:.8rem 0;
  padding:.8rem 1rem; background:var(--light);
  border-radius:8px; border-left:3px solid var(--primary);
  line-height:1.5;
}
.product-meta {
  display:flex; justify-content:space-between; align-items:center;
  margin:1rem 0; padding-top:1rem; border-top:1px solid var(--border);
}
.product-price { font-size:1.5rem; font-weight:800; color:var(--primary); letter-spacing:-.02em; }
.product-actions { display:flex; gap:.5rem; }
.btn-add { flex:1; padding:.8rem; font-size:.85rem; border-radius:10px; justify-content:center; }
.btn-quick {
  width:42px; height:42px; border-radius:10px;
  display:flex; align-items:center; justify-content:center;
  background:var(--light); border:1px solid var(--border);
  color:var(--text-secondary); cursor:pointer;
  transition:var(--transition); flex-shrink:0;
}
.btn-quick:hover { background:var(--primary); color:white; border-color:var(--primary); }

/* ── Testimonials ── */
.testimonials { background:var(--light); }
.testimonial-grid { display:grid; grid-template-columns:repeat(auto-fit, minmax(300px,1fr)); gap:1.8rem; margin-top:2rem; }
.testimonial-card {
  background:var(--white); padding:2rem; border-radius:var(--radius-lg);
  position:relative; border:1px solid var(--border-light);
  transition:all .4s var(--ease-bounce);
  box-shadow:var(--shadow-sm);
}
.testimonial-card:hover { transform:translateY(-4px); box-shadow:var(--shadow-lg); }
.testimonial-card::before {
  content:'\201C'; position:absolute; top:1rem; left:1.5rem;
  font-size:4rem; color:var(--primary-lighter);
  font-family:Georgia,serif; line-height:1; pointer-events:none;
}
.testimonial-content { margin-top:1.5rem; font-style:italic; color:var(--text-secondary); font-size:.95rem; line-height:1.6; position:relative; z-index:1; }
.testimonial-author {
  display:flex; align-items:center; gap:.8rem;
  margin-top:1.2rem; padding-top:1rem; border-top:1px solid var(--border);
}
.author-avatar {
  width:44px; height:44px; border-radius:50%;
  background:linear-gradient(135deg, var(--primary-bg), var(--primary-lighter));
  display:flex; align-items:center; justify-content:center;
  font-weight:700; color:var(--primary); font-size:.9rem;
}
.author-info strong { display:block; color:var(--dark); font-size:.95rem; }
.author-info span { font-size:.8rem; color:var(--text-secondary); }

/* ── FAQ ── */
.faq-list { max-width:750px; margin:0 auto; }
.faq-item {
  background:var(--white); border-radius:var(--radius);
  margin-bottom:.8rem; overflow:hidden;
  border:1px solid var(--border-light);
  transition:var(--transition);
}
.faq-item:hover { box-shadow:var(--shadow); }
.faq-question {
  padding:1.2rem 1.5rem; font-weight:600;
  cursor:pointer; display:flex; justify-content:space-between;
  align-items:center; transition:var(--transition);
  background:none; border:none; width:100%; text-align:left;
  font-size:1rem; color:var(--dark); gap:1rem; font-family:inherit;
}
.faq-question:hover { background:var(--light); }
.faq-answer { display:grid; grid-template-rows:0fr; transition:grid-template-rows .35s var(--ease); }
.faq-answer > div { overflow:hidden; padding:0 1.5rem; }
.faq-answer p { color:var(--text-secondary); font-size:.95rem; margin-bottom:0; padding-bottom:1.5rem; }
.faq-item.active .faq-answer { grid-template-rows:1fr; }
.faq-toggle {
  width:28px; height:28px; border-radius:50%;
  display:flex; align-items:center; justify-content:center;
  transition:var(--transition); flex-shrink:0;
  background:var(--light); color:var(--text-secondary); font-size:.8rem;
}
.faq-item.active .faq-toggle { background:var(--primary); color:white; transform:rotate(45deg); }

/* ── Footer ── */
.site-footer {
  background:var(--dark); color:rgba(255,255,255,.85);
  padding:4.5rem 0 2rem; margin-top:4rem; position:relative;
}
.site-footer::before {
  content:''; position:absolute; top:0; left:0; right:0;
  height:4px;
  background:linear-gradient(90deg, var(--primary), var(--accent), var(--primary));
}
.footer-grid { display:grid; grid-template-columns:2fr 1fr 1fr 1.5fr; gap:2.5rem; margin-bottom:3rem; }
.footer-col h3 { color:white; margin-bottom:1.2rem; font-size:1rem; text-transform:uppercase; letter-spacing:.05em; opacity:.7; }
.footer-col p { color:rgba(255,255,255,.65); font-size:.85rem; }
.footer-links { list-style:none; padding:0; margin:0; }
.footer-links li { margin-bottom:.5rem; }
.footer-links a { color:rgba(255,255,255,.6); font-size:.9rem; transition:var(--transition); display:inline-flex; align-items:center; gap:.3rem; }
.footer-links a:hover { color:var(--accent-light); transform:translateX(4px); }
.social-links { display:flex; gap:.6rem; margin-top:1.2rem; }
.social-links a {
  width:38px; height:38px; border-radius:10px;
  background:rgba(255,255,255,.08);
  display:flex; align-items:center; justify-content:center;
  color:rgba(255,255,255,.7); transition:var(--transition);
  font-size:.9rem;
}
.social-links a:hover { background:var(--accent); color:white; transform:translateY(-3px); }
.footer-bottom { text-align:center; padding-top:2rem; border-top:1px solid rgba(255,255,255,.06); font-size:.8rem; opacity:.5; }
.footer-bottom p { color:rgba(255,255,255,.5); margin:0; }

.newsletter-form { display:flex; gap:.4rem; }
.newsletter-form input[type="email"] {
  flex:1; padding:.7rem 1rem; border:none; border-radius:10px;
  font-size:.85rem; font-family:inherit;
  background:rgba(255,255,255,.08); color:white;
  transition:var(--transition); outline:none;
}
.newsletter-form input[type="email"]:focus { background:rgba(255,255,255,.14); box-shadow:0 0 0 2px var(--primary); }
.newsletter-form input[type="email"]::placeholder { color:rgba(255,255,255,.4); }
.newsletter-form .btn { padding:.7rem 1rem; font-size:.85rem; border-radius:10px; }

/* ── Back to Top ── */
.back-to-top {
  position:fixed; bottom:2rem; right:2rem;
  width:46px; height:46px; border-radius:50%;
  background:linear-gradient(135deg, var(--primary), var(--primary-dark));
  color:white; border:none; cursor:pointer;
  display:flex; align-items:center; justify-content:center;
  font-size:1.1rem;
  box-shadow:0 4px 14px rgba(57,181,74,.35);
  transition:all .3s var(--ease-bounce); z-index:999;
  opacity:0; transform:translateY(20px); pointer-events:none;
}
.back-to-top.visible { opacity:1; transform:translateY(0); pointer-events:auto; }
.back-to-top:hover { transform:translateY(-4px); box-shadow:0 8px 25px rgba(57,181,74,.4); }

/* ── Toast ── */
.toast-container { position:fixed; top:calc(var(--header-h) + 1rem); right:1.5rem; z-index:10000; display:flex; flex-direction:column; gap:.5rem; }
.toast {
  background:var(--white); border-radius:var(--radius);
  padding:1rem 1.2rem; box-shadow:var(--shadow-xl);
  border:1px solid var(--border-light);
  border-left:4px solid var(--primary);
  display:flex; align-items:center; gap:.75rem;
  min-width:280px; max-width:400px;
  animation:toast-in .35s var(--ease);
  font-size:.9rem;
}
.toast.toast-error { border-left-color:var(--accent); }
.toast-icon {
  width:32px; height:32px; border-radius:50%;
  display:flex; align-items:center; justify-content:center;
  flex-shrink:0; background:var(--primary-bg); color:var(--primary);
}
.toast.toast-error .toast-icon { background:#fef2f2; color:var(--accent); }
@keyframes toast-in { from { opacity:0; transform:translateX(40px); } to { opacity:1; transform:translateX(0); } }

/* ── Modal ── */
.modal-overlay { display:none; position:fixed; inset:0; background:rgba(0,0,0,.5); backdrop-filter:blur(8px); z-index:9999; align-items:center; justify-content:center; padding:2rem; }
.modal-overlay.active { display:flex; }
.modal-content { background:var(--white); border-radius:var(--radius-xl); max-width:500px; width:100%; padding:2rem; box-shadow:var(--shadow-xl); position:relative; animation:modal-in .3s var(--ease); }
@keyframes modal-in { from { opacity:0; transform:scale(.95) translateY(10px); } to { opacity:1; transform:scale(1) translateY(0); } }
.modal-close {
  position:absolute; top:1rem; right:1rem;
  width:32px; height:32px; border-radius:50%;
  border:none; background:var(--light); cursor:pointer;
  display:flex; align-items:center; justify-content:center;
  transition:var(--transition); font-size:1rem; color:var(--text-secondary);
}
.modal-close:hover { background:var(--border); color:var(--dark); }
.modal-product-icon { font-size:3.5rem; text-align:center; margin-bottom:1rem; }
.modal-content h3 { font-family:var(--font-heading); font-size:1.4rem; text-align:center; margin-bottom:.5rem; }
.modal-content .product-price { text-align:center; font-size:2rem; margin:1rem 0; }
.modal-content .product-desc { text-align:center; max-width:400px; margin:0 auto 1.5rem; }

/* ── Archive / Blog ── */
.site-main { padding-top:var(--header-h); min-height:60vh; }
.archive-header { padding:2rem 0 1.5rem; margin-bottom:2rem; border-bottom:2px solid var(--border); }
.archive-header h1 { font-family:var(--font-heading); font-size:2rem; margin-bottom:.4rem; }
.archive-header p { color:var(--text-secondary); margin:0; }
.post-card {
  background:var(--white); border-radius:var(--radius-lg);
  overflow:hidden; transition:all .4s var(--ease-bounce);
  margin-bottom:2rem; border:1px solid var(--border-light);
  box-shadow:var(--shadow-sm);
}
.post-card:hover { box-shadow:var(--shadow-xl); transform:translateY(-4px); }
.post-thumbnail { height:250px; overflow:hidden; }
.post-thumbnail img { width:100%; height:100%; object-fit:cover; transition:transform .6s var(--ease); }
.post-card:hover .post-thumbnail img { transform:scale(1.06); }
.post-content { padding:1.5rem; }
.post-meta { display:flex; gap:1rem; font-size:.8rem; color:var(--text-secondary); margin-bottom:.8rem; }
.post-meta a { color:var(--text-secondary); }
.post-meta a:hover { color:var(--primary); }
.post-title { font-family:var(--font-heading); font-size:1.35rem; margin-bottom:.6rem; }
.post-title a { color:var(--dark); }
.post-title a:hover { color:var(--primary); }
.post-excerpt { color:var(--text-secondary); font-size:.9rem; margin-bottom:1rem; }
.read-more { font-weight:600; font-size:.85rem; display:inline-flex; align-items:center; gap:.3rem; }

/* ── Single Post ── */
.single-post .container { max-width:800px; }
.post-header { margin-bottom:2rem; }
.post-header h1 { font-family:var(--font-heading); font-size:clamp(1.5rem,3vw,2.2rem); margin-bottom:.75rem; line-height:1.2; }
.post-body { font-size:1.05rem; line-height:1.8; color:var(--dark); }
.post-body p { margin-bottom:1.5rem; color:var(--dark); }
.post-body h2 { font-family:var(--font-heading); font-size:1.6rem; margin:2.5rem 0 1rem; }
.post-body h3 { font-family:var(--font-heading); font-size:1.25rem; margin:2rem 0 .8rem; }
.post-body img { border-radius:var(--radius); margin:2rem 0; box-shadow:var(--shadow); }
.post-body blockquote {
  border-left:4px solid var(--primary);
  padding:1rem 1.5rem; margin:2rem 0;
  background:var(--light); border-radius:0 var(--radius) var(--radius) 0;
  font-style:italic; color:var(--dark);
}
.post-tags { margin-top:2rem; padding-top:2rem; border-top:1px solid var(--border); }
.post-tags a {
  display:inline-block; background:var(--light);
  padding:.25rem .8rem; border-radius:var(--radius-full);
  font-size:.8rem; margin-right:.4rem; margin-bottom:.4rem;
  transition:var(--transition);
}
.post-tags a:hover { background:var(--primary); color:white; }

/* ── 404 ── */
.error-404 { padding:calc(var(--header-h) + 60px) 0 5rem; text-align:center; min-height:60vh; display:flex; align-items:center; }
.error-404 h1 {
  font-size:clamp(4rem,10vw,8rem);
  background:linear-gradient(135deg, var(--primary), var(--primary-light));
  -webkit-background-clip:text; -webkit-text-fill-color:transparent;
  background-clip:text; margin-bottom:0; line-height:1;
}
.error-404 h2 { font-family:var(--font-heading); font-size:1.5rem; margin-bottom:1rem; }
.error-404 p { color:var(--text-secondary); margin-bottom:2rem; }

/* ── Search ── */
.search-form { display:flex; max-width:500px; margin:2rem auto; gap:.5rem; }
.search-form input[type="search"] {
  flex:1; padding:.8rem 1.2rem;
  border:2px solid var(--border); border-radius:var(--radius-full);
  font-size:1rem; transition:var(--transition);
  font-family:inherit; outline:none;
}
.search-form input[type="search"]:focus { border-color:var(--primary); box-shadow:0 0 0 3px rgba(57,181,74,.1); }
.search-form button { padding:.8rem 1.5rem; background:var(--primary); color:white; border:none; border-radius:var(--radius-full); cursor:pointer; transition:var(--transition); }

/* ── Sidebar ── */
.sidebar { padding-left:3rem; }
.widget { background:var(--white); padding:1.5rem; border-radius:var(--radius); box-shadow:var(--shadow-sm); margin-bottom:2rem; border:1px solid var(--border-light); }
.widget h3 { font-family:var(--font-heading); font-size:1rem; margin-bottom:1rem; padding-bottom:.75rem; border-bottom:2px solid var(--border); }
.widget ul { list-style:none; padding:0; margin:0; }
.widget li { padding:.4rem 0; border-bottom:1px solid var(--border-light); font-size:.9rem; }
.widget li:last-child { border-bottom:none; }
.widget li a { color:var(--text-secondary); }
.widget li a:hover { color:var(--primary); }
.content-area { display:grid; grid-template-columns:1fr 300px; gap:3rem; }

/* ── Pagination ── */
.pagination { display:flex; justify-content:center; gap:.4rem; margin-top:3rem; }
.pagination a,.pagination span { padding:.5rem .9rem; border-radius:8px; font-weight:600; transition:var(--transition); font-size:.9rem; }
.pagination a { background:var(--light); color:var(--dark); }
.pagination a:hover { background:var(--primary); color:white; }
.pagination .current { background:var(--primary); color:white; }

/* ── Comments ── */
.comments-area { margin-top:3rem; padding-top:2rem; border-top:2px solid var(--border); }
.comments-title { font-family:var(--font-heading); font-size:1.3rem; margin-bottom:1.5rem; }
.comment { padding:1.5rem; background:var(--light); border-radius:var(--radius); margin-bottom:1rem; }
.comment-author { font-weight:600; margin-bottom:.3rem; }
.comment-meta { font-size:.8rem; color:var(--text-secondary); margin-bottom:.8rem; }
.comment-content { color:var(--dark); font-size:.9rem; }
.comment-form { margin-top:2rem; }
.comment-form textarea,.comment-form input[type="text"],.comment-form input[type="email"] {
  width:100%; padding:.75rem 1rem;
  border:2px solid var(--border); border-radius:10px;
  margin-bottom:1rem; font-family:inherit; font-size:1rem;
  transition:var(--transition); outline:none;
}
.comment-form textarea:focus,.comment-form input:focus { border-color:var(--primary); box-shadow:0 0 0 3px rgba(57,181,74,.1); }
.comment-form .btn { width:100%; justify-content:center; }

/* ── Scroll Animations ── */
.fade-in { opacity:0; transform:translateY(30px); transition:opacity .6s var(--ease), transform .6s var(--ease); }
.fade-in.visible { opacity:1; transform:translateY(0); }
.fade-in-up { opacity:0; transform:translateY(40px); transition:opacity .7s ease, transform .7s ease; }
.fade-in-up.visible { opacity:1; transform:translateY(0); }
.stagger-1 { transition-delay:.1s; }
.stagger-2 { transition-delay:.2s; }
.stagger-3 { transition-delay:.3s; }
.stagger-4 { transition-delay:.4s; }

/* ── About Page ── */
.page-hero {
  padding:calc(var(--header-h) + 60px) 0 4rem;
  background:linear-gradient(160deg, #0a4515 0%, #1d7a2e 40%, #2d9e3d 70%, #166d24 100%);
  color:white; text-align:center; position:relative; overflow:hidden;
}
.page-hero::before {
  content:''; position:absolute; inset:0;
  background:
    radial-gradient(ellipse 600px 400px at 20% 40%, rgba(216,12,114,.06) 0%, transparent 60%),
    radial-gradient(ellipse 500px 500px at 80% 60%, rgba(57,181,74,.08) 0%, transparent 60%);
  pointer-events:none;
}
.page-hero-inner { position:relative; z-index:2; max-width:650px; margin:0 auto; }
.page-hero-tag {
  display:inline-block;
  background:rgba(255,255,255,.1); backdrop-filter:blur(8px);
  padding:.35rem 1.2rem; border-radius:50px; font-size:.8rem; font-weight:600;
  border:1px solid rgba(255,255,255,.1); margin-bottom:1.5rem;
  letter-spacing:.1em; text-transform:uppercase;
}
.page-hero h1 {
  font-size:clamp(2rem,4.5vw,3.2rem); font-weight:800;
  margin-bottom:1.2rem; line-height:1.1; color:white;
}
.page-hero p { font-size:1.1rem; opacity:.85; max-width:520px; margin:0 auto 2rem; color:rgba(255,255,255,.9); }
.page-hero-cta { display:flex; gap:1rem; justify-content:center; flex-wrap:wrap; }

/* Stats Strip */
.stats-strip { background:var(--white); border-bottom:1px solid var(--border-light); }
.stats-strip-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:1px; background:var(--border-light); }
.stats-strip-item {
  padding:2rem; text-align:center; background:var(--white);
}
.stats-strip-item strong { display:block; font-size:1.8rem; font-weight:800; color:var(--primary); font-family:var(--font-heading); }
.stats-strip-item span { font-size:.85rem; color:var(--text-secondary); font-weight:500; }

/* About Grid */
.about-grid { display:grid; grid-template-columns:1fr 1fr; gap:3rem; align-items:start; }
.about-text p { color:var(--text-secondary); line-height:1.75; margin-bottom:1rem; font-size:.95rem; }
.about-visual { display:flex; flex-direction:column; gap:1rem; }
.about-card {
  background:var(--white); border-radius:var(--radius-lg); padding:1.5rem;
  border:1px solid var(--border-light); box-shadow:var(--shadow-sm);
  display:flex; align-items:flex-start; gap:1rem;
  transition:all .3s var(--ease);
}
.about-card:hover { box-shadow:var(--shadow); transform:translateX(4px); }
.about-card-icon {
  width:48px; height:48px; border-radius:12px;
  background:var(--primary-bg); color:var(--primary);
  display:flex; align-items:center; justify-content:center;
  font-size:1.2rem; flex-shrink:0;
}
.about-card h3 { font-family:var(--font-heading); font-size:1rem; margin-bottom:.25rem; }
.about-card p { font-size:.85rem; color:var(--text-secondary); line-height:1.5; margin:0; }

/* Values */
.values-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:2rem; margin-top:2rem; }
.value-card { background:var(--white); border-radius:var(--radius-lg); padding:2rem; text-align:center; border:1px solid var(--border-light); box-shadow:var(--shadow-sm); transition:all .4s var(--ease-bounce); }
.value-card:hover { transform:translateY(-6px); box-shadow:var(--shadow-xl); }
.value-icon { width:56px; height:56px; border-radius:50%; background:var(--primary-bg); color:var(--primary); display:flex; align-items:center; justify-content:center; font-size:1.3rem; margin:0 auto 1rem; }
.value-card h3 { font-family:var(--font-heading); font-size:1.1rem; margin-bottom:.6rem; }
.value-card p { font-size:.9rem; color:var(--text-secondary); line-height:1.5; }

/* CTA Section */
.cta-section { background:linear-gradient(160deg, #0a4515 0%, #1d7a2e 50%, #166d24 100%); color:white; }
.cta-section .section-title { color:white; }
.cta-section p { color:rgba(255,255,255,.85); }

/* ── Basics Page ── */
.basics-intro { display:grid; grid-template-columns:1.2fr .8fr; gap:3rem; align-items:start; }
.basics-intro-text p { color:var(--text-secondary); line-height:1.75; margin-bottom:1rem; font-size:.95rem; }
.basics-intro-text p:last-child { margin-bottom:0; }
.basics-intro-visual { display:flex; flex-direction:column; gap:1rem; position:sticky; top:calc(var(--header-h) + 2rem); }
.basics-icon-card {
  background:var(--white); border-radius:var(--radius-lg); padding:1.5rem;
  border:1px solid var(--border-light); box-shadow:var(--shadow-sm);
  text-align:center; transition:all .3s var(--ease);
}
.basics-icon-card:hover { box-shadow:var(--shadow); transform:translateY(-3px); }
.basics-icon {
  width:52px; height:52px; border-radius:50%;
  background:var(--primary-bg); color:var(--primary);
  display:flex; align-items:center; justify-content:center;
  font-size:1.3rem; margin:0 auto .75rem;
}
.basics-icon-card h3 { font-family:var(--font-heading); font-size:1rem; margin-bottom:.4rem; }
.basics-icon-card p { font-size:.85rem; color:var(--text-secondary); line-height:1.5; margin:0; }

@media (max-width:900px) {
  .basics-intro { grid-template-columns:1fr; gap:2rem; }
  .basics-intro-visual { position:static; flex-direction:row; flex-wrap:wrap; }
  .basics-icon-card { flex:1; min-width:160px; }
  .service-block { grid-template-columns:1fr; gap:2rem; }
  .service-block-reverse .service-visual { order:-1; }
  .service-visual { flex-direction:row; flex-wrap:wrap; }
  .service-card { flex:1; min-width:160px; }
}

/* ── Services Page ── */
.service-block { display:grid; grid-template-columns:1fr 1fr; gap:3rem; align-items:center; }
.service-block-reverse .service-content { order:1; }
.service-block-reverse .service-visual { order:0; }
.service-content p { color:var(--text-secondary); line-height:1.75; margin-bottom:1rem; font-size:.95rem; }
.service-tag {
  display:inline-block; padding:.25rem 1rem; border-radius:50px;
  font-size:.75rem; font-weight:700; text-transform:uppercase;
  letter-spacing:.08em; margin-bottom:1rem;
}
.service-cta { margin-top:1.5rem; }
.service-visual { display:flex; flex-direction:column; gap:1rem; }
.service-card {
  background:var(--white); border-radius:var(--radius-lg); padding:1.5rem;
  border:1px solid var(--border-light); box-shadow:var(--shadow-sm);
  transition:all .3s var(--ease);
}
.service-card:hover { box-shadow:var(--shadow); transform:translateY(-3px); }
.service-card-icon {
  width:48px; height:48px; border-radius:12px;
  background:var(--primary-bg); color:var(--primary);
  display:flex; align-items:center; justify-content:center;
  font-size:1.2rem; margin-bottom:.75rem;
}
.service-card h3 { font-family:var(--font-heading); font-size:1rem; margin-bottom:.3rem; }
.service-card p { font-size:.85rem; color:var(--text-secondary); line-height:1.5; margin:0; }
.service-card-value { font-size:1.3rem; font-weight:700; color:var(--dark); margin-bottom:.25rem !important; }

@media (max-width:600px) {
  .stats-strip-grid { grid-template-columns:repeat(2,1fr); }
  .stats-strip-item { padding:1.25rem; }
  .stats-strip-item strong { font-size:1.4rem; }
  .page-hero { padding:calc(var(--header-h) + 30px) 0 3rem; }
}

/* ── Partner Logos ── */
.partner-logos { padding:3rem 0; }
.partner-logos-grid { display:grid; grid-template-columns:repeat(auto-fit, minmax(120px,1fr)); gap:1.5rem; align-items:center; margin-top:2rem; }
.partner-logo { display:flex; flex-direction:column; align-items:center; justify-content:center; gap:.5rem; padding:1.5rem 1rem; background:var(--white); border-radius:var(--radius); box-shadow:var(--shadow-sm); border:1px solid var(--border-light); transition:var(--transition); text-decoration:none; }
.partner-logo:hover { box-shadow:var(--shadow); transform:translateY(-3px); }
.partner-logo-fallback { width:56px; height:56px; border-radius:50%; background:var(--primary-bg); color:var(--primary); display:flex; align-items:center; justify-content:center; font-weight:800; font-size:1rem; }
.partner-logo-name { font-size:.8rem; font-weight:600; color:var(--text-secondary); text-align:center; }

/* ── Quote Section ── */
.quote-section { background:var(--cream); position:relative; overflow:hidden; }
.quote-section::before { content:'\201C'; position:absolute; top:-40px; left:50%; transform:translateX(-50%); font-size:16rem; color:var(--primary-lighter); font-family:Georgia,serif; line-height:1; pointer-events:none; opacity:.3; }
.quote-content { position:relative; z-index:2; max-width:800px; margin:0 auto; text-align:center; }
.quote-text { font-size:1.25rem; font-style:italic; color:var(--dark); line-height:1.7; margin-bottom:1.5rem; }
.quote-author { font-weight:700; color:var(--primary); }
.quote-author-title { font-size:.85rem; color:var(--text-secondary); display:block; margin-top:.2rem; }

/* ── Two Column ── */
.two-col-section { display:grid; grid-template-columns:1fr 1fr; gap:3rem; align-items:center; }
.two-col-section .section-title { margin-bottom:1rem; }
.two-col-section p { font-size:.95rem; margin-bottom:1.5rem; }
.two-col-section img { border-radius:var(--radius-lg); box-shadow:var(--shadow-lg); width:100%; height:auto; }

/* ── Responsive ── */
@media (max-width:1024px) {
  .footer-grid { grid-template-columns:1fr 1fr; gap:2rem; }
}
@media (max-width:900px) {
  .menu-toggle { display:flex; }
  .main-navigation {
    position:fixed; top:0; left:-320px; width:300px; height:100vh;
    background:var(--white); padding:1.5rem;
    padding-top:calc(var(--header-h) + 1rem);
    transition:left .35s var(--ease);
    box-shadow:5px 0 30px rgba(0,0,0,.1);
    z-index:999; overflow-y:auto;
  }
  .main-navigation.active { left:0; }
  .mobile-overlay.active { display:block; }
  .main-navigation ul { flex-direction:column; gap:0; }
  .main-navigation li { border-bottom:1px solid var(--border-light); }
  .main-navigation a { display:block; padding:.9rem 0; font-size:1rem; }
  .hero { min-height:auto; padding:calc(var(--header-h) + 30px) 0 0; }
  .hero-inner { grid-template-columns:1fr; gap:2rem; }
  .hero-content { text-align:center; }
  .hero-cta { justify-content:center; }
  .hero h1 { font-size:2.2rem; text-align:center; }
  .hero p { font-size:1rem; margin-left:auto; margin-right:auto; }
  .trust-badges { justify-content:center; }
  .hero-visual { min-height:auto; }
  .hero-visual-inner { max-width:380px; }
  .hero-card { padding:1.25rem; }
  .about-grid { grid-template-columns:1fr; gap:2rem; }
  .values-grid { grid-template-columns:1fr; }
  .stats-strip-grid { grid-template-columns:repeat(2,1fr); }
  .page-hero-tag { font-size:.7rem; }
  .section { padding:3.5rem 0; }
  .section-title { font-size:1.7rem; }
  .products-grid { grid-template-columns:repeat(2,1fr); gap:1rem; }
  .content-area { grid-template-columns:1fr; gap:2rem; }
  .sidebar { padding-left:0; }
  .trust-badges { gap:.8rem; }
  .stats-grid { grid-template-columns:repeat(2,1fr); }
  .stat-value { font-size:2rem; }
  .two-col-section { grid-template-columns:1fr; gap:2rem; }
  .partner-logos-grid { grid-template-columns:repeat(3,1fr); }
}
@media (max-width:600px) {
  :root { --header-h:64px; }
  .hero { padding:calc(var(--header-h) + 30px) 0 0; min-height:auto; }
  .hero-inner { grid-template-columns:1fr; gap:1.5rem; }
  .hero h1 { font-size:1.7rem; text-align:center; }
  .hero p { text-align:center; }
  .hero-cta { flex-direction:column; align-items:center; }
  .hero-visual-inner { max-width:320px; }
  .hero-stat-mini strong { font-size:1rem; }
  .hero-stat-mini span { font-size:.65rem; }
  .btn { width:100%; justify-content:center; }
  .btn-outline { width:auto; }
  .stats-grid { grid-template-columns:1fr 1fr; gap:.8rem; }
  .stat-value { font-size:1.6rem; }
  .footer-grid { grid-template-columns:1fr; gap:2rem; }
  .section-title { font-size:1.4rem; }
  .back-to-top { bottom:1rem; right:1rem; width:40px; height:40px; }
  .modal-content { padding:1.5rem; }
  .dashboard { padding:2rem 1.5rem; border-radius:var(--radius); }
  .partner-logos-grid { grid-template-columns:repeat(2,1fr); }
  .quote-text { font-size:1.05rem; }
}

@media (prefers-reduced-motion:reduce) {
  *,*::before,*::after { animation-duration:.01ms!important; animation-iteration-count:1!important; transition-duration:.01ms!important; }
  html { scroll-behavior:auto; }
}

.skip-link { position:absolute; top:-100%; left:0; background:var(--primary); color:white; padding:8px 16px; z-index:10000; transition:top .3s; border-radius:0 0 8px 0; font-weight:600; }
.skip-link:focus { top:0; }
.screen-reader-text { position:absolute; width:1px; height:1px; padding:0; margin:-1px; overflow:hidden; clip:rect(0,0,0,0); border:0; }
:focus-visible { outline:2px solid var(--primary); outline-offset:2px; }

/* ── WooCommerce Cart ── */
.woocommerce-cart .site-main { padding-top:calc(var(--header-h) + 40px); }
.woocommerce-cart .entry-header { display:none; }
.woocommerce-cart .woocommerce { max-width:1200px; margin:0 auto; padding:0 1.5rem; }
.woocommerce-cart .woocommerce-notices-wrapper { margin-bottom:2rem; }
.woocommerce-cart .woocommerce-message { background:var(--primary-bg); color:var(--primary-dark); border:1px solid var(--primary-lighter); border-radius:var(--radius); padding:1rem 1.2rem; margin-bottom:1rem; font-size:.9rem; display:flex; align-items:center; gap:.6rem; }
.woocommerce-cart .woocommerce-message::before { content:'\f00c'; font-family:'Font Awesome 6 Free'; font-weight:900; color:var(--primary); }
.woocommerce-cart .woocommerce-error { background:#fef2f2; color:var(--accent); border:1px solid #fecaca; border-radius:var(--radius); padding:1rem 1.2rem; margin-bottom:1rem; font-size:.9rem; list-style:none; }
.woocommerce-cart .woocommerce-error li { display:flex; align-items:center; gap:.6rem; }
.woocommerce-cart .woocommerce-error li::before { content:'\f071'; font-family:'Font Awesome 6 Free'; font-weight:900; color:var(--accent); }
.woocommerce-cart .return-to-shop { margin-top:2rem; }
.woocommerce-cart .return-to-shop .button { display:inline-flex; align-items:center; gap:.5rem; padding:.75rem 1.8rem; background:var(--primary); color:white; border-radius:var(--radius-full); font-weight:600; font-size:.9rem; text-decoration:none; transition:all .3s var(--ease-bounce); box-shadow:0 4px 14px rgba(57,181,74,.3); }
.woocommerce-cart .return-to-shop .button:hover { background:var(--primary-dark); transform:translateY(-2px); box-shadow:0 8px 25px rgba(57,181,74,.35); }
.woocommerce-cart .cart-empty { text-align:center; padding:4rem 0; font-size:1.1rem; color:var(--text-secondary); }
.woocommerce-cart .cart-empty::before { content:'\f07a'; font-family:'Font Awesome 6 Free'; font-weight:900; font-size:4rem; display:block; margin-bottom:1.5rem; color:var(--border); }
.woocommerce-cart .wc-proceed-to-checkout { display:flex; justify-content:flex-end; margin-top:2rem; }
.woocommerce-cart .wc-proceed-to-checkout .button { display:inline-flex; align-items:center; gap:.5rem; padding:1rem 2.5rem; background:linear-gradient(135deg, var(--accent), var(--accent-hover)); color:white; border:none; border-radius:var(--radius-full); font-weight:700; font-size:1.05rem; cursor:pointer; transition:all .3s var(--ease-bounce); box-shadow:0 4px 14px rgba(216,12,114,.35); text-decoration:none; }
.woocommerce-cart .wc-proceed-to-checkout .button:hover { transform:translateY(-3px); box-shadow:0 8px 25px rgba(216,12,114,.4); }
.woocommerce-cart .wc-proceed-to-checkout .button:disabled { opacity:.5; cursor:not-allowed; transform:none; }

.woocommerce-cart .cart-collaterals { display:grid; grid-template-columns:1fr 380px; gap:2rem; margin-top:3rem; align-items:start; }
.woocommerce-cart .cart_totals { background:var(--white); border-radius:var(--radius-lg); padding:2rem; border:1px solid var(--border-light); box-shadow:var(--shadow-sm); }
.woocommerce-cart .cart_totals h2 { font-family:var(--font-heading); font-size:1.3rem; margin-bottom:1.5rem; padding-bottom:.75rem; border-bottom:2px solid var(--border); }
.woocommerce-cart .cart_totals table.shop_table { width:100%; border-collapse:collapse; }
.woocommerce-cart .cart_totals table.shop_table th,
.woocommerce-cart .cart_totals table.shop_table td { padding:.8rem 0; border-bottom:1px solid var(--border); font-size:.9rem; }
.woocommerce-cart .cart_totals table.shop_table th { font-weight:600; color:var(--dark); text-align:left; }
.woocommerce-cart .cart_totals table.shop_table td { text-align:right; }
.woocommerce-cart .cart_totals table.shop_table .order-total th,
.woocommerce-cart .cart_totals table.shop_table .order-total td { font-size:1.1rem; font-weight:700; border-bottom:none; padding-top:1.2rem; }
.woocommerce-cart .cart_totals table.shop_table .order-total td { color:var(--primary); font-size:1.3rem; }
.woocommerce-cart .cart_totals .includes_tax { font-size:.8rem; color:var(--text-secondary); }
.woocommerce-cart .cart_totals .shipping-calculator-button { color:var(--primary); font-size:.85rem; text-decoration:underline; }
.woocommerce-cart .cart_totals .shipping-calculator-button:hover { color:var(--primary-dark); }
.woocommerce-cart .cart_totals .woocommerce-shipping-destination { font-size:.85rem; color:var(--text-secondary); margin:.5rem 0; }
.woocommerce-cart .cart_totals .woocommerce-shipping-methods { list-style:none; padding:0; margin:.5rem 0; }
.woocommerce-cart .cart_totals .woocommerce-shipping-methods li { padding:.3rem 0; font-size:.85rem; }
.woocommerce-cart .cart_totals .woocommerce-shipping-methods input { margin-right:.4rem; accent-color:var(--primary); }

.woocommerce-cart .cross-sells { margin-top:3rem; padding-top:2rem; border-top:2px solid var(--border); }
.woocommerce-cart .cross-sells h2 { font-family:var(--font-heading); font-size:1.3rem; margin-bottom:1.5rem; }
.woocommerce-cart .cross-sells .products { display:grid; grid-template-columns:repeat(4,1fr); gap:1.5rem; list-style:none; padding:0; }
.woocommerce-cart .cross-sells .product { background:var(--white); border-radius:var(--radius-lg); overflow:hidden; border:1px solid var(--border-light); box-shadow:var(--shadow-sm); transition:all .4s var(--ease-bounce); }
.woocommerce-cart .cross-sells .product:hover { transform:translateY(-6px); box-shadow:var(--shadow-xl); }
.woocommerce-cart .cross-sells .product a { text-decoration:none; display:block; }
.woocommerce-cart .cross-sells .product .button { margin:1rem; display:block; text-align:center; padding:.8rem; background:var(--primary); color:white; border-radius:10px; font-weight:600; font-size:.85rem; transition:all .3s var(--ease-bounce); box-shadow:0 4px 14px rgba(57,181,74,.3); }
.woocommerce-cart .cross-sells .product .button:hover { background:var(--primary-dark); transform:translateY(-2px); box-shadow:0 8px 25px rgba(57,181,74,.35); }
.woocommerce-cart .cross-sells .product .button.added { display:none; }
.woocommerce-cart .cross-sells .woocommerce-loop-product__title { font-family:var(--font-heading); font-size:1rem; padding:.5rem 1rem 0; margin:0; }
.woocommerce-cart .cross-sells .price { padding:0 1rem 1rem; display:block; font-size:.9rem; color:var(--primary); font-weight:700; }
.woocommerce-cart .cross-sells .star-rating { margin:.5rem 1rem; }

.woocommerce-cart .coupon { display:flex; gap:.5rem; margin-bottom:1.5rem; padding:1.5rem; background:var(--light); border-radius:var(--radius); }
.woocommerce-cart .coupon label { display:none; }
.woocommerce-cart .coupon input[type="text"] { flex:1; padding:.7rem 1rem; border:2px solid var(--border); border-radius:10px; font-size:.85rem; font-family:inherit; outline:none; transition:var(--transition); }
.woocommerce-cart .coupon input[type="text"]:focus { border-color:var(--primary); box-shadow:0 0 0 3px rgba(57,181,74,.1); }
.woocommerce-cart .coupon button { padding:.7rem 1.4rem; background:var(--primary); color:white; border:none; border-radius:10px; font-weight:600; font-size:.85rem; cursor:pointer; transition:all .3s var(--ease-bounce); white-space:nowrap; font-family:inherit; }
.woocommerce-cart .coupon button:hover { background:var(--primary-dark); transform:translateY(-2px); box-shadow:0 4px 14px rgba(57,181,74,.3); }

.woocommerce-cart .shop_table.cart { width:100%; border-collapse:separate; border-spacing:0; background:var(--white); border-radius:var(--radius-lg); overflow:hidden; border:1px solid var(--border-light); box-shadow:var(--shadow-sm); }
.woocommerce-cart .shop_table.cart thead { background:var(--light); }
.woocommerce-cart .shop_table.cart th { padding:1rem 1.2rem; font-size:.8rem; font-weight:600; text-transform:uppercase; letter-spacing:.05em; color:var(--text-secondary); text-align:left; }
.woocommerce-cart .shop_table.cart td { padding:1.2rem; border-top:1px solid var(--border); vertical-align:middle; }
.woocommerce-cart .shop_table.cart .product-thumbnail { width:80px; }
.woocommerce-cart .shop_table.cart .product-thumbnail img { width:64px; height:64px; border-radius:10px; object-fit:cover; border:1px solid var(--border-light); }
.woocommerce-cart .shop_table.cart .product-name { font-weight:600; color:var(--dark); }
.woocommerce-cart .shop_table.cart .product-name a { color:var(--dark); }
.woocommerce-cart .shop_table.cart .product-name a:hover { color:var(--primary); }
.woocommerce-cart .shop_table.cart .product-name .variation { font-size:.8rem; color:var(--text-secondary); font-weight:400; margin-top:.3rem; }
.woocommerce-cart .shop_table.cart .product-name .variation dt { display:inline; font-weight:600; }
.woocommerce-cart .shop_table.cart .product-name .variation dd { display:inline; margin:0 .8rem 0 0; }
.woocommerce-cart .shop_table.cart .product-price { font-weight:600; color:var(--text); }
.woocommerce-cart .shop_table.cart .product-subtotal { font-weight:700; color:var(--primary); }
.woocommerce-cart .shop_table.cart .product-remove { width:40px; text-align:center; }
.woocommerce-cart .shop_table.cart .product-remove a { display:inline-flex; align-items:center; justify-content:center; width:32px; height:32px; border-radius:50%; background:var(--light); color:var(--text-secondary); font-size:1rem; text-decoration:none; transition:all .2s ease; }
.woocommerce-cart .shop_table.cart .product-remove a:hover { background:var(--accent); color:white; transform:scale(1.1); }
.woocommerce-cart .shop_table.cart .quantity { display:inline-flex; align-items:center; border:2px solid var(--border); border-radius:10px; overflow:hidden; }
.woocommerce-cart .shop_table.cart .quantity .qty { width:60px; padding:.5rem; border:none; text-align:center; font-weight:600; font-size:.9rem; font-family:inherit; outline:none; }
.woocommerce-cart .shop_table.cart .quantity .qty::-webkit-inner-spin-button { opacity:1; }
.woocommerce-cart .shop_table.cart .actions { padding:1.2rem; background:var(--light); }
.woocommerce-cart .shop_table.cart .actions .button { padding:.7rem 1.4rem; background:var(--primary); color:white; border:none; border-radius:10px; font-weight:600; font-size:.85rem; cursor:pointer; transition:all .3s var(--ease-bounce); font-family:inherit; }
.woocommerce-cart .shop_table.cart .actions .button:hover { background:var(--primary-dark); transform:translateY(-2px); }

.woocommerce-cart .shop_table.cart .actions .button[name="update_cart"] { background:var(--dark-soft); }
.woocommerce-cart .shop_table.cart .actions .button[name="update_cart"]:hover { background:var(--dark); }

@media (max-width:900px) {
  .woocommerce-cart .cart-collaterals { grid-template-columns:1fr; }
  .woocommerce-cart .cross-sells .products { grid-template-columns:repeat(2,1fr); }
  .woocommerce-cart .shop_table.cart thead { display:none; }
  .woocommerce-cart .shop_table.cart tbody tr { display:block; padding:1rem; border-bottom:1px solid var(--border); }
  .woocommerce-cart .shop_table.cart tbody tr:last-child { border-bottom:none; }
  .woocommerce-cart .shop_table.cart td { display:flex; align-items:center; justify-content:space-between; padding:.5rem 0; border:none; }
  .woocommerce-cart .shop_table.cart td::before { content:attr(data-title); font-size:.8rem; font-weight:600; color:var(--text-secondary); text-transform:uppercase; letter-spacing:.03em; }
  .woocommerce-cart .shop_table.cart .product-thumbnail { justify-content:flex-start; }
  .woocommerce-cart .shop_table.cart .product-thumbnail img { width:48px; height:48px; }
  .woocommerce-cart .shop_table.cart .product-remove { position:absolute; top:.5rem; right:.5rem; }
  .woocommerce-cart .shop_table.cart tbody tr { position:relative; }
  .woocommerce-cart .shop_table.cart .actions { flex-direction:column; gap:.5rem; }
  .woocommerce-cart .shop_table.cart .coupon { flex-direction:column; }
}
@media (max-width:600px) {
  .woocommerce-cart .cross-sells .products { grid-template-columns:1fr; }
  .woocommerce-cart .coupon { flex-direction:column; }
  .woocommerce-cart .wc-proceed-to-checkout .button { width:100%; justify-content:center; }
}

/* ── WooCommerce Checkout ── */
.woocommerce-checkout .site-main { padding-top:calc(var(--header-h) + 40px); }
.woocommerce-checkout .entry-header { display:none; }
.woocommerce-checkout .woocommerce { margin:0 auto; padding:0 1.5rem; }
.woocommerce-checkout .woocommerce-notices-wrapper { margin-bottom:2rem; }
.woocommerce-checkout .woocommerce-info { background:var(--primary-bg); color:var(--primary-dark); border:1px solid var(--primary-lighter); border-radius:var(--radius); padding:1rem 1.2rem; margin-bottom:1rem; font-size:.9rem; display:flex; align-items:center; gap:.6rem; flex-wrap:wrap; }
.woocommerce-checkout .woocommerce-info a { color:var(--primary-dark); font-weight:600; text-decoration:underline; }
.woocommerce-checkout .woocommerce-info a:hover { color:var(--primary); }
.woocommerce-checkout .woocommerce-info::before { content:'\f05a'; font-family:'Font Awesome 6 Free'; font-weight:900; color:var(--primary); }

.woocommerce-checkout .checkout_coupon { background:var(--light); border-radius:var(--radius-lg); padding:1.5rem; margin-bottom:2rem; border:1px solid var(--border-light); display:flex; align-items:center; gap:1rem; flex-wrap:wrap; }
.woocommerce-checkout .checkout_coupon p { margin:0; }
.woocommerce-checkout .checkout_coupon .form-row { margin:0; }
.woocommerce-checkout .checkout_coupon input[type="text"] { padding:.65rem 1rem; border:2px solid var(--border); border-radius:10px; font-size:.85rem; font-family:inherit; outline:none; transition:var(--transition); min-width:200px; }
.woocommerce-checkout .checkout_coupon input[type="text"]:focus { border-color:var(--primary); box-shadow:0 0 0 3px rgba(57,181,74,.1); }
.woocommerce-checkout .checkout_coupon button { padding:.65rem 1.4rem; background:var(--primary); color:white; border:none; border-radius:10px; font-weight:600; font-size:.85rem; cursor:pointer; transition:all .3s var(--ease-bounce); font-family:inherit; }
.woocommerce-checkout .checkout_coupon button:hover { background:var(--primary-dark); transform:translateY(-2px); }

.woocommerce-checkout .woocommerce-checkout { display:grid; grid-template-columns:1fr 440px; gap:2rem; align-items:start; }
.woocommerce-checkout .woocommerce-checkout .col2-set { width:100%; }
.woocommerce-checkout .woocommerce-checkout .col2-set .col-1,
.woocommerce-checkout .woocommerce-checkout .col2-set .col-2 { width:100%; }
.woocommerce-checkout .woocommerce-checkout h3 { font-family:var(--font-heading); font-size:1.2rem; margin-bottom:1.2rem; padding-bottom:.6rem; border-bottom:2px solid var(--border); }
.woocommerce-checkout .woocommerce-checkout #customer_details { background:var(--white); border-radius:var(--radius-lg); padding:2rem; border:1px solid var(--border-light); box-shadow:var(--shadow-sm); }
.woocommerce-checkout .woocommerce-checkout #customer_details .col-1 { margin-bottom:2rem; }

.woocommerce-checkout .form-row { margin-bottom:1rem; }
.woocommerce-checkout .form-row label { display:block; font-weight:600; font-size:.85rem; margin-bottom:.3rem; color:var(--dark); }
.woocommerce-checkout .form-row label .required { color:var(--accent); text-decoration:none; }
.woocommerce-checkout .form-row input[type="text"],
.woocommerce-checkout .form-row input[type="tel"],
.woocommerce-checkout .form-row input[type="email"],
.woocommerce-checkout .form-row select,
.woocommerce-checkout .form-row textarea { width:100%; padding:.7rem 1rem; border:2px solid var(--border); border-radius:10px; font-size:.9rem; font-family:inherit; outline:none; transition:var(--transition); background:var(--white); color:var(--dark); box-sizing:border-box; }
.woocommerce-checkout .form-row input:focus,
.woocommerce-checkout .form-row select:focus,
.woocommerce-checkout .form-row textarea:focus { border-color:var(--primary); box-shadow:0 0 0 3px rgba(57,181,74,.1); }
.woocommerce-checkout .form-row .select2-selection { height:auto; padding:.4rem; border:2px solid var(--border); border-radius:10px; }
.woocommerce-checkout .form-row .select2-selection:focus { border-color:var(--primary); }
.woocommerce-checkout .form-row .select2-selection__rendered { padding-left:.4rem; }
.woocommerce-checkout .form-row .select2-container--focus .select2-selection { border-color:var(--primary); box-shadow:0 0 0 3px rgba(57,181,74,.1); }
.woocommerce-checkout .form-row textarea { min-height:80px; resize:vertical; }
.woocommerce-checkout .form-row .woocommerce-input-wrapper { display:block; }

.woocommerce-checkout .form-row.woocommerce-invalid input,
.woocommerce-checkout .form-row.woocommerce-invalid select,
.woocommerce-checkout .form-row.woocommerce-invalid textarea { border-color:var(--accent); box-shadow:0 0 0 3px rgba(216,12,114,.08); }
.woocommerce-checkout .form-row.woocommerce-validated input,
.woocommerce-checkout .form-row.woocommerce-validated select,
.woocommerce-checkout .form-row.woocommerce-validated textarea { border-color:var(--primary); }

.woocommerce-checkout .form-row .woocommerce-error { background:transparent; border:none; padding:0; margin-top:.4rem; font-size:.8rem; color:var(--accent); }
.woocommerce-checkout .form-row .woocommerce-error li { padding:0; }

.woocommerce-checkout .woocommerce-checkout-review-order { background:var(--white); border-radius:var(--radius-lg); padding:2rem; border:1px solid var(--border-light); box-shadow:var(--shadow-sm); position:sticky; top:calc(var(--header-h) + 2rem); }
.woocommerce-checkout .woocommerce-checkout-review-order table.shop_table { width:100%; border-collapse:collapse; margin-bottom:1.5rem; }
.woocommerce-checkout .woocommerce-checkout-review-order table.shop_table thead th { padding:.8rem 0; font-size:.8rem; font-weight:600; text-transform:uppercase; letter-spacing:.05em; color:var(--text-secondary); border-bottom:2px solid var(--border); text-align:left; }
.woocommerce-checkout .woocommerce-checkout-review-order table.shop_table thead th:last-child { text-align:right; }
.woocommerce-checkout .woocommerce-checkout-review-order table.shop_table tbody td { padding:.8rem 0; border-bottom:1px solid var(--border); font-size:.9rem; }
.woocommerce-checkout .woocommerce-checkout-review-order table.shop_table tbody td:last-child { text-align:right; font-weight:600; }
.woocommerce-checkout .woocommerce-checkout-review-order table.shop_table tbody .product-name { font-weight:600; color:var(--dark); }
.woocommerce-checkout .woocommerce-checkout-review-order table.shop_table tbody .product-total { color:var(--text); }
.woocommerce-checkout .woocommerce-checkout-review-order table.shop_table tfoot th { padding:.7rem 0; text-align:left; font-weight:600; font-size:.9rem; color:var(--dark); }
.woocommerce-checkout .woocommerce-checkout-review-order table.shop_table tfoot td { padding:.7rem 0; text-align:right; font-size:.9rem; }
.woocommerce-checkout .woocommerce-checkout-review-order table.shop_table tfoot .order-total th,
.woocommerce-checkout .woocommerce-checkout-review-order table.shop_table tfoot .order-total td { font-size:1.1rem; font-weight:700; padding-top:1.2rem; border-top:2px solid var(--border); }
.woocommerce-checkout .woocommerce-checkout-review-order table.shop_table tfoot .order-total td { color:var(--primary); font-size:1.3rem; }
.woocommerce-checkout .woocommerce-checkout-review-order table.shop_table .cart-subtotal td { color:var(--text); }
.woocommerce-checkout .woocommerce-checkout-review-order table.shop_table .shipping td { font-size:.85rem; }
.woocommerce-checkout .woocommerce-checkout-review-order table.shop_table .shipping td .woocommerce-shipping-methods { list-style:none; padding:0; margin:0; display:flex; flex-direction:column; gap:.3rem; }
.woocommerce-checkout .woocommerce-checkout-review-order table.shop_table .shipping td .woocommerce-shipping-methods li { font-size:.85rem; display:flex; align-items:center; gap:.4rem; justify-content:flex-end; }

.woocommerce-checkout #payment { background:var(--light); border-radius:var(--radius); padding:1.5rem; border:1px solid var(--border-light); }
.woocommerce-checkout #payment .wc_payment_methods { list-style:none; padding:0; margin:0; }
.woocommerce-checkout #payment .wc_payment_methods li { margin-bottom:.5rem; }
.woocommerce-checkout #payment .wc_payment_methods li:last-child { margin-bottom:0; }
.woocommerce-checkout #payment .wc_payment_methods .payment_box { background:var(--white); border-radius:var(--radius); padding:1rem 1.2rem; margin-top:.5rem; border:1px solid var(--border-light); font-size:.85rem; color:var(--text-secondary); }
.woocommerce-checkout #payment .wc_payment_methods .payment_box p:last-child { margin-bottom:0; }
.woocommerce-checkout #payment .wc_payment_methods label { display:flex; align-items:center; gap:.6rem; font-weight:600; font-size:.9rem; cursor:pointer; padding:.6rem .2rem; }
.woocommerce-checkout #payment .wc_payment_methods input[type="radio"] { accent-color:var(--primary); }
.woocommerce-checkout #payment .place-order { margin-top:1.5rem; }
.woocommerce-checkout #payment .place-order .button { width:100%; padding:1rem; background:linear-gradient(135deg, var(--accent), var(--accent-hover)); color:white; border:none; border-radius:var(--radius-full); font-weight:700; font-size:1.1rem; cursor:pointer; transition:all .3s var(--ease-bounce); box-shadow:0 4px 14px rgba(216,12,114,.35); font-family:inherit; }
.woocommerce-checkout #payment .place-order .button:hover { transform:translateY(-3px); box-shadow:0 8px 25px rgba(216,12,114,.4); }
.woocommerce-checkout #payment .place-order .button:disabled { opacity:.5; cursor:not-allowed; transform:none; }

.woocommerce-checkout .woocommerce-terms-and-conditions-wrapper { margin-top:1.5rem; padding-top:1.2rem; border-top:1px solid var(--border); font-size:.85rem; }
.woocommerce-checkout .woocommerce-terms-and-conditions-wrapper label { display:flex; align-items:center; gap:.5rem; cursor:pointer; font-weight:500; }
.woocommerce-checkout .woocommerce-terms-and-conditions-wrapper input[type="checkbox"] { accent-color:var(--primary); }
.woocommerce-checkout .woocommerce-terms-and-conditions-wrapper a { color:var(--primary); text-decoration:underline; }
.woocommerce-checkout .woocommerce-privacy-policy-text { font-size:.82rem; color:var(--text-secondary); margin-top:1rem; padding-top:1rem; border-top:1px solid var(--border); }
.woocommerce-checkout .woocommerce-privacy-policy-text a { color:var(--primary); text-decoration:underline; }
.woocommerce-checkout .woocommerce-privacy-policy-text p:last-child { margin-bottom:0; }

.woocommerce-checkout .woocommerce-billing-fields__field-wrapper,
.woocommerce-checkout .woocommerce-shipping-fields__field-wrapper { display:grid; grid-template-columns:1fr 1fr; gap:0 1.5rem; }
.woocommerce-checkout .woocommerce-billing-fields__field-wrapper .form-row-wide,
.woocommerce-checkout .woocommerce-shipping-fields__field-wrapper .form-row-wide { grid-column:1 / -1; }
.woocommerce-checkout .woocommerce-shipping-fields { margin-top:2rem; padding-top:2rem; border-top:1px solid var(--border); }
.woocommerce-checkout .woocommerce-shipping-fields #ship-to-different-address { margin-bottom:1rem; }
.woocommerce-checkout .woocommerce-shipping-fields #ship-to-different-address label { display:flex; align-items:center; gap:.5rem; cursor:pointer; }
.woocommerce-checkout .woocommerce-shipping-fields #ship-to-different-address input { accent-color:var(--primary); }
.woocommerce-checkout .woocommerce-shipping-fields #ship-to-different-address span { font-weight:600; }
.woocommerce-checkout .woocommerce-account-fields { margin-top:1rem; }
.woocommerce-checkout .woocommerce-account-fields .form-row label { display:flex; align-items:center; gap:.5rem; cursor:pointer; font-weight:500; }
.woocommerce-checkout .woocommerce-account-fields input[type="checkbox"] { accent-color:var(--primary); }

.woocommerce-checkout .woocommerce-checkout-payment { margin-top:1.5rem; }

@media (max-width:900px) {
  .woocommerce-checkout .woocommerce-checkout { grid-template-columns:1fr; }
  .woocommerce-checkout .woocommerce-checkout-review-order { position:static; }
  .woocommerce-checkout .woocommerce-billing-fields__field-wrapper,
  .woocommerce-checkout .woocommerce-shipping-fields__field-wrapper { grid-template-columns:1fr; }
  .woocommerce-checkout .checkout_coupon { flex-direction:column; align-items:stretch; }
  .woocommerce-checkout .checkout_coupon input[type="text"] { min-width:0; }
}
@media (max-width:600px) {
  .woocommerce-checkout #customer_details { padding:1.25rem; }
  .woocommerce-checkout .woocommerce-checkout-review-order { padding:1.25rem; }
  .woocommerce-checkout #payment { padding:1rem; }
}

