/*
Theme Name: Kemer Buket Premium
Theme URI: https://kemerbuket.com
Author: OpenAI
Description: Kemer Buket için premium floral tema.
Version: 1.0.0
Text Domain: kemer-buket-premium
*/

:root {
  --bg: #f7fbf8;
  --bg-soft: #eef7f2;
  --bg-blue: #edf6fa;
  --surface: rgba(255, 255, 255, 0.9);
  --surface-strong: #ffffff;
  --line: rgba(23, 54, 42, 0.1);
  --line-strong: rgba(23, 54, 42, 0.18);
  --text: #163629;
  --text-soft: #6d8075;
  --primary: #1a4c39;
  --primary-2: #214f5f;
  --accent: #b9efe0;
  --accent-2: #dff5ec;
  --glow: rgba(132, 212, 186, 0.32);
  --shadow: 0 18px 50px rgba(19, 48, 38, 0.08);
  --shadow-soft: 0 12px 30px rgba(20, 48, 39, 0.06);
  --radius: 28px;
  --radius-md: 22px;
  --radius-sm: 16px;
  --container: 1220px;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  background:
    radial-gradient(circle at top left, rgba(212, 244, 234, 0.9), transparent 34%),
    radial-gradient(circle at top right, rgba(226, 240, 247, 0.92), transparent 30%),
    var(--bg);
  color: var(--text);
  font-family: 'Inter', sans-serif;
  line-height: 1.65;
}
body.modal-open { overflow: hidden; }
a { color: inherit; text-decoration: none; }
img { max-width: 100%; display: block; }
button, input, select, textarea { font: inherit; }
button { cursor: pointer; }

.container {
  width: min(calc(100% - 32px), var(--container));
  margin: 0 auto;
}

.eyebrow,
.card-chip,
.footer-kicker,
.kemer-thankyou-chip {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 8px 14px;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.7);
  border: 1px solid rgba(23, 54, 42, 0.08);
  color: var(--primary);
  font-size: 0.78rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  backdrop-filter: blur(12px);
}

h1, h2, h3, h4 {
  margin: 0;
  font-family: 'Cormorant Garamond', serif;
  line-height: 1.05;
  letter-spacing: -0.02em;
}

p { margin: 0; color: var(--text-soft); }

.kb-btn,
button.kb-btn,
.woocommerce a.button,
.woocommerce button.button,
.woocommerce input.button,
.woocommerce #respond input#submit {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  min-height: 52px;
  padding: 0 24px;
  border-radius: 999px;
  border: 1px solid transparent;
  font-weight: 700;
  transition: transform .25s ease, box-shadow .25s ease, background .25s ease, border-color .25s ease;
}

.kb-btn:hover,
.woocommerce a.button:hover,
.woocommerce button.button:hover,
.woocommerce input.button:hover,
.woocommerce #respond input#submit:hover {
  transform: translateY(-2px);
}

.kb-btn-primary,
.woocommerce a.button,
.woocommerce button.button,
.woocommerce input.button,
.woocommerce #respond input#submit,
.woocommerce .button.alt {
  background: linear-gradient(135deg, var(--primary), var(--primary-2));
  color: #fff !important;
  box-shadow: 0 14px 30px rgba(26, 76, 57, 0.18);
}

.kb-btn-secondary {
  border-color: rgba(23, 54, 42, 0.12);
  background: rgba(255,255,255,0.72);
  color: var(--text);
  box-shadow: var(--shadow-soft);
}

.kb-btn-small { min-height: 44px; padding: 0 18px; font-size: 0.92rem; }
.inline-link {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  color: var(--primary);
  font-weight: 700;
}
.inline-link::after { content: '→'; }

.site-header {
  position: sticky;
  top: 0;
  z-index: 90;
  padding: 16px 0;
  transition: padding .25s ease, background .25s ease, box-shadow .25s ease;
}
.site-header.is-scrolled {
  padding: 10px 0;
  background: rgba(247, 251, 248, 0.86);
  backdrop-filter: blur(14px);
  box-shadow: 0 8px 26px rgba(22, 54, 41, 0.08);
}
.header-shell {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 24px;
  padding: 14px 18px;
  border-radius: 999px;
  background: rgba(255,255,255,0.68);
  border: 1px solid rgba(255,255,255,0.72);
  box-shadow: var(--shadow-soft);
  backdrop-filter: blur(14px);
}
.site-logo img {
  width: auto;
  height: 64px;
  max-width: 220px;
  object-fit: contain;
}
.site-nav,
.header-actions {
  display: flex;
  align-items: center;
  gap: 20px;
}
.site-nav a {
  font-weight: 600;
  color: rgba(22, 54, 41, 0.82);
}
.header-whatsapp {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 44px;
  padding: 0 18px;
  border-radius: 999px;
  background: rgba(219, 245, 235, 0.86);
  color: var(--primary);
  font-weight: 700;
}
.header-cart {
  position: relative;
  width: 46px;
  height: 46px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  background: rgba(255,255,255,0.88);
  border: 1px solid rgba(23, 54, 42, 0.08);
}
.header-cart i { font-size: 1.1rem; color: var(--primary); }
.cart-count-badge {
  position: absolute;
  top: -6px;
  right: -6px;
  min-width: 20px;
  height: 20px;
  border-radius: 999px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: var(--primary);
  color: #fff;
  font-size: 0.72rem;
  font-weight: 700;
  padding: 0 5px;
}
.header-lang-wrapper img {
  width: 20px !important;
  height: 20px !important;
  border-radius: 999px;
  box-shadow: 0 5px 14px rgba(17, 55, 45, 0.18);
}

.home-hero,
.store-hero,
.about-hero {
  padding: 34px 0 24px;
}
.home-hero__grid,
.store-hero__grid,
.about-hero__grid {
  display: grid;
  grid-template-columns: minmax(0, 1.02fr) minmax(0, 0.98fr);
  align-items: center;
  gap: 42px;
}
.home-hero__copy,
.store-hero__copy,
.about-hero__copy { padding: 34px 0; }
.home-hero__copy h1,
.store-hero__copy h1,
.about-hero__copy h1 {
  margin-top: 16px;
  font-size: clamp(3rem, 6vw, 5.6rem);
}
.home-hero__copy p,
.store-hero__copy p,
.about-hero__copy p {
  max-width: 620px;
  margin-top: 12px;
  font-size: 1.08rem;
}
.hero-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 14px;
  margin-top: 30px;
}
.hero-notes {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  margin-top: 28px;
}
.hero-notes span {
  display: inline-flex;
  align-items: center;
  min-height: 42px;
  padding: 0 16px;
  border-radius: 999px;
  background: rgba(255,255,255,0.68);
  border: 1px solid rgba(23, 54, 42, 0.08);
  font-size: 0.93rem;
  color: var(--text);
}
.home-hero__frame,
.store-hero__frame,
.about-hero__frame {
  position: relative;
  overflow: hidden;
  border-radius: 34px;
  background: linear-gradient(180deg, #f5fbf8, #edf6fa);
  border: 1px solid rgba(255,255,255,0.72);
  box-shadow: var(--shadow);
}
.home-hero__frame { min-height: 680px; }
.store-hero__frame,
.about-hero__frame { min-height: 580px; }
.home-hero__frame img,
.store-hero__frame img,
.about-hero__frame img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.hero-floating-card {
  position: absolute;
  left: 24px;
  bottom: 24px;
  display: grid;
  gap: 6px;
  min-width: 220px;
  padding: 18px 18px 16px;
  border-radius: 22px;
  background: rgba(255,255,255,0.82);
  backdrop-filter: blur(12px);
  border: 1px solid rgba(255,255,255,0.7);
  box-shadow: 0 14px 30px rgba(20, 44, 36, 0.08);
}
.hero-floating-card strong { font-size: 1rem; }
.hero-floating-card span { color: var(--text-soft); }

.section-block { padding: 28px 0 72px; }
.section-soft { background: linear-gradient(180deg, rgba(237, 246, 250, 0.28), rgba(247, 251, 248, 0)); }
.section-head {
  display: grid;
  gap: 12px;
  margin-bottom: 26px;
}
.section-head h2 { font-size: clamp(2.2rem, 5vw, 3.8rem); }

.premium-card {
  border-radius: var(--radius);
  background: rgba(255,255,255,0.86);
  border: 1px solid rgba(255,255,255,0.78);
  box-shadow: var(--shadow-soft);
  backdrop-filter: blur(14px);
}

.today-showcase-section { padding: 8px 0 34px; }
.today-showcase-card {
  display: grid;
  grid-template-columns: minmax(0, 0.9fr) minmax(0, 1.1fr);
  gap: 16px;
  align-items: center;
  padding: 20px;
  border-radius: 32px;
  background:
    linear-gradient(180deg, rgba(255,255,255,0.92), rgba(255,255,255,0.86)),
    linear-gradient(130deg, rgba(185, 239, 224, 0.28), rgba(226, 240, 247, 0.22));
  border: 1px solid rgba(171, 224, 205, 0.56);
  box-shadow: 0 24px 50px rgba(22, 54, 41, 0.08), 0 0 0 1px rgba(190, 241, 224, 0.48), 0 0 40px rgba(160, 236, 209, 0.18);
}
.today-showcase__media {
  position: relative;
  overflow: hidden;
  min-height: 430px;
  border-radius: 26px;
  background: linear-gradient(180deg, #f4fbf8, #edf5f9);
}
.today-showcase__media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.showcase-ribbon {
  position: absolute;
  top: 16px;
  left: 16px;
  z-index: 2;
  display: inline-flex;
  min-height: 38px;
  align-items: center;
  padding: 0 14px;
  border-radius: 999px;
  background: rgba(255,255,255,0.88);
  color: var(--primary);
  font-weight: 700;
}
.today-showcase__copy {
  display: grid;
  gap: 16px;
  padding: 8px 12px 8px 4px;
}
.today-showcase__copy h2 { font-size: 1.3rem; color: var(--primary); }
.today-showcase__copy h3 { font-size: clamp(2.1rem, 4vw, 3.6rem); }
.price-stack {
  display: flex;
  align-items: center;
  gap: 18px;
  flex-wrap: wrap;
}
.price-old {
  color: #91a298;
  text-decoration: line-through;
  font-size: 1.1rem;
  font-weight: 700;
}
.price-new {
  color: var(--primary);
  font-size: clamp(2rem, 4vw, 3.4rem);
  font-weight: 800;
  line-height: 1;
}

.category-grid,
.featured-grid,
.highlight-grid {
  display: grid;
  grid-template-columns: repeat(12, minmax(0, 1fr));
  gap: 22px;
}
.category-card,
.featured-card,
.highlight-card,
.service-chip,
.contact-card {
  overflow: hidden;
}
.category-card { grid-column: span 3; }
.featured-card { grid-column: span 4; }
.highlight-card { grid-column: span 4; padding: 24px; }
.highlight-card h3,
.service-chip strong { font-size: 1.65rem; }
.highlight-card p,
.service-chip p { margin-top: 12px; }
.category-card__image,
.featured-card__image {
  position: relative;
  aspect-ratio: 0.86;
  overflow: hidden;
  background: #eef6f2;
}
.category-card__image img,
.featured-card__image img,
.store-item__image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform .35s ease;
}
.category-card:hover img,
.featured-card:hover img,
.store-item:hover img { transform: scale(1.03); }
.category-card__content,
.featured-card__content {
  display: grid;
  gap: 12px;
  padding: 18px;
}
.category-card__content h3,
.featured-card__content h3 { font-size: 2rem; }
.service-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 18px;
}
.service-chip { padding: 26px; }
.contact-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.3fr) minmax(0, 0.7fr);
  gap: 24px;
}
.contact-card { padding: 28px; }
.contact-card h2 { margin-top: 12px; font-size: clamp(2.2rem, 5vw, 4rem); }
.contact-card p { margin-top: 14px; }
.contact-card--meta {
  display: grid;
  align-content: start;
  gap: 14px;
}
.contact-meta-row {
  display: flex;
  justify-content: space-between;
  gap: 14px;
  padding: 15px 0;
  border-bottom: 1px solid rgba(23, 54, 42, 0.08);
}
.contact-meta-row span { color: var(--text-soft); }
.contact-meta-row a { font-weight: 700; color: var(--primary); }

.store-section { padding-top: 12px; }
.filter-bar {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  margin-bottom: 26px;
}
.filter-btn {
  min-height: 42px;
  padding: 0 16px;
  border-radius: 999px;
  border: 1px solid rgba(23,54,42,.1);
  background: rgba(255,255,255,.74);
  color: var(--text);
  font-weight: 700;
}
.filter-btn.active {
  background: linear-gradient(135deg, var(--primary), var(--primary-2));
  color: #fff;
}
.store-grid {
  display: grid;
  grid-template-columns: repeat(12, minmax(0, 1fr));
  gap: 22px;
}
.store-item {
  grid-column: span 4;
  overflow: hidden;
}
.store-item__image {
  position: relative;
  display: block;
  width: 100%;
  aspect-ratio: 0.82;
  border: 0;
  padding: 0;
  background: #eef6f2;
}
.store-item__image .card-chip {
  position: absolute;
  top: 16px;
  left: 16px;
  z-index: 2;
}
.store-item__body {
  display: grid;
  gap: 12px;
  padding: 22px;
}
.store-item__body h3 { font-size: 1.9rem; }
.store-item__footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  margin-top: 4px;
}
.store-price {
  font-size: 1.3rem;
  font-weight: 800;
  color: var(--primary);
}
.store-loading {
  grid-column: 1 / -1;
  min-height: 220px;
  display: grid;
  place-items: center;
  gap: 12px;
  text-align: center;
  color: var(--text-soft);
}
.store-loading i { font-size: 2rem; color: var(--primary); }

.modal {
  display: none;
  position: fixed;
  inset: 0;
  z-index: 9999;
  padding: 20px;
  background: rgba(18, 34, 28, 0.72);
  backdrop-filter: blur(6px);
  align-items: center;
  justify-content: center;
}
.modal-content {
  position: relative;
  width: min(1100px, 100%);
  max-height: 92vh;
  display: grid;
  grid-template-columns: minmax(0, 1.08fr) minmax(0, 0.92fr);
  overflow: hidden;
  border-radius: 30px;
  background: #fff;
  box-shadow: 0 30px 70px rgba(0,0,0,0.32);
}
.close-btn {
  position: absolute;
  top: 18px;
  right: 18px;
  z-index: 3;
  width: 42px;
  height: 42px;
  border: 0;
  border-radius: 50%;
  background: rgba(255,255,255,0.9);
  color: var(--text);
  font-size: 1.6rem;
}
.modal-img-container {
  display: flex;
  flex-direction: column;
  min-height: 100%;
  background: linear-gradient(180deg, #f5fbf8, #eef6f2);
}
.main-img-box {
  min-height: 540px;
  background: #f1f7f4;
}
.main-img-box img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.thumbnails-row {
  display: flex;
  gap: 12px;
  padding: 16px;
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  scroll-snap-type: x proximity;
}
.thumb-btn {
  flex: 0 0 96px;
  height: 96px;
  border-radius: 18px;
  border: 1px solid rgba(23,54,42,.1);
  padding: 0;
  overflow: hidden;
  background: #fff;
  scroll-snap-align: start;
}
.thumb-btn.active {
  box-shadow: 0 0 0 2px rgba(26, 76, 57, 0.24);
}
.thumb-btn img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.modal-info {
  display: flex;
  flex-direction: column;
  gap: 18px;
  padding: 34px 30px 30px;
  overflow-y: auto;
}
.modal-info h2 { font-size: 3rem; }
#modalDesc { color: var(--text-soft); }
.modal-price {
  font-size: 2rem;
  font-weight: 800;
  color: var(--primary);
}
.product-options {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 16px;
}
.option-group { display: grid; gap: 10px; }
.option-group--full { grid-column: 1 / -1; }
.option-group label { font-weight: 700; color: var(--text); }
.option-group select,
.option-group textarea,
.woocommerce form .form-row input.input-text,
.woocommerce form .form-row textarea,
.woocommerce form .form-row select,
#loginform input[type="text"],
#loginform input[type="password"] {
  width: 100%;
  min-height: 56px;
  padding: 14px 16px;
  border-radius: 16px;
  border: 1px solid rgba(23,54,42,.12);
  background: #fbfdfc;
  color: var(--text);
}
.option-group textarea,
.woocommerce form .form-row textarea { min-height: 120px; resize: vertical; }
.modal-add-btn { width: 100%; margin-top: auto; }
.modal-add-btn:disabled { opacity: 0.55; cursor: not-allowed; transform: none; }

.about-stack { display: grid; gap: 22px; }
.about-row {
  display: grid;
  grid-template-columns: minmax(0, 0.96fr) minmax(0, 1.04fr);
  gap: 24px;
  align-items: stretch;
}
.about-row.reverse { grid-template-columns: minmax(0, 1.04fr) minmax(0, 0.96fr); }
.about-row.reverse .about-row__image { order: 2; }
.about-row.reverse .about-row__copy { order: 1; }
.about-row__image { overflow: hidden; min-height: 420px; }
.about-row__image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.about-row__copy {
  display: grid;
  align-content: center;
  gap: 16px;
  padding: 34px;
}
.about-row__copy h2 { font-size: clamp(2.2rem, 5vw, 3.7rem); }

.page-hero-header { padding: 36px 0 16px; }
.page-hero-header h1 { margin-top: 14px; font-size: clamp(2.3rem, 5vw, 4rem); }
.page-content-area { padding: 0 0 70px; }
.content-box { padding: 30px; }
.content-box > * + * { margin-top: 16px; }
.content-box h2,
.content-box h3 { font-size: clamp(1.8rem, 4vw, 2.6rem); }

.site-footer {
  margin-top: 32px;
  padding-top: 28px;
  background: linear-gradient(180deg, rgba(237, 246, 250, 0.22), rgba(247, 251, 248, 0.95));
  border-top: 1px solid rgba(23,54,42,.08);
}
.footer-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.1fr) minmax(0, 0.55fr) minmax(0, 0.75fr);
  gap: 28px;
  padding: 20px 0 32px;
}
.footer-brand h3 { margin-top: 12px; font-size: 2.2rem; }
.footer-brand p { margin-top: 14px; max-width: 380px; }
.footer-links,
.footer-contact { display: grid; gap: 12px; align-content: start; }
.footer-links h4,
.footer-contact h4 { font-size: 1.45rem; }
.footer-links a,
.footer-contact a { color: var(--text-soft); }
.footer-bottom {
  padding: 16px 0 22px;
  text-align: center;
  color: var(--text-soft);
  border-top: 1px solid rgba(23,54,42,.08);
}
.sticky-contact-bar {
  position: fixed;
  right: 16px;
  bottom: 16px;
  z-index: 80;
  display: grid;
  gap: 10px;
}
.sticky-item {
  width: 52px;
  height: 52px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 18px;
  color: #fff;
  box-shadow: 0 12px 26px rgba(22, 54, 41, 0.2);
}
.sticky-item.phone { background: linear-gradient(135deg, #1e5c46, #2d7d5f); }
.sticky-item.whatsapp { background: linear-gradient(135deg, #1c9a63, #2cc572); }
.sticky-item.map { background: linear-gradient(135deg, #20576b, #3b90af); }

.kb-cart-line-item,
.kb-order-line-item {
  display: flex;
  align-items: center;
  gap: 14px;
}
.kb-cart-line-item__media,
.kb-order-line-item__media {
  width: 68px;
  height: 68px;
  overflow: hidden;
  border-radius: 16px;
  background: #eef6f2;
  flex-shrink: 0;
}
.kb-cart-line-item__media img,
.kb-order-line-item__media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.kb-cart-line-item__copy,
.kb-order-line-item__copy { font-weight: 700; color: var(--text); }

.woocommerce,
.woocommerce-page { color: var(--text); }
.woocommerce .woocommerce-notices-wrapper,
.woocommerce form.checkout_coupon,
.woocommerce .woocommerce-message,
.woocommerce-error,
.woocommerce-info {
  border-radius: 18px;
  border: 1px solid rgba(23,54,42,.1);
  background: rgba(255,255,255,.86);
  box-shadow: var(--shadow-soft);
}
.woocommerce .quantity .qty { min-height: 44px; border-radius: 12px; border: 1px solid rgba(23,54,42,.12); }
.woocommerce-cart .cart-collaterals .cart_totals,
.woocommerce-checkout-review-order,
.woocommerce-checkout #customer_details,
.woocommerce-account .woocommerce,
.woocommerce form.checkout,
.woocommerce .col2-set,
.woocommerce .cart-empty,
.woocommerce .return-to-shop,
.woocommerce .woocommerce-order,
.woocommerce table.shop_table {
  border-radius: 24px;
  background: rgba(255,255,255,.86);
  border: 1px solid rgba(255,255,255,.8);
  box-shadow: var(--shadow-soft);
}
.woocommerce table.shop_table { border-collapse: separate; overflow: hidden; }
.woocommerce table.shop_table th,
.woocommerce table.shop_table td { padding: 18px 16px; border-color: rgba(23,54,42,.08); }
.woocommerce-checkout #customer_details,
.woocommerce-checkout-review-order,
.woocommerce form.checkout,
.woocommerce .woocommerce-order { padding: 24px; }
.woocommerce .col2-set .col-1,
.woocommerce .col2-set .col-2 {
  width: 100%;
  float: none;
}
.woocommerce form .form-row label { font-weight: 700; color: var(--text); margin-bottom: 8px; }
.kb-delivery-box {
  margin-top: 18px;
  padding: 20px;
  border-radius: 22px;
  background: linear-gradient(180deg, rgba(237, 246, 250, 0.4), rgba(255,255,255,0.82));
  border: 1px solid rgba(23,54,42,.08);
}
.kb-delivery-box h3 { font-size: 1.6rem; margin-bottom: 12px; }
.woocommerce #payment {
  border-radius: 22px;
  background: rgba(248, 252, 250, 0.86);
}
.woocommerce ul.order_details {
  padding: 0;
  margin: 0 0 20px;
}
.woocommerce ul.order_details li {
  border-right: 1px solid rgba(23,54,42,.08);
  padding-right: 14px;
  margin-right: 14px;
}
.kemer-received-inline { display: block; margin-top: 8px; font-weight: 700; color: var(--primary); }
.kemer-thankyou-hero { margin: 0 0 24px; }
.kemer-thankyou-card {
  border-radius: 28px;
  padding: 28px;
  background: linear-gradient(180deg, rgba(255,255,255,.94), rgba(247,251,248,.88));
  border: 1px solid rgba(255,255,255,.8);
  box-shadow: var(--shadow-soft);
}
.kemer-thankyou-card h2 {
  margin-top: 16px;
  font-size: clamp(2.1rem, 4vw, 3.6rem);
}
.kemer-thankyou-card p { margin-top: 12px; }
.kemer-thankyou-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 14px;
  margin-top: 24px;
}
.kemer-thankyou-stat {
  padding: 18px;
  border-radius: 22px;
  background: rgba(255,255,255,.72);
  border: 1px solid rgba(23,54,42,.08);
}
.kemer-thankyou-stat span {
  display: block;
  color: var(--text-soft);
  font-size: 0.86rem;
  margin-bottom: 8px;
}
.kemer-thankyou-stat strong { font-size: 1rem; }
.kemer-thankyou-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  margin-top: 24px;
}
.kemer-thankyou-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 48px;
  padding: 0 20px;
  border-radius: 999px;
  font-weight: 700;
}
.kemer-thankyou-btn-primary { background: linear-gradient(135deg, var(--primary), var(--primary-2)); color: #fff; }
.kemer-thankyou-btn-soft { background: rgba(255,255,255,.82); color: var(--primary); border: 1px solid rgba(23,54,42,.12); }

@media (max-width: 1180px) {
  .site-nav { display: none; }
  .category-card,
  .featured-card,
  .highlight-card,
  .store-item { grid-column: span 6; }
}

@media (max-width: 980px) {
  .home-hero__grid,
  .store-hero__grid,
  .about-hero__grid,
  .today-showcase-card,
  .contact-grid,
  .about-row,
  .about-row.reverse,
  .footer-grid,
  .modal-content {
    grid-template-columns: 1fr;
  }
  .about-row.reverse .about-row__image,
  .about-row.reverse .about-row__copy { order: initial; }
  .header-shell {
    padding: 14px 16px;
    border-radius: 28px;
    flex-wrap: wrap;
    justify-content: center;
  }
  .header-actions { width: 100%; justify-content: center; }
  .home-hero__frame,
  .store-hero__frame,
  .about-hero__frame,
  .today-showcase__media { min-height: 420px; }
  .main-img-box { min-height: 320px; }
  .modal-info { max-height: 42vh; }
  .product-options { grid-template-columns: 1fr; }
  .service-grid { grid-template-columns: 1fr; }
  .kemer-thankyou-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}

@media (max-width: 720px) {
  .site-header { padding-top: 12px; }
  .site-logo img { height: 52px; }
  .header-whatsapp { display: none; }
  .home-hero__copy,
  .store-hero__copy,
  .about-hero__copy { padding: 12px 0 0; }
  .home-hero__copy h1,
  .store-hero__copy h1,
  .about-hero__copy h1 { font-size: clamp(2.5rem, 10vw, 4rem); }
  .home-hero__frame,
  .store-hero__frame,
  .about-hero__frame,
  .today-showcase__media { min-height: 320px; }
  .today-showcase-card,
  .contact-card,
  .service-chip,
  .highlight-card,
  .about-row__copy,
  .kemer-thankyou-card,
  .content-box,
  .woocommerce-checkout #customer_details,
  .woocommerce-checkout-review-order,
  .woocommerce form.checkout,
  .woocommerce .woocommerce-order { padding: 22px 18px; }
  .category-card,
  .featured-card,
  .highlight-card,
  .store-item { grid-column: 1 / -1; }
  .filter-bar { overflow-x: auto; flex-wrap: nowrap; padding-bottom: 2px; }
  .filter-btn { white-space: nowrap; }
  .modal {
    padding: 10px;
    align-items: flex-end;
  }
  .modal-content {
    width: 100%;
    max-height: 96vh;
    border-radius: 26px 26px 0 0;
  }
  .modal-info h2 { font-size: 2.4rem; }
  .thumb-btn { flex-basis: 84px; height: 84px; }
  .sticky-contact-bar {
    right: 50%;
    transform: translateX(50%);
    bottom: 14px;
    grid-auto-flow: column;
  }
  .kemer-thankyou-grid { grid-template-columns: 1fr; }
}

/* ===== 2026.04.07.2 HOME + VITRINE + MODAL FIX ===== */
.home-hero--signature { padding: 28px 0 14px; }
.home-hero-shell {
  padding: 22px;
  border: 1px solid rgba(255,255,255,0.82);
  background:
    linear-gradient(180deg, rgba(255,255,255,0.9), rgba(255,255,255,0.82)),
    linear-gradient(130deg, rgba(219, 245, 235, 0.16), rgba(226, 240, 247, 0.14));
}
.home-hero--signature .home-hero__grid { gap: 30px; align-items: stretch; }
.home-hero--signature .home-hero__copy {
  padding: 34px 22px 34px 10px;
  display: flex;
  flex-direction: column;
  justify-content: center;
}
.home-hero--signature .home-hero__copy h1 {
  max-width: 640px;
  font-size: clamp(3.2rem, 6.5vw, 5.8rem);
}
.home-hero--signature .home-hero__copy p {
  max-width: 560px;
  font-size: 1.06rem;
}
.home-hero--signature .home-hero__frame {
  min-height: 660px;
  border-radius: 34px;
  overflow: hidden;
  background: linear-gradient(180deg, #f5fbf8, #edf5f8);
}
.home-hero--signature .home-hero__frame img { object-position: center; }
.home-hero--signature .hero-floating-card {
  left: 28px;
  bottom: 28px;
  min-width: 240px;
  border-radius: 24px;
  box-shadow: 0 24px 38px rgba(20, 44, 36, 0.12);
}

.section-head--between {
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: end;
  gap: 18px;
}
.section-head--between p { max-width: 620px; }
.section-block--compact { padding-top: 8px; }

.home-vitrine-section { padding: 8px 0 34px; }
.home-vitrine-shell {
  position: relative;
  padding: 26px;
  border-radius: 34px;
  background:
    linear-gradient(180deg, rgba(255,255,255,0.9), rgba(255,255,255,0.84)),
    linear-gradient(125deg, rgba(223, 245, 236, 0.38), rgba(237, 246, 250, 0.34));
  border: 1px solid rgba(172, 226, 206, 0.72);
  box-shadow:
    0 28px 60px rgba(19, 48, 38, 0.08),
    0 0 0 1px rgba(199, 244, 228, 0.34),
    0 0 42px rgba(161, 236, 209, 0.18);
}
.home-vitrine-shell::before {
  content: '';
  position: absolute;
  inset: -1px;
  border-radius: inherit;
  pointer-events: none;
  box-shadow: 0 0 26px rgba(164, 236, 210, 0.16);
}
.home-vitrine-head { margin-bottom: 22px; }
.home-vitrine-grid {
  display: grid;
  grid-template-columns: repeat(12, minmax(0, 1fr));
  gap: 22px;
}
.home-vitrine-card {
  grid-column: span 3;
  overflow: hidden;
  border-radius: 30px;
  border: 1px solid rgba(196, 239, 223, 0.9);
  box-shadow: 0 14px 34px rgba(20, 52, 41, 0.07), 0 0 0 1px rgba(228, 250, 241, 0.82);
}
.home-vitrine-card__media {
  position: relative;
  aspect-ratio: 0.82;
  overflow: hidden;
  background: linear-gradient(180deg, #f4faf7, #edf5f9);
}
.home-vitrine-card__media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform .35s ease;
}
.home-vitrine-card:hover .home-vitrine-card__media img { transform: scale(1.03); }
.home-vitrine-card__body {
  display: grid;
  gap: 12px;
  padding: 20px;
}
.home-vitrine-card__body h3 {
  font-size: 2rem;
  min-height: 74px;
}
.home-vitrine-card__body p {
  min-height: 72px;
}
.home-vitrine-card__footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  margin-top: 4px;
}
.home-vitrine-grid.vitrine-count-3 .home-vitrine-card { grid-column: span 4; }
.home-vitrine-grid.vitrine-count-2 .home-vitrine-card { grid-column: span 6; }
.home-vitrine-grid.vitrine-count-1 .home-vitrine-card { grid-column: span 12; max-width: 460px; }

.modal-content--premium {
  width: min(1120px, 100%);
  grid-template-columns: minmax(0, 1.08fr) minmax(0, 0.92fr);
  border-radius: 34px;
  background: linear-gradient(180deg, rgba(255,255,255,0.98), rgba(255,255,255,0.96));
}
.modal-content--premium .close-btn {
  top: 16px;
  right: 16px;
  box-shadow: 0 10px 28px rgba(22, 54, 41, 0.14);
}
.modal-content--premium .modal-img-container {
  padding: 14px;
  background: linear-gradient(180deg, #f5fbf8, #eef6f2);
  border-right: 1px solid rgba(23,54,42,.07);
}
.modal-content--premium .main-img-box {
  position: relative;
  min-height: 0;
  height: min(66vh, 700px);
  border-radius: 26px;
  overflow: hidden;
  background: linear-gradient(180deg, #f7fbf8, #edf5f8);
}
.modal-content--premium .main-img-box img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  padding: 20px;
}
.modal-nav {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  z-index: 2;
  width: 46px;
  height: 46px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border: 0;
  border-radius: 50%;
  background: rgba(255,255,255,0.9);
  color: var(--primary);
  box-shadow: 0 10px 22px rgba(20, 48, 39, 0.12);
}
.modal-nav--prev { left: 16px; }
.modal-nav--next { right: 16px; }
.modal-nav.is-hidden { display: none; }
.modal-content--premium .thumbnails-row {
  gap: 10px;
  padding: 14px 4px 4px;
}
.modal-content--premium .thumb-btn {
  flex: 0 0 86px;
  height: 96px;
  border-radius: 18px;
  background: rgba(255,255,255,0.96);
  border: 1px solid rgba(23,54,42,.08);
}
.modal-content--premium .thumb-btn.active {
  box-shadow: 0 0 0 2px rgba(26, 76, 57, 0.18), 0 10px 24px rgba(20, 48, 39, 0.08);
}
.modal-content--premium .modal-info {
  padding: 38px 32px 30px;
  gap: 16px;
}
.modal-content--premium .modal-info h2 {
  font-size: clamp(2.4rem, 4vw, 3.2rem);
  max-width: 92%;
}
.modal-content--premium #modalDesc {
  font-size: 0.98rem;
  line-height: 1.8;
}
.modal-content--premium .modal-price {
  font-size: clamp(1.8rem, 3vw, 2.3rem);
}
.modal-content--premium .product-options {
  gap: 14px;
}
.modal-content--premium .option-group select,
.modal-content--premium .option-group textarea {
  background: #f9fcfa;
}

@media (max-width: 1120px) {
  .home-vitrine-card { grid-column: span 6; }
  .home-vitrine-grid.vitrine-count-3 .home-vitrine-card { grid-column: span 6; }
  .home-vitrine-grid.vitrine-count-1 .home-vitrine-card { grid-column: 1 / -1; }
}

@media (max-width: 920px) {
  .home-hero-shell { padding: 18px; }
  .home-hero--signature .home-hero__copy { padding: 14px 4px 2px; }
  .home-hero--signature .home-hero__frame { min-height: 440px; }
  .section-head--between { grid-template-columns: 1fr; }
  .home-vitrine-shell { padding: 18px; }
  .home-vitrine-card,
  .home-vitrine-grid.vitrine-count-3 .home-vitrine-card,
  .home-vitrine-grid.vitrine-count-2 .home-vitrine-card { grid-column: 1 / -1; }
  .modal-content--premium {
    display: flex;
    flex-direction: column;
    max-height: 95vh;
  }
  .modal-content--premium .modal-img-container {
    border-right: 0;
    border-bottom: 1px solid rgba(23,54,42,.07);
  }
  .modal-content--premium .main-img-box {
    height: min(50vh, 480px);
  }
}

@media (max-width: 640px) {
  .home-hero--signature { padding-top: 18px; }
  .home-hero-shell { padding: 14px; border-radius: 26px; }
  .home-hero--signature .home-hero__copy h1 { font-size: clamp(2.6rem, 11vw, 4rem); }
  .home-hero--signature .home-hero__frame {
    min-height: 360px;
    border-radius: 24px;
  }
  .home-hero--signature .hero-floating-card {
    left: 16px;
    right: 16px;
    bottom: 16px;
    min-width: 0;
  }
  .home-vitrine-shell {
    padding: 14px;
    border-radius: 26px;
  }
  .home-vitrine-card { border-radius: 22px; }
  .home-vitrine-card__body { padding: 16px; }
  .home-vitrine-card__body h3 {
    font-size: 1.8rem;
    min-height: 0;
  }
  .home-vitrine-card__body p { min-height: 0; }
  .modal {
    padding: 10px;
    align-items: flex-end;
  }
  .modal-content--premium {
    width: 100%;
    border-radius: 24px 24px 0 0;
  }
  .modal-content--premium .modal-img-container {
    padding: 10px 10px 12px;
  }
  .modal-content--premium .main-img-box {
    height: 42vh;
    border-radius: 18px;
  }
  .modal-content--premium .main-img-box img { padding: 12px; }
  .modal-content--premium .thumbnails-row {
    padding: 10px 0 2px;
  }
  .modal-content--premium .thumb-btn {
    flex-basis: 74px;
    height: 82px;
    border-radius: 14px;
  }
  .modal-content--premium .modal-info {
    padding: 22px 18px 20px;
  }
  .modal-content--premium .modal-info h2 { max-width: 100%; }
  .modal-content--premium .product-options {
    grid-template-columns: 1fr;
  }
  .modal-nav {
    width: 40px;
    height: 40px;
  }
  .modal-nav--prev { left: 10px; }
  .modal-nav--next { right: 10px; }
}

/* ===== V4 overrides ===== */
.site-footer {
  background: linear-gradient(180deg, #14372a 0%, #0f2d22 100%);
  color: rgba(255,255,255,0.92);
  border-top: 1px solid rgba(255,255,255,0.08);
}
.site-footer .footer-kicker {
  background: rgba(255,255,255,0.08);
  border-color: rgba(255,255,255,0.12);
  color: #e9fff7;
}
.site-footer .footer-brand p,
.site-footer .footer-links a,
.site-footer .footer-contact a,
.site-footer .footer-bottom {
  color: rgba(255,255,255,0.74);
}
.footer-bottom {
  border-top: 1px solid rgba(255,255,255,0.08);
}

.hero-wrapper--clean,
.catalog-section--simple,
.story-section--simple,
.map-section--simple {
  width: min(calc(100% - 32px), 1240px);
  margin: 0 auto;
}

.hero-wrapper--clean {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(360px, 0.9fr);
  align-items: center;
  gap: 16px;
  padding: 16px 0 8px;
  background: transparent;
  border: 0;
  box-shadow: none;
}
.hero-wrapper--clean .hero-text {
  padding: 18px 0;
}
.hero-wrapper--clean .hero-text .eyebrow {
  background: rgba(255,255,255,0.54);
  border-color: rgba(182, 154, 92, 0.16);
  color: #6f5a2d;
}
.hero-wrapper--clean .hero-text h1 {
  margin-top: 16px;
  max-width: 7.4ch;
  font-size: clamp(3.3rem, 6.6vw, 6rem);
  font-style: italic;
  font-weight: 600;
  line-height: 0.96;
  letter-spacing: -0.035em;
  color: #a88446;
  text-shadow: 0 8px 24px rgba(168,132,70,0.08);
}
.hero-wrapper--clean .hero-text p {
  margin-top: 18px;
  max-width: 560px;
  font-size: 1.05rem;
}
.hero-wrapper--clean .hero-actions {
  margin-top: 28px;
  display: flex;
  flex-wrap: wrap;
  gap: 14px;
}
.hero-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 52px;
  padding: 0 24px;
  border-radius: 999px;
  background: linear-gradient(135deg, var(--primary), var(--primary-2));
  color: #fff;
  font-weight: 700;
  box-shadow: 0 14px 28px rgba(26, 76, 57, 0.18);
}
.hero-btn--ghost {
  background: rgba(255,255,255,0.72);
  border: 1px solid rgba(23,54,42,0.1);
  color: var(--text);
  box-shadow: var(--shadow-soft);
}
.hero-wrapper--clean .hero-image {
  position: relative;
  overflow: hidden;
  border-radius: 30px;
  aspect-ratio: 0.92;
  min-height: 0;
  background: transparent;
  box-shadow: 0 24px 46px rgba(20, 48, 39, 0.1);
}
.hero-wrapper--clean .hero-image::after {
  content: '';
  position: absolute;
  inset: 0;
  border-radius: inherit;
  box-shadow: inset 0 0 0 1px rgba(255,255,255,0.38);
  pointer-events: none;
}
.hero-wrapper--clean .hero-image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.home-vitrine-inline-section {
  width: min(calc(100% - 32px), 1240px);
  margin: 12px auto 0;
}
.home-vitrine-inline-shell {
  position: relative;
  padding: 24px;
  border-radius: 30px;
  background: linear-gradient(180deg, rgba(255,255,255,0.94), rgba(255,255,255,0.88));
  border: 1px solid rgba(189, 245, 225, 0.9);
  box-shadow:
    0 20px 40px rgba(21, 47, 37, 0.06),
    0 0 0 1px rgba(202, 250, 232, 0.42),
    0 0 26px rgba(157, 244, 211, 0.16),
    0 0 56px rgba(157, 244, 211, 0.08);
}
.home-vitrine-inline-shell::before {
  content: '';
  position: absolute;
  inset: -1px;
  border-radius: inherit;
  box-shadow: 0 0 22px rgba(165, 243, 214, 0.18);
  pointer-events: none;
}
.home-vitrine-inline-head {
  display: grid;
  gap: 10px;
  margin-bottom: 14px;
}
.home-vitrine-inline-head h2 {
  font-size: clamp(2.2rem, 4vw, 3.5rem);
}
.home-vitrine-inline-grid {
  display: grid;
  grid-template-columns: repeat(12, minmax(0, 1fr));
  gap: 12px;
}
.home-vitrine-inline-card {
  grid-column: span 3;
  overflow: hidden;
  border-radius: 26px;
  border: 1px solid rgba(199, 244, 228, 0.84);
  box-shadow: 0 14px 30px rgba(20, 52, 41, 0.06), 0 0 0 1px rgba(234, 252, 244, 0.9);
}
.home-vitrine-inline-grid.vitrine-count-3 .home-vitrine-inline-card { grid-column: span 4; }
.home-vitrine-inline-grid.vitrine-count-2 .home-vitrine-inline-card { grid-column: span 6; }
.home-vitrine-inline-grid.vitrine-count-1 .home-vitrine-inline-card { grid-column: span 12; max-width: 430px; }
.home-vitrine-inline-media {
  position: relative;
  display: block;
  width: 100%;
  padding: 0;
  border: 0;
  background: linear-gradient(180deg, #f7fbf8, #edf6fa);
  aspect-ratio: 0.84;
  overflow: hidden;
}
.home-vitrine-inline-media .card-chip {
  position: absolute;
  z-index: 2;
  top: 14px;
  left: 14px;
}
.home-vitrine-inline-media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform .35s ease;
}
.home-vitrine-inline-card:hover .home-vitrine-inline-media img { transform: scale(1.03); }
.home-vitrine-inline-body {
  display: grid;
  gap: 8px;
  padding: 16px;
}
.home-vitrine-inline-body h3 {
  font-size: 1.95rem;
}
.home-vitrine-inline-price {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
}
.price-old,
.modal-price-old {
  color: #95a59c;
  text-decoration: line-through;
  font-weight: 700;
}
.price-new,
.modal-price-new {
  color: var(--primary);
  font-weight: 800;
  font-size: 1.45rem;
}
.modal-price {
  display: flex;
  align-items: center;
  gap: 12px;
  flex-wrap: wrap;
}

.catalog-section--simple,
.story-section--simple,
.map-section--simple {
  padding-top: 16px;
}
.catalog-section--simple .catalog-title .catalog-title,
.map-section--simple .catalog-title {
  text-align: left;
  font-size: clamp(2.2rem, 4vw, 3.5rem);
}
.catalog-subtitle {
  margin-top: 10px;
  max-width: 700px;
}
.slider-wrapper {
  position: relative;
  margin-top: 20px;
}
.scroll-hint-btn {
  position: absolute;
  right: 12px;
  top: 18px;
  z-index: 3;
  width: 44px;
  height: 44px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  background: rgba(255,255,255,0.92);
  border: 1px solid rgba(23,54,42,0.08);
  box-shadow: var(--shadow-soft);
}
.catalog-row,
.featured-row {
  display: flex;
  gap: 10px;
  overflow-x: auto;
  padding: 4px 4px 8px;
  scroll-snap-type: x proximity;
}
.catalog-row::-webkit-scrollbar,
.featured-row::-webkit-scrollbar { height: 8px; }
.catalog-row::-webkit-scrollbar-thumb,
.featured-row::-webkit-scrollbar-thumb { background: rgba(23,54,42,0.16); border-radius: 999px; }
.catalog-item,
.featured-item {
  flex: 0 0 292px;
  overflow: hidden;
  border-radius: 24px;
  scroll-snap-align: start;
}
.catalog-item img,
.featured-item img,
.story-image img {
  width: 100%;
  height: 340px;
  object-fit: cover;
}
.catalog-item h3,
.featured-item h3 {
  padding: 18px 18px 0;
  font-size: 1.7rem;
}
.catalog-btn,
.story-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 46px;
  padding: 0 18px;
  margin: 14px 18px 18px;
  border-radius: 999px;
  background: linear-gradient(135deg, var(--primary), var(--primary-2));
  color: #fff;
  font-weight: 700;
}
.story-section--simple {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(400px, 0.94fr);
  gap: 28px;
  align-items: center;
}
.story-text {
  display: grid;
  gap: 14px;
}
.story-text h2 { font-size: clamp(2.4rem, 4vw, 3.8rem); }
.story-image {
  overflow: hidden;
  border-radius: 28px;
  box-shadow: var(--shadow);
}
.contact-grid-wrapper {
  display: grid;
  grid-template-columns: minmax(0, 1.1fr) minmax(340px, 0.9fr);
  gap: 16px;
  margin-top: 14px;
}
.map-box,
.review-box {
  overflow: hidden;
  border-radius: 26px;
}
.review-box {
  padding: 22px;
  min-height: 450px;
}
.review-box h3 {
  margin-bottom: 16px;
  font-size: 2rem;
  color: var(--primary);
}

.modal-content--premium {
  width: 90%;
  max-width: 1100px;
  height: 85vh;
  border-radius: 18px;
  grid-template-columns: 1.15fr 0.95fr;
  background: #fff;
  overflow: hidden;
  box-shadow: 0 25px 60px rgba(0,0,0,0.35);
}
.modal-content--premium .close-btn {
  color: #333;
  position: absolute;
  top: 15px;
  right: 20px;
  width: 42px;
  height: 42px;
  border-radius: 50%;
  background: rgba(255,255,255,0.92);
  box-shadow: 0 10px 22px rgba(22,54,41,0.12);
}
.modal-content--premium .modal-img-container {
  padding: 0;
  background: #f8fbf9;
  border-right: 1px solid #edf2ef;
}
.modal-content--premium .main-img-box {
  height: calc(100% - 86px);
  border-radius: 0;
  background: #fff;
}
.modal-content--premium .main-img-box img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  padding: 0;
}
.modal-content--premium .thumbnails-row {
  height: 86px;
  display: flex;
  gap: 10px;
  justify-content: center;
  align-items: center;
  padding: 10px;
  background: #fff;
  border-top: 1px solid #edf2ef;
}
.modal-content--premium .thumb-btn {
  width: 64px;
  min-width: 64px;
  height: 64px;
  padding: 0;
  border-radius: 10px;
  overflow: hidden;
  background: #fff;
  border: 2px solid #fff;
  box-shadow: 0 2px 5px rgba(0,0,0,0.1);
}
.modal-content--premium .thumb-btn img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.modal-content--premium .thumb-btn.active {
  border-color: var(--primary);
  box-shadow: 0 0 0 2px rgba(26,76,57,0.12);
}
.modal-content--premium .modal-info {
  padding: 28px;
  height: 100%;
  overflow-y: auto;
  gap: 14px;
}
.modal-content--premium .modal-info h2 {
  max-width: 100%;
  font-size: clamp(2.3rem, 4vw, 3rem);
}
.modal-content--premium #modalDesc,
.modal-content--premium #indexModalDesc {
  font-size: 0.96rem;
  line-height: 1.7;
}
.modal-content--premium .product-options {
  gap: 12px;
}
.modal-content--premium .option-group select,
.modal-content--premium .option-group textarea {
  background: #fbfdfc;
}
.modal-nav {
  width: 42px;
  height: 42px;
}

@media (max-width: 1120px) {
  .hero-wrapper--clean,
  .story-section--simple,
  .contact-grid-wrapper {
    grid-template-columns: 1fr;
  }
  .hero-wrapper--clean .hero-image { min-height: 460px; }
  .home-vitrine-inline-card { grid-column: span 6; }
  .home-vitrine-inline-grid.vitrine-count-3 .home-vitrine-inline-card { grid-column: span 6; }
}

@media (max-width: 760px) {
  .hero-wrapper--clean {
    grid-template-columns: 1fr;
    padding: 18px;
    border-radius: 24px;
  }
  .hero-wrapper--clean .hero-image {
    min-height: 360px;
    order: -1;
  }
  .home-vitrine-inline-shell {
    padding: 16px;
    border-radius: 24px;
  }
  .home-vitrine-inline-card,
  .home-vitrine-inline-grid.vitrine-count-3 .home-vitrine-inline-card,
  .home-vitrine-inline-grid.vitrine-count-2 .home-vitrine-inline-card {
    grid-column: 1 / -1;
  }
  .catalog-item,
  .featured-item { flex-basis: 82%; }
  .story-section--simple { gap: 20px; }
  .modal-content--premium {
    width: 95%;
    height: 95vh;
    display: flex;
    flex-direction: column;
  }
  .modal-content--premium .modal-img-container {
    border-right: 0;
    border-bottom: 1px solid #edf2ef;
    height: 350px;
  }
  .modal-content--premium .main-img-box {
    height: calc(100% - 1px);
  }
  .modal-content--premium .thumbnails-row { display: none; }
  .modal-content--premium .modal-info {
    padding: 20px;
    flex: 1;
  }
}


.featured-section--simple { display: none !important; }

@media (max-width: 980px) {
  .hero-wrapper--clean {
    grid-template-columns: 1fr;
    gap: 22px;
    padding-top: 12px;
  }
  .hero-wrapper--clean .hero-text h1 {
    max-width: none;
    font-size: clamp(2.8rem, 12vw, 4.6rem);
  }
  .hero-wrapper--clean .hero-image {
    aspect-ratio: 1 / 1.08;
  }
}

/* ===== V5 refinements ===== */
.hero-wrapper--clean .hero-text h1 {
  font-family: Georgia, 'Times New Roman', serif;
  background: linear-gradient(180deg, #c9ab68 0%, #a88446 48%, #7d6532 100%);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}
.hero-wrapper--clean .hero-text p {
  max-width: 520px;
}
.home-vitrine-inline-head h2,
.home-vitrine-inline-body h3 {
  font-family: Georgia, 'Times New Roman', serif;
  font-style: italic;
}
.home-vitrine-inline-head h2 {
  color: #a88446;
  letter-spacing: -0.03em;
}
.home-vitrine-inline-head p {
  max-width: 680px;
}
.home-vitrine-inline-card {
  transition: transform .28s ease, box-shadow .28s ease, border-color .28s ease;
  box-shadow:
    0 18px 34px rgba(20, 52, 41, 0.06),
    0 0 0 1px rgba(234, 252, 244, 0.94),
    0 0 18px rgba(157, 244, 211, 0.10);
}
.home-vitrine-inline-card:hover {
  transform: translateY(-4px);
  border-color: rgba(166, 240, 212, 0.98);
  box-shadow:
    0 24px 42px rgba(20, 52, 41, 0.1),
    0 0 0 1px rgba(234, 252, 244, 0.98),
    0 0 28px rgba(157, 244, 211, 0.16);
}
.home-vitrine-inline-price {
  margin-top: 2px;
}
.price-old,
.modal-price-old {
  font-size: .95rem;
  letter-spacing: .01em;
}
.price-new,
.modal-price-new {
  font-size: clamp(1.55rem, 2vw, 1.9rem);
  letter-spacing: -0.03em;
}
.modal-price {
  margin-top: 8px;
  padding: 14px 16px;
  border-radius: 18px;
  background: linear-gradient(180deg, rgba(251,253,252,0.98), rgba(245,250,247,0.96));
  border: 1px solid rgba(23,54,42,0.08);
  box-shadow: 0 10px 22px rgba(20, 52, 41, 0.05);
}
.home-trust-strip {
  width: min(calc(100% - 32px), 1240px);
  margin: 14px auto 0;
}
.home-trust-strip__inner {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
}
.home-trust-pill {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  min-height: 60px;
  padding: 12px 18px;
  border-radius: 999px;
  background: rgba(255,255,255,0.72);
  border: 1px solid rgba(23,54,42,0.08);
  box-shadow: 0 12px 26px rgba(20, 52, 41, 0.05);
  color: var(--text);
  font-weight: 600;
}
.home-trust-pill i {
  color: #a88446;
}
.store-item {
  transition: transform .26s ease, box-shadow .26s ease, border-color .26s ease;
}
.store-item:hover {
  transform: translateY(-5px);
  border-color: rgba(185, 230, 212, 0.95);
  box-shadow: 0 24px 42px rgba(20, 52, 41, 0.1), 0 0 0 1px rgba(232, 250, 242, 0.94);
}
.site-footer .footer-grid {
  align-items: start;
}
.footer-mini-note {
  display: inline-flex;
  margin-top: 8px;
  color: rgba(255,255,255,0.62);
  font-size: .92rem;
  line-height: 1.45;
}
@media (max-width: 980px) {
  .home-trust-strip__inner {
    grid-template-columns: 1fr;
  }
}
@media (max-width: 760px) {
  .home-trust-pill {
    justify-content: flex-start;
    border-radius: 20px;
  }
}


/* ===== V6 spacing refinements ===== */
.hero-wrapper--clean .hero-actions { margin-top: 16px; gap: 12px; }
.home-vitrine-inline-body h3 { margin-bottom: 0; }
.home-vitrine-inline-price { gap: 8px; }
.catalog-item h3,
.featured-item h3 { padding: 14px 16px 0; }
.catalog-btn,
.story-btn { margin: 12px 16px 16px; }
.story-text { gap: 12px; }
.review-box h3 { margin-bottom: 12px; }
@media (max-width: 980px) {
  .hero-wrapper--clean { gap: 14px; }
}
@media (max-width: 760px) {
  .hero-wrapper--clean { padding: 14px 0 6px; }
  .home-vitrine-inline-shell { padding: 14px; }
  .story-section--simple { gap: 14px; }
}


/* ===== 2026.04.08.1 CART + CHECKOUT REWORK ===== */
body.woocommerce-cart .page-content-area .content-box,
body.woocommerce-checkout .page-content-area .content-box {
  padding: 0;
  background: transparent;
  border: 0;
  box-shadow: none;
}

body.woocommerce-cart .woocommerce,
body.woocommerce-checkout .woocommerce {
  color: var(--text);
}

body.woocommerce-cart .woocommerce > .woocommerce-notices-wrapper,
body.woocommerce-cart .woocommerce > form.woocommerce-cart-form,
body.woocommerce-cart .woocommerce > .cart-collaterals {
  margin-top: 0;
}

body.woocommerce-cart .woocommerce {
  display: grid;
  grid-template-columns: minmax(0, 1.2fr) minmax(320px, 0.8fr);
  gap: 22px;
  align-items: start;
}

body.woocommerce-cart .woocommerce-notices-wrapper,
body.woocommerce-cart .woocommerce > h2,
body.woocommerce-cart .cart-empty,
body.woocommerce-cart .return-to-shop {
  grid-column: 1 / -1;
}

body.woocommerce-cart form.woocommerce-cart-form {
  grid-column: 1;
  min-width: 0;
}

body.woocommerce-cart .cart-collaterals {
  grid-column: 2;
  width: 100%;
}

body.woocommerce-cart .cart-collaterals .cart_totals {
  position: sticky;
  top: 108px;
  width: 100% !important;
  padding: 28px;
  border-radius: 28px;
  background: linear-gradient(180deg, rgba(255,255,255,.96), rgba(246,250,248,.92));
  border: 1px solid rgba(255,255,255,.82);
  box-shadow: 0 20px 44px rgba(21, 49, 38, 0.08);
}

body.woocommerce-cart .cart-collaterals .cart_totals h2,
body.woocommerce-checkout #order_review_heading {
  margin: 0 0 18px;
  font-size: clamp(2rem, 3.2vw, 3rem);
  color: var(--text);
}

body.woocommerce-cart table.shop_table,
body.woocommerce-checkout table.shop_table {
  width: 100%;
  border-radius: 28px;
  overflow: hidden;
  background: linear-gradient(180deg, rgba(255,255,255,.96), rgba(248,252,250,.92));
  border: 1px solid rgba(255,255,255,.82);
  box-shadow: 0 18px 38px rgba(21, 49, 38, 0.06);
}

body.woocommerce-cart table.shop_table th,
body.woocommerce-cart table.shop_table td,
body.woocommerce-checkout table.shop_table th,
body.woocommerce-checkout table.shop_table td {
  padding: 18px 18px;
  vertical-align: middle;
}

body.woocommerce-cart table.shop_table thead th,
body.woocommerce-checkout table.shop_table thead th,
body.woocommerce-checkout #payment .payment_methods > li > label {
  font-size: .95rem;
  font-weight: 700;
  color: var(--text);
}

body.woocommerce-cart .product-remove a.remove {
  width: 34px;
  height: 34px;
  border-radius: 999px;
  display: inline-flex !important;
  align-items: center;
  justify-content: center;
  background: rgba(190, 43, 43, 0.08);
  color: #b3261e !important;
}

body.woocommerce-cart .product-remove a.remove:hover {
  background: rgba(190, 43, 43, 0.16);
  color: #8c1d18 !important;
}

body.woocommerce-cart .actions {
  padding-top: 20px !important;
}

body.woocommerce-cart .coupon {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
}

body.woocommerce-cart .coupon input.input-text {
  min-width: 180px;
}

body.woocommerce-cart .actions > .button,
body.woocommerce-cart .coupon .button {
  min-height: 50px;
}

body.woocommerce-cart .wc-proceed-to-checkout {
  padding-bottom: 0;
}

body.woocommerce-cart .wc-proceed-to-checkout a.checkout-button {
  width: 100%;
  min-height: 58px;
  font-size: 1.05rem;
}

body.woocommerce-checkout form.checkout {
  display: grid;
  grid-template-columns: minmax(0, 1.06fr) minmax(360px, 0.94fr);
  gap: 22px 24px;
  padding: 0;
  background: transparent;
  border: 0;
  box-shadow: none;
}

body.woocommerce-checkout #customer_details,
body.woocommerce-checkout #order_review_heading,
body.woocommerce-checkout .woocommerce-checkout-review-order {
  min-width: 0;
}

body.woocommerce-checkout #customer_details {
  grid-column: 1;
  grid-row: 1 / span 2;
  padding: 28px;
  border-radius: 28px;
  background: linear-gradient(180deg, rgba(255,255,255,.96), rgba(247,251,248,.92));
  border: 1px solid rgba(255,255,255,.82);
  box-shadow: 0 20px 44px rgba(21, 49, 38, 0.08);
}

body.woocommerce-checkout #order_review_heading {
  grid-column: 2;
  align-self: end;
  padding: 0 4px;
}

body.woocommerce-checkout .woocommerce-checkout-review-order {
  grid-column: 2;
  align-self: start;
  position: sticky;
  top: 108px;
  padding: 28px;
  border-radius: 28px;
  background: linear-gradient(180deg, rgba(255,255,255,.98), rgba(246,250,248,.94));
  border: 1px solid rgba(255,255,255,.82);
  box-shadow: 0 20px 44px rgba(21, 49, 38, 0.08);
}

body.woocommerce-checkout .col2-set,
body.woocommerce-checkout #customer_details .col-1,
body.woocommerce-checkout #customer_details .col-2 {
  width: 100%;
  float: none;
}

body.woocommerce-checkout #customer_details .col-2,
body.woocommerce-checkout .woocommerce-shipping-fields,
body.woocommerce-checkout #ship-to-different-address {
  display: none !important;
}

body.woocommerce-checkout .woocommerce-billing-fields > h3,
body.woocommerce-checkout .woocommerce-additional-fields > h3 {
  margin: 0 0 18px;
  font-size: 1.8rem;
  color: var(--text);
}

body.woocommerce-checkout .woocommerce-billing-fields__field-wrapper,
body.woocommerce-checkout .woocommerce-additional-fields__field-wrapper {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px 16px;
}

body.woocommerce-checkout .woocommerce-billing-fields__field-wrapper .form-row-wide,
body.woocommerce-checkout .woocommerce-additional-fields__field-wrapper .form-row-wide,
body.woocommerce-checkout .woocommerce-billing-fields__field-wrapper .woocommerce-input-wrapper,
body.woocommerce-checkout .woocommerce-additional-fields__field-wrapper .woocommerce-input-wrapper,
body.woocommerce-checkout .kb-delivery-box,
body.woocommerce-checkout .woocommerce-additional-fields {
  grid-column: 1 / -1;
}

body.woocommerce-checkout .woocommerce form .form-row-first,
body.woocommerce-checkout .woocommerce form .form-row-last,
body.woocommerce-checkout .woocommerce form .form-row-wide {
  width: 100%;
  float: none;
  margin: 0;
}

body.woocommerce form .form-row label {
  margin-bottom: 8px;
  font-size: .92rem;
  font-weight: 700;
  color: var(--text);
}

body.woocommerce form .input-text,
body.woocommerce form select,
body.woocommerce form textarea,
body.woocommerce .select2-container .select2-selection--single,
body.woocommerce .select2-container .select2-selection--multiple {
  min-height: 56px;
  border-radius: 16px;
  border: 1px solid rgba(23, 54, 42, 0.12);
  background: rgba(252,254,253,.96);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.64);
}

body.woocommerce form textarea {
  min-height: 120px;
  padding-top: 16px;
  resize: vertical;
}

body.woocommerce form .input-text,
body.woocommerce form select,
body.woocommerce form textarea,
body.woocommerce .select2-container .select2-selection--single {
  padding-left: 16px;
  padding-right: 16px;
}

body.woocommerce .select2-container--default .select2-selection--single .select2-selection__rendered {
  line-height: 54px;
  padding-left: 0;
  color: var(--text);
}

body.woocommerce .select2-container--default .select2-selection--single .select2-selection__arrow {
  height: 54px;
  right: 10px;
}

body.woocommerce form .input-text:focus,
body.woocommerce form select:focus,
body.woocommerce form textarea:focus,
body.woocommerce .select2-container--default.select2-container--focus .select2-selection--single,
body.woocommerce .select2-container--default.select2-container--open .select2-selection--single {
  border-color: rgba(33, 95, 77, 0.36);
  outline: none;
  box-shadow: 0 0 0 4px rgba(165, 223, 202, 0.22);
}

body.woocommerce-checkout .kb-delivery-box {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px 16px;
  margin-top: 18px;
  padding: 22px;
  border-radius: 22px;
  background: linear-gradient(180deg, rgba(236, 246, 250, 0.52), rgba(255,255,255,0.92));
  border: 1px solid rgba(23,54,42,.08);
}

body.woocommerce-checkout .kb-delivery-box h3 {
  grid-column: 1 / -1;
  margin: 0;
  font-size: 1.55rem;
}

body.woocommerce-checkout #payment {
  margin-top: 18px;
  border-radius: 22px;
  background: rgba(248, 252, 250, 0.9);
  border: 1px solid rgba(23,54,42,.08);
}

body.woocommerce-checkout #payment div.payment_box {
  border-radius: 16px;
  background: rgba(232, 237, 243, 0.55);
}

body.woocommerce-checkout #payment .place-order {
  padding-bottom: 0;
}

body.woocommerce-checkout #place_order {
  width: 100%;
  min-height: 58px;
  font-size: 1.02rem;
}

body.woocommerce-checkout .woocommerce-terms-and-conditions-wrapper,
body.woocommerce-checkout .woocommerce-privacy-policy-text {
  font-size: .92rem;
  color: var(--text-soft);
}

body.woocommerce-checkout .shop_table.woocommerce-checkout-review-order-table .product-total,
body.woocommerce-checkout .shop_table.woocommerce-checkout-review-order-table .order-total td,
body.woocommerce-cart .shop_table .product-subtotal,
body.woocommerce-cart .shop_table .product-price {
  font-weight: 700;
  color: var(--text);
}

body.woocommerce-checkout .shop_table.woocommerce-checkout-review-order-table .cart_item .product-name,
body.woocommerce-cart .shop_table .product-name {
  font-weight: 700;
}

body.woocommerce-checkout .shop_table.woocommerce-checkout-review-order-table .variation,
body.woocommerce-checkout .shop_table.woocommerce-checkout-review-order-table dl.variation,
body.woocommerce-cart .shop_table dl.variation {
  margin-top: 10px;
  font-size: .92rem;
  color: var(--text-soft);
}

@media (max-width: 980px) {
  body.woocommerce-cart .woocommerce,
  body.woocommerce-checkout form.checkout {
    grid-template-columns: 1fr;
  }

  body.woocommerce-cart .cart-collaterals,
  body.woocommerce-checkout #order_review_heading,
  body.woocommerce-checkout .woocommerce-checkout-review-order,
  body.woocommerce-checkout #customer_details {
    grid-column: 1;
    grid-row: auto;
  }

  body.woocommerce-cart .cart-collaterals .cart_totals,
  body.woocommerce-checkout .woocommerce-checkout-review-order {
    position: static;
  }
}

@media (max-width: 720px) {
  body.woocommerce-checkout #customer_details,
  body.woocommerce-checkout .woocommerce-checkout-review-order,
  body.woocommerce-cart .cart-collaterals .cart_totals,
  body.woocommerce-cart table.shop_table,
  body.woocommerce-checkout table.shop_table {
    padding: 18px;
    border-radius: 24px;
  }

  body.woocommerce-checkout .woocommerce-billing-fields__field-wrapper,
  body.woocommerce-checkout .woocommerce-additional-fields__field-wrapper,
  body.woocommerce-checkout .kb-delivery-box {
    grid-template-columns: 1fr;
  }

  body.woocommerce-cart .coupon {
    flex-direction: column;
    align-items: stretch;
  }

  body.woocommerce-cart .coupon input.input-text,
  body.woocommerce-cart .coupon .button,
  body.woocommerce-cart .actions > .button,
  body.woocommerce-checkout #place_order {
    width: 100%;
  }

  body.woocommerce-checkout #order_review_heading {
    margin-bottom: 12px;
  }
}


/* ===== 2026.04.08.2 CART THUMB FIX ===== */
body.woocommerce-cart table.cart .kb-cart-line-item,
body.woocommerce-checkout .kb-order-line-item {
  align-items: center;
}

body.woocommerce-cart table.cart .kb-cart-line-item__media,
body.woocommerce-checkout .kb-order-line-item__media {
  width: 72px !important;
  height: 72px !important;
  min-width: 72px !important;
  min-height: 72px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  overflow: hidden !important;
}

body.woocommerce-cart table.cart .kb-cart-line-item__media img,
body.woocommerce-checkout .kb-order-line-item__media img {
  display: block !important;
  width: 100% !important;
  height: 100% !important;
  min-width: 100% !important;
  min-height: 100% !important;
  max-width: none !important;
  object-fit: cover !important;
  border-radius: 0 !important;
  box-shadow: none !important;
}


/* ===== MOBILE RESPONSIVE FINAL FIX ===== */
.header-menu-toggle,
.mobile-menu-backdrop,
.mobile-menu-drawer { display: none; }

@media (max-width: 980px) {
  .site-header {
    padding: 8px 0 10px;
  }

  .site-header.is-scrolled {
    padding: 6px 0 8px;
  }

  .header-shell {
    gap: 10px;
    padding: 10px 12px;
    border-radius: 22px;
  }

  .site-logo {
    min-width: 0;
    flex: 1 1 auto;
    max-width: calc(100% - 172px);
  }

  .site-logo img {
    height: 44px !important;
    max-width: 100%;
  }

  .site-nav,
  .header-whatsapp--desktop {
    display: none !important;
  }

  .header-actions {
    width: auto !important;
    gap: 8px;
    margin-left: auto;
    flex: 0 0 auto;
  }

  .header-cart {
    width: 42px;
    height: 42px;
  }

  .header-lang-wrapper {
    min-width: 0;
    margin-left: 0;
  }

  .header-lang-wrapper .gtranslate_wrapper,
  .header-lang-wrapper .switcher,
  .header-lang-wrapper .gt_switcher,
  .header-lang-wrapper .skiptranslate,
  .header-lang-wrapper .notranslate {
    min-height: 42px !important;
    padding: 0 10px !important;
    border-radius: 14px !important;
  }

  .header-lang-wrapper select,
  .header-lang-wrapper .goog-te-combo,
  .header-lang-wrapper .gt_selector,
  .header-lang-wrapper .switcher .selected,
  .header-lang-wrapper .gt_switcher .selected {
    min-width: 68px !important;
    max-width: 78px;
    height: 34px !important;
    padding: 0 18px 0 24px !important;
    font-size: 0 !important;
    color: transparent !important;
  }

  .header-lang-wrapper img {
    width: 18px !important;
    height: 18px !important;
    margin-right: 0 !important;
  }

  .header-lang-wrapper::after {
    right: 10px;
    font-size: 11px;
  }

  .header-menu-toggle {
    display: inline-flex;
    width: 42px;
    height: 42px;
    align-items: center;
    justify-content: center;
    flex-direction: column;
    gap: 4px;
    border: 1px solid rgba(23,54,42,.08);
    border-radius: 14px;
    background: rgba(255,255,255,.88);
    box-shadow: 0 10px 22px rgba(18,56,42,.08);
  }

  .header-menu-toggle span {
    width: 18px;
    height: 2px;
    border-radius: 99px;
    background: var(--primary);
  }

  .mobile-menu-backdrop {
    position: fixed;
    inset: 0;
    background: rgba(12, 23, 18, 0.38);
    backdrop-filter: blur(4px);
    z-index: 140;
    opacity: 0;
    pointer-events: none;
    transition: opacity .25s ease;
  }

  .mobile-menu-drawer {
    position: fixed;
    top: 0;
    right: 0;
    width: min(88vw, 340px);
    height: 100dvh;
    padding: 18px 18px 22px;
    background: rgba(255,255,255,.98);
    box-shadow: -18px 0 40px rgba(18,56,42,.12);
    z-index: 150;
    transform: translateX(104%);
    transition: transform .28s ease;
    display: flex;
    flex-direction: column;
    gap: 18px;
  }

  .mobile-menu-drawer__head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    padding-bottom: 14px;
    border-bottom: 1px solid rgba(23,54,42,.08);
    font-weight: 800;
    color: var(--primary);
  }

  .mobile-menu-close {
    width: 40px;
    height: 40px;
    border: 0;
    border-radius: 12px;
    background: rgba(236,244,239,.9);
    color: var(--primary);
    font-size: 1.5rem;
    line-height: 1;
  }

  .mobile-menu-nav {
    display: grid;
    gap: 10px;
  }

  .mobile-menu-nav a {
    display: flex;
    align-items: center;
    min-height: 54px;
    padding: 0 16px;
    border-radius: 16px;
    background: #f6fbf8;
    border: 1px solid rgba(23,54,42,.08);
    color: var(--text);
    font-weight: 700;
  }

  body.mobile-menu-open {
    overflow: hidden;
  }

  body.mobile-menu-open .mobile-menu-backdrop {
    opacity: 1;
    pointer-events: auto;
    display: block;
  }

  body.mobile-menu-open .mobile-menu-drawer {
    transform: translateX(0);
    display: flex;
  }

  .home-hero,
  .store-hero,
  .about-hero {
    padding-top: 16px;
  }

  .home-hero__grid,
  .store-hero__grid,
  .about-hero__grid,
  .hero-wrapper--clean,
  .story-section--simple,
  .contact-grid-wrapper,
  .footer-grid {
    grid-template-columns: 1fr !important;
    gap: 18px !important;
  }

  .hero-wrapper--clean {
    padding: 16px !important;
    border-radius: 24px !important;
  }

  .hero-wrapper--clean .hero-image {
    order: -1;
    min-height: 280px !important;
  }

  .hero-wrapper--clean .hero-image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
  }

  .hero-actions {
    gap: 10px;
  }

  .hero-actions .hero-btn,
  .hero-actions .kb-btn {
    flex: 1 1 calc(50% - 5px);
    min-width: 0;
  }

  .store-grid,
  .home-vitrine-inline-grid,
  .catalog-row,
  .featured-row {
    gap: 12px !important;
  }

  .store-item,
  .home-vitrine-inline-card,
  .catalog-item,
  .featured-item {
    border-radius: 22px;
  }

  .catalog-item,
  .featured-item {
    flex-basis: 82%;
  }

  .contact-grid-wrapper iframe {
    min-height: 300px;
  }

  /* modal mobile */
  .modal {
    padding: 0 !important;
    align-items: flex-end !important;
    overflow: hidden;
  }

  .modal-content--premium,
  .modal-content {
    width: 100% !important;
    max-width: 100% !important;
    height: min(88dvh, 88vh) !important;
    max-height: min(88dvh, 88vh) !important;
    border-radius: 26px 26px 0 0 !important;
    grid-template-columns: 1fr !important;
    display: flex !important;
    flex-direction: column !important;
    overflow: hidden !important;
    margin: 0;
  }

  .modal-content--premium::before,
  .modal-content::before {
    content: '';
    width: 52px;
    height: 5px;
    border-radius: 99px;
    background: rgba(22,54,41,.16);
    position: absolute;
    left: 50%;
    top: 10px;
    transform: translateX(-50%);
    z-index: 5;
  }

  .modal-content--premium .close-btn,
  .modal-content .close-btn {
    top: 12px !important;
    right: 12px !important;
    width: 38px !important;
    height: 38px !important;
  }

  .modal-content--premium .modal-img-container,
  .modal-content .modal-img-container {
    flex: 0 0 auto;
    padding: 16px 14px 10px !important;
    border-right: 0 !important;
    border-bottom: 1px solid rgba(23,54,42,.07) !important;
    background: linear-gradient(180deg, #f7fbf8, #eef5f0) !important;
  }

  .modal-content--premium .main-img-box,
  .modal-content .main-img-box {
    height: 28dvh !important;
    min-height: 220px !important;
    max-height: 320px !important;
    border-radius: 18px !important;
    background: #fff !important;
    overflow: hidden;
  }

  .modal-content--premium .main-img-box img,
  .modal-content .main-img-box img {
    width: 100% !important;
    height: 100% !important;
    object-fit: contain !important;
    padding: 12px !important;
  }

  .modal-content--premium .thumbnails-row,
  .modal-content .thumbnails-row {
    display: flex !important;
    gap: 8px !important;
    padding: 10px 2px 0 !important;
    min-height: 0;
  }

  .modal-content--premium .thumb-btn,
  .modal-content .thumb-btn {
    flex: 0 0 62px !important;
    width: 62px !important;
    min-width: 62px !important;
    height: 62px !important;
    border-radius: 12px !important;
  }

  .modal-content--premium .modal-info,
  .modal-content .modal-info {
    flex: 1 1 auto !important;
    min-height: 0 !important;
    overflow-y: auto !important;
    -webkit-overflow-scrolling: touch;
    padding: 18px 16px 18px !important;
    gap: 12px !important;
  }

  .modal-content--premium .modal-info h2,
  .modal-content .modal-info h2 {
    font-size: clamp(2rem, 8vw, 2.6rem) !important;
    max-width: 100% !important;
    line-height: 1.02;
  }

  .modal-content--premium #modalDesc,
  .modal-content--premium #indexModalDesc,
  .modal-content #modalDesc,
  .modal-content #indexModalDesc {
    font-size: .95rem !important;
    line-height: 1.65 !important;
  }

  .modal-content--premium .modal-price,
  .modal-content .modal-price {
    position: sticky;
    top: 0;
    z-index: 2;
    background: linear-gradient(180deg, rgba(255,255,255,.98), rgba(255,255,255,.92));
    padding-bottom: 6px;
    margin-bottom: -2px;
  }

  .modal-content--premium .product-options,
  .modal-content .product-options {
    grid-template-columns: 1fr !important;
    gap: 12px !important;
  }

  .modal-content--premium .option-group label,
  .modal-content .option-group label {
    font-size: .92rem;
  }

  .modal-content--premium .option-group select,
  .modal-content--premium .option-group textarea,
  .modal-content .option-group select,
  .modal-content .option-group textarea {
    min-height: 52px !important;
    border-radius: 14px !important;
  }

  .modal-content--premium .option-group textarea,
  .modal-content .option-group textarea {
    min-height: 92px !important;
  }

  .modal-content--premium .modal-add-btn,
  .modal-content .modal-add-btn {
    position: sticky;
    bottom: 0;
    z-index: 2;
    width: 100% !important;
    min-height: 54px !important;
    margin-top: 4px !important;
    box-shadow: 0 -10px 22px rgba(255,255,255,.92), 0 12px 24px rgba(20,48,39,.12);
  }

  .modal-nav {
    width: 36px !important;
    height: 36px !important;
  }

  .modal-nav--prev { left: 8px !important; }
  .modal-nav--next { right: 8px !important; }

  body.woocommerce-cart table.shop_table,
  body.woocommerce-checkout table.shop_table {
    display: block;
    overflow-x: auto;
    white-space: nowrap;
  }
}

@media (max-width: 640px) {
  .container {
    width: min(calc(100% - 20px), var(--container));
  }

  .header-shell {
    padding: 8px 10px;
    gap: 8px;
  }

  .site-logo {
    max-width: calc(100% - 148px);
  }

  .site-logo img {
    height: 40px !important;
  }

  .header-cart,
  .header-menu-toggle {
    width: 40px;
    height: 40px;
  }

  .home-trust-strip__inner {
    grid-template-columns: 1fr;
  }

  .home-vitrine-inline-shell,
  .story-section--simple,
  .map-section--simple,
  .catalog-section--simple {
    padding-left: 0;
    padding-right: 0;
  }

  .catalog-item,
  .featured-item,
  .store-item {
    flex-basis: 88%;
  }

  .modal-content--premium .main-img-box,
  .modal-content .main-img-box {
    height: 26dvh !important;
    min-height: 210px !important;
  }
}


/* ===== MOBILE POLISH V10 ===== */
body.modal-open .site-header {
  opacity: 0;
  transform: translateY(-18px);
  pointer-events: none;
}

@media (max-width: 980px) {
  body {
    background:
      radial-gradient(circle at top left, rgba(214, 244, 234, 0.82), transparent 34%),
      radial-gradient(circle at top right, rgba(226, 240, 247, 0.82), transparent 30%),
      linear-gradient(180deg, #f7fbf8 0%, #f4faf7 34%, #f6fbf9 100%);
  }

  main {
    display: grid;
    gap: 14px;
    padding-bottom: 18px;
  }

  .site-header {
    padding: 6px 0 8px;
  }

  .site-header.is-scrolled {
    padding: 4px 0 6px;
  }

  .header-shell {
    gap: 8px;
    padding: 8px 10px;
    border-radius: 18px;
    background: rgba(255,255,255,0.82);
    border: 1px solid rgba(255,255,255,0.92);
    box-shadow: 0 12px 26px rgba(20,48,39,0.08);
  }

  .site-logo img {
    height: 42px !important;
  }

  .hero-wrapper--clean,
  .home-vitrine-inline-shell,
  .catalog-section--simple,
  .story-section--simple,
  .map-section--simple,
  .store-hero__grid,
  .store-section .container,
  .home-trust-strip__inner {
    position: relative;
    background: linear-gradient(180deg, rgba(255,255,255,0.94), rgba(248,252,249,0.88));
    border: 1px solid rgba(23,54,42,0.07);
    box-shadow: 0 16px 38px rgba(20,48,39,0.06);
    overflow: hidden;
  }

  .hero-wrapper--clean::after,
  .home-vitrine-inline-shell::after,
  .catalog-section--simple::after,
  .story-section--simple::after,
  .map-section--simple::after,
  .store-hero__grid::after,
  .store-section .container::after,
  .home-trust-strip__inner::after {
    content: '';
    position: absolute;
    inset: auto 18px -18px;
    height: 24px;
    border-radius: 999px;
    background: linear-gradient(180deg, rgba(179, 235, 216, 0.14), rgba(179, 235, 216, 0));
    filter: blur(18px);
    pointer-events: none;
  }

  .hero-wrapper--clean,
  .store-hero__grid {
    padding: 16px !important;
    border-radius: 24px !important;
  }

  .home-vitrine-inline-section,
  .home-trust-strip,
  .catalog-section--simple,
  .story-section--simple,
  .map-section--simple,
  .store-section {
    width: min(calc(100% - 20px), 1240px);
    margin: 0 auto !important;
  }

  .home-vitrine-inline-shell,
  .catalog-section--simple,
  .story-section--simple,
  .map-section--simple,
  .store-section .container {
    border-radius: 24px !important;
    padding: 16px !important;
  }

  .home-trust-strip__inner {
    border-radius: 22px;
    padding: 12px;
    gap: 10px;
  }

  .home-trust-pill {
    min-height: 52px;
    background: rgba(255,255,255,0.92);
    border: 1px solid rgba(23,54,42,0.06);
    border-radius: 16px;
  }

  .catalog-section--simple .slider-wrapper,
  .map-section--simple .contact-grid-wrapper,
  .story-section--simple {
    margin-top: 14px;
  }

  .store-item,
  .home-vitrine-inline-card,
  .catalog-item,
  .featured-item,
  .review-box,
  .map-box {
    border-radius: 20px !important;
    box-shadow: 0 14px 26px rgba(20,48,39,0.06) !important;
  }

  .modal {
    padding: 0 !important;
    align-items: flex-end !important;
    overflow: hidden !important;
  }

  .modal-content--premium,
  .modal-content {
    width: 100% !important;
    max-width: 100% !important;
    min-height: 100dvh !important;
    height: 100dvh !important;
    max-height: 100dvh !important;
    padding-bottom: max(12px, env(safe-area-inset-bottom)) !important;
    border-radius: 24px 24px 0 0 !important;
    grid-template-columns: 1fr !important;
    display: flex !important;
    flex-direction: column !important;
    overflow: hidden !important;
    margin: 0 !important;
    background: linear-gradient(180deg, rgba(255,255,255,0.99), rgba(250,252,251,0.99)) !important;
  }

  .modal-content--premium::before,
  .modal-content::before {
    top: 8px !important;
  }

  .modal-content--premium .close-btn,
  .modal-content .close-btn {
    top: 14px !important;
    right: 14px !important;
    width: 40px !important;
    height: 40px !important;
    z-index: 8 !important;
  }

  .modal-content--premium .modal-img-container,
  .modal-content .modal-img-container {
    flex: 0 0 auto !important;
    padding: 18px 14px 8px !important;
    border-right: 0 !important;
    border-bottom: 1px solid rgba(23,54,42,.06) !important;
    background: linear-gradient(180deg, #f8fcfa 0%, #eef7f2 100%) !important;
  }

  .modal-content--premium .main-img-box,
  .modal-content .main-img-box {
    height: clamp(210px, 33vh, 290px) !important;
    min-height: 210px !important;
    max-height: 290px !important;
    border-radius: 18px !important;
    background: #fff !important;
    overflow: hidden !important;
  }

  .modal-content--premium .main-img-box img,
  .modal-content .main-img-box img {
    width: 100% !important;
    height: 100% !important;
    object-fit: contain !important;
    padding: 10px !important;
  }

  .modal-content--premium .thumbnails-row,
  .modal-content .thumbnails-row {
    display: flex !important;
    gap: 8px !important;
    padding: 10px 0 0 !important;
    min-height: 70px !important;
    overflow-x: auto !important;
  }

  .modal-content--premium .thumb-btn,
  .modal-content .thumb-btn {
    flex: 0 0 58px !important;
    width: 58px !important;
    min-width: 58px !important;
    height: 58px !important;
    border-radius: 12px !important;
  }

  .modal-content--premium .modal-info,
  .modal-content .modal-info {
    flex: 1 1 auto !important;
    min-height: 0 !important;
    display: flex !important;
    flex-direction: column !important;
    justify-content: flex-start !important;
    overflow-y: auto !important;
    -webkit-overflow-scrolling: touch;
    padding: 14px 16px calc(18px + env(safe-area-inset-bottom)) !important;
    gap: 14px !important;
  }

  .modal-content--premium .modal-info h2,
  .modal-content .modal-info h2 {
    font-size: clamp(1.95rem, 8vw, 2.45rem) !important;
    line-height: 0.98 !important;
    max-width: 100% !important;
  }

  .modal-content--premium #modalDesc,
  .modal-content--premium #indexModalDesc,
  .modal-content #modalDesc,
  .modal-content #indexModalDesc {
    font-size: 0.94rem !important;
    line-height: 1.62 !important;
  }

  .modal-content--premium .modal-price,
  .modal-content .modal-price {
    position: static !important;
    background: transparent !important;
    padding: 0 !important;
    margin: 0 !important;
    gap: 10px !important;
  }

  .modal-price-old {
    font-size: 0.98rem !important;
  }

  .modal-price-new {
    font-size: 1.5rem !important;
  }

  .modal-content--premium .product-options,
  .modal-content .product-options {
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 12px !important;
  }

  .modal-content--premium .option-group,
  .modal-content .option-group {
    gap: 8px !important;
  }

  .modal-content--premium .option-group label,
  .modal-content .option-group label {
    font-size: 0.9rem !important;
    font-weight: 700 !important;
  }

  .modal-content--premium .option-group select,
  .modal-content--premium .option-group textarea,
  .modal-content .option-group select,
  .modal-content .option-group textarea {
    min-height: 50px !important;
    border-radius: 14px !important;
    background: #fbfdfc !important;
  }

  .modal-content--premium .option-group textarea,
  .modal-content .option-group textarea {
    min-height: 88px !important;
  }

  .modal-content--premium .modal-add-btn,
  .modal-content .modal-add-btn {
    position: sticky !important;
    bottom: 0 !important;
    z-index: 3 !important;
    width: 100% !important;
    min-height: 54px !important;
    margin-top: auto !important;
    border-radius: 16px !important;
    box-shadow: 0 -8px 18px rgba(255,255,255,.95), 0 14px 24px rgba(20,48,39,.10) !important;
  }

  .modal-nav {
    width: 34px !important;
    height: 34px !important;
  }

  .modal-nav--prev {
    left: 8px !important;
  }

  .modal-nav--next {
    right: 8px !important;
  }
}

@media (max-width: 640px) {
  .hero-wrapper--clean .hero-text h1 {
    font-size: clamp(2.8rem, 12vw, 3.8rem) !important;
  }

  .hero-wrapper--clean .hero-image {
    min-height: 240px !important;
    aspect-ratio: 0.92 !important;
  }

  .home-vitrine-inline-shell,
  .catalog-section--simple,
  .story-section--simple,
  .map-section--simple,
  .store-section .container,
  .hero-wrapper--clean,
  .store-hero__grid {
    border-radius: 22px !important;
    padding: 14px !important;
  }

  .modal-content--premium .main-img-box,
  .modal-content .main-img-box {
    height: 220px !important;
    min-height: 220px !important;
  }
}


/* ===== MOBILE REBUILD FINAL V11 ===== */
html, body {
  max-width: 100%;
  overflow-x: clip;
}
body,
.site,
.site-main,
main,
section,
div,
article {
  box-sizing: border-box;
}

@media (max-width: 980px) {
  body {
    background:
      radial-gradient(circle at top left, rgba(216,242,233,.78), transparent 36%),
      radial-gradient(circle at top right, rgba(226,239,247,.78), transparent 30%),
      linear-gradient(180deg, #f7fbf8 0%, #f4faf7 52%, #f8fbfa 100%);
  }

  main {
    display: grid;
    gap: 16px;
    padding-bottom: 20px;
  }

  .container,
  .header-shell,
  .store-hero__grid,
  .store-section .container,
  .hero-wrapper--clean,
  .home-vitrine-inline-shell,
  .catalog-section--simple,
  .story-section--simple,
  .map-section--simple,
  .home-trust-strip,
  .home-trust-strip__inner,
  .contact-grid-wrapper,
  .store-grid,
  .store-item,
  .store-item__body,
  .store-item__footer,
  .store-item__image,
  .modal,
  .modal-content,
  .modal-content--premium,
  .modal-info,
  .modal-img-container,
  .main-img-box,
  .thumbnails-row,
  .product-options,
  .option-group,
  .catalog-row,
  .slider-wrapper {
    max-width: 100%;
    min-width: 0;
  }

  .site-header {
    top: 0;
    padding: 8px 0 10px !important;
  }

  .header-shell {
    display: grid !important;
    grid-template-columns: minmax(0,1fr) auto auto auto;
    align-items: center;
    gap: 8px !important;
    padding: 8px 10px !important;
    border-radius: 18px !important;
    background: rgba(255,255,255,.88) !important;
    border: 1px solid rgba(255,255,255,.96) !important;
    box-shadow: 0 12px 26px rgba(20,48,39,.08) !important;
  }

  .site-logo {
    min-width: 0 !important;
    max-width: none !important;
    flex: none !important;
  }

  .site-logo img {
    width: auto !important;
    max-width: 100% !important;
    height: 44px !important;
    object-fit: contain !important;
  }

  .site-nav,
  .header-whatsapp--desktop {
    display: none !important;
  }

  .header-actions {
    display: contents !important;
  }

  .header-lang-wrapper {
    order: 2;
    margin: 0 !important;
  }

  .header-cart {
    order: 3;
    width: 42px !important;
    height: 42px !important;
    border-radius: 14px !important;
  }

  .header-menu-toggle {
    order: 4;
    display: inline-flex !important;
    width: 42px !important;
    height: 42px !important;
    align-items: center;
    justify-content: center;
    flex-direction: column;
    gap: 4px;
    border: 1px solid rgba(23,54,42,.08);
    border-radius: 14px;
    background: rgba(255,255,255,.92);
    box-shadow: 0 10px 22px rgba(18,56,42,.08);
  }

  .header-menu-toggle span {
    width: 18px;
    height: 2px;
    border-radius: 99px;
    background: var(--primary);
  }

  .header-lang-wrapper .gtranslate_wrapper,
  .header-lang-wrapper .switcher,
  .header-lang-wrapper .gt_switcher,
  .header-lang-wrapper .skiptranslate,
  .header-lang-wrapper .notranslate {
    min-height: 42px !important;
    padding: 0 10px !important;
    border-radius: 14px !important;
    background: rgba(255,255,255,.92) !important;
    border: 1px solid rgba(23,54,42,.08) !important;
  }

  .header-lang-wrapper select,
  .header-lang-wrapper .goog-te-combo,
  .header-lang-wrapper .gt_selector,
  .header-lang-wrapper .switcher .selected,
  .header-lang-wrapper .gt_switcher .selected {
    min-width: 64px !important;
    max-width: 74px !important;
    height: 34px !important;
    padding: 0 18px 0 22px !important;
    font-size: 0 !important;
    color: transparent !important;
  }

  .mobile-menu-backdrop {
    display: block !important;
    position: fixed;
    inset: 0;
    z-index: 110;
    background: rgba(17,34,28,.38);
    opacity: 0;
    visibility: hidden;
    transition: opacity .24s ease, visibility .24s ease;
  }

  .mobile-menu-drawer {
    display: flex !important;
    position: fixed;
    top: 0;
    right: 0;
    z-index: 111;
    width: min(86vw, 360px);
    height: 100dvh;
    padding: 18px;
    flex-direction: column;
    gap: 16px;
    background: rgba(255,255,255,.98);
    border-left: 1px solid rgba(23,54,42,.08);
    box-shadow: -20px 0 44px rgba(17,34,28,.16);
    transform: translateX(100%);
    transition: transform .26s ease;
  }

  .mobile-menu-drawer__head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding-bottom: 12px;
    border-bottom: 1px solid rgba(23,54,42,.08);
    font-weight: 800;
    color: var(--primary);
  }

  .mobile-menu-close {
    width: 40px;
    height: 40px;
    border: 0;
    border-radius: 12px;
    background: rgba(239,246,242,.92);
    color: var(--primary);
    font-size: 1.6rem;
  }

  .mobile-menu-nav {
    display: grid;
    gap: 10px;
  }

  .mobile-menu-nav a {
    display: flex;
    align-items: center;
    min-height: 50px;
    padding: 0 16px;
    border-radius: 16px;
    background: rgba(247,251,248,.95);
    border: 1px solid rgba(23,54,42,.06);
    font-weight: 700;
    color: var(--text);
  }

  body.mobile-menu-open {
    overflow: hidden;
  }

  body.mobile-menu-open .mobile-menu-backdrop {
    opacity: 1;
    visibility: visible;
  }

  body.mobile-menu-open .mobile-menu-drawer {
    transform: translateX(0);
  }

  .hero-wrapper--clean,
  .home-vitrine-inline-shell,
  .catalog-section--simple,
  .story-section--simple,
  .map-section--simple,
  .store-hero__grid,
  .store-section .container,
  .home-trust-strip__inner {
    background: linear-gradient(180deg, rgba(255,255,255,.96), rgba(248,252,249,.92)) !important;
    border: 1px solid rgba(23,54,42,.07) !important;
    box-shadow: 0 14px 34px rgba(20,48,39,.06) !important;
    border-radius: 24px !important;
    overflow: hidden;
  }

  .hero-wrapper--clean,
  .store-hero__grid,
  .home-vitrine-inline-shell,
  .catalog-section--simple,
  .story-section--simple,
  .map-section--simple,
  .store-section .container {
    padding: 14px !important;
  }

  .home-vitrine-inline-section,
  .home-trust-strip,
  .catalog-section--simple,
  .story-section--simple,
  .map-section--simple,
  .store-section,
  .store-hero {
    width: min(calc(100% - 20px), 1240px);
    margin: 0 auto !important;
  }

  .store-hero__grid,
  .hero-wrapper--clean,
  .story-section--simple,
  .contact-grid-wrapper {
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 14px !important;
  }

  .hero-wrapper--clean .hero-image,
  .store-hero__visual,
  .story-image,
  .about-row__image {
    min-height: 250px !important;
    aspect-ratio: 0.92 !important;
  }

  .filter-bar {
    flex-wrap: nowrap !important;
    overflow-x: auto !important;
    gap: 10px !important;
    padding-bottom: 4px;
    scrollbar-width: none;
  }
  .filter-bar::-webkit-scrollbar { display: none; }

  .filter-btn {
    flex: 0 0 auto;
    min-height: 40px !important;
    padding: 0 14px !important;
    border-radius: 999px !important;
  }

  .store-grid {
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 14px !important;
    overflow: visible !important;
  }

  .store-item {
    grid-column: 1 / -1 !important;
    display: grid !important;
    gap: 0 !important;
    border-radius: 22px !important;
    overflow: hidden !important;
  }

  .store-item__image {
    aspect-ratio: 0.92 !important;
    width: 100% !important;
    min-width: 0 !important;
  }

  .store-item__image img {
    width: 100% !important;
    height: 100% !important;
    object-fit: cover !important;
  }

  .store-item__body {
    padding: 16px !important;
    gap: 10px !important;
  }

  .store-item__body h3 {
    font-size: clamp(1.55rem, 7vw, 2rem) !important;
    line-height: 1.02 !important;
  }

  .store-item__body p {
    font-size: .95rem !important;
    line-height: 1.55 !important;
  }

  .store-item__footer {
    display: grid !important;
    grid-template-columns: 1fr auto !important;
    align-items: center !important;
    gap: 12px !important;
  }

  .store-price {
    font-size: 1.28rem !important;
  }

  .catalog-row,
  .home-vitrine-inline-grid {
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 12px !important;
    overflow: visible !important;
  }

  .catalog-item,
  .home-vitrine-inline-card,
  .featured-item {
    width: 100% !important;
    max-width: 100% !important;
    grid-column: 1 / -1 !important;
    flex-basis: auto !important;
  }

  .modal {
    padding: 0 !important;
    align-items: flex-end !important;
    justify-content: stretch !important;
    background: rgba(18,34,28,.72) !important;
  }

  .modal-content,
  .modal-content--premium {
    display: block !important;
    width: 100% !important;
    max-width: 100% !important;
    height: 100dvh !important;
    max-height: 100dvh !important;
    min-height: 100dvh !important;
    margin: 0 !important;
    overflow-y: auto !important;
    overflow-x: hidden !important;
    border-radius: 24px 24px 0 0 !important;
    background: linear-gradient(180deg, rgba(255,255,255,.995), rgba(249,252,250,.995)) !important;
    -webkit-overflow-scrolling: touch;
  }

  .modal-content::before,
  .modal-content--premium::before {
    content: '';
    position: sticky;
    top: 8px;
    display: block;
    width: 64px;
    height: 6px;
    margin: 8px auto 10px;
    border-radius: 999px;
    background: rgba(76,109,97,.22);
    z-index: 6;
  }

  .modal-content .close-btn,
  .modal-content--premium .close-btn {
    position: sticky !important;
    top: 10px !important;
    margin-left: auto !important;
    margin-right: 14px !important;
    right: auto !important;
    display: flex !important;
    align-items: center;
    justify-content: center;
    width: 40px !important;
    height: 40px !important;
    z-index: 8 !important;
  }

  .modal-img-container,
  .modal-content .modal-img-container,
  .modal-content--premium .modal-img-container {
    display: block !important;
    padding: 0 14px 10px !important;
    background: linear-gradient(180deg, #f8fcfa 0%, #eef7f2 100%) !important;
    border: 0 !important;
  }

  .main-img-box,
  .modal-content .main-img-box,
  .modal-content--premium .main-img-box {
    position: relative;
    height: clamp(220px, 36vh, 320px) !important;
    min-height: 220px !important;
    max-height: 320px !important;
    border-radius: 18px !important;
    overflow: hidden !important;
    background: #fff !important;
  }

  .main-img-box img,
  .modal-content .main-img-box img,
  .modal-content--premium .main-img-box img {
    width: 100% !important;
    height: 100% !important;
    object-fit: contain !important;
    padding: 12px !important;
  }

  .thumbnails-row,
  .modal-content .thumbnails-row,
  .modal-content--premium .thumbnails-row {
    display: flex !important;
    gap: 8px !important;
    padding: 10px 0 0 !important;
    overflow-x: auto !important;
    scrollbar-width: none;
  }
  .thumbnails-row::-webkit-scrollbar { display: none; }

  .thumb-btn,
  .modal-content .thumb-btn,
  .modal-content--premium .thumb-btn {
    flex: 0 0 58px !important;
    width: 58px !important;
    min-width: 58px !important;
    height: 58px !important;
    border-radius: 12px !important;
  }

  .modal-info,
  .modal-content .modal-info,
  .modal-content--premium .modal-info {
    display: flex !important;
    flex-direction: column !important;
    gap: 14px !important;
    padding: 14px 16px calc(20px + env(safe-area-inset-bottom)) !important;
    overflow: visible !important;
    min-height: auto !important;
  }

  .modal-info h2,
  .modal-content .modal-info h2,
  .modal-content--premium .modal-info h2 {
    font-size: clamp(1.9rem, 8vw, 2.45rem) !important;
    line-height: 1 !important;
    max-width: 100% !important;
  }

  #modalDesc,
  #indexModalDesc {
    font-size: .95rem !important;
    line-height: 1.62 !important;
  }

  .modal-price {
    display: flex !important;
    flex-wrap: wrap !important;
    align-items: baseline !important;
    gap: 10px !important;
    margin: 0 !important;
  }

  .modal-price-old { font-size: .98rem !important; }
  .modal-price-new { font-size: 1.5rem !important; }

  .product-options,
  .modal-content .product-options,
  .modal-content--premium .product-options {
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 12px !important;
  }

  .option-group { gap: 8px !important; }

  .option-group select,
  .option-group textarea {
    min-height: 52px !important;
    border-radius: 14px !important;
    background: #fbfdfc !important;
  }

  .option-group textarea { min-height: 96px !important; }

  .modal-add-btn,
  .modal-content .modal-add-btn,
  .modal-content--premium .modal-add-btn {
    position: sticky !important;
    bottom: max(10px, env(safe-area-inset-bottom)) !important;
    z-index: 5 !important;
    width: 100% !important;
    min-height: 54px !important;
    border-radius: 16px !important;
    margin-top: 6px !important;
    box-shadow: 0 -10px 18px rgba(255,255,255,.96), 0 14px 24px rgba(20,48,39,.10) !important;
  }

  .modal-nav {
    width: 34px !important;
    height: 34px !important;
  }

  .modal-nav--prev { left: 8px !important; }
  .modal-nav--next { right: 8px !important; }

  body.modal-open .site-header {
    opacity: 0 !important;
    transform: translateY(-18px) !important;
    pointer-events: none !important;
  }

  body.woocommerce-cart table.shop_table,
  body.woocommerce-checkout table.shop_table {
    display: block;
    overflow-x: auto;
    white-space: nowrap;
  }
}

@media (max-width: 640px) {
  .container {
    width: min(calc(100% - 20px), var(--container)) !important;
  }

  .site-logo img {
    height: 40px !important;
  }

  .header-cart,
  .header-menu-toggle {
    width: 40px !important;
    height: 40px !important;
  }

  .hero-wrapper--clean .hero-text h1 {
    font-size: clamp(2.7rem, 12vw, 3.7rem) !important;
  }

  .hero-wrapper--clean .hero-image,
  .store-hero__visual,
  .story-image,
  .about-row__image {
    min-height: 230px !important;
  }

  .modal-content,
  .modal-content--premium {
    border-radius: 22px 22px 0 0 !important;
  }

  .main-img-box,
  .modal-content .main-img-box,
  .modal-content--premium .main-img-box {
    height: 240px !important;
    min-height: 240px !important;
  }
}

/* ===== MOBILE REBUILD FINAL OVERRIDES v12 ===== */
html, body {
  max-width: 100%;
  overflow-x: hidden !important;
}

@media (max-width: 760px) {
  body {
    background:
      linear-gradient(180deg, #eef7f2 0%, #f7fbf8 24%, #f5faf8 100%) !important;
  }

  .site-header {
    padding: 10px 0 !important;
  }

  .header-shell {
    display: grid !important;
    grid-template-columns: minmax(0,1fr) auto auto auto !important;
    align-items: center !important;
    gap: 10px !important;
    padding: 12px 14px !important;
    border-radius: 26px !important;
  }

  .site-logo {
    min-width: 0 !important;
    max-width: 140px !important;
  }

  .site-logo img {
    width: auto !important;
    height: 34px !important;
    max-width: 100% !important;
  }

  .site-nav,
  .header-whatsapp--desktop {
    display: none !important;
  }

  .header-actions {
    justify-content: flex-end !important;
    gap: 8px !important;
  }

  .header-lang-wrapper {
    min-width: 62px !important;
    max-width: 74px !important;
    overflow: hidden !important;
  }

  .header-lang-wrapper * {
    max-width: 100% !important;
  }

  .header-cart,
  .header-menu-toggle {
    width: 44px !important;
    height: 44px !important;
    border-radius: 16px !important;
  }

  .header-menu-toggle {
    border: 1px solid rgba(23,54,42,.08) !important;
    background: rgba(255,255,255,.88) !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    flex-direction: column !important;
    gap: 5px !important;
  }

  .header-menu-toggle span {
    display: block !important;
    width: 18px !important;
    height: 2px !important;
    border-radius: 999px !important;
    background: var(--primary) !important;
  }

  .mobile-menu-drawer {
    width: min(88vw, 340px) !important;
    padding: 18px 16px 22px !important;
  }

  .mobile-menu-nav {
    gap: 8px !important;
  }

  .mobile-menu-nav a {
    min-height: 52px !important;
    border-radius: 16px !important;
    padding: 0 16px !important;
    background: rgba(240,247,243,.88) !important;
  }

  .home-hero,
  .store-hero,
  .about-hero {
    padding: 8px 0 14px !important;
  }

  .hero-wrapper--clean,
  .store-hero__grid,
  .about-hero__grid,
  .story-section--simple {
    grid-template-columns: 1fr !important;
    gap: 16px !important;
  }

  .hero-wrapper--clean,
  .home-vitrine-inline-shell,
  .story-section,
  .map-box,
  .review-box,
  .store-item,
  .store-hero__copy,
  .about-row__copy {
    border-radius: 24px !important;
  }

  .hero-wrapper--clean {
    padding: 18px 16px !important;
  }

  .hero-wrapper--clean .hero-image,
  .store-hero__visual,
  .story-image,
  .about-row__image {
    min-height: 220px !important;
    max-height: 260px !important;
    overflow: hidden !important;
    border-radius: 22px !important;
  }

  .hero-wrapper--clean .hero-image img,
  .store-hero__visual img,
  .story-image img,
  .about-row__image img {
    width: 100% !important;
    height: 100% !important;
    object-fit: cover !important;
  }

  .hero-wrapper--clean .hero-text h1,
  .store-hero__copy h1,
  .about-hero__copy h1 {
    font-size: clamp(2.2rem, 10vw, 3.25rem) !important;
    line-height: .92 !important;
    overflow-wrap: anywhere !important;
  }

  .hero-wrapper--clean .hero-text p,
  .store-hero__copy p,
  .about-hero__copy p {
    font-size: 1rem !important;
  }

  .hero-actions {
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 10px !important;
    margin-top: 18px !important;
  }

  .hero-actions .kb-btn,
  .hero-actions .hero-btn {
    width: 100% !important;
  }

  /* index: vitrin ve altı mobilde yatay kaydırmalı */
  .home-vitrine-inline-grid,
  .catalog-row,
  .story-section,
  .contact-grid-wrapper,
  .home-trust-strip__inner {
    display: flex !important;
    flex-wrap: nowrap !important;
    gap: 12px !important;
    overflow-x: auto !important;
    overflow-y: hidden !important;
    scroll-snap-type: x proximity !important;
    padding-bottom: 4px !important;
    -webkit-overflow-scrolling: touch !important;
    scrollbar-width: none !important;
  }

  .home-vitrine-inline-grid::-webkit-scrollbar,
  .catalog-row::-webkit-scrollbar,
  .story-section::-webkit-scrollbar,
  .contact-grid-wrapper::-webkit-scrollbar,
  .home-trust-strip__inner::-webkit-scrollbar,
  .filter-bar::-webkit-scrollbar,
  .thumbnails-row::-webkit-scrollbar {
    display: none !important;
  }

  .home-vitrine-inline-card,
  .catalog-item,
  .story-text,
  .story-image,
  .map-box,
  .review-box {
    flex: 0 0 84% !important;
    max-width: 84% !important;
    scroll-snap-align: start !important;
  }

  .home-trust-pill {
    flex: 0 0 auto !important;
    white-space: nowrap !important;
  }

  .catalog-section,
  .map-section,
  .story-section,
  .home-vitrine-inline-section,
  .home-trust-strip {
    margin-top: 14px !important;
    margin-bottom: 14px !important;
  }

  .slider-wrapper {
    overflow: visible !important;
  }

  .scroll-hint-btn {
    display: none !important;
  }

  /* mağaza mobil */
  .store-hero__grid {
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 14px !important;
  }

  .store-hero__visual {
    display: none !important;
  }

  .store-hero__copy {
    padding: 18px 16px !important;
  }

  .filter-bar {
    flex-wrap: nowrap !important;
    overflow-x: auto !important;
    gap: 10px !important;
    padding-bottom: 2px !important;
    margin-bottom: 14px !important;
  }

  .filter-btn {
    flex: 0 0 auto !important;
    min-height: 44px !important;
    padding: 0 18px !important;
  }

  .store-grid {
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 14px !important;
    overflow: visible !important;
  }

  .store-item {
    width: 100% !important;
    max-width: 100% !important;
    overflow: hidden !important;
  }

  .store-item__image {
    width: 100% !important;
    min-width: 0 !important;
    aspect-ratio: .9 !important;
  }

  .store-item__image img {
    width: 100% !important;
    height: 100% !important;
    object-fit: cover !important;
  }

  .store-item__body {
    padding: 16px !important;
    display: grid !important;
    gap: 10px !important;
  }

  .store-item__body h3 {
    font-size: clamp(1.8rem, 8vw, 2.35rem) !important;
    line-height: 1 !important;
  }

  .store-item__footer {
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    gap: 10px !important;
  }

  .store-item__footer .kb-btn {
    min-height: 44px !important;
  }

  /* modal mobil: foto + içerik tek ekranda görünür */
  .modal {
    z-index: 999999 !important;
  }

  .modal.modal-mobile-active {
    align-items: flex-end !important;
    justify-content: stretch !important;
    padding: 0 !important;
    background: rgba(17, 33, 28, 0.78) !important;
  }

  .modal.modal-mobile-active .modal-content,
  .modal.modal-mobile-active .modal-content--premium {
    display: flex !important;
    flex-direction: column !important;
    width: 100% !important;
    max-width: 100% !important;
    height: 100dvh !important;
    min-height: 100dvh !important;
    max-height: 100dvh !important;
    margin: 0 !important;
    border-radius: 24px 24px 0 0 !important;
    overflow: hidden !important;
    background: linear-gradient(180deg, #ffffff 0%, #f8fcfa 100%) !important;
  }

  .modal.modal-mobile-active .modal-content::before,
  .modal.modal-mobile-active .modal-content--premium::before {
    content: '' !important;
    position: absolute !important;
    left: 50% !important;
    top: 8px !important;
    transform: translateX(-50%) !important;
    width: 60px !important;
    height: 6px !important;
    border-radius: 999px !important;
    background: rgba(89,112,102,.22) !important;
    z-index: 8 !important;
  }

  .modal.modal-mobile-active .close-btn {
    position: absolute !important;
    top: 14px !important;
    right: 14px !important;
    margin: 0 !important;
    width: 42px !important;
    height: 42px !important;
    z-index: 10 !important;
  }

  .modal.modal-mobile-active .modal-img-container {
    flex: 0 0 auto !important;
    display: block !important;
    padding: 20px 14px 10px !important;
    background: linear-gradient(180deg, #f6fbf8 0%, #edf6f2 100%) !important;
    border: 0 !important;
  }

  .modal.modal-mobile-active .main-img-box {
    position: relative !important;
    height: 180px !important;
    min-height: 180px !important;
    max-height: 180px !important;
    border-radius: 18px !important;
    overflow: hidden !important;
    background: #ffffff !important;
  }

  .modal.modal-mobile-active .main-img-box img {
    width: 100% !important;
    height: 100% !important;
    object-fit: contain !important;
    padding: 8px !important;
  }

  .modal.modal-mobile-active .thumbnails-row {
    display: none !important;
  }

  .modal.modal-mobile-active .modal-nav {
    width: 36px !important;
    height: 36px !important;
  }

  .modal.modal-mobile-active .modal-nav--prev { left: 10px !important; }
  .modal.modal-mobile-active .modal-nav--next { right: 10px !important; }

  .modal.modal-mobile-active .modal-info {
    display: flex !important;
    flex: 1 1 auto !important;
    min-height: 0 !important;
    padding: 16px 16px calc(90px + env(safe-area-inset-bottom)) !important;
    gap: 12px !important;
    overflow-y: auto !important;
    overflow-x: hidden !important;
    -webkit-overflow-scrolling: touch !important;
    background: #ffffff !important;
  }

  .modal.modal-mobile-active .modal-info h2 {
    font-size: clamp(2rem, 8vw, 2.6rem) !important;
    line-height: .96 !important;
    max-width: 100% !important;
  }

  .modal.modal-mobile-active #modalDesc,
  .modal.modal-mobile-active #indexModalDesc {
    font-size: 1rem !important;
    line-height: 1.58 !important;
  }

  .modal.modal-mobile-active .modal-price {
    display: flex !important;
    flex-wrap: wrap !important;
    gap: 8px !important;
    margin: 0 !important;
  }

  .modal.modal-mobile-active .modal-price-new {
    font-size: 1.55rem !important;
  }

  .modal.modal-mobile-active .product-options {
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 12px !important;
  }

  .modal.modal-mobile-active .option-group {
    display: grid !important;
    gap: 8px !important;
  }

  .modal.modal-mobile-active .option-group label {
    font-size: .9rem !important;
    font-weight: 700 !important;
  }

  .modal.modal-mobile-active .option-group select,
  .modal.modal-mobile-active .option-group textarea {
    min-height: 52px !important;
    padding: 13px 14px !important;
    border-radius: 14px !important;
    background: #fbfdfc !important;
  }

  .modal.modal-mobile-active .option-group textarea {
    min-height: 92px !important;
  }

  .modal.modal-mobile-active .modal-add-btn {
    position: sticky !important;
    bottom: max(12px, env(safe-area-inset-bottom)) !important;
    width: 100% !important;
    min-height: 54px !important;
    border-radius: 16px !important;
    margin-top: auto !important;
    box-shadow: 0 -10px 20px rgba(255,255,255,.94), 0 12px 28px rgba(20,48,39,.12) !important;
  }

  body.kb-mobile-modal .site-header {
    opacity: 0 !important;
    pointer-events: none !important;
    transform: translateY(-16px) !important;
  }
}

@media (max-width: 420px) {
  .home-vitrine-inline-card,
  .catalog-item,
  .story-text,
  .story-image,
  .map-box,
  .review-box {
    flex-basis: 88% !important;
    max-width: 88% !important;
  }

  .modal.modal-mobile-active .main-img-box {
    height: 168px !important;
    min-height: 168px !important;
    max-height: 168px !important;
  }

  .modal.modal-mobile-active .modal-info h2 {
    font-size: clamp(1.85rem, 8vw, 2.25rem) !important;
  }
}

/* =========================================================
   KB SHOP LEGACY RESPONSIVE FIX - V13
   ========================================================= */
.kb-shop-page {
  position: relative;
  z-index: 1;
}

.kb-shop-hero {
  padding: 34px 0 20px;
}

.kb-shop-hero__inner {
  display: grid;
  grid-template-columns: 1.05fr .95fr;
  gap: 28px;
  align-items: center;
  padding: 36px;
  background: rgba(255,255,255,.84);
  border: 1px solid rgba(28,65,53,.08);
  border-radius: 34px;
  box-shadow: 0 18px 40px rgba(30,58,47,.08);
}

.kb-shop-hero__copy h1 {
  margin: 10px 0 12px;
  font-family: 'Cormorant Garamond', serif;
  font-size: clamp(3rem, 5vw, 4.6rem);
  line-height: .96;
  color: #193f31;
}

.kb-shop-hero__copy p {
  margin: 0 0 20px;
  max-width: 560px;
  color: #64766d;
  font-size: 1.05rem;
}

.kb-shop-hero__actions {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
}

.kb-shop-hero__visual {
  min-width: 0;
}

.kb-shop-hero__visual img {
  display: block;
  width: 100%;
  aspect-ratio: 1 / 1.06;
  object-fit: cover;
  border-radius: 30px;
  box-shadow: 0 18px 38px rgba(23,58,43,.12);
}

.kb-shop-catalog {
  padding-top: 12px;
}

.kb-shop-filters {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  margin-bottom: 22px;
}

.kb-shop-filter {
  appearance: none;
  border: 1px solid rgba(25,63,49,.14);
  background: rgba(255,255,255,.82);
  color: #224d3b;
  border-radius: 999px;
  padding: 13px 24px;
  font-weight: 700;
  font-size: 1rem;
  cursor: pointer;
  transition: .22s ease;
  white-space: nowrap;
}

.kb-shop-filter.is-active,
.kb-shop-filter:hover {
  background: linear-gradient(135deg, #215f48, #2a6671);
  color: #fff;
  border-color: transparent;
  box-shadow: 0 12px 24px rgba(34,96,77,.16);
}

.kb-shop-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 20px;
  align-items: stretch;
}

.kb-shop-card {
  display: flex;
  flex-direction: column;
  min-width: 0;
  background: rgba(255,255,255,.9);
  border: 1px solid rgba(27,63,50,.08);
  border-radius: 28px;
  overflow: hidden;
  box-shadow: 0 14px 32px rgba(25,55,43,.08);
  transition: transform .2s ease, box-shadow .2s ease;
}

.kb-shop-card:hover {
  transform: translateY(-3px);
  box-shadow: 0 18px 38px rgba(25,55,43,.12);
}

.kb-shop-card__image {
  position: relative;
  display: block;
  padding: 0;
  border: 0;
  background: transparent;
  cursor: pointer;
  overflow: hidden;
}

.kb-shop-card__image img {
  display: block;
  width: 100%;
  aspect-ratio: 1 / 1.1;
  object-fit: cover;
}

.kb-shop-card__label {
  position: absolute;
  z-index: 2;
  left: 16px;
  top: 16px;
  padding: 10px 16px;
  border-radius: 999px;
  background: rgba(255,255,255,.92);
  color: #1d4a38;
  font-size: .9rem;
  font-weight: 800;
  letter-spacing: .06em;
  text-transform: uppercase;
}

.kb-shop-card__body {
  display: flex;
  flex-direction: column;
  gap: 10px;
  padding: 18px 18px 20px;
  flex: 1 1 auto;
}

.kb-shop-card__body h3 {
  margin: 0;
  font-family: 'Cormorant Garamond', serif;
  font-size: 2rem;
  line-height: .95;
  color: #1c4535;
}

.kb-shop-card__body p {
  margin: 0;
  color: #6f7c76;
  line-height: 1.55;
  min-height: 48px;
}

.kb-shop-card__footer {
  margin-top: auto;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}

.kb-shop-card__price {
  font-size: 1.25rem;
  font-weight: 800;
  color: #194b39;
}

.kb-shop-modal {
  display: none;
  position: fixed;
  inset: 0;
  z-index: 999999;
  padding: 24px;
  background: rgba(14, 27, 22, .78);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  align-items: center;
  justify-content: center;
}

.kb-shop-modal__content {
  position: relative;
  display: grid;
  grid-template-columns: minmax(0, 1fr) 430px;
  width: min(1080px, 100%);
  max-height: min(90vh, 860px);
  overflow: hidden;
  background: #fff;
  border-radius: 28px;
  box-shadow: 0 26px 70px rgba(0,0,0,.28);
}

.kb-shop-modal__close {
  position: absolute;
  top: 16px;
  right: 16px;
  z-index: 5;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 48px;
  height: 48px;
  border: 0;
  border-radius: 999px;
  background: rgba(255,255,255,.94);
  color: #26493d;
  font-size: 2rem;
  cursor: pointer;
  box-shadow: 0 10px 24px rgba(14,31,24,.12);
}

.kb-shop-modal__gallery {
  display: flex;
  flex-direction: column;
  min-width: 0;
  background: #f7faf8;
  border-right: 1px solid rgba(27,63,50,.08);
}

.kb-shop-modal__main {
  position: relative;
  min-height: 540px;
  background: #fff;
  overflow: hidden;
}

.kb-shop-modal__main img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.kb-shop-modal__thumbs {
  display: flex;
  gap: 12px;
  align-items: center;
  padding: 16px 18px 18px;
  overflow-x: auto;
  background: #fff;
  border-top: 1px solid rgba(27,63,50,.08);
}

.kb-shop-modal__thumbs::-webkit-scrollbar { display: none; }

.kb-shop-modal__thumb {
  flex: 0 0 auto;
  width: 72px;
  height: 72px;
  padding: 0;
  border: 2px solid transparent;
  border-radius: 18px;
  overflow: hidden;
  background: #f2f4f3;
  cursor: pointer;
}

.kb-shop-modal__thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.kb-shop-modal__thumb.is-active { border-color: #1f5a3a; }

.kb-shop-modal__info {
  min-width: 0;
  display: flex;
  flex-direction: column;
  gap: 18px;
  padding: 34px 30px 30px;
  overflow-y: auto;
}

.kb-shop-modal__info h2 {
  margin: 0;
  font-family: 'Cormorant Garamond', serif;
  font-size: 3rem;
  line-height: .96;
  color: #173c2e;
}

#modalDesc {
  color: #6b7873;
  line-height: 1.6;
}

.kb-shop-modal__price {
  display: flex;
  align-items: baseline;
  flex-wrap: wrap;
  gap: 12px;
}

.kb-shop-modal__price-old {
  text-decoration: line-through;
  color: #97a39e;
  font-size: 1.1rem;
}

.kb-shop-modal__price-new {
  color: #194f3b;
  font-weight: 900;
  font-size: 2.05rem;
}

.kb-shop-modal__options {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
  padding: 16px;
  border-radius: 22px;
  background: #f8faf9;
  border: 1px solid rgba(27,63,50,.08);
}

.kb-shop-field {
  min-width: 0;
}

.kb-shop-field--full {
  grid-column: 1 / -1;
}

.kb-shop-field label {
  display: block;
  margin-bottom: 7px;
  font-size: .82rem;
  font-weight: 800;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: #3c5b50;
}

.kb-shop-field select,
.kb-shop-field textarea {
  display: block;
  width: 100%;
  max-width: 100%;
  border: 1px solid rgba(31,90,58,.15);
  border-radius: 16px;
  background: #fff;
  color: #213f35;
  font: inherit;
  box-sizing: border-box;
}

.kb-shop-field select {
  min-height: 54px;
  padding: 0 16px;
}

.kb-shop-field textarea {
  min-height: 104px;
  padding: 14px 16px;
  resize: vertical;
}

.kb-shop-modal__add {
  width: 100%;
  margin-top: 4px;
  min-height: 58px;
  justify-content: center;
}

.kb-shop-modal__add:disabled {
  opacity: .58;
  cursor: not-allowed;
  transform: none;
}

.kb-shop-modal__nav {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  z-index: 3;
  width: 48px;
  height: 48px;
  border: 0;
  border-radius: 999px;
  background: rgba(255,255,255,.92);
  color: #20533f;
  box-shadow: 0 8px 24px rgba(16,32,25,.14);
  cursor: pointer;
}

.kb-shop-modal__nav--prev { left: 16px; }
.kb-shop-modal__nav--next { right: 16px; }
.kb-shop-modal__nav.is-hidden { display: none; }

body.kb-shop-modal-open {
  overflow: hidden;
}

@media (max-width: 1100px) {
  .kb-shop-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .kb-shop-hero__inner,
  .kb-shop-modal__content {
    grid-template-columns: 1fr;
  }

  .kb-shop-hero__visual {
    order: -1;
  }

  .kb-shop-hero__visual img {
    aspect-ratio: 16 / 10;
  }

  .kb-shop-modal__gallery {
    border-right: 0;
    border-bottom: 1px solid rgba(27,63,50,.08);
  }

  .kb-shop-modal__main {
    min-height: 420px;
  }
}

@media (max-width: 767px) {
  .kb-shop-page {
    padding-bottom: 116px;
  }

  .kb-shop-hero {
    padding: 14px 0 10px;
  }

  .kb-shop-hero__inner {
    grid-template-columns: 1fr;
    gap: 16px;
    padding: 20px 18px;
    border-radius: 26px;
  }

  .kb-shop-hero__copy h1 {
    font-size: 2.9rem;
    line-height: .94;
    overflow-wrap: anywhere;
  }

  .kb-shop-hero__copy p {
    font-size: 1rem;
    margin-bottom: 16px;
  }

  .kb-shop-hero__actions {
    display: grid;
    grid-template-columns: 1fr;
  }

  .kb-shop-hero__visual {
    display: none;
  }

  .kb-shop-filters {
    flex-wrap: nowrap;
    overflow-x: auto;
    padding-bottom: 2px;
    margin-bottom: 16px;
    -webkit-overflow-scrolling: touch;
  }

  .kb-shop-filters::-webkit-scrollbar { display: none; }

  .kb-shop-filter {
    padding: 12px 18px;
    font-size: .95rem;
  }

  .kb-shop-grid {
    grid-template-columns: 1fr;
    gap: 14px;
  }

  .kb-shop-card {
    border-radius: 24px;
  }

  .kb-shop-card__image img {
    aspect-ratio: 1 / 1.02;
  }

  .kb-shop-card__body {
    padding: 15px 15px 16px;
    gap: 8px;
  }

  .kb-shop-card__body h3 {
    font-size: 2rem;
  }

  .kb-shop-card__body p {
    min-height: 0;
    font-size: .96rem;
  }

  .kb-shop-card__footer {
    align-items: center;
  }

  .kb-shop-card__footer .kb-btn {
    min-height: 44px;
    padding: 0 18px;
  }

  .kb-shop-modal {
    align-items: flex-start;
    justify-content: stretch;
    padding: 0;
    overflow-y: auto;
  }

  .kb-shop-modal__content {
    width: 100%;
    min-height: 100dvh;
    max-height: none;
    border-radius: 28px 28px 0 0;
    margin-top: 14px;
    overflow: visible;
    box-shadow: none;
  }

  .kb-shop-modal__content::before {
    content: '';
    width: 74px;
    height: 6px;
    border-radius: 999px;
    background: rgba(33,74,58,.16);
    position: absolute;
    top: 12px;
    left: 50%;
    transform: translateX(-50%);
  }

  .kb-shop-modal__close {
    top: 18px;
    right: 16px;
    width: 46px;
    height: 46px;
    font-size: 1.9rem;
  }

  .kb-shop-modal__gallery {
    border-bottom: 0;
    background: #fff;
    padding: 22px 16px 10px;
  }

  .kb-shop-modal__main {
    min-height: 0;
    aspect-ratio: 1 / 1;
    border-radius: 24px;
    overflow: hidden;
  }

  .kb-shop-modal__main img {
    height: 100%;
  }

  .kb-shop-modal__thumbs {
    padding: 12px 0 4px;
    gap: 10px;
    background: transparent;
    border-top: 0;
  }

  .kb-shop-modal__thumb {
    width: 64px;
    height: 64px;
    border-radius: 16px;
  }

  .kb-shop-modal__info {
    overflow: visible;
    padding: 8px 16px 22px;
    gap: 14px;
  }

  .kb-shop-modal__info h2 {
    font-size: 2.45rem;
    line-height: .96;
    padding-right: 52px;
    overflow-wrap: anywhere;
  }

  #modalDesc {
    font-size: .98rem;
    line-height: 1.55;
  }

  .kb-shop-modal__price {
    gap: 8px 12px;
  }

  .kb-shop-modal__price-new {
    font-size: 1.95rem;
  }

  .kb-shop-modal__options {
    grid-template-columns: 1fr;
    gap: 12px;
    padding: 14px;
    border-radius: 20px;
  }

  .kb-shop-field label {
    margin-bottom: 6px;
  }

  .kb-shop-field select {
    min-height: 52px;
  }

  .kb-shop-field textarea {
    min-height: 96px;
  }

  .kb-shop-modal__add {
    position: static !important;
    display: flex !important;
    min-height: 54px !important;
    margin: 2px 0 0 !important;
    padding: 0 16px !important;
    width: 100% !important;
    box-sizing: border-box !important;
  }

  .kb-shop-modal__nav {
    width: 42px;
    height: 42px;
    top: calc(50% - 12px);
  }

  .kb-shop-modal__nav--prev { left: 10px; }
  .kb-shop-modal__nav--next { right: 10px; }

  body.kb-shop-modal-open .site-header {
    opacity: 0;
    pointer-events: none;
  }
}


/* ===============================
   KB SHOP RESET FIX
   =============================== */
.kb-shop-reset{
  padding-bottom: 48px;
}
.kb-shop-reset .container{max-width:1200px;}
.kb-store-hero-wrap{
  padding: 18px 0 10px;
}
.kb-store-hero{
  display:grid;
  grid-template-columns:minmax(0,1fr) minmax(320px,460px);
  gap:24px;
  align-items:center;
  background:linear-gradient(135deg, rgba(255,255,255,.94), rgba(247,251,249,.92));
  border:1px solid rgba(24,68,52,.08);
  border-radius:32px;
  padding:28px;
  box-shadow:0 20px 50px rgba(26,62,49,.08);
}
.kb-store-hero__copy{min-width:0;}
.kb-store-hero__eyebrow{
  display:inline-flex;
  align-items:center;
  min-height:44px;
  padding:0 18px;
  border-radius:999px;
  border:1px solid rgba(24,68,52,.12);
  color:#245340;
  font-weight:700;
  letter-spacing:.12em;
  text-transform:uppercase;
  font-size:13px;
}
.kb-store-hero h1{
  margin:18px 0 10px;
  color:#173e2f;
  font-family:"Cormorant Garamond", serif;
  font-size: clamp(44px, 5.5vw, 76px);
  line-height:.95;
}
.kb-store-hero p{
  margin:0;
  color:#6b8078;
  font-size:18px;
  line-height:1.65;
  max-width:640px;
}
.kb-store-hero__cta{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  margin-top:22px;
  min-height:56px;
  padding:0 28px;
  border-radius:999px;
  background:linear-gradient(135deg,#1f5a3a,#215a73);
  color:#fff;
  font-weight:800;
  text-decoration:none;
  box-shadow:0 18px 34px rgba(31,90,58,.24);
}
.kb-store-hero__visual{
  min-width:0;
  border-radius:28px;
  overflow:hidden;
  background:#eef3f0;
  min-height:420px;
}
.kb-store-hero__visual img{
  width:100%;
  height:100%;
  display:block;
  object-fit:cover;
}
.kb-store-filter-wrap{margin-top:16px;}
.kb-store-filters{
  display:flex;
  gap:12px;
  overflow-x:auto;
  padding:6px 2px 4px;
  scrollbar-width:none;
}
.kb-store-filters::-webkit-scrollbar{display:none;}
.kb-store-filter{
  flex:0 0 auto;
  min-height:54px;
  padding:0 28px;
  border-radius:999px;
  border:1px solid rgba(23,54,42,.12);
  background:#fff;
  color:#214837;
  font-weight:800;
  font-size:18px;
  cursor:pointer;
}
.kb-store-filter.is-active{
  color:#fff;
  background:linear-gradient(135deg,#1f5a3a,#215a73);
  border-color:transparent;
}
.kb-store-grid-wrap{margin-top:18px;}
.kb-store-grid{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:20px;
}
.store-item{
  display:flex;
  flex-direction:column;
  background:rgba(255,255,255,.92);
  border:1px solid rgba(24,68,52,.08);
  border-radius:28px;
  overflow:hidden;
  min-width:0;
  box-shadow:0 18px 38px rgba(25,58,46,.08);
}
.store-item__badge{
  position:absolute;
  top:18px;
  left:18px;
  z-index:2;
  display:inline-flex;
  align-items:center;
  min-height:44px;
  padding:0 18px;
  border-radius:999px;
  background:rgba(255,255,255,.92);
  color:#214938;
  font-weight:800;
  letter-spacing:.08em;
  text-transform:uppercase;
}
.img-box{
  position:relative;
  display:block;
  padding:0;
  border:0;
  width:100%;
  background:none;
  cursor:pointer;
  overflow:hidden;
  aspect-ratio: 4 / 4.7;
}
.img-box img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}
.info-box{
  padding:20px 20px 22px;
  display:flex;
  flex-direction:column;
  gap:12px;
  min-width:0;
}
.info-box h3{
  margin:0;
  color:#173e2f;
  font-family:"Cormorant Garamond", serif;
  font-size:42px;
  line-height:.95;
}
.info-box p{
  margin:0;
  color:#6b8078;
  font-size:16px;
  line-height:1.65;
  display:-webkit-box;
  -webkit-line-clamp:2;
  -webkit-box-orient:vertical;
  overflow:hidden;
}
.store-card-bottom{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
}
.store-price{
  color:#194a36;
  font-size:34px;
  font-weight:800;
}
.add-btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:50px;
  padding:0 20px;
  border-radius:999px;
  background:linear-gradient(135deg,#1f5a3a,#215a73) !important;
  color:#fff !important;
  border:none;
  font-weight:800;
  white-space:nowrap;
  width:auto;
}
.store-loading{
  grid-column:1/-1;
  text-align:center;
  padding:48px 18px;
  background:rgba(255,255,255,.82);
  border-radius:28px;
}
.store-loading i{font-size:30px;color:#1f5a3a;}
.store-loading p{margin:14px 0 0;color:#587067;}

/* Modal reset */
#productModal.modal{
  display:none;
  position:fixed;
  inset:0;
  z-index:999999;
  background:rgba(10,20,16,.62);
  align-items:center;
  justify-content:center;
  padding:20px;
}
#productModal .kb-modal-shell,
#productModal .modal-content{
  width:min(1100px, 100%);
  height:min(86vh, 920px);
  margin:0;
  background:#fff;
  border-radius:30px;
  overflow:hidden;
  display:grid !important;
  grid-template-columns:minmax(0,1.05fr) minmax(360px,.95fr);
  position:relative;
  box-shadow:0 35px 90px rgba(0,0,0,.28);
}
#productModal .close-btn{
  position:absolute;
  top:16px;
  right:16px;
  z-index:9;
  width:56px;
  height:56px;
  border-radius:50%;
  border:none;
  background:rgba(255,255,255,.92);
  color:#294738;
  font-size:42px;
  line-height:1;
  display:flex;
  align-items:center;
  justify-content:center;
}
#productModal .modal-img-container{
  background:#f5f8f7;
  min-width:0;
  display:flex;
  flex-direction:column;
  overflow:hidden;
}
#productModal .main-img-box{
  position:relative;
  flex:1 1 auto;
  min-height:0;
  display:flex;
  align-items:center;
  justify-content:center;
  background:#f5f8f7;
}
#productModal .main-img-box img{
  width:100%;
  height:100%;
  object-fit:contain;
  display:block;
  padding:34px;
}
#productModal .thumbnails-row{
  display:flex;
  gap:12px;
  padding:14px 16px 18px;
  overflow-x:auto;
  background:#fff;
  border-top:1px solid rgba(23,54,42,.08);
  scrollbar-width:none;
}
#productModal .thumbnails-row::-webkit-scrollbar{display:none;}
#productModal .thumb-img{
  flex:0 0 auto;
  width:72px;
  height:72px;
  padding:0;
  border:2px solid rgba(23,54,42,.12);
  background:#fff;
  border-radius:18px;
  overflow:hidden;
}
#productModal .thumb-img img{width:100%;height:100%;object-fit:cover;display:block;}
#productModal .thumb-img.active{border-color:#1f5a3a;box-shadow:0 0 0 3px rgba(31,90,58,.12);}
#productModal .modal-info{
  min-width:0;
  display:flex;
  flex-direction:column;
  gap:18px;
  padding:34px 28px 28px;
  overflow:auto;
}
#productModal .modal-info h2{
  margin:0;
  color:#173e2f;
  font-family:"Cormorant Garamond", serif;
  font-size:56px;
  line-height:.92;
}
#productModal #modalDesc{
  margin:0;
  color:#6c8179;
  font-size:17px;
  line-height:1.7;
}
#productModal .modal-price{
  display:flex;
  align-items:flex-end;
  flex-wrap:wrap;
  gap:10px;
}
#productModal .modal-price-old{
  color:#8f9f99;
  text-decoration:line-through;
  font-size:22px;
  font-weight:700;
}
#productModal .modal-price-new{
  color:#194a36;
  font-size:44px;
  font-weight:900;
  line-height:1;
}
#productModal .product-options{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:14px;
  padding:18px;
  border-radius:24px;
  background:#f7faf8;
  border:1px solid rgba(23,54,42,.08);
}
#productModal .option-group{min-width:0;display:flex;flex-direction:column;gap:8px;}
#productModal .option-group-full{grid-column:1/-1;}
#productModal .option-group label{
  color:#284739;
  font-weight:700;
  font-size:14px;
}
#productModal .option-group select,
#productModal .option-group textarea{
  width:100%;
  min-width:0;
  border-radius:16px;
  border:1px solid rgba(23,54,42,.12);
  background:#fff;
  color:#223b32;
  padding:14px 16px;
  font-size:15px;
  box-sizing:border-box;
}
#productModal .option-group textarea{
  min-height:112px;
  resize:vertical;
}
#productModal .modal-add-btn{
  width:100%;
  min-height:58px;
  margin-top:auto;
  font-size:16px;
}
#productModal .modal-add-btn:disabled{
  opacity:.6;
  cursor:not-allowed;
  transform:none;
}
#productModal .modal-nav{
  position:absolute;
  top:50%;
  transform:translateY(-50%);
  width:52px;
  height:52px;
  border:none;
  border-radius:50%;
  background:rgba(255,255,255,.9);
  color:#214837;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  box-shadow:0 10px 24px rgba(0,0,0,.10);
}
#productModal .modal-nav--prev{left:16px;}
#productModal .modal-nav--next{right:16px;}

body.modal-open{overflow:hidden !important;}
body.modal-open .site-header{display:none !important;}

@media (max-width: 1024px){
  .kb-store-hero{grid-template-columns:1fr;}
  .kb-store-grid{grid-template-columns:repeat(2,minmax(0,1fr));}
  #productModal .kb-modal-shell,
  #productModal .modal-content{grid-template-columns:1fr; height:min(92vh, 980px);} 
  #productModal .modal-img-container{min-height:320px;}
}

@media (max-width: 768px){
  .kb-store-hero-wrap{padding-top:10px;}
  .kb-store-hero{
    border-radius:26px;
    padding:18px;
    gap:16px;
  }
  .kb-store-hero h1{font-size: clamp(34px, 11vw, 52px);}
  .kb-store-hero p{font-size:16px;}
  .kb-store-hero__cta{width:100%;}
  .kb-store-hero__visual{min-height:240px; border-radius:22px;}
  .kb-store-filter-wrap{margin-top:10px;}
  .kb-store-filter{min-height:48px; padding:0 22px; font-size:15px;}
  .kb-store-grid{grid-template-columns:1fr; gap:16px;}
  .store-item{border-radius:24px;}
  .img-box{aspect-ratio: 4 / 4.8;}
  .info-box{padding:16px 16px 18px; gap:10px;}
  .info-box h3{font-size:38px;}
  .info-box p{font-size:15px; -webkit-line-clamp:3;}
  .store-card-bottom{align-items:center;}
  .store-price{font-size:28px;}
  .add-btn{min-height:46px; padding:0 18px;}

  #productModal.modal{padding:0; align-items:flex-end;}
  #productModal .kb-modal-shell,
  #productModal .modal-content{
    width:100%;
    height:100dvh;
    max-height:none;
    border-radius:28px 28px 0 0;
    grid-template-columns:1fr;
  }
  #productModal .close-btn{top:14px; right:14px; width:52px; height:52px; font-size:38px;}
  #productModal .modal-img-container{min-height:auto; max-height:none;}
  #productModal .main-img-box{height:340px; flex:0 0 auto;}
  #productModal .main-img-box img{padding:24px 22px 18px;}
  #productModal .thumbnails-row{padding:12px 14px 14px; gap:10px;}
  #productModal .thumb-img{width:66px; height:66px; border-radius:16px;}
  #productModal .modal-info{
    padding:18px 18px calc(24px + env(safe-area-inset-bottom));
    gap:14px;
    min-height:0;
  }
  #productModal .modal-info h2{font-size:42px;}
  #productModal #modalDesc{font-size:15px; line-height:1.65;}
  #productModal .modal-price-new{font-size:34px;}
  #productModal .modal-price-old{font-size:18px;}
  #productModal .product-options{grid-template-columns:1fr; gap:12px; padding:14px; border-radius:20px;}
  #productModal .option-group select,
  #productModal .option-group textarea{font-size:16px; padding:13px 14px;}
  #productModal .option-group textarea{min-height:96px;}
  #productModal .modal-add-btn{
    position:sticky;
    bottom:0;
    z-index:5;
    min-height:54px;
    box-shadow:0 -10px 24px rgba(255,255,255,.92);
  }
  #productModal .modal-nav{width:46px; height:46px;}
  #productModal .modal-nav--prev{left:10px;}
  #productModal .modal-nav--next{right:10px;}
}


/* ===== FINAL MODAL ALIGN FIX (SHOP + INDEX) ===== */
#productModal .modal-add-btn,
#indexProductModal .modal-add-btn{
  position:static !important;
  bottom:auto !important;
  left:auto !important;
  right:auto !important;
  margin-top:14px !important;
  width:100% !important;
  min-height:54px !important;
  box-shadow:none !important;
  z-index:auto !important;
  display:inline-flex !important;
  align-items:center !important;
  justify-content:center !important;
}

#productModal .product-options,
#indexProductModal .product-options{
  grid-template-columns:repeat(2,minmax(0,1fr)) !important;
}

#productModal .option-group-full,
#indexProductModal .option-group-full{
  grid-column:1 / -1 !important;
}

#productModal .modal-info,
#indexProductModal .modal-info{
  overflow:visible !important;
}

#indexProductModal .modal-content,
#indexProductModal .modal-content--premium{
  display:grid !important;
  grid-template-columns:minmax(0,1.02fr) minmax(320px,.98fr) !important;
  gap:0 !important;
  width:min(1120px, calc(100vw - 40px)) !important;
  max-width:min(1120px, calc(100vw - 40px)) !important;
  max-height:min(92vh, 980px) !important;
  height:min(92vh, 980px) !important;
  border-radius:34px !important;
  overflow:hidden !important;
  background:#fff !important;
}

#indexProductModal .modal-img-container{
  min-width:0 !important;
  display:flex !important;
  flex-direction:column !important;
  background:#f5f8f7 !important;
  overflow:hidden !important;
}

#indexProductModal .main-img-box{
  position:relative !important;
  flex:1 1 auto !important;
  min-height:0 !important;
  display:flex !important;
  align-items:center !important;
  justify-content:center !important;
  background:#f5f8f7 !important;
}

#indexProductModal .main-img-box img{
  width:100% !important;
  height:100% !important;
  object-fit:contain !important;
  display:block !important;
  padding:34px !important;
}

#indexProductModal .thumbnails-row{
  display:flex !important;
  gap:12px !important;
  padding:14px 16px 18px !important;
  overflow-x:auto !important;
  background:#fff !important;
  border-top:1px solid rgba(23,54,42,.08) !important;
  scrollbar-width:none !important;
}

#indexProductModal .thumbnails-row::-webkit-scrollbar{display:none !important;}

#indexProductModal .thumb-btn{
  flex:0 0 auto !important;
  width:72px !important;
  height:72px !important;
  padding:0 !important;
  border:2px solid rgba(23,54,42,.12) !important;
  background:#fff !important;
  border-radius:18px !important;
  overflow:hidden !important;
}

#indexProductModal .thumb-btn img{width:100% !important;height:100% !important;object-fit:cover !important;display:block !important;}
#indexProductModal .thumb-btn.active{border-color:#1f5a3a !important;box-shadow:0 0 0 3px rgba(31,90,58,.12) !important;}

#indexProductModal .modal-info{
  min-width:0 !important;
  display:flex !important;
  flex-direction:column !important;
  gap:18px !important;
  padding:34px 28px 28px !important;
  overflow:auto !important;
  background:#fff !important;
}

#indexProductModal .modal-info h2{
  margin:0 !important;
  color:#173e2f !important;
  font-family:"Cormorant Garamond", serif !important;
  font-size:56px !important;
  line-height:.92 !important;
}

#indexProductModal #indexModalDesc{
  margin:0 !important;
  color:#6c8179 !important;
  font-size:17px !important;
  line-height:1.7 !important;
}

#indexProductModal .modal-price{display:flex !important;align-items:flex-end !important;flex-wrap:wrap !important;gap:10px !important;}
#indexProductModal .modal-price-old{color:#8f9f99 !important;text-decoration:line-through !important;font-size:22px !important;font-weight:700 !important;}
#indexProductModal .modal-price-new{color:#194a36 !important;font-size:44px !important;font-weight:900 !important;line-height:1 !important;}

#indexProductModal .product-options{
  display:grid !important;
  gap:14px !important;
  padding:18px !important;
  border-radius:24px !important;
  background:#f7faf8 !important;
  border:1px solid rgba(23,54,42,.08) !important;
}

#indexProductModal .option-group{min-width:0 !important;display:flex !important;flex-direction:column !important;gap:8px !important;}
#indexProductModal .option-group label{color:#284739 !important;font-weight:700 !important;font-size:14px !important;}
#indexProductModal .option-group select,
#indexProductModal .option-group textarea{
  width:100% !important;
  min-width:0 !important;
  border-radius:16px !important;
  border:1px solid rgba(23,54,42,.12) !important;
  background:#fff !important;
  color:#223b32 !important;
  padding:14px 16px !important;
  font-size:15px !important;
  box-sizing:border-box !important;
}
#indexProductModal .option-group textarea{min-height:112px !important;resize:vertical !important;}

#indexProductModal .modal-nav{
  position:absolute !important;
  top:50% !important;
  transform:translateY(-50%) !important;
  width:52px !important;
  height:52px !important;
  border:none !important;
  border-radius:50% !important;
  background:rgba(255,255,255,.9) !important;
  color:#214837 !important;
  display:inline-flex !important;
  align-items:center !important;
  justify-content:center !important;
  box-shadow:0 10px 24px rgba(0,0,0,.10) !important;
}
#indexProductModal .modal-nav--prev{left:16px !important;}
#indexProductModal .modal-nav--next{right:16px !important;}
#indexProductModal .modal-nav.is-hidden{display:none !important;}

@media (max-width: 768px){
  #productModal .product-options,
  #indexProductModal .product-options{
    grid-template-columns:1fr !important;
    gap:12px !important;
    padding:14px !important;
    border-radius:20px !important;
  }

  #productModal .modal-info,
  #indexProductModal .modal-info{
    padding:18px 18px calc(24px + env(safe-area-inset-bottom)) !important;
    gap:14px !important;
  }

  #productModal .modal-info h2,
  #indexProductModal .modal-info h2{font-size:42px !important;}

  #productModal #modalDesc,
  #indexProductModal #indexModalDesc{font-size:15px !important;line-height:1.65 !important;}

  #productModal .modal-price-new,
  #indexProductModal .modal-price-new{font-size:34px !important;}

  #productModal .modal-price-old,
  #indexProductModal .modal-price-old{font-size:18px !important;}

  #productModal .option-group textarea,
  #indexProductModal .option-group textarea{min-height:96px !important;}

  #productModal .option-group select,
  #productModal .option-group textarea,
  #indexProductModal .option-group select,
  #indexProductModal .option-group textarea{font-size:16px !important;padding:13px 14px !important;}

  #productModal.modal,
  #indexProductModal.modal{padding:0 !important;align-items:flex-end !important;}

  #productModal .kb-modal-shell,
  #productModal .modal-content,
  #indexProductModal .modal-content,
  #indexProductModal .modal-content--premium{
    width:100% !important;
    height:100dvh !important;
    max-height:none !important;
    border-radius:28px 28px 0 0 !important;
    grid-template-columns:1fr !important;
  }

  #productModal .close-btn,
  #indexProductModal .close-btn{top:14px !important;right:14px !important;width:52px !important;height:52px !important;font-size:38px !important;}

  #productModal .modal-img-container,
  #indexProductModal .modal-img-container{min-height:auto !important;max-height:none !important;}

  #productModal .main-img-box,
  #indexProductModal .main-img-box{height:340px !important;flex:0 0 auto !important;}

  #productModal .main-img-box img,
  #indexProductModal .main-img-box img{padding:24px 22px 18px !important;}

  #productModal .thumbnails-row,
  #indexProductModal .thumbnails-row{padding:12px 14px 14px !important;gap:10px !important;}

  #productModal .thumb-img,
  #indexProductModal .thumb-btn{width:66px !important;height:66px !important;border-radius:16px !important;}

  #productModal .modal-nav,
  #indexProductModal .modal-nav{width:46px !important;height:46px !important;}

  #productModal .modal-nav--prev,
  #indexProductModal .modal-nav--prev{left:10px !important;}

  #productModal .modal-nav--next,
  #indexProductModal .modal-nav--next{right:10px !important;}
}
/* =========================================================
   YENİ ANASAYFA (PROMO GRID & FAQ) - V14
   ========================================================= */

.kb-home-promo-section {
  padding: 24px 0 32px;
}

.kb-promo-header {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 20px;
  margin-bottom: 24px;
}

.kb-promo-title-area h1 {
  margin: 10px 0 12px;
  font-family: 'Cormorant Garamond', serif;
  font-size: clamp(2.8rem, 5vw, 4.2rem);
  color: #173e2f;
  line-height: 1;
}

.kb-promo-title-area p {
  font-size: 1.05rem;
  color: #6b8078;
  max-width: 600px;
}

.kb-promo-actions {
  display: flex;
  gap: 12px;
}

.kb-promo-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 20px;
}

.promo-card {
  position: relative;
  display: block;
  overflow: hidden;
  border-radius: 28px;
  background: #f0f7f3;
  isolation: isolate;
}

.promo-card img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.4s ease;
}

.promo-card:hover img {
  transform: scale(1.04);
}

.promo-card__overlay {
  position: absolute;
  inset: 0;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  padding: 24px;
  background: linear-gradient(0deg, rgba(14, 38, 28, 0.7) 0%, rgba(14, 38, 28, 0.1) 60%, rgba(0,0,0,0) 100%);
  color: #fff;
}

.promo-card--large {
  min-height: 480px;
}

.promo-card--large h2 {
  font-size: clamp(2.2rem, 4vw, 3.2rem);
  color: #fff;
  margin-bottom: 12px;
}

.promo-card-smalls {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 20px;
}

.promo-card--small {
  min-height: 230px;
}

.promo-card--small h3 {
  font-size: 1.5rem;
  color: #fff;
  margin-top: auto;
  margin-bottom: 8px;
}

.promo-badge {
  align-self: flex-start;
  background: rgba(255,255,255,0.2);
  backdrop-filter: blur(8px);
  padding: 6px 12px;
  border-radius: 999px;
  font-size: 0.8rem;
  font-weight: 700;
  letter-spacing: 0.05em;
  margin-bottom: auto;
}

.promo-card__btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: rgba(255, 255, 255, 0.9);
  color: #173e2f;
  padding: 10px 20px;
  border-radius: 999px;
  font-weight: 800;
  font-size: 0.95rem;
  align-self: flex-start;
  transition: background 0.3s ease;
}

.promo-card:hover .promo-card__btn {
  background: #fff;
  box-shadow: 0 8px 20px rgba(0,0,0,0.15);
}

/* SSS Akordeon Stilleri */
.kb-faq-item {
  border-bottom: 1px solid rgba(23, 54, 42, 0.1);
}

.kb-faq-item:last-child {
  border-bottom: none;
}

.kb-faq-item summary {
  padding: 22px 0;
  font-size: 1.2rem;
  font-weight: 700;
  color: #173e2f;
  cursor: pointer;
  list-style: none;
  display: flex;
  justify-content: space-between;
  align-items: center;
}

.kb-faq-item summary::-webkit-details-marker {
  display: none;
}

.kb-faq-item summary::after {
  content: '+';
  font-size: 1.8rem;
  color: var(--primary);
  line-height: 1;
  transition: transform 0.3s ease;
}

.kb-faq-item[open] summary::after {
  transform: rotate(45deg);
}

.kb-faq-content {
  padding-bottom: 22px;
  color: #5a6e65;
  font-size: 1.05rem;
  line-height: 1.6;
}

/* MOBİL UYUMLULUK */
@media (max-width: 980px) {
  .kb-promo-header {
    flex-direction: column;
    align-items: flex-start;
  }
  
  .kb-promo-actions {
    width: 100%;
  }

  .kb-promo-actions .kb-btn {
    flex: 1;
  }
}

@media (max-width: 768px) {
  .kb-promo-grid {
    grid-template-columns: 1fr;
  }

  .promo-card--large {
    min-height: 380px;
  }

  .promo-card-smalls {
    gap: 14px;
  }

  .promo-card--small {
    min-height: 200px;
  }
  
  .kb-faq-item summary {
      font-size: 1.05rem;
  }
}

/* ===== 2026.04.14 KEMERBUKET INDEX + MAGAZA RESPONSIVE OVERRIDE ===== */
.kb-home-top-grid{
  display:grid !important;
  grid-template-columns:minmax(0,1.08fr) minmax(0,.92fr) !important;
  gap:24px !important;
  align-items:stretch !important;
  margin-top:18px !important;
}
.kb-home-hero-copy{
  min-width:0;
  display:flex;
  flex-direction:column;
  justify-content:center;
  padding:clamp(22px,3vw,36px);
  border-radius:32px;
  background:linear-gradient(180deg,rgba(255,255,255,.92),rgba(245,250,247,.92));
  border:1px solid rgba(24,68,52,.08);
  box-shadow:0 20px 46px rgba(18,54,41,.08);
}
.kb-home-hero-copy h1{
  margin:8px 0 14px;
  font-size:clamp(3rem,5vw,5rem);
  line-height:.92;
}
.kb-home-hero-copy p{
  margin:0;
  max-width:62ch;
  color:#5e756c;
  font-size:1.08rem;
  line-height:1.72;
}
.kb-home-hero-copy .hero-actions{
  display:flex;
  flex-wrap:wrap;
  gap:12px;
  margin-top:22px;
}
.kb-home-hero-cards,
.hero-category-grid{
  display:grid !important;
  grid-template-columns:repeat(2,minmax(0,1fr)) !important;
  gap:16px !important;
  min-width:0 !important;
}
.hero-cat-card{
  position:relative;
  display:block;
  min-width:0;
  aspect-ratio:1 / 1;
  border-radius:26px;
  overflow:hidden;
  box-shadow:0 18px 38px rgba(24,60,47,.10);
}
.hero-cat-card img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}
.hero-cat-card .cat-overlay{
  position:absolute;
  inset:auto 0 0 0;
  display:flex;
  flex-direction:column;
  gap:8px;
  padding:18px;
  background:linear-gradient(180deg,rgba(10,20,16,0),rgba(10,20,16,.68));
  color:#fff;
}
.hero-cat-card .cat-overlay h3{
  margin:0;
  color:#fff;
  font-size:1.35rem;
  line-height:1.05;
}
.hero-cat-card .cat-btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:max-content;
  min-height:36px;
  padding:0 14px;
  border-radius:999px;
  background:rgba(255,255,255,.94);
  color:#1d4737;
  font-size:.82rem;
  font-weight:800;
}
.home-vitrine-inline-grid{
  grid-template-columns:repeat(4,minmax(0,1fr)) !important;
  gap:18px !important;
}
.home-vitrine-inline-card,
.home-vitrine-inline-grid.vitrine-count-3 .home-vitrine-inline-card,
.home-vitrine-inline-grid.vitrine-count-2 .home-vitrine-inline-card,
.home-vitrine-inline-grid.vitrine-count-1 .home-vitrine-inline-card{
  grid-column:auto !important;
  max-width:none !important;
}
.kb-home-products-grid{
  grid-template-columns:repeat(4,minmax(0,1fr)) !important;
  gap:20px !important;
}
.kb-faq-section{
  margin:40px auto 52px !important;
}
.kb-faq-inner{
  padding:28px !important;
  border-radius:30px !important;
  background:#f0f7f3 !important;
}
.contact-grid-wrapper{
  display:grid !important;
  grid-template-columns:minmax(0,1.08fr) minmax(320px,.92fr) !important;
  gap:18px !important;
  align-items:stretch !important;
}
.map-box,
.review-box{
  min-width:0;
  height:100%;
}
.map-box iframe{
  display:block;
  width:100%;
  min-height:420px;
  border:0;
}
.review-box{
  padding:22px;
}
.review-box h3{
  margin:0 0 12px;
  font-size:1.5rem;
}
@media (min-width: 1200px){
  .kb-store-grid{
    grid-template-columns:repeat(4,minmax(0,1fr)) !important;
  }
}
@media (max-width: 1180px){
  .kb-home-products-grid{
    grid-template-columns:repeat(3,minmax(0,1fr)) !important;
  }
}
@media (max-width: 980px){
  .kb-home-top-grid{
    grid-template-columns:1fr !important;
  }
  .kb-home-hero-copy{
    order:1;
    border-radius:26px;
    padding:22px;
  }
  .kb-home-hero-cards,
  .hero-category-grid{
    order:2;
    grid-template-columns:repeat(2,minmax(0,1fr)) !important;
  }
  .home-vitrine-inline-grid{
    grid-template-columns:repeat(2,minmax(0,1fr)) !important;
  }
  .kb-home-products-grid{
    grid-template-columns:repeat(2,minmax(0,1fr)) !important;
  }
  .contact-grid-wrapper{
    grid-template-columns:1fr !important;
  }
  .map-box iframe{
    min-height:340px;
  }
  .header-shell{
    grid-template-columns:minmax(0,1fr) auto auto auto !important;
    gap:8px !important;
  }
}
@media (max-width: 768px){
  .site-header{
    padding:8px 0 10px !important;
  }
  .header-shell{
    padding:10px 12px !important;
    border-radius:18px !important;
  }
  .site-logo img{
    height:40px !important;
  }
  .header-cart,
  .header-menu-toggle{
    width:42px !important;
    height:42px !important;
  }
  .header-lang-wrapper{
    display:flex;
    align-items:center;
    min-width:0;
  }
  .kb-home-hero-copy h1{
    font-size:clamp(2.4rem,10vw,3.4rem) !important;
  }
  .kb-home-hero-copy p{
    font-size:.96rem !important;
    line-height:1.65 !important;
  }
  .kb-home-hero-copy .hero-actions{
    display:grid !important;
    grid-template-columns:1fr !important;
    gap:10px !important;
  }
  .hero-cat-card{
    border-radius:18px !important;
  }
  .hero-cat-card .cat-overlay{
    padding:12px !important;
    gap:6px !important;
  }
  .hero-cat-card .cat-overlay h3{
    font-size:1rem !important;
  }
  .hero-cat-card .cat-btn{
    min-height:30px !important;
    padding:0 10px !important;
    font-size:.72rem !important;
  }
  .home-vitrine-inline-grid,
  .kb-store-grid,
  .kb-home-products-grid{
    grid-template-columns:repeat(2,minmax(0,1fr)) !important;
    gap:12px !important;
  }
  .home-vitrine-inline-shell,
  .kb-faq-inner,
  .map-box,
  .review-box{
    border-radius:22px !important;
  }
  .home-vitrine-inline-body{
    padding:14px !important;
    gap:8px !important;
  }
  .home-vitrine-inline-body h3{
    font-size:1.2rem !important;
    line-height:1.05 !important;
  }
  .home-vitrine-inline-price .price-new{
    font-size:1.1rem !important;
  }
  .store-item{
    border-radius:20px !important;
  }
  .store-item__badge{
    top:10px !important;
    left:10px !important;
    min-height:30px !important;
    padding:0 10px !important;
    font-size:10px !important;
    letter-spacing:.04em !important;
  }
  .img-box{
    aspect-ratio:1 / 1.22 !important;
  }
  .info-box{
    padding:12px 12px 14px !important;
    gap:8px !important;
  }
  .info-box h3{
    font-size:1.55rem !important;
    line-height:.98 !important;
  }
  .info-box p{
    font-size:.84rem !important;
    line-height:1.45 !important;
    -webkit-line-clamp:2 !important;
  }
  .store-card-bottom{
    flex-direction:column !important;
    align-items:stretch !important;
    gap:8px !important;
  }
  .store-price{
    font-size:1.35rem !important;
  }
  .add-btn{
    width:100% !important;
    min-height:42px !important;
    padding:0 14px !important;
    font-size:.9rem !important;
  }
  .map-box iframe{
    min-height:300px !important;
  }
  .review-box{
    padding:16px !important;
  }
  .kb-faq-inner{
    padding:18px !important;
  }
  .kb-faq-item summary{
    padding:18px 0 !important;
    font-size:1rem !important;
  }
}
/* modal stabilizasyonu */
#productModal.modal,
#indexProductModal.modal{
  overscroll-behavior:contain;
  -webkit-overflow-scrolling:touch;
}
#productModal .modal-content,
#productModal .kb-modal-shell,
#indexProductModal .modal-content,
#indexProductModal .kb-modal-shell{
  width:min(1120px,calc(100vw - 32px)) !important;
  max-width:min(1120px,calc(100vw - 32px)) !important;
}
#productModal .modal-info,
#indexProductModal .modal-info{
  min-width:0 !important;
}
#productModal .main-img-box img,
#indexProductModal .main-img-box img{
  object-fit:contain !important;
}
@media (max-width: 768px){
  #productModal.modal,
  #indexProductModal.modal{
    padding:0 !important;
    align-items:flex-end !important;
  }
  #productModal .modal-content,
  #productModal .kb-modal-shell,
  #indexProductModal .modal-content,
  #indexProductModal .kb-modal-shell{
    width:100% !important;
    max-width:100% !important;
    height:100dvh !important;
    max-height:100dvh !important;
    border-radius:26px 26px 0 0 !important;
    grid-template-columns:1fr !important;
  }
  #productModal .modal-img-container,
  #indexProductModal .modal-img-container{
    min-height:auto !important;
  }
  #productModal .main-img-box,
  #indexProductModal .main-img-box{
    height:300px !important;
    flex:0 0 auto !important;
  }
  #productModal .thumbnails-row,
  #indexProductModal .thumbnails-row{
    padding:10px 12px 12px !important;
    gap:8px !important;
  }
  #productModal .thumb-img,
  #indexProductModal .thumb-btn{
    width:58px !important;
    height:58px !important;
    border-radius:14px !important;
  }
  #productModal .modal-info,
  #indexProductModal .modal-info{
    padding:16px 16px calc(20px + env(safe-area-inset-bottom)) !important;
    gap:12px !important;
    overflow:auto !important;
  }
  #productModal .modal-info h2,
  #indexProductModal .modal-info h2{
    font-size:2rem !important;
    line-height:.95 !important;
  }
  #productModal .modal-price-new,
  #indexProductModal .modal-price-new{
    font-size:1.9rem !important;
  }
  #productModal .product-options,
  #indexProductModal .product-options{
    grid-template-columns:1fr !important;
    gap:10px !important;
    padding:12px !important;
    border-radius:18px !important;
  }
  #productModal .option-group select,
  #productModal .option-group textarea,
  #indexProductModal .option-group select,
  #indexProductModal .option-group textarea{
    font-size:16px !important;
  }
  #productModal .modal-add-btn,
  #indexProductModal .modal-add-btn{
    margin-top:8px !important;
  }
}


/* ===== 2026-04-14 FINAL GRID + MODAL HOTFIX ===== */
.kb-home-hero-copy > .eyebrow{display:none !important;}
.kb-home-hero-cards,
.hero-category-grid{
  grid-template-columns:repeat(2,minmax(0,1fr)) !important;
}
.kb-store-grid,
.kb-home-products-grid{
  display:grid !important;
  align-items:start !important;
}
.kb-store-grid > *,
.kb-home-products-grid > *{
  min-width:0 !important;
}
.store-item,
.home-vitrine-inline-card,
.hero-cat-card{
  width:100% !important;
  max-width:100% !important;
}
.img-box,
.home-vitrine-inline-media,
.hero-cat-card{
  overflow:hidden !important;
}
.img-box img,
.home-vitrine-inline-media img,
.hero-cat-card img{
  display:block !important;
  width:100% !important;
  height:100% !important;
}
@media (min-width: 981px){
  .kb-store-grid,
  .kb-home-products-grid{
    grid-template-columns:repeat(4,minmax(0,1fr)) !important;
    gap:20px !important;
  }
}
@media (max-width: 980px){
  .kb-store-grid,
  .kb-home-products-grid{
    grid-template-columns:repeat(2,minmax(0,1fr)) !important;
    gap:14px !important;
  }
}
@media (max-width: 768px){
  .kb-store-grid,
  .kb-home-products-grid{
    grid-template-columns:repeat(2,minmax(0,1fr)) !important;
    gap:12px !important;
  }
  .store-item{
    border-radius:20px !important;
  }
  .img-box{
    aspect-ratio:1 / 1.16 !important;
  }
  .info-box{
    padding:12px !important;
    gap:8px !important;
  }
  .info-box h3{
    font-size:1.15rem !important;
    line-height:1.1 !important;
  }
  .info-box p{
    font-size:.83rem !important;
    line-height:1.45 !important;
    -webkit-line-clamp:2 !important;
  }
  .store-card-bottom{
    flex-direction:column !important;
    align-items:stretch !important;
    gap:8px !important;
  }
  .store-price{
    font-size:1.1rem !important;
  }
  .add-btn{
    width:100% !important;
  }
}

/* shop + index modal: same structure, same look */
#productModal .modal-content,
#indexProductModal .modal-content,
#productModal .kb-modal-shell,
#indexProductModal .kb-modal-shell{
  display:grid !important;
  grid-template-columns:minmax(0,1.02fr) minmax(320px,.98fr) !important;
  gap:0 !important;
  width:min(1120px,calc(100vw - 40px)) !important;
  max-width:min(1120px,calc(100vw - 40px)) !important;
  height:min(92vh,980px) !important;
  max-height:min(92vh,980px) !important;
  border-radius:34px !important;
  overflow:hidden !important;
  background:#fff !important;
}
#productModal .modal-img-container,
#indexProductModal .modal-img-container{
  min-width:0 !important;
  display:flex !important;
  flex-direction:column !important;
  justify-content:flex-start !important;
  align-items:stretch !important;
  padding:0 !important;
  background:#f5f8f7 !important;
  overflow:hidden !important;
  border-right:1px solid rgba(23,54,42,.08) !important;
}
#productModal .main-img-box,
#indexProductModal .main-img-box{
  position:relative !important;
  flex:1 1 auto !important;
  min-height:0 !important;
  height:auto !important;
  margin:0 !important;
  display:flex !important;
  align-items:center !important;
  justify-content:center !important;
  background:#f5f8f7 !important;
}
#productModal .main-img-box img,
#indexProductModal .main-img-box img{
  width:100% !important;
  height:100% !important;
  object-fit:contain !important;
  display:block !important;
  padding:24px !important;
}
#productModal .thumbnails-row,
#indexProductModal .thumbnails-row{
  display:flex !important;
  gap:12px !important;
  align-items:center !important;
  padding:14px 16px 18px !important;
  overflow-x:auto !important;
  overflow-y:hidden !important;
  background:#fff !important;
  border-top:1px solid rgba(23,54,42,.08) !important;
  scrollbar-width:none !important;
}
#productModal .thumbnails-row::-webkit-scrollbar,
#indexProductModal .thumbnails-row::-webkit-scrollbar{display:none !important;}
#productModal .thumb-img,
#indexProductModal .thumb-img{
  flex:0 0 auto !important;
  width:72px !important;
  height:72px !important;
  padding:0 !important;
  border:2px solid rgba(23,54,42,.12) !important;
  background:#fff !important;
  border-radius:18px !important;
  overflow:hidden !important;
}
#productModal .thumb-img img,
#indexProductModal .thumb-img img{
  width:100% !important;
  height:100% !important;
  object-fit:cover !important;
  display:block !important;
}
#productModal .thumb-img.active,
#indexProductModal .thumb-img.active{
  border-color:#1f5a3a !important;
  box-shadow:0 0 0 3px rgba(31,90,58,.12) !important;
}
#productModal .modal-info,
#indexProductModal .modal-info{
  min-width:0 !important;
  display:flex !important;
  flex-direction:column !important;
  gap:16px !important;
  padding:28px !important;
  overflow:auto !important;
  background:#fff !important;
}
#productModal .modal-info h2,
#indexProductModal .modal-info h2{
  margin:0 !important;
  max-width:100% !important;
  font-size:clamp(2.25rem,4vw,3rem) !important;
  line-height:.95 !important;
}
#productModal #modalDesc,
#indexProductModal #indexModalDesc{
  margin:0 !important;
  font-size:.98rem !important;
  line-height:1.65 !important;
}
#productModal .modal-price,
#indexProductModal .modal-price{
  display:flex !important;
  align-items:flex-end !important;
  flex-wrap:wrap !important;
  gap:10px !important;
}
#productModal .product-options,
#indexProductModal .product-options{
  display:grid !important;
  grid-template-columns:repeat(2,minmax(0,1fr)) !important;
  gap:14px !important;
  padding:16px !important;
  border-radius:22px !important;
  background:#f7faf8 !important;
  border:1px solid rgba(23,54,42,.08) !important;
}
#productModal .option-group-full,
#indexProductModal .option-group-full{
  grid-column:1 / -1 !important;
}
#productModal .option-group,
#indexProductModal .option-group{
  min-width:0 !important;
}
#productModal .option-group select,
#productModal .option-group textarea,
#indexProductModal .option-group select,
#indexProductModal .option-group textarea{
  width:100% !important;
  min-width:0 !important;
  border-radius:16px !important;
  font-size:15px !important;
  padding:14px 16px !important;
  box-sizing:border-box !important;
}
#productModal .modal-add-btn,
#indexProductModal .modal-add-btn{
  position:static !important;
  width:100% !important;
  min-height:54px !important;
  margin-top:4px !important;
}
@media (max-width: 768px){
  #productModal.modal,
  #indexProductModal.modal{
    padding:0 !important;
    align-items:flex-end !important;
  }
  #productModal .modal-content,
  #indexProductModal .modal-content,
  #productModal .kb-modal-shell,
  #indexProductModal .kb-modal-shell{
    width:100% !important;
    max-width:100% !important;
    height:100dvh !important;
    max-height:100dvh !important;
    border-radius:28px 28px 0 0 !important;
    grid-template-columns:1fr !important;
    grid-template-rows:auto minmax(0,1fr) !important;
  }
  #productModal .close-btn,
  #indexProductModal .close-btn{
    top:12px !important;
    right:12px !important;
    width:50px !important;
    height:50px !important;
    font-size:36px !important;
  }
  #productModal .modal-img-container,
  #indexProductModal .modal-img-container{
    padding:14px 14px 10px !important;
    border-right:0 !important;
    border-bottom:1px solid rgba(23,54,42,.08) !important;
    background:#f5f8f7 !important;
    overflow:visible !important;
  }
  #productModal .main-img-box,
  #indexProductModal .main-img-box{
    flex:0 0 auto !important;
    height:320px !important;
    min-height:320px !important;
    border-radius:18px !important;
    background:#fff !important;
  }
  #productModal .main-img-box img,
  #indexProductModal .main-img-box img{
    padding:0 !important;
  }
  #productModal .thumbnails-row,
  #indexProductModal .thumbnails-row{
    padding:10px 0 0 !important;
    gap:10px !important;
    background:transparent !important;
    border-top:0 !important;
  }
  #productModal .thumb-img,
  #indexProductModal .thumb-img{
    width:64px !important;
    height:64px !important;
    border-radius:16px !important;
  }
  #productModal .modal-info,
  #indexProductModal .modal-info{
    padding:18px 16px calc(24px + env(safe-area-inset-bottom)) !important;
    gap:12px !important;
  }
  #productModal .modal-info h2,
  #indexProductModal .modal-info h2{
    font-size:clamp(2rem,9vw,2.7rem) !important;
  }
  #productModal #modalDesc,
  #indexProductModal #indexModalDesc{
    font-size:15px !important;
    line-height:1.55 !important;
  }
  #productModal .modal-price-new,
  #indexProductModal .modal-price-new{
    font-size:2rem !important;
  }
  #productModal .product-options,
  #indexProductModal .product-options{
    grid-template-columns:1fr !important;
    gap:12px !important;
    padding:14px !important;
    border-radius:20px !important;
  }
  #productModal .option-group select,
  #productModal .option-group textarea,
  #indexProductModal .option-group select,
  #indexProductModal .option-group textarea{
    font-size:16px !important;
  }
}


/* ===== 2026.04.14 THANK YOU PAGE MOBILE + SIMPLIFY FIX ===== */
body.woocommerce-order-received .woocommerce .woocommerce-order {
  padding: 0 !important;
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
}

body.woocommerce-order-received .woocommerce-notice--success,
body.woocommerce-order-received .woocommerce-thankyou-order-received {
  margin: 0 0 18px;
  padding: 16px 20px;
  border-radius: 20px;
  background: rgba(255,255,255,.82);
  border: 1px solid rgba(23,54,42,.08);
  box-shadow: var(--shadow-soft);
  font-weight: 600;
}

body.woocommerce-order-received .woocommerce-order-overview,
body.woocommerce-order-received .woocommerce-order-details,
body.woocommerce-order-received .woocommerce-customer-details,
body.woocommerce-order-received .woocommerce-columns--addresses {
  display: none !important;
}

.kemer-thankyou-grid--compact {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.kemer-thankyou-inline-note {
  margin-top: 16px;
  padding: 14px 16px;
  border-radius: 18px;
  background: rgba(237, 246, 250, 0.62);
  border: 1px solid rgba(23,54,42,.08);
  color: var(--text-soft);
  font-size: .96rem;
}

body.woocommerce-order-received .woocommerce-order > .woocommerce-notice + .kemer-thankyou-hero {
  margin-top: 0;
}

@media (max-width: 720px) {
  body.woocommerce-order-received .site-main {
    overflow-x: hidden;
  }

  body.woocommerce-order-received .woocommerce-notice--success,
  body.woocommerce-order-received .woocommerce-thankyou-order-received {
    padding: 14px 16px;
    border-radius: 18px;
    font-size: .95rem;
    line-height: 1.5;
  }

  .kemer-thankyou-card {
    padding: 20px 16px;
    border-radius: 24px;
  }

  .kemer-thankyou-card h2 {
    margin-top: 12px;
    font-size: clamp(2rem, 9vw, 2.9rem);
    line-height: .96;
  }

  .kemer-thankyou-card p {
    font-size: .98rem;
    line-height: 1.55;
  }

  .kemer-thankyou-grid,
  .kemer-thankyou-grid--compact {
    grid-template-columns: 1fr;
    gap: 10px;
    margin-top: 18px;
  }

  .kemer-thankyou-stat {
    padding: 15px 16px;
    border-radius: 18px;
  }

  .kemer-thankyou-stat strong {
    font-size: 1rem;
    word-break: break-word;
  }

  .kemer-thankyou-inline-note {
    margin-top: 12px;
    padding: 13px 14px;
    border-radius: 16px;
    font-size: .92rem;
    line-height: 1.5;
  }

  .kemer-thankyou-actions {
    margin-top: 16px;
    flex-direction: column;
  }

  .kemer-thankyou-btn {
    width: 100%;
  }
}
/* ===== CARD HEIGHT EQUALIZER HOTFIX ===== */
#homeProductGrid,
#product-container.kb-store-grid,
.kb-home-products-grid,
.kb-store-grid{
  align-items:stretch !important;
  grid-auto-rows:1fr !important;
}

#homeProductGrid > .store-item,
#product-container.kb-store-grid > .store-item,
.kb-home-products-grid > .store-item,
.kb-store-grid > .store-item{
  height:100% !important;
  display:flex !important;
  flex-direction:column !important;
}

.store-item .info-box{
  flex:1 1 auto !important;
  display:flex !important;
  flex-direction:column !important;
}

.store-item .info-box h3{
  display:-webkit-box !important;
  -webkit-box-orient:vertical !important;
  -webkit-line-clamp:2 !important;
  overflow:hidden !important;
  min-height:2.1em !important;
}

.store-item .info-box p{
  min-height:3.3em !important;
}

.store-item .store-card-bottom{
  margin-top:auto !important;
  align-items:flex-end !important;
}

.store-item .store-price{
  line-height:1 !important;
}

.store-item .add-btn{
  min-width:112px !important;
}

@media (max-width: 768px){
  .store-item .info-box h3{
    min-height:2.2em !important;
  }
  .store-item .info-box p{
    min-height:2.9em !important;
  }
}
/* ===== MODAL PRICE BOX NO BORDER ===== */
.product-modal .product-price,
.modal-product-price,
.quickview-price,
#productModal .product-price,
#storeProductModal .product-price {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: flex-start !important;
  width: auto !important;
  min-height: unset !important;
  padding: 14px 18px !important;
  margin: 0 0 18px 0 !important;
  background: rgba(23, 79, 61, 0.08) !important;
  border: 0 !important;
  outline: 0 !important;
  border-radius: 20px !important;
  box-shadow: none !important;
}

.product-modal .product-price .amount,
.modal-product-price .amount,
.quickview-price .amount,
#productModal .product-price .amount,
#storeProductModal .product-price .amount {
  display: inline-flex !important;
  align-items: center !important;
  font-size: clamp(34px, 4vw, 52px) !important;
  line-height: 1 !important;
  font-weight: 800 !important;
  color: #174f3d !important;
  padding: 0 !important;
  margin: 0 !important;
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
}

.product-modal .product-price *:not(.amount),
.modal-product-price *:not(.amount),
.quickview-price *:not(.amount),
#productModal .product-price *:not(.amount),
#storeProductModal .product-price *:not(.amount) {
  background: transparent !important;
  border: 0 !important;
  outline: 0 !important;
  box-shadow: none !important;
}

@media (max-width: 768px) {
  .product-modal .product-price,
  .modal-product-price,
  .quickview-price,
  #productModal .product-price,
  #storeProductModal .product-price {
    padding: 12px 16px !important;
    border-radius: 16px !important;
    margin-bottom: 16px !important;
  }

  .product-modal .product-price .amount,
  .modal-product-price .amount,
  .quickview-price .amount,
  #productModal .product-price .amount,
  #storeProductModal .product-price .amount {
    font-size: 28px !important;
  }
}
/* ===== INDEX MOBILE FINAL FIX / SAĞA KAYMA + VITRIN SCROLL ===== */
@media (max-width: 768px) {
  html,
  body,
  body.home {
    overflow-x: hidden !important;
    max-width: 100% !important;
  }

  body.home main,
  body.home .site-header,
  body.home .container,
  body.home .header-shell,
  body.home .kb-home-top-grid,
  body.home .kb-home-hero-copy,
  body.home .hero-content,
  body.home .kb-home-hero-cards,
  body.home .hero-category-grid,
  body.home .home-trust-strip,
  body.home .kb-home-products-section,
  body.home #homeProductGrid,
  body.home .map-section,
  body.home .kb-faq-section {
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
    box-sizing: border-box !important;
  }

  body.home .container,
  body.home .home-trust-strip,
  body.home .kb-home-products-section.container,
  body.home .kb-faq-section.container,
  body.home .kb-home-top-grid.container {
    width: calc(100% - 24px) !important;
    max-width: calc(100% - 24px) !important;
    margin-left: auto !important;
    margin-right: auto !important;
  }

  body.home .header-shell {
    display: grid !important;
    grid-template-columns: minmax(0, 1fr) 64px 44px 44px !important;
    gap: 8px !important;
    padding: 10px 12px !important;
    align-items: center !important;
  }

  body.home .site-logo {
    min-width: 0 !important;
    overflow: hidden !important;
  }

  body.home .site-logo img {
    display: block !important;
    max-width: 100% !important;
    width: auto !important;
    height: 34px !important;
    object-fit: contain !important;
  }

  body.home .header-lang-wrapper {
    min-width: 0 !important;
    max-width: 64px !important;
    overflow: hidden !important;
  }

  body.home .header-actions {
    min-width: 0 !important;
  }

  body.home .hero-actions {
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 10px !important;
  }

  body.home .hero-actions .kb-btn,
  body.home .hero-actions a {
    width: 100% !important;
    max-width: 100% !important;
  }

  body.home .hero-category-grid,
  body.home .kb-home-hero-cards,
  body.home #homeProductGrid {
    margin-left: 0 !important;
    margin-right: 0 !important;
  }

  /* Vitrin mobil kaydırma geri aç */
  body.home .home-vitrine-inline-section,
  body.home .home-vitrine-inline-shell {
    overflow: visible !important;
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
    box-sizing: border-box !important;
  }

  body.home .home-vitrine-inline-grid {
    display: flex !important;
    flex-wrap: nowrap !important;
    gap: 12px !important;
    overflow-x: auto !important;
    overflow-y: hidden !important;
    padding: 2px 2px 8px !important;
    margin: 0 !important;
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
    scroll-snap-type: x proximity !important;
    -webkit-overflow-scrolling: touch !important;
    scrollbar-width: none !important;
  }

  body.home .home-vitrine-inline-grid::-webkit-scrollbar {
    display: none !important;
  }

  body.home .home-vitrine-inline-card,
  body.home .home-vitrine-inline-grid.vitrine-count-1 .home-vitrine-inline-card,
  body.home .home-vitrine-inline-grid.vitrine-count-2 .home-vitrine-inline-card,
  body.home .home-vitrine-inline-grid.vitrine-count-3 .home-vitrine-inline-card,
  body.home .home-vitrine-inline-grid.vitrine-count-4 .home-vitrine-inline-card {
    flex: 0 0 84% !important;
    min-width: 84% !important;
    max-width: 84% !important;
    scroll-snap-align: start !important;
    grid-column: auto !important;
  }
}
/* ===== HEADER LOGO + LANGUAGE FIX ===== */

/* Desktop */
.site-header .header-shell {
  align-items: center !important;
}

.site-logo {
  display: flex !important;
  align-items: center !important;
  min-width: 0 !important;
  overflow: visible !important;
}

.site-logo img {
  display: block !important;
  width: auto !important;
  height: 64px !important;
  max-width: 260px !important;
  object-fit: contain !important;
}

.header-lang-wrapper {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  min-width: 120px !important;
  height: 48px !important;
  padding: 0 12px !important;
  border-radius: 18px !important;
  background: #fff !important;
  border: 1px solid #e2e8e1 !important;
  overflow: visible !important;
  position: relative !important;
  z-index: 20 !important;
}

.header-lang-wrapper * {
  pointer-events: auto !important;
}

.header-lang-wrapper select,
.header-lang-wrapper .gt_selector,
.header-lang-wrapper .goog-te-combo {
  width: 100% !important;
  min-width: 90px !important;
  max-width: none !important;
  height: auto !important;
  border: 0 !important;
  outline: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
  font-size: 14px !important;
  line-height: 1.2 !important;
  color: #173f34 !important;
  cursor: pointer !important;
}

/* GTranslate bazı sürümlerde iç div üretirse */
.header-lang-wrapper .gt_switcher,
.header-lang-wrapper .gt_float_switcher,
.header-lang-wrapper .notranslate {
  width: 100% !important;
  max-width: none !important;
  position: relative !important;
  box-shadow: none !important;
  border: 0 !important;
  background: transparent !important;
}

/* Mobile */
@media (max-width: 768px) {
  body.home .header-shell,
  .header-shell {
    display: grid !important;
    grid-template-columns: minmax(0, 1fr) auto auto auto !important;
    gap: 8px !important;
    align-items: center !important;
  }

  body.home .site-logo,
  .site-logo {
    overflow: visible !important;
  }

  body.home .site-logo img,
  .site-logo img {
    height: 52px !important;
    max-width: 180px !important;
    width: auto !important;
  }

  body.home .header-lang-wrapper,
  .header-lang-wrapper {
    min-width: 92px !important;
    max-width: none !important;
    height: 44px !important;
    padding: 0 10px !important;
    overflow: visible !important;
  }

  body.home .header-lang-wrapper select,
  body.home .header-lang-wrapper .gt_selector,
  body.home .header-lang-wrapper .goog-te-combo,
  .header-lang-wrapper select,
  .header-lang-wrapper .gt_selector,
  .header-lang-wrapper .goog-te-combo {
    min-width: 72px !important;
    font-size: 13px !important;
  }
}
/* ===== HERO ALTINA DIL SECICI ===== */
.hero-lang-strip{
  margin: 14px auto 18px !important;
}

.hero-lang-strip__inner{
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 8px !important;
  padding: 10px 14px !important;
  border-radius: 22px !important;
  background: rgba(255,255,255,.78) !important;
  backdrop-filter: blur(10px) !important;
  -webkit-backdrop-filter: blur(10px) !important;
  box-shadow: 0 10px 24px rgba(23,79,61,.06) !important;
  overflow: visible !important;
}

/* GTranslate kapsayıcıları */
.hero-lang-strip .gtranslate_wrapper,
.hero-lang-strip .gt_switcher,
.hero-lang-strip .gt_float_switcher,
.hero-lang-strip .goog-te-gadget,
.hero-lang-strip .goog-te-gadget-simple,
.hero-lang-strip .notranslate,
.hero-lang-strip .gt_option{
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 8px !important;
  width: auto !important;
  max-width: none !important;
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
  padding: 0 !important;
  margin: 0 !important;
  position: static !important;
  opacity: 1 !important;
  visibility: visible !important;
  pointer-events: auto !important;
  transform: none !important;
  overflow: visible !important;
}

/* select/dropdown varsa kapat */
.hero-lang-strip .gt_selected,
.hero-lang-strip .goog-te-gadget > span,
.hero-lang-strip select,
.hero-lang-strip .goog-te-combo{
  display: none !important;
}

/* flag item */
.hero-lang-strip a.glink,
.hero-lang-strip .gt_option a,
.hero-lang-strip a[title]{
  width: 38px !important;
  height: 38px !important;
  min-width: 38px !important;
  min-height: 38px !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  padding: 0 !important;
  margin: 0 !important;
  border-radius: 12px !important;
  overflow: hidden !important;
  background: #fff !important;
  border: 1px solid #dfe8e2 !important;
  box-shadow: 0 4px 10px rgba(23,79,61,.05) !important;
  text-decoration: none !important;
  font-size: 0 !important;
  line-height: 0 !important;
  color: transparent !important;
}

.hero-lang-strip a.glink span,
.hero-lang-strip .gt_option a span,
.hero-lang-strip a[title] span{
  display: none !important;
}

.hero-lang-strip a.glink img,
.hero-lang-strip .gt_option a img,
.hero-lang-strip a[title] img{
  display: block !important;
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  margin: 0 !important;
  border-radius: inherit !important;
}

.hero-lang-strip a.glink.gt-current-lang,
.hero-lang-strip a.glink.active,
.hero-lang-strip .gt_option a.active{
  border-color: #174f3d !important;
  box-shadow: 0 0 0 2px rgba(23,79,61,.12) !important;
}

@media (max-width: 768px){
  .hero-lang-strip{
    margin: 12px auto 16px !important;
  }

  .hero-lang-strip__inner{
    gap: 6px !important;
    padding: 8px 10px !important;
    border-radius: 18px !important;
  }

  .hero-lang-strip a.glink,
  .hero-lang-strip .gt_option a,
  .hero-lang-strip a[title]{
    width: 32px !important;
    height: 32px !important;
    min-width: 32px !important;
    min-height: 32px !important;
    border-radius: 10px !important;
  }
}
/* ===== HEADER LOGO BÜYÜTME FINAL ===== */
.site-logo{
  display:flex !important;
  align-items:center !important;
  flex-shrink:0 !important;
  overflow:visible !important;
}

.site-logo img{
  display:block !important;
  width:auto !important;
  height:110px !important;
  max-width:520px !important;
  object-fit:contain !important;
}

@media (max-width: 1024px){
  .site-logo img{
    height:88px !important;
    max-width:360px !important;
  }
}

@media (max-width: 768px){
  .site-logo img,
  body.home .site-logo img{
    height:72px !important;
    max-width:260px !important;
    width:auto !important;
  }
}