/* =========================================================
   Rose Santos Assolini — Nutrição Clínica e Oncológica
   Estilo do site  •  Paleta: verde sálvia #6D7955 + creme
   ========================================================= */

:root{
  --cream:      #F5F1E8;
  --cream-2:    #EFE9DC;
  --cream-3:    #E7DFCE;
  --sage:       #6D7955;
  --sage-soft:  #8A9472;
  --sage-deep:  #4D5739;
  --forest:     #262C1D;
  --forest-2:   #1C2116;
  --ink:        #2B2D24;
  --ink-soft:   #5A5C4F;
  --gold:       #B79B62;
  --line:       rgba(77,87,57,.18);
  --shadow:     0 24px 60px -28px rgba(38,44,29,.45);
  --shadow-sm:  0 12px 30px -18px rgba(38,44,29,.40);

  --font-display: "Cormorant Garamond", Georgia, serif;
  --font-sans:    "Jost", "Segoe UI", sans-serif;

  --maxw: 1200px;
  --radius: 22px;
}

*,*::before,*::after{ box-sizing:border-box; }

html{ scroll-behavior:smooth; }

body{
  margin:0;
  font-family:var(--font-sans);
  font-weight:300;
  color:var(--ink);
  background-color:var(--cream);
  background-image:
    radial-gradient(900px 500px at 85% -5%, rgba(109,121,85,.10), transparent 60%),
    radial-gradient(700px 600px at -10% 30%, rgba(109,121,85,.07), transparent 55%);
  line-height:1.7;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}

/* subtle paper grain */
body::before{
  content:"";
  position:fixed; inset:0; z-index:0; pointer-events:none;
  opacity:.035;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

img{ max-width:100%; display:block; }

a{ color:inherit; text-decoration:none; }

h1,h2,h3{
  font-family:var(--font-display);
  font-weight:500;
  line-height:1.08;
  letter-spacing:-.01em;
  color:var(--sage-deep);
  margin:0;
}

p{ margin:0 0 1rem; }

.wrap{ width:min(var(--maxw), calc(100% - 3rem)); margin-inline:auto; position:relative; z-index:1; }

/* ---------- Eyebrow label ---------- */
.eyebrow{
  font-family:var(--font-sans);
  font-weight:400;
  font-size:.74rem;
  letter-spacing:.34em;
  text-transform:uppercase;
  color:var(--sage);
  display:inline-flex; align-items:center; gap:.8rem;
  margin-bottom:1.1rem;
}
.eyebrow::before{
  content:""; width:34px; height:1px; background:var(--sage); display:inline-block; opacity:.6;
}
.eyebrow.center::after{
  content:""; width:34px; height:1px; background:var(--sage); display:inline-block; opacity:.6;
}

/* ---------- Buttons ---------- */
.btn{
  font-family:var(--font-sans);
  font-weight:400;
  font-size:.82rem;
  letter-spacing:.16em;
  text-transform:uppercase;
  display:inline-flex; align-items:center; gap:.6rem;
  padding:1rem 1.9rem;
  border-radius:100px;
  cursor:pointer;
  border:1px solid transparent;
  transition:transform .35s cubic-bezier(.2,.8,.2,1), background .35s, color .35s, box-shadow .35s;
  white-space:nowrap;
}
.btn-primary{
  background:var(--sage-deep); color:var(--cream);
  box-shadow:0 14px 30px -14px rgba(77,87,57,.7);
}
.btn-primary:hover{ background:var(--forest); transform:translateY(-3px); }
.btn-ghost{
  background:transparent; color:var(--sage-deep); border-color:var(--line);
}
.btn-ghost:hover{ border-color:var(--sage); transform:translateY(-3px); background:rgba(109,121,85,.06); }
.btn-light{
  background:var(--cream); color:var(--sage-deep);
}
.btn-light:hover{ transform:translateY(-3px); box-shadow:var(--shadow-sm); }
.btn svg{ width:17px; height:17px; }

/* ---------- Header ---------- */
.site-header{
  position:sticky; top:0; z-index:50;
  backdrop-filter:saturate(140%) blur(10px);
  background:rgba(245,241,232,.78);
  border-bottom:1px solid var(--line);
  transition:padding .3s;
}
.nav{
  display:flex; align-items:center; justify-content:space-between;
  padding:.85rem 0; gap:1.5rem;
}
.brand{ display:flex; align-items:center; gap:.7rem; }
.brand img{ height:42px; width:auto; }
.brand > span{ display:flex; flex-direction:column; justify-content:center; }
.brand .brand-name{
  display:block;
  font-family:var(--font-display); font-size:1.18rem; color:var(--sage-deep);
  line-height:1.05; letter-spacing:.02em; white-space:nowrap;
}
.brand .brand-sub{
  display:block;
  font-family:var(--font-sans); font-size:.56rem; letter-spacing:.24em;
  text-transform:uppercase; color:var(--sage); margin-top:4px; white-space:nowrap;
}
.nav-links{ display:flex; gap:2rem; align-items:center; }
.nav-links a{
  font-size:.8rem; letter-spacing:.12em; text-transform:uppercase; font-weight:400;
  color:var(--ink-soft); position:relative; padding:.3rem 0;
}
.nav-links a::after{
  content:""; position:absolute; left:0; bottom:0; height:1px; width:0; background:var(--sage);
  transition:width .35s;
}
.nav-links a:hover{ color:var(--sage-deep); }
.nav-links a:hover::after{ width:100%; }
.nav-cta{ display:flex; align-items:center; gap:1rem; }
.menu-toggle{ display:none; background:none; border:0; cursor:pointer; padding:.4rem; }
.menu-toggle span{ display:block; width:24px; height:2px; background:var(--sage-deep); margin:5px 0; transition:.3s; border-radius:2px; }

/* ---------- Hero ---------- */
.hero{ position:relative; padding:5.5rem 0 6rem; overflow:hidden; }
.hero-grid{
  display:grid; grid-template-columns:1.15fr .85fr; gap:3.5rem; align-items:center;
}
.hero h1{
  font-size:clamp(2.7rem, 6vw, 4.7rem);
  font-weight:500;
}
.hero h1 em{ font-style:italic; color:var(--sage); }
.hero-lead{
  font-size:1.12rem; color:var(--ink-soft); max-width:34rem; margin:1.6rem 0 2.3rem;
}
.hero-actions{ display:flex; gap:1rem; flex-wrap:wrap; }
.hero-trust{
  margin-top:2.6rem; display:flex; gap:2.2rem; flex-wrap:wrap;
  border-top:1px solid var(--line); padding-top:1.6rem;
}
.hero-trust div span{ font-family:var(--font-display); font-size:1.9rem; color:var(--sage-deep); display:block; line-height:1; }
.hero-trust div small{ font-size:.72rem; letter-spacing:.14em; text-transform:uppercase; color:var(--ink-soft); }

/* Hero visual (symbol medallion) */
.hero-visual{ position:relative; display:flex; align-items:center; justify-content:center; min-height:380px; }
.medallion{
  position:relative; width:min(420px, 90%); aspect-ratio:1;
  border-radius:50%;
  background:
    radial-gradient(circle at 30% 25%, rgba(255,255,255,.5), transparent 55%),
    linear-gradient(150deg, var(--cream-2), var(--cream-3));
  box-shadow: var(--shadow), inset 0 2px 10px rgba(255,255,255,.6);
  display:flex; align-items:center; justify-content:center;
  border:1px solid rgba(255,255,255,.6);
}
.medallion::after{
  content:""; position:absolute; inset:18px; border-radius:50%;
  border:1px dashed rgba(109,121,85,.35);
}
.medallion img{ width:58%; position:relative; z-index:2; }
.leaf-blob{ position:absolute; border-radius:50%; filter:blur(2px); opacity:.5; z-index:0; }
.leaf-blob.b1{ width:120px; height:120px; background:rgba(109,121,85,.25); top:-20px; right:30px; }
.leaf-blob.b2{ width:80px; height:80px; background:rgba(183,155,98,.20); bottom:10px; left:0; }

/* ---------- Section base ---------- */
section{ position:relative; padding:5.5rem 0; }
.section-head{ max-width:42rem; }
.section-head.center{ margin-inline:auto; text-align:center; }
.section-head h2{ font-size:clamp(2rem,4vw,3rem); margin-bottom:.6rem; }
.section-head p{ color:var(--ink-soft); font-size:1.05rem; }

/* alt background band */
.band{ background:var(--cream-2); }
.band-deep{
  background:var(--forest);
  color:var(--cream);
}
.band-deep h2,.band-deep h3{ color:var(--cream); }
.band-deep .eyebrow{ color:var(--sage-soft); }
.band-deep .eyebrow::before,.band-deep .eyebrow.center::after{ background:var(--sage-soft); }
.band-deep p{ color:rgba(245,241,232,.78); }

/* ---------- About ---------- */
.about-grid{ display:grid; grid-template-columns:.9fr 1.1fr; gap:3.5rem; align-items:center; }
.about-photo{
  position:relative; border-radius:var(--radius); overflow:hidden;
  aspect-ratio:4/5; background:linear-gradient(160deg,var(--cream-3),var(--sage-soft));
  display:flex; align-items:center; justify-content:center; box-shadow:var(--shadow);
}
.about-photo img{ width:100%; height:100%; object-fit:cover; }
.about-photo .ph-note{
  position:absolute; text-align:center; color:var(--sage-deep); padding:1rem;
  font-size:.8rem; letter-spacing:.05em;
}
.about-photo .ph-note strong{ display:block; font-family:var(--font-display); font-size:1.3rem; margin-bottom:.4rem; }
.chips{ display:flex; flex-wrap:wrap; gap:.6rem; margin-top:1.6rem; }
.chip{
  font-size:.74rem; letter-spacing:.1em; text-transform:uppercase; color:var(--sage-deep);
  border:1px solid var(--line); padding:.5rem .9rem; border-radius:100px; background:rgba(255,255,255,.4);
}

/* ---------- Services ---------- */
.cards{ display:grid; grid-template-columns:repeat(3,1fr); gap:1.4rem; margin-top:3rem; }
.card{
  background:rgba(255,255,255,.55);
  border:1px solid var(--line);
  border-radius:var(--radius);
  padding:2.1rem 1.8rem;
  transition:transform .4s cubic-bezier(.2,.8,.2,1), box-shadow .4s, background .4s;
}
.card:hover{ transform:translateY(-6px); box-shadow:var(--shadow); background:#fff; }
.card .ic{
  width:54px; height:54px; border-radius:14px;
  background:rgba(109,121,85,.12); color:var(--sage-deep);
  display:flex; align-items:center; justify-content:center; margin-bottom:1.2rem;
}
.card .ic svg{ width:26px; height:26px; }
.card h3{ font-size:1.5rem; margin-bottom:.5rem; color:var(--sage-deep); }
.card p{ font-size:.97rem; color:var(--ink-soft); margin:0; }

/* ---------- Process ---------- */
.steps{ display:grid; grid-template-columns:repeat(4,1fr); gap:1.4rem; margin-top:3rem; }
.step{ position:relative; padding-top:1rem; }
.step .num{
  font-family:var(--font-display); font-size:2.6rem; color:var(--sage-soft); line-height:1;
  display:block; margin-bottom:.6rem;
}
.step h3{ font-size:1.35rem; color:var(--cream); margin-bottom:.4rem; }
.step p{ font-size:.95rem; }

/* ---------- Packages teaser ---------- */
.teaser{
  background:linear-gradient(140deg, var(--sage-deep), var(--forest));
  color:var(--cream); border-radius:var(--radius); padding:3.5rem clamp(1.6rem,5vw,4rem);
  display:grid; grid-template-columns:1.4fr .9fr; gap:2.5rem; align-items:center; box-shadow:var(--shadow);
  position:relative; overflow:hidden;
}
.teaser h2{ color:var(--cream); font-size:clamp(2rem,4vw,2.8rem); }
.teaser p{ color:rgba(245,241,232,.82); margin:1rem 0 0; }
.teaser .eyebrow{ color:var(--sage-soft); }
.teaser .eyebrow::before{ background:var(--sage-soft); }
.teaser .teaser-cta{ justify-self:end; }
.teaser-bg{ position:absolute; right:-40px; bottom:-60px; width:280px; opacity:.10; }

/* ---------- Testimonials ---------- */
.quotes{ display:grid; grid-template-columns:repeat(3,1fr); gap:1.4rem; margin-top:3rem; }
.quote{ background:rgba(255,255,255,.55); border:1px solid var(--line); border-radius:var(--radius); padding:2rem; }
.quote .mark{ font-family:var(--font-display); font-size:3rem; color:var(--sage-soft); line-height:.4; }
.quote p{ font-family:var(--font-display); font-size:1.25rem; font-style:italic; color:var(--ink); margin:1rem 0; }
.quote .who{ font-size:.78rem; letter-spacing:.12em; text-transform:uppercase; color:var(--sage); }

/* ---------- Contact ---------- */
.contact-grid{ display:grid; grid-template-columns:1fr 1fr; gap:2.5rem; align-items:center; }
.contact-list{ display:flex; flex-direction:column; gap:1.1rem; margin-top:1.8rem; }
.contact-item{ display:flex; align-items:center; gap:1rem; }
.contact-item .ic{
  width:46px; height:46px; border-radius:12px; background:rgba(109,121,85,.12); color:var(--sage-deep);
  display:flex; align-items:center; justify-content:center; flex-shrink:0;
}
.contact-item .ic svg{ width:21px; height:21px; }
.contact-item small{ display:block; font-size:.7rem; letter-spacing:.16em; text-transform:uppercase; color:var(--sage); }
.contact-item span{ font-size:1.05rem; color:var(--ink); }
.contact-card{
  background:var(--forest); color:var(--cream); border-radius:var(--radius);
  padding:3rem; box-shadow:var(--shadow); text-align:center;
}
.contact-card h3{ color:var(--cream); font-size:2rem; margin-bottom:.6rem; }
.contact-card p{ color:rgba(245,241,232,.78); margin-bottom:1.8rem; }

/* ---------- Footer ---------- */
.site-footer{
  background:var(--forest-2); color:rgba(245,241,232,.7);
  padding:4rem 0 2rem; position:relative; overflow:hidden;
}
.footer-pattern{ position:absolute; inset:0; opacity:.05; background-size:340px; }
.footer-grid{ display:grid; grid-template-columns:1.4fr 1fr 1fr; gap:2.5rem; position:relative; z-index:1; }
.site-footer img.flogo{ height:78px; margin-bottom:1.2rem; }
.site-footer h4{ font-family:var(--font-sans); font-size:.78rem; letter-spacing:.2em; text-transform:uppercase; color:var(--sage-soft); margin:0 0 1rem; }
.site-footer a{ color:rgba(245,241,232,.7); transition:color .3s; }
.site-footer a:hover{ color:var(--cream); }
.footer-links{ display:flex; flex-direction:column; gap:.6rem; font-size:.95rem; }
.footer-bottom{
  border-top:1px solid rgba(245,241,232,.12); margin-top:2.6rem; padding-top:1.6rem;
  display:flex; justify-content:space-between; gap:1rem; flex-wrap:wrap;
  font-size:.8rem; position:relative; z-index:1;
}
.disclaimer{
  font-size:.8rem; color:rgba(245,241,232,.5); max-width:46rem; margin-top:1rem;
  position:relative; z-index:1; line-height:1.6;
}

/* ---------- Page hero (pacotes) ---------- */
.page-hero{ padding:4.5rem 0 2rem; text-align:center; }
.page-hero h1{ font-size:clamp(2.4rem,5vw,3.8rem); }
.page-hero p{ color:var(--ink-soft); max-width:38rem; margin:1.2rem auto 0; font-size:1.08rem; }

/* ---------- Pricing ---------- */
.pricing{ display:grid; grid-template-columns:repeat(3,1fr); gap:1.6rem; margin-top:3rem; align-items:stretch; }
.price-card{
  background:rgba(255,255,255,.6); border:1px solid var(--line); border-radius:var(--radius);
  padding:2.4rem 2rem; display:flex; flex-direction:column; position:relative;
  transition:transform .4s cubic-bezier(.2,.8,.2,1), box-shadow .4s;
}
.price-card:hover{ transform:translateY(-6px); box-shadow:var(--shadow); }
.price-card.featured{ background:var(--forest); color:var(--cream); border-color:var(--forest); transform:scale(1.02); }
.price-card.featured:hover{ transform:scale(1.02) translateY(-6px); }
.price-card.featured h3,.price-card.featured .price{ color:var(--cream); }
.price-card.featured .feat-list li{ color:rgba(245,241,232,.85); }
.price-card.featured .feat-list svg{ color:var(--sage-soft); }
.badge{
  position:absolute; top:-13px; left:50%; transform:translateX(-50%);
  background:var(--gold); color:var(--forest); font-size:.66rem; letter-spacing:.18em;
  text-transform:uppercase; padding:.45rem 1.1rem; border-radius:100px; font-weight:500;
}
.price-card .tier{ font-size:.74rem; letter-spacing:.2em; text-transform:uppercase; color:var(--sage); margin-bottom:.4rem; }
.price-card.featured .tier{ color:var(--sage-soft); }
.price-card h3{ font-size:1.9rem; margin-bottom:.8rem; }
.price{ font-family:var(--font-display); font-size:2.8rem; color:var(--sage-deep); line-height:1; margin-bottom:.2rem; }
.price small{ font-family:var(--font-sans); font-size:.8rem; letter-spacing:.06em; color:var(--ink-soft); }
.price-card.featured .price small{ color:rgba(245,241,232,.6); }
.price-note{ font-size:.86rem; color:var(--ink-soft); margin-bottom:1.4rem; }
.price-card.featured .price-note{ color:rgba(245,241,232,.65); }
.feat-list{ list-style:none; padding:0; margin:0 0 1.8rem; display:flex; flex-direction:column; gap:.75rem; flex:1; }
.feat-list li{ display:flex; gap:.7rem; font-size:.96rem; color:var(--ink-soft); align-items:flex-start; }
.feat-list svg{ width:18px; height:18px; color:var(--sage); flex-shrink:0; margin-top:3px; }
.price-card .btn{ width:100%; justify-content:center; }

/* ---------- FAQ ---------- */
.faq{ max-width:46rem; margin:3rem auto 0; }
.faq details{
  border-bottom:1px solid var(--line); padding:1.3rem 0;
}
.faq summary{
  font-family:var(--font-display); font-size:1.4rem; color:var(--sage-deep); cursor:pointer;
  list-style:none; display:flex; justify-content:space-between; align-items:center; gap:1rem;
}
.faq summary::-webkit-details-marker{ display:none; }
.faq summary::after{ content:"+"; font-size:1.6rem; color:var(--sage); transition:transform .3s; font-family:var(--font-sans); }
.faq details[open] summary::after{ transform:rotate(45deg); }
.faq details p{ color:var(--ink-soft); margin:.9rem 0 0; font-size:1rem; }

/* ---------- Reveal animation ---------- */
.reveal{ opacity:0; transform:translateY(26px); transition:opacity .8s ease, transform .8s cubic-bezier(.2,.8,.2,1); }
.reveal.in{ opacity:1; transform:none; }
.reveal.d1{ transition-delay:.08s; }
.reveal.d2{ transition-delay:.16s; }
.reveal.d3{ transition-delay:.24s; }
.reveal.d4{ transition-delay:.32s; }

/* ---------- WhatsApp float ---------- */
.wa-float{
  position:fixed; right:22px; bottom:22px; z-index:60;
  width:58px; height:58px; border-radius:50%; background:#25D366;
  display:flex; align-items:center; justify-content:center; box-shadow:0 12px 28px -8px rgba(0,0,0,.4);
  transition:transform .3s;
}
.wa-float:hover{ transform:scale(1.08); }
.wa-float svg{ width:30px; height:30px; fill:#fff; }

/* ---------- Responsive ---------- */
@media (max-width:980px){
  .hero-grid,.about-grid,.contact-grid,.teaser{ grid-template-columns:1fr; }
  .hero-visual{ order:-1; min-height:auto; }
  .medallion{ width:min(320px,80%); }
  .cards,.quotes,.pricing{ grid-template-columns:1fr 1fr; }
  .steps{ grid-template-columns:1fr 1fr; }
  .price-card.featured{ transform:none; }
  .teaser .teaser-cta{ justify-self:start; }
  .footer-grid{ grid-template-columns:1fr 1fr; }
}
@media (max-width:680px){
  .wrap{ width:calc(100% - 2.2rem); }
  .brand img{ height:36px; }
  .brand .brand-name{ font-size:1.02rem; }
  .brand .brand-sub{ font-size:.5rem; letter-spacing:.18em; }
  .nav-links{
    position:fixed; inset:0 0 0 auto; width:min(78%,320px);
    background:var(--cream); flex-direction:column; align-items:flex-start;
    padding:5rem 2rem; gap:1.4rem; transform:translateX(100%); transition:transform .4s; box-shadow:var(--shadow);
  }
  .nav-links.open{ transform:none; }
  .menu-toggle{ display:block; z-index:51; }
  .nav .desktop-cta{ display:none; }
  .cards,.quotes,.pricing,.steps,.footer-grid{ grid-template-columns:1fr; }
  section{ padding:3.8rem 0; }
  .hero{ padding:3rem 0 4rem; }
  .teaser{ padding:2.4rem; }
  .contact-card,.contact-list{ padding:0; }
  .contact-card{ padding:2.2rem; }
  .footer-bottom{ flex-direction:column; }
}

/* =========================================================
   Fotos da profissional (hero, sobre, contato)
   ========================================================= */
.hero-portrait{ position:relative; width:min(410px,86%); }
.hero-portrait::before{
  content:""; position:absolute; inset:-15px;
  border:1px solid rgba(109,121,85,.45);
  border-radius:236px 236px 34px 34px; pointer-events:none;
}
.hp-frame{
  position:relative; aspect-ratio:4/5;
  border-radius:224px 224px 24px 24px; overflow:hidden; box-shadow:var(--shadow);
  background:linear-gradient(160deg,var(--cream-3),var(--sage-soft));
}
.hp-frame img{ width:100%; height:100%; object-fit:cover; object-position:center 16%; }
.hp-frame::after{ content:""; position:absolute; inset:0; box-shadow:inset 0 -55px 70px -42px rgba(38,44,29,.4); }
.sym-badge{
  position:absolute; bottom:-24px; left:50%; transform:translateX(-50%);
  width:72px; height:72px; border-radius:50%; background:var(--cream);
  display:flex; align-items:center; justify-content:center;
  box-shadow:var(--shadow-sm); border:1px solid var(--line); z-index:4;
}
.sym-badge img{ width:62%; }

/* Sobre: enquadramento do rosto */
.about-photo img{ object-position:center 14%; }

/* Card de contato com foto + sobreposição */
.contact-photo{
  position:relative; border-radius:var(--radius); overflow:hidden;
  min-height:460px; display:flex; align-items:flex-end; box-shadow:var(--shadow);
}
.contact-photo img{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; object-position:center 18%; }
.contact-photo .overlay{
  position:relative; z-index:2; width:100%; padding:2.4rem;
  background:linear-gradient(to top, rgba(28,33,22,.94), rgba(28,33,22,.5) 55%, rgba(28,33,22,0));
  color:var(--cream);
}
.contact-photo h3{ color:var(--cream); font-size:2rem; margin-bottom:.5rem; }
.contact-photo p{ color:rgba(245,241,232,.86); margin-bottom:1.3rem; }

@media (max-width:980px){
  .hero-portrait{ width:min(330px,72%); margin-inline:auto; }
}
