:root {

  /* ── LAYER 1: CORE PRIMITIVES ── */
  --core-green-50:  #f0faf4;
  --core-green-100: #d9f2e4;
  --core-green-200: #b3e5c9;
  --core-green-300: #6fcba0;
  --core-green-400: #4ab37d;
  --core-green-500: #2d8659;
  --core-green-600: #1e6b44;
  --core-green-700: #155233;
  --core-green-800: #0e3a24;
  --core-green-900: #0a2418;
  --core-green-950: #051409;

  --core-neutral-0:   #ffffff;
  --core-neutral-50:  #f8fafc;
  --core-neutral-100: #f1f5f9;
  --core-neutral-200: #e2e8f0;
  --core-neutral-300: #cbd5e1;
  --core-neutral-400: #94a3b8;
  --core-neutral-500: #64748b;
  --core-neutral-600: #475569;
  --core-neutral-700: #334155;
  --core-neutral-800: #1e293b;
  --core-neutral-900: #0f172a;
  --core-neutral-950: #020617;

  --core-orange-50:  #fff7ed;
  --core-orange-100: #ffedd5;
  --core-orange-400: #fb923c;
  --core-orange-500: #f97316;
  --core-orange-600: #ea6c0a;
  --core-orange-700: #c2560a;

  --core-success:    #16a34a;
  --core-warning:    #f59e0b;
  --core-error:      #dc2626;
  --core-star:       #fbbf24;
  --core-whatsapp-light: #25d366;
  --core-whatsapp-dark:  #128c7e;

  --core-space-1:  4px;
  --core-space-2:  8px;
  --core-space-3:  12px;
  --core-space-4:  16px;
  --core-space-5:  20px;
  --core-space-6:  24px;
  --core-space-8:  32px;
  --core-space-10: 40px;
  --core-space-12: 48px;
  --core-space-16: 64px;
  --core-space-20: 80px;
  --core-space-24: 96px;
  --core-space-28: 112px;
  --core-space-32: 128px;

  --core-radius-xs:   6px;
  --core-radius-sm:   10px;
  --core-radius-md:   14px;
  --core-radius-lg:   20px;
  --core-radius-xl:   24px;
  --core-radius-2xl:  32px;
  --core-radius-full: 9999px;

  --core-text-xs:   0.75rem;
  --core-text-sm:   0.875rem;
  --core-text-base: 1rem;
  --core-text-lg:   1.125rem;
  --core-text-xl:   1.25rem;
  --core-text-2xl:  1.5rem;
  --core-text-3xl:  1.875rem;
  --core-text-4xl:  2.25rem;
  --core-text-5xl:  3rem;
  --core-text-6xl:  3.75rem;

  --core-weight-normal:    400;
  --core-weight-medium:    500;
  --core-weight-semibold:  600;
  --core-weight-bold:      700;
  --core-weight-extrabold: 800;

  --core-leading-tight:   1.2;
  --core-leading-snug:    1.35;
  --core-leading-normal:  1.5;
  --core-leading-relaxed: 1.65;
  --core-leading-loose:   1.8;

  --core-ease-default: 0.3s ease;
  --core-ease-smooth:  0.3s cubic-bezier(0.4, 0, 0.2, 1);
  --core-ease-spring:  0.4s cubic-bezier(0.34, 1.56, 0.64, 1);
  --core-ease-fast:    0.15s ease;

  /* ── LAYER 2: SEMANTIC ALIASES ── */
  --color-primary:       var(--core-green-500);
  --color-primary-hover: var(--core-green-600);
  --color-primary-light: var(--core-green-50);
  --color-primary-muted: rgba(45, 134, 89, 0.08);

  --color-accent:       var(--core-orange-500);
  --color-accent-hover: var(--core-orange-600);
  --color-accent-light: var(--core-orange-50);

  --color-bg:         var(--core-neutral-0);
  --color-bg-soft:    var(--core-neutral-50);
  --color-bg-subtle:  var(--core-neutral-100);
  --color-bg-overlay: rgba(15, 23, 42, 0.6);

  --color-text:        var(--core-neutral-900);
  --color-text-muted:  var(--core-neutral-500);
  --color-text-subtle: var(--core-neutral-400);
  --color-text-inverse: var(--core-neutral-0);

  --color-border:        var(--core-neutral-200);
  --color-border-strong: var(--core-neutral-300);

  --color-surface-dark:      var(--core-neutral-900);
  --color-surface-dark-mid:  var(--core-neutral-800);
  --color-surface-dark-border: rgba(255,255,255,0.10);

  --gradient-primary:   linear-gradient(135deg, var(--core-green-500), var(--core-green-700));
  --gradient-hero:      linear-gradient(135deg, var(--core-green-500) 0%, var(--core-green-900) 100%);
  --gradient-cta:       linear-gradient(135deg, var(--core-green-600), var(--core-green-900));
  --gradient-accent:    linear-gradient(135deg, var(--core-orange-500), var(--core-orange-700));
  --gradient-whatsapp:  linear-gradient(135deg, var(--core-whatsapp-light), var(--core-whatsapp-dark));

  --color-success: var(--core-success);
  --color-warning: var(--core-warning);
  --color-error:   var(--core-error);

  --shadow-xs:      0 1px 3px rgba(15,23,42,0.08);
  --shadow-sm:      0 4px 12px rgba(15,23,42,0.08);
  --shadow-md:      0 8px 24px rgba(15,23,42,0.10);
  --shadow-lg:      0 16px 40px rgba(15,23,42,0.12);
  --shadow-xl:      0 24px 60px rgba(15,23,42,0.15);
  --shadow-primary: 0 12px 32px rgba(45,134,89,0.25);
  --shadow-accent:  0 12px 32px rgba(249,115,22,0.25);

  --space-section:    clamp(var(--core-space-16), 8vw, var(--core-space-24));
  --space-section-sm: clamp(var(--core-space-12), 6vw, var(--core-space-20));
  --space-card:       var(--core-space-8);
  --space-card-sm:    var(--core-space-6);

  --container-max:    1180px;
  --container-narrow: 820px;
  --header-height:    76px;

  --radius-xs:   var(--core-radius-xs);
  --radius-sm:   var(--core-radius-sm);
  --radius-md:   var(--core-radius-md);
  --radius-lg:   var(--core-radius-lg);
  --radius-xl:   var(--core-radius-xl);
  --radius-full: var(--core-radius-full);
  --radius-card: var(--core-radius-xl);
  --radius-btn:  var(--core-radius-md);
  --radius-input: var(--core-radius-md);
  --radius-badge: var(--core-radius-full);
  --radius-icon:  var(--core-radius-lg);

  --font-heading: 'Poppins', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  --font-body:    'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;

  --text-xs:   var(--core-text-xs);
  --text-sm:   var(--core-text-sm);
  --text-base: var(--core-text-base);
  --text-lg:   var(--core-text-lg);
  --text-xl:   var(--core-text-xl);
  --text-2xl:  var(--core-text-2xl);
  --text-3xl:  var(--core-text-3xl);
  --text-4xl:  var(--core-text-4xl);
  --text-5xl:  var(--core-text-5xl);

  --weight-normal:    var(--core-weight-normal);
  --weight-medium:    var(--core-weight-medium);
  --weight-semibold:  var(--core-weight-semibold);
  --weight-bold:      var(--core-weight-bold);
  --weight-extrabold: var(--core-weight-extrabold);

  /* ── LAYER 3: COMPONENT TOKENS ── */
  --btn-height:        50px;
  --btn-height-sm:     40px;
  --btn-height-lg:     58px;
  --btn-padding:       0 var(--core-space-6);
  --btn-padding-sm:    0 var(--core-space-4);
  --btn-padding-lg:    0 var(--core-space-8);
  --btn-radius:        var(--radius-btn);
  --btn-font-weight:   var(--weight-bold);
  --btn-transition:    all var(--core-ease-smooth);
  --btn-hover-lift:    translateY(-3px);

  --card-bg:         var(--color-bg);
  --card-border:     1px solid var(--color-border);
  --card-radius:     var(--radius-card);
  --card-shadow:     var(--shadow-md);
  --card-padding:    var(--space-card);
  --card-padding-sm: var(--space-card-sm);

  --icon-box-size:   56px;
  --icon-box-radius: var(--radius-icon);
  --icon-box-bg:     var(--gradient-primary);

  --header-bg:          rgba(255,255,255,0.88);
  --header-bg-scrolled: rgba(255,255,255,0.96);
  --header-blur:        blur(16px);
  --header-border:      1px solid rgba(203,213,225,0.7);
  --header-shadow:      0 8px 24px rgba(15,23,42,0.08);

  --footer-bg:          var(--color-surface-dark);
  --footer-mid-bg:      var(--color-surface-dark-mid);
  --footer-border:      var(--color-surface-dark-border);
  --footer-text:        rgba(255,255,255,0.75);
  --footer-text-bold:   rgba(255,255,255,0.92);

  --wa-size:        60px;
  --wa-size-sm:     54px;
  --wa-bg:          var(--gradient-whatsapp);
  --wa-shadow:      0 8px 24px rgba(37,211,102,0.35);
  --wa-shadow-hover: 0 14px 36px rgba(37,211,102,0.50);
  --wa-icon-size:   28px;

  --review-bg:        rgba(255,255,255,0.07);
  --review-bg-hover:  rgba(255,255,255,0.12);
  --review-border:    rgba(255,255,255,0.12);
  --review-star:      var(--core-star);

  /* ── ALIASES RETROATIVOS (compatibilidade) ── */
  --primary:    var(--color-primary);
  --primary-dark: var(--color-primary-hover);
  --green:      var(--core-green-400);
  --green-dark: var(--core-green-900);
  --accent:     var(--color-accent);
  --text:       var(--color-text);
  --muted:      var(--color-text-muted);
  --border:     var(--color-border);
  --bg:         var(--color-bg);
  --bg-soft:    var(--color-bg-soft);
  --shadow:     var(--shadow-md);
  --radius:     var(--radius-card);
  --container:  var(--container-max);
}
* { box-sizing: border-box; }
html { scroll-behavior: smooth; overflow-x: hidden; }
body { overflow-x: hidden; }
main { overflow-x: clip; }
body {
  margin: 0;
  font-family: var(--font-body);
  color: var(--color-text);
  background: var(--color-bg);
  line-height: var(--core-leading-relaxed);
  font-size: var(--text-base);
  font-weight: var(--weight-normal);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}
a { color: inherit; text-decoration: none; transition: color .3s ease; }
img { max-width: 100%; display: block; height: auto; }
svg { width: 24px; height: 24px; }
.icon-box svg, .feature-icon svg { width: 28px; height: 28px; }
h1,h2,h3,h4 { font-family: var(--font-heading); line-height: var(--core-leading-tight); margin: 0 0 var(--core-space-5); font-weight: var(--weight-bold); letter-spacing: -0.03em; color: var(--color-text); }
h1 { font-size: clamp(var(--text-4xl), 5vw, var(--text-6xl)); }
h2 { font-size: clamp(var(--text-3xl), 4vw, var(--text-5xl)); }
h3 { font-size: clamp(var(--text-xl), 3vw, var(--text-3xl)); }
h4 { font-size: var(--text-xl); }
p { margin: 0 0 var(--core-space-5); color: var(--color-text-muted); line-height: var(--core-leading-relaxed); }
ul { margin: 0; padding: 0; list-style: none; }
.container { width: min(calc(100% - var(--core-space-8)), var(--container-max)); margin: 0 auto; }
.center { text-align: center; }
.narrow { max-width: 820px; }
.site-header {
  position: sticky; top: 0; z-index: 100;
  background: var(--header-bg); backdrop-filter: var(--header-blur); -webkit-backdrop-filter: var(--header-blur);
  border-bottom: var(--header-border);
  transition: box-shadow var(--core-ease-default), background var(--core-ease-default);
}
.site-header.is-scrolled { box-shadow: var(--header-shadow); background: var(--header-bg-scrolled); }
.header-inner { display: flex; align-items: center; justify-content: space-between; gap: var(--core-space-5); min-height: var(--header-height); }
.brand img { width: auto; height: 44px; }
.main-nav { display: flex; align-items: center; gap: var(--core-space-6); font-weight: var(--weight-semibold); }
.main-nav a:not(.btn) { position: relative; color: var(--color-text); }
.main-nav a:not(.btn)::after { content: ''; position: absolute; left: 0; bottom: -6px; width: 0; height: 2px; background: var(--color-primary); transition: width var(--core-ease-default); border-radius: 2px; }
.main-nav a:not(.btn):hover { color: var(--color-primary); }
.main-nav a:not(.btn):hover::after { width: 100%; }
.menu-toggle { display: none; width: 44px; height: 44px; border: 0; background: var(--color-bg-soft); border-radius: var(--radius-sm); padding: 0; cursor: pointer; flex-direction: column; align-items: center; justify-content: center; gap: 0; overflow: hidden; }
.menu-toggle span { display: block; width: 16px; height: 2px; background: var(--color-text); margin: 3px 0; transition: transform .3s ease, opacity .25s ease; border-radius: 2px; }
.menu-toggle.is-open span:nth-child(1) { transform: translateY(8px) rotate(45deg); }
.menu-toggle.is-open span:nth-child(2) { opacity: 0; transform: scaleX(0); }
.menu-toggle.is-open span:nth-child(3) { transform: translateY(-8px) rotate(-45deg); }
.hero { position: relative; color: var(--color-text-inverse); overflow: hidden; background: var(--gradient-hero); }
.hero-home { min-height: 86vh; display: grid; align-items: center; }
.hero-mini { padding: 110px 0 88px; }
.hero-media { position: absolute; inset: 0; opacity: .20; }
.hero-media img { width: 100%; height: 100%; object-fit: cover; }
.hero-content { position: relative; z-index: 1; padding: var(--core-space-8) 0; }
.hero-content h1 { font-size: clamp(var(--text-4xl), 6vw, var(--text-6xl)); margin-bottom: var(--core-space-6); color: var(--color-text-inverse); line-height: 1.1; }
.hero-content .lead { font-size: var(--text-lg); color: rgba(255,255,255,.92); margin-bottom: var(--core-space-4); line-height: var(--core-leading-relaxed); }
.hero-content p { max-width: 680px; color: rgba(255,255,255,.82); margin-bottom: var(--core-space-6); line-height: var(--core-leading-relaxed); }
.eyebrow, .section-tag {
  display: inline-flex; align-items: center; gap: var(--core-space-2);
  padding: var(--core-space-2) var(--core-space-4); border-radius: var(--radius-badge);
  font-size: var(--text-xs); font-weight: var(--weight-extrabold); letter-spacing: .06em; text-transform: uppercase;
  margin-bottom: var(--core-space-4);
}
.eyebrow { background: rgba(255,255,255,.14); color: var(--color-text-inverse); }
.section-tag { background: var(--color-primary-muted); color: var(--color-primary); }
.section-tag-light { background: rgba(255,255,255,.14); color: var(--color-text-inverse); }
.hero-actions, .card-actions, .section-cta, .footer-socials, .contact-points, .mini-meta { display: flex; flex-wrap: wrap; gap: var(--core-space-4); }
.chips { display: flex; flex-wrap: wrap; gap: var(--core-space-3); margin: var(--core-space-8) 0 var(--core-space-10); }
.chips span { padding: var(--core-space-2) var(--core-space-4); border-radius: var(--radius-full); background: rgba(255,255,255,.12); border: 1px solid rgba(255,255,255,.22); font-weight: var(--weight-semibold); font-size: var(--text-sm); }
.btn {
  display: inline-flex; align-items: center; justify-content: center; gap: var(--core-space-2);
  min-height: var(--btn-height); padding: var(--btn-padding); border-radius: var(--btn-radius); border: 1.5px solid transparent;
  font-family: var(--font-body); font-weight: var(--btn-font-weight); font-size: var(--text-base);
  text-decoration: none; cursor: pointer; transition: var(--btn-transition); white-space: nowrap;
}
.btn:hover { transform: var(--btn-hover-lift); }
.btn-primary { background: var(--gradient-primary); color: var(--color-text-inverse); }
.btn-primary:hover { box-shadow: var(--shadow-primary); }
.btn-accent { background: var(--gradient-accent); color: var(--color-text-inverse); }
.btn-accent:hover { box-shadow: var(--shadow-accent); }
.btn-light { background: var(--color-bg); color: var(--color-primary); }
.btn-light:hover { box-shadow: var(--shadow-md); }
.btn-outline, .btn-outline-light { border-color: currentColor; background: transparent; }
.btn-outline { color: var(--color-primary); }
.btn-outline:hover { background: var(--color-primary-muted); }
.btn-outline-light { color: var(--color-text-inverse); }
.btn-outline-light:hover { background: rgba(255,255,255,.12); }
.btn-sm { min-height: var(--btn-height-sm); padding: var(--btn-padding-sm); font-size: var(--text-sm); }
.btn-lg { min-height: var(--btn-height-lg); padding: var(--btn-padding-lg); font-size: var(--text-lg); }
.btn-block { width: 100%; }
.section { padding: var(--space-section) 0; margin: 0; }
.section + .section { margin-top: 0; }
.alt-bg { background: var(--color-bg-soft); }
.section-head { margin-bottom: var(--core-space-12); text-align: center; }
.section-head h2, .center h2 { font-size: clamp(var(--text-3xl), 4vw, var(--text-5xl)); }
.section-cta { justify-content: center; margin-top: var(--core-space-10); }
.grid { display: grid; gap: var(--core-space-8); }
.grid-2 { grid-template-columns: repeat(2, minmax(0, 1fr)); }
.grid-3 { grid-template-columns: repeat(3, minmax(0, 1fr)); }
.grid-4 { grid-template-columns: repeat(4, minmax(0, 1fr)); }
.two-col { display: grid; grid-template-columns: 1.1fr .9fr; gap: var(--core-space-10); }
.align-center { align-items: center; }
.card, .panel, .media-card, .step-card, .stat-box, .sidebar-panel, .list-card, .faq-item, .feature {
  background: var(--card-bg); border: var(--card-border); border-radius: var(--card-radius); box-shadow: var(--card-shadow);
  transition: transform var(--core-ease-smooth), box-shadow var(--core-ease-smooth);
}
.card:hover, .feature:hover { transform: translateY(-4px); box-shadow: var(--shadow-lg); }
.card, .panel, .step-card, .stat-box, .sidebar-panel, .faq-item { padding: var(--card-padding); margin: 0; }
.media-card { overflow: hidden; }
.media-card img, .gallery-card img, .card-image img { width: 100%; height: 100%; object-fit: cover; }
.icon-box, .feature-icon {
  display: inline-flex; align-items: center; justify-content: center;
  width: var(--icon-box-size); height: var(--icon-box-size);
  border-radius: var(--icon-box-radius); color: var(--color-text-inverse); margin-bottom: var(--core-space-4);
  background: var(--icon-box-bg); flex-shrink: 0;
  transition: transform var(--core-ease-smooth), box-shadow var(--core-ease-smooth);
}
.icon-box:hover, .feature-icon:hover {
  transform: translateY(-4px) scale(1.05); box-shadow: var(--shadow-primary);
}
.icon-box svg, .feature-icon svg { width: 26px; height: 26px; }
.feature { display: flex; gap: var(--core-space-5); padding: var(--core-space-6); }
.stack-list { display: flex; flex-direction: column; gap: var(--core-space-4); }
.compact-grid .list-card, .stack-list .list-card { padding: 18px 18px; }
.list-card {
  display: flex; align-items: flex-start; gap: 12px; padding: 20px; color: var(--text);
}
.list-card svg, .check-list li svg, .back-link svg, .mini-meta svg { flex-shrink: 0; color: var(--primary); }
.check-list { display: grid; gap: 14px; }
.check-list li { display: flex; gap: 12px; align-items: flex-start; }
.topic-group { margin-top: 24px; padding-top: 24px; border-top: 1px solid var(--border); }
.topic-group strong { display: block; margin-bottom: 10px; }
.topic-group li { position: relative; padding-left: 16px; color: var(--muted); margin-bottom: 8px; }
.topic-group li::before { content: '•'; position: absolute; left: 0; color: var(--primary); }
.step-number {
  display: inline-flex; width: 52px; height: 52px; align-items: center; justify-content: center;
  border-radius: 999px; font-weight: 800; color: #fff; background: linear-gradient(135deg, var(--primary), var(--green)); margin-bottom: 18px;
}
.cta-band {
  padding: var(--space-section) 0; color: var(--color-text-inverse); background: var(--gradient-cta);
  position: relative; overflow: hidden;
}
.cta-band h2 { color: var(--color-text-inverse); }
.cta-band p { color: rgba(255,255,255,.85); max-width: 680px; margin-left: auto; margin-right: auto; }
.contact-points { justify-content: center; margin: var(--core-space-6) 0 var(--core-space-8); }
.contact-points span {
  padding: var(--core-space-3) var(--core-space-4); border-radius: var(--radius-full);
  background: rgba(255,255,255,.12); border: 1px solid rgba(255,255,255,.20);
  font-weight: var(--weight-semibold); font-size: var(--text-sm);
}
.filter-section { padding-top: 42px; padding-bottom: 42px; }
.filter-bar { display: grid; grid-template-columns: 2fr 1fr; gap: 16px; }
.filter-bar input, .filter-bar select {
  width: 100%; min-height: 56px; border: 1px solid var(--color-border); border-radius: var(--radius-input); padding: 0 var(--core-space-5); font: inherit; color: var(--color-text); background: var(--color-bg);
  transition: border-color var(--core-ease-default), box-shadow var(--core-ease-default);
}
.filter-bar input:focus, .filter-bar select:focus {
  outline: none; border-color: var(--color-primary); box-shadow: 0 0 0 3px var(--color-primary-muted);
}
.results-note { margin-top: 18px; color: var(--muted); font-weight: 600; }
.course-card { display: flex; flex-direction: column; }
.card-image { aspect-ratio: 16 / 10; border-radius: var(--radius-lg); overflow: hidden; margin-bottom: var(--core-space-5); }
.course-meta {
  display: inline-flex; align-self: flex-start; padding: 8px 12px; border-radius: 999px; margin-bottom: 12px;
  background: rgba(45,134,89,.08); color: var(--primary); font-size: .85rem; font-weight: 800; text-transform: uppercase;
}
.mini-meta { margin: 18px 0 22px; font-size: .92rem; color: var(--muted); }
.mini-meta span { display: inline-flex; align-items: center; gap: 8px; }
.empty-state { text-align: center; padding: 24px 0 0; }
.faq-list { display: grid; gap: 18px; }
.faq-item { border-left: 4px solid var(--primary); }
.subnav-band { background: var(--bg-soft); border-bottom: 1px solid var(--border); }
.back-link { display: inline-flex; align-items: center; gap: 10px; padding: 18px 0; font-weight: 700; color: var(--primary); }
.detail-layout { display: grid; grid-template-columns: minmax(0, 1.6fr) minmax(300px, .8fr); gap: 28px; align-items: start; }
.stats-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 18px; margin-bottom: 28px; }
.stat-box {
  padding: var(--core-space-5) !important;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: var(--core-space-2);
}
.stat-box span {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 44px; height: 44px;
  border-radius: var(--radius-sm);
  background: var(--color-primary-muted);
  color: var(--color-primary);
  flex-shrink: 0;
}
.stat-box span svg { width: 22px; height: 22px; }
.stat-box strong { font-size: var(--text-xs); font-weight: var(--weight-extrabold); text-transform: uppercase; letter-spacing: .04em; color: var(--color-text-muted); }
.stat-box p { margin: 0; font-weight: var(--weight-bold); color: var(--color-text); font-size: var(--text-base); }
.detail-section { margin-top: 36px; }
.detail-section > p { color: var(--muted); }
.sidebar-panel { position: sticky; top: 100px; }
.sidebar-panel dl { display: grid; gap: 18px; margin: 0 0 24px; }
.sidebar-panel dt { font-size: .8rem; font-weight: 800; text-transform: uppercase; color: var(--muted); margin-bottom: 5px; }
.sidebar-panel dd { margin: 0; font-weight: 700; }
.sidebar-panel .btn + .btn { margin-top: var(--core-space-3); }
.gallery-card { border-radius: var(--radius); overflow: hidden; min-height: 250px; box-shadow: var(--shadow); }
.sobre-stats { grid-template-columns: 1fr 1fr; gap: var(--core-space-5); }
.site-footer { background: var(--footer-bg); color: var(--footer-text); margin-top: 0; }
.footer-map-reviews { background: var(--footer-mid-bg); border-top: 1px solid var(--footer-border); border-bottom: 1px solid var(--footer-border); }
/* Seção de avaliações inline */
.footer-reviews-section { padding: var(--core-space-12) 0 var(--core-space-10); }
.footer-reviews-section h4 { color: var(--color-text-inverse); margin-bottom: var(--core-space-5); font-size: var(--text-lg); font-weight: var(--weight-semibold); }
.reviews-inline { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--core-space-5); margin-bottom: var(--core-space-6); }
.reviews-actions { display: flex; align-items: center; gap: var(--core-space-4); flex-wrap: wrap; }
/* Mapa 100% largura */
.footer-map-full { width: 100%; line-height: 0; }
.footer-map-full iframe { width: 100%; height: 360px; display: block; border: 0; }
/* Footer socials (links de redes sociais) */
.footer-socials { display: flex; flex-wrap: wrap; gap: var(--core-space-3); margin-top: var(--core-space-5); }
.footer-socials a { display: inline-flex; align-items: center; padding: var(--core-space-2) var(--core-space-4); border: 1px solid rgba(255,255,255,.18); border-radius: var(--radius-sm); color: var(--footer-text); font-size: var(--text-sm); font-weight: var(--weight-medium); transition: all var(--core-ease-default); }
.footer-socials a:hover { background: rgba(255,255,255,.10); color: var(--color-text-inverse); border-color: rgba(255,255,255,.35); }
.google-rating-badge { display: flex; align-items: center; justify-content: space-between; flex-wrap: wrap; gap: var(--core-space-4); background: rgba(255,255,255,.06); border: 1px solid rgba(255,255,255,.12); border-radius: var(--radius-md); padding: var(--core-space-4) var(--core-space-5); margin-bottom: var(--core-space-5); }
.rating-main { display: flex; align-items: center; gap: var(--core-space-4); }
.rating-number { font-size: var(--text-5xl); font-weight: var(--weight-extrabold); color: var(--color-text-inverse); line-height: 1; }
.rating-stars-row { color: var(--review-star); font-size: var(--text-lg); letter-spacing: 3px; margin-bottom: var(--core-space-1); }
.rating-label { color: rgba(255,255,255,.60); font-size: var(--text-xs); }
.reviews-list { display: flex; flex-direction: column; gap: var(--core-space-4); margin-bottom: var(--core-space-5); }
.review-card { background: var(--review-bg); border: 1px solid var(--review-border); border-radius: var(--radius-md); padding: var(--core-space-5); transition: all var(--core-ease-default); }
.review-card:hover { background: var(--review-bg-hover); border-color: rgba(255,255,255,.22); }
.review-header { display: flex; align-items: center; gap: var(--core-space-3); margin-bottom: var(--core-space-3); }
.review-stars { color: var(--review-star); font-size: var(--text-sm); font-weight: var(--weight-extrabold); letter-spacing: 2px; }
.review-author { color: rgba(255,255,255,.92); font-weight: var(--weight-semibold); font-size: var(--text-sm); }
.review-text { color: rgba(255,255,255,.72); margin: 0; font-size: var(--text-sm); line-height: var(--core-leading-relaxed); }
.site-footer p, .site-footer li, .site-footer a { color: var(--footer-text); }
.site-footer a:hover { color: var(--color-text-inverse); }
.footer-grid { display: grid; grid-template-columns: 1.4fr 1fr 1fr 1fr; gap: var(--core-space-10); padding: var(--core-space-12) 0 var(--core-space-10); }
.footer-grid h3 { color: var(--color-text-inverse); margin-bottom: var(--core-space-4); font-size: var(--text-xl); }
.footer-logo { height: 48px; width: auto; display: block; margin-bottom: var(--core-space-5); filter: brightness(0) invert(1); }
.footer-grid h4 { color: var(--footer-text-bold); margin-bottom: var(--core-space-4); font-size: var(--text-base); font-weight: var(--weight-semibold); }
.footer-grid li { margin-bottom: var(--core-space-3); }
.footer-bottom { border-top: 1px solid var(--footer-border); }
.footer-bottom-inner { display: flex; align-items: center; justify-content: space-between; flex-wrap: wrap; gap: var(--core-space-4); padding: var(--core-space-5) 0; }
.footer-bottom-inner p, .footer-bottom-inner a { color: rgba(255,255,255,.45); font-size: var(--text-sm); }
.footer-bottom-inner a:hover { color: rgba(255,255,255,.80); }
.footer-bottom-inner div { display: flex; gap: var(--core-space-5); }
.floating-whatsapp {
  position: fixed;
  right: 28px;
  bottom: 28px;
  z-index: 9999;
  display: inline-flex; align-items: center; justify-content: center;
  width: var(--wa-size); height: var(--wa-size);
  border-radius: var(--radius-full); background: var(--wa-bg);
  color: var(--color-text-inverse); text-decoration: none;
  box-shadow: var(--wa-shadow);
  transition: transform var(--core-ease-spring), box-shadow var(--core-ease-default);
  will-change: transform;
  transform: translateZ(0);
  -webkit-transform: translateZ(0);
}
.floating-whatsapp:hover {
  transform: translateZ(0) scale(1.12) translateY(-2px);
  box-shadow: var(--wa-shadow-hover);
}
.floating-whatsapp svg { width: var(--wa-icon-size); height: var(--wa-icon-size); fill: currentColor; }
.reveal {
  opacity: 0; transform: translateY(34px);
  transition: opacity .7s ease, transform .7s ease;
  animation: reveal-fallback 0.7s ease 1.5s forwards;
}
.reveal-left { transform: translateX(-24px); }
.reveal-right { transform: translateX(24px); }
.reveal.is-visible {
  opacity: 1; transform: translate(0, 0);
  animation: none;
}
@keyframes reveal-fallback {
  to { opacity: 1; transform: translate(0, 0); }
}
@media (max-width: 1100px) {
  .grid-4 { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .grid-3, .grid-2, .two-col, .detail-layout, .footer-grid { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 860px) {
  .reviews-inline { grid-template-columns: 1fr; }
  .footer-map-full iframe { height: 280px; }
  .menu-toggle { display: inline-flex; align-items: center; justify-content: center; }
  .main-nav {
    position: absolute; left: var(--core-space-4); right: var(--core-space-4);
    top: calc(100% + var(--core-space-3)); display: none; flex-direction: column; align-items: stretch;
    padding: var(--core-space-5); background: rgba(255,255,255,.98);
    border: var(--card-border); border-radius: var(--radius-xl); box-shadow: var(--shadow-xl);
  }
  .main-nav.is-open { display: flex; }
  .hero-home { min-height: auto; padding: var(--core-space-32) 0 var(--core-space-24); }
  .filter-bar, .stats-grid, .grid-4, .grid-3, .grid-2, .two-col, .detail-layout, .footer-grid, .footer-bottom-inner { grid-template-columns: 1fr; display: grid; }
  .sidebar-panel { position: static; }
  .detail-layout { overflow: visible; }
  .reveal-left, .reveal-right { transform: none; opacity: 0; }
}
@media (max-width: 640px) {
  .section, .cta-band { padding: var(--core-space-20) 0; }
  .header-inner { min-height: 68px; }
  .hero-content h1 { font-size: var(--text-4xl); }
  .hero-mini { padding: 72px 0 56px; }
  .hero-mini .hero-content h1 { font-size: var(--text-3xl); }
  .card, .panel, .step-card, .stat-box, .sidebar-panel, .faq-item { padding: var(--card-padding-sm); }
  .contact-points span { font-size: var(--text-xs); }
  .floating-whatsapp {
    right: 16px;
    bottom: 20px;
    bottom: calc(20px + env(safe-area-inset-bottom, 0px));
    left: auto;
    width: var(--wa-size-sm);
    height: var(--wa-size-sm);
  }
  .stats-grid { grid-template-columns: 1fr !important; }
  .footer-bottom-inner { justify-content: center; text-align: center; }
  .two-col { gap: var(--core-space-8); }
}
