/* FoodClone — sections.css · personalização, despensa, descobrir, planos, FAQ, rodapé */

/* Zonas claras têm fundo próprio — texto escuro nunca cai sobre a noite */
.persona, .pantry, .discover, .plans, .faq {
  background:
    radial-gradient(circle at 30% 8%,
      color-mix(in oklch, var(--color-cream) 94%, white) 0%,
      var(--color-cream) 70%);
}

/* ---------- Personalização ---------- */
.persona-grid {
  display: grid;
  grid-template-columns: 1.15fr .85fr;
  gap: var(--space-6);
  margin-top: var(--space-16);
  align-items: stretch;
}
.persona-card {
  position: relative;
  border-radius: var(--radius-2xl);
  padding: clamp(1.8rem, 2.8vw, 2.8rem);
  display: flex;
  flex-direction: column;
  overflow: hidden;
  isolation: isolate;
}

/* — Card do perfil: ficha pessoal, calorosa — */
.persona-card.profile {
  background:
    radial-gradient(120% 80% at 8% 0%, color-mix(in oklch, var(--color-sage-deep) 12%, var(--color-cream-light)) 0%, var(--color-cream-light) 52%);
  box-shadow: var(--highlight-top), var(--shadow-floating);
  gap: var(--space-7, 1.75rem);
}
.persona-card.profile::before {
  content: '';
  position: absolute;
  inset: 0 0 auto 0;
  height: 4px;
  background: linear-gradient(90deg, var(--color-sage-deep), color-mix(in oklch, var(--color-sage-deep) 40%, var(--color-mango)));
  opacity: .8;
}
.pp-private {
  position: absolute;
  top: clamp(1.4rem, 2.2vw, 2rem);
  right: clamp(1.4rem, 2.2vw, 2rem);
  display: inline-flex;
  align-items: center;
  gap: .45em;
  white-space: nowrap;
  font-size: .68rem;
  font-weight: 600;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--color-sage-deep);
  background: color-mix(in oklch, var(--color-sage-deep) 10%, transparent);
  border: 1px solid color-mix(in oklch, var(--color-sage-deep) 28%, transparent);
  padding: .42em .85em;
  border-radius: var(--radius-pill);
}
.pp-private svg { width: 1.05em; height: 1.05em; fill: none; stroke: currentColor; stroke-width: 1.7; }

.pp-head {
  display: flex;
  align-items: center;
  gap: var(--space-4);
  padding-right: 8rem;
}
.pp-avatar {
  width: 3.6rem; height: 3.6rem;
  border-radius: 50%;
  background:
    radial-gradient(circle at 35% 28%, #F7D9C9 0%, #EBB59E 70%, #D99877 100%);
  color: #8a3b1e;
  font-family: var(--font-display);
  font-weight: 800;
  font-size: 1.5rem;
  display: grid;
  place-items: center;
  flex: 0 0 auto;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.55), 0 0 0 4px color-mix(in oklch, var(--color-sage-deep) 14%, transparent);
}
.pp-id { display: grid; gap: .2rem; }
.pp-id b { font-family: var(--font-display); font-weight: 800; font-size: 1.4rem; letter-spacing: var(--tracking-tight); }
.pp-desc {
  font-family: var(--font-serif);
  font-style: italic;
  font-weight: 330;
  font-size: 1rem;
  color: var(--text-secondary);
}

.pp-group { display: grid; gap: var(--space-3); }
.pp-glabel {
  font-size: .72rem;
  font-weight: 600;
  letter-spacing: .16em;
  text-transform: uppercase;
  color: color-mix(in oklch, var(--color-sage-deep) 88%, var(--color-espresso));
}
.pp-chips { display: flex; flex-wrap: wrap; gap: .55rem; }
.p-chip {
  display: inline-flex;
  align-items: center;
  gap: .5em;
  padding: .58em 1.1em;
  border-radius: var(--radius-pill);
  background: var(--color-cream-light);
  border: 1px solid color-mix(in oklch, var(--color-sage-deep) 30%, transparent);
  box-shadow: var(--shadow-resting);
  font-size: .94rem;
  font-weight: 500;
  color: var(--text-primary);
  cursor: default;
}
.p-chip::before {
  content: '';
  width: .5em; height: .5em;
  border-radius: 50%;
  background: var(--color-sage-deep);
  flex: 0 0 auto;
}
.pp-nosup { display: flex; flex-wrap: wrap; gap: .55rem; }
.pp-nosup .nos {
  display: inline-flex;
  align-items: center;
  gap: .45em;
  padding: .5em 1em;
  border-radius: var(--radius-pill);
  border: 1px dashed color-mix(in oklch, var(--color-tomato) 45%, transparent);
  background: color-mix(in oklch, var(--color-tomato) 7%, transparent);
  color: var(--color-tomato-deep);
  font-size: .92rem;
}
.pp-nosup .nos::before {
  content: '⊘';
  font-size: .9em;
  opacity: .8;
}
.pp-nav {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-4);
  margin-top: auto;
  padding-top: var(--space-5);
  border-top: 1px solid var(--border-subtle);
}
.pp-arrow {
  width: 2.6rem; height: 2.6rem;
  border-radius: 50%;
  border: 1.5px solid var(--border-default);
  display: grid;
  place-items: center;
  font-size: 1rem;
  color: var(--text-primary);
  transition: border-color var(--duration-fast) var(--ease-standard), background-color var(--duration-fast) var(--ease-standard);
}
.pp-arrow:hover { border-color: var(--color-sage-deep); background: color-mix(in oklch, var(--color-sage-deep) 8%, transparent); }
.pp-dots { display: inline-flex; gap: .5rem; }
.pp-dots i {
  width: .5rem; height: .5rem;
  border-radius: 50%;
  background: color-mix(in oklch, var(--color-espresso) 16%, transparent);
  transition: background-color var(--duration-fast) var(--ease-standard), width var(--duration-fast) var(--ease-standard);
}
.pp-dots i.on { background: var(--color-sage-deep); width: 1.3rem; border-radius: var(--radius-pill); }

/* — Card do efeito: espresso premium — */
.persona-card.fx {
  background:
    radial-gradient(120% 70% at 88% -8%, rgba(244,161,0,.20) 0%, transparent 55%),
    linear-gradient(168deg, color-mix(in oklch, var(--color-espresso) 90%, var(--color-tomato)) 0%, var(--color-espresso) 62%);
  color: var(--color-cream-light);
  box-shadow: var(--shadow-lifted);
}
.persona-card.fx::before {
  content: '';
  position: absolute;
  inset: 0;
  border-radius: inherit;
  padding: 1px;
  background: linear-gradient(160deg, rgba(244,161,0,.5), transparent 45%, rgba(244,161,0,.2));
  -webkit-mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
  -webkit-mask-composite: xor;
  mask-composite: exclude;
  pointer-events: none;
}
.persona-card.fx .fx-label {
  font-size: .72rem;
  font-weight: 600;
  letter-spacing: .18em;
  color: var(--color-mango);
  margin-bottom: var(--space-5);
}
.fx-list {
  list-style: none;
  padding: 0;
  margin: 0 0 var(--space-5);
  display: grid;
  gap: var(--space-4);
}
.fx-list li {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: .8em;
  align-items: start;
}
.fx-list .fx-tag {
  font-family: var(--font-mono);
  font-size: .64rem;
  letter-spacing: .06em;
  text-transform: uppercase;
  padding: .42em .7em;
  border-radius: var(--radius-pill);
  background: color-mix(in oklch, var(--color-mango) 18%, transparent);
  color: var(--color-mango);
  white-space: nowrap;
}
.fx-list .fx-text { font-size: .98rem; line-height: 1.5; color: color-mix(in oklch, var(--color-cream) 84%, transparent); text-wrap: pretty; }
.fx-empty { color: color-mix(in oklch, var(--color-cream) 50%, transparent); font-family: var(--font-serif); font-style: italic; font-weight: 330; }

/* exemplo concreto de troca dentro do clone do perfil */
.fx-swap {
  border-radius: var(--radius-md);
  border: 1px solid rgba(245,237,223,.16);
  background: rgba(245,237,223,.06);
  padding: var(--space-4) var(--space-5);
  margin-top: auto;
  margin-bottom: var(--space-5);
  font-size: .95rem;
  line-height: 1.5;
  color: color-mix(in oklch, var(--color-cream) 80%, transparent);
}
.fx-swap em { font-family: var(--font-serif); font-style: italic; font-weight: 330; color: var(--color-mango); }
.fx-swap s { text-decoration-color: color-mix(in oklch, var(--color-tomato) 70%, transparent); text-decoration-thickness: 1.5px; opacity: .75; }
.fx-swap b { color: var(--color-cream-light); font-weight: 600; }
.persona-card.fx .microcopy { color: color-mix(in oklch, var(--color-cream) 48%, transparent); }

/* ---------- Da despensa (rotativo) ---------- */
.pantry-card {
  margin-top: var(--space-16);
  border-radius: var(--radius-2xl);
  background:
    radial-gradient(80% 120% at 12% 0%, color-mix(in oklch, var(--color-mango) 12%, var(--color-cream-light)) 0%, var(--color-cream-light) 55%);
  box-shadow: var(--highlight-top), var(--shadow-floating);
  padding: clamp(1.8rem, 3.2vw, 3.2rem);
  position: relative;
  overflow: hidden;
}
.pantry-main {
  display: grid;
  grid-template-columns: minmax(14rem, .9fr) 1.1fr;
  gap: clamp(1.5rem, 4vw, 4rem);
  align-items: center;
  min-height: 14rem;
}
.pantry-cat {
  font-size: .72rem;
  letter-spacing: .2em;
  text-transform: uppercase;
  color: var(--text-tertiary);
}
.pantry-name {
  font-family: var(--font-display);
  font-weight: 800;
  letter-spacing: var(--tracking-display);
  font-size: clamp(2.4rem, 4.6vw, 4.2rem);
  line-height: 1.06;
  padding-bottom: .06em;
  margin-block: .35em .45em;
  background: linear-gradient(115deg,
    var(--color-tomato-deep) 0%,
    var(--color-tomato) 45%,
    var(--color-mango-deep) 85%);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
  text-wrap: balance;
}
.pantry-stats { display: flex; flex-wrap: wrap; gap: .5rem; }
.pantry-stats span {
  font-family: var(--font-mono);
  font-size: .76rem;
  padding: .42em .95em;
  border-radius: var(--radius-pill);
  border: 1px solid var(--border-subtle);
  background: color-mix(in oklch, var(--color-cream) 55%, var(--color-cream-light));
  color: var(--text-secondary);
  white-space: nowrap;
}
.pantry-theme {
  display: inline-block;
  font-size: .72rem;
  font-weight: 600;
  letter-spacing: .18em;
  text-transform: uppercase;
  padding: .5em 1.1em;
  border-radius: var(--radius-pill);
  margin-bottom: var(--space-4);
}
.pantry-theme.t-micro { background: color-mix(in oklch, var(--color-sage-deep) 14%, transparent); color: var(--color-sage-deep); border: 1px solid color-mix(in oklch, var(--color-sage-deep) 40%, transparent); }
.pantry-theme.t-infl  { background: color-mix(in oklch, var(--color-mango) 18%, transparent); color: var(--color-mango-deep); border: 1px solid color-mix(in oklch, var(--color-mango) 50%, transparent); }
.pantry-theme.t-peso  { background: color-mix(in oklch, var(--color-tomato) 12%, transparent); color: var(--color-tomato-deep); border: 1px solid color-mix(in oklch, var(--color-tomato) 40%, transparent); }
.pantry-fact {
  font-size: clamp(1.05rem, 1.4vw, 1.25rem);
  line-height: var(--leading-relaxed);
  color: var(--text-secondary);
  text-wrap: pretty;
  max-width: 34em;
}
.pantry-nav {
  display: flex;
  align-items: center;
  gap: var(--space-5);
  margin-top: var(--space-8);
}
.pantry-arrow {
  width: 2.8rem; height: 2.8rem;
  border-radius: 50%;
  border: 1.5px solid var(--border-default);
  display: grid;
  place-items: center;
  font-size: 1.05rem;
  color: var(--text-primary);
  transition: border-color var(--duration-fast) var(--ease-standard), background-color var(--duration-fast) var(--ease-standard);
}
.pantry-arrow:hover { border-color: var(--color-tomato); background: color-mix(in oklch, var(--color-tomato) 7%, transparent); }
.pantry-progress {
  flex: 1;
  height: 3px;
  border-radius: var(--radius-pill);
  background: color-mix(in oklch, var(--color-espresso) 10%, transparent);
  overflow: hidden;
}
.pantry-progress i {
  display: block;
  height: 100%;
  width: 0%;
  border-radius: inherit;
  background: linear-gradient(90deg, var(--color-tomato), var(--color-mango));
}
.pantry-note { margin-top: var(--space-6); text-align: center; }

/* ---------- Descobrir: feed real ---------- */
.discover { overflow: clip; }
.discover-rail-wrap { position: relative; margin-top: var(--space-12); }
.discover-rail-wrap::before,
.discover-rail-wrap::after {
  content: '';
  position: absolute;
  top: 0; bottom: 0;
  width: clamp(2rem, 6vw, 7rem);
  z-index: 1;
  pointer-events: none;
}
.discover-rail-wrap::before { left: 0; background: linear-gradient(90deg, var(--color-cream), transparent); }
.discover-rail-wrap::after { right: 0; background: linear-gradient(270deg, var(--color-cream), transparent); }
.rail-arrow {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  z-index: 2;
  width: 3.2rem; height: 3.2rem;
  border-radius: 50%;
  border: 1.5px solid var(--border-default);
  background: color-mix(in oklch, var(--color-cream-light) 80%, transparent);
  -webkit-backdrop-filter: blur(10px);
  backdrop-filter: blur(10px);
  box-shadow: var(--shadow-raised);
  display: grid;
  place-items: center;
  font-size: 1.1rem;
  color: var(--text-primary);
  transition: border-color var(--duration-fast) var(--ease-standard),
              background-color var(--duration-fast) var(--ease-standard),
              transform var(--duration-fast) var(--ease-standard);
}
.rail-arrow:hover {
  border-color: var(--color-tomato);
  background: color-mix(in oklch, var(--color-tomato) 8%, var(--color-cream-light));
  transform: translateY(-50%) scale(1.06);
}
.rail-arrow:active { transform: translateY(-50%) scale(.96); }
.rail-prev { left: clamp(.7rem, 2.5vw, 2.6rem); }
.rail-next { right: clamp(.7rem, 2.5vw, 2.6rem); }
@media (max-width: 640px) {
  .rail-arrow { width: 2.7rem; height: 2.7rem; }
}
.discover-rail {
  display: flex;
  gap: var(--space-6);
  padding-block: var(--space-4);
  overflow-x: auto;
  scroll-snap-type: x mandatory;
  scrollbar-width: none;
  padding-inline: max(1.5rem, calc((100vw - var(--container-default)) / 2));
}
.discover-rail::-webkit-scrollbar { display: none; }
.feed-card {
  flex: 0 0 clamp(17rem, 25vw, 22rem);
  scroll-snap-align: center;
  border-radius: var(--radius-xl);
  padding: var(--space-8) var(--space-6) var(--space-6);
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
  color: var(--color-cream-light);
  position: relative;
  overflow: hidden;
  box-shadow: var(--shadow-floating);
  min-height: 23rem;
  transition: filter .5s var(--ease-standard), transform .5s var(--ease-standard), opacity .5s var(--ease-standard);
}
.feed-card::before {
  content: '';
  position: absolute;
  inset: 0;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='300' height='300'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.8' numOctaves='2' seed='5'/><feColorMatrix values='0 0 0 0 1 0 0 0 0 1 0 0 0 0 1 0 0 0 0.5 0'/></filter><rect width='100%' height='100%' filter='url(%23n)'/></svg>");
  opacity: .07;
  mix-blend-mode: overlay;
  pointer-events: none;
}
.feed-card.off { filter: blur(2px) saturate(.92); transform: scale(.97); opacity: .8; }
.feed-card .feed-kicker {
  font-family: var(--font-mono);
  font-size: .68rem;
  letter-spacing: .16em;
  text-transform: uppercase;
  opacity: .75;
}
.feed-card .feed-name {
  font-family: var(--font-display);
  font-weight: 800;
  letter-spacing: var(--tracking-display);
  font-size: clamp(1.5rem, 2vw, 1.9rem);
  line-height: 1.04;
  text-wrap: balance;
}
.feed-card .feed-desc {
  font-size: .9rem;
  line-height: 1.55;
  opacity: .82;
  display: -webkit-box;
  -webkit-line-clamp: 4;
  -webkit-box-orient: vertical;
  overflow: hidden;
  text-wrap: pretty;
}
.feed-card .feed-foot {
  margin-top: auto;
  display: flex;
  flex-wrap: wrap;
  gap: .45rem;
  padding-top: var(--space-4);
}
.feed-card .feed-foot span {
  font-family: var(--font-mono);
  font-size: .72rem;
  padding: .4em .85em;
  border-radius: var(--radius-pill);
  background: rgba(245,237,223,.13);
  border: 1px solid rgba(245,237,223,.25);
  white-space: nowrap;
}
.feed-card .feed-foot span.feed-per {
  background: rgba(245,237,223,.06);
  border-style: dashed;
  opacity: .92;
}
.feed-card.g0 { background: radial-gradient(circle at 70% 18%, var(--color-mango) 0%, var(--color-tomato) 52%, var(--color-tomato-deep) 100%); }
.feed-card.g1 { background: radial-gradient(circle at 28% 16%, #E2784F 0%, #B5431F 55%, #6E2812 100%); }
.feed-card.g2 { background: radial-gradient(circle at 72% 14%, #C98E3C 0%, #9A6526 55%, #5C3B14 100%); }
.feed-card.g3 { background: radial-gradient(circle at 30% 20%, #6B5138 0%, #483524 55%, #2A1F14 100%); }
.feed-card.g4 { background: radial-gradient(circle at 68% 22%, #8a4a2a 0%, #67301b 55%, #3c1c10 100%); }
.feed-card.g5 { background: radial-gradient(circle at 32% 14%, #B07B28 0%, #7d5417 60%, #4a3110 100%); }
.discover-foot {
  width: min(var(--container-default), 100% - 3rem);
  margin: var(--space-8) auto 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: var(--space-6);
}
.discover-progress {
  width: min(22rem, 70vw);
  height: 3px;
  border-radius: var(--radius-pill);
  background: color-mix(in oklch, var(--color-espresso) 10%, transparent);
  overflow: hidden;
}
.discover-progress i {
  display: block;
  height: 100%;
  width: 0%;
  border-radius: inherit;
  background: linear-gradient(90deg, var(--color-tomato), var(--color-mango));
}

/* ---------- Planos ---------- */
.plans .section-head { margin-inline: auto; text-align: center; }
.plans-toggle-wrap { text-align: center; }
.plans-toggle {
  position: relative;
  display: inline-flex;
  align-items: center;
  margin: var(--space-10) auto var(--space-12);
  padding: .3rem;
  border-radius: var(--radius-pill);
  background: color-mix(in oklch, var(--color-espresso) 7%, transparent);
  border: 1px solid var(--border-subtle);
  isolation: isolate;
}
.toggle-thumb {
  position: absolute;
  top: .3rem;
  bottom: .3rem;
  left: 0;
  width: 4rem;
  border-radius: var(--radius-pill);
  background: var(--color-espresso);
  box-shadow: var(--shadow-raised);
  z-index: 0;
  will-change: transform, width;
}
.plans-toggle button {
  position: relative;
  z-index: 1;
  padding: .7rem 1.6rem;
  border-radius: var(--radius-pill);
  font-family: var(--font-display);
  font-weight: 600;
  font-size: .98rem;
  color: var(--text-secondary);
  display: inline-flex;
  align-items: center;
  gap: .6em;
  white-space: nowrap;
  transition: color var(--duration-normal) var(--ease-standard);
}
.plans-toggle button.active { color: var(--color-cream-light); }
.plans-toggle .bonus {
  font-size: .68rem;
  font-weight: 600;
  letter-spacing: .04em;
  padding: .32em .8em;
  border-radius: var(--radius-pill);
  background: color-mix(in oklch, var(--color-mango) 30%, transparent);
  color: color-mix(in oklch, var(--color-mango-deep) 85%, var(--color-espresso));
  transition: background-color var(--duration-normal) var(--ease-standard), color var(--duration-normal) var(--ease-standard);
}
.plans-toggle button.active .bonus { background: var(--color-mango); color: var(--color-espresso); }

.plans-duo {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 24rem));
  justify-content: center;
  gap: var(--space-6);
  align-items: stretch;
}
.plan-card {
  border-radius: var(--radius-xl);
  padding: clamp(2rem, 2.6vw, 2.8rem);
  display: flex;
  flex-direction: column;
  gap: var(--space-5);
  position: relative;
  overflow: hidden;
}
.plan-name {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: 1.35rem;
  letter-spacing: var(--tracking-tight);
}
.plan-price {
  display: flex;
  align-items: baseline;
  gap: .5rem;
  min-height: 3.2rem;
  white-space: nowrap;
}
.plan-price .amount {
  font-weight: 700;
  font-size: clamp(2.2rem, 3.2vw, 2.9rem);
  letter-spacing: -.02em;
  line-height: 1;
}
.plan-price .period {
  font-family: var(--font-serif);
  font-style: italic;
  font-weight: 330;
  font-size: 1.05rem;
}
.plan-equiv { font-size: var(--font-body-sm); min-height: 1.3em; }
.plan-features {
  list-style: none;
  padding: 0;
  display: grid;
  gap: .75rem;
  margin-block: var(--space-3) var(--space-5);
  font-size: var(--font-body-md);
}
.plan-features li {
  position: relative;
  padding-left: 1.7em;
  text-wrap: pretty;
}
.plan-features li::before {
  content: '✓';
  position: absolute;
  left: 0;
  top: 0;
  font-family: var(--font-mono);
  font-size: .85em;
  line-height: 1.8;
}
.plan-card .btn { margin-top: auto; width: 100%; }
.plan-cta-note { text-align: center; font-size: var(--font-body-sm); }

/* Pro — recomendado, quente */
.plan-card.pro {
  background:
    radial-gradient(120% 90% at 80% 0%, color-mix(in oklch, var(--color-tomato) 10%, var(--color-cream-light)) 0%, var(--color-cream-light) 55%);
  box-shadow: var(--highlight-top), var(--shadow-lifted);
  color: var(--text-primary);
}
/* badge "mais escolhido" — vive no MAX (founder 2026-06-12) */
.plan-card.max .plan-flag {
  position: absolute;
  top: 1.4rem;
  right: 1.6rem;
  font-size: .68rem;
  font-weight: 600;
  letter-spacing: .12em;
  text-transform: uppercase;
  padding: .45em 1.1em;
  border-radius: var(--radius-pill);
  background: linear-gradient(110deg, #F6C66A 0%, var(--color-mango) 60%, #C8923B 100%);
  color: var(--color-espresso);
  box-shadow: 0 2px 10px color-mix(in oklch, var(--color-mango) 35%, transparent);
}
/* anel de destaque acompanha o badge */
.plan-card.max.featured {
  outline: 2px solid color-mix(in oklch, var(--color-mango) 60%, transparent);
  outline-offset: -2px;
}
.plan-card.pro .plan-price .amount { color: var(--color-tomato-deep); }
.plan-card.pro .plan-price .period, .plan-card.pro .plan-equiv { color: var(--text-tertiary); }
.plan-card.pro .plan-features li { color: var(--text-secondary); }
.plan-card.pro .plan-features li::before { color: var(--color-tomato); }
.plan-card.pro .plan-features li strong { color: var(--text-primary); font-weight: 600; }
.plan-card.pro .plan-cta-note { color: var(--text-tertiary); }

/* Max — premium, espresso + ouro */
.plan-card.max {
  background:
    radial-gradient(110% 70% at 85% -10%, rgba(244,161,0,.22) 0%, transparent 55%),
    linear-gradient(168deg, #2A2014 0%, #191209 58%, #120D07 100%);
  color: var(--color-cream-light);
  box-shadow: var(--shadow-lifted);
}
.plan-card.max::before {
  content: '';
  position: absolute;
  inset: 0;
  border-radius: inherit;
  padding: 1.5px;
  background: linear-gradient(150deg,
    rgba(244,161,0,.75) 0%,
    rgba(244,161,0,.12) 35%,
    rgba(244,161,0,.05) 60%,
    rgba(244,161,0,.45) 100%);
  -webkit-mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
  -webkit-mask-composite: xor;
  mask-composite: exclude;
  pointer-events: none;
}
.plan-card.max .plan-mark {
  position: absolute;
  top: 1.2rem;
  right: 1.5rem;
  font-size: .72rem;
  font-weight: 700;
  letter-spacing: .34em;
  color: var(--color-mango);
  opacity: .85;
}
.plan-card.max .plan-price .amount {
  background: linear-gradient(110deg, #F6C66A 0%, var(--color-mango) 45%, #C8923B 100%);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}
.plan-card.max .plan-price .period, .plan-card.max .plan-equiv { color: color-mix(in oklch, var(--color-cream) 52%, transparent); }
.plan-card.max .plan-features li { color: color-mix(in oklch, var(--color-cream) 78%, transparent); }
.plan-card.max .plan-features li::before { color: var(--color-mango); }
.plan-card.max .plan-features li strong { color: var(--color-cream-light); font-weight: 600; }
.plan-card.max .plan-cta-note { color: color-mix(in oklch, var(--color-cream) 45%, transparent); }
.btn-gold {
  background: linear-gradient(160deg, #F0BE5E 0%, #DCA33F 55%, #B97F27 100%);
  color: #221708;
  padding: 1rem 2.2rem;
  font-size: 1.02rem;
  box-shadow: inset 0 1px 0 rgba(255,251,244,.45), 0 8px 20px rgba(244,161,0,.25);
}
.btn-gold:hover { box-shadow: inset 0 1px 0 rgba(255,251,244,.45), 0 10px 26px rgba(244,161,0,.38); }
.btn-gold:active { transform: scale(.98); }

/* Free — faixa discreta, sem disputa */
.plan-free {
  max-width: 49.5rem;
  margin: var(--space-8) auto 0;
  border-radius: var(--radius-lg);
  border: 1px dashed var(--border-default);
  background: color-mix(in oklch, var(--color-cream-light) 60%, transparent);
  padding: var(--space-6) var(--space-8);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-6);
  flex-wrap: wrap;
}
.plan-free-copy { max-width: 34rem; display: grid; gap: .3rem; }
.plan-free-copy b { font-family: var(--font-display); font-weight: 700; font-size: 1.05rem; }
.plan-free-copy span { font-size: var(--font-body-sm); color: var(--text-tertiary); line-height: 1.55; text-wrap: pretty; }
.plan-free .btn-secondary { padding: .8rem 1.7rem; font-size: .95rem; flex: 0 0 auto; }

/* ---------- Perguntas honestas ---------- */
.faq .container-narrow { max-width: 50rem; }
.faq-list { margin-top: var(--space-12); }
.faq-item {
  padding-block: clamp(1.8rem, 3vw, 2.6rem);
  border-top: 1px solid var(--border-subtle);
  display: grid;
  gap: var(--space-4);
}
.faq-item:last-of-type { border-bottom: 1px solid var(--border-subtle); }
.faq-item .faq-q {
  font-family: var(--font-serif);
  font-style: italic;
  font-weight: 330;
  font-size: clamp(1.3rem, 2.2vw, 1.7rem);
  letter-spacing: -.01em;
}
.faq-item .faq-a { color: var(--text-secondary); line-height: var(--leading-relaxed); max-width: 60ch; text-wrap: pretty; }
.faq-item .faq-a strong { color: var(--text-primary); font-weight: 600; }

/* ---------- Rodapé ---------- */
.site-footer {
  background:
    radial-gradient(80% 60% at 50% 0%, color-mix(in oklch, var(--color-espresso) 92%, var(--color-tomato)) 0%, var(--color-espresso) 70%);
  color: var(--color-cream-light);
  padding-block: clamp(3rem, 6vw, 5rem) var(--space-10);
}
.footer-cta { text-align: center; margin-bottom: clamp(2.5rem, 5vw, 4rem); }
.footer-cta h2 { color: var(--color-cream-light); margin-bottom: var(--space-6); }
.footer-cta h2 .serif-italic { color: color-mix(in oklch, var(--color-cream) 75%, transparent); }
.footer-cta .microcopy { color: color-mix(in oklch, var(--color-cream) 55%, transparent); margin-top: var(--space-4); }

.footer-legal {
  border-top: 1px solid rgba(245,237,223,.14);
  padding-top: clamp(2.5rem, 5vw, 4rem);
  display: grid;
  gap: var(--space-5);
  font-size: var(--font-body-sm);
  color: color-mix(in oklch, var(--color-cream) 50%, transparent);
}
.footer-row {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: var(--space-8);
  flex-wrap: wrap;
  margin-bottom: clamp(1.5rem, 3vw, 2.5rem);
}
.footer-brand { display: grid; gap: var(--space-4); }

/* Nav discreta de conteúdo (Para você / Receitas / Ingredientes / Trocas /
   Comparar / Índice glicêmico) — presente no rodapé, pouco destaque. */
.footer-explore {
  display: flex;
  flex-wrap: wrap;
  align-items: baseline;
  gap: .4rem 1.15rem;
  margin-bottom: clamp(1.5rem, 3vw, 2.5rem);
}
.footer-explore-label {
  font-family: var(--font-mono);
  font-size: .66rem;
  letter-spacing: .2em;
  text-transform: uppercase;
  color: color-mix(in oklch, var(--color-cream) 40%, transparent);
}
.footer-explore a {
  color: color-mix(in oklch, var(--color-cream) 72%, transparent);
  text-decoration: none;
  transition: color .2s ease;
}
.footer-explore a:hover {
  color: var(--color-cream-light);
  text-decoration: underline;
  text-underline-offset: 3px;
}
.footer-logo {
  height: 60px;
  width: auto;
  filter: brightness(0) invert(.93);
  opacity: .95;
}
.footer-tagline {
  font-family: var(--font-display);
  font-weight: 700;
  letter-spacing: var(--tracking-tight);
  font-size: clamp(1.1rem, 1.6vw, 1.35rem);
  color: color-mix(in oklch, var(--color-cream) 88%, transparent);
}
.footer-tagline .serif-italic {
  font-size: 1em;
  font-weight: 330;
  color: color-mix(in oklch, var(--color-mango) 80%, var(--color-cream));
}
.footer-links { display: flex; gap: var(--space-8); }
.footer-links a {
  color: color-mix(in oklch, var(--color-cream) 72%, transparent);
  text-decoration: none;
  font-size: var(--font-body-md);
  transition: color var(--duration-fast) var(--ease-standard);
}
.footer-links a:hover { color: var(--color-mango); }
.footer-legal p { max-width: 64ch; text-wrap: pretty; }
.footer-legal .crisis { color: color-mix(in oklch, var(--color-cream) 68%, transparent); }
.footer-copyright {
  font-size: var(--font-body-xs);
  color: color-mix(in oklch, var(--color-cream) 38%, transparent);
  margin-top: var(--space-2);
}

@media (max-width: 980px) {
  .persona-grid { grid-template-columns: 1fr; }
  .pantry-main { grid-template-columns: 1fr; }
  .plans-duo { grid-template-columns: minmax(0, 26rem); }
}

/* ════════ Indique o FoodClone (founder 2026-06-12, v2: painel brasa) ════════
   Cerâmica escura com calor vivo: espresso profundo, brasa de tomate
   subindo da base, luz de mango no canto, grain e fio de luz na borda —
   o mesmo clima do card Max e da noite. */
.refer { padding-block: clamp(3rem, 8vh, 6rem) clamp(4rem, 10vh, 7rem); }
.refer-card {
  position: relative;
  overflow: clip;
  text-align: center;
  max-width: 46rem;
  margin-inline: auto;
  padding: clamp(2.75rem, 6.5vw, 4.5rem) clamp(1.5rem, 5vw, 4rem);
  background:
    radial-gradient(85% 70% at 50% 115%, color-mix(in oklch, var(--color-tomato) 38%, transparent) 0%, transparent 60%),
    radial-gradient(60% 45% at 88% -8%, color-mix(in oklch, var(--color-mango) 16%, transparent) 0%, transparent 70%),
    linear-gradient(165deg, color-mix(in oklch, var(--color-espresso) 88%, var(--color-tomato)) 0%, var(--color-espresso) 58%, color-mix(in oklch, var(--color-espresso) 92%, black) 100%);
  border-radius: var(--radius-2xl, 2.5rem);
  box-shadow:
    inset 0 1px 0 color-mix(in oklch, var(--color-cream) 16%, transparent),
    0 24px 60px -20px color-mix(in oklch, var(--color-espresso) 55%, transparent);
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-4);
}
/* grain proprio do painel (multiply do body nao morde fundo escuro) */
.refer-card::after {
  content: '';
  position: absolute;
  inset: 0;
  pointer-events: none;
  opacity: .05;
  mix-blend-mode: screen;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='300' height='300'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.8' numOctaves='2' seed='7'/><feColorMatrix values='0 0 0 0 1 0 0 0 0 1 0 0 0 0 1 0 0 0 .5 0'/></filter><rect width='100%' height='100%' filter='url(%23n)'/></svg>");
}
.refer-kicker {
  font-family: var(--font-serif);
  font-style: italic;
  font-size: 1.05rem;
  color: var(--color-mango);
}
.refer-card h2 {
  font-family: var(--font-display);
  font-size: var(--font-display-lg);
  font-weight: 800;
  letter-spacing: var(--tracking-display);
  text-wrap: balance;
  max-width: 20em;
  color: var(--color-cream-light);
}
.refer-card p {
  color: color-mix(in oklch, var(--color-cream) 72%, transparent);
  line-height: var(--leading-relaxed);
  max-width: 38em;
  text-wrap: pretty;
}
.refer-action {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-3);
  margin-top: var(--space-2);
  min-height: 5.5rem; /* reserva a linha do feedback — zero CLS */
}
.refer-action .btn svg { width: 1.05em; height: 1.05em; margin-right: .55em; vertical-align: -.15em; }
/* botao do Indique: dourado vivo sobre a brasa (diferente do CTA tomato),
   com luz dupla, brilho que acende no hover e afundada macia no aperto */
.refer-btn {
  position: relative;
  background: linear-gradient(168deg, #F8D084 0%, #EFB54C 42%, #C8923B 100%);
  color: #2A1B07;
  box-shadow:
    inset 0 1px 0 rgba(255, 248, 234, .65),
    inset 0 -2px 6px rgba(120, 78, 18, .35),
    0 10px 28px rgba(244, 161, 0, .28);
  transition: box-shadow .25s var(--ease-standard), transform .25s var(--ease-standard);
  -webkit-tap-highlight-color: transparent;
  touch-action: manipulation;
}
.refer-btn:hover {
  transform: translateY(-1px);
  box-shadow:
    inset 0 1px 0 rgba(255, 248, 234, .75),
    inset 0 -2px 6px rgba(120, 78, 18, .3),
    0 14px 36px rgba(244, 161, 0, .42);
}
.refer-btn:active {
  transform: translateY(1px) scale(.965);
  transition-duration: .09s;
  outline: none;
  box-shadow:
    inset 0 2px 8px rgba(120, 78, 18, .45),
    0 2px 8px rgba(244, 161, 0, .2);
}
.refer-feedback {
  font-family: var(--font-mono);
  font-size: .8rem;
  letter-spacing: .08em;
  color: var(--color-mango);
}
