/* ============================================================
   Fagian — Additional sections (Processo, Pacotes, FAQ,
   Bastidores, Reserva, Hospitais, Atendimento icons)
   ============================================================ */

/* ===== O PROCESSO ===== */
.proc {
  background: var(--color-cream);
  padding: var(--section-gap) 0;
  border-top: 1px solid var(--color-rule);
}
.proc__head {
  max-width: 1680px;
  margin: 0 auto var(--space-16);
  padding: 0 var(--space-8);
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-12);
  align-items: end;
}
.proc__title { max-width: 14ch; }
.proc__intro { color: var(--color-muted); max-width: 44ch; }
.proc__steps {
  max-width: 1680px;
  margin: 0 auto;
  padding: 0 var(--space-8);
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 0;
  border-top: 1px solid var(--color-rule);
  border-bottom: 1px solid var(--color-rule);
}
.proc__step {
  padding: var(--space-12) var(--space-6) var(--space-12) 0;
  border-right: 1px solid var(--color-rule);
  position: relative;
  transition: background 600ms ease;
}
.proc__step:last-child { border-right: 0; }
.proc__step:hover { background: rgba(184, 90, 44, 0.04); }
.proc__step__num {
  font-size: 12px;
  letter-spacing: var(--tracking-xloose);
  color: var(--color-terracotta);
  margin-bottom: var(--space-6);
}
.proc__step__title {
  font-size: clamp(20px, 1.8vw, 26px);
  font-weight: 300;
  letter-spacing: -0.01em;
  line-height: 1.15;
  margin-bottom: var(--space-4);
  max-width: 14ch;
}
.proc__step__body {
  font-size: 14px;
  line-height: 1.6;
  color: var(--color-ink-soft);
  font-weight: 300;
  max-width: 32ch;
}
@media (max-width: 880px) {
  .proc__head { grid-template-columns: 1fr; }
  .proc__steps { grid-template-columns: 1fr; }
  .proc__step { border-right: 0; border-bottom: 1px solid var(--color-rule); padding-right: 0; }
  .proc__step:last-child { border-bottom: 0; }
}

/* ===== PACOTES ===== */
.pkg {
  background: var(--color-paper);
  padding: var(--section-gap) 0;
}
.pkg__head {
  max-width: 1480px;
  margin: 0 auto var(--space-16);
  padding: 0 var(--space-8);
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-12);
  align-items: end;
}
.pkg__title { max-width: 14ch; }
.pkg__intro { color: var(--color-muted); max-width: 44ch; }
.pkg__grid {
  max-width: 1480px;
  margin: 0 auto;
  padding: 0 var(--space-8);
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-8);
}
.pkg__card {
  background: var(--color-cream);
  padding: var(--space-12);
  display: flex;
  flex-direction: column;
  border: 1px solid var(--color-rule);
  transition: border-color 400ms ease;
  position: relative;
  overflow: hidden;
}
.pkg__card:hover { border-color: var(--color-ink); }
.pkg__card__num {
  position: absolute;
  top: var(--space-6); right: var(--space-6);
  font-size: 11px;
  letter-spacing: var(--tracking-xloose);
  color: var(--color-muted);
}
.pkg__card__eyebrow {
  font-size: 11px;
  letter-spacing: var(--tracking-xloose);
  text-transform: uppercase;
  color: var(--color-terracotta);
  margin-bottom: var(--space-5);
}
.pkg__card__title {
  font-size: clamp(28px, 3vw, 44px);
  font-weight: 300;
  letter-spacing: -0.015em;
  line-height: 1.05;
  margin-bottom: var(--space-5);
  max-width: 12ch;
}
.pkg__card__lede {
  font-size: 15px;
  line-height: 1.6;
  color: var(--color-ink-soft);
  font-weight: 300;
  margin-bottom: var(--space-8);
  max-width: 42ch;
}
.pkg__card__list {
  list-style: none;
  padding: 0;
  margin: 0 0 var(--space-10);
  border-top: 1px solid var(--color-rule);
}
.pkg__card__list li {
  display: grid;
  grid-template-columns: 24px 1fr;
  gap: var(--space-3);
  padding: var(--space-4) 0;
  border-bottom: 1px solid var(--color-rule);
  font-size: 14px;
  line-height: 1.55;
  font-weight: 300;
  color: var(--color-ink);
}
.pkg__card__list li::before {
  content: "+";
  color: var(--color-terracotta);
  font-weight: 400;
  line-height: 1.55;
}
.pkg__card__price {
  margin-top: auto;
  padding-top: var(--space-6);
  border-top: 1px solid var(--color-rule);
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: var(--space-4);
}
.pkg__card__price__label {
  font-size: 11px;
  letter-spacing: var(--tracking-xloose);
  text-transform: uppercase;
  color: var(--color-muted);
}
.pkg__card__price__value {
  font-size: 14px;
  letter-spacing: var(--tracking-loose);
  text-transform: uppercase;
  color: var(--color-ink);
}
.pkg__card__cta {
  margin-top: var(--space-6);
  display: inline-flex;
  align-items: center;
  gap: var(--space-3);
  padding: 14px 20px;
  background: var(--color-ink);
  color: var(--color-cream);
  font-size: 11px;
  letter-spacing: var(--tracking-loose);
  text-transform: uppercase;
  transition: background 300ms ease;
  align-self: flex-start;
}
.pkg__card__cta:hover { background: var(--color-terracotta); }
@media (max-width: 880px) {
  .pkg__head { grid-template-columns: 1fr; }
  .pkg__grid { grid-template-columns: 1fr; }
}

/* ===== FAQ ===== */
.faq {
  background: var(--color-cream);
  padding: var(--section-gap) 0;
}
.faq__inner {
  max-width: 1240px;
  margin: 0 auto;
  padding: 0 var(--space-8);
  display: grid;
  grid-template-columns: 1fr 1.4fr;
  gap: var(--space-16);
  align-items: start;
}
.faq__title {
  position: sticky;
  top: 100px;
  max-width: 12ch;
}
.faq__sub {
  color: var(--color-muted);
  max-width: 32ch;
  margin-top: var(--space-5);
  font-weight: 300;
}
.faq__list {
  list-style: none;
  padding: 0;
  margin: 0;
  border-top: 1px solid var(--color-rule);
}
.faq__item {
  border-bottom: 1px solid var(--color-rule);
}
.faq__q {
  width: 100%;
  display: grid;
  grid-template-columns: 1fr auto;
  gap: var(--space-6);
  padding: var(--space-6) 0;
  text-align: left;
  font-size: clamp(17px, 1.4vw, 22px);
  font-weight: 400;
  letter-spacing: -0.005em;
  line-height: 1.3;
  color: var(--color-ink);
  transition: color 300ms ease;
}
.faq__q:hover { color: var(--color-terracotta); }
.faq__q__icon {
  width: 24px; height: 24px;
  position: relative;
  flex-shrink: 0;
  align-self: center;
}
.faq__q__icon::before,
.faq__q__icon::after {
  content: "";
  position: absolute;
  top: 50%; left: 0;
  width: 100%;
  height: 1px;
  background: currentColor;
  transition: transform 400ms cubic-bezier(.2,.7,.2,1);
}
.faq__q__icon::after { transform: rotate(90deg); }
.faq__item.is-open .faq__q__icon::after { transform: rotate(0deg); }
.faq__a {
  max-height: 0;
  overflow: hidden;
  transition: max-height 600ms cubic-bezier(.2,.7,.2,1), opacity 400ms ease, padding 400ms ease;
  opacity: 0;
  padding: 0;
}
.faq__item.is-open .faq__a {
  max-height: 600px;
  opacity: 1;
  padding: 0 0 var(--space-8) 0;
}
.faq__a p {
  font-size: 15px;
  line-height: 1.65;
  font-weight: 300;
  color: var(--color-ink-soft);
  max-width: 56ch;
}
.faq__a p + p { margin-top: var(--space-3); }
@media (max-width: 880px) {
  .faq__inner { grid-template-columns: 1fr; gap: var(--space-10); }
  .faq__title { position: static; }
}

/* ===== BASTIDORES ===== */
.behind {
  background: var(--color-ink);
  color: var(--color-cream);
  padding: var(--section-gap) 0;
  overflow: hidden;
}
.behind__inner {
  max-width: 1480px;
  margin: 0 auto;
  padding: 0 var(--space-8);
  display: grid;
  grid-template-columns: 1fr 1.05fr;
  gap: var(--space-20);
  align-items: center;
}
.behind__copy { display: grid; gap: var(--space-6); }
.behind__copy h2 {
  letter-spacing: -0.015em;
  font-weight: 300;
  max-width: 16ch;
}
.behind__copy p {
  color: rgba(241, 235, 222, 0.78);
  max-width: 44ch;
  font-size: clamp(15px, 1.1vw, 17px);
  line-height: 1.65;
  font-weight: 300;
}
.behind__list {
  margin-top: var(--space-6);
  display: grid;
  gap: var(--space-3);
  border-top: 1px solid rgba(241, 235, 222, 0.18);
  padding-top: var(--space-6);
}
.behind__list span {
  font-size: 11px;
  letter-spacing: var(--tracking-loose);
  text-transform: uppercase;
  color: rgba(241, 235, 222, 0.7);
  display: grid;
  grid-template-columns: 24px 1fr;
  gap: var(--space-3);
}
.behind__list span::before {
  content: "—";
  color: var(--color-terracotta);
}
.behind__media {
  display: grid;
  grid-template-columns: 1.4fr 1fr;
  grid-template-rows: 1fr 1fr;
  gap: var(--space-3);
  aspect-ratio: 5 / 4;
}
.behind__media figure {
  margin: 0;
  overflow: hidden;
  background: #1a1714;
}
.behind__media figure img {
  width: 100%; height: 100%;
  object-fit: cover;
  filter: grayscale(0.4) brightness(0.95);
  transition: transform 1.2s cubic-bezier(.2,.7,.2,1), filter 600ms ease;
}
.behind__media figure:hover img { transform: scale(1.04); filter: grayscale(0) brightness(1); }
.behind__media figure:nth-child(1) { grid-row: 1 / span 2; }
@media (max-width: 880px) {
  .behind__inner { grid-template-columns: 1fr; gap: var(--space-10); }
  .behind__media { aspect-ratio: 16/10; }
}

/* ===== HOSPITAIS ===== */
.hosp {
  background: var(--color-paper);
  padding: var(--space-20) 0;
  border-top: 1px solid var(--color-rule);
  border-bottom: 1px solid var(--color-rule);
}
.hosp__inner {
  max-width: 1480px;
  margin: 0 auto;
  padding: 0 var(--space-8);
  display: grid;
  grid-template-columns: 220px 1fr;
  gap: var(--space-12);
  align-items: center;
}
.hosp__label {
  font-size: 11px;
  letter-spacing: var(--tracking-xloose);
  text-transform: uppercase;
  color: var(--color-muted);
  line-height: 1.5;
  max-width: 18ch;
}
.hosp__label strong {
  display: block;
  color: var(--color-ink);
  font-weight: 400;
  font-size: 13px;
  margin-bottom: 6px;
}
.hosp__row {
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  gap: var(--space-6);
  align-items: center;
}
.hosp__logo {
  display: flex;
  align-items: center;
  justify-content: center;
  height: 56px;
  filter: grayscale(1) opacity(0.55);
  transition: filter 400ms ease;
}
.hosp__logo:hover { filter: grayscale(0) opacity(1); }
.hosp__logo img {
  max-width: 100%;
  max-height: 100%;
  object-fit: contain;
}
@media (max-width: 880px) {
  .hosp__inner { grid-template-columns: 1fr; gap: var(--space-6); }
  .hosp__row { grid-template-columns: repeat(3, 1fr); gap: var(--space-4); }
}

/* ===== RESERVA (form) ===== */
.resv {
  background: var(--color-cream);
  padding: 0 0 var(--space-24);
}
.resv__inner {
  max-width: 1240px;
  margin: 0 auto;
  padding: 0 var(--space-8);
  display: grid;
  grid-template-columns: 1fr 1.1fr;
  gap: var(--space-16);
  align-items: start;
}
.resv__copy h2 {
  font-weight: 300;
  letter-spacing: -0.02em;
  max-width: 12ch;
}
.resv__copy p {
  margin-top: var(--space-6);
  color: var(--color-muted);
  max-width: 40ch;
  font-size: clamp(15px, 1.1vw, 17px);
  line-height: 1.65;
  font-weight: 300;
}
.resv__form {
  display: grid;
  gap: var(--space-5);
  border-top: 1px solid var(--color-rule);
  padding-top: var(--space-8);
}
.resv__field {
  display: grid;
  gap: var(--space-2);
}
.resv__field label {
  font-size: 11px;
  letter-spacing: var(--tracking-xloose);
  text-transform: uppercase;
  color: var(--color-muted);
}
.resv__field input,
.resv__field select {
  font: inherit;
  font-size: 16px;
  font-weight: 300;
  color: var(--color-ink);
  background: transparent;
  border: 0;
  border-bottom: 1px solid var(--color-rule);
  padding: var(--space-3) 0;
  outline: none;
  transition: border-color 300ms ease;
  font-family: inherit;
  width: 100%;
}
.resv__field input::placeholder { color: rgba(12,10,8,0.35); }
.resv__field input:focus,
.resv__field select:focus { border-bottom-color: var(--color-ink); }
.resv__field--row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-6);
}
.resv__submit {
  margin-top: var(--space-4);
  display: inline-flex;
  align-items: center;
  justify-content: space-between;
  padding: 18px 24px;
  background: var(--color-ink);
  color: var(--color-cream);
  font-size: 12px;
  letter-spacing: var(--tracking-loose);
  text-transform: uppercase;
  transition: background 300ms ease;
}
.resv__submit:hover { background: var(--color-terracotta); }
.resv__submit__arrow { opacity: 0.7; }
.resv__hint {
  font-size: 11px;
  letter-spacing: var(--tracking-loose);
  text-transform: uppercase;
  color: var(--color-muted);
  margin-top: var(--space-2);
}
@media (max-width: 880px) {
  .resv__inner { grid-template-columns: 1fr; gap: var(--space-8); }
  .resv__field--row { grid-template-columns: 1fr; }
}

/* ===== ATENDIMENTO icon buttons (replaces plain links) ===== */
.atend {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-4);
  margin-top: var(--space-4);
}
.atend__card {
  display: grid;
  grid-template-columns: 44px 1fr auto;
  gap: var(--space-4);
  align-items: center;
  padding: var(--space-5) var(--space-5);
  border: 1px solid rgba(241,235,222,0.2);
  color: var(--color-cream);
  transition: border-color 300ms ease, background 300ms ease, padding 300ms cubic-bezier(.2,.7,.2,1);
}
.atend__card:hover {
  border-color: var(--color-cream);
  background: rgba(241,235,222,0.04);
  padding-left: calc(var(--space-5) + 6px);
}
.atend__icon {
  width: 44px; height: 44px;
  display: grid;
  place-items: center;
  background: var(--color-terracotta);
  color: var(--color-cream);
  border-radius: 999px;
  transition: background 300ms ease, transform 600ms cubic-bezier(.2,.7,.2,1);
}
.atend__card:hover .atend__icon {
  background: var(--color-cream);
  color: var(--color-ink);
}
.atend__icon svg {
  width: 22px; height: 22px;
  display: block;
}
.atend__main {
  display: flex;
  flex-direction: column;
  gap: 2px;
  min-width: 0;
}
.atend__handle {
  font-size: 15px;
  font-weight: 400;
  letter-spacing: -0.005em;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.atend__label {
  font-size: 10px;
  letter-spacing: var(--tracking-xloose);
  text-transform: uppercase;
  color: rgba(241,235,222,0.55);
}
.atend__arrow {
  font-size: 16px;
  opacity: 0.6;
  transition: transform 300ms ease, opacity 300ms ease;
}
.atend__card:hover .atend__arrow {
  opacity: 1;
  transform: translate(2px, -2px);
}
@media (max-width: 720px) {
  .atend { grid-template-columns: 1fr; }
}

/* Override contact section: replace .contact__link pattern with .atend cards
   (keep existing classes intact, we render new markup in the section.) */
.contact__col h4 + .atend { margin-top: var(--space-2); }

/* ===== HERO LOGO MARK ===== */
.hero__mark {
  position: absolute;
  top: calc(var(--space-32) - 32px);
  left: var(--space-8);
  width: 140px;
  z-index: 3;
  opacity: 0;
  animation: heroMarkIn 1.4s 0.4s cubic-bezier(.2,.7,.2,1) forwards;
}
.hero__mark img {
  width: 100%;
  display: block;
}
@keyframes heroMarkIn {
  to { opacity: 1; }
}
@media (max-width: 720px) {
  .hero__mark { top: 80px; left: var(--space-5); width: 64px; }
}

/* ===== FOOTER LOGO ===== */
.foot__brand {
  display: inline-flex;
  align-items: center;
  gap: var(--space-3);
}
.foot__brand img {
  height: 32px;
  width: auto;
  opacity: 0.85;
}
.foot {
  align-items: center;
}
