﻿/* ========== CSS VARIABLES & RESET ========== */
:root {
  /* Primary Colors - Rich Teal */
  --color-primary: #0A6E6B;
  --color-primary-dark: #07524F;
  --color-primary-light: #0D8C88;
  --color-primary-ultra-light: #E8F5F4;

  /* Accent - Warm Coral/Gold */
  --color-accent: #E8734A;
  --color-accent-dark: #D45D35;
  --color-accent-light: #FF8F6B;
  --color-accent-ultra-light: #FFF0EB;

  /* Neutrals */
  --color-dark: #1A1A2E;
  --color-dark-light: #2D2D44;
  --color-body: #4A4A5A;
  --color-muted: #6B6B7B;
  --color-border: #E5E5EE;
  --color-border-light: #F0F0F5;
  --color-bg: #FAFAFC;
  --color-white: #FFFFFF;

  /* WhatsApp Green */
  --color-whatsapp: #25D366;
  --color-whatsapp-dark: #1EBE5A;

  /* Typography */
  --font-display: "DM Serif Display", Georgia, serif;
  --font-body: "Sora", "Noto Sans SC", sans-serif;
  --font-chinese: "Noto Sans SC", sans-serif;

  /* Spacing */
  --space-xs: 0.25rem;
  --space-sm: 0.5rem;
  --space-md: 1rem;
  --space-lg: 1.5rem;
  --space-xl: 2rem;
  --space-2xl: 3rem;
  --space-3xl: 4rem;
  --space-4xl: 6rem;

  /* Border Radius */
  --radius-sm: 0.375rem;
  --radius-md: 0.75rem;
  --radius-lg: 1rem;
  --radius-xl: 1.5rem;
  --radius-full: 9999px;

  /* Shadows */
  --shadow-sm: 0 1px 3px rgba(26, 26, 46, 0.08);
  --shadow-md: 0 4px 12px rgba(26, 26, 46, 0.1);
  --shadow-lg: 0 8px 30px rgba(26, 26, 46, 0.12);
  --shadow-xl: 0 20px 50px rgba(26, 26, 46, 0.15);

  /* Transitions */
  --transition-fast: 150ms ease;
  --transition-base: 250ms ease;
  --transition-slow: 400ms ease;

  /* Layout */
  --max-width: 1200px;
  --header-height: 72px;
}

/* Reset */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; scroll-padding-top: var(--header-height); }
body {
  font-family: var(--font-body);
  color: var(--color-body);
  background-color: var(--color-bg);
  line-height: 1.6;
  font-size: 16px;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}
img { max-width: 100%; height: auto; display: block; }
a { color: var(--color-primary); text-decoration: none; transition: color var(--transition-fast); }
a:hover { color: var(--color-primary-light); }
ul { list-style: none; }
button { font-family: inherit; cursor: pointer; border: none; background: none; }
input, textarea, select { font-family: inherit; font-size: inherit; }
h1, h2, h3, h4, h5, h6 { color: var(--color-dark); line-height: 1.2; }

/* Skip Link */
.skip-link {
  position: absolute;
  top: -100%;
  left: var(--space-md);
  background: var(--color-primary);
  color: var(--color-white);
  padding: var(--space-sm) var(--space-md);
  border-radius: var(--radius-sm);
  z-index: 10000;
  font-weight: 600;
}
.skip-link:focus { top: var(--space-md); }

/* Container */
.container { width: 100%; max-width: var(--max-width); margin: 0 auto; padding: 0 var(--space-lg); }
@media (max-width: 768px) { .container { padding: 0 var(--space-md); } }

/* ========== HEADER & NAVIGATION ========== */
.header {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 1000;
  background: rgba(255, 255, 255, 0.95);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  border-bottom: 1px solid var(--color-border-light);
  height: var(--header-height);
  transition: box-shadow var(--transition-base);
}
.header.scrolled { box-shadow: var(--shadow-md); }
.header__inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  height: var(--header-height);
}
.logo { display: flex; align-items: center; gap: var(--space-sm); }
.logo__icon { font-size: 2rem; line-height: 1; }
.logo__text { display: flex; flex-direction: column; }
.logo__name {
  font-family: var(--font-display);
  font-size: 1.25rem;
  color: var(--color-primary-dark);
  line-height: 1.2;
}
.logo__tagline { font-size: 0.7rem; color: var(--color-muted); letter-spacing: 0.5px; }
.nav__menu { display: flex; align-items: center; gap: var(--space-xs); }
.nav__link {
  padding: var(--space-sm) var(--space-md);
  border-radius: var(--radius-full);
  font-size: 0.9rem;
  font-weight: 500;
  color: var(--color-dark);
  transition: all var(--transition-fast);
  white-space: nowrap;
}
.nav__link:hover { background: var(--color-primary-ultra-light); color: var(--color-primary); }
.nav__link.active { background: var(--color-primary); color: var(--color-white); }
.nav__link--cta {
  background: var(--color-accent);
  color: var(--color-white);
  font-weight: 600;
}
.nav__link--cta:hover { background: var(--color-accent-dark); color: var(--color-white); }
.nav__toggle { display: none; flex-direction: column; gap: 5px; padding: var(--space-sm); }
.nav__toggle-line { width: 24px; height: 2px; background: var(--color-dark); border-radius: 2px; transition: all var(--transition-base); }
.header__actions { display: flex; align-items: center; gap: var(--space-md); }
.lang-toggle {
  display: flex; align-items: center; gap: var(--space-xs);
  padding: var(--space-sm) var(--space-md);
  border: 2px solid var(--color-border);
  border-radius: var(--radius-full);
  font-size: 0.85rem; font-weight: 600;
  color: var(--color-dark);
  transition: all var(--transition-fast);
}
.lang-toggle:hover { border-color: var(--color-primary); background: var(--color-primary-ultra-light); }
.lang-toggle__icon { font-size: 1.1rem; }
@media (max-width: 768px) {
  .nav__toggle { display: flex; }
  .nav__menu {
    position: fixed;
    top: var(--header-height);
    left: 0; right: 0;
    background: var(--color-white);
    flex-direction: column;
    padding: var(--space-lg);
    gap: var(--space-xs);
    box-shadow: var(--shadow-lg);
    transform: translateY(-120%);
    opacity: 0;
    transition: all var(--transition-slow);
    pointer-events: none;
  }
  .nav__menu.open { transform: translateY(0); opacity: 1; pointer-events: all; }
  .nav__link { width: 100%; text-align: center; padding: var(--space-md); }
  .nav__link.active { background: var(--color-primary-ultra-light); color: var(--color-primary); }
}

/* ========== BUTTONS ========== */
.btn {
  display: inline-flex; align-items: center; justify-content: center; gap: var(--space-sm);
  padding: 0.75rem 1.5rem;
  font-size: 0.95rem; font-weight: 600;
  border-radius: var(--radius-full);
  transition: all var(--transition-fast);
  text-align: center; line-height: 1.4;
  border: 2px solid transparent;
  cursor: pointer;
}
.btn:hover { transform: translateY(-2px); box-shadow: var(--shadow-md); }
.btn:active { transform: translateY(0); }
.btn--primary { background: var(--color-accent); color: var(--color-white); border-color: var(--color-accent); }
.btn--primary:hover { background: var(--color-accent-dark); border-color: var(--color-accent-dark); color: var(--color-white); }
.btn--outline { background: transparent; color: var(--color-primary); border-color: var(--color-primary); }
.btn--outline:hover { background: var(--color-primary); color: var(--color-white); }
.btn--whatsapp { background: var(--color-whatsapp); color: var(--color-white); border-color: var(--color-whatsapp); }
.btn--whatsapp:hover { background: var(--color-whatsapp-dark); border-color: var(--color-whatsapp-dark); color: var(--color-white); }
.btn--lg { padding: 1rem 2rem; font-size: 1.05rem; }
.btn--full { width: 100%; }
.btn__icon { font-size: 1.2em; line-height: 1; }

/* ========== HERO SECTION ========== */
.hero { padding-top: calc(var(--header-height) + var(--space-4xl)); padding-bottom: var(--space-3xl); background: linear-gradient(135deg, var(--color-primary-ultra-light) 0%, var(--color-bg) 50%, var(--color-accent-ultra-light) 100%); position: relative; overflow: hidden; }
.hero__bg-pattern { position: absolute; inset: 0; background-image: radial-gradient(circle at 20% 50%, rgba(10, 110, 107, 0.05) 0%, transparent 50%), radial-gradient(circle at 80% 20%, rgba(232, 115, 74, 0.05) 0%, transparent 50%); pointer-events: none; }
.hero__inner { display: grid; grid-template-columns: 1fr 1fr; gap: var(--space-3xl); align-items: center; position: relative; z-index: 1; }
.hero__badge { display: inline-block; padding: var(--space-sm) var(--space-lg); background: var(--color-white); border: 1px solid var(--color-border); border-radius: var(--radius-full); font-size: 0.85rem; font-weight: 500; color: var(--color-dark); margin-bottom: var(--space-lg); box-shadow: var(--shadow-sm); }
.hero__title { font-family: var(--font-display); font-size: clamp(2rem, 5vw, 3.5rem); color: var(--color-dark); line-height: 1.15; margin-bottom: var(--space-lg); }
.hero__title::first-letter { color: var(--color-primary); }
.hero__subtitle { font-size: 1.1rem; color: var(--color-muted); line-height: 1.7; margin-bottom: var(--space-2xl); max-width: 540px; }
.hero__actions { display: flex; flex-wrap: wrap; gap: var(--space-md); margin-bottom: var(--space-2xl); }
.hero__stats { display: flex; gap: var(--space-2xl); padding-top: var(--space-xl); border-top: 1px solid var(--color-border-light); }
.hero__stat { display: flex; flex-direction: column; }
.hero__stat-number { font-family: var(--font-display); font-size: 1.75rem; color: var(--color-primary); line-height: 1.2; }
.hero__stat-label { font-size: 0.85rem; color: var(--color-muted); }
.hero__image { display: flex; justify-content: center; align-items: center; }
.hero__image-placeholder { width: 100%; max-width: 420px; aspect-ratio: 4/3; background: linear-gradient(135deg, var(--color-primary-ultra-light), var(--color-accent-ultra-light)); border-radius: var(--radius-xl); display: flex; flex-direction: column; align-items: center; justify-content: center; gap: var(--space-md); border: 2px dashed var(--color-border); }
.hero__image-icon { font-size: 4rem; }
.hero__image-text { font-size: 0.9rem; color: var(--color-muted); font-weight: 500; }
@media (max-width: 900px) {
  .hero__inner { grid-template-columns: 1fr; gap: var(--space-2xl); }
  .hero__image { order: -1; }
  .hero__image-placeholder { max-width: 320px; }
  .hero__stats { gap: var(--space-lg); }
}
@media (max-width: 480px) {
  .hero__stats { flex-direction: column; gap: var(--space-md); }
  .hero__actions { flex-direction: column; }
  .hero__actions .btn { width: 100%; }
}

/* ========== CATEGORIES ========== */
.categories { padding: var(--space-3xl) 0; }
.categories__title { text-align: center; font-family: var(--font-display); font-size: 1.75rem; margin-bottom: var(--space-2xl); color: var(--color-dark); }
.categories__grid { display: grid; grid-template-columns: repeat(6, 1fr); gap: var(--space-md); }
.category-card {
  display: flex; flex-direction: column; align-items: center; gap: var(--space-sm);
  padding: var(--space-xl) var(--space-md);
  background: var(--color-white);
  border: 1px solid var(--color-border-light);
  border-radius: var(--radius-lg);
  transition: all var(--transition-base);
  text-align: center;
}
.category-card:hover { border-color: var(--color-primary); box-shadow: var(--shadow-md); transform: translateY(-4px); }
.category-card__icon { font-size: 2rem; }
.category-card__name { font-size: 0.85rem; font-weight: 600; color: var(--color-dark); }
@media (max-width: 768px) { .categories__grid { grid-template-columns: repeat(3, 1fr); } }
@media (max-width: 480px) { .categories__grid { grid-template-columns: repeat(2, 1fr); } }

/* ========== SECTION COMMON ========== */
.section-header { text-align: center; margin-bottom: var(--space-2xl); }
.section-title { font-family: var(--font-display); font-size: clamp(1.75rem, 4vw, 2.5rem); margin-bottom: var(--space-sm); color: var(--color-dark); }
.section-subtitle { font-size: 1rem; color: var(--color-muted); max-width: 600px; margin: 0 auto; }
.section-label { display: inline-block; padding: var(--space-xs) var(--space-md); background: var(--color-primary-ultra-light); color: var(--color-primary); border-radius: var(--radius-full); font-size: 0.8rem; font-weight: 600; text-transform: uppercase; letter-spacing: 1px; margin-bottom: var(--space-md); }
.section-cta { text-align: center; margin-top: var(--space-2xl); }
.featured-section { padding: var(--space-3xl) 0; background: var(--color-white); }

/* ========== PRODUCT FILTERS ========== */
.product-filters { display: flex; flex-wrap: wrap; justify-content: center; gap: var(--space-sm); margin-bottom: var(--space-2xl); }
.filter-btn {
  padding: var(--space-sm) var(--space-lg);
  border: 2px solid var(--color-border);
  border-radius: var(--radius-full);
  font-size: 0.85rem; font-weight: 600;
  color: var(--color-muted);
  transition: all var(--transition-fast);
  cursor: pointer;
}
.filter-btn:hover { border-color: var(--color-primary); color: var(--color-primary); }
.filter-btn.active { background: var(--color-primary); border-color: var(--color-primary); color: var(--color-white); }

/* ========== PRODUCT GRID ========== */
.product-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(260px, 1fr)); gap: var(--space-xl); }
.product-grid--featured { grid-template-columns: repeat(auto-fill, minmax(240px, 1fr)); }

/* ========== PRODUCT CARD ========== */
.product-card {
  background: var(--color-white);
  border-radius: var(--radius-lg);
  border: 1px solid var(--color-border-light);
  overflow: hidden;
  transition: all var(--transition-base);
  position: relative;
}
.product-card:hover { box-shadow: var(--shadow-lg); transform: translateY(-6px); border-color: transparent; }
.product-card__image { aspect-ratio: 1/1; background: linear-gradient(135deg, #F5F5FA, #EDEDF5); display: flex; align-items: center; justify-content: center; position: relative; overflow: hidden; }
.product-card__placeholder { font-size: 3rem; opacity: 0.6; }
.product-card__badge { position: absolute; top: var(--space-md); left: var(--space-md); padding: var(--space-xs) var(--space-md); border-radius: var(--radius-full); font-size: 0.75rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.5px; color: var(--color-white); z-index: 2; }
.product-card__badge--hot { background: var(--color-accent); }
.product-card__badge--new { background: var(--color-primary); }
.product-card__badge--promo { background: #8B5CF6; }
.product-card__content { padding: var(--space-lg); }
.product-card__category { display: inline-block; font-size: 0.75rem; font-weight: 600; color: var(--color-primary); text-transform: uppercase; letter-spacing: 0.5px; margin-bottom: var(--space-xs); }
.product-card__name { font-family: var(--font-display); font-size: 1.15rem; margin-bottom: var(--space-sm); }
.product-card__desc { font-size: 0.85rem; color: var(--color-muted); line-height: 1.5; margin-bottom: var(--space-md); display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }
.product-card__footer { display: flex; align-items: center; justify-content: space-between; padding-top: var(--space-md); border-top: 1px solid var(--color-border-light); }
.product-card__price { font-size: 0.8rem; font-weight: 600; color: var(--color-accent); }
.product-card__cta { display: inline-flex; align-items: center; gap: var(--space-xs); padding: var(--space-sm) var(--space-md); background: var(--color-whatsapp); color: var(--color-white); border-radius: var(--radius-full); font-size: 0.8rem; font-weight: 600; transition: all var(--transition-fast); }
.product-card__cta:hover { background: var(--color-whatsapp-dark); transform: scale(1.05); color: var(--color-white); }
@media (max-width: 480px) { .product-grid { grid-template-columns: 1fr; } .product-grid--featured { grid-template-columns: repeat(2, 1fr); } }

/* ========== PROMO BANNER ========== */
.promo-banner { margin-top: var(--space-3xl); background: linear-gradient(135deg, var(--color-primary-ultra-light) 0%, var(--color-accent-ultra-light) 100%); border-radius: var(--radius-xl); padding: var(--space-3xl); display: grid; grid-template-columns: 1fr auto; gap: var(--space-2xl); align-items: center; border: 1px solid var(--color-border-light); }
.promo-banner__badge { font-size: 0.85rem; font-weight: 600; color: var(--color-primary); display: block; margin-bottom: var(--space-md); }
.promo-banner__title { font-family: var(--font-display); font-size: 1.75rem; margin-bottom: var(--space-md); }
.promo-banner__text { color: var(--color-muted); margin-bottom: var(--space-xl); max-width: 500px; }
.promo-banner__image { display: flex; align-items: center; justify-content: center; }
.promo-banner__icon { font-size: 5rem; opacity: 0.8; }
@media (max-width: 768px) { .promo-banner { grid-template-columns: 1fr; text-align: center; } .promo-banner__image { display: none; } }

/* ========== ABOUT SECTION ========== */
.about-section { padding: var(--space-4xl) 0; background: var(--color-bg); }
.about-grid { display: grid; grid-template-columns: 1.2fr 1fr; gap: var(--space-3xl); align-items: start; }
.about__text { margin-bottom: var(--space-lg); line-height: 1.8; color: var(--color-body); }
.about__features { display: flex; flex-direction: column; gap: var(--space-lg); margin-top: var(--space-2xl); }
.about__feature { display: flex; gap: var(--space-md); align-items: flex-start; }
.about__feature-icon { font-size: 1.5rem; flex-shrink: 0; }
.about__feature h4 { font-size: 1rem; margin-bottom: var(--space-xs); }
.about__feature p { font-size: 0.9rem; color: var(--color-muted); }
.about__visual { position: sticky; top: calc(var(--header-height) + var(--space-xl)); }
.about__image-placeholder { aspect-ratio: 4/3; background: linear-gradient(135deg, var(--color-primary-ultra-light), var(--color-accent-ultra-light)); border-radius: var(--radius-xl); display: flex; flex-direction: column; align-items: center; justify-content: center; gap: var(--space-md); border: 2px dashed var(--color-border); margin-bottom: var(--space-xl); }
.about__image-icon { font-size: 3.5rem; }
.about__image-text { font-size: 0.9rem; color: var(--color-muted); font-weight: 500; }
.about__info-card { background: var(--color-white); border-radius: var(--radius-lg); padding: var(--space-xl); box-shadow: var(--shadow-md); border: 1px solid var(--color-border-light); }
.about__info-card h4 { font-family: var(--font-display); font-size: 1.15rem; margin-bottom: var(--space-md); }
.about__hours { display: flex; flex-direction: column; gap: var(--space-sm); }
.about__hours li { display: flex; justify-content: space-between; font-size: 0.9rem; padding: var(--space-sm) 0; border-bottom: 1px solid var(--color-border-light); }
.about__hours li:last-child { border-bottom: none; }
.about__hours li span:first-child { color: var(--color-body); }
.about__hours li span:last-child { font-weight: 600; color: var(--color-dark); }
@media (max-width: 900px) { .about-grid { grid-template-columns: 1fr; } .about__visual { position: static; } }

/* ========== GALLERY SECTION ========== */
.gallery-section { padding: var(--space-4xl) 0; background: var(--color-white); }
.gallery-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--space-md); margin-bottom: var(--space-3xl); }
.gallery-item { border-radius: var(--radius-md); overflow: hidden; }
.gallery-item--wide { grid-column: span 2; }
.gallery-item__placeholder { aspect-ratio: 4/3; background: linear-gradient(135deg, #F0F0F5, #E8E8F0); display: flex; flex-direction: column; align-items: center; justify-content: center; gap: var(--space-sm); cursor: pointer; transition: all var(--transition-base); }
.gallery-item__placeholder:hover { background: linear-gradient(135deg, var(--color-primary-ultra-light), var(--color-accent-ultra-light)); }
.gallery-item__placeholder span:first-child { font-size: 2.5rem; opacity: 0.5; }
.gallery-item__placeholder span:last-child { font-size: 0.85rem; color: var(--color-muted); font-weight: 500; }
@media (max-width: 768px) { .gallery-grid { grid-template-columns: repeat(2, 1fr); } .gallery-item--wide { grid-column: span 1; } }

/* ========== REVIEWS ========== */
.reviews { padding-top: var(--space-3xl); border-top: 1px solid var(--color-border-light); }
.reviews__title { font-family: var(--font-display); font-size: 1.75rem; text-align: center; margin-bottom: var(--space-2xl); }
.reviews__grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--space-xl); margin-bottom: var(--space-2xl); }
.review-card { background: var(--color-bg); border-radius: var(--radius-lg); padding: var(--space-xl); border: 1px solid var(--color-border-light); transition: all var(--transition-base); }
.review-card:hover { box-shadow: var(--shadow-md); border-color: var(--color-border); }
.review-card__header { display: flex; align-items: center; gap: var(--space-md); margin-bottom: var(--space-md); }
.review-card__avatar { width: 48px; height: 48px; background: var(--color-primary-ultra-light); border-radius: var(--radius-full); display: flex; align-items: center; justify-content: center; font-size: 1.5rem; }
.review-card__name { font-size: 0.95rem; }
.review-card__rating { font-size: 0.85rem; }
.review-card__text { font-size: 0.9rem; line-height: 1.7; color: var(--color-body); }
.review-cta { text-align: center; padding: var(--space-2xl); background: var(--color-bg); border-radius: var(--radius-lg); }
.review-cta p { font-size: 1.1rem; color: var(--color-dark); margin-bottom: var(--space-lg); }
@media (max-width: 768px) { .reviews__grid { grid-template-columns: 1fr; } }

/* ========== CONTACT SECTION ========== */
.contact-section { padding: var(--space-4xl) 0; background: var(--color-bg); }
.contact-grid { display: grid; grid-template-columns: 1fr 1.2fr; gap: var(--space-3xl); margin-bottom: var(--space-3xl); }
.contact-info { display: flex; flex-direction: column; gap: var(--space-lg); }
.contact-info__card { display: flex; gap: var(--space-md); align-items: flex-start; padding: var(--space-lg); background: var(--color-white); border-radius: var(--radius-lg); border: 1px solid var(--color-border-light); transition: all var(--transition-base); }
.contact-info__card:hover { box-shadow: var(--shadow-md); border-color: var(--color-primary-ultra-light); }
.contact-info__icon { font-size: 1.5rem; flex-shrink: 0; }
.contact-info__card h4 { font-size: 0.95rem; margin-bottom: var(--space-xs); }
.contact-info__card p, .contact-info__card a { font-size: 0.9rem; color: var(--color-muted); line-height: 1.6; }
.contact-info__card a:hover { color: var(--color-primary); }
.contact-form-wrapper { background: var(--color-white); border-radius: var(--radius-xl); padding: var(--space-2xl); box-shadow: var(--shadow-md); border: 1px solid var(--color-border-light); }
.contact-form__title { font-family: var(--font-display); font-size: 1.5rem; margin-bottom: var(--space-sm); }
.contact-form__desc { font-size: 0.9rem; color: var(--color-muted); margin-bottom: var(--space-xl); }
.contact-form { display: flex; flex-direction: column; gap: var(--space-lg); }
.form-group { display: flex; flex-direction: column; gap: var(--space-sm); }
.form-label { font-size: 0.85rem; font-weight: 600; color: var(--color-dark); }
.form-input { padding: 0.875rem 1rem; border: 2px solid var(--color-border); border-radius: var(--radius-md); font-size: 0.95rem; transition: all var(--transition-fast); background: var(--color-bg); }
.form-input:focus { outline: none; border-color: var(--color-primary); box-shadow: 0 0 0 3px rgba(10, 110, 107, 0.1); background: var(--color-white); }
.form-input::placeholder { color: var(--color-muted); }
.form-input--textarea { resize: vertical; min-height: 120px; }
@media (max-width: 900px) { .contact-grid { grid-template-columns: 1fr; } }

/* ========== MAP SECTION ========== */
.map-section { text-align: center; }
.map__title { font-family: var(--font-display); font-size: 1.5rem; margin-bottom: var(--space-xl); }
.map-container { border-radius: var(--radius-lg); overflow: hidden; margin-bottom: var(--space-xl); box-shadow: var(--shadow-md); border: 2px solid var(--color-border-light); }
.map-container iframe { display: block; width: 100%; }

/* ========== WHATSAPP FLOAT ========== */
.whatsapp-float {
  position: fixed;
  bottom: var(--space-xl);
  right: var(--space-xl);
  z-index: 999;
  display: flex;
  align-items: center;
  gap: var(--space-sm);
  background: var(--color-whatsapp);
  color: var(--color-white);
  padding: var(--space-md) var(--space-lg);
  border-radius: var(--radius-full);
  box-shadow: 0 4px 20px rgba(37, 211, 102, 0.4);
  font-weight: 600;
  font-size: 0.9rem;
  transition: all var(--transition-base);
}
.whatsapp-float:hover { background: var(--color-whatsapp-dark); transform: translateY(-4px); box-shadow: 0 8px 30px rgba(37, 211, 102, 0.5); color: var(--color-white); }
.whatsapp-float__icon { width: 28px; height: 28px; }
.whatsapp-float__label { display: inline; }
@media (max-width: 768px) {
  .whatsapp-float { bottom: var(--space-md); right: var(--space-md); padding: var(--space-sm) var(--space-md); }
  .whatsapp-float__label { display: none; }
  .whatsapp-float { padding: var(--space-md); border-radius: var(--radius-full); }
}

/* ========== FOOTER ========== */
.footer { background: var(--color-dark); color: rgba(255, 255, 255, 0.7); padding: var(--space-4xl) 0 var(--space-xl); }
.footer__grid { display: grid; grid-template-columns: 1.5fr 1fr 1fr 1fr; gap: var(--space-2xl); margin-bottom: var(--space-2xl); }
.footer__brand p { font-size: 0.9rem; line-height: 1.7; margin-top: var(--space-md); max-width: 280px; }
.footer__logo { display: flex; align-items: center; gap: var(--space-sm); }
.footer__logo .logo__icon { font-size: 1.75rem; }
.footer__logo .logo__name { color: var(--color-white); font-family: var(--font-display); font-size: 1.1rem; }
.footer__nav h4, .footer__contact h4, .footer__hours h4 { color: var(--color-white); font-size: 0.95rem; margin-bottom: var(--space-lg); }
.footer__nav ul { display: flex; flex-direction: column; gap: var(--space-sm); }
.footer__nav a { color: rgba(255, 255, 255, 0.6); font-size: 0.9rem; transition: color var(--transition-fast); }
.footer__nav a:hover { color: var(--color-white); }
.footer__contact p, .footer__hours p { font-size: 0.9rem; margin-bottom: var(--space-sm); }
.footer__contact a { color: rgba(255, 255, 255, 0.6); }
.footer__contact a:hover { color: var(--color-white); }
.footer__bottom { padding-top: var(--space-xl); border-top: 1px solid rgba(255, 255, 255, 0.1); text-align: center; font-size: 0.85rem; }
@media (max-width: 768px) { .footer__grid { grid-template-columns: 1fr 1fr; gap: var(--space-xl); } }
@media (max-width: 480px) { .footer__grid { grid-template-columns: 1fr; } }

/* ========== PAGE SECTIONS ========== */
.page-section { scroll-margin-top: var(--header-height); }
.products-section { padding: var(--space-4xl) 0; }

/* ========== ANIMATIONS ========== */
@keyframes fadeInUp {
  from { opacity: 0; transform: translateY(30px); }
  to { opacity: 1; transform: translateY(0); }
}
@keyframes fadeIn {
  from { opacity: 0; }
  to { opacity: 1; }
}
@keyframes pulse {
  0%, 100% { transform: scale(1); }
  50% { transform: scale(1.05); }
}
.hero__content { animation: fadeInUp 0.8s ease both; }
.hero__image { animation: fadeInUp 0.8s ease 0.2s both; }
.hero__badge { animation: fadeIn 0.6s ease 0.3s both; }
.category-card { animation: fadeInUp 0.5s ease both; }
.category-card:nth-child(1) { animation-delay: 0.1s; }
.category-card:nth-child(2) { animation-delay: 0.15s; }
.category-card:nth-child(3) { animation-delay: 0.2s; }
.category-card:nth-child(4) { animation-delay: 0.25s; }
.category-card:nth-child(5) { animation-delay: 0.3s; }
.category-card:nth-child(6) { animation-delay: 0.35s; }
.product-card { animation: fadeInUp 0.5s ease both; }
.product-card:nth-child(1) { animation-delay: 0.1s; }
.product-card:nth-child(2) { animation-delay: 0.2s; }
.product-card:nth-child(3) { animation-delay: 0.3s; }
.product-card:nth-child(4) { animation-delay: 0.4s; }
.product-card:nth-child(5) { animation-delay: 0.5s; }
.product-card:nth-child(6) { animation-delay: 0.6s; }
.review-card { animation: fadeInUp 0.5s ease both; }
.review-card:nth-child(1) { animation-delay: 0.1s; }
.review-card:nth-child(2) { animation-delay: 0.2s; }
.review-card:nth-child(3) { animation-delay: 0.3s; }

/* ========== REAL IMAGE STYLES ========== */
.hero__image-real { width: 100%; height: 100%; object-fit: cover; border-radius: var(--radius-xl); box-shadow: var(--shadow-lg); }
.hero__image { display: flex; justify-content: center; align-items: center; }
.hero__image-placeholder { display: none; }
.product-card__img { width: 100%; height: 100%; object-fit: cover; transition: transform var(--transition-slow); }
.product-card:hover .product-card__img { transform: scale(1.05); }
.product-card__placeholder { display: none; }
.about__image-real { width: 100%; height: 100%; object-fit: cover; border-radius: var(--radius-xl); box-shadow: var(--shadow-lg); }
.about__image-placeholder { display: none; }
.gallery__img { width: 100%; height: 100%; object-fit: cover; transition: transform var(--transition-base); }
.gallery-item__placeholder:hover .gallery__img { transform: scale(1.05); }
.gallery-item__placeholder { aspect-ratio: 4/3; overflow: hidden; background: transparent; border: none; }
.gallery-item__placeholder span { display: none; }
