/* Pages-level CSS — sections, cards, forms, blog, FAQ */

/* ========================================================================
   HERO
   ======================================================================== */
.hero{
  position:relative;
  max-width:1320px;margin:0 auto;
  padding:64px 32px 96px;
  display:grid;grid-template-columns:1.05fr 1fr;
  gap:64px;align-items:center;
  overflow:visible;
}
.hero__copy{position:relative;}
.hero__copy .eyebrow{display:flex;align-items:center;gap:14px;}
.hero__copy .eyebrow::before{
  content:"";display:block;width:40px;height:1px;background:var(--accent-gold);
}
.hero__title{
  font-family:var(--font-display);
  font-size:clamp(44px,6vw,88px);
  font-weight:200;letter-spacing:.01em;line-height:1.0;
  text-transform:uppercase;text-wrap:balance;
  margin:24px 0 28px;color:var(--vinho-profundo);
}
.hero__title em{
  font-style:italic;color:var(--rosa-tempo);font-weight:300;
}
.hero__title small{
  display:block;font-size:.42em;font-weight:400;
  letter-spacing:.18em;color:var(--accent-gold);
  margin-top:14px;text-transform:uppercase;
}
.hero__lead{
  max-width:480px;font-size:18px;line-height:1.55;
  color:var(--fg-muted);margin:0 0 32px;
}
.hero__ctas{display:flex;gap:14px;flex-wrap:wrap;}
.hero__meta{
  display:grid;grid-template-columns:repeat(3,1fr);gap:20px;
  margin-top:56px;padding-top:32px;
  border-top:1px solid var(--divider);
}
.hero__meta div{display:flex;flex-direction:column;gap:4px;}
.hero__meta strong{
  font-family:var(--font-display);font-size:36px;font-weight:300;
  color:var(--rosa-tempo);letter-spacing:.02em;line-height:1;
}
.hero__meta span{
  font-size:11px;letter-spacing:.16em;text-transform:uppercase;
  color:var(--fg-muted);font-weight:500;
}
.hero__media{
  position:relative;aspect-ratio:4/5;
  display:flex;align-items:center;justify-content:center;
}
/* Organic blob frame for portrait */
.hero__portrait-wrap{
  position:absolute;inset:0;
  border-radius: 50% 45% 52% 48% / 48% 52% 45% 55%;
  overflow:hidden;
  box-shadow: 0 30px 80px -20px rgba(80,59,59,.25);
  animation: blob-morph 18s ease-in-out infinite;
}
@keyframes blob-morph {
  0%,100%{border-radius: 50% 45% 52% 48% / 48% 52% 45% 55%;}
  33%{border-radius: 48% 52% 45% 55% / 52% 48% 50% 50%;}
  66%{border-radius: 45% 55% 50% 50% / 50% 45% 55% 48%;}
}
.hero__portrait-wrap img{
  width:100%;height:100%;object-fit:cover;
  object-position:center 18%;
  animation: ken-burns 16s ease-in-out infinite alternate;
}
@keyframes ken-burns{
  from{transform:scale(1.0);}
  to{transform:scale(1.08);}
}
.hero__pattern{
  position:absolute;
  width:240px;height:240px;
  background-image:url('assets/pattern.png');
  background-size:cover;background-position:center;
  border-radius: 60% 40% 50% 50% / 50% 50% 50% 50%;
  opacity:.65;
  z-index:-1;
}
.hero__pattern--tl{top:-32px;left:-48px;}
.hero__pattern--br{
  bottom:-40px;right:-32px;width:180px;height:180px;
  border-radius: 40% 60% 55% 45% / 50% 50% 50% 50%;
}
.hero__symbol{
  position:absolute;left:-12px;bottom:30px;
  width:80px;height:80px;
  background:var(--marfim-sereno);
  border-radius:999px;
  display:flex;align-items:center;justify-content:center;
  box-shadow:var(--shadow-md);
  z-index:2;
}
.hero__symbol img{width:48px;height:48px;}
.hero__badge{
  position:absolute;right:-8px;top:32px;
  background:#fff;border:1px solid var(--border);
  border-radius:999px;padding:10px 18px;
  display:flex;align-items:center;gap:10px;
  box-shadow:var(--shadow-sm);
  font-size:12px;letter-spacing:.06em;
  color:var(--vinho-profundo);font-weight:500;z-index:2;
}
.hero__badge i{
  width:8px;height:8px;border-radius:50%;
  background:#3FB47A;animation:pulse 2s infinite;
}
@keyframes pulse{
  0%,100%{box-shadow:0 0 0 0 rgba(63,180,122,.6);}
  50%{box-shadow:0 0 0 6px rgba(63,180,122,0);}
}

/* HERO LAYOUT VARIANTS (tweakable) */
.hero[data-layout="centered"]{
  grid-template-columns:1fr;text-align:center;
  padding-top:80px;padding-bottom:120px;
}
.hero[data-layout="centered"] .hero__copy .eyebrow{justify-content:center;}
.hero[data-layout="centered"] .hero__copy .eyebrow::before{display:none;}
.hero[data-layout="centered"] .hero__lead{margin-left:auto;margin-right:auto;}
.hero[data-layout="centered"] .hero__ctas{justify-content:center;}
.hero[data-layout="centered"] .hero__meta{margin-left:auto;margin-right:auto;max-width:680px;}
.hero[data-layout="centered"] .hero__media{
  margin-top:64px;max-width:640px;margin-left:auto;margin-right:auto;
  width:100%;aspect-ratio:5/3;
}

.hero[data-layout="split"]{
  /* default = side-by-side, already grid 1.05/1 */
}

.hero[data-layout="editorial"] .hero__title{
  font-size:clamp(60px,8vw,120px);
  font-weight:100;letter-spacing:0;
}
.hero[data-layout="editorial"] .hero__media{
  aspect-ratio:1/1.15;
}
.hero[data-layout="editorial"] .hero__portrait-wrap{
  border-radius:var(--tk-radius);
  animation:none;
}

@media (max-width:960px){
  .hero{grid-template-columns:1fr;gap:48px;padding:48px 20px 64px;}
  .hero__media{max-width:480px;margin:0 auto;width:100%;aspect-ratio:4/5;}
  .hero__meta{grid-template-columns:1fr 1fr;gap:24px;}
  .hero__meta div:last-child{grid-column:1/-1;}
  .hero__pattern--tl{top:-16px;left:-16px;width:140px;height:140px;}
  .hero__pattern--br{display:none;}
}

/* ========================================================================
   MARQUEE: trust strip
   ======================================================================== */
.marquee{
  background:var(--bg-soft);
  padding:32px 0;
  overflow:hidden;
  border-top:1px solid var(--divider);
  border-bottom:1px solid var(--divider);
}
.marquee__track{
  display:flex;gap:64px;align-items:center;
  animation: marquee 36s linear infinite;
  width:max-content;
}
.marquee__item{
  display:flex;align-items:center;gap:14px;flex-shrink:0;
  font-family:var(--font-display);font-size:14px;
  letter-spacing:.18em;text-transform:uppercase;
  color:var(--vinho-profundo);font-weight:500;
}
.marquee__item::after{
  content:"";display:block;width:6px;height:6px;border-radius:50%;
  background:var(--rosa-tempo);
}
@keyframes marquee{
  from{transform:translateX(0);}
  to{transform:translateX(-50%);}
}

/* ========================================================================
   INTRO BLOCK
   ======================================================================== */
.intro{
  display:grid;grid-template-columns:1fr 1.2fr;gap:80px;align-items:center;
}
.intro__media{
  position:relative;aspect-ratio:4/5;border-radius:var(--tk-radius);overflow:hidden;
  box-shadow:var(--shadow-md);
}
.intro__media img{width:100%;height:100%;object-fit:cover;}
.intro__media .placeholder-img{height:100%;}
.intro__copy h2{
  font-size:clamp(32px,3.8vw,52px);font-weight:300;letter-spacing:.02em;
  line-height:1.06;text-transform:uppercase;text-wrap:balance;margin:18px 0 24px;
}
.intro__copy h2 em{font-style:italic;color:var(--rosa-tempo);font-weight:300;}
.intro__copy p{font-size:17px;line-height:1.65;color:var(--fg-muted);margin:0 0 18px;}
.intro__pillars{
  display:grid;grid-template-columns:repeat(2,1fr);gap:24px;margin-top:32px;
}
.intro__pillar{display:flex;gap:14px;align-items:flex-start;}
.intro__pillar-icon{
  flex-shrink:0;width:44px;height:44px;border-radius:999px;
  background:var(--tk-primary-strong);color:var(--rosa-tempo);
  display:flex;align-items:center;justify-content:center;font-size:22px;
}
.intro__pillar h4{margin:0 0 4px;font-size:14px;letter-spacing:.04em;color:var(--vinho-profundo);}
.intro__pillar p{font-size:14px;line-height:1.5;margin:0;color:var(--fg-muted);}

@media (max-width:880px){
  .intro{grid-template-columns:1fr;gap:32px;}
  .intro__pillars{grid-template-columns:1fr;}
}

/* ========================================================================
   PLACEHOLDER IMAGE
   ======================================================================== */
.placeholder-img{
  background:linear-gradient(135deg,#F7EFE7 0%,#EAD9C5 100%);
  display:flex;align-items:center;justify-content:center;
  position:relative;overflow:hidden;
  color:var(--vinho-profundo);
}
.placeholder-img::before{
  content:"";position:absolute;inset:0;
  background-image:url('assets/pattern.png');
  background-size:cover;background-position:center;
  opacity:.18;mix-blend-mode:multiply;
}
.placeholder-img__inner{
  position:relative;z-index:1;text-align:center;
  display:flex;flex-direction:column;align-items:center;gap:12px;
  padding:24px;
}
.placeholder-img__inner img{width:48px;height:48px;opacity:.6;}
.placeholder-img__inner span{
  font-size:11px;letter-spacing:.18em;text-transform:uppercase;
  color:var(--vinho-profundo);opacity:.65;font-weight:500;
}

/* ========================================================================
   SERVICES
   ======================================================================== */
.services-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:24px;
}
.service{
  position:relative;background:#fff;
  border:1px solid var(--border);
  border-radius:var(--tk-radius);
  padding:0;
  transition:transform var(--dur-base) var(--ease-soft),
             box-shadow var(--dur-base) var(--ease-soft),
             border-color var(--dur-base) var(--ease-soft);
  display:flex;flex-direction:column;gap:0;
  box-shadow:var(--shadow-sm);
  overflow:hidden;
}
.service__media{overflow:hidden;aspect-ratio:3/2;flex-shrink:0;}
.service__media img{width:100%;height:100%;object-fit:cover;object-position:center;display:block;}
.service__content{padding:28px 28px 28px;display:flex;flex-direction:column;gap:14px;flex:1;}
.service::before{
  content:"";position:absolute;top:0;left:0;right:0;height:3px;
  background:var(--rosa-tempo);
  transform:scaleX(0);transform-origin:left;
  transition:transform var(--dur-base) var(--ease-out);
}
.service:hover{
  transform:translateY(-4px);
  box-shadow:var(--shadow-md);
  border-color:var(--rosa-tempo-32);
}
.service:hover::before{transform:scaleX(1);}
.service__num{
  font-family:var(--font-display);font-size:13px;
  letter-spacing:.18em;color:var(--accent-gold);font-weight:500;
}
.service__icon{
  width:56px;height:56px;border-radius:999px;
  background:var(--tk-primary-strong);color:var(--rosa-tempo);
  display:flex;align-items:center;justify-content:center;font-size:26px;
  margin-bottom:8px;
}
.service__title{
  font-family:var(--font-display);font-size:22px;font-weight:400;
  letter-spacing:.04em;text-transform:uppercase;
  margin:0;color:var(--vinho-profundo);line-height:1.2;
}
.service__body{font-size:15px;line-height:1.55;color:var(--fg-muted);margin:0;flex:1;}
.service__list{margin:8px 0 16px;padding:0;list-style:none;display:flex;flex-direction:column;gap:8px;}
.service__list li{
  position:relative;padding-left:22px;font-size:13.5px;
  color:var(--vinho-profundo);line-height:1.4;
}
.service__list li::before{
  content:"";position:absolute;left:0;top:8px;
  width:8px;height:8px;border-radius:50%;
  background:var(--rosa-tempo);
}
.service__more{
  display:inline-flex;align-items:center;gap:8px;
  font-family:var(--font-sans);font-size:11px;letter-spacing:.18em;
  text-transform:uppercase;color:var(--rosa-tempo);font-weight:500;
  background:transparent;border:0;outline:0;cursor:pointer;padding:0;
  margin-top:auto;border-bottom:0;-webkit-appearance:none;appearance:none;
}
.service__more:hover,.service__more:focus,.service__more:active{
  background:transparent;border:0;outline:0;
}
.service__more svg{transition:transform var(--dur-fast) var(--ease-soft);}
.service__more:hover svg{transform:translateX(4px);}
.service__badge{
  position:absolute;top:24px;right:24px;font-size:10px;
  letter-spacing:.18em;text-transform:uppercase;font-weight:600;
  padding:6px 12px;border-radius:999px;
  background:var(--dourado-vital-gradient);color:var(--vinho-profundo);
}

@media (max-width:1080px){.services-grid{grid-template-columns:repeat(2,1fr);}}
@media (max-width:680px){.services-grid{grid-template-columns:1fr;}}

/* ========================================================================
   MÉTODO VIDA
   ======================================================================== */
.metodo-grid{
  display:grid;grid-template-columns:repeat(4,1fr);gap:24px;
}
.metodo-card{
  position:relative;background:#fff;
  border:1px solid var(--border);
  border-radius:var(--tk-radius);
  padding:36px 28px 32px;
  display:flex;flex-direction:column;align-items:center;text-align:center;
  gap:8px;
  box-shadow:var(--shadow-sm);
  transition:transform var(--dur-base) var(--ease-soft),
             box-shadow var(--dur-base) var(--ease-soft),
             border-color var(--dur-base) var(--ease-soft);
  overflow:hidden;
}
.metodo-card::before{
  content:"";position:absolute;top:0;left:0;right:0;height:3px;
  background:var(--rosa-tempo);
  transform:scaleX(0);transform-origin:left;
  transition:transform var(--dur-base) var(--ease-out);
}
.metodo-card:hover{
  transform:translateY(-4px);
  box-shadow:var(--shadow-md);
  border-color:var(--rosa-tempo-32);
}
.metodo-card:hover::before{transform:scaleX(1);}
.metodo-card__letter{
  font-family:var(--font-display);font-size:84px;font-weight:200;
  color:var(--rosa-tempo);line-height:1;letter-spacing:.02em;
  font-style:italic;margin:0 0 4px;
}
.metodo-card__title{
  font-family:var(--font-display);font-size:18px;font-weight:400;
  letter-spacing:.04em;text-transform:uppercase;
  margin:0;color:var(--vinho-profundo);line-height:1.2;
}
.metodo-card__body{
  font-size:15px;line-height:1.55;color:var(--fg-muted);margin:4px 0 0;
}
.metodo-card__copy{display:contents;}

@media (max-width:980px){
  .metodo-grid{grid-template-columns:repeat(2,1fr);gap:16px;}
  .metodo-card{padding:28px 22px 24px;}
  .metodo-card__letter{font-size:64px;}
}
@media (max-width:520px){
  .metodo-grid{grid-template-columns:1fr;gap:14px;}
  .metodo-card{
    flex-direction:row;align-items:center;text-align:left;
    padding:20px 22px;gap:18px;
  }
  .metodo-card__letter{font-size:56px;flex:0 0 auto;margin:0;width:44px;text-align:center;}
  .metodo-card__copy{display:flex;flex-direction:column;gap:4px;flex:1;}
  .metodo-card__title{font-size:15px;}
  .metodo-card__body{font-size:13.5px;line-height:1.5;margin:0;}
}

/* Estética íntima — card normal centralizado abaixo de Hormônios */
.service--solo{grid-column:2;}
@media (max-width:1080px){.service--solo{grid-column:unset;}}


/* ========================================================================
   DIFERENCIAIS
   ======================================================================== */
.diffs{
  display:grid;grid-template-columns:repeat(4,1fr);gap:24px;
}
.diff{
  text-align:left;padding:32px 28px;
  border-radius:var(--tk-radius);
  background:rgba(255,251,244,.6);
  border:1px solid rgba(255,251,244,.18);
  transition:transform var(--dur-base) var(--ease-soft);
}
.diff:hover{transform:translateY(-4px);}
.diff__icon{
  width:52px;height:52px;border-radius:999px;
  background:rgba(213,186,148,.24);color:var(--areia-essencial);
  display:flex;align-items:center;justify-content:center;
  margin-bottom:24px;font-size:22px;
}
.diff h4{
  font-family:var(--font-display);font-size:18px;font-weight:500;
  letter-spacing:.04em;text-transform:uppercase;
  margin:0 0 10px;color:var(--marfim-sereno);
}
.diff p{font-size:14.5px;line-height:1.6;color:rgba(255,251,244,.78);margin:0;}

@media (max-width:1080px){.diffs{grid-template-columns:repeat(2,1fr);}}
@media (max-width:540px){.diffs{grid-template-columns:1fr;}}

/* ========================================================================
   ABOUT DOCTOR
   ======================================================================== */
.doc{
  display:grid;grid-template-columns:0.95fr 1.05fr;gap:80px;align-items:center;
  background:var(--bg-soft);
  border-radius:var(--tk-radius);
  padding:72px;
  position:relative;overflow:hidden;
}
.doc::before{
  content:"";position:absolute;
  top:-40%;right:-12%;width:520px;height:520px;
  background-image:url('assets/pattern.png');
  background-size:cover;background-position:center;
  border-radius:50%;opacity:.12;pointer-events:none;
}
.doc__media{position:relative;aspect-ratio:4/5;border-radius:var(--tk-radius);overflow:hidden;
  box-shadow:var(--shadow-md);
}
.doc__media img{width:100%;height:100%;object-fit:cover;}
.doc__copy h2{
  font-size:clamp(32px,3.6vw,48px);font-weight:300;letter-spacing:.02em;
  line-height:1.08;text-transform:uppercase;text-wrap:balance;margin:18px 0 24px;
}
.doc__copy h2 em{font-style:italic;color:var(--rosa-tempo);font-weight:300;}
.doc__copy p{font-size:17px;line-height:1.65;color:var(--fg-muted);margin:0 0 16px;}
.doc__credits{
  display:grid;grid-template-columns:1fr 1fr;gap:18px;margin:32px 0;
}
.doc__credit{
  padding:14px 0;border-top:1px solid var(--border);
  display:flex;flex-direction:column;gap:4px;
}
.doc__credit strong{
  font-size:11px;letter-spacing:.18em;text-transform:uppercase;
  color:var(--accent-gold);font-weight:500;
}
.doc__credit span{font-size:14px;color:var(--vinho-profundo);}
.doc__sign{margin-top:32px;padding-top:24px;border-top:1px solid var(--border);}
.doc__sign .signature{
  font-family:var(--font-script);font-size:36px;color:var(--accent-gold);
  display:block;line-height:1;
}
.doc__sign small{
  display:block;margin-top:8px;color:var(--fg-muted);
  font-size:12px;letter-spacing:.06em;
}

@media (max-width:960px){
  .doc{grid-template-columns:1fr;gap:40px;padding:40px 28px;}
}

/* ========================================================================
   TESTIMONIALS
   ======================================================================== */
.testimonial-stage{
  position:relative;padding:120px 32px;
  isolation:isolate;display:flex;justify-content:center;
  background:var(--vinho-profundo);
}
.testimonial-stage__pattern{
  position:absolute;inset:0;
  background-image:url('assets/pattern.png');
  background-size:cover;background-position:center;
  opacity:.18;mix-blend-mode:screen;z-index:-1;
}
.testimonials{
  width:100%;max-width:1200px;
  display:grid;grid-template-columns:repeat(3,1fr);gap:24px;
}
.tstm{
  background:rgba(255,251,244,.96);
  border-radius:var(--tk-radius);
  padding:36px 32px;
  display:flex;flex-direction:column;gap:20px;
  box-shadow:var(--shadow-md);
  transition:transform var(--dur-base) var(--ease-out);
}
.tstm:hover{transform:translateY(-4px);}
.tstm__stars{display:flex;gap:3px;color:var(--accent-gold);font-size:14px;}
.tstm blockquote{
  font-family:var(--font-display);font-size:19px;font-weight:300;
  line-height:1.45;color:var(--vinho-profundo);
  font-style:italic;letter-spacing:.01em;margin:0;flex:1;
}
.tstm figcaption{
  display:flex;align-items:center;gap:14px;
  border-top:1px solid var(--divider);padding-top:18px;
}
.tstm__avatar{
  width:48px;height:48px;border-radius:999px;
  background:var(--rosa-tempo-16);color:var(--rosa-tempo);
  display:flex;align-items:center;justify-content:center;
  font-family:var(--font-display);font-size:18px;font-weight:500;
}
.tstm figcaption strong{
  display:block;color:var(--vinho-profundo);
  font-family:var(--font-display);font-size:15px;
  letter-spacing:.04em;font-weight:500;text-transform:uppercase;
}
.tstm figcaption span{font-size:12px;color:var(--fg-muted);letter-spacing:.06em;}

@media (max-width:1080px){.testimonials{grid-template-columns:1fr;max-width:520px;}}

/* ========================================================================
   FAQ
   ======================================================================== */
.faq{display:flex;flex-direction:column;gap:0;max-width:880px;margin:0 auto;}
.faq__item{
  border-top:1px solid var(--border);
}
.faq__item:last-child{border-bottom:1px solid var(--border);}
.faq__btn{
  width:100%;background:none;border:0;cursor:pointer;
  display:flex;align-items:center;justify-content:space-between;gap:24px;
  padding:28px 0;text-align:left;
  font-family:var(--font-display);font-size:20px;font-weight:400;
  letter-spacing:.02em;color:var(--vinho-profundo);
  text-transform:uppercase;line-height:1.3;
  transition:color var(--dur-fast) var(--ease-soft);
}
.faq__btn:hover{color:var(--rosa-tempo);}
.faq__icon{
  flex-shrink:0;width:36px;height:36px;border-radius:999px;
  background:var(--tk-primary-strong);color:var(--rosa-tempo);
  display:flex;align-items:center;justify-content:center;
  transition:transform var(--dur-base) var(--ease-soft),
             background var(--dur-base) var(--ease-soft);
  font-size:16px;
}
.faq__item[data-open="1"] .faq__icon{
  transform:rotate(45deg);
  background:var(--rosa-tempo);color:var(--marfim-sereno);
}
.faq__panel{
  max-height:0;overflow:hidden;
  transition:max-height var(--dur-slow) var(--ease-soft);
}
.faq__item[data-open="1"] .faq__panel{max-height:400px;}
.faq__panel-inner{
  padding-bottom:28px;font-size:16px;line-height:1.65;
  color:var(--fg-muted);max-width:680px;
}

/* ========================================================================
   CTA SECTION
   ======================================================================== */
.cta{
  background:var(--rosa-tempo);
  color:var(--marfim-sereno);
  border-radius:var(--tk-radius);
  padding:80px 64px;text-align:center;
  position:relative;overflow:hidden;
}
.cta::before,.cta::after{
  content:"";position:absolute;
  background:rgba(255,251,244,.08);border-radius:50%;
}
.cta::before{width:280px;height:280px;top:-100px;left:-80px;}
.cta::after{width:340px;height:340px;bottom:-160px;right:-100px;}
.cta__inner{position:relative;z-index:1;}
.cta .eyebrow{color:var(--areia-essencial);}
.cta h2{
  color:var(--marfim-sereno);
  font-size:clamp(32px,4.4vw,56px);font-weight:300;
  letter-spacing:.02em;line-height:1.06;text-transform:uppercase;
  margin:18px auto 24px;max-width:760px;text-wrap:balance;
}
.cta h2 em{font-style:italic;color:var(--areia-essencial);font-weight:300;}
.cta p{font-size:18px;line-height:1.55;color:rgba(255,251,244,.85);margin:0 auto 36px;max-width:540px;}
.cta__ctas{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;}

@media (max-width:760px){
  .cta{padding:48px 28px;}
}

/* ========================================================================
   NEWSLETTER
   ======================================================================== */
.news{
  background:var(--bg-soft);border-radius:var(--tk-radius);
  padding:56px 48px;display:grid;grid-template-columns:1.1fr 1fr;gap:48px;align-items:center;
}
.news h3{
  font-family:var(--font-display);font-size:30px;font-weight:300;
  letter-spacing:.02em;line-height:1.1;text-transform:uppercase;
  margin:0 0 12px;color:var(--vinho-profundo);text-wrap:balance;
}
.news h3 em{font-style:italic;color:var(--rosa-tempo);font-weight:300;}
.news p{font-size:15px;line-height:1.55;color:var(--fg-muted);margin:0;}
.news form{display:flex;gap:12px;flex-wrap:wrap;}
.news input{
  flex:1;min-width:200px;
  background:#fff;border:1px solid var(--border);
  border-radius:999px;padding:14px 22px;
  font-size:14px;font-family:inherit;
  color:var(--vinho-profundo);outline:none;
  transition:border-color var(--dur-fast) var(--ease-soft),box-shadow var(--dur-fast) var(--ease-soft);
}
.news input:focus{border-color:var(--rosa-tempo);box-shadow:0 0 0 3px var(--rosa-tempo-16);}
@media (max-width:880px){
  .news{grid-template-columns:1fr;padding:40px 28px;gap:24px;}
}

/* ========================================================================
   FOOTER
   ======================================================================== */
.ftr{background:var(--vinho-profundo);color:var(--marfim-sereno);padding:80px 32px 32px;}
.ftr__inner{
  max-width:1320px;margin:0 auto;
  display:grid;grid-template-columns:1.4fr 2.6fr;gap:80px;align-items:flex-start;
}
.ftr__brand img{width:160px;height:auto;}
.ftr__brand p{font-size:14px;line-height:1.65;color:rgba(255,251,244,.7);margin:24px 0;max-width:300px;}
.ftr__social{display:flex;gap:12px;}
.ftr__social a{
  width:40px;height:40px;border-radius:999px;
  border:1px solid rgba(255,251,244,.18);
  display:flex;align-items:center;justify-content:center;
  color:var(--marfim-sereno);transition:all var(--dur-base) var(--ease-soft);
}
.ftr__social a:hover{
  background:var(--rosa-tempo);border-color:var(--rosa-tempo);
  transform:translateY(-2px);
}
.ftr__cols{display:grid;grid-template-columns:repeat(4,1fr);gap:32px;}
.ftr__cols h5{
  font-family:var(--font-display);font-size:13px;font-weight:500;
  letter-spacing:.18em;text-transform:uppercase;
  color:var(--areia-essencial);margin:0 0 18px;
}
.ftr__cols ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:10px;}
.ftr__cols a,.ftr__cols button{white-space:nowrap;
  background:none;border:0;cursor:pointer;text-align:left;padding:0;
  color:var(--marfim-sereno);font-size:14px;
  opacity:.78;border-bottom:1px solid transparent;
  font-family:inherit;
  transition:opacity var(--dur-fast) var(--ease-soft),color var(--dur-fast) var(--ease-soft);
}
.ftr__cols a:hover,.ftr__cols button:hover{opacity:1;color:var(--areia-essencial);}
.ftr__legal{
  max-width:1320px;margin:64px auto 0;padding-top:24px;
  border-top:1px solid rgba(255,251,244,.12);
  display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px;
  font-size:12px;opacity:.65;letter-spacing:.04em;
}

@media (max-width:1080px){
  .ftr__inner{grid-template-columns:1fr;gap:48px;}
  .ftr__cols{grid-template-columns:repeat(2,1fr);}
}
@media (max-width:540px){
  .ftr__cols{grid-template-columns:1fr;}
}

/* ========================================================================
   AGENDAMENTO PAGE
   ======================================================================== */
.book{
  display:grid;grid-template-columns:1fr 1.15fr;gap:64px;
  background:var(--bg-soft);border-radius:var(--tk-radius);
  padding:64px;position:relative;overflow:hidden;
}
.book::before{
  content:"";position:absolute;
  top:-30%;left:-20%;width:400px;height:400px;
  background-image:url('assets/pattern.png');
  background-size:cover;border-radius:50%;opacity:.15;pointer-events:none;
}
.book__copy{position:relative;z-index:1;}
.book__copy h2{
  font-size:clamp(32px,3.6vw,48px);font-weight:300;letter-spacing:.02em;
  line-height:1.06;text-transform:uppercase;text-wrap:balance;margin:14px 0 20px;
}
.book__copy h2 em{font-style:italic;color:var(--rosa-tempo);font-weight:300;}
.book__copy p{font-size:17px;line-height:1.65;color:var(--fg-muted);margin:0;}
.book__perks{margin-top:32px;display:flex;flex-direction:column;gap:14px;}
.book__perk{display:flex;gap:14px;align-items:flex-start;padding-top:14px;border-top:1px solid var(--border);}
.book__perk-icon{
  flex-shrink:0;width:36px;height:36px;border-radius:999px;
  background:var(--rosa-tempo);color:var(--marfim-sereno);
  display:flex;align-items:center;justify-content:center;font-size:14px;
}
.book__perk h4{margin:0 0 2px;font-size:14px;letter-spacing:.04em;}
.book__perk p{font-size:14px;line-height:1.5;margin:0;}
.book__form{
  background:#fff;border-radius:var(--tk-radius);
  padding:40px;box-shadow:var(--shadow-sm);
  display:flex;flex-direction:column;gap:20px;
  position:relative;z-index:1;
}
.book__form-head{
  margin-bottom:8px;padding-bottom:20px;border-bottom:1px solid var(--divider);
}
.book__form-head h3{
  font-family:var(--font-display);font-size:22px;font-weight:400;
  letter-spacing:.04em;text-transform:uppercase;margin:0 0 6px;color:var(--vinho-profundo);
}
.book__form-head p{font-size:13px;color:var(--fg-muted);margin:0;}
.field{display:flex;flex-direction:column;gap:8px;}
.field > label{
  font-family:var(--font-sans);font-size:11px;letter-spacing:.18em;
  text-transform:uppercase;color:var(--fg-muted);font-weight:500;
}
.field input,.field select,.field textarea{
  font-family:var(--font-sans);font-size:15px;color:var(--vinho-profundo);
  background:#fff;border:1px solid var(--border);
  border-radius:8px;padding:14px 16px;outline:none;
  transition:border-color var(--dur-fast) var(--ease-soft),
             box-shadow var(--dur-fast) var(--ease-soft);
}
.field input:focus,.field select:focus,.field textarea:focus{
  border-color:var(--rosa-tempo);
  box-shadow:0 0 0 3px var(--rosa-tempo-16);
}
.field textarea{resize:vertical;min-height:90px;}
.row-2{display:grid;grid-template-columns:1fr 1fr;gap:14px;}
.chip-row{display:flex;flex-wrap:wrap;gap:10px;}
.chip{
  background:var(--bg-soft);border:1px solid var(--border);
  padding:10px 16px;border-radius:999px;cursor:pointer;
  font-family:var(--font-sans);font-size:13px;
  letter-spacing:.04em;color:var(--vinho-profundo);
  transition:all var(--dur-fast) var(--ease-soft);
}
.chip:hover{border-color:var(--rosa-tempo);}
.chip[data-on="1"]{
  background:var(--rosa-tempo);color:var(--marfim-sereno);border-color:var(--rosa-tempo);
}
.book__sent{
  text-align:center;padding:36px 12px;
  display:flex;flex-direction:column;align-items:center;gap:8px;
}
.book__sent-icon{
  width:80px;height:80px;border-radius:999px;
  background:var(--tk-primary-strong);color:var(--rosa-tempo);
  display:flex;align-items:center;justify-content:center;
  margin-bottom:12px;font-size:36px;
}
.book__sent h3{
  font-family:var(--font-display);font-size:24px;font-weight:400;
  letter-spacing:.04em;text-transform:uppercase;margin:0;
}
.book__sent p{font-size:15px;color:var(--fg-muted);max-width:340px;margin:0;}

@media (max-width:960px){
  .book{grid-template-columns:1fr;gap:32px;padding:32px 24px;}
  .book__form{padding:28px 24px;}
  .row-2{grid-template-columns:1fr;}
}

/* ========================================================================
   PAGE BANNERS (inner pages)
   ======================================================================== */
.banner{
  background:var(--bg-soft);
  padding:80px 32px 64px;
  position:relative;overflow:hidden;
}
.banner__inner{max-width:1320px;margin:0 auto;position:relative;z-index:1;}
.banner__crumbs{
  display:flex;gap:8px;font-size:11px;letter-spacing:.18em;
  text-transform:uppercase;color:var(--fg-muted);margin-bottom:18px;
}
.banner__crumbs button{
  background:none;border:0;cursor:pointer;padding:0;
  color:var(--fg-muted);font:inherit;letter-spacing:inherit;text-transform:inherit;
}
.banner__crumbs button:hover{color:var(--rosa-tempo);}
.banner__crumbs span{color:var(--rosa-tempo);}
.banner h1{
  font-size:clamp(40px,5vw,72px);font-weight:200;letter-spacing:.02em;
  line-height:1.04;text-transform:uppercase;text-wrap:balance;margin:0 0 14px;max-width:900px;
}
.banner h1 em{font-style:italic;color:var(--rosa-tempo);font-weight:300;}
.banner p{font-size:18px;line-height:1.55;color:var(--fg-muted);margin:0;max-width:600px;}
.banner::after{
  content:"";position:absolute;
  top:-40%;right:-10%;width:480px;height:480px;
  background-image:url('assets/pattern.png');
  background-size:cover;border-radius:50%;opacity:.15;pointer-events:none;
}

/* ========================================================================
   ABOUT PAGE
   ======================================================================== */
.about-grid{
  display:grid;grid-template-columns:1fr 1fr 1fr;gap:24px;margin-top:48px;
}
.about-card{
  background:#fff;border:1px solid var(--border);border-radius:var(--tk-radius);
  padding:40px 32px;display:flex;flex-direction:column;gap:14px;box-shadow:var(--shadow-sm);
}
.about-card__num{
  font-family:var(--font-display);font-size:14px;color:var(--accent-gold);
  letter-spacing:.18em;font-weight:500;
}
.about-card h3{
  font-family:var(--font-display);font-size:22px;font-weight:400;
  letter-spacing:.04em;text-transform:uppercase;margin:0;color:var(--vinho-profundo);
}
.about-card p{font-size:15px;line-height:1.6;color:var(--fg-muted);margin:0;}
@media (max-width:880px){.about-grid{grid-template-columns:1fr;}}

.gallery{
  display:grid;grid-template-columns:2fr 1fr 1fr;grid-template-rows:1fr 1fr;
  gap:16px;height:560px;
}
.gallery > div:nth-child(1){grid-row:span 2;}
.gallery > div{
  border-radius:var(--tk-radius);overflow:hidden;
}
.gallery__photo{width:100%;height:100%;}
.gallery__photo img{width:100%;height:100%;object-fit:cover;display:block;}
@media (max-width:760px){
  .gallery{grid-template-columns:1fr 1fr;grid-template-rows:repeat(3,1fr);height:auto;}
  .gallery > div{aspect-ratio:1;}
  .gallery > div:nth-child(1){grid-row:span 1;grid-column:span 2;aspect-ratio:16/9;}
}

/* ========================================================================
   TEAM PAGE
   ======================================================================== */
.team{display:grid;grid-template-columns:1fr;gap:32px;}
.team-card{
  display:grid;grid-template-columns:1fr 1.4fr;gap:48px;
  background:#fff;border:1px solid var(--border);
  border-radius:var(--tk-radius);overflow:hidden;
  box-shadow:var(--shadow-sm);
}
.team-card__media{aspect-ratio:4/5;overflow:hidden;}
.team-card__media img{width:100%;height:100%;object-fit:cover;object-position:center top;}
.team-card__copy{padding:48px 56px 48px 0;display:flex;flex-direction:column;gap:14px;}
.team-card__copy h3{
  font-family:var(--font-display);font-size:30px;font-weight:300;
  letter-spacing:.02em;text-transform:uppercase;margin:8px 0 0;color:var(--vinho-profundo);
}
.team-card__role{
  font-family:var(--font-sans);font-size:12px;letter-spacing:.18em;
  text-transform:uppercase;color:var(--accent-gold);font-weight:500;
}
.team-card__copy p{font-size:15px;line-height:1.65;color:var(--fg-muted);margin:0;}
.team-card__creds{
  display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-top:20px;
}
.team-card__cred{padding:12px 0;border-top:1px solid var(--border);font-size:13px;}
.team-card__cred strong{
  display:block;font-size:11px;letter-spacing:.18em;
  text-transform:uppercase;color:var(--accent-gold);
  font-weight:500;margin-bottom:4px;
}
.team-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:48px;
}
.team-mini{
  background:#fff;border:1px solid var(--border);
  border-radius:var(--tk-radius);overflow:hidden;
  box-shadow:var(--shadow-sm);display:flex;flex-direction:column;
}
.team-mini__media{aspect-ratio:4/5;background:var(--bg-soft);position:relative;overflow:hidden;}
.team-mini__media .ph-block{width:100%;height:100%;}
.team-mini__copy{padding:24px 28px 28px;display:flex;flex-direction:column;gap:8px;flex:1;}
.team-mini__role{
  font-family:var(--font-sans);font-size:11px;letter-spacing:.18em;
  text-transform:uppercase;color:var(--accent-gold);font-weight:500;
}
.team-mini__copy h4{
  font-family:var(--font-display);font-size:22px;font-weight:300;
  letter-spacing:.02em;text-transform:uppercase;
  color:var(--vinho-profundo);margin:4px 0 0;line-height:1.15;
}
.team-mini__copy p{font-size:14px;line-height:1.6;color:var(--fg-muted);margin:8px 0 0;}
.team-mini__spec{
  margin-top:auto;padding-top:16px;border-top:1px solid var(--border);
  font-size:12px;color:var(--vinho-profundo);font-weight:500;letter-spacing:.02em;
}
@media (max-width:880px){.team-grid{grid-template-columns:1fr 1fr;}}
@media (max-width:540px){.team-grid{grid-template-columns:1fr;}}
  margin-bottom:4px;font-weight:500;
}
@media (max-width:880px){
  .team-card{grid-template-columns:1fr;}
  .team-card__media{aspect-ratio:1/1;}
  .team-card__media img{object-position:center 20%;}
  .team-card__copy{padding:32px 28px;}
  .team-card__creds{grid-template-columns:1fr;}
}

/* ========================================================================
   BLOG
   ======================================================================== */
.blog-tools{
  display:flex;justify-content:space-between;gap:24px;margin-bottom:32px;
  align-items:center;flex-wrap:wrap;
}
.blog-search{
  flex:1;max-width:380px;display:flex;align-items:center;gap:10px;
  background:#fff;border:1px solid var(--border);
  border-radius:999px;padding:12px 20px;
  transition:border-color var(--dur-fast) var(--ease-soft),box-shadow var(--dur-fast) var(--ease-soft);
}
.blog-search:focus-within{border-color:var(--rosa-tempo);box-shadow:0 0 0 3px var(--rosa-tempo-16);}
.blog-search svg{color:var(--rosa-tempo);flex-shrink:0;}
.blog-search input{flex:1;border:0;outline:none;font-family:inherit;font-size:14px;background:none;color:var(--vinho-profundo);}
.blog-cats{display:flex;gap:8px;flex-wrap:wrap;}
.blog-cats button{
  background:none;border:1px solid var(--border);
  padding:8px 16px;border-radius:999px;cursor:pointer;
  font-family:var(--font-sans);font-size:11px;
  letter-spacing:.14em;text-transform:uppercase;
  color:var(--vinho-profundo);font-weight:500;
  transition:all var(--dur-fast) var(--ease-soft);
}
.blog-cats button:hover{border-color:var(--rosa-tempo);}
.blog-cats button[data-on="1"]{
  background:var(--rosa-tempo);color:var(--marfim-sereno);border-color:var(--rosa-tempo);
}

.blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:32px;}
.blog-card{
  background:#fff;border:1px solid var(--border);border-radius:var(--tk-radius);
  overflow:hidden;display:flex;flex-direction:column;
  transition:transform var(--dur-base) var(--ease-soft),box-shadow var(--dur-base) var(--ease-soft);
  cursor:pointer;
}
.blog-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md);}
.blog-card__media{position:relative;overflow:hidden;padding-bottom:75%;/* 4:3 */height:0;}
.blog-card__img,.blog-card__media img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center top;display:block;}
.blog-card__media .placeholder-img{position:absolute;inset:0;height:100%;}
.blog-card__body{padding:28px 28px 32px;display:flex;flex-direction:column;gap:12px;flex:1;}
.blog-card__meta{
  display:flex;gap:16px;align-items:center;
  font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--fg-muted);font-weight:500;
}
.blog-card__cat{color:var(--rosa-tempo);}
.blog-card h3{
  font-family:var(--font-display);font-size:20px;font-weight:400;
  letter-spacing:.02em;text-transform:none;
  line-height:1.25;margin:0;color:var(--vinho-profundo);
}
.blog-card p{font-size:14px;line-height:1.55;color:var(--fg-muted);margin:0;flex:1;}
.blog-card__more{
  display:inline-flex;align-items:center;gap:8px;margin-top:8px;
  font-size:11px;letter-spacing:.18em;text-transform:uppercase;
  color:var(--rosa-tempo);font-weight:500;
}

@media (max-width:1080px){.blog-grid{grid-template-columns:repeat(2,1fr);}}
@media (max-width:680px){.blog-grid{grid-template-columns:1fr;}}

/* ========================================================================
   RESULTADOS (VIDEO DEPOIMENTOS)
   ======================================================================== */
.video-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:28px;
  margin-top:8px;
}
.video-card{
  background:#fff;border-radius:var(--tk-radius);
  overflow:hidden;border:1px solid var(--border);
  box-shadow:var(--shadow-sm);
  display:flex;flex-direction:column;
  transition:transform var(--dur-fast) var(--ease-soft),box-shadow var(--dur-fast) var(--ease-soft);
}
.video-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-md);}
.video-card__player{
  position:relative;width:100%;
  padding-bottom:56.25%; /* 16:9 */
  background:var(--bg-soft);overflow:hidden;
}
.video-card__player iframe,
.video-card__player video{
  position:absolute;inset:0;width:100%;height:100%;
  border:0;object-fit:cover;
}
.video-card__player video{background:#000;}
.video-card__body{
  padding:20px 22px 22px;
  display:flex;flex-direction:column;gap:6px;
}
.video-card__name{
  font-family:var(--font-display);font-size:17px;font-weight:400;
  color:var(--vinho-profundo);letter-spacing:.02em;margin:0;
}
.video-card__tag{
  display:inline-block;font-size:10px;letter-spacing:.16em;
  text-transform:uppercase;color:var(--rosa-tempo);font-weight:500;margin:0;
}
.video-card__quote{
  font-size:13.5px;color:var(--fg-muted);line-height:1.55;margin:4px 0 0;
  font-style:italic;
}
/* Instagram Reels — portrait 9:16 */
.video-card--reel .video-card__player{padding-bottom:177.78%;}
@media (max-width:960px){.video-grid{grid-template-columns:repeat(2,1fr);}}
@media (max-width:600px){.video-grid{grid-template-columns:1fr;}}

/* ========================================================================
   CONTACT PAGE
   ======================================================================== */
.contact-grid{display:grid;grid-template-columns:1fr 1.1fr;gap:64px;}
.contact-info{display:flex;flex-direction:column;gap:24px;}
.contact-card{
  background:#fff;border:1px solid var(--border);border-radius:var(--tk-radius);
  padding:28px 32px;display:flex;gap:18px;align-items:flex-start;
}
.contact-card__icon{
  flex-shrink:0;width:48px;height:48px;border-radius:999px;
  background:var(--tk-primary-strong);color:var(--rosa-tempo);
  display:flex;align-items:center;justify-content:center;font-size:20px;
}
.contact-card h4{
  font-family:var(--font-sans);font-size:11px;letter-spacing:.18em;
  text-transform:uppercase;color:var(--accent-gold);margin:0 0 4px;font-weight:500;
}
.contact-card p,.contact-card a{
  margin:0;font-size:16px;color:var(--vinho-profundo);
  font-family:var(--font-display);letter-spacing:.02em;border-bottom:0;
}
.contact-card small{display:block;font-size:13px;color:var(--fg-muted);margin-top:4px;letter-spacing:.04em;}

.map{
  margin-top:48px;border-radius:var(--tk-radius);overflow:hidden;
  height:380px;background:var(--bg-soft);position:relative;
  border:1px solid var(--border);
}
.map .placeholder-img{height:100%;}
.map iframe{width:100%;height:100%;border:0;display:block;filter:saturate(.9) contrast(.96);}
.map__cta{
  position:absolute;left:20px;bottom:20px;z-index:2;
  display:inline-flex;align-items:center;gap:8px;
  padding:12px 18px;border-radius:999px;
  background:#fff;color:var(--vinho-profundo);
  font-family:var(--font-sans);font-size:12px;font-weight:600;
  letter-spacing:.14em;text-transform:uppercase;text-decoration:none;
  box-shadow:0 8px 24px -8px rgba(0,0,0,.25),0 2px 6px rgba(0,0,0,.08);
  transition:transform var(--dur-fast) var(--ease-soft),background var(--dur-fast) var(--ease-soft),color var(--dur-fast) var(--ease-soft);
}
.map__cta:hover{transform:translateY(-2px);background:var(--rosa-tempo);color:#fff;}
.map__cta svg{stroke-width:1.8;}

@media (max-width:960px){
  .contact-grid{grid-template-columns:1fr;gap:32px;}
}

/* ========================================================================
   SERVICE DETAIL DRAWER
   ======================================================================== */
.sv-drawer{
  position:fixed;inset:0;z-index:80;
  background:rgba(40,28,30,.55);
  display:flex;justify-content:flex-end;
  animation:fade-in var(--dur-base) var(--ease-out);
  backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);
}
.sv-drawer__panel{
  width:min(720px,96vw);height:100%;
  background:var(--marfim-sereno);
  overflow-y:auto;overflow-x:hidden;
  position:relative;
  animation:sv-slide-in .42s var(--ease-out);
  box-shadow:-32px 0 80px -20px rgba(40,28,30,.35);
}
@keyframes sv-slide-in{from{transform:translateX(40px);opacity:.4}to{transform:translateX(0);opacity:1}}

.sv-drawer__close{
  position:absolute;top:20px;right:20px;z-index:5;
  width:44px;height:44px;border-radius:999px;
  background:#fff;border:1px solid var(--border);cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  color:var(--vinho-profundo);
  box-shadow:var(--shadow-sm);
  transition:transform var(--dur-fast) var(--ease-soft),background var(--dur-fast) var(--ease-soft),color var(--dur-fast) var(--ease-soft);
}
.sv-drawer__close:hover{background:var(--rosa-tempo);color:#fff;transform:rotate(90deg);}

.sv-drawer__head{
  position:relative;
  padding:56px 64px 40px;
  background:linear-gradient(160deg, var(--tk-primary-strong) 0%, var(--marfim-sereno) 70%);
  border-bottom:1px solid var(--border);
}
.sv-drawer__num{
  position:absolute;top:56px;right:80px;
  font-family:var(--font-display);font-size:13px;letter-spacing:.22em;
  color:var(--accent-gold);font-weight:500;
}
.sv-drawer__icon{
  width:64px;height:64px;border-radius:999px;
  background:#fff;color:var(--rosa-tempo);
  display:flex;align-items:center;justify-content:center;
  margin-bottom:20px;
  box-shadow:var(--shadow-sm);
}
.sv-drawer__eyebrow{
  font-family:var(--font-sans);font-size:11px;letter-spacing:.22em;
  text-transform:uppercase;color:var(--rosa-tempo);font-weight:500;
}
.sv-drawer__head h2{
  font-family:var(--font-display);font-weight:300;font-style:italic;
  font-size:clamp(32px,4vw,46px);line-height:1.05;letter-spacing:.01em;
  color:var(--vinho-profundo);margin:8px 0 16px;text-wrap:balance;
}
.sv-drawer__tagline{
  font-family:var(--font-display);font-weight:400;
  font-size:18px;line-height:1.4;color:var(--vinho-profundo);
  margin:0;max-width:54ch;text-wrap:balance;
}

.sv-drawer__body{padding:48px 64px 56px;}
.sv-drawer__intro{
  font-size:17px;line-height:1.65;color:var(--fg-muted);
  margin:0 0 40px;max-width:60ch;
}

.sv-block{margin-bottom:40px;}
.sv-block:last-child{margin-bottom:0;}
.sv-block h3{
  font-family:var(--font-display);font-size:13px;font-weight:500;
  letter-spacing:.22em;text-transform:uppercase;
  color:var(--vinho-profundo);
  margin:0 0 18px;padding-bottom:12px;
  border-bottom:1px solid var(--border);
}
.sv-block > p{
  font-size:15px;line-height:1.65;color:var(--fg-muted);margin:0;
  max-width:62ch;
}

.sv-bullets{margin:0;padding:0;list-style:none;display:flex;flex-direction:column;gap:10px;}
.sv-bullets li{
  position:relative;padding-left:24px;font-size:15px;line-height:1.5;
  color:var(--vinho-profundo);
}
.sv-bullets li::before{
  content:"";position:absolute;left:0;top:10px;
  width:8px;height:8px;border-radius:50%;
  background:var(--rosa-tempo);
}

.sv-steps{margin:0;padding:0;list-style:none;display:flex;flex-direction:column;gap:20px;}
.sv-steps li{
  display:grid;grid-template-columns:auto 1fr;gap:20px;
  padding:20px 22px;background:#fff;border:1px solid var(--border);
  border-radius:calc(var(--tk-radius) * .7);
}
.sv-steps__n{
  font-family:var(--font-display);font-size:24px;font-weight:300;font-style:italic;
  color:var(--rosa-tempo);line-height:1;letter-spacing:.02em;align-self:start;
}
.sv-steps li strong{
  display:block;font-family:var(--font-display);font-size:16px;font-weight:500;
  letter-spacing:.04em;text-transform:uppercase;color:var(--vinho-profundo);
  margin-bottom:6px;
}
.sv-steps li p{font-size:14.5px;line-height:1.55;color:var(--fg-muted);margin:0;}

.sv-procs{display:grid;grid-template-columns:1fr 1fr;gap:14px;}
.sv-proc{
  padding:20px 22px;background:#fff;border:1px solid var(--border);
  border-radius:calc(var(--tk-radius) * .7);
}
.sv-proc strong{
  display:block;font-family:var(--font-display);font-size:15px;font-weight:500;
  letter-spacing:.04em;text-transform:uppercase;color:var(--vinho-profundo);
  margin-bottom:8px;
}
.sv-proc p{font-size:14px;line-height:1.55;color:var(--fg-muted);margin:0;}

.sv-checks{margin:0;padding:0;list-style:none;display:grid;grid-template-columns:1fr 1fr;gap:12px 24px;}
.sv-checks li{
  display:flex;align-items:flex-start;gap:10px;
  font-size:14.5px;line-height:1.5;color:var(--vinho-profundo);
}
.sv-checks li svg{
  flex:0 0 auto;margin-top:3px;color:var(--rosa-tempo);stroke-width:2.2;
}

.sv-meta{
  display:grid;grid-template-columns:auto 1fr;gap:14px 32px;
  padding:24px 28px;background:var(--bg-soft);
  border-radius:calc(var(--tk-radius) * .7);
  border:1px solid var(--border);
}
.sv-meta h3{display:none;}
.sv-meta > div{display:flex;flex-direction:column;gap:4px;}
.sv-meta__lbl{
  font-family:var(--font-sans);font-size:10.5px;letter-spacing:.22em;
  text-transform:uppercase;color:var(--accent-gold);font-weight:600;
}
.sv-meta strong{
  font-family:var(--font-display);font-size:16px;font-weight:400;
  color:var(--vinho-profundo);letter-spacing:.02em;
}
.sv-meta p{font-size:14px;line-height:1.55;color:var(--fg-muted);margin:0;}

.sv-drawer__foot{
  margin-top:48px;padding-top:32px;
  border-top:1px solid var(--border);
  display:flex;flex-wrap:wrap;gap:14px;
}

@media (max-width:760px){
  .sv-drawer__panel{width:100vw;}
  .sv-drawer__head{padding:64px 28px 32px;}
  .sv-drawer__num{top:24px;right:74px;}
  .sv-drawer__body{padding:36px 28px 48px;}
  .sv-procs,.sv-checks{grid-template-columns:1fr;}
  .sv-meta{grid-template-columns:1fr;gap:16px;padding:22px 22px;}
  .sv-drawer__head h2{font-size:30px;}
  .sv-drawer__tagline{font-size:16px;}
  .sv-drawer__foot{flex-direction:column;}
  .sv-drawer__foot .btn{width:100%;justify-content:center;}
}

/* ========================================================================
   ARTICLE DRAWER
   ======================================================================== */
.art-drawer{
  position:fixed;inset:0;z-index:80;
  background:rgba(40,28,30,.55);
  display:flex;justify-content:center;align-items:stretch;
  animation:fade-in var(--dur-base) var(--ease-out);
  backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);
  overflow-y:auto;
}
.art-drawer__panel{
  width:min(820px,100%);
  background:var(--marfim-sereno);
  position:relative;
  animation:art-fade-up .42s var(--ease-out);
  box-shadow:0 32px 80px -20px rgba(40,28,30,.35);
  margin:0 auto;
  max-height:none;
  overflow-x:hidden;
}
@keyframes art-fade-up{from{transform:translateY(24px);opacity:.4}to{transform:translateY(0);opacity:1}}

.art-drawer__close{
  position:fixed;top:24px;right:max(24px, calc(50vw - 410px + 24px));z-index:5;
  width:46px;height:46px;border-radius:999px;
  background:#fff;border:1px solid var(--border);cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  color:var(--vinho-profundo);
  box-shadow:0 8px 24px -8px rgba(40,28,30,.3);
  transition:transform var(--dur-fast) var(--ease-soft),background var(--dur-fast) var(--ease-soft),color var(--dur-fast) var(--ease-soft);
}
.art-drawer__close:hover{background:var(--rosa-tempo);color:#fff;transform:rotate(90deg);}

.art-drawer__hero{
  position:relative;height:clamp(280px,38vh,420px);
  overflow:hidden;background:var(--bg-soft);
}
.art-drawer__hero img{
  width:100%;height:100%;object-fit:cover;display:block;
}
.art-drawer__hero-overlay{
  position:absolute;inset:0;
  background:linear-gradient(180deg, rgba(40,28,30,.10) 0%, rgba(40,28,30,.30) 100%);
}

.art-drawer__head{
  padding:48px 72px 32px;
  border-bottom:1px solid var(--border);
}
.art-drawer__meta{
  display:flex;flex-wrap:wrap;gap:12px;
  font-family:var(--font-sans);font-size:11px;letter-spacing:.18em;
  text-transform:uppercase;color:var(--fg-muted);font-weight:500;
  margin-bottom:20px;
}
.art-drawer__cat{color:var(--rosa-tempo);}
.art-drawer__head h1{
  font-family:var(--font-display);font-weight:300;font-style:italic;
  font-size:clamp(30px,4vw,46px);line-height:1.1;letter-spacing:.01em;
  color:var(--vinho-profundo);margin:0 0 24px;text-wrap:balance;
}
.art-drawer__author{
  display:flex;flex-wrap:wrap;gap:8px;align-items:center;
  font-size:13.5px;color:var(--fg-muted);
}
.art-drawer__author strong{color:var(--vinho-profundo);font-weight:500;}
.art-drawer__sep{color:var(--border-strong, var(--border));}

.art-drawer__body{padding:40px 72px 56px;}
.art-drawer__lead{
  font-family:var(--font-display);font-weight:400;font-style:italic;
  font-size:20px;line-height:1.5;color:var(--vinho-profundo);
  margin:0 0 40px;text-wrap:pretty;
}

.art-drawer__section{margin-bottom:36px;}
.art-drawer__section:last-of-type{margin-bottom:0;}
.art-drawer__section h2{
  font-family:var(--font-display);font-size:22px;font-weight:400;
  letter-spacing:.01em;color:var(--vinho-profundo);
  margin:0 0 14px;line-height:1.25;
}
.art-drawer__section p{
  font-size:16px;line-height:1.7;color:var(--fg-muted);
  margin:0;max-width:64ch;text-wrap:pretty;
}

.art-drawer__cta{
  margin-top:56px;padding:36px 36px;
  background:var(--bg-soft);
  border-radius:var(--tk-radius);
  border:1px solid var(--border);
  border-left:3px solid var(--rosa-tempo);
}
.art-drawer__cta .eyebrow{display:block;margin-bottom:8px;}
.art-drawer__cta h3{
  font-family:var(--font-display);font-size:22px;font-weight:400;
  letter-spacing:.01em;color:var(--vinho-profundo);
  margin:0 0 8px;line-height:1.3;
}
.art-drawer__cta p{
  font-size:15px;line-height:1.6;color:var(--fg-muted);margin:0;
}

.art-drawer__foot{
  margin-top:48px;padding-top:24px;
  border-top:1px solid var(--border);
  display:flex;justify-content:space-between;align-items:center;
  flex-wrap:wrap;gap:12px;
  font-size:12.5px;color:var(--fg-muted);
}
.art-drawer__foot button{
  background:transparent;border:0;cursor:pointer;
  font-family:var(--font-sans);font-size:11px;letter-spacing:.18em;
  text-transform:uppercase;color:var(--rosa-tempo);font-weight:500;
}

@media (max-width:760px){
  .art-drawer__close{top:16px;right:16px;}
  .art-drawer__head{padding:36px 28px 24px;}
  .art-drawer__body{padding:32px 28px 48px;}
  .art-drawer__head h1{font-size:28px;}
  .art-drawer__lead{font-size:17px;}
  .art-drawer__section h2{font-size:19px;}
  .art-drawer__section p{font-size:15px;}
  .art-drawer__cta{padding:28px 24px;}
}

/* Make blog card "Ler artigo" a real button */
button.blog-card__more{
  background:transparent;border:0;padding:0;cursor:pointer;
  font-family:var(--font-sans);
}
button.blog-card__more:hover{color:var(--vinho-profundo);}
button.blog-card__more svg{transition:transform var(--dur-fast) var(--ease-soft);}
.blog-card:hover button.blog-card__more svg{transform:translateX(4px);}
