.mq {
  background: var(--ink);
  border-top: 1px solid var(--bd);
  border-bottom: 1px solid var(--bd);
  overflow: hidden;
  white-space: nowrap;
  padding: 14px 0;
}
.mq-t {
  display: inline-block;
  animation: mqscroll 42s linear infinite; /* literal: idiosyncratic animation timing — not a brand token */
  font-family: var(--D);
  font-size: var(--fs-body-sm);
  letter-spacing: -0.02em;
  text-transform: uppercase;
}
.mq-t span {
  padding: 0 var(--space-6);
  color: var(--bone);
}
.mq-t span.x {
  color: var(--accent-text);
}
.mq-t span:nth-child(6n + 1) {
  color: var(--bone);
}
.mq-t span:nth-child(6n + 2) {
  color: var(--accent-text);
}
.mq-t span:nth-child(6n + 3) {
  color: var(--bone);
}
.mq-t span:nth-child(6n + 4) {
  color: var(--rye);
}
.mq-t span:nth-child(6n + 5) {
  color: var(--bone);
}
.mq-t span:nth-child(6n + 6) {
  color: var(--millet);
}
@keyframes mqscroll {
  from {
    transform: translate3d(0, 0, 0);
  }
  to {
    transform: translate3d(-50%, 0, 0);
  }
}
.hero {
  padding: var(--space-16) max(2rem, calc((100% - 1480px) / 2)) var(--space-20);
  display: grid;
  grid-template-columns: 1.05fr 1fr;
  gap: 4vw;
  align-items: center;
  position: relative;
  background: var(--ink);
  overflow: hidden;
}
.hero-grid-overlay {
  position: absolute;
  inset: 0;
  background-image: linear-gradient(rgba(244, 239, 230, 0.02) 1px, transparent 1px),
    linear-gradient(90deg, rgba(244, 239, 230, 0.02) 1px, transparent 1px);
  background-size: 40px 40px;
  pointer-events: none;
}
.hero-l {
  position: relative;
  z-index: 2;
}
.hero-kicker {
  display: inline-flex;
  align-items: center;
  gap: 0.55rem;
  font-family: var(--M);
  font-size: var(--fs-label);
  font-weight: 700;
  letter-spacing: 0.3em;
  text-transform: uppercase;
  color: var(--ink);
  background: var(--wheat);
  padding: 0.4rem 0.9rem;
  border-radius: var(--radius-stamp);
  margin-bottom: 1.65rem;
}
.hkd {
  display: inline-block;
  width: 8px;
  height: 8px;
  border-radius: var(--radius-circle);
  background: var(--ink);
  animation: pulse 1.4s ease-in-out infinite; /* literal: idiosyncratic animation timing — not a brand token */
}
@keyframes pulse {
  0%,
  100% {
    opacity: 1;
  }
  50% {
    opacity: 0.35;
  }
}
.hero-h1 {
  font-family: var(--D);
  font-size: clamp(2.97rem, 8.5vw, 7.65rem);
  letter-spacing: -0.05em;
  line-height: 0.86;
  text-transform: uppercase;
  margin-bottom: var(--space-6);
  color: var(--bone);
}
.hero-h1 .ac {
  color: var(--bone);
}
.hero-h1 .or {
  color: var(--accent-text);
}
.hero-h1 .strike {
  position: relative;
  display: inline-block;
  color: var(--bone);
  opacity: 0.55;
}
.hero-h1 .strike::after {
  content: "";
  position: absolute;
  left: -2%;
  right: -2%;
  top: 54%;
  height: 0.065em;
  background: var(--rye);
  transform: rotate(-3deg);
}
.hero-desc {
  font-family: var(--B);
  font-size: 1.25rem;
  line-height: 1.7;
  color: var(--text-body-soft);
  max-width: 540px;
  margin-bottom: 1.85rem;
  font-weight: 500;
}
.hero-desc strong {
  color: var(--bone);
  font-weight: 700;
}
.hero-acts {
  display: flex;
  gap: var(--space-3);
  flex-wrap: wrap;
  margin-bottom: 2.25rem;
}
.hero-stats {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--space-6);
  border-top: 1px solid var(--bd);
  padding-top: 1.4rem;
}
.hs {
  min-width: 80px;
}
.hs-v {
  font-family: var(--D);
  font-size: 2.25rem;
  letter-spacing: -0.04em;
  line-height: 1;
  color: var(--bone);
}
.hs-v.or {
  color: var(--accent-text);
}
.hs-l {
  font-family: var(--M);
  font-size: 0.58rem;
  letter-spacing: 0.24em;
  text-transform: uppercase;
  color: var(--mut);
  margin-top: 0.4rem;
}
.hero-r {
  position: relative;
  aspect-ratio: 0.76 / 1;
  max-width: 540px;
  justify-self: end;
  width: 100%;
}
.hero-bread {
  width: 100%;
  height: 100%;
  background: var(--ink-elev);
  border: 1px solid var(--bd);
  border-radius: var(--radius-card-lg);
  position: relative;
  overflow: hidden;
  box-shadow:
    0 30px 60px rgba(0, 0, 0, 0.5),
    0 0 0 6px rgba(232, 181, 0, 0.04);
}
.hero-bread img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  opacity: 0.85;
}
.hero-stickers > * {
  position: absolute;
}
.hs-stamp-no-maida {
  top: var(--space-6);
  left: var(--space-6);
  font-family: var(--D);
  font-size: 1rem;
  background: var(--wheat);
  color: var(--ink);
  padding: 0.35rem 0.85rem;
  border-radius: var(--radius-stamp);
  transform: rotate(-4deg);
  letter-spacing: -0.02em;
  text-transform: uppercase;
}
.hs-stamp-fresh {
  top: var(--space-6);
  right: var(--space-6);
  font-family: var(--M);
  font-size: var(--fs-mono-sm);
  background: var(--rye);
  color: var(--ink);
  padding: 0.35rem var(--space-3);
  border-radius: var(--radius-rect-badge);
  letter-spacing: 0.22em;
  text-transform: uppercase;
  font-weight: 700;
}
.hs-scrawl-arrow {
  bottom: var(--space-20);
  left: var(--space-6);
  font-family: var(--B);
  font-size: var(--fs-mono-md);
  color: var(--bone);
  letter-spacing: 0.12em;
  line-height: 1.4;
}
.hs-scrawl-arrow em {
  display: block;
  color: var(--accent-text);
  font-style: italic;
  font-weight: 700;
}
.hs-receipt {
  bottom: var(--space-5);
  right: var(--space-5);
  background: var(--ink);
  border: 1px solid var(--wheat);
  padding: 0.85rem var(--space-4);
  border-radius: var(--radius-xs);
  font-family: var(--M);
  font-size: var(--fs-mono-sm);
  color: var(--bone);
  letter-spacing: 0.12em;
  min-width: 150px;
}
.hs-receipt strong {
  display: block;
  color: var(--accent-text);
  margin-bottom: 0.35rem;
  font-size: var(--fs-label);
}
.hs-receipt .row {
  display: flex;
  justify-content: space-between;
  padding: 0.1rem 0;
  border-bottom: 1px dashed rgba(244, 239, 230, 0.15);
}
.hs-receipt .row:last-child {
  border-bottom: none;
}
.hs-receipt .row.tot {
  border-top: 1px solid var(--wheat);
  margin-top: 0.3rem;
  padding-top: 0.35rem;
  color: var(--accent-text);
  font-weight: 700;
}
.ls-kicker {
  display: inline-block;
  font-family: var(--M);
  font-size: 0.62rem;
  font-weight: 700;
  letter-spacing: 0.28em;
  text-transform: uppercase;
  color: var(--accent-text);
  margin-bottom: 0.65rem;
}
.process-strip {
  padding: var(--space-20) max(2rem, calc((100% - 1400px) / 2));
  background: var(--ink);
  border-top: 1px solid var(--bd);
  text-align: center;
}
.process-hd {
  margin-bottom: var(--space-12);
}
.process-hd .sl {
  margin-bottom: 0.85rem;
}
.process-flow {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--space-8);
  position: relative;
}
.process-flow::before {
  content: "";
  position: absolute;
  top: 88px;
  left: 14%;
  right: 14%;
  height: 1px;
  background-image: linear-gradient(90deg, var(--mut) 50%, transparent 50%);
  background-size: 10px 1px;
  opacity: 0;
  z-index: 0;
  transform: scaleX(0);
  transform-origin: left center;
  transition:
    opacity 0.6s var(--easing-reveal),
    transform 0.8s var(--easing-reveal) var(--duration-normal); /* literal: idiosyncratic animation timing — not a brand token */
}
.process-flow.sa-visible::before {
  opacity: 0.45;
  transform: scaleX(1);
}
@media (prefers-reduced-motion: reduce) {
  .process-flow::before {
    opacity: 0.45;
    transform: scaleX(1);
    transition: none;
  }
}
.proc-step {
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  z-index: 1;
}
.proc-num {
  font-family: var(--M);
  font-size: var(--fs-label);
  font-weight: 700;
  letter-spacing: 0.28em;
  color: var(--accent-text);
  margin-bottom: 0.85rem;
}
.proc-icon {
  width: 88px;
  height: 88px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: var(--ink);
  border: 1px solid var(--bd);
  border-radius: var(--radius-circle);
  color: var(--bone);
  margin-bottom: var(--space-5);
  padding: 14px;
  transition:
    border-color var(--duration-medium) var(--easing-smooth),
    transform var(--duration-medium) var(--easing-smooth);
}
.proc-icon svg {
  width: 100%;
  height: 100%;
  display: block;
}
.proc-step:hover .proc-icon {
  border-color: var(--accent-text);
  transform: scale(1.04);
  transition:
    border-color 0.22s var(--easing-smooth),
    transform 0.22s var(--easing-smooth); /* literal: idiosyncratic animation timing — not a brand token */
}
.proc-name {
  font-family: var(--D);
  font-size: 1.35rem;
  letter-spacing: -0.01em;
  text-transform: uppercase;
  color: var(--bone);
  margin: 0 0 0.55rem;
  line-height: 1;
}
.proc-desc {
  font-family: var(--B);
  font-size: 0.9rem;
  line-height: 1.5;
  color: var(--mut);
  max-width: 22ch;
  margin: 0;
}
.process-foot {
  margin: var(--space-12) 0 0;
  text-align: center;
}
.proc-link {
  font-family: var(--M);
  font-size: 0.78rem;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  font-weight: 700;
  color: var(--accent-text);
  text-decoration: none;
  border-bottom: 1px solid currentColor;
  padding-bottom: 2px;
  transition: opacity var(--duration-subtle) ease;
}
.proc-link {
  transition:
    opacity var(--duration-subtle) ease,
    letter-spacing var(--duration-subtle) var(--easing-smooth);
}
.proc-link:hover {
  opacity: 0.85;
  letter-spacing: 0.24em;
}
@media (max-width: 760px) {
  .process-strip {
    padding: var(--space-12) var(--space-5);
  }
  .process-flow {
    grid-template-columns: 1fr 1fr;
    gap: var(--space-10) var(--space-5);
  }
  .process-flow::before {
    display: none;
  }
  .proc-icon {
    width: 72px;
    height: 72px;
    padding: 12px;
  }
  .proc-name {
    font-size: 1.15rem;
  }
  .proc-desc {
    font-size: 0.85rem;
  }
}
.lifestyle-band {
  position: relative;
  min-height: clamp(380px, 50vw, 560px);
  overflow: hidden;
  border-top: 1px solid var(--bd);
  border-bottom: 1px solid var(--bd);
}
.lifestyle-band-img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  z-index: 1;
  aspect-ratio: 1480 / 720;
}
.lifestyle-band-img.sa {
  opacity: 0;
  transform: scale(1.04);
  filter: blur(6px);
}
.lifestyle-band-img.sa.sa-visible {
  opacity: 1;
  transform: scale(1);
  filter: blur(0);
  transition:
    opacity 0.8s var(--easing-reveal),
    transform 0.9s var(--easing-reveal),
    filter 0.8s var(--easing-reveal); /* literal: idiosyncratic animation timing — not a brand token */
}
.lifestyle-band-overlay {
  position: relative;
  z-index: 2;
  display: flex;
  flex-direction: column;
  justify-content: center;
  min-height: clamp(380px, 50vw, 560px);
  padding: var(--space-16) max(2rem, calc((100% - 1400px) / 2));
  background: linear-gradient(
    100deg,
    rgba(20, 17, 14, 0.85) 0%,
    rgba(20, 17, 14, 0.7) 40%,
    rgba(20, 17, 14, 0.15) 80%,
    transparent 100%
  );
  color: #f4efe6; /* literal: text on fixed-dark gradient (rgba ink) — theme-independent */
  max-width: 100%;
}
.lifestyle-band-title {
  font-family: var(--D);
  font-size: clamp(2.3rem, 5.5vw, 4.2rem);
  line-height: 0.92;
  letter-spacing: -0.04em;
  text-transform: uppercase;
  color: #f4efe6; /* literal: heading on fixed-dark gradient — theme-independent */
  margin-bottom: var(--space-4);
  max-width: 16ch;
}
.lifestyle-band-title .ac {
  color: #e8b500; /* literal: accent on fixed-dark gradient — theme-independent */
}
.lifestyle-band-sub {
  font-family: var(--B);
  font-size: 1.15rem;
  line-height: 1.55;
  color: rgba(244, 239, 230, 0.85);
  max-width: 36ch;
}
.lifestyle-band-overlay .ls-kicker {
  color: #e8b500; /* literal: kicker on fixed-dark gradient — theme-independent */
}
@media (max-width: 720px) {
  .lifestyle-band-overlay {
    padding: var(--space-12) var(--space-5);
    background: linear-gradient(
      180deg,
      rgba(20, 17, 14, 0.65) 0%,
      rgba(20, 17, 14, 0.85) 60%,
      rgba(20, 17, 14, 0.95) 100%
    );
  }
  .lifestyle-band-sub {
    font-size: 1rem;
  }
}
.who {
  background: var(--ink);
  border-top: 1px solid var(--bd);
}
.who-in {
  display: grid;
  grid-template-columns: 1fr 2fr;
  gap: 4vw;
  align-items: start;
}
.who-sub {
  font-family: var(--B);
  font-size: var(--fs-body-sm);
  color: var(--mut);
  line-height: 1.75;
  margin-top: var(--space-5);
  max-width: 360px;
}
.who-sub .scrawl {
  display: block;
  margin-top: var(--space-5);
  font-family: var(--D);
  font-size: 1.2rem;
  color: var(--accent-text);
  letter-spacing: -0.02em;
}
.who-cards {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-4);
}
.wc {
  background: var(--ink-elev);
  border: 1px solid var(--bd);
  padding: var(--space-6);
  border-radius: var(--radius-card-sm);
  transition:
    background-color var(--duration-subtle) var(--easing-smooth),
    color var(--duration-subtle) var(--easing-smooth),
    border-color var(--duration-subtle) var(--easing-smooth),
    transform var(--duration-subtle) var(--easing-smooth),
    opacity var(--duration-subtle) var(--easing-smooth);
}
.wc:hover {
  border-color: var(--accent-text);
}
.wc-n {
  font-family: var(--D);
  font-size: 2rem;
  color: var(--accent-text);
  line-height: 1;
  margin-bottom: var(--space-3);
  letter-spacing: -0.04em;
}
.wc-t {
  font-family: var(--D);
  font-size: var(--fs-title);
  letter-spacing: -0.01em;
  text-transform: uppercase;
  margin-bottom: 0.55rem;
  color: var(--bone);
}
.wc-d {
  font-family: var(--B);
  font-size: 0.82rem;
  color: var(--mut);
  line-height: 1.7;
}
@media (max-width: 960px) {
  .who-in {
    grid-template-columns: 1fr;
    gap: var(--space-8);
  }
  .who-cards {
    grid-template-columns: 1fr 1fr;
  }
}
@media (max-width: 600px) {
  .who-cards {
    grid-template-columns: 1fr;
  }
}
.lbl {
  background: var(--ink);
  border-top: 1px solid var(--bd);
}
.lbl-sub {
  font-family: var(--B);
  font-size: 0.92rem;
  color: var(--mut);
  max-width: 520px;
  margin: 0 0 var(--space-10);
  line-height: 1.75;
}
.lbl-cmp {
  display: grid;
  grid-template-columns: 1fr 60px 1fr;
  align-items: stretch;
  gap: 0;
}
.lc {
  background: var(--ink-elev);
  border: 1px solid var(--bd);
  border-radius: var(--radius-card);
  position: relative;
  padding-top: var(--space-4);
}
.lc-bad {
  border-color: var(--rye);
}
.lc-good {
  border-color: var(--accent-text);
}
.lc-stamp {
  position: absolute;
  top: -14px;
  left: 50%;
  transform: translateX(-50%) rotate(-3deg);
  font-family: var(--D);
  font-size: 0.8rem;
  letter-spacing: -0.01em;
  padding: 0.3rem 0.85rem;
  border-radius: var(--radius-stamp);
  background: var(--rye);
  color: var(--ink);
  text-transform: uppercase;
  z-index: 2;
}
.lc-good .lc-stamp {
  background: var(--wheat);
  color: var(--ink);
}
.lc-hd {
  padding: 1.85rem var(--space-7) var(--space-5);
  border-bottom: 1px dashed var(--bd);
  display: flex;
  align-items: flex-start;
  gap: var(--space-5);
  background: rgba(244, 239, 230, 0.02);
}
.lc-good .lc-hd {
  background: rgba(232, 181, 0, 0.04);
}
.lc-bad .lc-hd {
  background: rgba(255, 90, 54, 0.04);
}
.lc-n {
  font-family: var(--D);
  font-size: 4rem;
  line-height: 1;
  letter-spacing: -0.04em;
  flex-shrink: 0;
}
.lc-n-r {
  color: var(--rye);
}
.lc-n-g {
  color: var(--accent-text);
}
.lc-ht {
  font-family: var(--D);
  font-size: var(--fs-title);
  letter-spacing: -0.01em;
  text-transform: uppercase;
}
.lc-ht-r {
  color: var(--rye);
}
.lc-ht-g {
  color: var(--accent-text);
}
.lc-hs {
  font-family: var(--M);
  font-size: 0.62rem;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--mut);
  margin-top: 0.35rem;
  line-height: 1.5;
}
.lc-bd {
  padding: var(--space-6) var(--space-7);
}
.lc-ul {
  list-style: none;
}
.lc-li {
  display: flex;
  align-items: flex-start;
  gap: var(--space-3);
  padding: 0.55rem 0;
  border-bottom: 1px dashed var(--bd);
}
.lc-li:last-child {
  border-bottom: none;
}
.lc-dot {
  width: 8px;
  height: 8px;
  border-radius: var(--radius-circle);
  flex-shrink: 0;
  margin-top: 0.45rem;
}
.lc-dr {
  background: var(--rye);
}
.lc-dg {
  background: var(--wheat);
}
.lc-tx {
  font-family: var(--B);
  font-size: 0.82rem;
  line-height: 1.6;
  color: var(--text-body);
  font-weight: 500;
}
.lc-tx strong {
  color: var(--bone);
  font-weight: 700;
}
.lc-fn {
  font-family: var(--M);
  font-size: 0.62rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  font-style: normal;
  margin-top: var(--space-5);
  color: var(--mut);
  line-height: 1.5;
}
.lc-vs {
  display: flex;
  align-items: center;
  justify-content: center;
}
.lc-vs-t {
  font-family: var(--D);
  font-size: 1.8rem;
  letter-spacing: -0.04em;
  color: var(--ink);
  background: var(--wheat);
  width: 60px;
  height: 60px;
  border: 2px solid var(--ink);
  border-radius: var(--radius-circle);
  display: flex;
  align-items: center;
  justify-content: center;
  transform: rotate(-8deg);
}
@media (max-width: 960px) {
  .lbl-cmp {
    grid-template-columns: 1fr;
    gap: var(--space-8);
  }
  .lc-vs-t {
    margin: 0 auto;
  }
}
.ings {
  background: var(--ink);
  border-top: 1px solid var(--bd);
  text-align: left;
}
.ing-g {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-5);
  margin-top: var(--space-8);
}
.ing-c {
  background: var(--ink-elev);
  border: 1px solid var(--bd);
  border-radius: var(--radius-card);
  overflow: hidden;
}
.ing-ct {
  padding: var(--space-5) var(--space-6);
  border-bottom: 1px dashed var(--bd);
  background: rgba(232, 181, 0, 0.04);
}
.ing-cp {
  font-family: var(--D);
  font-size: 1.15rem;
  letter-spacing: -0.02em;
  text-transform: uppercase;
  color: var(--accent-text);
  line-height: 1;
}
.ing-cc {
  font-family: var(--M);
  font-size: 0.62rem;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--mut);
  margin-top: 0.4rem;
}
.ing-cb {
  padding: var(--space-5) var(--space-6) var(--space-6);
}
.ing-li {
  display: flex;
  align-items: flex-start;
  gap: 0.85rem;
  padding: 0.55rem 0;
  border-bottom: 1px dashed var(--bd);
}
.ing-li:last-of-type {
  border-bottom: none;
  padding-bottom: 0.9rem;
}
.ing-n {
  font-family: var(--D);
  font-size: 1.1rem;
  color: var(--accent-text);
  line-height: 1;
  width: 22px;
  flex-shrink: 0;
  letter-spacing: -0.02em;
}
.ing-t {
  display: flex;
  flex-direction: column;
}
.ing-t strong {
  font-family: var(--D);
  font-size: 0.92rem;
  color: var(--bone);
  letter-spacing: -0.01em;
}
.ing-t span {
  font-family: var(--B);
  font-size: 0.75rem;
  color: var(--mut);
  margin-top: 0.2rem;
}
.ing-end {
  font-family: var(--M);
  font-size: var(--fs-mono-sm);
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--accent-text);
  margin-top: 0.65rem;
  padding-top: 0.65rem;
  border-top: 1px solid var(--wheat);
  text-align: center;
}
@media (max-width: 960px) {
  .ing-g {
    grid-template-columns: 1fr;
    gap: var(--space-4);
  }
}
.shame {
  background: var(--ink);
  border-top: 1px solid var(--bd);
  position: relative;
  overflow: hidden;
}
.shame::before {
  content: "WALL OF SHAME · WALL OF SHAME · WALL OF SHAME · WALL OF SHAME · ";
  position: absolute;
  top: 30px;
  left: 0;
  right: 0;
  font-family: var(--D);
  font-size: 7rem;
  color: rgba(255, 90, 54, 0.05);
  white-space: nowrap;
  letter-spacing: -0.04em;
  pointer-events: none;
}
.shame-hd {
  position: relative;
  z-index: 2;
  margin-bottom: var(--space-12);
}
.shame-tabloid {
  font-family: var(--M);
  text-transform: uppercase;
  color: var(--rye);
  font-size: 0.82rem;
  letter-spacing: 0.34em;
  margin-bottom: 0.65rem;
  font-weight: 700;
}
.shame-tabloid::before,
.shame-tabloid::after {
  content: " ★ ";
  opacity: 0.5;
}
.shame-sub {
  font-family: var(--B);
  color: var(--mut);
  font-size: 0.92rem;
  max-width: 560px;
  margin-top: var(--space-4);
  line-height: 1.75;
}
.shame-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-6);
  position: relative;
  z-index: 2;
}
.shame-card {
  background: var(--ink-elev);
  border: 1px solid var(--bd);
  border-radius: var(--radius-card-sm);
  padding: var(--space-6);
  position: relative;
}
.shame-card:hover {
  transform: translateY(-3px);
  border-color: var(--rye);
}
.shame-stamp {
  position: absolute;
  top: 10px;
  right: 12px;
  font-family: var(--D);
  font-size: 0.82rem;
  letter-spacing: -0.01em;
  background: var(--rye);
  color: var(--ink);
  padding: var(--space-1) var(--space-3);
  border-radius: var(--radius-stamp);
  transform: rotate(4deg);
  text-transform: uppercase;
}
.shame-cat {
  font-family: var(--M);
  font-size: 0.58rem;
  text-transform: uppercase;
  letter-spacing: 0.26em;
  color: var(--mut);
  margin-bottom: 0.45rem;
}
.shame-claim {
  font-family: var(--D);
  font-size: 1.1rem;
  text-transform: uppercase;
  letter-spacing: -0.02em;
  margin-bottom: var(--space-4);
  line-height: 1.05;
  color: var(--bone);
}
.shame-label {
  background: var(--ink);
  border: 1px dashed var(--bd);
  padding: 0.85rem;
  font-family: var(--M);
  font-size: var(--fs-label);
  line-height: 1.7;
  letter-spacing: 0.04em;
  color: var(--mut);
  border-radius: var(--radius-xs);
  margin-bottom: var(--space-4);
}
.shame-label-h {
  font-family: var(--D);
  font-size: 0.75rem;
  letter-spacing: -0.01em;
  color: var(--bone);
  margin-bottom: 0.35rem;
}
.shame-verdict {
  font-family: var(--D);
  font-size: 1rem;
  color: var(--bone);
  letter-spacing: -0.01em;
  text-transform: uppercase;
  line-height: 1.15;
}
.shame-verdict .scrawl-line {
  display: block;
  font-family: var(--D);
  font-size: 1.1rem;
  color: var(--accent-text);
  text-transform: none;
  letter-spacing: -0.01em;
  margin-top: 0.45rem;
}
@media (max-width: 960px) {
  .shame-grid {
    grid-template-columns: 1fr;
    gap: var(--space-4);
  }
}
.toast {
  background: var(--ink);
  border-top: 1px solid var(--bd);
}
.toast-hd {
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
  margin-bottom: var(--space-10);
  flex-wrap: wrap;
  gap: var(--space-6);
}
.toast-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--space-4);
}
.toast-c {
  background: var(--ink-elev);
  border: 1px solid var(--bd);
  border-radius: var(--radius-card-sm);
  overflow: hidden;
  position: relative;
}
.toast-c:hover {
  transform: translateY(-3px);
  border-color: var(--accent-text);
}
.toast-img {
  height: 200px;
  position: relative;
  overflow: hidden;
  background: var(--ink-elev-2);
}
.toast-img img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  opacity: 0.9;
}
.toast-num {
  position: absolute;
  top: 8px;
  left: 8px;
  font-family: var(--D);
  font-size: 1rem;
  background: var(--wheat);
  color: var(--ink);
  padding: 0.2rem 0.65rem;
  border-radius: var(--radius-stamp);
  letter-spacing: -0.02em;
}
.toast-bd {
  padding: var(--space-4) var(--space-5) var(--space-5);
}
.toast-tag {
  font-family: var(--M);
  font-size: 0.58rem;
  letter-spacing: 0.26em;
  text-transform: uppercase;
  color: var(--accent-text);
  font-weight: 700;
  margin-bottom: 0.4rem;
}
.toast-name {
  font-family: var(--D);
  font-size: 0.89rem;
  letter-spacing: -0.02em;
  text-transform: uppercase;
  margin-bottom: 0.55rem;
  line-height: 1.05;
  color: var(--bone);
}
.toast-d {
  font-family: var(--B);
  font-size: 0.97rem;
  color: var(--mut);
  line-height: 1.6;
  margin-bottom: 0.85rem;
}
.toast-time {
  font-family: var(--M);
  font-size: 0.62rem;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--bone);
  font-weight: 700;
  display: flex;
  align-items: center;
  gap: 0.4rem;
  padding-top: 0.65rem;
  border-top: 1px dashed var(--bd);
}
@media (max-width: 960px) {
  .toast-grid {
    grid-template-columns: 1fr 1fr;
  }
}
@media (max-width: 600px) {
  .toast-grid {
    grid-template-columns: 1fr;
  }
}
.rev {
  background: var(--ink);
  border-top: 1px solid var(--bd);
}
.rev-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-5);
  margin-top: var(--space-8);
}
.rev-c {
  background: var(--ink-elev);
  border: 1px solid var(--bd);
  border-radius: var(--radius-card-sm);
  padding: var(--space-6);
  position: relative;
}
.rev-c::before {
  content: '"';
  position: absolute;
  top: 0.6rem;
  right: var(--space-4);
  font-family: var(--D);
  font-size: 4rem;
  color: var(--accent-text);
  opacity: 0.35;
  line-height: 1;
}
.stars {
  color: var(--accent-text);
  font-size: 0.92rem;
  margin-bottom: var(--space-4);
}
.rev-quote {
  font-family: var(--B);
  font-size: 1.15rem;
  color: var(--text-body);
  line-height: 1.7;
  margin-bottom: var(--space-5);
}
.rev-quote mark {
  background: var(--wheat);
  color: var(--ink);
  padding: 0 0.2em;
}
.rev-by {
  display: flex;
  align-items: center;
  gap: 0.85rem;
  border-top: 1px dashed var(--bd);
  padding-top: var(--space-4);
}
.rev-by-avatar {
  width: 38px;
  height: 38px;
  border-radius: var(--radius-circle);
  background: var(--wheat);
  color: var(--ink);
  display: grid;
  place-items: center;
  font-family: var(--D);
  font-size: 0.85rem;
}
.rev-by-name {
  font-family: var(--D);
  font-size: 0.78rem;
  color: var(--bone);
  letter-spacing: -0.01em;
  text-transform: uppercase;
}
.rev-by-role {
  font-family: var(--M);
  font-size: 0.62rem;
  color: var(--mut);
  letter-spacing: 0.2em;
  text-transform: uppercase;
  margin-top: 0.15rem;
}
@media (max-width: 960px) {
  .rev-grid {
    grid-template-columns: 1fr;
  }
}
.avail {
  background: var(--ink);
  border-top: 1px solid var(--bd);
}
.avail-logos {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: var(--space-4);
  margin-top: var(--space-8);
}
.avail-cities {
  display: flex;
  flex-wrap: wrap;
  gap: 0.85rem;
  margin-top: var(--space-8);
}
.avail-soon-row {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
  align-items: center;
}
.avail-soon-note {
  font-family: var(--M);
  font-size: 0.6rem;
  font-weight: 700;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--mut);
  margin-top: var(--space-1);
}
.avail-sub {
  font-family: var(--B);
  font-size: var(--fs-body-sm);
  color: var(--mut);
  line-height: 1.75;
  max-width: 640px;
  margin-bottom: var(--space-4);
}
.avail-sub strong {
  color: var(--bone);
  font-weight: 700;
}
.avail-logo-card,
.avail-city,
.av {
  display: inline-flex;
  align-items: center;
  gap: 0.85rem;
  background: var(--ink-elev);
  border: 1.5px solid var(--bd);
  border-radius: var(--radius-stamp);
  padding: 0.85rem var(--space-5) 0.85rem var(--space-4);
  position: relative;
  transition:
    border-color var(--duration-subtle),
    background var(--duration-subtle);
  font-family: var(--M);
  font-size: var(--fs-mono-md);
  letter-spacing: 0.14em;
}
.avail-logo-card:hover,
.avail-city:hover {
  border-color: var(--accent-text);
}
.avail-logo-card.avail-live {
  border-color: var(--accent-text);
}
.avail-icon {
  font-size: 1rem;
  display: inline-grid;
  place-items: center;
  width: 28px;
  height: 28px;
  background: var(--ink);
  border-radius: var(--radius-circle);
  flex-shrink: 0;
}
.avail-name,
.avail-city-name {
  font-family: var(--D);
  font-size: 0.82rem;
  letter-spacing: -0.01em;
  text-transform: uppercase;
  color: var(--bone);
  white-space: nowrap;
}
.avail-tag,
.avail-city-status {
  font-family: var(--M);
  font-size: 0.6rem;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  font-weight: 700;
  color: var(--mut);
  margin-left: auto;
  white-space: nowrap;
}
.avail-city-status.soon {
  color: var(--mut);
}
.avail-logo-card.avail-live {
  background: var(--ink);
  border-color: var(--accent-text);
  border-width: 2px;
  padding: 1.1rem var(--space-6) 1.1rem 1.1rem;
  gap: var(--space-4);
}
.avail-logo-card.avail-live .avail-name {
  font-size: 1rem;
  color: var(--accent-text);
}
.avail-logo-card.avail-live .avail-tag {
  color: var(--accent-text);
  font-size: var(--fs-mono-sm);
}
.avail-logo-card.avail-live .avail-icon {
  background: var(--wheat);
  color: var(--ink);
  width: 36px;
  height: 36px;
  font-size: 1.2rem;
}
.avail-logo-card.avail-soon {
  opacity: 0.65;
  padding: 0.55rem 0.9rem 0.55rem 0.65rem;
  gap: var(--space-2);
  font-size: var(--fs-label);
}
.avail-logo-card.avail-soon .avail-icon {
  width: 22px;
  height: 22px;
  font-size: 0.8rem;
}
.avail-logo-card.avail-soon .avail-name {
  font-size: var(--fs-mono-md);
}
.avail-logo-card.avail-soon:hover {
  opacity: 1;
}
.avail-city.avail-city-soon {
  opacity: 0.72;
}
.avail-city.avail-city-soon:hover {
  opacity: 1;
}
.avail-city.avail-city-live {
  display: inline-flex;
  align-items: center;
  gap: 0.85rem;
  padding: 0.95rem 1.35rem 0.95rem 1.1rem;
  background: var(--ink);
  border: 1.5px solid var(--accent-text);
  border-radius: var(--radius-stamp);
  color: var(--bone);
  text-decoration: none;
  position: relative;
  overflow: hidden;
  transition:
    transform var(--duration-normal) var(--easing-smooth),
    border-color var(--duration-normal) var(--easing-smooth),
    box-shadow var(--duration-normal) var(--easing-smooth);
}
.avail-city.avail-city-live::before {
  content: "";
  position: absolute;
  inset: -2px;
  border-radius: inherit;
  background: radial-gradient(circle at 12% 50%, rgba(232, 181, 0, 0.18), transparent 55%);
  z-index: 0;
  pointer-events: none;
}
.avail-city.avail-city-live > * {
  position: relative;
  z-index: 1;
}
.avail-city.avail-city-live:hover {
  transform: translateY(-2px);
  border-color: var(--wheat);
  box-shadow: 0 6px 20px -10px rgba(232, 181, 0, 0.55);
}
.avail-city.avail-city-live .avail-city-name {
  font-family: var(--D);
  font-size: 1rem;
  letter-spacing: -0.01em;
  text-transform: uppercase;
  color: var(--bone);
}
.avail-city.avail-city-live .avail-city-status {
  font-family: var(--M);
  font-size: 0.62rem;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--accent-text);
  margin-left: 0;
}
.avail-live-dot {
  display: inline-block;
  width: 9px;
  height: 9px;
  border-radius: var(--radius-circle);
  background: var(--wheat);
  box-shadow: 0 0 0 0 rgba(232, 181, 0, 0.6);
  animation: bw-live-pulse 1.6s var(--easing-reveal) infinite; /* literal: idiosyncratic animation timing — not a brand token */
  flex-shrink: 0;
}
@keyframes bw-live-pulse {
  0% {
    box-shadow: 0 0 0 0 rgba(232, 181, 0, 0.55);
  }
  70% {
    box-shadow: 0 0 0 10px rgba(232, 181, 0, 0);
  }
  100% {
    box-shadow: 0 0 0 0 rgba(232, 181, 0, 0);
  }
}
@media (prefers-reduced-motion: reduce) {
  .avail-live-dot {
    animation: none;
  }
}
.avail-live-tag {
  font-family: var(--M);
  font-size: 0.6rem;
  font-weight: 700;
  letter-spacing: 0.22em;
  background: var(--wheat);
  color: var(--ink);
  padding: var(--space-1) 0.55rem;
  border-radius: var(--radius-stamp);
  margin-left: 0.35rem;
}
html[data-theme="light"] .avail-city.avail-city-live {
  background: var(--ink-elev);
  border-color: var(--accent-text);
}
html[data-theme="light"] .avail-city.avail-city-live .avail-city-name {
  color: var(--bone);
}
html[data-theme="light"] .avail-live-tag {
  background: var(--wheat);
  color: #14110e; /* literal: dark-on-wheat in light theme — wheat doesn't flip */
}
html[data-theme="light"] .avail-city.avail-city-live:hover {
  border-color: var(--wheat);
  box-shadow: 0 6px 20px -10px rgba(160, 116, 8, 0.45);
}
@media (max-width: 600px) {
  .avail-cities {
    gap: 0.55rem;
  }
  .avail-city {
    width: 100%;
    padding: 0.65rem 0.85rem;
  }
  .avail-logo-card.avail-live {
    width: 100%;
    padding: 0.9rem 1.1rem;
    flex-wrap: wrap;
  }
  .avail-logo-card.avail-live .avail-tag {
    margin-left: 0;
  }
  .avail-city.avail-city-live {
    width: 100%;
    flex-wrap: wrap;
    box-sizing: border-box;
    padding: 0.85rem 1.1rem;
  }
  .avail-city.avail-city-live .avail-city-status {
    margin-left: 0;
  }
  .avail-soon-row {
    gap: 0.35rem;
  }
  .avail-name {
    font-size: 0.76rem;
  }
}
@media (max-width: 400px) {
  .avail-logo-card.avail-live .avail-name {
    font-size: 0.82rem;
  }
  .avail-city.avail-city-live .avail-city-status {
    display: none;
  }
}
.cta-slab,
.nl {
  background: var(--wheat);
  color: var(--ink);
  padding: var(--space-24) var(--space-8);
  text-align: center;
  position: relative;
  overflow: hidden;
}
.cta-slab::before,
.nl::before {
  content: "";
  position: absolute;
  inset: 0;
  background-image: radial-gradient(rgba(0, 0, 0, 0.07) 1px, transparent 1px);
  background-size: 4px 4px;
  pointer-events: none;
}
.cta-slab > *,
.nl > * {
  position: relative;
  z-index: 2;
}
.cta-slab h2.slab,
.nl h2 {
  font-family: var(--D);
  font-size: clamp(3.5rem, 9vw, 8rem);
  margin-bottom: var(--space-5);
  max-width: 16ch;
  margin-left: auto;
  margin-right: auto;
  letter-spacing: -0.04em;
  line-height: 0.88;
  text-transform: uppercase;
}
.cta-slab .lede,
.nl p {
  font-family: var(--M);
  font-size: 0.82rem;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  max-width: 520px;
  margin: 0 auto var(--space-8);
  font-weight: 700;
}
.cta-slab .cta-ac,
.nl .cta-ac {
  background: var(--ink);
  color: var(--accent-text);
  border-color: var(--ink);
  padding: var(--space-5) 2.25rem;
  font-size: 1rem;
}
.cta-slab .cta-ac:hover,
.nl .cta-ac:hover {
  background: var(--bone);
  color: var(--ink);
  border-color: var(--bone);
}
.nl-in {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 4vw;
  align-items: center;
  max-width: 1200px;
  margin: 0 auto;
  position: relative;
  z-index: 2;
  text-align: left;
}
.nl .st {
  font-size: clamp(2.2rem, 3.8vw, 3.8rem);
  margin-bottom: 0;
  color: #14110e; /* literal: dark text on .nl wheat bg — theme-independent */
}
html .nl .st .ac,
html .nl .st .ac2,
html[data-theme="light"] .nl .st .ac,
html[data-theme="light"] .nl .st .ac2 {
  color: #14110e; /* literal: dark text on .nl wheat bg — theme-independent */
  background: transparent;
  padding: 0;
}
.nl .sl {
  color: #14110e; /* literal: dark text on .nl wheat bg — theme-independent */
}
.nl .sl::before {
  background: #14110e; /* literal: dark accent rule on .nl wheat bg — theme-independent */
}
.nl-rp {
  font-family: var(--B);
  font-size: 0.92rem;
  color: rgba(20, 17, 14, 0.72);
  margin-bottom: var(--space-6);
  line-height: 1.7;
}
.nl-form {
  display: flex;
  gap: 0;
  background: var(--ink);
  border: 2px solid var(--ink);
  border-radius: var(--radius-stamp);
  padding: 4px;
}
.nl-form input {
  flex: 1;
  background: transparent;
  border: 0;
  font-family: var(--M);
  font-size: 0.8rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  padding: 0.85rem var(--space-5);
  color: var(--bone);
  outline: none;
}
.nl-form input::placeholder {
  color: rgba(244, 239, 230, 0.45);
}
.nl-form button {
  font-family: var(--D);
  font-size: 0.82rem;
  letter-spacing: -0.01em;
  text-transform: uppercase;
  padding: 0.85rem var(--space-6);
  border-radius: var(--radius-stamp);
  background: var(--wheat);
  color: var(--ink);
  border: 0;
  cursor: pointer;
}
.nl-form button:hover {
  background: var(--bone);
}
.slim-cta {
  background: var(--ink);
  border-top: 2px solid var(--wheat);
  border-bottom: 2px solid var(--wheat);
  text-align: center;
  padding-top: 3.5rem;
  padding-bottom: 3.5rem;
}
.slim-cta .sl {
  justify-content: center;
}
.slim-cta-desc {
  font-family: var(--B);
  color: var(--mut);
  font-size: var(--fs-body-sm);
  max-width: 520px;
  margin: var(--space-5) auto var(--space-7);
  line-height: 1.7;
}
@media (max-width: 960px) {
  .nl-in {
    grid-template-columns: 1fr;
    gap: var(--space-8);
    text-align: center;
  }
}
@media (max-width: 600px) {
  .hero {
    grid-template-columns: 1fr;
    gap: var(--space-8);
    padding: var(--space-10) var(--space-6) 3.5rem;
  }
  .hero-r {
    max-width: 380px;
    margin: 0 auto;
  }
  .hero-h1 {
    font-size: clamp(2.4rem, 11vw, 3.6rem);
    margin-bottom: var(--space-5);
  }
  .hero-desc {
    font-size: var(--fs-title);
    margin-bottom: var(--space-6);
  }
  .hero-kicker {
    font-size: 0.62rem;
    padding: 0.35rem 0.8rem;
    margin-bottom: var(--space-5);
  }
  .hero-acts {
    gap: 0.65rem;
    margin-bottom: var(--space-7);
  }
  .hero-acts .cta-ac,
  .hero-acts .cta-wh {
    min-height: 48px;
    padding: 0.85rem var(--space-5);
    flex: 1 1 auto;
    justify-content: center;
  }
  .hero-stats {
    grid-template-columns: 1fr 1fr;
    gap: var(--space-6) var(--space-5);
    padding-top: var(--space-7);
  }
  .hs-v {
    font-size: 1.65rem;
  }
  .hs-l {
    font-size: 0.55rem;
  }
  .cta-slab {
    padding: 3.5rem var(--space-6);
  }
  .nl-form {
    flex-direction: column;
    gap: var(--space-2);
    border-radius: var(--radius-card);
    padding: var(--space-2);
  }
  .nl-form input {
    padding: 0.95rem var(--space-5);
    min-height: 48px;
  }
  .nl-form button {
    border-radius: var(--radius-md);
    min-height: 48px;
  }
  .wc,
  .shame-card,
  .rev-c,
  .ing-c,
  .ing-ct,
  .toast-c {
    padding-left: var(--space-5);
    padding-right: var(--space-5);
  }
}
/* Mobile availability cards (≤600px): drop the wrap-to-second-row
   sub-labels on the live cards so heights match the soon cards
   stacked beneath them. The yellow border on BREADWINNERFOODS already
   signals "live"; the green LIVE pill on Mumbai signals "today". The
   "AVAILABLE NOW" tag and "Direct delivery · today" caption are
   redundant once the colour/badge is doing the work. */
@media (max-width: 600px) {
  .avail-logo-card.avail-live {
    flex-wrap: nowrap;
    padding: var(--space-3) 1.1rem;
    gap: 0.85rem;
  }
  .avail-logo-card.avail-live .avail-name {
    font-size: 0.82rem;
  }
  .avail-logo-card.avail-live .avail-icon {
    width: 28px;
    height: 28px;
    font-size: 1rem;
  }
  .avail-logo-card.avail-live .avail-tag {
    display: none;
  }
  .avail-city.avail-city-live {
    flex-wrap: nowrap;
    padding: 0.7rem 1.1rem;
    gap: var(--space-3);
  }
  .avail-city.avail-city-live .avail-city-name {
    font-size: 0.85rem;
  }
  .avail-city.avail-city-live .avail-city-status {
    display: none;
  }
}
/* Hero corner stamps shrink on small phones so "No Maida." and
   "Baked Today" don't collide on a narrow bread-image area. At very
   small widths (≤380px, e.g. iPhone SE) the decorative red BAKED
   TODAY stamp hides entirely — the yellow NO MAIDA pill is the
   brand-essential one. */
@media (max-width: 600px) {
  .hs-stamp-no-maida {
    top: var(--space-4);
    left: var(--space-4);
    font-size: 0.82rem;
    padding: var(--space-1) 0.65rem;
  }
  .hs-stamp-fresh {
    top: var(--space-4);
    right: var(--space-4);
    font-size: 0.55rem;
    padding: var(--space-1) 0.55rem;
    letter-spacing: 0.16em;
  }
}
@media (max-width: 380px) {
  .hs-stamp-fresh {
    display: none;
  }
}
/* Avail + Newsletter section shrink (audit-2026-05-19 user feedback —
   "take too much space without conveying much, at least 80% smaller").
   These two sections were ~600-800px tall on desktop with giant slab
   headlines + 5-6rem vertical padding. Cut padding to ~1.5rem and
   headline clamp to ~1.5rem so they read as inline-ish utility strips
   rather than landing-page hero sections. Copy moved to single-line
   variants in index.html. */
.sec.avail {
  padding: var(--space-6) max(2rem, calc((100% - 1400px) / 2));
}
.sec.avail .sl {
  margin-bottom: var(--space-2);
}
.sec.avail .st {
  font-size: clamp(1.15rem, 1.7vw, 1.55rem);
  margin-bottom: 0.55rem;
  line-height: 1.15;
}
.sec.avail .avail-sub {
  font-size: 0.82rem;
  margin-bottom: 0.85rem;
  line-height: 1.5;
  max-width: none;
}
.sec.avail .avail-logos {
  margin-top: 0.85rem;
  gap: 0.55rem;
}
.sec.avail .avail-cities {
  margin-top: 0.85rem;
  gap: var(--space-2);
}
.sec.avail .avail-logo-card.avail-live {
  padding: var(--space-2) 0.95rem var(--space-2) 0.7rem;
  border-width: 1.5px;
  gap: 0.6rem;
}
.sec.avail .avail-logo-card.avail-live .avail-name {
  font-size: 0.82rem;
}
.sec.avail .avail-logo-card.avail-live .avail-icon {
  width: 22px;
  height: 22px;
  font-size: 0.8rem;
}
.sec.avail .avail-logo-card.avail-live .avail-tag {
  font-size: 0.54rem;
}
.sec.avail .avail-logo-card.avail-soon {
  padding: 0.35rem 0.65rem 0.35rem var(--space-2);
  font-size: 0.6rem;
}
.sec.avail .avail-logo-card.avail-soon .avail-name {
  font-size: 0.66rem;
}
.sec.avail .avail-soon-note {
  font-size: 0.54rem;
  margin-top: 0.15rem;
}
.sec.avail .avail-city {
  padding: var(--space-2) 0.8rem;
}
.sec.avail .avail-city .avail-city-name {
  font-size: 0.76rem;
}
.sec.avail .avail-city.avail-city-live {
  padding: var(--space-2) 0.85rem var(--space-2) 0.7rem;
  gap: 0.55rem;
}
.sec.avail .avail-city.avail-city-live .avail-city-name {
  font-size: 0.85rem;
}
.sec.avail .avail-city.avail-city-live .avail-city-status {
  font-size: 0.54rem;
}
.sec.avail .avail-live-tag {
  font-size: 0.5rem;
  padding: 0.15rem 0.4rem;
}
.sec.avail .avail-live-dot {
  width: 7px;
  height: 7px;
}
/* Mobile-only inline alternates introduced for the avail-section shrink */
.avail-soon-text-mobile {
  display: none;
}
.avail-cities-toggle {
  display: none;
}
@media (max-width: 600px) {
  .avail-soon-text-mobile {
    display: block;
    font-family: var(--M);
    font-size: 0.6rem;
    letter-spacing: 0.06em;
    color: var(--mut);
    line-height: 1.55;
    margin-top: 0.4rem;
    text-transform: uppercase;
  }
  .avail-soon-text-mobile strong {
    color: var(--bone);
    font-weight: 700;
    letter-spacing: 0.04em;
  }
  .avail-cities-toggle {
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
    margin-top: 0.45rem;
    background: transparent;
    border: 1px dashed var(--bd);
    color: var(--mut);
    font-family: var(--M);
    font-size: 0.6rem;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    padding: 0.45rem 0.85rem;
    border-radius: var(--radius-stamp);
    cursor: pointer;
    transition:
      border-color var(--duration-fast),
      color var(--duration-fast);
  }
  .avail-cities-toggle:hover,
  .avail-cities-toggle:focus-visible {
    border-color: var(--accent-text);
    color: var(--bone);
  }
  .avail-cities-toggle[aria-expanded="true"] {
    border-style: solid;
    color: var(--bone);
  }
  .avail-cities-toggle[aria-expanded="true"]::before {
    content: "−";
    font-family: var(--D);
    font-size: 0.85rem;
    font-weight: 900;
    color: var(--accent-text);
  }
  .avail-cities-toggle:not([aria-expanded="true"])::before {
    content: "+";
    font-family: var(--D);
    font-size: 0.85rem;
    font-weight: 900;
    color: var(--accent-text);
  }
  /* Remove the literal '+' from the button text since the ::before adds one */
  .avail-cities-toggle {
    text-indent: 0;
  }
}
html[data-theme="light"] .avail-cities-toggle {
  border-color: var(--bd);
  color: var(--mut);
}
html[data-theme="light"] .avail-soon-text-mobile {
  color: var(--mut);
}
html[data-theme="light"] .avail-soon-text-mobile strong {
  color: var(--bone);
}

.sec.nl {
  padding: var(--space-6) var(--space-8);
  text-align: left;
}
.sec.nl::before {
  display: none;
}
.sec.nl .nl-in {
  gap: var(--space-8);
  align-items: center;
  text-align: left;
}
.sec.nl .sl {
  margin-bottom: 0.4rem;
}
.sec.nl .st {
  font-size: clamp(1.15rem, 1.7vw, 1.55rem);
  margin-bottom: 0;
  line-height: 1.15;
}
.sec.nl .nl-rp {
  font-size: 0.78rem;
  margin-bottom: 0.65rem;
  line-height: 1.55;
}
.sec.nl .nl-form {
  padding: 3px;
  border-width: 1.5px;
}
.sec.nl .nl-form input {
  padding: 0.6rem var(--space-4);
  font-size: var(--fs-mono-md);
  min-height: 0;
}
.sec.nl .nl-form button {
  padding: 0.6rem 1.1rem;
  font-size: 0.7rem;
  min-height: 0;
}

@media (max-width: 600px) {
  .sec.avail {
    padding: 0.85rem var(--space-4);
  }
  .sec.avail .sl {
    margin-bottom: var(--space-1);
    font-size: 0.55rem;
    letter-spacing: 0.22em;
  }
  .sec.avail .st {
    font-size: 1rem;
    line-height: 1.15;
    margin-bottom: 0.4rem;
  }
  /* Option C: drop avail-sub paragraph on mobile (headline + visible pills
     tell the same story already). Saves ~50px. */
  .sec.avail .avail-sub {
    display: none;
  }
  .sec.avail .avail-logos {
    margin-top: 0.45rem;
    gap: 0.35rem;
  }
  .sec.avail .avail-cities {
    margin-top: 0.45rem;
    gap: 0.3rem;
    flex-wrap: wrap;
  }
  /* "Coming soon to all of the above" was a redundant repeater — every
     soon pill already says 'coming soon'. Hide on mobile to reclaim space. */
  .sec.avail .avail-soon-note {
    display: none;
  }
  /* Option A: hide the 5 stacked brand-platform soon pills on mobile;
     show the one-line .avail-soon-text-mobile instead. */
  .sec.avail .avail-soon-row {
    display: none;
  }
  /* Option B: hide the 4 soon-city pills by default on mobile, behind
     the .avail-cities-toggle button. Default state shows Mumbai LIVE
     only. Tap toggle to expand the list. */
  .sec.avail .avail-cities .avail-city.avail-city-soon {
    display: none;
  }
  .sec.avail .avail-cities.is-expanded .avail-city.avail-city-soon {
    display: inline-flex;
  }
  /* Brand pills (SWIGGY/ZEPTO/etc): 2-3 per row instead of 1-per-row stack */
  .sec.avail .avail-soon-row {
    display: flex;
    flex-wrap: wrap;
    gap: 0.35rem;
  }
  .sec.avail .avail-soon-row .avail-logo-card.avail-soon {
    width: auto;
    flex: 0 0 auto;
    padding: 0.3rem 0.6rem 0.3rem var(--space-2);
  }
  .sec.avail .avail-logo-card.avail-live {
    width: 100%;
    padding: var(--space-2) 0.85rem;
  }
  .sec.avail .avail-logo-card.avail-live .avail-name {
    font-size: 0.78rem;
  }
  .sec.avail .avail-soon-note {
    font-size: 0.5rem;
    margin-top: 0.15rem;
  }
  /* City pills: Mumbai LIVE keeps full row for emphasis, others 2 per row */
  .sec.avail .avail-cities .avail-city.avail-city-live {
    width: 100%;
    padding: var(--space-2) 0.85rem var(--space-2) 0.65rem;
    gap: var(--space-2);
  }
  .sec.avail .avail-cities .avail-city.avail-city-live .avail-city-name {
    font-size: 0.85rem;
  }
  .sec.avail .avail-cities .avail-city.avail-city-live .avail-city-status {
    font-size: 0.5rem;
    display: inline;
  }
  .sec.avail .avail-cities .avail-city.avail-city-soon {
    width: calc(50% - 0.2rem);
    flex: 0 0 calc(50% - 0.2rem);
    padding: 0.4rem 0.6rem;
    justify-content: space-between;
  }
  .sec.avail .avail-cities .avail-city.avail-city-soon .avail-city-name {
    font-size: var(--fs-label);
  }
  .sec.avail .avail-cities .avail-city.avail-city-soon .avail-city-status {
    font-size: 0.48rem;
    letter-spacing: 0.12em;
  }

  /* Newsletter mobile padding tightened. Specificity 0,2,0 (.sec.nl)
     beats 0,1,0 (.sec) naturally — no !important needed once the
     duplicate .sec{padding:...!important} pollution in pages.css is
     removed (commit chain 2026-05-20). */
  .sec.nl {
    padding: 0.55rem 0.9rem 0.65rem;
  }
  .sec.avail {
    padding: 0.85rem var(--space-4);
  }
  .sec.nl .sl {
    margin-bottom: 0.2rem;
    font-size: 0.55rem;
  }
  .sec.nl .st {
    font-size: var(--fs-title);
    margin-bottom: 0;
    line-height: 1.1;
  }
  .sec.nl .nl-in {
    gap: 0.4rem;
    text-align: left;
  }
  .sec.nl .nl-rp {
    font-size: 0.62rem;
    margin-bottom: 0.35rem;
    line-height: 1.5;
  }
  /* Form returns to column at mobile so the input + Subscribe button don't
     get clipped on narrow phones (320-414px). Was forced to row in pass 1
     of the shrink — visual saving was real but caused right-side overflow
     per user feedback 2026-05-19 11:35 PM. */
  .sec.nl .nl-form {
    flex-direction: column;
    gap: var(--space-1);
    border-radius: var(--radius-md);
    padding: 0.2rem;
  }
  .sec.nl .nl-form input {
    min-height: 0;
    padding: 0.45rem 0.8rem;
    width: 100%;
    box-sizing: border-box;
    font-size: var(--fs-label);
  }
  .sec.nl .nl-form button {
    min-height: 0;
    padding: 0.45rem 0.8rem;
    border-radius: var(--radius-sm);
    width: 100%;
    font-size: var(--fs-label);
  }
}
