/* Sozo Terra Insights — tokens espelhados do projeto React (src/styles.css) */
:root{
  --radius: 0.75rem;
  --heading-font: "Plus Jakarta Sans", sans-serif;
  --body-font: "Kanit", sans-serif;

  /* Brand palette (oklch — idêntico ao projeto original) */
  --background: oklch(0.985 0.005 80);
  --foreground: oklch(0.18 0.02 60);
  --card: oklch(1 0 0);
  --card-foreground: oklch(0.18 0.02 60);
  --primary: oklch(0.36 0.08 145);
  --primary-foreground: oklch(0.985 0.005 80);
  --secondary: oklch(0.95 0.015 70);
  --secondary-foreground: oklch(0.22 0.03 60);
  --muted: oklch(0.94 0.012 70);
  --muted-foreground: oklch(68.295% 0.00008 271.152);
  --accent: oklch(0.65 0.13 65);
  --accent-foreground: oklch(0.99 0.005 80);
  --gold: oklch(0.68 0.14 65);
  --gold-foreground: oklch(0.99 0.005 80);
  --forest: oklch(0.36 0.08 145);
  --earth: oklch(0.42 0.08 50);
  --border: oklch(0.88 0.012 70);
  --input: oklch(0.88 0.012 70);
  --ring: oklch(0.65 0.13 65);

  /* Gradientes & sombras (idênticos) */
  --gradient-hero: linear-gradient(135deg, oklch(0.25 0.04 60 / 0.85) 0%, oklch(0.18 0.02 50 / 0.55) 60%, oklch(0.42 0.08 50 / 0.45) 100%);
  --gradient-gold: linear-gradient(135deg, oklch(0.55 0.13 60), oklch(0.68 0.14 65));
  --gradient-earth: linear-gradient(160deg, oklch(0.45 0.10 55), oklch(0.32 0.06 45));
  --shadow-elegant: 0 20px 50px -20px oklch(0.25 0.05 60 / 0.35);
  --shadow-soft: 0 4px 20px -8px oklch(0.25 0.05 60 / 0.18);
  --transition-smooth: all 0.4s cubic-bezier(0.4, 0, 0.2, 1);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
html,body{font-family:var(--body-font);color:var(--foreground);background:var(--background);-webkit-font-smoothing:antialiased;font-feature-settings:"ss01","cv11"}

p {
  margin-top: 0;
  margin-bottom: 1rem;
  font-size: 1.25rem;
  font-weight: 300;
}

.font-display,h1,h2,h3,h4,h5,h6{font-family:var(--heading-font);letter-spacing:-0.02em}
.text-gold{color:var(--gold)!important}
.text-accent{color:var(--accent)!important}
.text-foreground{color:var(--foreground)!important}
.text-muted-2{color:var(--muted-foreground)!important}
.bg-light-soft{background:var(--secondary)}
.bg-card{background:var(--card)}
.bg-gradient-gold{background:var(--gradient-gold)!important}
.bg-gradient-earth{background:var(--gradient-earth)!important}
.bg-gradient-hero{background:var(--gradient-hero)!important}
.shadow-soft{box-shadow:var(--shadow-soft)!important}
.shadow-elegant{box-shadow:var(--shadow-elegant)!important}
.transition-smooth{transition:var(--transition-smooth)}
a{color:var(--accent);text-decoration:none}
a:hover{color:color-mix(in oklab, var(--accent) 80%, white)}

/* Buttons */
.btn-gold {
  background: var(--gradient-gold);
  color: var(--gold-foreground);
  border: none;
  box-shadow: var(--shadow-soft);
  transition: var(--transition-smooth);
  font-weight: normal;
  letter-spacing: .05em;
}

.btn-contact {
  padding: 15px;
}

.btn-gold:hover{filter:brightness(1.1);color:var(--gold-foreground);box-shadow:var(--shadow-elegant)}
.btn-outline-gold{border:1px solid var(--accent);color:var(--accent);background:transparent}
.btn-outline-gold:hover{background:var(--accent);color:var(--accent-foreground)}
.eyebrow{color:var(--accent);letter-spacing:.3em;font-size:.78rem;font-weight:700;text-transform:uppercase}

/* Navbar */
.sozo-navbar {
  background: #ffffff;
  backdrop-filter: blur(10px);
  border-bottom: 1px solid var(--border);
  border-radius: 0 0 10px 10px;
  padding: 10px 20px;
}
.sozo-navbar .navbar-brand img{height:48px}
.sozo-navbar .nav-link{font-weight:normal;text-transform:uppercase;letter-spacing:.05em;font-size:.85rem;color:var(--foreground);padding:.75rem 1rem;transition:var(--transition-smooth)}
.sozo-navbar .nav-link:hover,.sozo-navbar .nav-link.active{color:var(--accent)}
.lang-switch .btn{font-weight:normal;border-color:var(--border);color:var(--foreground)}
.lang-switch .btn.active{background:var(--gradient-gold);color:var(--gold-foreground);border-color:transparent}

.lang-switch a {
  padding: 2px 5px;
  font-size: 10px;
}

/* Hero carousel */
.hero-carousel {
  margin-top: -80px;
}
.hero-carousel .carousel-item{height:88vh;min-height:560px}
.hero-img{width:100%;height:100%;object-fit:cover}
.hero-overlay{position:absolute;inset:0;background:var(--gradient-hero)}
.hero-caption{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2rem 1rem;text-align:center;color:#fff}
.hero-caption .display-3{text-shadow:0 2px 14px rgba(0,0,0,.4)}

.hero-caption .display-3 span {
  color: var(--gold) !important;
  display: block;
}


.carousel-indicators [data-bs-target]{height:8px;border-radius:99px;border:none;background:rgba(255,255,255,.5)}
.carousel-indicators .active{background:var(--accent);width:36px}

/* Page hero */
.page-hero {
  background: var(--gradient-earth);
  position: relative;
  overflow: hidden;
  color: #fff;
  margin-top: -80px;
  padding-top: 110px !important;
}
.page-hero::before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 20% 30%, oklch(0.65 0.13 65 / .35), transparent 55%),radial-gradient(circle at 80% 70%, oklch(0.32 0.06 45 / .55), transparent 55%);opacity:.6}
.page-hero>.container{position:relative;z-index:1}

/* Cards (espelha rounded-2xl + shadow-soft do React) */
.stat-card{border:1px solid var(--border);background:var(--card);border-radius:1rem;padding:1.25rem;box-shadow:var(--shadow-soft);text-align:center}
.stat-num {
  font-size: 36px;
  color: var(--accent);
  font-weight: bold;
  font-family: var(--heading-font);
  letter-spacing: -3px;
}
.stat-label{color:var(--muted-foreground);letter-spacing:.05em;text-transform:uppercase;font-size:.75rem;margin-top:.5rem}
.stat-card-dark{background:rgba(255,255,255,.05);border-color:rgba(255,255,255,.18);color:#fff}
.stat-card-dark .stat-num{color:var(--accent)}

.target-card,.elem-card,.info-card,.doc-card,.pillar-card,.news-card,.step-card{
  background:var(--card);border:1px solid var(--border);border-radius:1.25rem;padding:1.5rem;
  box-shadow:var(--shadow-soft);transition:var(--transition-smooth);
}
.target-card:hover,.pillar-card:hover,.news-card:hover,.doc-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-elegant)}
.pillar-card .pillar-icon{width:64px;height:64px;border-radius:1.125rem;background:color-mix(in oklab, var(--accent) 12%, transparent);color:var(--accent);display:flex;align-items:center;justify-content:center;font-size:1.7rem}
.step-card{display:flex;gap:1rem;align-items:flex-start}
.step-num{flex:none;width:42px;height:42px;border-radius:50%;background:var(--gradient-gold);color:var(--gold-foreground);font-weight:700;display:flex;align-items:center;justify-content:center;font-family:var(--heading-font)}
.badge-pill-gold{background:color-mix(in oklab, var(--accent) 12%, transparent);color:var(--accent);border:1px solid color-mix(in oklab, var(--accent) 35%, transparent);border-radius:99px;padding:.3rem .85rem;font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em}
.badge-soft{background:rgba(255,255,255,.12);color:var(--accent);border-radius:99px;padding:.35rem .85rem;display:inline-flex;align-items:center;gap:.4rem}

/* Project image card */
.card-project{background:var(--earth);color:#fff;text-decoration:none;display:block;position:relative;border-radius:1.5rem;overflow:hidden;box-shadow:var(--shadow-elegant)}
.card-project-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform .7s ease}
.card-project:hover .card-project-img{transform:scale(1.05)}
.card-project-overlay{position:absolute;inset:0;background:linear-gradient(to top, oklch(0.42 0.08 50 / .95), transparent)}
.card-project-body{position:relative;padding:2rem;display:flex;flex-direction:column;justify-content:flex-end;height:100%;min-height:420px;color:#fff}

.cta-earth{background:var(--gradient-earth);box-shadow:var(--shadow-elegant);color:#fff;border-radius:1.5rem}

/* News */
.news-card{padding:0;overflow:hidden;display:flex;flex-direction:column;color:inherit}
.news-cover-wrap{aspect-ratio:16/10;overflow:hidden}
.news-cover{width:100%;height:100%;object-fit:cover;transition:transform .5s}
.news-card:hover .news-cover{transform:scale(1.05)}
.news-card .news-body{padding:1.5rem}

/* Docs */
.doc-icon{width:60px;height:60px;border-radius:.875rem;background:color-mix(in oklab, var(--accent) 12%, transparent);color:var(--accent);display:flex;align-items:center;justify-content:center;font-size:1.7rem}

/* Contact */
.contact-item{display:flex;gap:1rem;align-items:flex-start;padding:1.25rem;border:1px solid var(--border);border-radius:1rem;background:var(--card);box-shadow:var(--shadow-soft)}
.contact-item i{width:48px;height:48px;border-radius:.75rem;background:var(--gradient-gold);color:var(--gold-foreground);display:flex;align-items:center;justify-content:center;flex:none}
.contact-item a{text-decoration:none;color:var(--foreground);font-weight:600}
.form-control,.form-control-lg{border-radius:.75rem;border-color:var(--border);background:var(--background);padding:.85rem 1rem}
.form-control:focus{border-color:var(--accent);box-shadow:0 0 0 .25rem color-mix(in oklab, var(--accent) 20%, transparent)}

/* Filtros */
.news-filter-btn,.doc-filter-btn{border:1px solid var(--border);background:var(--card);color:var(--foreground);border-radius:99px;padding:.5rem 1rem;font-weight:700;font-size:.72rem;text-transform:uppercase;letter-spacing:.06em;transition:var(--transition-smooth)}
.news-filter-btn.active,.doc-filter-btn.active{background:var(--gradient-gold);color:var(--gold-foreground);border-color:transparent}

/* Footer */
.sozo-footer{background:var(--secondary);border-top:1px solid var(--border);color:var(--foreground)}
.sozo-footer a{color:#fff}
.sozo-footer a:hover{color:var(--accent)}
.social-btn{width:40px;height:40px;border-radius:50%;background:var(--gradient-gold);color:var(--gold-foreground);display:inline-flex;align-items:center;justify-content:center;text-decoration:none;transition:var(--transition-smooth)}
.social-btn:hover{transform:scale(1.12);color:var(--gold-foreground);box-shadow:var(--shadow-soft)}

/* Whatsapp FAB */
.whatsapp-fab{position:fixed;bottom:24px;right:24px;width:56px;height:56px;border-radius:50%;background:#25d366;color:#fff;display:flex;align-items:center;justify-content:center;font-size:1.6rem;box-shadow:0 8px 22px rgba(37,211,102,.45);z-index:999;text-decoration:none}
.whatsapp-fab:hover{color:#fff;transform:scale(1.08)}

.article-body p{margin-bottom:1.1rem;font-size:1.05rem;line-height:1.75;color:var(--muted-foreground)}
.article-body h2,.article-body h3{color:var(--foreground);margin-top:2rem}

@media (max-width:991px){
  .hero-carousel .carousel-item{height:auto;min-height:0}
  .hero-img{height:90vh;min-height:520px}
  .hero-caption .display-3{font-size:2.2rem}
}
