/* ============================================
   CUIDAR FORMULAS - Professional Veterinary
   Clean, Serious, Clinical
   ============================================ */

:root {
    --purple: #5E2470; --purple-light: #7B3A91; --purple-soft: #F3EBF6;
    --accent: #C4922A; --accent-dark: #A67B1E;
    --gradient: linear-gradient(135deg, #5E2470, #7B3A91);
    --accent-gradient: linear-gradient(135deg, #5E2470, #C4922A);
    --white: #fff; --g50: #FAFBFC; --g100: #F2F3F5; --g200: #E5E7EB; --g300: #D1D5DB; --g900: #111827;
    --text: #111827; --text2: #4B5563; --text3: #9CA3AF;
    --shadow-sm: 0 1px 3px rgba(0,0,0,.06); --shadow-md: 0 4px 16px rgba(0,0,0,.06); --shadow-lg: 0 8px 30px rgba(0,0,0,.08);
    --r-sm: 6px; --r-md: 10px; --r-lg: 12px; --r-xl: 16px; --r-full: 9999px;
    --border: #E5E7EB;
}

*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior: smooth; scroll-padding-top: 80px; }
body { font-family:'Poppins',sans-serif; color:var(--text); background:var(--white); overflow-x:hidden; line-height:1.6; -webkit-font-smoothing:antialiased; }

::-webkit-scrollbar { width:6px }
::-webkit-scrollbar-track { background:var(--g100) }
::-webkit-scrollbar-thumb { background:var(--purple); border-radius:10px }
::selection { background:var(--purple); color:var(--white) }

img { display:block; max-width:100%; background:var(--g100); }
.container { max-width:1200px; margin:0 auto; padding:0 24px; }
.gradient-text { color:var(--purple); -webkit-text-fill-color:var(--purple); }
.section-tag { display:inline-block; padding:5px 14px; background:var(--purple-soft); color:var(--purple); border-radius:var(--r-full); font-size:.8rem; font-weight:600; margin-bottom:10px; letter-spacing:.5px; text-transform:uppercase; }
.section-title { font-size:clamp(1.8rem,3.5vw,2.5rem); font-weight:700; line-height:1.25; margin-bottom:12px; color:var(--text); }
.section-subtitle { font-size:1rem; color:var(--text2); max-width:560px; margin:0 auto; line-height:1.7; }
.section-header { text-align:center; margin-bottom:48px; }
.section { padding:80px 0; position:relative; z-index:1; }

/* ═══ PRELOADER ═══ */
#preloader { position:fixed; inset:0; background:var(--white); display:flex; align-items:center; justify-content:center; z-index:10000; transition:opacity .4s,visibility .4s }
#preloader.loaded { opacity:0; visibility:hidden; pointer-events:none }
.preloader-inner { text-align:center }
.preloader-circle { animation:spin 1.8s linear infinite; transform-origin:center }
@keyframes spin { from{stroke-dashoffset:565} to{stroke-dashoffset:0} }
.preloader-text { font-size:1rem; font-weight:600; color:var(--purple); margin-top:.8rem; animation:pulse 1.5s ease infinite }
@keyframes pulse { 0%,100%{opacity:.4} 50%{opacity:1} }

#particles-canvas { position:fixed; inset:0; pointer-events:none; z-index:0; opacity:.12 }

/* ═══ NAV ═══ */
.navbar { position:fixed; top:0; left:0; right:0; z-index:1000; padding:12px 0; transition:all .3s; background:rgba(17,24,39,.35); backdrop-filter:blur(8px); -webkit-backdrop-filter:blur(8px) }
.navbar.scrolled { padding:6px 0; background:rgba(255,255,255,.96); backdrop-filter:blur(16px); -webkit-backdrop-filter:blur(16px); box-shadow:0 1px 12px rgba(0,0,0,.04); border-bottom:1px solid var(--border) }
.nav-container { max-width:1200px; margin:0 auto; padding:0 24px; display:flex; align-items:center; justify-content:space-between; gap:16px }
.nav-logo { display:flex; align-items:center; gap:10px; text-decoration:none; flex-shrink:0 }
.logo-icon { width:40px; height:40px; filter:brightness(1.4); transition:filter .3s }
.navbar.scrolled .logo-icon { filter:brightness(1) }
.logo-text { display:flex; flex-direction:column; line-height:1.1 }
.logo-name { font-size:1.15rem; font-weight:700; color:var(--white); transition:color .3s }
.logo-sub { font-size:.65rem; font-weight:600; color:rgba(255,255,255,.7); letter-spacing:2.5px; text-transform:uppercase; transition:color .3s }
.navbar.scrolled .logo-name { color:var(--purple) }
.navbar.scrolled .logo-sub { color:var(--accent) }
.nav-links { display:flex; align-items:center; gap:0 }
.nav-link { padding:8px 14px; color:rgba(255,255,255,.8); text-decoration:none; font-size:.87rem; font-weight:500; border-radius:var(--r-sm); transition:all .2s; white-space:nowrap; position:relative }
.nav-link:hover,.nav-link.active { color:var(--white); background:rgba(255,255,255,.12) }
.nav-link.active::after { content:''; position:absolute; bottom:4px; left:50%; transform:translateX(-50%); width:16px; height:2px; background:var(--white); border-radius:2px }
.navbar.scrolled .nav-link { color:var(--text2) }
.navbar.scrolled .nav-link:hover,.navbar.scrolled .nav-link.active { color:var(--purple); background:var(--purple-soft) }
.navbar.scrolled .nav-link.active::after { background:var(--purple) }
.nav-cta { display:inline-flex; align-items:center; gap:8px; padding:9px 22px; background:rgba(255,255,255,.15); border:1px solid rgba(255,255,255,.25); color:var(--white); text-decoration:none; font-size:.87rem; font-weight:600; border-radius:var(--r-sm); transition:all .2s; flex-shrink:0; white-space:nowrap }
.nav-cta:hover { background:rgba(255,255,255,.25) }
.navbar.scrolled .nav-cta { background:var(--purple); color:var(--white); border-color:var(--purple) }
.navbar.scrolled .nav-cta:hover { background:var(--purple-light); border-color:var(--purple-light); box-shadow:var(--shadow-md) }
.cta-pulse { display:none }
.nav-toggle { display:none; flex-direction:column; gap:5px; background:none; border:none; cursor:pointer; padding:8px; z-index:1001 }
.nav-toggle span { display:block; width:22px; height:2px; background:var(--white); transition:all .2s; border-radius:2px }
.navbar.scrolled .nav-toggle span { background:var(--text) }
.nav-toggle.active span:nth-child(1){transform:rotate(45deg) translate(5px,5px)} .nav-toggle.active span:nth-child(2){opacity:0} .nav-toggle.active span:nth-child(3){transform:rotate(-45deg) translate(5px,-5px)}

.mobile-menu { position:fixed; inset:0; background:rgba(255,255,255,.98); backdrop-filter:blur(16px); z-index:999; display:flex; align-items:center; justify-content:center; opacity:0; visibility:hidden; transition:all .3s }
.mobile-menu.active { opacity:1; visibility:visible }
.mobile-menu-content { display:flex; flex-direction:column; align-items:center; gap:16px }
.mobile-link { font-size:1.3rem; font-weight:600; color:var(--text); text-decoration:none; transform:translateY(15px); opacity:0; transition:all .3s }
.mobile-menu.active .mobile-link { transform:translateY(0); opacity:1 }
.mobile-menu.active .mobile-link:nth-child(1){transition-delay:.05s} .mobile-menu.active .mobile-link:nth-child(2){transition-delay:.1s} .mobile-menu.active .mobile-link:nth-child(3){transition-delay:.15s} .mobile-menu.active .mobile-link:nth-child(4){transition-delay:.2s} .mobile-menu.active .mobile-link:nth-child(5){transition-delay:.25s} .mobile-menu.active .mobile-link:nth-child(6){transition-delay:.3s} .mobile-menu.active .mobile-link:nth-child(7){transition-delay:.35s} .mobile-menu.active .mobile-link:nth-child(8){transition-delay:.4s}
.mobile-link:hover { color:var(--purple) }
.mobile-cta { margin-top:12px; padding:13px 30px; background:var(--purple); color:var(--white); text-decoration:none; font-size:1rem; font-weight:600; border-radius:var(--r-sm); transform:translateY(15px); opacity:0; transition:all .3s }
.mobile-menu.active .mobile-cta { transform:translateY(0); opacity:1; transition-delay:.45s }

/* ═══ HERO ═══ */
.hero { min-height:100vh; display:flex; align-items:center; position:relative; overflow:hidden }
.hero-parallax-bg { position:absolute; inset:0; z-index:0; background:var(--g900) }
.hero-bg-img { width:100%; height:100%; object-fit:cover; object-position:center 30%; background:transparent }
.hero-overlay { position:absolute; inset:0; background:linear-gradient(160deg,rgba(17,24,39,.78) 0%,rgba(94,36,112,.45) 50%,rgba(17,24,39,.6) 100%) }
.hero-content { position:relative; z-index:2; width:100%; padding-top:80px }
.hero-left { max-width:620px }
.hero-badge { display:inline-flex; align-items:center; gap:8px; padding:7px 18px; background:rgba(255,255,255,.08); border:1px solid rgba(255,255,255,.12); border-radius:var(--r-sm); font-size:.82rem; font-weight:500; color:rgba(255,255,255,.9); margin-bottom:20px; backdrop-filter:blur(8px) }
.badge-dot { width:6px; height:6px; background:var(--accent); border-radius:50%; animation:bdot 2.5s ease infinite }
@keyframes bdot { 0%,100%{opacity:1} 50%{opacity:.3} }
.hero-title { font-size:clamp(2.2rem,5vw,3.5rem); font-weight:700; line-height:1.15; margin-bottom:20px; color:var(--white) }
.title-highlight { color:var(--accent); -webkit-text-fill-color:var(--accent) }
.paw-icon { display:inline-block }
.hero-description { font-size:1.05rem; color:rgba(255,255,255,.75); line-height:1.7; margin-bottom:28px; max-width:480px }
.hero-actions { display:flex; gap:12px; flex-wrap:wrap; margin-bottom:40px }

.btn { display:inline-flex; align-items:center; gap:10px; padding:12px 26px; font-family:inherit; font-size:.9rem; font-weight:600; text-decoration:none; border-radius:var(--r-sm); cursor:pointer; transition:all .2s; border:none; position:relative }
.btn-primary { background:var(--purple); color:var(--white); box-shadow:0 2px 8px rgba(94,36,112,.2) }
.btn-primary:hover { background:var(--purple-light); box-shadow:0 4px 16px rgba(94,36,112,.25) }
.btn-glass { background:rgba(255,255,255,.08); backdrop-filter:blur(8px); color:var(--white); border:1px solid rgba(255,255,255,.18) }
.btn-glass:hover { background:rgba(255,255,255,.18) }
.btn-white { background:var(--white); color:var(--purple); box-shadow:0 2px 10px rgba(0,0,0,.1) }
.btn-white:hover { box-shadow:0 4px 20px rgba(0,0,0,.15) }
.btn-glass-light { background:rgba(255,255,255,.1); backdrop-filter:blur(8px); color:var(--white); border:1px solid rgba(255,255,255,.2) }
.btn-glass-light:hover { background:rgba(255,255,255,.2) }
.btn-lg { padding:14px 32px; font-size:.95rem }

.hero-stats { display:flex; align-items:center; gap:28px }
.stat-item { text-align:center }
.stat-number { font-size:1.8rem; font-weight:700; color:var(--white) }
.stat-suffix { font-size:1.2rem; font-weight:700; color:var(--accent) }
.stat-label { display:block; font-size:.75rem; color:rgba(255,255,255,.55); font-weight:500; margin-top:2px; text-transform:uppercase; letter-spacing:.5px }
.stat-divider { width:1px; height:32px; background:rgba(255,255,255,.15) }

.hero-scroll-indicator { position:absolute; bottom:28px; left:50%; transform:translateX(-50%); display:flex; flex-direction:column; align-items:center; gap:6px; z-index:5; opacity:0; animation:fadeUp .8s ease 1.2s forwards }
@keyframes fadeUp { to{opacity:1} }
.scroll-mouse { width:20px; height:32px; border:2px solid rgba(255,255,255,.3); border-radius:10px; position:relative }
.scroll-wheel { width:3px; height:6px; background:var(--white); border-radius:2px; position:absolute; top:5px; left:50%; transform:translateX(-50%); animation:wheel 2s ease infinite }
@keyframes wheel { 0%{opacity:1;transform:translateX(-50%) translateY(0)} 100%{opacity:0;transform:translateX(-50%) translateY(10px)} }
.hero-scroll-indicator span { font-size:.65rem; color:rgba(255,255,255,.4); letter-spacing:1.5px; text-transform:uppercase }

/* ═══ ECOSYSTEM ═══ */
.ecosystem-bar { padding:20px 0; background:var(--g50); border-bottom:1px solid var(--border); z-index:1; position:relative }
.ecosystem-label { text-align:center; font-size:.7rem; color:var(--text3); text-transform:uppercase; letter-spacing:2.5px; margin-bottom:10px; font-weight:500 }
.ecosystem-brands { display:flex; align-items:center; justify-content:center; gap:14px; flex-wrap:wrap }
.brand-item { display:flex; align-items:center; gap:7px; position:relative }
.brand-logo-circle { width:30px; height:30px; border-radius:50%; display:flex; align-items:center; justify-content:center; flex-shrink:0 }
.brand-item span { font-size:.8rem; font-weight:500; color:var(--text3); white-space:nowrap }
.brand-connector { display:flex; align-items:center }
.active-brand span:first-of-type { color:var(--purple); font-weight:600 }
.new-badge { position:absolute; top:-7px; right:-28px; background:var(--accent); color:var(--white)!important; font-size:.55rem!important; font-weight:700!important; padding:2px 6px; border-radius:var(--r-full) }

/* ═══ SOBRE ═══ */
.sobre { background:var(--white) }
.sobre-grid { display:grid; grid-template-columns:1fr 1fr; gap:60px; align-items:center }
.sobre-text { font-size:.95rem; color:var(--text2); line-height:1.8; margin-bottom:12px }
.sobre-features { margin-top:24px; display:flex; flex-direction:column; gap:10px }
.feature-item { display:flex; align-items:center; gap:10px }
.feature-icon { width:28px; height:28px; display:flex; align-items:center; justify-content:center; color:var(--purple); flex-shrink:0 }
.feature-item span { font-size:.9rem; color:var(--text2) }

.sobre-image-stack { position:relative; padding-bottom:20px; padding-right:20px }
.image-card { border-radius:var(--r-lg); overflow:hidden; box-shadow:var(--shadow-md); background:var(--g100) }
.image-card img { width:100%; height:100%; object-fit:cover; transition:transform .6s ease }
.image-card:hover img { transform:scale(1.02) }
.image-card-1 { width:100%; aspect-ratio:4/3 }
.image-card-2 { position:absolute; bottom:0; right:0; width:48%; aspect-ratio:1; border:3px solid var(--white); border-radius:var(--r-lg) }
.sobre-badge { position:absolute; top:16px; left:-12px; background:var(--purple); color:var(--white); padding:16px 18px; border-radius:var(--r-lg); text-align:center; box-shadow:var(--shadow-lg); z-index:3 }
.badge-number { font-size:1.6rem; font-weight:700; line-height:1 }
.badge-text { font-size:.68rem; opacity:.85; line-height:1.3; margin-top:2px }

/* ═══ SERVIÇOS ═══ */
.servicos { background:var(--g50) }
.services-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:20px }
.service-card { background:var(--white); border-radius:var(--r-lg); overflow:hidden; border:1px solid var(--border); transition:all .25s; display:flex; flex-direction:column }
.service-card:hover { border-color:rgba(94,36,112,.15); box-shadow:var(--shadow-lg) }
.service-card-img { width:100%; aspect-ratio:16/10; object-fit:cover; object-position:center top; transition:transform .5s }
.service-card:hover .service-card-img { transform:scale(1.03) }
.service-card-body { padding:20px; flex:1; display:flex; flex-direction:column }
.service-card-body h3 { font-size:1rem; font-weight:700; margin-bottom:6px; color:var(--text) }
.service-card-body p { font-size:.85rem; color:var(--text2); line-height:1.6; margin-bottom:10px; flex:1 }
.service-tags { display:flex; flex-wrap:wrap; gap:6px }
.tag { padding:3px 10px; background:var(--g100); border-radius:var(--r-full); font-size:.72rem; font-weight:500; color:var(--text3); transition:all .2s }
.service-card:hover .tag { background:var(--purple-soft); color:var(--purple) }

/* ═══ COMO FUNCIONA ═══ */
.como-funciona { background:var(--white) }
.steps-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:20px }
.step-card { text-align:center }
.step-img-wrap { position:relative; border-radius:var(--r-lg); overflow:hidden; aspect-ratio:3/4; margin-bottom:16px; box-shadow:var(--shadow-sm); background:var(--g100) }
.step-img-wrap img { width:100%; height:100%; object-fit:cover; transition:transform .5s }
.step-img-wrap:hover img { transform:scale(1.03) }
.step-number-overlay { position:absolute; top:10px; left:10px; width:40px; height:40px; background:var(--purple); color:var(--white); font-size:.9rem; font-weight:700; border-radius:var(--r-sm); display:flex; align-items:center; justify-content:center; box-shadow:var(--shadow-md) }
.step-card h3 { font-size:.93rem; font-weight:700; margin-bottom:6px }
.step-card p { font-size:.82rem; color:var(--text2); line-height:1.5; padding:0 4px }

/* ═══ PARALLAX COUNTER ═══ */
.parallax-divider { position:relative; height:40vh; min-height:260px; overflow:hidden; z-index:1; display:flex; align-items:center; justify-content:center }
.parallax-bg-img { position:absolute; inset:-10% 0; width:100%; height:120%; object-fit:cover }
.parallax-overlay { position:absolute; inset:0; background:linear-gradient(160deg,rgba(94,36,112,.82) 0%,rgba(17,24,39,.7) 100%) }
.parallax-counter-row { position:relative; z-index:2; display:flex; gap:50px; justify-content:center; flex-wrap:wrap; padding:0 24px }
.parallax-counter { text-align:center }
.pc-number { font-size:clamp(2rem,4vw,3rem); font-weight:700; color:var(--white) }
.pc-suffix { font-size:clamp(1.2rem,2.2vw,1.8rem); font-weight:700; color:var(--accent) }
.pc-label { display:block; font-size:.8rem; color:rgba(255,255,255,.65); margin-top:4px; font-weight:400 }

/* ═══ DIFERENCIAIS ═══ */
.diferenciais { background:var(--g50) }
.diff-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:16px }
.diff-card { background:var(--white); border-radius:var(--r-lg); padding:28px 20px; text-align:center; transition:all .25s; border:1px solid var(--border); overflow:hidden; position:relative }
.diff-card:hover { box-shadow:var(--shadow-md); border-color:rgba(94,36,112,.1) }
.diff-card-large { grid-column:span 2; grid-row:span 2; color:var(--white); display:flex; align-items:center; justify-content:center; min-height:260px; border-color:transparent }
.diff-card-bg-img { position:absolute; inset:0; width:100%; height:100%; object-fit:cover }
.diff-card-overlay { position:absolute; inset:0; background:linear-gradient(160deg,rgba(94,36,112,.88),rgba(17,24,39,.7)) }
.diff-card-content { position:relative; z-index:2 }
.diff-emoji { font-size:1.8rem; margin-bottom:10px; display:flex; align-items:center; justify-content:center; width:48px; height:48px; background:var(--purple-soft); border-radius:var(--r-md); margin:0 auto 12px }
.diff-card h3 { font-size:.95rem; font-weight:700; margin-bottom:6px; color:var(--text) }
.diff-card p { font-size:.82rem; color:var(--text2); line-height:1.5 }
.diff-card-large h3 { color:var(--white); font-size:1.2rem }
.diff-card-large p { color:rgba(255,255,255,.8); font-size:.9rem }
.diff-card-large .diff-emoji { background:rgba(255,255,255,.15) }

/* ═══ FORMAS ═══ */
.formas { background:var(--white); overflow:hidden }
.formas-carousel { position:relative; overflow:hidden }
.formas-track { display:flex; gap:20px; transition:transform .5s cubic-bezier(.4,0,.2,1); cursor:grab }
.formas-track:active { cursor:grabbing }
.forma-card { flex:0 0 calc(25% - 15px); background:var(--g50); border-radius:var(--r-lg); overflow:hidden; transition:all .25s; border:1px solid var(--border) }
.forma-card:hover { background:var(--white); border-color:rgba(94,36,112,.12); box-shadow:var(--shadow-md) }
.forma-img-wrap { width:100%; aspect-ratio:4/3; overflow:hidden; background:var(--g100) }
.forma-img-wrap img { width:100%; height:100%; object-fit:cover; transition:transform .5s }
.forma-card:hover .forma-img-wrap img { transform:scale(1.04) }
.forma-card h3 { font-size:.9rem; font-weight:700; margin:12px 16px 6px; color:var(--text) }
.forma-card p { font-size:.8rem; color:var(--text2); line-height:1.5; padding:0 16px 16px }
.carousel-controls { display:flex; align-items:center; justify-content:center; gap:14px; margin-top:28px }
.carousel-btn { width:38px; height:38px; display:flex; align-items:center; justify-content:center; background:var(--white); border:1px solid var(--border); border-radius:var(--r-sm); cursor:pointer; color:var(--text2); transition:all .2s }
.carousel-btn:hover { background:var(--purple); color:var(--white); border-color:var(--purple) }
.carousel-dots { display:flex; gap:6px }
.carousel-dot { width:8px; height:8px; border-radius:50%; background:var(--g300); cursor:pointer; transition:all .2s }
.carousel-dot.active { width:20px; border-radius:4px; background:var(--purple) }

/* ═══ SABORES + ESPÉCIES ═══ */
.sabores-especies { background:var(--g50) }
.sabores-content { display:grid; grid-template-columns:1fr 1.6fr; gap:40px; align-items:start; margin-bottom:48px }
.sabores-text p { font-size:.92rem; color:var(--text2); line-height:1.7; margin-top:10px }
.sabores-grid { display:flex; flex-wrap:wrap; gap:8px; align-content:start }
.sabor-chip { display:inline-flex; align-items:center; gap:6px; padding:7px 14px; background:var(--white); border-radius:var(--r-sm); font-size:.84rem; font-weight:500; border:1px solid var(--border); transition:all .2s; cursor:default }
.sabor-chip:hover { border-color:var(--purple); background:var(--purple-soft); color:var(--purple) }
.sabor-chip span { font-size:1rem }
.more-chip { background:var(--purple); color:var(--white); border-color:transparent; font-weight:600 }
.more-chip:hover { background:var(--purple-light); color:var(--white); border-color:transparent }

.especies-row { padding-top:8px }
.especies-title { font-size:1.2rem; font-weight:700; text-align:center; margin-bottom:24px }
.especies-grid { display:grid; grid-template-columns:repeat(6,1fr); gap:16px }
.especie-card { background:var(--white); border-radius:var(--r-lg); overflow:hidden; transition:all .25s; border:1px solid var(--border); text-align:center }
.especie-card:hover { border-color:rgba(94,36,112,.12); box-shadow:var(--shadow-md) }
.especie-img { width:100%; aspect-ratio:1; overflow:hidden; background:var(--g100) }
.especie-img img { width:100%; height:100%; object-fit:cover; transition:transform .5s }
.especie-card:hover .especie-img img { transform:scale(1.05) }
.especie-card h4 { font-size:.85rem; font-weight:600; padding:10px 0 12px; color:var(--text) }

/* ═══ DEPOIMENTOS ═══ */
.depoimentos { background:var(--white) }
.depoimentos-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:20px }
.depo-card { background:var(--g50); border-radius:var(--r-lg); padding:28px; transition:all .25s; border:1px solid var(--border) }
.depo-card:hover { box-shadow:var(--shadow-md); border-color:rgba(94,36,112,.08); background:var(--white) }
.depo-stars { color:var(--accent); font-size:1rem; margin-bottom:12px; letter-spacing:2px }
.depo-text { font-size:.9rem; color:var(--text2); line-height:1.7; margin-bottom:16px; font-style:italic }
.depo-author { display:flex; align-items:center; gap:10px }
.depo-avatar { width:42px; height:42px; border-radius:50%; overflow:hidden; flex-shrink:0; border:2px solid var(--purple-soft); background:var(--g100) }
.depo-avatar img { width:100%; height:100%; object-fit:cover }
.depo-author strong { display:block; font-size:.85rem }
.depo-author span { font-size:.76rem; color:var(--text3) }

/* ═══ CTA ═══ */
.cta-section { padding:40px 0 80px }
.cta-box { border-radius:var(--r-xl); overflow:hidden; position:relative; min-height:320px; display:flex; align-items:center; justify-content:center }
.cta-bg-img { position:absolute; inset:0; width:100%; height:100%; object-fit:cover }
.cta-overlay { position:absolute; inset:0; background:linear-gradient(160deg,rgba(94,36,112,.9),rgba(17,24,39,.75)) }
.cta-content { position:relative; z-index:2; text-align:center; padding:50px 32px }
.cta-box h2 { font-size:clamp(1.4rem,3vw,1.9rem); font-weight:700; color:var(--white); margin-bottom:12px }
.cta-highlight { color:var(--accent); -webkit-text-fill-color:var(--accent) }
.cta-box p { color:rgba(255,255,255,.75); font-size:1rem; margin-bottom:28px; max-width:480px; margin-left:auto; margin-right:auto }
.cta-actions { display:flex; gap:12px; justify-content:center; flex-wrap:wrap }

/* ═══ CONTATO ═══ */
.contato { background:var(--g50) }
.contato-grid { display:grid; grid-template-columns:1fr 1fr; gap:40px }
.contato-info { display:flex; flex-direction:column; gap:12px }
.contato-card { display:flex; align-items:flex-start; gap:14px; padding:16px; background:var(--white); border-radius:var(--r-md); transition:all .2s; border:1px solid var(--border) }
.contato-card:hover { border-color:rgba(94,36,112,.08); box-shadow:var(--shadow-sm) }
.contato-icon { width:40px; height:40px; display:flex; align-items:center; justify-content:center; background:var(--purple-soft); border-radius:var(--r-sm); color:var(--purple); flex-shrink:0 }
.contato-card h4 { font-size:.88rem; font-weight:700; margin-bottom:2px }
.contato-card p { font-size:.85rem; color:var(--text2); line-height:1.5 }
.contato-social { display:flex; gap:10px; margin-top:4px }
.social-link { width:40px; height:40px; display:flex; align-items:center; justify-content:center; background:var(--white); border:1px solid var(--border); border-radius:var(--r-sm); color:var(--text2); text-decoration:none; transition:all .2s }
.social-link:hover { background:var(--purple); color:var(--white); border-color:var(--purple) }
.contato-map { position:relative }
.map-wrapper { width:100%; height:380px; border-radius:var(--r-lg); overflow:hidden; box-shadow:var(--shadow-sm); background:var(--g100); border:1px solid var(--border) }
.map-overlay-info { position:absolute; bottom:-12px; left:20px; right:20px; background:var(--white); border-radius:var(--r-md); padding:14px 18px; box-shadow:var(--shadow-md); border:1px solid var(--border) }
.map-overlay-info strong { font-size:.85rem; display:block }
.map-overlay-info span { font-size:.76rem; color:var(--text3) }

/* ═══ FOOTER ═══ */
.footer { background:var(--g900); color:var(--white); padding:50px 0 0 }
.footer-top { display:grid; grid-template-columns:1.5fr 1fr 1fr 1fr; gap:36px; padding-bottom:36px; border-bottom:1px solid rgba(255,255,255,.06) }
.footer-brand .nav-logo { margin-bottom:12px }
.footer-brand .logo-name { color:var(--white) }
.footer-desc { font-size:.85rem; color:rgba(255,255,255,.45); line-height:1.6 }
.footer-links-group h4 { font-size:.85rem; font-weight:600; margin-bottom:12px }
.footer-links-group a { display:block; font-size:.82rem; color:rgba(255,255,255,.45); text-decoration:none; padding:3px 0; transition:all .2s }
.footer-links-group a:hover { color:var(--accent); transform:translateX(2px) }
.footer-bottom { padding:20px 0; text-align:center }
.footer-bottom p { font-size:.76rem; color:rgba(255,255,255,.3) }
.footer-note { margin-top:3px; font-size:.7rem!important; color:rgba(255,255,255,.2)!important }

/* ═══ FLOAT BUTTONS ═══ */
.whatsapp-float { position:fixed; bottom:22px; right:22px; width:54px; height:54px; background:#25D366; border-radius:var(--r-md); display:flex; align-items:center; justify-content:center; box-shadow:0 4px 14px rgba(37,211,102,.3); z-index:999; transition:all .2s }
.whatsapp-float:hover { box-shadow:0 6px 20px rgba(37,211,102,.4) }
.back-to-top { position:fixed; bottom:22px; left:22px; width:38px; height:38px; background:var(--white); border:1px solid var(--border); border-radius:var(--r-sm); display:flex; align-items:center; justify-content:center; cursor:pointer; opacity:0; visibility:hidden; transition:all .2s; z-index:999; color:var(--text2) }
.back-to-top.visible { opacity:1; visibility:visible }
.back-to-top:hover { background:var(--purple); color:var(--white); border-color:var(--purple) }

/* ═══ REVEAL ═══ */
.reveal-up { opacity:0; transform:translateY(20px); transition:opacity .5s ease,transform .5s ease }
.reveal-up.revealed { opacity:1; transform:translateY(0) }

/* ═══ RESPONSIVE ═══ */
@media(max-width:1024px) {
    .nav-links,.nav-cta { display:none }
    .nav-toggle { display:flex }
    .sobre-grid { grid-template-columns:1fr; gap:32px }
    .sobre-visual { max-width:560px; margin:0 auto }
    .services-grid { grid-template-columns:repeat(2,1fr) }
    .steps-grid { grid-template-columns:repeat(2,1fr) }
    .diff-grid { grid-template-columns:repeat(2,1fr) }
    .diff-card-large { grid-column:span 2; grid-row:span 1; min-height:200px }
    .forma-card { flex:0 0 calc(33.333% - 14px) }
    .especies-grid { grid-template-columns:repeat(3,1fr) }
    .depoimentos-grid { grid-template-columns:1fr 1fr }
    .depo-card:last-child { grid-column:span 2; max-width:480px; margin:0 auto }
    .contato-grid { grid-template-columns:1fr }
    .map-wrapper { height:320px }
    .footer-top { grid-template-columns:repeat(2,1fr) }
    .sabores-content { grid-template-columns:1fr }
}
@media(max-width:768px) {
    .section { padding:56px 0 }
    .section-header { margin-bottom:32px }
    .hero-title { font-size:2rem }
    .hero-description { font-size:.95rem }
    .hero-stats { flex-direction:row; flex-wrap:wrap; gap:16px; justify-content:flex-start }
    .stat-divider { width:1px; height:28px }
    .services-grid { grid-template-columns:1fr 1fr; gap:14px }
    .service-card-img { aspect-ratio:16/9 }
    .service-card-body { padding:16px }
    .service-card-body h3 { font-size:.93rem }
    .service-card-body p { font-size:.82rem }
    .diff-grid { grid-template-columns:1fr 1fr; gap:12px }
    .diff-card-large { grid-column:span 2; min-height:180px }
    .diff-card { padding:20px 16px }
    .diff-emoji { width:40px; height:40px; font-size:1.4rem }
    .diff-card h3 { font-size:.88rem }
    .diff-card p { font-size:.78rem }
    .forma-card { flex:0 0 calc(50% - 10px) }
    .especies-grid { grid-template-columns:repeat(3,1fr); gap:12px }
    .depoimentos-grid { grid-template-columns:1fr }
    .depo-card { padding:22px }
    .depo-card:last-child { grid-column:span 1; max-width:none }
    .footer-top { grid-template-columns:1fr 1fr; gap:20px }
    .cta-content { padding:36px 20px }
    .cta-actions { flex-direction:column; align-items:center }
    .brand-connector { display:none }
    .ecosystem-brands { gap:10px }
    .brand-item span { font-size:.73rem }
    .hero-scroll-indicator { display:none }
    .image-card-2 { position:relative; width:100%; margin-top:12px; aspect-ratio:16/9 }
    .sobre-badge { position:relative; display:inline-block; margin-top:12px; left:0; top:0 }
    .sobre-image-stack { padding:0 }
    .parallax-divider { height:auto; min-height:220px; padding:40px 0 }
    .parallax-counter-row { gap:20px }
    .parallax-counter { min-width:0 }
    .pc-label { font-size:.72rem }
    .steps-grid { grid-template-columns:repeat(2,1fr); gap:14px }
    .step-img-wrap { aspect-ratio:3/4 }
    .step-card h3 { font-size:.86rem }
    .step-card p { font-size:.78rem }
    .contato-grid { gap:24px }
    .map-wrapper { height:280px }
    .map-overlay-info { bottom:-8px; left:12px; right:12px; padding:10px 14px }
    .sabores-text .section-title { font-size:1.4rem }
}
@media(max-width:480px) {
    .container { padding:0 16px }
    .section { padding:44px 0 }
    .hero { min-height:100svh }
    .hero-content { padding-top:70px }
    .hero-title { font-size:1.7rem }
    .hero-description { font-size:.88rem; margin-bottom:20px }
    .hero-badge { font-size:.76rem; padding:5px 12px }
    .hero-actions { gap:10px }
    .section-title { font-size:1.35rem }
    .section-tag { font-size:.72rem; padding:4px 10px }
    .btn { padding:11px 20px; font-size:.84rem }
    .btn-lg { padding:12px 22px; font-size:.88rem }
    .services-grid { grid-template-columns:1fr; gap:14px }
    .service-card-img { aspect-ratio:16/9 }
    .forma-card { flex:0 0 calc(85% - 10px) }
    .especies-grid { grid-template-columns:repeat(3,1fr); gap:8px }
    .especie-card h4 { font-size:.78rem; padding:6px 0 8px }
    .diff-grid { grid-template-columns:1fr 1fr; gap:10px }
    .diff-card-large { grid-column:span 2 }
    .diff-card { padding:16px 12px }
    .diff-emoji { width:36px; height:36px; font-size:1.2rem }
    .diff-card h3 { font-size:.82rem }
    .diff-card p { font-size:.73rem }
    .map-wrapper { height:240px }
    .steps-grid { grid-template-columns:1fr 1fr; gap:10px }
    .step-img-wrap { aspect-ratio:1 }
    .footer-top { grid-template-columns:1fr; gap:20px }
    .parallax-counter-row { gap:16px; padding:0 16px }
    .pc-number { font-size:1.6rem }
    .pc-label { font-size:.68rem }
    .cta-box h2 { font-size:1.15rem }
    .cta-box p { font-size:.88rem }
    .sabores-grid { gap:6px }
    .sabor-chip { padding:5px 10px; font-size:.78rem }
    .depo-card { padding:18px }
    .depo-text { font-size:.84rem }
    .contato-card { padding:12px }
    .contato-card p { font-size:.82rem }
}
@media(max-width:360px) {
    .hero-title { font-size:1.5rem }
    .hero-stats { gap:12px }
    .stat-number { font-size:1.4rem }
    .stat-label { font-size:.68rem }
    .diff-grid { grid-template-columns:1fr; gap:10px }
    .diff-card-large { grid-column:span 1 }
    .especies-grid { grid-template-columns:repeat(2,1fr) }
    .steps-grid { grid-template-columns:1fr; gap:12px }
    .step-img-wrap { aspect-ratio:4/3 }
}
@media(prefers-reduced-motion:reduce) {
    *,*::before,*::after { animation-duration:.01ms!important; transition-duration:.01ms!important }
    html { scroll-behavior:auto }
    .reveal-up { opacity:1; transform:none }
}
