/* ════════════════════════════════════════════════════════════════
   onlinesiparisler — v2 · ENGAGEMENT styles
   Planner (.pl-) · Search (.sr-) · Booking (.bk-) · Newsletter (.nl-)
   Shared overlay shell (.eng-) mirrors the cart-drawer/scrim spring
   pattern. Inherits all tokens from draft.css :root.
   ════════════════════════════════════════════════════════════════ */

/* ─────────────── shared overlay shell ─────────────── */
.eng-overlay {
  position: fixed; inset: 0; z-index: 160;
  display: flex; justify-content: center;
}
/* `hidden` must win over the display:flex above, or the scrim keeps
   intercepting pointer events across the whole viewport after close. */
.eng-overlay[hidden] { display: none !important; }
.eng-scrim {
  position: absolute; inset: 0;
  background: rgba(12, 29, 20, 0.5);
  -webkit-backdrop-filter: blur(8px) saturate(1.2); backdrop-filter: blur(8px) saturate(1.2);
  opacity: 0;
  transition: opacity 0.55s var(--soft-out);
}
.eng-overlay.is-open .eng-scrim { opacity: 1; }

.eng-sheet {
  position: relative;
  margin: auto;
  width: min(560px, calc(100vw - 1.8rem));
  max-height: calc(100dvh - 2.4rem);
  display: flex; flex-direction: column;
  background: var(--porcelain);
  border: 1px solid var(--line);
  border-radius: var(--r-xl);
  box-shadow: var(--shadow-hover);
  overflow: hidden;
  opacity: 0;
  transform: translateY(18px) scale(0.985);
  transition: transform 0.6s var(--spring), opacity 0.5s var(--soft-out);
}
.eng-overlay.is-open .eng-sheet { opacity: 1; transform: translateY(0) scale(1); }

.eng-sheet-head {
  display: flex; align-items: center; justify-content: space-between;
  padding: 1.4rem 1.5rem 0.9rem;
}
.eng-sheet-head .eyebrow { margin-bottom: 0; }
.eng-close {
  flex: none;
  display: grid; place-items: center;
  width: 2.4rem; height: 2.4rem; border-radius: 50%;
  border: 1px solid var(--line-strong); color: var(--ink);
  transition: transform 0.45s var(--spring), background-color 0.45s var(--spring), border-color 0.45s var(--spring), color 0.45s var(--spring);
}
.eng-close:hover { background: var(--ink-deep); color: var(--cream-on-dark); border-color: var(--ink-deep); transform: rotate(90deg); }

/* tinted-initial fallback (mirrors draft.js .p-fallback feel) */
.eng-fallback {
  display: grid; place-items: center;
  font-family: var(--serif); color: var(--paper);
  background: var(--pc, #1E5B3C);
}

/* ════════════════════════════════════════════════════════════════
   A · PLANNER
   ════════════════════════════════════════════════════════════════ */
.pl-sheet { width: min(600px, calc(100vw - 1.8rem)); }

.pl-progress {
  height: 4px; margin: 0 1.5rem 0.4rem;
  background: var(--porcelain-2); border-radius: 999px; overflow: hidden;
}
.pl-progress-fill {
  display: block; height: 100%; width: 0%;
  background: linear-gradient(90deg, var(--sage), var(--herbalife));
  border-radius: inherit;
  transition: width 0.7s var(--spring);
}

.pl-panel { position: relative; overflow-y: auto; padding: 0.6rem 1.5rem 1.6rem; }

.pl-step, .pl-result {
  transition: opacity 0.42s var(--soft-out), transform 0.46s var(--spring);
}
.pl-enter { opacity: 0; transform: translateY(14px); }
.pl-leave { position: absolute; left: 1.5rem; right: 1.5rem; top: 0.6rem; pointer-events: none; }

.pl-count {
  font-size: 0.68rem; font-weight: 700; letter-spacing: 0.16em; text-transform: uppercase;
  color: var(--ink-soft); margin-bottom: 0.7rem;
}
.pl-title { font-family: var(--serif); font-weight: 400; font-size: clamp(1.9rem, 4vw, 2.4rem); line-height: 1.05; letter-spacing: -0.01em; }
.pl-title .serif-i { color: var(--clay); }
.pl-sub { margin-top: 0.6rem; font-size: 0.95rem; color: var(--ink-soft); line-height: 1.6; }
.pl-body { margin-top: 1.5rem; }

.pl-choices { display: flex; flex-direction: column; gap: 0.7rem; }
.pl-choices-2 { display: grid; grid-template-columns: 1fr 1fr; gap: 0.7rem; }
.pl-choice {
  text-align: left;
  display: flex; flex-direction: column; gap: 0.25rem;
  padding: 1.1rem 1.2rem;
  background: var(--paper);
  border: 1px solid var(--line);
  border-radius: var(--r-md);
  transition: transform 0.5s var(--spring), border-color 0.5s var(--spring), box-shadow 0.5s var(--spring), background-color 0.5s var(--spring);
}
.pl-choice:hover { transform: translateY(-3px); border-color: var(--line-strong); box-shadow: var(--shadow-soft); }
.pl-choice strong { font-family: var(--serif); font-weight: 400; font-size: 1.25rem; line-height: 1.1; }
.pl-choice span { font-size: 0.82rem; color: var(--ink-soft); }
.pl-choice.is-on {
  background: var(--ink-deep); color: var(--cream-on-dark); border-color: var(--ink-deep);
  box-shadow: var(--shadow-float);
}
.pl-choice.is-on span { color: rgba(242,237,224,0.66); }
.pl-choice-row { flex-direction: row; align-items: center; justify-content: space-between; }
.pl-mult { font-family: var(--serif); font-size: 1.05rem; color: var(--ink-soft); }
.pl-choice.is-on .pl-mult { color: var(--sage); }

.pl-numwrap {
  position: relative;
  display: flex; align-items: center;
  background: var(--paper);
  border: 1px solid var(--line-strong);
  border-radius: var(--r-md);
  padding: 0.3rem 1.1rem;
  transition: border-color 0.4s var(--spring), box-shadow 0.4s var(--spring);
}
.pl-numwrap:focus-within { border-color: var(--herbalife); box-shadow: var(--focus); }
.pl-input {
  flex: 1; min-width: 0;
  font-family: var(--serif); font-size: 2rem; color: var(--ink);
  background: none; border: none; outline: none;
  padding: 0.6rem 0;
  -moz-appearance: textfield;
}
.pl-input::-webkit-outer-spin-button, .pl-input::-webkit-inner-spin-button { -webkit-appearance: none; margin: 0; }
.pl-input.is-err ~ .pl-unit, .pl-input.is-err { color: var(--clay); }
.pl-numwrap:has(.pl-input.is-err) { border-color: var(--clay); }
.pl-unit { font-size: 0.95rem; font-weight: 600; color: var(--ink-soft); letter-spacing: 0.04em; }
.pl-err { margin-top: 0.6rem; font-size: 0.82rem; color: var(--clay); font-weight: 500; }

.pl-nav {
  margin-top: 1.8rem;
  display: flex; align-items: center; justify-content: space-between; gap: 0.8rem;
}
.pl-nav .btn-ghost { padding: 0.62rem 1.3rem; }

/* result */
.pl-result .eyebrow { margin-bottom: 1.1rem; }
.pl-kcal {
  margin-top: 1.3rem; padding: 1.3rem 1.4rem;
  background: var(--ink-deep); color: var(--cream-on-dark);
  border-radius: var(--r-lg);
}
.pl-kcal-big { display: flex; align-items: baseline; gap: 0.6rem; }
.pl-kcal-big strong { font-family: var(--serif); font-weight: 400; font-size: clamp(2.6rem, 7vw, 3.4rem); line-height: 1; }
.pl-kcal-big span { font-size: 0.8rem; font-weight: 600; letter-spacing: 0.08em; text-transform: uppercase; color: var(--sage); }
.pl-kcal-note { margin-top: 0.7rem; font-size: 0.74rem; color: rgba(242,237,224,0.62); line-height: 1.55; }

.pl-block { margin-top: 1.8rem; }
.pl-block-h {
  font-size: 0.68rem; font-weight: 700; letter-spacing: 0.16em; text-transform: uppercase;
  color: var(--ink-soft); margin-bottom: 0.9rem;
}

.pl-schedule { list-style: none; padding: 0; display: flex; flex-direction: column; gap: 0.55rem; }
.pl-slot {
  background: var(--paper); border: 1px solid var(--line);
  border-radius: var(--r-md); padding: 0.85rem 1rem;
}
.pl-slot-head { display: flex; align-items: baseline; gap: 0.7rem; }
.pl-time {
  font-family: var(--serif); font-size: 1.05rem; color: var(--clay);
  min-width: 3.4rem;
}
.pl-slot-head strong { font-weight: 600; font-size: 0.95rem; }
.pl-natural { margin-top: 0.3rem; font-size: 0.82rem; color: var(--ink-soft); font-style: italic; }
.pl-items { list-style: none; padding: 0; margin: 0.5rem 0 0; display: flex; flex-direction: column; gap: 0.2rem; }
.pl-items li { font-size: 0.86rem; color: var(--ink); line-height: 1.5; }
.pl-items b { font-weight: 600; }
.pl-items span { color: var(--ink-soft); }

.pl-prods { display: grid; grid-template-columns: 1fr 1fr; gap: 0.7rem; }
.pl-prod {
  display: flex; flex-direction: column;
  background: var(--paper); border: 1px solid var(--line);
  border-radius: var(--r-md); overflow: hidden;
  transition: transform 0.5s var(--spring), box-shadow 0.5s var(--spring);
}
.pl-prod:hover { transform: translateY(-3px); box-shadow: var(--shadow-soft); }
.pl-prod-media {
  /* Definite pixel height so the image's max-height:100% resolves and rows stay
     uniform. An aspect-ratio box gives children no resolvable % height in
     Chromium, which left tall products top-aligned/clipped — same fix as
     .p-media in the catalog (draft.css). */
  height: clamp(150px, 16vw, 195px);
  background: radial-gradient(12rem 9rem at 50% 28%, #fff, var(--porcelain-2));
  display: flex; align-items: center; justify-content: center;
  padding: clamp(0.6rem, 2vw, 1rem); overflow: hidden;
}
/* Fill the padded box and let object-fit:contain scale the bitmap fully inside
   it → every recommended product stays centered & visible, portrait or not. */
.pl-prod-img {
  max-width: 100%; max-height: 100%; width: auto; height: auto;
  object-fit: contain; filter: drop-shadow(0 8px 16px rgba(17, 39, 28, 0.12));
}
span.pl-prod-img { width: 60%; aspect-ratio: 1; border-radius: 50%; font-size: 1.7rem; }
.pl-prod-body { padding: 0.8rem 0.85rem 0.9rem; display: flex; flex-direction: column; gap: 0.15rem; flex: 1; }
.pl-prod-body h5 { font-family: var(--serif); font-weight: 400; font-size: 1.02rem; line-height: 1.15; }
.pl-prod-sub { font-size: 0.72rem; color: var(--ink-soft); }
.pl-prod-foot { margin-top: auto; padding-top: 0.7rem; display: flex; align-items: center; justify-content: space-between; gap: 0.4rem; }
.pl-prod-price { font-family: var(--serif); font-size: 1.05rem; }
.pl-prod-add {
  display: inline-flex; align-items: center; gap: 0.35rem;
  font-size: 0.72rem; font-weight: 600;
  padding: 0.32rem 0.4rem 0.32rem 0.72rem;
  border-radius: 999px; border: 1px solid var(--line-strong);
  transition: all 0.45s var(--spring);
}
.pl-prod-add .btn-orb { width: 1.35rem; height: 1.35rem; background: rgba(12,29,20,0.07); }
.pl-prod-add:hover { background: var(--ink-deep); color: var(--cream-on-dark); border-color: var(--ink-deep); }
.pl-prod-add:hover .btn-orb { background: rgba(242,237,224,0.16); transform: rotate(90deg); }
.pl-empty { font-size: 0.85rem; color: var(--ink-soft); font-style: italic; }

.pl-disclaimer {
  margin-top: 1.6rem; padding: 0.9rem 1.1rem;
  font-size: 0.78rem; line-height: 1.6; color: var(--ink-soft);
  background: var(--shell-tint); border: 1px solid var(--line);
  border-left: 3px solid var(--clay);
  border-radius: var(--r-md);
}
.pl-result-actions { margin-top: 1.4rem; display: flex; gap: 0.7rem; flex-wrap: wrap; }
.pl-result-actions .btn-ghost { padding: 0.62rem 1.3rem; }

/* ════════════════════════════════════════════════════════════════
   B · SEARCH
   ════════════════════════════════════════════════════════════════ */
.sr-overlay { align-items: flex-start; }
.sr-panel {
  position: relative;
  margin: clamp(1rem, 8vh, 6rem) auto auto;
  width: min(720px, calc(100vw - 1.8rem));
  max-height: calc(100dvh - 4rem);
  display: flex; flex-direction: column;
  background: rgba(252, 250, 244, 0.86);
  -webkit-backdrop-filter: blur(22px) saturate(1.5); backdrop-filter: blur(22px) saturate(1.5);
  border: 1px solid rgba(255,255,255,0.7);
  border-radius: var(--r-xl);
  box-shadow: var(--shadow-hover);
  overflow: hidden;
  opacity: 0; transform: translateY(-16px) scale(0.99);
  transition: transform 0.6s var(--spring), opacity 0.5s var(--soft-out);
}
.sr-overlay.is-open .sr-panel { opacity: 1; transform: translateY(0) scale(1); }

.sr-bar {
  display: flex; align-items: center; gap: 0.8rem;
  padding: 1.1rem 1.2rem;
  border-bottom: 1px solid var(--line);
}
.sr-ico { color: var(--ink-soft); flex: none; }
.sr-input {
  flex: 1; min-width: 0;
  font-family: var(--serif); font-size: clamp(1.5rem, 3.5vw, 2rem);
  color: var(--ink); background: none; border: none; outline: none;
  letter-spacing: -0.01em;
}
.sr-input::placeholder { color: var(--ink-soft); opacity: 0.6; }
.sr-input::-webkit-search-cancel-button { -webkit-appearance: none; }
.sr-close { flex: none; }

.sr-results { overflow-y: auto; padding: 0.4rem 0.6rem 1rem; }
.sr-state { text-align: center; padding: 3rem 1.4rem 3.4rem; }
.sr-state-h { font-family: var(--serif); font-size: 1.5rem; color: var(--ink); }
.sr-state-sub { margin-top: 0.6rem; font-size: 0.9rem; color: var(--ink-soft); line-height: 1.6; max-width: 40ch; margin-inline: auto; }

.sr-group { padding: 0.6rem 0.5rem 0.2rem; }
.sr-group-h {
  display: flex; align-items: center; gap: 0.5rem;
  font-size: 0.66rem; font-weight: 700; letter-spacing: 0.16em; text-transform: uppercase;
  color: var(--ink-soft); padding: 0.4rem 0.6rem;
}
.sr-group-h span {
  display: grid; place-items: center; min-width: 1.2rem; height: 1.2rem; padding-inline: 0.3rem;
  font-size: 0.62rem; background: var(--porcelain-2); border-radius: 999px; color: var(--ink-soft);
}
.sr-list { display: flex; flex-direction: column; gap: 0.2rem; }
.sr-hit {
  display: flex; align-items: center; gap: 0.9rem; width: 100%; text-align: left;
  padding: 0.6rem 0.7rem;
  border-radius: var(--r-md);
  border: 1px solid transparent;
  transition: background-color 0.3s var(--soft-out), border-color 0.3s var(--soft-out), transform 0.3s var(--spring);
}
.sr-hit:hover, .sr-hit:focus-visible { background: var(--paper); border-color: var(--line); transform: translateX(2px); outline: none; }
.sr-hit:focus-visible { box-shadow: var(--focus); }
.sr-hit-media {
  flex: none; width: 52px; height: 52px; border-radius: 0.7rem;
  background: radial-gradient(4rem 3rem at 50% 30%, #fff, var(--porcelain-2));
  display: grid; place-items: center; overflow: hidden;
}
.sr-hit-media-cover { background: var(--porcelain-2); }
.sr-hit-img { width: 78%; height: 82%; object-fit: contain; }
.sr-hit-media-cover .sr-hit-img { width: 100%; height: 100%; object-fit: cover; }
span.sr-hit-img { width: 100%; height: 100%; font-size: 1.4rem; border-radius: 0; }
.sr-hit-body { flex: 1; min-width: 0; display: flex; flex-direction: column; gap: 0.1rem; }
.sr-hit-name { font-family: var(--serif); font-size: 1.08rem; line-height: 1.15; }
.sr-hit-sub { font-size: 0.76rem; color: var(--ink-soft); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.sr-hit-price { flex: none; font-family: var(--serif); font-size: 1rem; color: var(--ink); }

/* ════════════════════════════════════════════════════════════════
   C · BOOKING  (light coach section background)
   ════════════════════════════════════════════════════════════════ */
.bk-card { margin-top: clamp(2.5rem, 5vw, 4rem); }
.bk-core { padding: clamp(1.6rem, 3.5vw, 2.6rem); }

.bk-head { max-width: 56ch; }
.bk-head .eyebrow { margin-bottom: 1.1rem; }
.bk-title { font-family: var(--serif); font-weight: 400; font-size: clamp(1.9rem, 4vw, 2.6rem); line-height: 1.05; letter-spacing: -0.01em; }
.bk-title .serif-i { color: var(--clay); }
.bk-sub { margin-top: 0.9rem; font-size: 0.98rem; color: var(--ink-soft); line-height: 1.65; }
.bk-sub strong { color: var(--ink); font-weight: 600; }
.bk-review { margin-top: 1.3rem; font-size: 0.84rem; color: var(--ink-soft); line-height: 1.6; }
.bk-review a { color: var(--leaf); border-bottom: 1px solid currentColor; }
.bk-review a:hover { opacity: 0.7; }

.bk-loading { display: flex; flex-direction: column; align-items: center; gap: 1rem; padding: 3rem 1rem; color: var(--ink-soft); }
.bk-spin {
  width: 2rem; height: 2rem; border-radius: 50%;
  border: 2px solid var(--line); border-top-color: var(--leaf);
  animation: bk-spin 0.9s linear infinite;
}
@keyframes bk-spin { to { transform: rotate(360deg); } }

.bk-banner {
  margin-top: 1.4rem; padding: 0.75rem 1rem;
  font-size: 0.82rem; line-height: 1.5; color: var(--ink-soft);
  background: rgba(201, 104, 63, 0.08);
  border: 1px solid rgba(201, 104, 63, 0.25);
  border-radius: var(--r-md);
}

.bk-cal { margin-top: 1.8rem; }
.bk-days {
  display: grid; grid-auto-flow: column; grid-auto-columns: minmax(58px, 1fr);
  gap: 0.5rem; overflow-x: auto; padding-bottom: 0.5rem;
  scrollbar-width: thin;
}
.bk-day {
  display: flex; flex-direction: column; align-items: center; gap: 0.1rem;
  padding: 0.75rem 0.4rem 0.7rem;
  background: var(--paper); border: 1px solid var(--line);
  border-radius: var(--r-md);
  transition: transform 0.45s var(--spring), border-color 0.45s var(--spring), background-color 0.45s var(--spring), box-shadow 0.45s var(--spring);
}
.bk-day:hover:not(.is-full) { transform: translateY(-2px); border-color: var(--line-strong); box-shadow: var(--shadow-soft); }
.bk-day-dow { font-size: 0.66rem; font-weight: 700; letter-spacing: 0.08em; text-transform: uppercase; color: var(--ink-soft); }
.bk-day-num { font-family: var(--serif); font-size: 1.5rem; line-height: 1; }
.bk-day-mon { font-size: 0.64rem; color: var(--ink-soft); }
.bk-day.is-sel { background: var(--ink-deep); border-color: var(--ink-deep); color: var(--cream-on-dark); box-shadow: var(--shadow-float); }
.bk-day.is-sel .bk-day-dow, .bk-day.is-sel .bk-day-mon { color: var(--sage); }
.bk-day.is-full { opacity: 0.4; cursor: not-allowed; }

.bk-slots {
  margin-top: 1.1rem;
  display: grid; grid-template-columns: repeat(auto-fill, minmax(96px, 1fr)); gap: 0.55rem;
}
.bk-slot {
  position: relative;
  padding: 0.7rem 0.6rem;
  font-size: 0.95rem; font-weight: 600;
  background: var(--paper); border: 1px solid var(--line);
  border-radius: var(--r-md);
  transition: transform 0.45s var(--spring), border-color 0.45s var(--spring), background-color 0.45s var(--spring), color 0.45s var(--spring);
}
.bk-slot:hover:not(.is-taken) { transform: translateY(-2px); border-color: var(--ink); }
.bk-slot.is-sel { background: var(--leaf); border-color: var(--leaf); color: var(--cream-on-dark); box-shadow: var(--shadow-soft); }
.bk-slot.is-taken { opacity: 0.45; cursor: not-allowed; text-decoration: line-through; }
.bk-slot-x { display: block; font-size: 0.6rem; font-weight: 600; letter-spacing: 0.06em; text-transform: uppercase; margin-top: 0.1rem; text-decoration: none; }
.bk-empty { font-size: 0.85rem; color: var(--ink-soft); font-style: italic; }

/* form */
.bk-form-wrap { }
.bk-form {
  margin-top: 1.6rem; padding-top: 1.6rem;
  border-top: 1px solid var(--line);
  display: flex; flex-direction: column; gap: 0.9rem;
}
.bk-chosen { font-size: 0.9rem; color: var(--ink-soft); }
.bk-chosen strong { font-family: var(--serif); font-weight: 400; font-size: 1.1rem; color: var(--ink); }
.bk-field { display: flex; flex-direction: column; gap: 0.35rem; }
.bk-field label { font-size: 0.78rem; font-weight: 600; letter-spacing: 0.04em; color: var(--ink); }
.bk-opt { font-weight: 400; color: var(--ink-soft); letter-spacing: 0; }
.bk-field input, .bk-field textarea {
  font-family: var(--sans); font-size: 0.95rem; color: var(--ink);
  background: var(--paper); border: 1px solid var(--line-strong);
  border-radius: var(--r-md); padding: 0.7rem 0.9rem;
  transition: border-color 0.4s var(--spring), box-shadow 0.4s var(--spring);
  resize: vertical;
}
.bk-field input:focus, .bk-field textarea:focus { outline: none; border-color: var(--herbalife); box-shadow: var(--focus); }

.bk-consent, .nl-consent {
  display: flex; align-items: flex-start; gap: 0.6rem;
  font-size: 0.82rem; color: var(--ink-soft); line-height: 1.5;
  cursor: pointer;
}
.bk-consent input, .nl-consent input {
  flex: none; width: 1.15rem; height: 1.15rem; margin-top: 0.1rem;
  accent-color: var(--herbalife); cursor: pointer;
}
.bk-consent .text-link, .nl-consent .text-link { color: var(--leaf); }

/* honeypot — visually removed, kept in a11y tree off */
.bk-hp, .nl-hp {
  position: absolute !important; left: -9999px !important;
  width: 1px; height: 1px; overflow: hidden;
}

.bk-err, .nl-err { font-size: 0.84rem; color: var(--clay); font-weight: 500; }
.bk-submit.is-busy, .nl-submit.is-busy { opacity: 0.7; pointer-events: none; }

.bk-actions { margin-top: 1.6rem; display: flex; gap: 0.7rem; flex-wrap: wrap; }
.bk-actions .btn-ghost { padding: 0.62rem 1.3rem; }
.bk-note { margin-top: 1.2rem; font-size: 0.78rem; color: var(--ink-soft); }

/* success */
.bk-success { text-align: center; padding: 1.4rem 0.5rem 0.5rem; display: flex; flex-direction: column; align-items: center; }
.bk-check, .nl-check {
  display: grid; place-items: center;
  width: 3.6rem; height: 3.6rem; border-radius: 50%;
  background: rgba(0, 158, 73, 0.12); color: var(--herbalife);
  margin-bottom: 1.2rem;
}
.bk-success .bk-sub { max-width: 48ch; margin-inline: auto; }
.bk-success .bk-actions { justify-content: center; }

/* ════════════════════════════════════════════════════════════════
   D · NEWSLETTER
   ════════════════════════════════════════════════════════════════ */
.newsletter { padding-block: 0 var(--sec-y); }
.nl-card { box-shadow: var(--shadow-soft); }
.nl-core {
  padding: clamp(2rem, 4vw, 3.2rem);
  display: grid; grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
  gap: clamp(2rem, 4vw, 3.5rem);
  align-items: center;
  background:
    radial-gradient(34rem 22rem at 92% 0%, rgba(168,191,160,0.14), transparent 64%),
    var(--paper);
}
.nl-copy .eyebrow { margin-bottom: 1.1rem; }
.nl-title { font-family: var(--serif); font-weight: 400; font-size: clamp(1.9rem, 3.6vw, 3rem); line-height: 1.04; letter-spacing: -0.01em; }
.nl-title .serif-i { color: var(--clay); }
.nl-sub { margin-top: 1rem; font-size: 0.98rem; color: var(--ink-soft); line-height: 1.65; max-width: 42ch; }

.nl-form { display: flex; flex-direction: column; gap: 0.9rem; }
.nl-row { display: flex; gap: 0.6rem; }
.nl-input {
  flex: 1; min-width: 0;
  font-family: var(--sans); font-size: 0.98rem; color: var(--ink);
  background: var(--porcelain); border: 1px solid var(--line-strong);
  border-radius: 999px; padding: 0.85rem 1.3rem;
  transition: border-color 0.4s var(--spring), box-shadow 0.4s var(--spring), background-color 0.4s var(--spring);
}
.nl-input:focus { outline: none; border-color: var(--herbalife); box-shadow: var(--focus); background: #fff; }
.nl-submit { flex: none; white-space: nowrap; }
.nl-opt { color: var(--ink-soft); }

.nl-core-done { display: flex; flex-direction: column; align-items: center; text-align: center; }
.nl-core-done .nl-sub { margin-inline: auto; }
.nl-code {
  margin-top: 1rem; font-size: 0.92rem; color: var(--ink-soft);
}
.nl-code strong {
  font-family: var(--sans); font-weight: 700; letter-spacing: 0.12em;
  color: var(--leaf);
  background: rgba(0,158,73,0.08); border: 1px dashed rgba(0,158,73,0.4);
  padding: 0.2rem 0.7rem; border-radius: 0.5rem; margin-left: 0.3rem;
}

/* ════════════════════════════════════════════════════════════════
   RESPONSIVE — full-width below 560px
   ════════════════════════════════════════════════════════════════ */
@media (max-width: 768px) {
  .nl-core { grid-template-columns: 1fr; }
}

@media (max-width: 560px) {
  /* overlays drop to bottom-sheet feel, full width */
  .eng-overlay { align-items: flex-end; }
  .sr-overlay { align-items: flex-start; }
  .eng-sheet, .pl-sheet {
    width: 100%; margin: auto 0 0;
    max-height: 92dvh;
    border-radius: var(--r-xl) var(--r-xl) 0 0;
    transform: translateY(40px);
  }
  .eng-overlay.is-open .eng-sheet { transform: translateY(0); }
  .sr-panel { width: 100%; margin: 0 auto auto; border-radius: 0 0 var(--r-xl) var(--r-xl); }

  .pl-choices-2 { grid-template-columns: 1fr; }
  .pl-prods { grid-template-columns: 1fr; }
  .pl-result-actions { flex-direction: column; align-items: stretch; }
  .pl-result-actions .btn { justify-content: space-between; }

  .nl-row { flex-direction: column; }
  .nl-submit { justify-content: space-between; }

  .bk-slots { grid-template-columns: repeat(auto-fill, minmax(78px, 1fr)); }
  .bk-actions { flex-direction: column; align-items: stretch; }
  .bk-actions .btn { justify-content: space-between; }
}

/* ════════════════════════════════════════════════════════════════
   REDUCED MOTION
   ════════════════════════════════════════════════════════════════ */
@media (prefers-reduced-motion: reduce) {
  .eng-scrim, .eng-sheet, .sr-panel,
  .pl-progress-fill, .pl-step, .pl-result,
  .pl-choice, .pl-prod, .bk-day, .bk-slot, .sr-hit { transition: none; }
  .bk-spin { animation: none; }
  .eng-sheet, .pl-sheet, .sr-panel { transform: none; }
  .pl-enter { opacity: 1; transform: none; }
}
