/* ==========================================================================
   SOUZA NUNES ADVOGADOS ASSOCIADOS — PREMIUM DESIGN SYSTEM v3
   Obsidian • Champagne Gold • Cinematic Motion
   ========================================================================== */

/* --------------------------------------------------------------------------
   1. DESIGN TOKENS
   -------------------------------------------------------------------------- */
:root {
  /* === PALETTE: Ebony + Antique Gold === */
  --color-ebony:           #14110e;
  --color-ebony-light:    #1d1916;
  --color-ebony-mid:      #28221d;
  --color-gold:           #c4a159;
  --color-gold-light:     #dbc07c;
  --color-gold-dark:      #a6823a;
  --color-gold-pale:      #f7f0e0;
  --color-ivory:          #fcf9f5;
  --color-cream:          #f6f1e8;
  --color-paper:          #fefdfb;
  --color-taupe:          #8a8075;
  --color-taupe-dark:     #5b544a;
  --color-success:        #1da851;

  /* Legacy aliases */
  --color-obsidian:       var(--color-ebony);
  --color-obsidian-light: var(--color-ebony-light);
  --color-obsidian-mid:   var(--color-ebony-mid);
  --color-champagne:      var(--color-gold);
  --color-champagne-light:var(--color-gold-light);
  --color-champagne-dark: var(--color-gold-dark);
  --color-champagne-pale: var(--color-gold-pale);
  --color-white:          #ffffff;

  /* === TYPOGRAPHY === */
  --font-display: 'Cormorant Garamond', 'EB Garamond', 'Georgia', serif;
  --font-body:    'DM Sans', 'Inter', -apple-system, sans-serif;

  /* === SPACING === */
  --space-xs:  0.5rem;
  --space-sm:  1rem;
  --space-md:  1.5rem;
  --space-lg:  2.5rem;
  --space-xl:  4rem;
  --space-2xl: 6rem;
  --space-3xl: 8rem;

  /* === RADIUS & SHADOWS === */
  --radius-sm:  4px;
  --radius-md:  8px;
  --radius-lg:  16px;
  --shadow-sm:  0 2px 12px rgba(20,17,14,.06);
  --shadow-md:  0 8px 32px rgba(20,17,14,.10);
  --shadow-lg:  0 16px 56px rgba(20,17,14,.15);
  --shadow-gold:0 4px 32px rgba(196,161,89,.28);

  /* === EASING === */
  --ease-out-expo: cubic-bezier(0.16, 1, 0.3, 1);
  --ease-out-back: cubic-bezier(0.34, 1.56, 0.64, 1);
  --ease-in-out:   cubic-bezier(0.65, 0, 0.35, 1);
}
/* --------------------------------------------------------------------------
   2. RESET & BASE
   -------------------------------------------------------------------------- */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}
body{
  font-family:var(--font-body);
  font-weight:400;font-size:1rem;line-height:1.75;
  color:var(--color-taupe-dark);
  background-color:var(--color-ivory);
  overflow-x:hidden;
}

h1,h2,h3,h4,h5,h6{font-family:var(--font-display);font-weight:500;line-height:1.15;color:var(--color-obsidian)}
h1{font-size:clamp(2rem,5vw,3.5rem)}
h2{font-size:clamp(1.6rem,4vw,2.6rem)}
h3{font-size:clamp(1.3rem,3vw,1.8rem)}
h4{font-size:1.15rem}
p{margin-bottom:1rem}
a{color:inherit;text-decoration:none;transition:color .3s var(--ease-out-expo)}
img{max-width:100%;height:auto;display:block}
ul,ol{list-style:none}
button{cursor:pointer;font-family:var(--font-body);border:none;background:none}
::selection{background:var(--color-champagne);color:var(--color-white)}

/* Subtle grain on body */
body::after{
  content:'';position:fixed;inset:0;z-index:99999;pointer-events:none;opacity:.025;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.75' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

/* --------------------------------------------------------------------------
   3. ACCESSIBILITY — Skip link + focus
   -------------------------------------------------------------------------- */
.skip-link{
  position:absolute;top:-100%;left:1rem;
  background:var(--color-gold);color:var(--color-ebony);
  font-family:var(--font-body);font-weight:600;font-size:.9rem;
  padding:.6rem 1.2rem;border-radius:var(--radius-sm);
  z-index:99999;text-decoration:none;
  transition:top .3s var(--ease-out-expo);
}
.skip-link:focus{top:1rem;outline:3px solid var(--color-ebony);outline-offset:2px}

/* Global focus indicator */
:focus-visible{
  outline:2px solid var(--color-gold);
  outline-offset:3px;
  border-radius:2px;
}
/* Stronger focus for form elements */
input:focus-visible,textarea:focus-visible,button:focus-visible{
  outline:3px solid var(--color-gold);
  outline-offset:2px;
}
/* Override for elements with custom focus styles */
.modal-search-input:focus-visible,
.form-group input:focus-visible,
.form-group textarea:focus-visible{outline:none}

/* --------------------------------------------------------------------------
   4. UTILITIES
   -------------------------------------------------------------------------- */
.container{width:100%;max-width:1280px;margin:0 auto;padding:0 1.5rem}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}

/* Gold decorative line */
.gold-line{width:70px;height:2px;background:var(--color-champagne);margin:0 auto var(--space-lg)}
.gold-line.left{margin-left:0}

/* --------------------------------------------------------------------------
   4. HEADER — Fixed with glass effect
   -------------------------------------------------------------------------- */
.site-header{
  position:fixed;top:0;left:0;width:100%;z-index:1000;
  background:rgba(22,20,18,.88);
  backdrop-filter:blur(24px) saturate(180%);
  -webkit-backdrop-filter:blur(24px) saturate(180%);
  border-bottom:1px solid rgba(196,161,89,.18);
  transition:all .5s var(--ease-out-expo);
}
.site-header.scrolled{background:rgba(22,20,18,.96);box-shadow:var(--shadow-lg)}

.header-inner{
  display:flex;align-items:center;justify-content:space-between;
  padding:.65rem 1.5rem;max-width:1400px;margin:0 auto;
}
.header-logo img{height:2.5rem;width:auto;transition:transform .3s var(--ease-out-expo)}
.header-logo:hover img{transform:scale(1.05)}

.nav-list{display:none}
.header-whatsapp{display:none}

.menu-toggle{
  display:flex;align-items:center;justify-content:center;
  font-size:1.3rem;color:var(--color-champagne);cursor:pointer;
  padding:.4rem;transition:all .3s;
}
.menu-toggle:hover{color:var(--color-champagne-light);transform:scale(1.1)}

/* --------------------------------------------------------------------------
   5. MOBILE NAV
   -------------------------------------------------------------------------- */
.mobile-nav{
  position:fixed;inset:0;z-index:9998;
  background:rgba(22,20,18,.97);
  backdrop-filter:blur(40px);
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2.5rem;
  opacity:0;visibility:hidden;
  transition:all .5s var(--ease-out-expo);
}
.mobile-nav.active{opacity:1;visibility:visible}
.mobile-nav a{
  font-family:var(--font-display);font-size:1.6rem;font-weight:500;
  color:var(--color-white);transition:all .3s;
}
.mobile-nav a:hover{color:var(--color-champagne);transform:translateX(6px)}
.mobile-nav-close{
  position:absolute;top:1.5rem;right:1.5rem;
  font-size:2rem;color:var(--color-white);cursor:pointer;
  transition:all .3s;
}
.mobile-nav-close:hover{color:var(--color-champagne);transform:rotate(90deg)}

/* --------------------------------------------------------------------------
   6. HERO — Cinematic Parallax + Gold Particles
   -------------------------------------------------------------------------- */
.hero{
  position:relative;height:100vh;min-height:600px;
  display:flex;align-items:center;overflow:hidden;
  background-color:var(--color-obsidian);
}

/* Background image with parallax (moved by JS)
   Image resized per screen width to save bandwidth:
   Mobile: 640w | Tablet: 1280w | Desktop: 1920w
   Replace the Unsplash URL with your own image.
   Suggested searches: "law architecture", "courtroom dark", "marble columns"
   ================================================================== */
.hero-bg{
  position:absolute;inset:-10%;
  /* Mobile-first: 640px wide image (~100KB) */
  background-image:url('https://images.unsplash.com/photo-1589829545856-d10d557cf95f?w=640&q=80');
  background-size:cover;background-position:center;background-repeat:no-repeat;
  will-change:transform;
  /* Continuous micro-zoom */
  animation:heroCinematicZoom 60s ease-in-out infinite alternate;
}
@keyframes heroCinematicZoom{
  0%{transform:scale(1.02)}
  100%{transform:scale(1.18)}
}

/* Rich gradient overlay */
.hero-overlay{
  position:absolute;inset:0;z-index:1;
  background:
    radial-gradient(ellipse at 30% 50%,rgba(22,20,18,.4) 0%,rgba(22,20,18,.88) 70%),
    linear-gradient(180deg,rgba(22,20,18,.7) 0%,rgba(22,20,18,.55) 50%,rgba(22,20,18,.8) 100%);
}

/* Gold particle canvas */
#particlesCanvas{
  position:absolute;inset:0;z-index:2;pointer-events:none;
}

/* Text content */
.hero-content{
  position:relative;z-index:3;
  width:100%;padding:0 1.5rem;
  max-width:800px;
}

/* Staggered text reveal */
.hero-content .reveal-line{
  opacity:0;transform:translateY(40px);
  animation:textReveal .9s var(--ease-out-expo) forwards;
}
.hero-content .reveal-line:nth-child(1){animation-delay:.2s}
.hero-content .reveal-line:nth-child(2){animation-delay:.5s}
.hero-content .reveal-line:nth-child(3){animation-delay:.8s}
.hero-content .reveal-line:nth-child(4){animation-delay:1.1s}
.hero-content .reveal-line:nth-child(5){animation-delay:1.4s}
.hero-content .reveal-line:nth-child(6){animation-delay:1.7s}
@keyframes textReveal{
  to{opacity:1;transform:translateY(0)}
}

.hero-headline{
  font-family:var(--font-display);
  font-size:clamp(1.7rem,5.5vw,3.25rem);
  font-weight:600;line-height:1.2;
  color:var(--color-white);
  margin-bottom:var(--space-md);
  max-width:760px;
}
.hero-headline em{
  font-style:normal;color:var(--color-champagne-light);
}

/* Secondary decorative quote — kept for brand identity, de-emphasized */
.hero-quote-mini{
  font-family:var(--font-display);
  font-size:.85rem;font-style:italic;
  color:rgba(255,255,255,.45);
  line-height:1.6;max-width:520px;
  border-left:2px solid rgba(196,161,89,.35);
  padding-left:.9rem;margin:0;
}
.hero-quote-mini cite{
  display:block;font-family:var(--font-body);font-style:normal;
  font-size:.7rem;font-weight:500;
  color:rgba(255,255,255,.35);
  margin-top:.4rem;letter-spacing:.08em;text-transform:uppercase;
}

/* Primary CTA — gold, high contrast against hero overlay */
.hero-cta{
  display:inline-flex;align-items:center;gap:.6rem;
  background:var(--color-gold);color:var(--color-ebony);
  font-family:var(--font-body);font-weight:600;font-size:.85rem;
  letter-spacing:.06em;text-transform:uppercase;
  padding:.85rem 1.8rem;border-radius:var(--radius-sm);
  box-shadow:var(--shadow-md);
  transition:all .4s var(--ease-out-expo);
}
.hero-cta:hover{
  background:var(--color-gold-light);
  transform:translateY(-2px);
  box-shadow:var(--shadow-gold);
}
.hero-cta i{font-size:1.1rem}

/* Animated gold divider */
.hero-divider-wrap{overflow:hidden;margin:var(--space-md) 0}
.hero-divider{
  width:80px;height:2px;
  background:linear-gradient(90deg,var(--color-champagne),var(--color-champagne-light),var(--color-champagne));
  animation:dividerShimmer 3s ease-in-out infinite;
}
@keyframes dividerShimmer{
  0%,100%{width:80px;opacity:.7}
  50%{width:120px;opacity:1}
}

.hero-subtitle{
  font-family:var(--font-body);
  font-size:clamp(.8rem,1.6vw,.95rem);
  font-weight:500;letter-spacing:.08em;text-transform:uppercase;
  color:rgba(255,255,255,.75);
  line-height:1.7;max-width:600px;
}

/* Scroll indicator */
.hero-scroll-indicator{
  position:absolute;bottom:1.5rem;left:50%;transform:translateX(-50%);z-index:3;
  display:flex;flex-direction:column;align-items:center;gap:.4rem;
  color:rgba(255,255,255,.4);font-size:.68rem;
  letter-spacing:.12em;text-transform:uppercase;
}
.hero-scroll-indicator .scroll-line{
  width:1px;height:40px;
  background:linear-gradient(to bottom,var(--color-champagne),transparent);
  animation:scrollPulse 2s ease-in-out infinite;
}
@keyframes scrollPulse{
  0%,100%{opacity:.2;transform:scaleY(.7)}
  50%{opacity:1;transform:scaleY(1)}
}

/* Trust badges strip — below hero */
.hero-badges{
  background:var(--color-ebony-light);
  padding:var(--space-md) 0;
  position:relative;z-index:2;
}
.hero-badges-inner{
  max-width:1200px;margin:0 auto;padding:0 1.5rem;
  display:grid;grid-template-columns:1fr;gap:var(--space-sm);
}
.hero-badge{
  display:flex;align-items:center;gap:.8rem;
  font-family:var(--font-body);font-size:.85rem;font-weight:500;
  color:rgba(255,255,255,.85);
}
.hero-badge i{
  font-size:1.3rem;color:var(--color-champagne);
  width:1.5em;text-align:center;flex-shrink:0;
}

/* --------------------------------------------------------------------------
   7. SECTION HEADERS
   -------------------------------------------------------------------------- */
.section-kicker{
  font-family:var(--font-body);
  font-size:.72rem;font-weight:600;letter-spacing:.15em;
  text-transform:uppercase;color:var(--color-champagne);
  margin-bottom:var(--space-xs);
}
.section-title{
  font-family:var(--font-display);
  font-size:clamp(1.5rem,4vw,2.4rem);
  font-weight:500;color:var(--color-obsidian);
  margin-bottom:var(--space-sm);line-height:1.15;
}
.section-subtitle{
  font-family:var(--font-display);
  font-size:1.1rem;font-style:italic;color:var(--color-champagne-dark);
  margin-bottom:var(--space-lg);
}

/* --------------------------------------------------------------------------
   8. AREAS OF PRACTICE (replaces #office — now Section 2 after Hero)
   -------------------------------------------------------------------------- */

/* --------------------------------------------------------------------------
   9. TEAM SECTION (#team) — Carousel, random order
   -------------------------------------------------------------------------- */
#team{
  background:var(--color-cream);
  padding:var(--space-2xl) 0;
  position:relative;
}
#team::before{
  content:'';position:absolute;top:0;left:50%;transform:translateX(-50%);
  width:min(300px,60vw);height:1px;
  background:linear-gradient(90deg,transparent,var(--color-champagne),transparent);
}

.team-header{
  text-align:center;margin-bottom:var(--space-xl);padding:0 1.5rem;
}
.team-icon{font-size:2.2rem;color:var(--color-champagne);margin-bottom:var(--space-sm);display:block}

/* Carousel container */
.team-carousel-container{
  max-width:1000px;margin:0 auto;padding:0 3rem;
}

/* Individual slide */
.team-slide{padding:0 .5rem}
.team-slide-inner{
  display:flex;flex-direction:column; /* photo first, text below on mobile */
  border-radius:var(--radius-md);overflow:hidden;
  box-shadow:0 2px 16px rgba(20,17,14,.08);
  background:var(--color-white);
  transition:box-shadow .4s var(--ease-out-expo);
}
.team-slide-inner:hover{
  box-shadow:0 8px 40px rgba(20,17,14,.16);
}

/* Photo */
.team-photo{
  min-height:340px;
  background-size:cover;background-position:center 25%;
  position:relative;overflow:hidden;
}
.team-photo::before{
  content:'';position:absolute;bottom:0;left:0;right:0;height:3px;
  background:var(--color-gold);
  z-index:5;opacity:0;
  transform:scaleX(0);transform-origin:left;
  transition:all .6s var(--ease-out-expo);
}
.team-slide-inner:hover .team-photo::before{
  opacity:1;transform:scaleX(1);
}
.team-photo::after{
  content:'';position:absolute;inset:0;
  background:linear-gradient(to top,var(--color-ebony) 0%,rgba(20,17,14,.3) 40%,transparent 65%);
  z-index:1;
}

.team-photo-overlay{
  position:absolute;bottom:0;left:0;right:0;
  padding:var(--space-md);z-index:2;text-align:center;
}
.team-photo-overlay h3{
  font-family:var(--font-display);font-size:1.3rem;font-weight:600;
  color:var(--color-white);margin-bottom:.15rem;
}
.team-photo-overlay .oab{
  font-family:var(--font-body);font-size:.75rem;
  color:var(--color-gold);letter-spacing:.08em;font-weight:500;
}

/* Bio */
.team-bio{
  padding:var(--space-lg);
  background:linear-gradient(160deg,var(--color-paper) 0%,var(--color-ivory) 100%);
  position:relative;
}
.team-bio::before{
  content:'';position:absolute;top:15%;right:0;width:2px;height:70%;
  background:linear-gradient(to bottom,transparent,var(--color-gold),transparent);
  opacity:.35;
}
.team-bio p{font-size:.9rem;line-height:1.8;color:var(--color-taupe-dark);margin-bottom:0}

/* Responsive bios: short on mobile, full on desktop */
.bio-short{display:block}
.bio-full{display:none}

/* Slick overrides for team */
#team-carousel .slick-dots{bottom:-2rem}
#team-carousel .slick-dots li button:before{color:var(--color-gold)!important}
#team-carousel .slick-prev:before,
#team-carousel .slick-next:before{color:var(--color-gold)!important}

/* --------------------------------------------------------------------------
   10. UNIVERSAL SEARCH SECTION — "Seu caso tem solução"
   -------------------------------------------------------------------------- */
.solve-section{
  background:var(--color-cream);
  padding:var(--space-2xl) 0;
  position:relative;
}
.solve-section::before{
  content:'';position:absolute;top:0;left:0;right:0;height:1px;
  background:linear-gradient(90deg,transparent,var(--color-gold),transparent);
  opacity:.4;
}
.solve-container{
  max-width:800px;margin:0 auto;padding:0 1.5rem;
  text-align:center;
}

.solve-title{
  font-family:var(--font-display);font-size:clamp(1.8rem,5vw,2.6rem);
  font-weight:600;color:var(--color-ebony);
  margin-bottom:.35rem;line-height:1.15;
}
.solve-subtitle{
  font-size:.95rem;color:var(--color-taupe-dark);
  margin-bottom:var(--space-lg);line-height:1.6;
}

/* Search bar */
.solve-search{
  position:relative;max-width:650px;margin:0 auto var(--space-md);
}
.solve-search-icon{
  position:absolute;left:1.2rem;top:50%;transform:translateY(-50%);
  color:var(--color-gold);font-size:1rem;z-index:2;
}
.solve-search-input{
  width:100%;padding:.9rem 1.2rem .9rem 3rem;
  font-family:var(--font-body);font-size:.95rem;
  color:var(--color-ebony);
  background:var(--color-white);
  border:2px solid var(--color-gray-100);
  border-radius:999px;
  box-shadow:var(--shadow-sm);
  transition:all .35s var(--ease-out-expo);
  outline:none;
}
.solve-search-input:focus{
  border-color:var(--color-gold);
  box-shadow:0 0 0 4px rgba(196,161,89,.10),var(--shadow-md);
}
.solve-search-input::placeholder{color:var(--color-taupe);font-style:italic;font-size:.85rem}
.solve-result-count{
  position:absolute;right:1.2rem;top:50%;transform:translateY(-50%);
  font-size:.75rem;color:var(--color-taupe);
  white-space:nowrap;opacity:0;transition:opacity .3s;
}
.solve-result-count.visible{opacity:1}

/* Results list */
.solve-results{
  max-width:650px;margin:0 auto;
  display:flex;flex-direction:column;gap:.6rem;
}
.solve-result-card{
  background:var(--color-white);
  border:1px solid var(--color-gray-100);
  border-radius:var(--radius-md);
  padding:1rem 1.2rem;
  text-align:left;
  transition:all .35s var(--ease-out-expo);
  position:relative;overflow:hidden;
  animation:resultIn .4s var(--ease-out-expo) forwards;
  opacity:0;transform:translateY(12px);
}
@keyframes resultIn{to{opacity:1;transform:translateY(0)}}
.solve-result-card:hover{
  border-color:var(--color-gold);
  box-shadow:0 4px 20px rgba(196,161,89,.10);
}

/* Area badge */
.solve-area-badge{
  display:inline-block;
  font-family:var(--font-body);font-size:.68rem;font-weight:600;
  letter-spacing:.06em;text-transform:uppercase;
  color:var(--color-gold-dark);
  background:rgba(196,161,89,.10);
  padding:.15rem .6rem;border-radius:999px;
  margin-bottom:.4rem;
}

.solve-result-card h4{
  font-family:var(--font-display);font-size:1rem;font-weight:600;
  color:var(--color-ebony);margin-bottom:.25rem;line-height:1.3;
}
.solve-result-card p{
  font-size:.84rem;color:var(--color-taupe-dark);
  line-height:1.6;margin-bottom:.5rem;
}

/* Discreet CTA */
.solve-cta{
  display:inline-flex;align-items:center;gap:.3rem;
  font-size:.75rem;font-weight:500;
  color:var(--color-gold-dark);
  transition:all .3s;
  padding:.25rem 0;
  border-bottom:1px solid transparent;
}
.solve-cta:hover{color:var(--color-gold);border-bottom-color:var(--color-gold)}
.solve-cta i{font-size:.7rem}

/* Quick-link pills */
.solve-quick-links{
  display:flex;flex-wrap:wrap;justify-content:center;align-items:center;
  gap:.5rem;max-width:650px;margin:0 auto var(--space-md);
}
.solve-quick-label{
  font-size:.72rem;color:var(--color-taupe);
  letter-spacing:.04em;font-weight:500;margin-right:.2rem;
}
.solve-pill{
  display:inline-block;
  font-family:var(--font-body);font-size:.7rem;font-weight:500;
  color:var(--color-taupe-dark);
  background:var(--color-white);
  border:1px solid var(--color-gray-100);
  padding:.3rem .7rem;border-radius:999px;
  transition:all .3s var(--ease-out-expo);
  text-decoration:none;cursor:pointer;
}
.solve-pill:hover{
  color:var(--color-gold-dark);
  border-color:var(--color-gold);
  background:var(--color-gold-pale);
  transform:translateY(-1px);
}

/* SEO static content (inside <noscript> — Google indexes, users don't see) */
.solve-seo-content{
  max-width:650px;margin:var(--space-lg) auto 0;text-align:left;
  padding:var(--space-md);background:var(--color-white);
  border-radius:var(--radius-md);border:1px solid var(--color-gray-100);
}
.solve-seo-content h3{
  font-family:var(--font-display);font-size:1.1rem;color:var(--color-ebony);
  margin-bottom:var(--space-sm);
}
.solve-seo-content ul{list-style:disc;padding-left:1.5rem}
.solve-seo-content li{font-size:.85rem;color:var(--color-taupe-dark);margin-bottom:.4rem;line-height:1.6}
.solve-seo-content strong{color:var(--color-ebony)}

/* No results */
.solve-no-results{
  text-align:center;padding:1.5rem 1rem;
  color:var(--color-taupe);font-style:italic;
  display:none;
}
.solve-no-results.visible{display:block}

/* Responsive */
@media(max-width:640px){
  .solve-search-input{font-size:.88rem;padding:.75rem 1rem .75rem 2.6rem}
  .solve-search-input::placeholder{font-size:.78rem}
}

/* --------------------------------------------------------------------------
   11. PRACTICE AREAS (#areas)
   Cards: Clean premium — white surface, gold ring icon, bold typography.
   Hover: ring fills gold, border glows, card lifts with warm shadow.
   -------------------------------------------------------------------------- */
#areas{
  background:var(--color-obsidian);
  padding:var(--space-2xl) 0;
  position:relative;
}
.area-header{text-align:center;margin-bottom:var(--space-xl);padding:0 1.5rem}
.area-header .section-title{color:var(--color-white)}
.area-header .section-subtitle{color:var(--color-champagne);font-size:.95rem}
.area-icon-main{font-size:2.2rem;color:var(--color-champagne);margin-bottom:var(--space-sm);display:block}

.area-carousel{max-width:1200px;margin:0 auto;padding:0 2.8rem}

/* --- Card: Chamfered Octagon (Plaque Style) ---
   clip-path cuts the corners at 45° creating an elegant
   octagonal shape reminiscent of premium plaques and awards.
   drop-shadow follows the clipped shape for realistic depth.
   ------------------------------------------------------------------ */
.area-card{
  /* Octagon via chamfered corners */
  clip-path:polygon(
    12px 0,              calc(100% - 12px) 0,
    100% 12px,           100% calc(100% - 12px),
    calc(100% - 12px) 100%, 12px 100%,
    0 calc(100% - 12px), 0 12px
  );
  /* Shadow follows clip-path shape */
  filter:drop-shadow(0 1px 2px rgba(20,17,14,.06))
         drop-shadow(0 8px 24px rgba(20,17,14,.10));

  background:linear-gradient(170deg,var(--color-paper) 0%,var(--color-ivory) 60%,var(--color-gold-pale) 100%);
  padding:2.2rem 1.8rem 1.8rem;
  text-align:center;margin:0 .75rem;
  transition:all .55s cubic-bezier(.22,1,.36,1);
  min-height:330px;
  display:flex!important;flex-direction:column;align-items:center;justify-content:flex-start;gap:0;
  position:relative;overflow:visible;

  /* Inner gold frame — delicate rule inside the chamfered edge */
  --frame-inset:4px;
}
/* Inner gold frame using a pseudo-element that mirrors the clip-path */
.area-card::before{
  content:'';
  position:absolute;inset:var(--frame-inset);
  background:transparent;
  border:1.5px solid rgba(196,161,89,.22);
  clip-path:polygon(
    10px 0,              calc(100% - 10px) 0,
    100% 10px,           100% calc(100% - 10px),
    calc(100% - 10px) 100%, 10px 100%,
    0 calc(100% - 10px), 0 10px
  );
  pointer-events:none;
  transition:border-color .55s cubic-bezier(.22,1,.36,1);
  z-index:0;
}

/* --- Icon inside a gold ring --- */
.area-card .card-icon-wrap{
  width:72px;height:72px;border-radius:50%;
  border:2px solid var(--color-champagne);
  display:flex;align-items:center;justify-content:center;
  margin-bottom:1.2rem;
  transition:all .55s cubic-bezier(.22,1,.36,1);
  position:relative;z-index:1;
  background:transparent;
}
.area-card .card-icon{
  font-size:2rem;color:var(--color-champagne);
  transition:all .55s cubic-bezier(.22,1,.36,1);
}

/* --- Title --- */
.area-card h4{
  font-family:var(--font-display);font-size:1.25rem;font-weight:600;
  color:var(--color-obsidian);letter-spacing:-.01em;
  margin-bottom:.5rem;position:relative;z-index:1;
}

/* --- Gold separator line --- */
.area-card .card-sep{
  width:32px;height:2px;background:var(--color-champagne);
  margin:0 auto .75rem;position:relative;z-index:1;
  transition:width .55s cubic-bezier(.22,1,.36,1);
}

/* --- Description --- */
.area-card p{
  font-size:.85rem;color:var(--color-taupe-dark);line-height:1.6;
  margin-bottom:1rem;position:relative;z-index:1;
  flex:1;
}

/* --- CTA pill --- */
.area-card .saiba-mais{
  display:inline-flex;align-items:center;gap:.35rem;
  font-size:.75rem;font-weight:600;color:var(--color-champagne-dark);
  letter-spacing:.05em;text-transform:uppercase;
  position:relative;z-index:1;
  padding:.4rem 1rem;border-radius:999px;
  background:rgba(196,161,89,.08);
  transition:all .45s cubic-bezier(.22,1,.36,1);
  margin-top:auto;
}
.area-card .saiba-mais::after{
  content:'→';font-size:.85rem;
  transition:transform .35s cubic-bezier(.22,1,.36,1);
}

/* ================================================================
   HOVER STATE
   ================================================================ */
.area-card:hover{
  transform:translateY(-10px);
  filter:drop-shadow(0 2px 4px rgba(20,17,14,.05))
         drop-shadow(0 16px 40px rgba(20,17,14,.16))
         drop-shadow(0 0 60px rgba(196,161,89,.22));
}
/* Inner frame glows gold */
.area-card:hover::before{
  border-color:var(--color-champagne);
}

/* Ring fills with gold on hover */
.area-card:hover .card-icon-wrap{
  background:var(--color-champagne);
  border-color:var(--color-champagne);
  transform:scale(1.08);
  box-shadow:0 0 28px rgba(196,161,89,.3);
}
.area-card:hover .card-icon{
  color:var(--color-white);
  transform:scale(1.1);
}

/* Separator extends */
.area-card:hover .card-sep{width:56px}

/* CTA pill inverts */
.area-card:hover .saiba-mais{
  background:var(--color-champagne);
  color:var(--color-white);
}
.area-card:hover .saiba-mais::after{
  transform:translateX(4px);
}

/* --- Responsive: softer chamfer on mobile --- */
@media(max-width:768px){
  .area-card{
    clip-path:polygon(
      8px 0,              calc(100% - 8px) 0,
      100% 8px,           100% calc(100% - 8px),
      calc(100% - 8px) 100%, 8px 100%,
      0 calc(100% - 8px), 0 8px
    );
    min-height:290px;padding:1.8rem 1.2rem 1.4rem;
  }
  .area-card::before{
    clip-path:polygon(
      6px 0,              calc(100% - 6px) 0,
      100% 6px,           100% calc(100% - 6px),
      calc(100% - 6px) 100%, 6px 100%,
      0 calc(100% - 6px), 0 6px
    );
  }

  /* Modal mobile */
  .modal-overlay{padding:.75rem;align-items:flex-start}
  .modal-dialog{
    padding:1.5rem 1.2rem;max-height:88vh;
    border-radius:var(--radius-md);
  }
  .modal-dialog h3{font-size:1.3rem;padding-right:2.2rem}
  .modal-search{margin-bottom:1rem}
  .modal-search-input{font-size:.85rem;padding:.65rem 1rem .65rem 2.4rem}
  .modal-search-input::placeholder{font-size:.78rem}
  .scenario-card{padding:1rem 1.1rem}
  .scenario-query{font-size:.95rem!important}
  .scenario-text{font-size:.84rem}
}

/* Slick overrides */
.slick-prev:before,.slick-next:before{color:var(--color-champagne)!important;font-size:1.4rem!important;opacity:.6!important;transition:opacity .3s}
.slick-prev:hover:before,.slick-next:hover:before{opacity:1!important}
.slick-dots li button:before{color:var(--color-champagne)!important;font-size:7px!important;opacity:.3!important}
.slick-dots li.slick-active button:before{color:var(--color-champagne)!important;opacity:1!important}

/* --------------------------------------------------------------------------
   11. BLOG SECTION
   -------------------------------------------------------------------------- */
.blog-section{
  background:var(--color-obsidian);
  padding:var(--space-2xl) 0;
}
.blog-grid{
  display:flex;flex-direction:column;flex-wrap:wrap;gap:var(--space-lg);
  max-width:1200px;margin:0 auto;padding:0 1.5rem;
}
.blog-header-col{text-align:center}
.blog-header-col h2{color:var(--color-white);font-size:clamp(1.4rem,3vw,1.9rem);margin-bottom:var(--space-xs)}
.blog-header-col .section-subtitle{color:var(--color-champagne-light);font-size:1rem}
.blog-carousel-col{width:100%;display:flex;flex-direction:column;align-items:center}
.blog-carousel-slick{width:100%}

.blog-card{
  background:rgba(255,255,255,.04);
  border:1px solid rgba(196,161,89,.10);
  border-radius:var(--radius-md);
  padding:var(--space-md);margin:0 .5rem;
  transition:all .5s var(--ease-out-expo);
  min-height:210px;display:flex!important;flex-direction:column;
  position:relative;overflow:hidden;
}
.blog-card::after{
  content:'';position:absolute;bottom:0;left:0;right:0;height:2px;
  background:var(--color-champagne);
  transform:scaleX(0);transform-origin:right;
  transition:transform .5s var(--ease-out-expo);
}
.blog-card:hover{background:rgba(255,255,255,.07);border-color:rgba(196,161,89,.30);transform:translateY(-5px)}
.blog-card:hover::after{transform:scaleX(1);transform-origin:left}
.blog-card h3{font-family:var(--font-display);font-size:1.05rem;color:var(--color-champagne);margin-bottom:var(--space-xs)}
.blog-card .blog-author{font-size:.73rem;color:rgba(255,255,255,.4);margin-bottom:var(--space-sm);letter-spacing:.04em}
.blog-card .blog-excerpt{font-size:.85rem;color:rgba(255,255,255,.65);line-height:1.6;flex:1;margin-bottom:var(--space-md)}
.blog-read-more{
  display:inline-flex;align-items:center;gap:.45rem;
  font-size:.78rem;font-weight:600;color:var(--color-champagne);
  letter-spacing:.04em;text-transform:uppercase;
  transition:gap .3s var(--ease-out-expo);
}
.blog-read-more:hover{gap:.7rem}
.blog-read-more svg{width:14px;height:14px;transition:transform .3s}
.blog-read-more:hover svg{transform:translateX(4px)}

.blog-all-link{
  display:inline-flex;align-items:center;justify-content:center;
  background:transparent;color:var(--color-champagne);
  border:1.5px solid var(--color-champagne);
  font-family:var(--font-body);font-weight:600;
  font-size:.85rem;letter-spacing:.06em;text-transform:uppercase;
  padding:.8rem 1.8rem;border-radius:var(--radius-sm);
  margin-top:var(--space-lg);
  transition:all .4s var(--ease-out-expo);
}
.blog-all-link:hover{background:var(--color-champagne);color:var(--color-obsidian)}

/* --------------------------------------------------------------------------
   12. ARTICLE PAGES — Long-form blog post layout
   -------------------------------------------------------------------------- */
.article-hero{
  position:relative;
  background:linear-gradient(165deg,var(--color-ebony) 0%,var(--color-ebony-mid) 55%,var(--color-ebony-light) 100%);
  padding:calc(var(--space-3xl) + 4rem) 1.5rem var(--space-2xl);
  text-align:center;overflow:hidden;
}
.article-hero::before{
  content:'';position:absolute;top:0;left:50%;transform:translateX(-50%);
  width:min(400px,70vw);height:1px;
  background:linear-gradient(90deg,transparent,var(--color-gold),transparent);
  opacity:.5;
}
.article-breadcrumb{
  display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:.5rem;
  font-size:.78rem;color:rgba(255,255,255,.5);margin-bottom:var(--space-md);
  letter-spacing:.04em;
}
.article-breadcrumb a{color:var(--color-gold-light);transition:color .3s}
.article-breadcrumb a:hover{color:var(--color-gold)}
.article-breadcrumb i{font-size:.6rem;opacity:.5}

.article-hero h1{
  color:var(--color-white);font-size:clamp(1.85rem,5vw,3.1rem);
  max-width:880px;margin:0 auto var(--space-md);line-height:1.25;
}
.article-meta{
  display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:1.5rem;
  font-family:var(--font-body);font-size:.85rem;color:var(--color-gold-light);
  letter-spacing:.03em;
}
.article-meta span{display:inline-flex;align-items:center;gap:.5rem}
.article-meta i{color:var(--color-gold)}

.article-body{
  max-width:760px;margin:0 auto;
  padding:var(--space-2xl) 1.5rem;
  background:var(--color-paper);
}
.article-back{
  display:inline-flex;align-items:center;gap:.5rem;
  margin-bottom:var(--space-lg);
  font-size:.85rem;font-weight:600;letter-spacing:.04em;text-transform:uppercase;
  color:var(--color-gold-dark);transition:gap .3s var(--ease-out-expo);
}
.article-back:hover{gap:.8rem;color:var(--color-gold)}
.article-back i{font-size:.75rem}

.article-lead{
  font-family:var(--font-display);font-size:1.3rem;line-height:1.7;
  color:var(--color-ebony);font-weight:500;
  margin-bottom:var(--space-lg);padding-bottom:var(--space-lg);
  border-bottom:1px solid rgba(196,161,89,.2);
}
.article-body h2{
  font-size:clamp(1.35rem,3vw,1.8rem);color:var(--color-ebony);
  margin-top:var(--space-xl);margin-bottom:var(--space-sm);
  padding-bottom:.5rem;border-bottom:2px solid var(--color-gold-pale);
  position:relative;
}
.article-body h2::before{
  content:'';position:absolute;bottom:-2px;left:0;width:50px;height:2px;
  background:var(--color-gold);
}
.article-body h3{
  font-size:clamp(1.1rem,2.4vw,1.35rem);color:var(--color-gold-dark);
  margin-top:var(--space-lg);margin-bottom:var(--space-xs);font-weight:600;
}
.article-body p{
  font-size:1.05rem;line-height:1.9;color:var(--color-taupe-dark);
  margin-bottom:var(--space-md);
}
.article-body ul{margin:0 0 var(--space-md);padding-left:0}
.article-body ul li{
  position:relative;padding-left:1.6rem;margin-bottom:.6rem;
  font-size:1rem;line-height:1.8;color:var(--color-taupe-dark);
}
.article-body ul li::before{
  content:'';position:absolute;left:0;top:.65em;
  width:8px;height:8px;border-radius:50%;background:var(--color-gold);
}
.article-body blockquote{
  margin:var(--space-lg) 0;padding:var(--space-md) var(--space-lg);
  background:var(--color-cream);border-left:3px solid var(--color-gold);
  border-radius:0 var(--radius-md) var(--radius-md) 0;
  font-family:var(--font-display);font-size:1.15rem;font-style:italic;
  color:var(--color-ebony);line-height:1.7;
}
.article-body blockquote cite{
  display:block;margin-top:.6rem;font-family:var(--font-body);
  font-style:normal;font-size:.8rem;letter-spacing:.06em;
  text-transform:uppercase;color:var(--color-gold-dark);
}
.article-body strong{color:var(--color-ebony);font-weight:600}

.article-references{
  margin-top:var(--space-xl);padding-top:var(--space-lg);
  border-top:1px solid rgba(196,161,89,.2);
}
.article-references p{font-size:.85rem;color:var(--color-taupe);line-height:1.8;margin-bottom:.6rem}

.article-cta{
  margin-top:var(--space-2xl);padding:var(--space-lg);
  background:linear-gradient(160deg,var(--color-ebony) 0%,var(--color-ebony-mid) 100%);
  border-radius:var(--radius-lg);text-align:center;
  border:1px solid rgba(196,161,89,.2);
}
.article-cta h3{color:var(--color-white);margin-bottom:var(--space-xs);font-size:clamp(1.2rem,3vw,1.6rem)}
.article-cta p{color:rgba(255,255,255,.65);margin-bottom:var(--space-md);font-size:.95rem}

.article-related{
  background:var(--color-cream);padding:var(--space-2xl) 1.5rem;
}
.article-related-inner{max-width:760px;margin:0 auto}
.article-related h2{
  font-family:var(--font-display);color:var(--color-ebony);
  font-size:clamp(1.3rem,3vw,1.7rem);margin-bottom:var(--space-md);
  text-align:center;
}
.article-related-grid{
  display:grid;grid-template-columns:1fr;gap:var(--space-sm);
}
.article-related-card{
  display:block;background:var(--color-white);border:1px solid rgba(196,161,89,.15);
  border-radius:var(--radius-md);padding:var(--space-md);
  transition:all .4s var(--ease-out-expo);
}
.article-related-card:hover{border-color:var(--color-gold);transform:translateY(-3px);box-shadow:var(--shadow-sm)}
.article-related-card span{
  display:block;font-size:.7rem;font-weight:600;letter-spacing:.1em;
  text-transform:uppercase;color:var(--color-gold-dark);margin-bottom:.3rem;
}
.article-related-card h3{
  font-family:var(--font-display);font-size:1.05rem;color:var(--color-ebony);
  margin:0;font-weight:600;line-height:1.4;
}

/* --------------------------------------------------------------------------
   13. TESTIMONIALS (#review) — Light section for readability
   -------------------------------------------------------------------------- */
#review{
  background:var(--color-ivory);
  padding:var(--space-2xl) 0;
  border-bottom:3px solid var(--color-gold);
  position:relative;
}
#review::before{
  content:'';position:absolute;top:0;left:0;right:0;height:1px;
  background:linear-gradient(90deg,transparent,var(--color-gold),transparent);
  opacity:.4;
}

.review-header{text-align:center;margin-bottom:var(--space-xl);padding:0 1.5rem}
.review-title{font-family:var(--font-display);color:var(--color-ebony);font-size:clamp(1.5rem,4vw,2.2rem)}

/* Carousel container */
#div-reviews{width:100%;max-width:1100px;margin:0 auto}

.testimonial-card{
  background:var(--color-white);
  border:1px solid var(--color-gray-100);
  border-radius:var(--radius-md);
  padding:var(--space-lg) var(--space-md);
  margin:0 .6rem;
  text-align:center;
  transition:all .5s var(--ease-out-expo);
  display:flex!important;flex-direction:column;align-items:center;
  min-height:290px;
  position:relative;overflow:hidden;
  box-shadow:0 2px 12px rgba(20,17,14,.05);
}
.testimonial-card::before{
  content:'\201C';position:absolute;top:.5rem;left:1rem;
  font-family:var(--font-display);font-size:4rem;
  color:var(--color-gold);opacity:.12;
  line-height:1;
}
.testimonial-card:hover{
  border-color:var(--color-gold);
  transform:translateY(-6px);
  box-shadow:0 12px 40px rgba(20,17,14,.12);
}
.testimonial-card h4{
  font-family:var(--font-display);font-size:1.1rem;font-weight:600;
  color:var(--color-ebony);margin-bottom:var(--space-xs);
  position:relative;z-index:1;
}
.testimonial-stars{
  display:flex;justify-content:center;gap:4px;
  margin:0 auto var(--space-sm);
  color:var(--color-gold);font-size:.85rem;
  position:relative;z-index:1;
}
.testimonial-card p{
  font-size:.9rem;color:var(--color-taupe-dark);
  line-height:1.8;margin-bottom:0;flex:1;
  position:relative;z-index:1;
}

/* Slick overrides for testimonials */
#div-reviews .slick-track{display:flex!important;align-items:stretch}
#div-reviews .slick-slide{height:auto!important}
#div-reviews .slick-slide>div{height:100%}
#div-reviews .slick-list{margin:0 -.6rem}
#div-reviews .slick-dots{bottom:-2.5rem}
#div-reviews .slick-dots li button:before{color:var(--color-gold)!important;font-size:7px!important;opacity:.35!important}
#div-reviews .slick-dots li.slick-active button:before{color:var(--color-gold)!important;opacity:1!important}
#div-reviews .slick-prev:before,#div-reviews .slick-next:before{color:var(--color-gold)!important;opacity:.6!important}
#div-reviews .slick-prev:hover:before,#div-reviews .slick-next:hover:before{opacity:1!important}

/* --------------------------------------------------------------------------
   14. CONTACT SECTION
   -------------------------------------------------------------------------- */
#contato{
  background:var(--color-cream);
  padding:var(--space-2xl) 0;
}
.contact-grid{
  display:flex;flex-direction:column;flex-wrap:wrap;gap:var(--space-xl);
  max-width:1200px;margin:0 auto;padding:0 1.5rem;align-items:center;
}
.contact-map-col{width:100%;max-width:550px}
.contact-map-col h3{
  font-family:var(--font-display);font-size:1.25rem;
  color:var(--color-obsidian);margin-bottom:var(--space-md);text-align:center;
}
.contact-map-col iframe{
  width:100%;height:300px;border:none;border-radius:var(--radius-md);
  box-shadow:var(--shadow-lg);
}
.contact-form-col{width:100%;max-width:550px}
.contact-form-col h3{
  font-family:var(--font-display);font-size:1.25rem;
  color:var(--color-obsidian);margin-bottom:var(--space-md);text-align:center;
}
.contact-form{
  background:linear-gradient(145deg,var(--color-champagne),var(--color-champagne-dark));
  border-radius:var(--radius-md);padding:var(--space-md);
  box-shadow:0 20px 60px rgba(22,20,18,.15);
  position:relative;overflow:hidden;
}
.contact-form::before{
  content:'';position:absolute;top:0;right:0;width:120px;height:120px;
  background:radial-gradient(circle,rgba(255,255,255,.15) 0%,transparent 70%);
  border-radius:50%;transform:translate(40%,-40%);
}

.form-row{display:flex;flex-direction:column;gap:var(--space-sm);margin-bottom:var(--space-md);position:relative;z-index:1}
.form-group{flex:1;display:flex;flex-direction:column}
.form-group label{
  font-family:var(--font-body);font-size:.78rem;font-weight:600;
  color:rgba(255,255,255,.9);margin-bottom:.25rem;letter-spacing:.04em;
}
.form-group input,.form-group textarea{
  font-family:var(--font-body);font-size:.9rem;
  padding:.7rem .9rem;border:2px solid transparent;
  border-radius:var(--radius-sm);
  background:rgba(255,255,255,.94);color:var(--color-obsidian);
  transition:all .3s var(--ease-out-expo);resize:vertical;
}
.form-group input:focus,.form-group textarea:focus{
  outline:none;border-color:var(--color-obsidian);
  background:var(--color-white);
  box-shadow:0 0 0 4px rgba(22,20,18,.08);
}

.btn-submit{
  width:100%;background:var(--color-obsidian);color:var(--color-champagne-light);
  font-family:var(--font-body);font-size:.9rem;font-weight:600;
  letter-spacing:.06em;text-transform:uppercase;
  padding:.9rem;border-radius:var(--radius-sm);
  transition:all .4s var(--ease-out-expo);
  box-shadow:var(--shadow-md);
  display:flex;align-items:center;justify-content:center;gap:.5rem;
  position:relative;z-index:1;overflow:hidden;
}
.btn-submit::before{
  content:'';position:absolute;top:0;left:-100%;width:100%;height:100%;
  background:linear-gradient(90deg,transparent,rgba(255,255,255,.12),transparent);
  transition:left .6s var(--ease-out-expo);
}
.btn-submit:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg);color:var(--color-white)}
.btn-submit:hover::before{left:100%}

/* --------------------------------------------------------------------------
   15. FOOTER
   -------------------------------------------------------------------------- */
.site-footer{
  background:var(--color-obsidian);
  padding:var(--space-xl) 1.5rem;
  border-top:1px solid rgba(196,161,89,.15);
}
.footer-grid{
  display:flex;flex-direction:column;gap:var(--space-lg);
  max-width:800px;margin:0 auto;text-align:center;
}
.footer-col h3{
  font-family:var(--font-body);font-size:.85rem;
  color:var(--color-champagne);text-transform:uppercase;
  letter-spacing:.1em;margin-bottom:var(--space-sm);font-weight:600;
}
.footer-col p{font-size:.85rem;color:rgba(255,255,255,.55);line-height:1.9;margin-bottom:.1rem}
.social-links{display:flex;justify-content:center;gap:var(--space-sm);margin-top:var(--space-xs)}
.social-links a{
  display:flex;align-items:center;justify-content:center;
  width:40px;height:40px;border-radius:50%;
  border:1px solid rgba(255,255,255,.15);
  color:rgba(255,255,255,.55);font-size:.9rem;
  transition:all .4s var(--ease-out-expo);
}
.social-links a:hover{
  border-color:var(--color-champagne);color:var(--color-champagne);
  background:rgba(196,161,89,.08);
  transform:translateY(-3px);
}
.footer-bottom{
  text-align:center;background:rgba(0,0,0,.35);
  padding:var(--space-sm);
}
.footer-bottom span{font-size:.72rem;color:rgba(255,255,255,.4);letter-spacing:.05em}

/* --------------------------------------------------------------------------
   16. FLOATING WHATSAPP
   -------------------------------------------------------------------------- */
.floating-whatsapp{
  position:fixed;bottom:1.25rem;right:1.25rem;z-index:999;
  display:flex;align-items:center;justify-content:center;
  width:54px;height:54px;
  background:var(--color-success);color:var(--color-white);
  border-radius:50%;font-size:1.4rem;
  box-shadow:0 4px 24px rgba(34,197,94,.45);
  transition:all .4s var(--ease-out-expo);
  animation:whatsappPulse 3s ease-in-out infinite;
}
@keyframes whatsappPulse{
  0%,100%{box-shadow:0 4px 24px rgba(34,197,94,.45)}
  50%{box-shadow:0 4px 36px rgba(34,197,94,.65)}
}
.floating-whatsapp:hover{
  transform:scale(1.12);
  box-shadow:0 8px 36px rgba(34,197,94,.6);
  animation:none;
}

/* --------------------------------------------------------------------------
   17. MODAL — Premium Redesign
   -------------------------------------------------------------------------- */
.modal-overlay{
  position:fixed;inset:0;
  background:rgba(20,17,14,.90);
  backdrop-filter:blur(16px);
  -webkit-backdrop-filter:blur(16px);
  z-index:9999;
  display:flex;align-items:center;justify-content:center;
  padding:1.5rem;
  opacity:0;visibility:hidden;
  transition:all .45s var(--ease-out-expo);
}
.modal-overlay.active{opacity:1;visibility:visible}

.modal-dialog{
  background:linear-gradient(175deg,var(--color-paper) 0%,var(--color-ivory) 100%);
  border-radius:var(--radius-lg);
  padding:2.5rem 2rem 2rem;
  max-width:780px;width:100%;max-height:82vh;
  overflow-y:auto;overflow-x:hidden;
  position:relative;
  box-shadow:
    0 2px 8px rgba(20,17,14,.08),
    0 20px 60px rgba(20,17,14,.25);
  transform:translateY(40px) scale(.97);
  transition:transform .5s cubic-bezier(.22,1,.36,1);
  border:1px solid rgba(196,161,89,.12);
}
.modal-overlay.active .modal-dialog{
  transform:translateY(0) scale(1);
}

/* Close button */
.modal-close{
  position:absolute;top:1rem;right:1rem;
  font-size:1.5rem;color:var(--color-taupe);cursor:pointer;
  width:42px;height:42px;display:flex;align-items:center;justify-content:center;
  border-radius:50%;transition:all .35s var(--ease-out-expo);
  background:transparent;z-index:2;
}
.modal-close:hover{background:var(--color-gold-pale);color:var(--color-ebony)}

/* Title */
.modal-dialog h3{
  font-family:var(--font-display);font-size:1.6rem;font-weight:600;
  color:var(--color-ebony);margin-bottom:.15rem;padding-right:3rem;
  letter-spacing:-.01em;
}

/* ================================================================
   SEARCH BAR
   ================================================================ */
.modal-search{
  position:relative;margin-bottom:1.5rem;margin-top:.8rem;
}
.modal-search-icon{
  position:absolute;left:1rem;top:50%;transform:translateY(-50%);
  color:var(--color-gold);font-size:.95rem;z-index:2;
  transition:color .3s;
}
.modal-search-input{
  width:100%;padding:.8rem 1rem .8rem 2.8rem;
  font-family:var(--font-body);font-size:.92rem;
  color:var(--color-ebony);
  background:var(--color-white);
  border:2px solid var(--color-gray-100);
  border-radius:999px;
  transition:all .35s var(--ease-out-expo);
  outline:none;
}
.modal-search-input:focus{
  border-color:var(--color-gold);
  box-shadow:0 0 0 4px rgba(196,161,89,.10);
}
.modal-search-input::placeholder{
  color:var(--color-taupe);font-style:italic;font-size:.85rem;
}
.modal-result-count{
  position:absolute;right:1.2rem;top:50%;transform:translateY(-50%);
  font-size:.75rem;color:var(--color-taupe);
  white-space:nowrap;opacity:0;transition:opacity .3s;
}
.modal-result-count.visible{opacity:1}

/* ================================================================
   SCENARIO CARDS
   ================================================================ */
.modal-scenarios{
  display:flex;flex-direction:column;gap:.85rem;
}

.scenario-card{
  background:var(--color-white);
  border:1px solid var(--color-gray-100);
  border-radius:var(--radius-md);
  padding:1.25rem 1.4rem;
  transition:all .4s var(--ease-out-expo);
  opacity:1;transform:translateY(0);
  position:relative;overflow:hidden;
}
/* Subtle gold left accent */
.scenario-card::before{
  content:'';position:absolute;top:12%;left:0;width:3px;height:76%;
  background:var(--color-gold);
  border-radius:0 3px 3px 0;
  transform:scaleY(0);transform-origin:top;
  transition:transform .5s var(--ease-out-expo);
}
.scenario-card:hover{
  border-color:var(--color-gold);
  box-shadow:0 6px 28px rgba(196,161,89,.14);
  transform:translateX(4px);
}
.scenario-card:hover::before{transform:scaleY(1)}

/* Hidden visually but KEPT IN DOM for Google SEO indexing */
.scenario-card.filtered-out{
  opacity:0;transform:translateY(12px);
  max-height:0;padding-top:0;padding-bottom:0;margin:0;
  border-width:0;overflow:hidden;
  pointer-events:none;
  /* Content stays in DOM → Google indexes it */
}

/* No results message */
.modal-no-results{
  text-align:center;padding:2.5rem 1rem;
  color:var(--color-taupe);font-style:italic;
  display:none;
}
.modal-no-results.visible{display:block}
.modal-no-results strong{color:var(--color-ebony)}

.scenario-query{
  font-family:var(--font-display)!important;font-size:1.05rem!important;font-weight:600!important;
  color:var(--color-ebony)!important;margin-bottom:.35rem!important;padding-right:0!important;
  line-height:1.3!important;
}

.scenario-text{
  font-size:.9rem;line-height:1.75;color:var(--color-taupe-dark);
  margin-bottom:.75rem;
}

/* CTA button inside scenario */
.scenario-cta{
  display:inline-flex!important;align-items:center;gap:.45rem;
  background:var(--color-success)!important;color:#fff!important;
  font-family:var(--font-body)!important;font-size:.8rem!important;font-weight:600!important;
  padding:.5rem 1.1rem!important;border-radius:999px!important;
  text-decoration:none!important;white-space:nowrap;
  transition:all .35s var(--ease-out-expo)!important;
}
.scenario-cta:hover{
  transform:translateY(-2px);
  box-shadow:0 6px 20px rgba(29,168,81,.40);
}
.scenario-cta i{font-size:.85rem}

/* Highlight matching text in search */
.scenario-card mark{
  background:rgba(196,161,89,.2);color:var(--color-ebony);
  padding:0 .15rem;border-radius:2px;
}

/* --------------------------------------------------------------------------
   18. SCROLL REVEAL
   -------------------------------------------------------------------------- */
.reveal-on-scroll{
  opacity:0;transform:translateY(60px);
  transition:opacity .9s var(--ease-out-expo),
             transform .9s var(--ease-out-expo);
}
.reveal-on-scroll.revealed{opacity:1;transform:translateY(0)}

.reveal-on-scroll[data-delay="1"]{transition-delay:.1s}
.reveal-on-scroll[data-delay="2"]{transition-delay:.2s}
.reveal-on-scroll[data-delay="3"]{transition-delay:.3s}
.reveal-on-scroll[data-delay="4"]{transition-delay:.4s}
.reveal-on-scroll[data-delay="5"]{transition-delay:.5s}
.reveal-on-scroll[data-delay="6"]{transition-delay:.6s}

/* Staggered children reveal (for grids) */
.stagger-children>*{opacity:0;transform:translateY(40px)}
.stagger-children.revealed>*:nth-child(1){transition:all .7s var(--ease-out-expo) 0s}
.stagger-children.revealed>*:nth-child(2){transition:all .7s var(--ease-out-expo) .12s}
.stagger-children.revealed>*:nth-child(3){transition:all .7s var(--ease-out-expo) .24s}
.stagger-children.revealed>*:nth-child(4){transition:all .7s var(--ease-out-expo) .36s}
.stagger-children.revealed>*:nth-child(5){transition:all .7s var(--ease-out-expo) .48s}
.stagger-children.revealed>*{opacity:1;transform:translateY(0)}

/* --------------------------------------------------------------------------
   23. GLOBAL SLICK OVERRIDES
   -------------------------------------------------------------------------- */
.slick-track{display:flex!important;align-items:stretch}
.slick-slide{height:auto!important}
.slick-slide>div{height:100%}

/* --------------------------------------------------------------------------
   24. REDUCED MOTION
   -------------------------------------------------------------------------- */
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{
    animation-duration:.01ms!important;
    animation-iteration-count:1!important;
    transition-duration:.01ms!important;
    scroll-behavior:auto!important
  }
}
/* --------------------------------------------------------------------------
   19. RESPONSIVE — SMALL TABLET ≥ 640px
   -------------------------------------------------------------------------- */
@media(min-width:640px){
  .container{padding:0 2rem}
  .hero-content{padding:0 2.5rem}
  .hero-subtitle{font-size:.85rem}
  .hero-badges-inner{grid-template-columns:repeat(2,1fr);gap:var(--space-md) var(--space-lg)}
  /* Tablet hero image: 1280w */
  .hero-bg{background-image:url('https://images.unsplash.com/photo-1589829545856-d10d557cf95f?w=1280&q=85')}

  .area-carousel{padding:0 3rem}
  .area-card{min-height:300px}

  .modal-dialog{padding:2rem;max-width:620px}
  .modal-search-input{font-size:.9rem}

  .team-photo{min-height:350px}

  .testimonial-card{padding:var(--space-lg)}

  .contact-map-col{max-width:600px}
  .contact-map-col iframe{height:360px}
  .contact-form-col{max-width:600px}
  .contact-form{padding:var(--space-lg)}

  .form-row{flex-direction:row}

  .footer-grid{flex-direction:row;text-align:left;gap:4rem}
  .social-links{justify-content:flex-start}

  .floating-whatsapp{bottom:1.5rem;right:1.5rem;width:58px;height:58px;font-size:1.5rem}

  .section-padding{padding:var(--space-2xl) 0}

  .article-related-grid{grid-template-columns:repeat(2,1fr)}
}

/* --------------------------------------------------------------------------
   20. RESPONSIVE — TABLET ≥ 768px
   Header goes desktop. Content stays stacked for safety.
   -------------------------------------------------------------------------- */
@media(min-width:768px){
  .menu-toggle{display:none}
  .nav-list{display:flex;gap:1.8rem;align-items:center}
  .nav-list a{
    font-family:var(--font-body);font-size:.78rem;font-weight:500;
    letter-spacing:.06em;text-transform:uppercase;
    color:rgba(255,255,255,.75);position:relative;padding:.3rem 0;
    transition:color .3s var(--ease-out-expo);
  }
  .nav-list a::after{
    content:'';position:absolute;bottom:0;left:0;
    width:0;height:1.5px;background:var(--color-gold);
    transition:width .5s var(--ease-out-expo);
  }
  .nav-list a:hover{color:var(--color-gold)}
  .nav-list a:hover::after{width:100%}

  .header-whatsapp{
    display:flex!important;align-items:center;gap:.4rem;
    background:var(--color-success);color:var(--color-white);
    padding:.5rem 1.1rem;border-radius:999px;
    font-size:.78rem;font-weight:600;
    transition:all .4s var(--ease-out-expo);
    box-shadow:0 2px 14px rgba(34,197,94,.3);
  }
  .header-whatsapp:hover{transform:translateY(-2px);box-shadow:0 6px 24px rgba(34,197,94,.45)}
  .header-whatsapp i{font-size:1rem}

  .header-logo img{height:2.8rem}
  .header-inner{padding:.7rem 2rem}

  .hero-content{padding:0 3rem}

  .container{padding:0 2.5rem}

  #areas{padding:var(--space-xl) 0}
  #team{padding:var(--space-xl) 0}
  #review{padding:var(--space-xl) 0}
  #contato{padding:var(--space-xl) 0}
  .blog-section{padding:var(--space-xl) 0}

  .article-body{padding:var(--space-2xl) 2.5rem}
}

/* --------------------------------------------------------------------------
   21. RESPONSIVE — MEDIUM DESKTOP ≥ 900px
   Enough width for side-by-side layouts without cramping.
   -------------------------------------------------------------------------- */
@media(min-width:900px){
  .hero-content{padding:0 4rem}
  /* Desktop hero image: 1920w */
  .hero-bg{background-image:url('https://images.unsplash.com/photo-1589829545856-d10d557cf95f?w=1920&q=90')}

  /* Team carousel goes side-by-side + full bios */
  .team-slide-inner{flex-direction:row;min-height:380px}
  .bio-short{display:none}
  .bio-full{display:block}
  .team-slide-inner:nth-child(even){flex-direction:row-reverse}
  .team-photo{flex:0 0 40%;min-height:400px}
  .team-photo-overlay{text-align:left}
  .team-bio{padding:var(--space-lg)}

  /* Blog goes side-by-side */
  .blog-grid{flex-direction:row;align-items:flex-start}
  .blog-header-col{flex:0 0 30%;text-align:left}
  .blog-carousel-col{flex:1}

  /* Contact goes side-by-side */
  .contact-grid{flex-direction:row;align-items:flex-start}
  .contact-map-col{flex:0 0 44%}
  .contact-form-col{flex:1}

}

/* --------------------------------------------------------------------------
   22. RESPONSIVE — DESKTOP ≥ 1100px
   Comfortable desktop with generous spacing.
   -------------------------------------------------------------------------- */
@media(min-width:1100px){
  .header-inner{padding:.75rem 3rem}
  .nav-list{gap:2.5rem}
  .nav-list a{font-size:.82rem}

  .hero-content{padding:0 5rem}
  .hero-subtitle{font-size:.95rem}

  .hero-badges-inner{grid-template-columns:repeat(4,1fr);gap:var(--space-lg)}

  .section-title{font-size:2.2rem}

  .team-photo{flex:0 0 35%}
  .team-bio p{font-size:.95rem}

  .area-carousel{padding:0 3.5rem}

  .contact-map-col iframe{height:430px}

  .footer-grid{gap:6rem}

  .modal-dialog{max-width:780px;padding:2.8rem 2.5rem 2.5rem}
  .modal-dialog h3{font-size:1.8rem}

  #areas{padding:var(--space-3xl) 0}
  #team{padding:var(--space-3xl) 0}
  #review{padding:var(--space-3xl) 0}
  #contato{padding:var(--space-3xl) 0}
  .blog-section{padding:var(--space-3xl) 0}
}

/* --------------------------------------------------------------------------
   23. RESPONSIVE — XL ≥ 1400px
   Large screens — hero gets left margin, containers tighten.
   -------------------------------------------------------------------------- */
@media(min-width:1400px){
  .hero-content{margin-left:4rem;max-width:920px}
  .blog-grid,.contact-grid{padding:0}
}

/* --------------------------------------------------------------------------
