/* FoodClone — seal.css · seção do Taste Match */
.seal-section {
  background:
    radial-gradient(60% 38% at 88% 4%, color-mix(in oklch, var(--color-mango) 13%, transparent) 0%, transparent 70%),
    radial-gradient(50% 32% at 6% 92%, color-mix(in oklch, var(--color-tomato) 8%, transparent) 0%, transparent 65%),
    var(--color-cream);
}

.seal-states {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--space-5);
  margin-block: var(--space-16) var(--space-20);
}
.seal-state {
  border-radius: var(--radius-lg);
  background: var(--color-cream-light);
  box-shadow: var(--highlight-top), var(--shadow-raised);
  padding: var(--space-8) var(--space-6) var(--space-6);
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
  position: relative;
  overflow: hidden;
}
.seal-state .state-score {
  font-weight: 700;
  font-size: clamp(3rem, 4.6vw, 4.4rem);
  line-height: 1;
  letter-spacing: -.03em;
}
.seal-state .state-word {
  font-family: var(--font-serif);
  font-style: italic;
  font-weight: 330;
  font-size: 1.3rem;
  color: var(--text-primary);
}
.seal-state .state-note {
  font-size: var(--font-body-sm);
  color: var(--text-tertiary);
  line-height: 1.5;
  text-wrap: pretty;
  margin-bottom: var(--space-3);
}
/* régua 0–100 — a nota é auditável: preenchimento na cor da própria nota,
   lâmina de medição no fim (marca de instrumento, não controle) */
.score-ruler {
  --ruler-c: var(--color-tomato);
  --ruler-tick: color-mix(in oklch, var(--color-espresso) 16%, transparent);
  margin-top: auto;
  position: relative;
  height: 6px;
  border-radius: var(--radius-pill);
  background: color-mix(in oklch, var(--color-espresso) 8%, transparent);
}
/* ticks de régua a cada 25 pontos */
.score-ruler::before {
  content: '';
  position: absolute;
  inset: -4px 0;
  background: repeating-linear-gradient(90deg,
    var(--ruler-tick) 0 1px,
    transparent 1px calc(25% - .25px));
  pointer-events: none;
}
.score-ruler i {
  position: absolute;
  left: 0; top: 0; bottom: 0;
  width: var(--at, 50%);
  border-radius: inherit;
  background: linear-gradient(90deg,
    color-mix(in oklch, var(--ruler-c) 28%, transparent) 0%,
    var(--ruler-c) 100%);
  box-shadow: 0 0 14px color-mix(in oklch, var(--ruler-c) 30%, transparent);
}
/* a lâmina no ponto exato da nota */
.score-ruler i::after {
  content: '';
  position: absolute;
  right: -1px;
  top: -6px; bottom: -6px;
  width: 2.5px;
  border-radius: 2px;
  background: var(--ruler-c);
  box-shadow:
    0 0 9px color-mix(in oklch, var(--ruler-c) 75%, transparent),
    0 0 22px color-mix(in oklch, var(--ruler-c) 35%, transparent);
}
/* preenchimento anima no reveal, com leve overshoot — e respira de leve na lâmina */
@media (prefers-reduced-motion: no-preference) {
  html.js .seal-state .score-ruler i { width: 0; }
  html.js .seal-state.is-in .score-ruler i {
    width: var(--at, 50%);
    transition: width 1.25s cubic-bezier(.3, 1.35, .3, 1) .35s;
  }
  html.js .seal-state:nth-child(2).is-in .score-ruler i { transition-delay: .5s; }
  html.js .seal-state:nth-child(3).is-in .score-ruler i { transition-delay: .65s; }
  html.js .seal-state:nth-child(4).is-in .score-ruler i { transition-delay: .8s; }
  .seal-state.is-in .score-ruler i::after { animation: blade-breathe 3.2s var(--ease-standard) 1.8s infinite; }
  @keyframes blade-breathe {
    0%, 100% { box-shadow: 0 0 9px color-mix(in oklch, var(--ruler-c) 75%, transparent), 0 0 22px color-mix(in oklch, var(--ruler-c) 35%, transparent); }
    50%      { box-shadow: 0 0 5px color-mix(in oklch, var(--ruler-c) 45%, transparent), 0 0 10px color-mix(in oklch, var(--ruler-c) 18%, transparent); }
  }
}

/* temperaturas por nota */
.seal-state.s94 {
  background:
    radial-gradient(120% 100% at 80% 0%, color-mix(in oklch, var(--color-mango) 26%, var(--color-cream-light)) 0%, var(--color-cream-light) 60%);
  box-shadow: var(--highlight-top), var(--shadow-mango-deep);
}
.seal-state.s94 .state-score { color: var(--color-mango-deep); }
.seal-state.s94 .score-ruler { --ruler-c: var(--color-mango-deep); }
.seal-state.s87 {
  background:
    radial-gradient(120% 100% at 80% 0%, color-mix(in oklch, var(--color-tomato) 16%, var(--color-cream-light)) 0%, var(--color-cream-light) 65%);
}
.seal-state.s87 .state-score { color: var(--color-tomato); }
.seal-state.s87 .score-ruler { --ruler-c: var(--color-tomato); }
.seal-state.s76 .state-score { color: color-mix(in oklch, var(--color-tomato-deep) 70%, var(--color-espresso)); }
.seal-state.s76 .score-ruler { --ruler-c: color-mix(in oklch, var(--color-tomato-deep) 70%, var(--color-espresso)); }
.seal-state.is-honest {
  background: linear-gradient(170deg, color-mix(in oklch, var(--color-espresso) 92%, var(--color-tomato)) 0%, var(--color-espresso) 65%);
  color: var(--color-cream-light);
}
.seal-state.is-honest .state-score { color: var(--color-mango); }
.seal-state.is-honest .state-word { color: var(--color-cream-light); }
.seal-state.is-honest .state-note { color: color-mix(in oklch, var(--color-cream) 70%, transparent); }
.seal-state.is-honest .score-ruler {
  --ruler-c: var(--color-mango);
  --ruler-tick: rgba(245,237,223,.24);
  background: rgba(245,237,223,.13);
}

/* ---------- Como a nota nasce: 14 dimensões ---------- */
.dim-card {
  border-radius: var(--radius-2xl);
  background:
    radial-gradient(110% 80% at 88% -8%, rgba(244,161,0,.18) 0%, transparent 55%),
    radial-gradient(90% 70% at 0% 105%, rgba(217,79,42,.16) 0%, transparent 50%),
    linear-gradient(165deg, color-mix(in oklch, var(--color-espresso) 88%, var(--color-tomato)) 0%, var(--color-espresso) 62%);
  color: var(--color-cream-light);
  box-shadow: var(--shadow-lifted);
  padding: clamp(2rem, 4vw, 3.8rem);
  max-width: 62rem;
  margin-inline: auto;
  display: grid;
  grid-template-columns: 1.08fr .92fr;
  gap: clamp(2rem, 4vw, 4rem);
  align-items: center;
}
.dim-kicker {
  display: block;
  font-size: .78rem;
  font-weight: 600;
  letter-spacing: .2em;
  text-transform: uppercase;
  color: var(--color-mango);
  margin-bottom: var(--space-4);
}
.dim-copy h3 {
  font-size: clamp(1.7rem, 2.6vw, 2.4rem);
  font-weight: 800;
  letter-spacing: var(--tracking-display);
  color: var(--color-cream-light);
  margin-bottom: var(--space-5);
}
.dim-copy p {
  color: color-mix(in oklch, var(--color-cream) 74%, transparent);
  line-height: var(--leading-relaxed);
  text-wrap: pretty;
}
.dim-copy p + p { margin-top: var(--space-4); }
.dim-copy .dim-learn {
  font-family: var(--font-serif);
  font-style: italic;
  font-weight: 330;
  font-size: 1.08rem;
  color: color-mix(in oklch, var(--color-mango) 80%, var(--color-cream));
}

.dim-demo {
  border-radius: var(--radius-xl);
  background: rgba(245,237,223,.07);
  border: 1px solid rgba(245,237,223,.16);
  padding: clamp(1.5rem, 2.4vw, 2.2rem);
  display: grid;
  gap: var(--space-5);
}
.dim-demo-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-4);
  flex-wrap: wrap;
}
.dim-dish { font-size: 1.3rem; color: var(--color-cream-light); }
.dim-demo .tm-badge {
  background: color-mix(in oklch, var(--color-mango) 16%, transparent);
  border-color: color-mix(in oklch, var(--color-mango) 55%, transparent);
  color: var(--color-mango);
}
.dim-chips {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-wrap: wrap;
  gap: .55rem;
}
.dim-chips li {
  display: inline-flex;
  align-items: center;
  gap: .55em;
  padding: .55em 1.05em;
  border-radius: var(--radius-pill);
  background: rgba(245,237,223,.08);
  border: 1px solid rgba(245,237,223,.15);
  font-size: .94rem;
  color: color-mix(in oklch, var(--color-cream) 86%, transparent);
  white-space: nowrap;
}
.dim-chips li i {
  width: .6em; height: .6em;
  border-radius: 50%;
  flex: 0 0 auto;
}
.dim-chips li.keep i { background: #9DC183; box-shadow: 0 0 .6em rgba(157,193,131,.6); }
.dim-chips li.soft i { background: var(--color-mango); box-shadow: 0 0 .6em rgba(244,161,0,.6); }
.dim-chips li.adj i  { background: #E2784F; box-shadow: 0 0 .6em rgba(226,120,79,.6); }
.dim-foot {
  font-size: .9rem;
  color: color-mix(in oklch, var(--color-cream) 55%, transparent);
  text-wrap: pretty;
}

.seal-close {
  font-family: var(--font-serif);
  font-style: italic;
  font-weight: 310;
  font-size: clamp(1.7rem, 3vw, 2.6rem);
  letter-spacing: -0.015em;
  text-align: center;
  margin-top: var(--space-20);
  color: var(--text-primary);
}
.seal-close em { font-style: inherit; color: var(--color-tomato); }

@media (max-width: 980px) {
  .seal-states { grid-template-columns: repeat(2, 1fr); }
  .dim-card { grid-template-columns: 1fr; }
}
@media (max-width: 640px) {
  .seal-states { grid-template-columns: 1fr; }
}
