/* ============================================
   JAMILLE PORTO — Site Institucional 2026
   Design: Modern Editorial + Tech Institute
   Inspired by premium AI/education platforms
   ============================================ */

/* ---------- TOKENS ---------- */
:root {
  /* Paleta principal */
  --bg: #FAFAF8;
  --bg-alt: #F3F1ED;
  --bg-dark: #1A1A1F;
  --bg-card: #FFFFFF;
  --bg-glass: rgba(255,255,255,.72);

  --text: #1A1A1F;
  --text-body: #4A4A52;
  --text-muted: #8A8A92;
  --text-inverse: #FAFAF8;

  --accent: #6B2D3E;
  --accent-hover: #7D3549;
  --accent-light: rgba(107,45,62,.08);
  --accent-glow: rgba(107,45,62,.15);

  --green: #25D366;
  --border: rgba(0,0,0,.06);
  --border-strong: rgba(0,0,0,.1);
  --white: #FFFFFF;

  /* Sombras */
  --shadow-xs: 0 1px 2px rgba(0,0,0,.04);
  --shadow-sm: 0 2px 8px rgba(0,0,0,.05);
  --shadow-md: 0 4px 24px rgba(0,0,0,.07);
  --shadow-lg: 0 12px 48px rgba(0,0,0,.1);
  --shadow-xl: 0 24px 64px rgba(0,0,0,.12);
  --shadow-accent: 0 8px 32px rgba(107,45,62,.2);

  /* Tipografia */
  --font-display: 'Playfair Display', Georgia, serif;
  --font-sans: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;

  /* Spacing */
  --sp-1: .25rem;
  --sp-2: .5rem;
  --sp-3: .75rem;
  --sp-4: 1rem;
  --sp-5: 1.25rem;
  --sp-6: 1.5rem;
  --sp-8: 2rem;
  --sp-10: 2.5rem;
  --sp-12: 3rem;
  --sp-16: 4rem;
  --sp-20: 5rem;
  --sp-24: 6rem;
  --sp-32: 8rem;

  /* Layout */
  --max-w: 1200px;
  --max-w-narrow: 800px;
  --header-h: 72px;
  --radius-sm: 8px;
  --radius: 12px;
  --radius-lg: 16px;
  --radius-xl: 24px;
  --radius-full: 9999px;
  --ease: cubic-bezier(.4,0,.2,1);
  --duration: .3s;
}

/* ---------- RESET ---------- */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;overflow-x:hidden}
html.menu-open{overflow:hidden !important}
html.menu-open body{overflow:hidden !important;touch-action:none}
body{
  font-family:var(--font-sans);
  font-size:1rem;
  line-height:1.7;
  color:var(--text-body);
  background:var(--bg);
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none;transition:color var(--duration) var(--ease)}
ul,ol{list-style:none}
button{font-family:inherit;cursor:pointer;border:none;background:none}
input,textarea,select{font-family:inherit;border:none;outline:none}

/* ---------- TIPOGRAFIA ---------- */
h1,h2,h3,h4,h5{
  font-family:var(--font-display);
  font-weight:700;
  line-height:1.2;
  color:var(--text);
  letter-spacing:-.02em;
}
h1{font-size:clamp(2.25rem,5.5vw,3.75rem)}
h2{font-size:clamp(1.75rem,3.5vw,2.75rem)}
h3{font-size:clamp(1.25rem,2vw,1.5rem)}
h4{font-size:1.125rem}
p{margin-bottom:var(--sp-4);color:var(--text-body)}
.lead{font-size:1.125rem;line-height:1.85;color:var(--text-body)}
.overline{
  font-family:var(--font-sans);
  font-size:.75rem;
  font-weight:600;
  letter-spacing:.15em;
  text-transform:uppercase;
  color:var(--accent);
  display:inline-block;
  margin-bottom:var(--sp-4);
}
.overline::before{
  content:'';
  display:inline-block;
  width:24px;
  height:2px;
  background:var(--accent);
  margin-right:var(--sp-3);
  vertical-align:middle;
}

/* ---------- LAYOUT ---------- */
.container{width:100%;max-width:var(--max-w);margin:0 auto;padding:0 var(--sp-6)}

.section{padding:var(--sp-24) 0}
.section--alt{background:var(--bg-alt)}
.section--dark{background:var(--bg-dark);color:var(--text-inverse)}
.section--dark h2,.section--dark h3,.section--dark h4{color:var(--text-inverse)}
.section--dark p{color:rgba(255,255,255,.65)}
.section--dark .overline{color:rgba(255,255,255,.5)}
.section--dark .overline::before{background:rgba(255,255,255,.3)}

.section__header{
  max-width:640px;
  margin-bottom:var(--sp-16);
}
.section__header--center{
  text-align:center;
  margin-left:auto;
  margin-right:auto;
}
.section__header h2{margin-bottom:var(--sp-4)}
.section__header p{margin-bottom:0}

.grid{display:grid;gap:var(--sp-8)}
.grid--2{grid-template-columns:repeat(2,1fr)}
.grid--3{grid-template-columns:repeat(3,1fr)}
.grid--4{grid-template-columns:repeat(4,1fr)}

/* ---------- HEADER ---------- */
.header{
  position:fixed;
  top:0;left:0;right:0;
  z-index:1100;
  height:var(--header-h);
  background:transparent;
  transition:background var(--duration) var(--ease),
             box-shadow var(--duration) var(--ease),
             border-color var(--duration) var(--ease);
  -webkit-transform:translateZ(0);
  transform:translateZ(0);
  will-change:background,box-shadow;
  pointer-events:auto;
}
.header.scrolled{
  background:rgba(250,250,248,.95);
  backdrop-filter:blur(20px);
  -webkit-backdrop-filter:blur(20px);
  border-bottom:1px solid var(--border);
  box-shadow:var(--shadow-xs);
}
.header__inner{
  display:flex;
  align-items:center;
  justify-content:space-between;
  height:100%;
  max-width:var(--max-w);
  margin:0 auto;
  padding:0 var(--sp-6);
}
.header__logo{
  font-family:var(--font-display);
  font-size:1.35rem;
  font-weight:700;
  color:var(--text);
  letter-spacing:-.02em;
  transition:opacity var(--duration) var(--ease);
  white-space:nowrap;
}
.header__logo:hover{opacity:.7}

/* Navigation — mobile-first: hidden by default, shown on desktop */
.nav{
  position:fixed;
  top:0;right:0;bottom:0;
  width:min(320px, 85vw);
  height:100%;height:100dvh;
  background:var(--white, #fff);
  flex-direction:column;
  align-items:stretch;
  justify-content:flex-start;
  padding:calc(var(--header-h) + var(--sp-6)) var(--sp-6) var(--sp-8);
  gap:0;
  transform:translateX(100%);
  transition:transform .4s cubic-bezier(.4,.01,.165,.99);
  z-index:1200;
  box-shadow:-8px 0 32px rgba(0,0,0,.08);
  overflow-y:auto;
  -webkit-overflow-scrolling:touch;
  overscroll-behavior:contain;
  display:flex;
}
.nav.open{transform:translateX(0)}
.nav__link{
  font-size:1rem;
  font-weight:500;
  color:var(--text-body);
  padding:var(--sp-3) var(--sp-4);
  width:100%;
  border-radius:var(--radius-sm);
  transition:all .2s var(--ease);
  position:relative;
}
.nav__link:hover,
.nav__link:focus{background:var(--accent-light);color:var(--accent)}
.nav__link.active{background:var(--accent-light);color:var(--accent);font-weight:600}
.nav__link.active::after{display:none}

/* Page-hero pages: keep default dark text on light bg-alt background */

.nav__cta{
  display:inline-flex;
  align-items:center;
  gap:var(--sp-2);
  font-size:.95rem;
  font-weight:600;
  color:var(--white);
  background:var(--accent);
  padding:var(--sp-3) var(--sp-6);
  border-radius:var(--radius-sm);
  margin:var(--sp-4) var(--sp-4) 0;
  justify-content:center;
  width:calc(100% - var(--sp-8));
  transition:all var(--duration) var(--ease);
}
.nav__cta:hover{
  background:var(--accent-hover);
  color:var(--white);
  transform:translateY(-1px);
  box-shadow:var(--shadow-accent);
}
.nav__cta svg{width:16px;height:16px}

/* Nav divider (mobile sidebar) */
.nav__divider{
  display:block;
  height:1px;
  background:var(--border);
  margin:var(--sp-3) var(--sp-4);
}

/* Nav link stagger animation (mobile) */
.nav.open .nav__link,
.nav.open .nav__cta{
  animation:navSlideIn .3s var(--ease) both;
}
.nav.open .nav__link:nth-child(1){animation-delay:.05s}
.nav.open .nav__link:nth-child(2){animation-delay:.08s}
.nav.open .nav__link:nth-child(3){animation-delay:.11s}
.nav.open .nav__link:nth-child(4){animation-delay:.14s}
.nav.open .nav__link:nth-child(5){animation-delay:.17s}
.nav.open .nav__link:nth-child(6){animation-delay:.20s}
.nav.open .nav__link:nth-child(7){animation-delay:.23s}
.nav.open .nav__link:nth-child(8){animation-delay:.26s}
.nav.open .nav__link:nth-child(9){animation-delay:.29s}
.nav.open .nav__link:nth-child(10){animation-delay:.32s}
.nav.open .nav__link:nth-child(11){animation-delay:.35s}
.nav.open .nav__link:nth-child(12){animation-delay:.38s}
.nav.open .nav__link:nth-child(13){animation-delay:.41s}
.nav.open .nav__cta{animation-delay:.44s}
@keyframes navSlideIn{
  from{opacity:0;transform:translateX(16px)}
  to{opacity:1;transform:translateX(0)}
}

/* Hamburger */
.hamburger{
  display:flex;
  align-items:center;
  justify-content:center;
  width:48px;height:48px;
  padding:0;
  border-radius:var(--radius-sm);
  position:relative;
  z-index:1201;
  cursor:pointer;
  background:transparent;
  border:none;
  transition:background var(--duration) var(--ease);
  -webkit-tap-highlight-color:transparent;
  touch-action:manipulation;
  -webkit-appearance:none;
  appearance:none;
  user-select:none;
  -webkit-user-select:none;
}
.hamburger:hover{background:var(--accent-light)}
.hamburger .hamburger__lines{
  display:flex;flex-direction:column;gap:5px;
  width:22px;height:16px;
  position:relative;
}
.hamburger span{
  display:block;
  width:22px;height:2px;
  background:var(--text);
  border-radius:2px;
  transition:all .35s cubic-bezier(.4,.01,.165,.99);
  position:absolute;left:0;
}
.hamburger span:nth-child(1){top:0}
.hamburger span:nth-child(2){top:7px;width:16px}
.hamburger span:nth-child(3){top:14px}
.hamburger.active span:nth-child(1){top:7px;transform:rotate(45deg)}
.hamburger.active span:nth-child(2){opacity:0;width:0}
.hamburger.active span:nth-child(3){top:7px;transform:rotate(-45deg)}

/* Nav overlay backdrop */
.nav-overlay{
  position:fixed;
  top:0;left:0;right:0;bottom:0;
  width:100%;height:100%;
  background:rgba(26,26,31,.5);
  backdrop-filter:blur(4px);
  -webkit-backdrop-filter:blur(4px);
  z-index:1099;
  opacity:0;
  pointer-events:none;
  transition:opacity .35s var(--ease);
  -webkit-transform:translateZ(0);
  transform:translateZ(0);
}
.nav-overlay.visible{opacity:1;pointer-events:auto}

/* ---------- HERO ---------- */
.hero{
  padding:calc(var(--header-h) + var(--sp-20)) 0 var(--sp-20);
  min-height:90vh;
  display:flex;
  align-items:center;
  position:relative;
  overflow:hidden;
}
.hero::before{
  content:'';
  position:absolute;
  top:-20%;right:-10%;
  width:600px;height:600px;
  background:radial-gradient(circle,var(--accent-glow) 0%,transparent 70%);
  border-radius:50%;
  pointer-events:none;
  z-index:0;
}
.hero__inner{
  display:grid;
  grid-template-columns:1.1fr .9fr;
  gap:var(--sp-16);
  align-items:center;
  position:relative;
  z-index:1;
}
.hero__content{max-width:580px;position:relative;z-index:2}
.hero__badge{
  display:inline-flex;
  align-items:center;
  gap:var(--sp-2);
  font-size:.75rem;
  font-weight:600;
  letter-spacing:.1em;
  text-transform:uppercase;
  color:var(--accent);
  background:var(--accent-light);
  padding:var(--sp-2) var(--sp-4);
  border-radius:var(--radius-full);
  margin-bottom:var(--sp-6);
}
.hero__badge::before{
  content:'';
  width:6px;height:6px;
  background:var(--accent);
  border-radius:50%;
  animation:pulse 2s infinite;
}
@keyframes pulse{
  0%,100%{opacity:1;transform:scale(1)}
  50%{opacity:.5;transform:scale(1.5)}
}
.hero h1{margin-bottom:var(--sp-6)}
.hero__text{
  font-size:1.125rem;
  line-height:1.85;
  color:var(--text-body);
  margin-bottom:var(--sp-10);
  max-width:500px;
}
.hero__actions{display:flex;align-items:center;gap:var(--sp-4);flex-wrap:wrap}

.hero__image{position:relative;display:flex;justify-content:flex-end;z-index:1}
.hero__image img{
  width:100%;
  max-width:440px;
  border-radius:var(--radius-xl);
  object-fit:cover;
  aspect-ratio:3/4;
  box-shadow:var(--shadow-lg);
}
.hero__image::after{
  content:'';
  position:absolute;
  bottom:-14px;right:-14px;
  width:110px;height:110px;
  border:3px solid var(--accent);
  border-radius:var(--radius-xl);
  opacity:.12;
  z-index:-1;
}

/* Hero — micro text */
.hero__micro{
  display:block;
  font-size:.85rem;
  font-weight:500;
  letter-spacing:.32em;
  text-transform:uppercase;
  color:var(--text-muted);
  margin-bottom:var(--sp-4);
}

/* Hero — quote below hero grid */
.hero__quote{
  position:relative;
  font-family:var(--serif);
  font-style:italic;
  font-size:1.05rem;
  line-height:1.75;
  color:var(--text-body);
  text-align:center;
  margin:var(--sp-12) auto 0;
  padding:var(--sp-6) var(--sp-10);
  max-width:680px;
  background:var(--accent-light);
  border-radius:var(--radius);
  border-bottom:3px solid var(--accent);
}
.hero__quote::before{
  content:'\201C';
  position:absolute;
  top:-18px;left:50%;
  transform:translateX(-50%);
  font-family:var(--serif);
  font-size:4rem;
  font-style:normal;
  line-height:1;
  color:var(--accent);
  opacity:.3;
}

/* ---------- TEMAS SECTION ---------- */
.section__lead{
  font-size:1.05rem;
  line-height:1.8;
  color:var(--text-body);
  max-width:640px;
  margin:var(--sp-4) auto 0;
  text-align:center;
}
.temas__grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(280px,1fr));
  gap:var(--sp-6);
  margin-top:var(--sp-12);
}
.temas__item{
  display:flex;
  align-items:flex-start;
  gap:var(--sp-4);
  padding:var(--sp-6);
  background:var(--bg-card);
  border:1px solid var(--border);
  border-radius:var(--radius);
  transition:border-color var(--duration) var(--ease), box-shadow var(--duration) var(--ease);
}
.temas__item:hover{
  border-color:var(--accent-light);
  box-shadow:0 4px 20px rgba(107,45,62,.06);
}
.temas__icon{
  flex-shrink:0;
  width:44px;height:44px;
  display:flex;
  align-items:center;
  justify-content:center;
  background:var(--accent-light);
  border-radius:var(--radius-sm);
  color:var(--accent);
}
.temas__item h4{
  font-family:var(--sans);
  font-size:.95rem;
  font-weight:600;
  line-height:1.5;
  color:var(--text);
  margin:0;
}

/* ---------- BUTTONS ---------- */
.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:var(--sp-2);
  font-family:var(--font-sans);
  font-size:.875rem;
  font-weight:600;
  line-height:1;
  padding:var(--sp-4) var(--sp-8);
  border-radius:var(--radius-full);
  transition:all var(--duration) var(--ease);
  cursor:pointer;
  white-space:nowrap;
  border:none;
}
.btn--primary{
  background:var(--accent);
  color:var(--white);
}
.btn--primary:hover{
  background:var(--accent-hover);
  color:var(--white);
  transform:translateY(-2px);
  box-shadow:var(--shadow-accent);
}
.btn--outline{
  background:transparent;
  color:var(--accent);
  box-shadow:inset 0 0 0 1.5px var(--accent);
}
.btn--outline:hover{
  background:var(--accent);
  color:var(--white);
  transform:translateY(-2px);
}
.btn--ghost{
  background:transparent;
  color:var(--accent);
  padding:var(--sp-2) 0;
  gap:var(--sp-3);
}
.btn--ghost::after{
  content:'→';
  transition:transform var(--duration) var(--ease);
}
.btn--ghost:hover{color:var(--accent-hover)}
.btn--ghost:hover::after{transform:translateX(4px)}
.btn--white{background:var(--white);color:var(--accent)}
.btn--white:hover{background:rgba(255,255,255,.9);transform:translateY(-2px);box-shadow:var(--shadow-md)}
.btn--sm{font-size:.8rem;padding:var(--sp-3) var(--sp-5)}
.btn--lg{font-size:1rem;padding:var(--sp-5) var(--sp-10)}
.btn svg{width:18px;height:18px}

/* ---------- CARDS ---------- */
.card{
  background:var(--bg-card);
  border:1px solid var(--border);
  border-radius:var(--radius-lg);
  padding:var(--sp-8);
  transition:all var(--duration) var(--ease);
  position:relative;
  overflow:hidden;
}
.card::before{
  content:'';
  position:absolute;
  top:0;left:0;right:0;
  height:3px;
  background:var(--accent);
  transform:scaleX(0);
  transform-origin:left;
  transition:transform var(--duration) var(--ease);
}
.card:hover{
  border-color:var(--border-strong);
  box-shadow:var(--shadow-md);
  transform:translateY(-4px);
}
.card:hover::before{transform:scaleX(1)}
.card__icon{
  width:52px;height:52px;
  display:flex;align-items:center;justify-content:center;
  background:var(--accent-light);
  border-radius:var(--radius);
  margin-bottom:var(--sp-6);
  color:var(--accent);
  font-size:1.5rem;
}
.card__icon svg{width:24px;height:24px}
.card h3{margin-bottom:var(--sp-3)}
.card p{font-size:.925rem;color:var(--text-body);margin-bottom:var(--sp-4)}
.card .btn--ghost{font-size:.85rem}

/* Card com imagem */
.card--img{padding:0}
.card--img .card__img{
  width:100%;
  height:240px;
  object-fit:cover;
  border-radius:var(--radius-lg) var(--radius-lg) 0 0;
}
.card--img .card__body{padding:var(--sp-6)}
.card--img::before{display:none}


/* ---------- READINGS / LINKS ---------- */
.readings{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--sp-4)}
.reading-link{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:var(--sp-4);
  padding:var(--sp-5) var(--sp-6);
  background:var(--bg-card);
  border:1px solid var(--border);
  border-radius:var(--radius);
  transition:all var(--duration) var(--ease);
  color:var(--text);
  font-weight:500;
  font-size:.925rem;
}
.reading-link:hover{
  border-color:var(--accent);
  color:var(--accent);
  box-shadow:var(--shadow-sm);
  transform:translateX(4px);
}
.reading-link svg,.reading-link .arrow{
  width:20px;height:20px;
  color:var(--accent);
  flex-shrink:0;
  transition:transform var(--duration) var(--ease);
}
.reading-link:hover svg,.reading-link:hover .arrow{transform:translateX(4px)}

/* ---------- ABOUT PREVIEW ---------- */
.about-preview{
  display:grid;
  grid-template-columns:auto 1fr;
  gap:var(--sp-16);
  align-items:center;
}
.about-preview__image{
  position:relative;
}
.about-preview__image img{
  border-radius:var(--radius-xl);
  width:360px;
  height:auto;
  aspect-ratio:3/4;
  object-fit:cover;
  box-shadow:var(--shadow-md);
}
.about-preview__image::before{
  content:'';
  position:absolute;
  top:var(--sp-6);
  left:calc(-1 * var(--sp-4));
  width:100%;
  height:100%;
  border:2px solid var(--accent);
  border-radius:var(--radius-xl);
  opacity:.12;
  z-index:-1;
}
.about-preview__content h2{margin-bottom:var(--sp-6)}
.about-preview__content p{max-width:520px}

/* ---------- MAP ---------- */
.map-container{
  border-radius:var(--radius-lg);
  overflow:hidden;
  border:1px solid var(--border);
  box-shadow:var(--shadow-sm);
}
.map-container iframe{width:100%;height:380px;border:0}

/* ---------- LOCATION GRID ---------- */
.location-grid{
  display:grid;
  grid-template-columns:1fr 1.5fr;
  gap:var(--sp-12);
  align-items:start;
}
.location-info h3{margin-bottom:var(--sp-4);font-size:1.25rem}
.location-info p{font-size:.925rem;line-height:1.8;margin-bottom:var(--sp-6)}

/* ---------- PAGE HEADER (internas) ---------- */
.page-hero{
  padding:calc(var(--header-h) + var(--sp-16)) 0 var(--sp-16);
  background:var(--bg-alt);
  border-bottom:1px solid var(--border);
  position:relative;
  overflow:hidden;
}
.page-hero::before{
  content:'';
  position:absolute;
  top:-30%;right:-5%;
  width:400px;height:400px;
  background:radial-gradient(circle,var(--accent-glow) 0%,transparent 70%);
  border-radius:50%;
  pointer-events:none;
}
.page-hero .container{position:relative;z-index:1}
.page-hero__grid{
  display:grid;
  grid-template-columns:1fr auto;
  gap:var(--sp-12);
  align-items:center;
}
.page-hero h1{margin-bottom:var(--sp-4)}
.page-hero .lead{max-width:640px;margin-bottom:0}
.page-hero__image img{
  width:280px;height:350px;
  object-fit:cover;
  border-radius:var(--radius-xl);
  box-shadow:var(--shadow-md);
}

/* ---------- PAGE CONTENT ---------- */
.page-content{padding:var(--sp-24) 0}
.page-content .container{max-width:var(--max-w-narrow)}
.page-content h2{
  margin-top:var(--sp-16);
  margin-bottom:var(--sp-4);
  padding-bottom:var(--sp-3);
  border-bottom:1px solid var(--border);
}
.page-content h3{margin-top:var(--sp-10);margin-bottom:var(--sp-3)}
.page-content ul{margin:var(--sp-4) 0;padding-left:0}
.page-content ul li{
  position:relative;
  padding-left:var(--sp-6);
  margin-bottom:var(--sp-3);
  color:var(--text-body);
  font-size:.925rem;
  line-height:1.7;
}
.page-content ul li::before{
  content:'';
  position:absolute;
  left:0;top:.65rem;
  width:6px;height:6px;
  background:var(--accent);
  border-radius:50%;
}

/* ========== Atuação profissional ========== */
.atuacao__grid{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(300px,1fr));
  gap:var(--sp-6);
  margin-top:var(--sp-8);
}
.atuacao__card{
  background:rgba(255,255,255,.05);
  border:1px solid rgba(255,255,255,.08);
  border-radius:var(--radius);
  padding:var(--sp-8) var(--sp-6);
  display:flex;
  flex-direction:column;
  transition:border-color .3s ease,transform .3s ease;
}
.atuacao__card:hover{
  border-color:rgba(255,255,255,.2);
  transform:translateY(-4px);
}
.atuacao__card h3{
  color:#fff;
  font-size:1.35rem;
  margin-bottom:var(--sp-3);
}
.atuacao__card p{
  color:rgba(255,255,255,.6);
  font-size:.9rem;
  line-height:1.7;
  flex:1;
  margin-bottom:var(--sp-4);
}
.atuacao__link{
  display:inline-block;
  font-size:.85rem;
  font-weight:500;
  color:var(--accent-light-tone,#d4a0b0);
  text-decoration:none;
  transition:color .3s ease;
}
.atuacao__link:hover{color:#fff}

/* Container narrow */
.container--narrow{max-width:800px;margin-inline:auto}

/* ========== FAQ ========== */
.faq{display:flex;flex-direction:column;gap:var(--sp-3);counter-reset:faq-counter}

.faq__item{
  background:var(--bg-card);
  border:1px solid var(--border);
  border-radius:var(--radius);
  overflow:hidden;
  transition:border-color .3s ease,box-shadow .3s ease,background .3s ease;
  counter-increment:faq-counter;
}
.faq__item:hover{border-color:var(--accent)}
.faq__item[open]{
  border-color:var(--accent);
  box-shadow:0 4px 20px rgba(107,45,62,.08);
}

.faq__question{
  display:flex;
  align-items:center;
  gap:var(--sp-4);
  padding:var(--sp-5) var(--sp-6);
  font-family:var(--sans);
  font-size:1rem;
  font-weight:600;
  color:var(--text-heading);
  cursor:pointer;
  list-style:none;
  user-select:none;
  transition:color .3s ease;
}
.faq__question::-webkit-details-marker{display:none}
.faq__question::marker{display:none;content:''}

/* Number badge */
.faq__question::before{
  content:counter(faq-counter,decimal-leading-zero);
  flex-shrink:0;
  display:flex;
  align-items:center;
  justify-content:center;
  width:32px;height:32px;
  border-radius:50%;
  background:var(--accent-light);
  color:var(--accent);
  font-size:.75rem;
  font-weight:700;
  letter-spacing:.02em;
  transition:background .3s ease,color .3s ease;
}
.faq__item[open] .faq__question::before{
  background:var(--accent);
  color:#fff;
}

/* Chevron icon */
.faq__question::after{
  content:'';
  flex-shrink:0;
  width:20px;height:20px;
  margin-left:auto;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='20' height='20' viewBox='0 0 24 24' fill='none' stroke='%236B2D3E' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");
  background-repeat:no-repeat;
  background-position:center;
  transition:transform .3s ease;
}
.faq__item[open] .faq__question::after{transform:rotate(180deg)}
.faq__item[open] .faq__question{color:var(--accent)}

.faq__answer{
  padding:0 var(--sp-6) var(--sp-6);
  padding-left:calc(var(--sp-6) + 32px + var(--sp-4));
  font-size:.9rem;
  line-height:1.8;
  color:var(--text-body);
}
.faq__answer p{margin-bottom:var(--sp-3)}
.faq__answer p:last-child{margin-bottom:0}

/* CTA Block (internas) */
.cta-block{
  margin-top:var(--sp-16);
  padding:var(--sp-12);
  background:var(--bg-dark);
  color:var(--text-inverse);
  border-radius:var(--radius-xl);
  text-align:center;
}
.cta-block h3{color:var(--text-inverse);margin:0 0 var(--sp-3);font-size:1.5rem}
.cta-block p{color:rgba(255,255,255,.65);margin-bottom:var(--sp-6);max-width:480px;margin-left:auto;margin-right:auto}


/* ---------- BREADCRUMB ---------- */
.breadcrumb{
  font-size:.8rem;
  color:var(--text-muted);
  margin-bottom:var(--sp-6);
  display:flex;
  align-items:center;
  gap:var(--sp-2);
}
.breadcrumb a{color:var(--text-muted);transition:color var(--duration) var(--ease)}
.breadcrumb a:hover{color:var(--accent)}
.breadcrumb .sep{color:var(--text-muted);opacity:.4}

/* ---------- CROSS LINKS ---------- */
.cross-links{
  margin-top:var(--sp-16);
  padding:var(--sp-10);
  background:var(--bg-alt);
  border-radius:var(--radius-lg);
}
.cross-links h3{margin:0 0 var(--sp-6)}
.cross-links__grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--sp-3)}
.cross-links__item{
  display:flex;
  align-items:center;
  gap:var(--sp-3);
  color:var(--accent);
  font-weight:500;
  font-size:.9rem;
  padding:var(--sp-3) var(--sp-4);
  border-radius:var(--radius-sm);
  transition:all var(--duration) var(--ease);
}
.cross-links__item:hover{background:var(--accent-light)}
.cross-links__item::before{content:'→';font-size:.75rem}

/* ---------- MISTAKES ---------- */
.mistakes{
  margin-top:var(--sp-10);
  padding:var(--sp-8);
  background:linear-gradient(135deg,#FFF8F0,#FFF5E8);
  border-left:3px solid #D4880F;
  border-radius:0 var(--radius) var(--radius) 0;
}
.mistakes h3{margin:0 0 var(--sp-4);color:#8B5E0F;font-size:1.1rem}
.mistakes ul{padding-left:0}
.mistakes li{color:var(--text-body);margin-bottom:var(--sp-2)}
.mistakes li::before{background:#D4880F}

/* ---------- AUTHOR SIGNATURE ---------- */
.author-signature{
  margin-top:var(--sp-10);
  padding-top:var(--sp-6);
  border-top:1px solid var(--border);
  font-size:.85rem;
  color:var(--text-muted);
  font-style:italic;
}

/* ---------- CONTACT ---------- */
.contact-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:var(--sp-12);
  align-items:start;
}
.contact-info{display:flex;flex-direction:column;gap:var(--sp-8)}
.contact-item{display:flex;gap:var(--sp-4);align-items:flex-start}
.contact-item__icon{
  width:40px;height:40px;
  display:flex;align-items:center;justify-content:center;
  background:var(--accent-light);
  border-radius:var(--radius-sm);
  color:var(--accent);
  flex-shrink:0;
}
.contact-item__icon svg{width:20px;height:20px}
.contact-item p{margin:0;font-size:.925rem}
.contact-item strong{display:block;color:var(--text);margin-bottom:var(--sp-1)}

/* ---------- CATEGORIES ---------- */
.categories{display:flex;flex-wrap:wrap;gap:var(--sp-2);margin:var(--sp-6) 0}
.category-tag{
  display:inline-block;
  padding:var(--sp-2) var(--sp-5);
  background:var(--accent-light);
  color:var(--accent);
  font-size:.8rem;
  font-weight:600;
  border-radius:var(--radius-full);
  transition:all var(--duration) var(--ease);
}
.category-tag:hover{background:var(--accent);color:var(--white)}

/* ---------- FOOTER ---------- */
.footer{
  background:var(--bg-dark);
  color:rgba(255,255,255,.6);
  padding:var(--sp-24) 0 var(--sp-8);
}
.footer a{color:rgba(255,255,255,.6);transition:color var(--duration) var(--ease)}
.footer a:hover{color:var(--white)}
.footer__grid{
  display:grid;
  grid-template-columns:1.5fr 1fr 1fr 1fr;
  gap:var(--sp-12);
  margin-bottom:var(--sp-16);
}
.footer__brand{
  padding-right:var(--sp-8);
}
.footer__brand h3{
  font-family:var(--font-display);
  font-size:1.5rem;
  color:var(--white);
  margin-bottom:var(--sp-4);
}
.footer__brand p{font-size:.875rem;line-height:1.75;color:rgba(255,255,255,.5)}
.footer__col h4{
  font-family:var(--font-sans);
  font-size:.7rem;
  font-weight:700;
  letter-spacing:.15em;
  text-transform:uppercase;
  color:rgba(255,255,255,.3);
  margin-bottom:var(--sp-6);
}
.footer__col ul li{margin-bottom:var(--sp-3)}
.footer__col ul li a{font-size:.875rem}

.footer__neurallex{
  margin-top:var(--sp-8);
  padding-top:var(--sp-6);
  border-top:1px solid rgba(255,255,255,.08);
  display:flex;
  align-items:center;
  gap:var(--sp-3);
}
.footer__neurallex img{width:28px;height:28px;filter:brightness(0) invert(1);opacity:.6}
.footer__neurallex p{font-size:.8rem;color:rgba(255,255,255,.4);margin:0}

.footer__bottom{
  border-top:1px solid rgba(255,255,255,.06);
  padding-top:var(--sp-8);
  display:flex;
  justify-content:space-between;
  align-items:center;
  font-size:.8rem;
  color:rgba(255,255,255,.25);
}

/* ---------- PARA QUEM TRABALHO ---------- */
.paraquem__grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:var(--sp-6);
  margin-top:var(--sp-10);
}
.paraquem__card{
  background:var(--bg-card);
  border:1px solid var(--border);
  border-radius:var(--radius-lg);
  padding:var(--sp-8) var(--sp-6);
  text-align:center;
  transition:all var(--duration) var(--ease);
}
.paraquem__card:hover{
  transform:translateY(-4px);
  box-shadow:var(--shadow-md);
  border-color:var(--accent-light);
}
.paraquem__icon{
  width:56px;height:56px;
  background:var(--accent-light);
  border-radius:var(--radius);
  display:flex;align-items:center;justify-content:center;
  margin:0 auto var(--sp-5);
  color:var(--accent);
}
.paraquem__card h3{
  font-family:var(--font-display);
  font-size:1.15rem;
  font-weight:600;
  margin-bottom:var(--sp-3);
  color:var(--text);
}
.paraquem__card p{
  font-size:.92rem;
  line-height:1.7;
  color:var(--text-body);
}

/* ---------- ARTIGOS GRID (CARDS) ---------- */
.artigos__grid{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:var(--sp-6);
  margin-top:var(--sp-10);
}
.artigo__card{
  display:flex;
  flex-direction:column;
  background:var(--bg-card);
  border:1px solid var(--border);
  border-radius:var(--radius-lg);
  padding:var(--sp-6);
  text-decoration:none;
  transition:all var(--duration) var(--ease);
}
.artigo__card:hover{
  transform:translateY(-4px);
  box-shadow:var(--shadow-md);
  border-color:var(--accent);
}
.artigo__tag{
  display:inline-block;
  font-size:.72rem;
  font-weight:600;
  text-transform:uppercase;
  letter-spacing:.08em;
  color:var(--accent);
  background:var(--accent-light);
  padding:var(--sp-1) var(--sp-3);
  border-radius:var(--radius-full);
  margin-bottom:var(--sp-4);
  width:fit-content;
}
.artigo__card h3{
  font-family:var(--font-display);
  font-size:1.1rem;
  font-weight:600;
  color:var(--text);
  margin-bottom:var(--sp-3);
  line-height:1.4;
}
.artigo__card p{
  font-size:.9rem;
  line-height:1.7;
  color:var(--text-body);
  flex:1;
}
.artigo__cta{
  font-size:.85rem;
  font-weight:600;
  color:var(--accent);
  margin-top:var(--sp-4);
}

/* ---------- BADGE AUTHORITY ---------- */
.badge--authority{
  display:inline-block;
  font-size:.78rem;
  font-weight:600;
  text-transform:uppercase;
  letter-spacing:.1em;
  color:var(--accent);
  background:var(--accent-light);
  padding:var(--sp-2) var(--sp-5);
  border-radius:var(--radius-full);
  margin-bottom:var(--sp-4);
  border:1px solid rgba(107,45,62,.15);
}

/* ---------- MIGALHAS ---------- */
.migalhas__grid{
  display:grid;
  grid-template-columns:1fr;
  gap:0;
  margin-top:var(--sp-8);
}
.migalhas__link{
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:var(--sp-4) var(--sp-5);
  text-decoration:none;
  color:var(--text);
  border-bottom:1px solid var(--border);
  transition:all var(--duration) var(--ease);
  font-size:.95rem;
  line-height:1.5;
}
.migalhas__link:first-child{
  border-top:1px solid var(--border);
}
.migalhas__link:hover{
  background:var(--accent-light);
  color:var(--accent);
  padding-left:var(--sp-6);
}
.migalhas__link .arrow{
  flex-shrink:0;
  margin-left:var(--sp-4);
  font-size:1.1rem;
  color:var(--text-muted);
  transition:color var(--duration) var(--ease);
}
.migalhas__link:hover .arrow{
  color:var(--accent);
}

/* ---------- LIVROS ---------- */
.livros__grid{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:var(--sp-8);
  margin-top:var(--sp-10);
}
.livro__card{
  display:flex;
  gap:var(--sp-6);
  background:var(--bg-card);
  border:1px solid var(--border);
  border-radius:var(--radius-lg);
  padding:var(--sp-6);
  transition:all var(--duration) var(--ease);
}
.livro__card:hover{
  box-shadow:var(--shadow-md);
  transform:translateY(-2px);
}
.livro__cover{
  flex-shrink:0;
  width:120px;
}
.livro__cover img{
  width:100%;
  height:auto;
  border-radius:var(--radius-sm);
  box-shadow:var(--shadow-sm);
}
.livro__info{
  display:flex;
  flex-direction:column;
}
.livro__info h3{
  font-family:var(--font-display);
  font-size:1.05rem;
  font-weight:600;
  color:var(--text);
  margin-bottom:var(--sp-2);
}
.livro__info p{
  font-size:.88rem;
  line-height:1.65;
  color:var(--text-body);
  flex:1;
  margin-bottom:var(--sp-4);
}
.btn--sm{
  font-size:.82rem;
  padding:var(--sp-2) var(--sp-4);
  width:fit-content;
}

/* ---------- MIGALHAS LOGO & FOOTER LEGAL ---------- */
.migalhas__logo{
  display:block;
  margin:0 auto var(--sp-6);
  border-radius:var(--radius-lg);
  object-fit:cover;
  box-shadow:var(--shadow-sm);
}
.footer__legal{
  display:flex;
  align-items:center;
  gap:var(--sp-3);
  font-size:.85rem;
}
.footer__legal a{
  color:rgba(255,255,255,.5);
  text-decoration:none;
  transition:color .2s var(--ease);
}
.footer__legal a:hover{color:rgba(255,255,255,.85)}
.footer__legal span{color:rgba(255,255,255,.25)}

/* ---------- MIGALHAS PAGE ---------- */
.migalhas-list{
  display:flex;
  flex-direction:column;
  gap:var(--sp-3);
  max-width:860px;
  margin:0 auto;
}
.migalhas-card{
  display:flex;
  align-items:center;
  gap:var(--sp-5);
  padding:var(--sp-5) var(--sp-6);
  background:var(--bg-card);
  border:1px solid var(--border);
  border-radius:var(--radius);
  text-decoration:none;
  color:var(--text);
  transition:all .3s var(--ease);
}
.migalhas-card:hover{
  border-color:var(--accent);
  box-shadow:var(--shadow-sm);
  transform:translateY(-2px);
}
.migalhas-card__num{
  flex-shrink:0;
  display:flex;
  align-items:center;
  justify-content:center;
  width:40px;height:40px;
  border-radius:50%;
  background:var(--accent-light);
  color:var(--accent);
  font-size:.75rem;
  font-weight:700;
  font-family:var(--sans);
  letter-spacing:.02em;
  transition:background .3s ease,color .3s ease;
}
.migalhas-card:hover .migalhas-card__num{
  background:var(--accent);
  color:#fff;
}
.migalhas-card__body{
  flex:1;
  min-width:0;
}
.migalhas-card__title{
  font-family:var(--sans);
  font-size:.95rem;
  font-weight:600;
  line-height:1.5;
  color:var(--text-heading);
  margin:0 0 var(--sp-2) 0;
}
.migalhas-card__tag{
  display:inline-block;
  font-size:.7rem;
  font-weight:500;
  text-transform:uppercase;
  letter-spacing:.06em;
  color:var(--accent);
  background:var(--accent-light);
  padding:.15rem .5rem;
  border-radius:4px;
}
.migalhas-card__arrow{
  flex-shrink:0;
  width:20px;height:20px;
  color:var(--text-muted);
  transition:color .3s ease,transform .3s ease;
}
.migalhas-card:hover .migalhas-card__arrow{
  color:var(--accent);
  transform:translate(2px,-2px);
}
@media(max-width:768px){
  .migalhas-card{padding:var(--sp-4);gap:var(--sp-3)}
  .migalhas-card__num{width:32px;height:32px;font-size:.65rem}
  .migalhas-card__title{font-size:.88rem}
}

/* Legacy migalhas-page classes (kept for compatibility) */
.migalhas-page__grid{
  display:grid;
  grid-template-columns:1fr;
  gap:var(--sp-3);
  max-width:800px;
  margin:0 auto;
}
.migalhas-page__link{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:var(--sp-4);
  padding:var(--sp-5) var(--sp-6);
  background:var(--bg);
  border:1px solid var(--border);
  border-radius:var(--radius-md);
  text-decoration:none;
  color:var(--text);
  transition:all .25s var(--ease);
}
.migalhas-page__link:hover{
  border-color:var(--accent);
  box-shadow:var(--shadow-sm);
  transform:translateX(4px);
}
.migalhas-page__link span:first-child{
  font-size:.95rem;
  font-weight:500;
  line-height:1.5;
}
.migalhas-page__link .arrow{
  flex-shrink:0;
  color:var(--accent);
  font-size:1.1rem;
}

/* ---------- LEGAL PAGES ---------- */
.legal-page{
  max-width:800px;
  margin:0 auto;
  padding:120px 24px 80px;
}
.legal-page h1{
  font-family:var(--font-display);
  font-size:2rem;
  margin-bottom:var(--sp-2);
  color:var(--text-heading);
}
.legal-page .legal-date{
  font-size:.85rem;
  color:var(--text-muted);
  margin-bottom:var(--sp-10);
}
.legal-page h2{
  font-family:var(--font-display);
  font-size:1.3rem;
  margin-top:var(--sp-10);
  margin-bottom:var(--sp-4);
  color:var(--text-heading);
}
.legal-page p{
  font-size:1rem;
  line-height:1.85;
  color:var(--text-body);
  margin-bottom:var(--sp-4);
}
.legal-page ul{
  margin-bottom:var(--sp-4);
  padding-left:var(--sp-6);
}
.legal-page li{
  font-size:1rem;
  line-height:1.85;
  color:var(--text-body);
  margin-bottom:var(--sp-2);
}
@media(max-width:768px){
  .legal-page{padding:100px 20px 60px}
  .footer__legal{flex-wrap:wrap;justify-content:center}
}

/* ---------- FAQ DARK VARIANT ---------- */
.faq--dark .faq__item{
  background:rgba(255,255,255,.04);
  border-color:rgba(255,255,255,.12);
  backdrop-filter:blur(4px);
}
.faq--dark .faq__item:hover{
  border-color:rgba(255,255,255,.25);
  background:rgba(255,255,255,.07);
}
.faq--dark .faq__question{
  color:rgba(255,255,255,.92);
}
.faq--dark .faq__question:hover{
  color:#fff;
}
.faq--dark .faq__question::before{
  background:rgba(255,255,255,.1);
  color:rgba(255,255,255,.7);
}
.faq--dark .faq__item[open] .faq__question::before{
  background:rgba(255,255,255,.2);
  color:#fff;
}
.faq--dark .faq__question::after{
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='20' height='20' viewBox='0 0 24 24' fill='none' stroke='rgba(255,255,255,0.5)' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");
}
.faq--dark .faq__item[open] .faq__question::after{
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='20' height='20' viewBox='0 0 24 24' fill='none' stroke='%23fff' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");
}
.faq--dark .faq__answer{
  padding:0 var(--sp-6) var(--sp-6);
  padding-left:calc(var(--sp-6) + 32px + var(--sp-4));
  border-top:1px solid rgba(255,255,255,.08);
  margin-top:0;
  padding-top:var(--sp-4);
}
.faq--dark .faq__answer p{
  color:rgba(255,255,255,.8);
  line-height:1.9;
}
.faq--dark .faq__item[open]{
  border-color:rgba(255,255,255,.3);
  background:rgba(255,255,255,.08);
  box-shadow:0 4px 24px rgba(0,0,0,.2);
}
.faq--dark .faq__item[open] .faq__question{
  color:#fff;
  padding-bottom:var(--sp-3);
}

/* ---------- WHATSAPP FAB ---------- */
.whatsapp-fab{
  position:fixed;
  bottom:28px;right:28px;
  z-index:999;
  width:56px;height:56px;
  background:var(--green);
  border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 4px 20px rgba(37,211,102,.35);
  transition:all var(--duration) var(--ease);
}
.whatsapp-fab:hover{
  transform:scale(1.1) translateY(-2px);
  box-shadow:0 8px 32px rgba(37,211,102,.45);
}
.whatsapp-fab svg{width:28px;height:28px;fill:#fff}

/* ---------- ANIMATIONS ---------- */
.fade-in{
  opacity:0;
  transform:translateY(24px);
  transition:opacity .7s var(--ease),transform .7s var(--ease);
}
.fade-in.visible{opacity:1;transform:translateY(0)}
.fade-in-left{
  opacity:0;
  transform:translateX(-24px);
  transition:opacity .7s var(--ease),transform .7s var(--ease);
}
.fade-in-left.visible{opacity:1;transform:translateX(0)}
.fade-in-right{
  opacity:0;
  transform:translateX(24px);
  transition:opacity .7s var(--ease),transform .7s var(--ease);
}
.fade-in-right.visible{opacity:1;transform:translateX(0)}
@media(prefers-reduced-motion:reduce){
  .fade-in,.fade-in-left,.fade-in-right{opacity:1;transform:none;transition:none}
}

/* ---------- ARTICLE PAGES ---------- */
.article-page{max-width:800px;margin:0 auto;padding:120px 24px 80px}
.article-page h1{font-family:var(--font-display);font-size:2.2rem;margin-bottom:var(--sp-6);color:var(--text-heading);line-height:1.25}
.article-page h2{font-family:var(--font-display);font-size:1.5rem;margin-top:var(--sp-12);margin-bottom:var(--sp-4);color:var(--text-heading)}
.article-page h3{font-family:var(--font-display);font-size:1.2rem;margin-top:var(--sp-8);margin-bottom:var(--sp-3);color:var(--text-heading)}
.article-page p{font-size:1.05rem;line-height:1.85;color:var(--text-body);margin-bottom:var(--sp-5)}
.article-page ul,.article-page ol{margin-bottom:var(--sp-5);padding-left:var(--sp-6)}
.article-page li{font-size:1.05rem;line-height:1.85;color:var(--text-body);margin-bottom:var(--sp-2)}
.article-page strong{color:var(--text-heading)}
.article-back{display:inline-block;margin-bottom:var(--sp-8);color:var(--accent);font-weight:500;text-decoration:none;font-size:.95rem}
.article-back:hover{text-decoration:underline}
.article-meta{font-size:.9rem;color:var(--text-muted);margin-bottom:var(--sp-8);padding-bottom:var(--sp-6);border-bottom:1px solid var(--border)}
.article-cta{background:var(--accent);color:var(--text-inverse);padding:var(--sp-12);border-radius:var(--radius-lg);text-align:center;margin-top:var(--sp-16)}
.article-cta h3{color:var(--text-inverse);font-family:var(--font-display);margin-bottom:var(--sp-4);font-size:1.3rem}
.article-cta p{color:rgba(255,255,255,.85);margin-bottom:var(--sp-4)}
.article-cta a{display:inline-block;background:var(--bg);color:var(--accent);padding:var(--sp-4) var(--sp-8);border-radius:var(--radius-md);text-decoration:none;font-weight:600;transition:transform .2s var(--ease)}
.article-cta a:hover{transform:translateY(-2px)}
.article-related{margin-top:var(--sp-12);padding-top:var(--sp-8);border-top:1px solid var(--border)}
.article-related h3{margin-bottom:var(--sp-4);font-family:var(--font-display)}
.article-related a{display:block;color:var(--accent);padding:var(--sp-2) 0;text-decoration:none;font-weight:500;font-size:1rem}
.article-related a:hover{text-decoration:underline}
@media(max-width:768px){
  .article-page{padding:100px 20px 60px}
  .article-page h1{font-size:1.75rem}
  .article-cta{padding:var(--sp-8)}
}

/* ---------- UTILITY ---------- */
.text-center{text-align:center}
.text-accent{color:var(--accent)}
.mt-0{margin-top:0}
.mb-0{margin-bottom:0}
.gap-4{gap:var(--sp-4)}
.gap-6{gap:var(--sp-6)}

/* ---------- DESKTOP NAV (≥1025px) ---------- */
@media(min-width:1025px){
  .nav{
    position:static;
    width:auto;
    height:auto;
    background:transparent;
    flex-direction:row;
    align-items:center;
    justify-content:flex-end;
    padding:0;
    gap:var(--sp-1);
    transform:none;
    transition:none;
    z-index:auto;
    box-shadow:none;
    overflow:visible;
    overscroll-behavior:auto;
  }
  .nav__link{
    font-size:.82rem;
    padding:var(--sp-2) var(--sp-3);
    width:auto;
    white-space:nowrap;
  }
  .nav__link:hover,
  .nav__link:focus{background:transparent;color:var(--accent)}
  .nav__link.active{background:transparent}
  .nav__link.active::after{
    display:block;
    content:'';
    position:absolute;
    bottom:2px;
    left:var(--sp-3);
    right:var(--sp-3);
    height:2px;
    background:var(--accent);
    border-radius:1px;
  }
  .nav__cta{
    font-size:.82rem;
    padding:var(--sp-2) var(--sp-5);
    border-radius:var(--radius-full);
    margin:0 0 0 var(--sp-4);
    width:auto;
    justify-content:flex-start;
  }
  .hamburger{display:none}
  .nav__divider{display:none}
  .nav.open .nav__link,
  .nav.open .nav__cta{animation:none}
}

/* ---------- RESPONSIVE ---------- */
@media(max-width:1024px){
  .grid--4{grid-template-columns:repeat(2,1fr)}
  .footer__grid{grid-template-columns:1fr 1fr}
  .hero__inner{grid-template-columns:1fr;gap:var(--sp-10)}
  .hero__image{justify-content:center}
  .hero__image img{max-width:360px}
  .about-preview{grid-template-columns:1fr;gap:var(--sp-10)}
  .about-preview__image{text-align:center}
  .about-preview__image img{width:300px;margin:0 auto}
  .location-grid{grid-template-columns:1fr}
  .page-hero__grid{grid-template-columns:1fr}
  .page-hero__image{display:none}
  .paraquem__grid{grid-template-columns:repeat(2,1fr)}
  .livros__grid{grid-template-columns:1fr}
  .livro__card{flex-direction:column;align-items:center;text-align:center}
  .livro__cover{width:140px}
}

/* Mobile nav styles are now in the default (mobile-first) rules above */

@media(max-width:768px){
  :root{--header-h:64px}

  .section{padding:var(--sp-16) 0}

  /* Hero */
  .hero{min-height:auto;padding-top:calc(var(--header-h) + var(--sp-12))}
  .hero__inner{text-align:center}
  .hero__content{max-width:100%;margin:0 auto}
  .hero__text{max-width:100%;margin-left:auto;margin-right:auto}
  .hero__actions{justify-content:center}
  .hero__image{order:-1;justify-content:center}
  .hero__image img{max-width:280px}
  .hero__image::after{display:none}
  .hero::before{width:300px;height:300px;right:-20%;top:-10%}
  .hero__micro{text-align:center}
  .hero__quote{padding:var(--sp-5) var(--sp-6);font-size:.95rem}
  .temas__grid{grid-template-columns:1fr}
  .atuacao__grid{grid-template-columns:1fr}
  .paraquem__grid{grid-template-columns:1fr}
  .artigos__grid{grid-template-columns:1fr}
  .livros__grid{grid-template-columns:1fr}
  .migalhas__link{font-size:.95rem}

  /* Grids */
  .grid--2,.grid--3{grid-template-columns:1fr}
  .readings{grid-template-columns:1fr}
  .contact-grid{grid-template-columns:1fr}
  .cross-links__grid{grid-template-columns:1fr}

  /* Footer */
  .footer__grid{grid-template-columns:1fr;gap:var(--sp-10)}
  .footer__bottom{flex-direction:column;gap:var(--sp-2);text-align:center}

  /* Misc */
  .about-preview__image::before{display:none}
}

@media(max-width:480px){
  .grid--4{grid-template-columns:1fr}
  h1{font-size:clamp(1.75rem,8vw,2.5rem)}
}


/* ---------- COMO TRABALHO COM IA SECTION ---------- */
.como-ia__grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--sp-6);
  margin-bottom: var(--sp-8);
}

.como-ia__card {
  background: var(--bg-card);
  border-radius: var(--radius);
  padding: var(--sp-8) var(--sp-6);
  text-align: center;
  box-shadow: var(--shadow-sm);
  transition: transform .25s ease, box-shadow .25s ease;
}

.como-ia__card:hover {
  transform: translateY(-4px);
  box-shadow: var(--shadow-md);
}

.como-ia__icon {
  width: 56px;
  height: 56px;
  margin: 0 auto var(--sp-4);
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--accent-light);
  border-radius: 50%;
  color: var(--accent);
}

.como-ia__card h3 {
  font-family: var(--font-sans);
  font-size: 1.05rem;
  font-weight: 600;
  margin-bottom: var(--sp-3);
  color: var(--text);
}

.como-ia__card p {
  font-size: .92rem;
  line-height: 1.65;
  color: var(--text-body);
}

.como-ia__tags {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: var(--sp-3);
}

.como-ia__tag {
  font-size: .85rem;
  font-weight: 500;
  color: var(--accent);
  background: var(--accent-light);
  padding: var(--sp-2) var(--sp-5);
  border-radius: var(--radius-full);
}

@media (max-width: 1024px) {
  .como-ia__grid { grid-template-columns: repeat(2, 1fr); }
}

@media (max-width: 768px) {
  .como-ia__grid { grid-template-columns: 1fr; }
}

/* ---------- HERO NAME FIX ---------- */
.hero h1 {
  overflow-wrap: break-word;
  word-wrap: break-word;
}

/* ============================================
   SUBPAGE MODERN REDESIGN 2026
   ============================================ */

/* ---------- PAGE HERO (enhanced) ---------- */
.page-hero{
  position:relative;
  padding:calc(var(--header-h) + var(--sp-20)) 0 var(--sp-16);
  background:var(--bg-dark);
  color:var(--text-inverse);
  text-align:center;
  overflow:hidden;
}
.page-hero::before{
  content:'';
  position:absolute;inset:0;
  background:radial-gradient(ellipse 70% 50% at 50% 0%,rgba(107,45,62,.25),transparent 70%);
  pointer-events:none;
}
.page-hero .container{position:relative;z-index:1}
.page-hero .overline{
  display:inline-block;
  font-family:var(--font-sans);
  font-size:.8rem;
  font-weight:600;
  letter-spacing:.12em;
  text-transform:uppercase;
  color:rgba(255,255,255,.5);
  margin-bottom:var(--sp-4);
}
.page-hero h1{
  font-family:var(--font-display);
  font-size:clamp(2rem,4.5vw,3.25rem);
  font-weight:700;
  color:#fff;
  margin-bottom:var(--sp-5);
  line-height:1.2;
}
.page-hero .lead{
  font-size:1.12rem;
  line-height:1.75;
  color:rgba(255,255,255,.7);
  max-width:640px;
  margin:0 auto;
}

/* ---------- BREADCRUMB ---------- */
.breadcrumb{
  display:flex;
  align-items:center;
  gap:var(--sp-2);
  margin-bottom:var(--sp-5);
  justify-content:center;
}
.breadcrumb a,.breadcrumb span{
  font-size:.82rem;
  color:rgba(255,255,255,.4);
  text-decoration:none;
  transition:color .2s;
}
.breadcrumb a:hover{color:rgba(255,255,255,.8)}
.breadcrumb .sep{font-size:.7rem}

/* ---------- PROSE SECTION ---------- */
.sp-section{padding:var(--sp-16) 0}
.sp-section--alt{background:var(--bg-alt)}
.sp-section--dark{background:var(--bg-dark);color:var(--text-inverse)}
.sp-prose{max-width:720px;margin:0 auto}
.sp-prose p{
  font-size:1.05rem;
  line-height:1.85;
  color:var(--text-body);
  margin-bottom:var(--sp-5);
}
.sp-prose p:last-child{margin-bottom:0}
.sp-section--dark .sp-prose p{color:rgba(255,255,255,.7)}

/* ---------- ARTICLE PROSE ---------- */
.sp-article{max-width:760px;margin:0 auto}
.sp-article h2{
  font-family:var(--font-display);
  font-size:1.55rem;
  color:var(--text);
  margin-top:var(--sp-12);
  margin-bottom:var(--sp-5);
  padding-bottom:var(--sp-3);
  border-bottom:2px solid var(--accent-light);
}
.sp-article h2:first-child{margin-top:0}
.sp-article h3{
  font-family:var(--font-display);
  font-size:1.2rem;
  color:var(--text);
  margin-top:var(--sp-8);
  margin-bottom:var(--sp-4);
}
.sp-article p{
  font-size:1.05rem;
  line-height:1.9;
  color:var(--text-body);
  margin-bottom:var(--sp-5);
}
.sp-article ul,.sp-article ol{
  margin-bottom:var(--sp-6);
  padding-left:var(--sp-6);
}
.sp-article li{
  font-size:1.05rem;
  line-height:1.85;
  color:var(--text-body);
  margin-bottom:var(--sp-3);
}
.sp-article li strong{color:var(--text)}
.sp-article blockquote{
  border-left:4px solid var(--accent);
  padding:var(--sp-4) var(--sp-6);
  margin:var(--sp-8) 0;
  background:var(--accent-light);
  border-radius:0 var(--radius-md) var(--radius-md) 0;
}
.sp-article blockquote p{color:var(--text);font-style:italic;margin-bottom:0}

/* ---------- SECTION HEADER ---------- */
.sp-header{text-align:center;margin-bottom:var(--sp-10)}
.sp-header .overline{
  display:inline-block;
  font-family:var(--font-sans);
  font-size:.78rem;
  font-weight:600;
  letter-spacing:.12em;
  text-transform:uppercase;
  color:var(--accent);
  margin-bottom:var(--sp-3);
}
.sp-header h2{
  font-family:var(--font-display);
  font-size:clamp(1.5rem,3vw,2.25rem);
  color:var(--text);
  margin-bottom:var(--sp-3);
}
.sp-header p{
  font-size:1rem;
  color:var(--text-muted);
  max-width:560px;
  margin:0 auto;
}
.sp-section--dark .sp-header h2{color:#fff}
.sp-section--dark .sp-header .overline{color:rgba(255,255,255,.5)}
.sp-section--dark .sp-header p{color:rgba(255,255,255,.5)}

/* ---------- FEATURE CARDS ---------- */
.sp-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(280px,1fr));
  gap:var(--sp-6);
}
.sp-card{
  background:var(--bg-card);
  border:1px solid var(--border);
  border-radius:var(--radius-lg);
  padding:var(--sp-8);
  transition:transform var(--duration) var(--ease),box-shadow var(--duration) var(--ease);
}
.sp-card:hover{
  transform:translateY(-4px);
  box-shadow:var(--shadow-md);
}
.sp-card__icon{
  width:52px;height:52px;
  display:flex;align-items:center;justify-content:center;
  background:var(--accent-light);
  border-radius:50%;
  color:var(--accent);
  margin-bottom:var(--sp-4);
}
.sp-card__icon svg{width:24px;height:24px}
.sp-card h3{
  font-family:var(--font-sans);
  font-size:1.05rem;
  font-weight:600;
  color:var(--text);
  margin-bottom:var(--sp-3);
}
.sp-card p{
  font-size:.93rem;
  line-height:1.7;
  color:var(--text-body);
  margin:0;
}
a.sp-card--link{text-decoration:none;display:flex;flex-direction:column}
a.sp-card--link:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}
.sp-card__action{
  margin-top:auto;
  padding-top:var(--sp-4);
  font-size:.85rem;
  font-weight:600;
  color:var(--accent);
  transition:gap var(--duration) var(--ease);
}

/* ---------- ICON LIST ---------- */
.sp-icon-list{
  max-width:720px;
  margin:0 auto;
  display:flex;
  flex-direction:column;
  gap:var(--sp-4);
}
.sp-icon-list__item{
  display:flex;
  align-items:flex-start;
  gap:var(--sp-4);
  padding:var(--sp-5) var(--sp-6);
  background:var(--bg-card);
  border:1px solid var(--border);
  border-radius:var(--radius);
  transition:border-color .2s;
}
.sp-icon-list__item:hover{border-color:var(--accent)}
.sp-icon-list__marker{
  flex-shrink:0;
  width:36px;height:36px;
  display:flex;align-items:center;justify-content:center;
  background:var(--accent-light);
  border-radius:50%;
  color:var(--accent);
  font-size:.85rem;
  font-weight:700;
}
.sp-icon-list__text{
  font-size:.97rem;
  line-height:1.7;
  color:var(--text-body);
}
.sp-section--alt .sp-icon-list__item{background:var(--white)}

/* ---------- HIGHLIGHT BOX ---------- */
.sp-highlight{
  background:var(--accent-light);
  border-left:4px solid var(--accent);
  border-radius:0 var(--radius) var(--radius) 0;
  padding:var(--sp-6) var(--sp-8);
  margin:var(--sp-8) auto;
  max-width:720px;
}
.sp-highlight p{
  font-size:1rem;
  line-height:1.75;
  color:var(--text);
  margin:0;
  font-style:italic;
}

/* ---------- STAT STRIP ---------- */
.sp-stats{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(160px,1fr));
  gap:var(--sp-6);
  text-align:center;
  padding:var(--sp-10) 0;
}
.sp-stat__num{
  font-family:var(--font-display);
  font-size:2.5rem;
  font-weight:700;
  color:var(--accent);
  display:block;
}
.sp-stat__label{
  font-size:.88rem;
  color:var(--text-muted);
  margin-top:var(--sp-1);
}
.sp-section--dark .sp-stat__num{color:#fff}
.sp-section--dark .sp-stat__label{color:rgba(255,255,255,.5)}

/* ---------- CTA BLOCK (enhanced) ---------- */
.sp-cta{
  text-align:center;
  padding:var(--sp-16) 0;
  background:var(--bg-dark);
  color:var(--text-inverse);
  position:relative;
  overflow:hidden;
}
.sp-cta::before{
  content:'';
  position:absolute;inset:0;
  background:radial-gradient(ellipse 60% 60% at 50% 100%,rgba(107,45,62,.3),transparent 70%);
  pointer-events:none;
}
.sp-cta .container{position:relative;z-index:1}
.sp-cta h2{
  font-family:var(--font-display);
  font-size:clamp(1.5rem,3vw,2rem);
  color:#fff;
  margin-bottom:var(--sp-4);
}
.sp-cta p{
  font-size:1.05rem;
  color:rgba(255,255,255,.65);
  max-width:520px;
  margin:0 auto var(--sp-8);
  line-height:1.7;
}
.sp-cta .btn{
  display:inline-flex;
  align-items:center;
  gap:var(--sp-2);
}

/* ---------- TWO-COLUMN SECTION ---------- */
.sp-twocol{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:var(--sp-12);
  align-items:center;
}
.sp-twocol__text h2{
  font-family:var(--font-display);
  font-size:clamp(1.4rem,2.5vw,1.85rem);
  color:var(--text);
  margin-bottom:var(--sp-4);
}
.sp-twocol__text p{
  font-size:1rem;
  line-height:1.8;
  color:var(--text-body);
  margin-bottom:var(--sp-4);
}
.sp-twocol__text p:last-child{margin-bottom:0}
@media(max-width:768px){
  .sp-twocol{grid-template-columns:1fr;gap:var(--sp-8)}
}

/* ---------- BOOK CARD ---------- */
.sp-book{
  background:var(--bg-card);
  border:1px solid var(--border);
  border-radius:var(--radius-lg);
  padding:var(--sp-8);
  margin-bottom:var(--sp-6);
  transition:transform .2s,box-shadow .2s;
}
.sp-book:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}
.sp-book h3{
  font-family:var(--font-display);
  font-size:1.25rem;
  color:var(--text);
  margin-bottom:var(--sp-3);
}
.sp-book p{
  font-size:.95rem;
  line-height:1.75;
  color:var(--text-body);
  margin:0;
}
.sp-book__tag{
  display:inline-block;
  font-size:.78rem;
  font-weight:600;
  color:var(--accent);
  background:var(--accent-light);
  padding:var(--sp-1) var(--sp-3);
  border-radius:var(--radius-full);
  margin-bottom:var(--sp-3);
}

/* ---------- RESPONSIVE ---------- */
@media(max-width:768px){
  .sp-grid{grid-template-columns:1fr}
  .sp-stats{grid-template-columns:repeat(2,1fr)}
  .sp-card{padding:var(--sp-6)}
  .page-hero{padding:calc(var(--header-h) + var(--sp-12)) 0 var(--sp-10)}
}
