:root {
  /* Brand core */
  --color-red: #ee3a43;
  --color-red-dark: #c92a35;
  --color-blue: #007ac3;
  --color-blue-dark: #005f97;
  --color-gold: #faab53;

  /* Warm support surfaces */
  --color-cream: #f7f5ef;
  --color-surface: #ffffff;
  --color-surface-soft: #eef5fb;
  --color-surface-accent: #fff5df;
  --color-surface-warm: var(--color-cream);
  --color-surface-warm-accent: var(--color-surface-accent);

  /* Neutrals */
  --color-text: #1f2933;
  --color-text-muted: #536171;
  --color-border: #d6dde5;
  --shadow-soft: 0 18px 44px rgba(18, 40, 72, 0.12);
  --shadow-card: 0 12px 28px rgba(18, 40, 72, 0.08);
  --surface-card-public: rgba(255, 255, 255, 0.94);
  --surface-card-public-accent: linear-gradient(180deg, #fff 0%, var(--color-surface-accent) 100%);
  --surface-card-public-soft: linear-gradient(180deg, #fff 0%, var(--color-surface-soft) 100%);
  --surface-card-admin: linear-gradient(180deg, rgba(255, 255, 255, 0.97), rgba(247, 250, 253, 0.97));
  --surface-card-admin-border: rgba(188, 204, 220, 0.88);
  --surface-card-admin-shadow: 0 16px 34px rgba(20, 42, 63, 0.08);
  --surface-preview: linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(244, 248, 252, 0.98));
  --surface-preview-border: rgba(188, 204, 220, 0.88);
  --radius-lg: 28px;
  --radius-md: 20px;
  --radius-sm: 14px;
  --container: 1200px;
  --type-body: 1rem;
  --type-nav: 1rem;
  --type-eyebrow: 0.9rem;
  --type-title-xl: clamp(2.4rem, 5vw, 4.35rem);
  --type-title-lg: clamp(1.85rem, 3.2vw, 3rem);
  --type-title-md: clamp(1.4rem, 2vw, 1.9rem);
  --type-button: 0.98rem;
  --size-button-height: 50px;
  --size-button-padding-x: 1.2rem;
  --size-button-padding-y: 0.8rem;
  --button-radius: 999px;
  --button-primary-bg: var(--color-red);
  --button-primary-bg-hover: var(--color-red-dark);
  --button-primary-text: #fff;
  --button-on-dark-bg: #fff;
  --button-on-dark-text: var(--color-red);
  --button-on-dark-bg-hover: #fff5f7;
  --button-on-dark-text-hover: var(--color-red-dark);
  --button-outline-on-dark-border: #fff;
  --button-outline-on-dark-text: #fff;
  --button-outline-on-dark-bg-hover: rgba(255, 255, 255, 0.12);
  --button-secondary-bg: var(--color-blue);
  --button-secondary-bg-hover: var(--color-blue-dark);
  --button-secondary-text: #fff;
  --button-ghost-border: rgba(31, 41, 51, 0.16);
  --button-ghost-border-hover: rgba(31, 41, 51, 0.28);
  --button-ghost-bg: transparent;
  --button-ghost-bg-hover: rgba(31, 41, 51, 0.06);
  --button-ghost-text: var(--color-text);
}

.footer-link-external::after {
  content: "";
  width: 0.72rem;
  height: 0.72rem;
  flex: 0 0 0.72rem;
  background: currentColor;
  opacity: 0.82;
  -webkit-mask: url("/assets/vendor/fontawesome/svgs/solid/up-right-from-square.svg") center / contain no-repeat;
  mask: url("/assets/vendor/fontawesome/svgs/solid/up-right-from-square.svg") center / contain no-repeat;
}

*,
*::before,
*::after {
  box-sizing: border-box;
}

html {
  scroll-behavior: smooth;
  overflow-x: clip;
}

[hidden] {
  display: none !important;
}

body {
  margin: 0;
  font-family: "DM Sans", sans-serif;
  font-size: var(--type-body);
  line-height: 1.6;
  color: var(--color-text);
  overflow-x: clip;
  background:
    radial-gradient(circle at top left, rgba(248, 177, 51, 0.18), transparent 30%),
    linear-gradient(180deg, #ffffff 0%, #eef5fb 28%, #ffffff 100%);
}

img {
  display: block;
  max-width: 100%;
  height: auto;
}

a {
  color: inherit;
  text-decoration: none;
}

a:focus-visible,
button:focus-visible {
  outline: 3px solid var(--color-gold);
  outline-offset: 3px;
}

button,
input {
  font: inherit;
}

.sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

.skip-link {
  position: fixed;
  left: 1rem;
  top: 1rem;
  z-index: 100;
  padding: 0.75rem 1rem;
  border-radius: 0.75rem;
  background: #000;
  color: #fff;
  transform: translateY(-220%);
  transition: transform 0.2s ease;
}

.skip-link:focus {
  transform: translateY(0);
}

.container {
  width: min(calc(100% - 2rem), var(--container));
  margin: 0 auto;
}

.site-header {
  position: sticky;
  top: 0;
  z-index: 20;
  background: rgba(255, 255, 255, 0.94);
  backdrop-filter: blur(16px);
  border-bottom: 1px solid rgba(214, 221, 229, 0.85);
}

.utility-bar {
  background: linear-gradient(90deg, var(--color-blue-dark), var(--color-blue));
  color: #fff;
  font-size: 0.9rem;
}

.utility-bar__inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  min-height: 12px;
}

.utility-nav {
  display: flex;
  flex-wrap: wrap;
  gap: 1rem;
}

.utility-nav a:hover,
.utility-phone:hover {
  text-decoration: underline;
}

.nav-shell {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1.5rem;
  min-height: 102px;
}

.brand {
  display: inline-flex;
  align-items: center;
  flex: 0 0 auto;
}

.brand img {
  display: block;
  width: auto;
  max-width: 100%;
  height: 82px;
  max-height: 82px;
}

.nav-cluster {
  display: flex;
  align-items: center;
  gap: 1.5rem;
  min-width: 0;
}

.site-nav {
  display: flex;
  align-items: center;
  gap: 1.25rem;
  font-size: var(--type-nav);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  min-width: 0;
}

.site-nav a {
  position: relative;
  padding: 0.4rem 0;
}

.site-nav a::after {
  content: "";
  position: absolute;
  left: 0;
  bottom: 0;
  width: 100%;
  height: 3px;
  background: var(--color-red);
  transform: scaleX(0);
  transform-origin: left;
  transition: transform 0.2s ease;
}

.site-nav a:hover::after,
.site-nav a[aria-current="page"]::after {
  transform: scaleX(1);
}

.socials {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
  gap: 0.75rem;
  color: var(--color-text-muted);
  min-width: 0;
}

.social-link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 46px;
  height: 46px;
  padding: 0;
  border: 1px solid rgba(214, 221, 229, 0.95);
  border-radius: 999px;
  background: #fff;
  color: var(--color-text-muted);
  transition: transform 0.2s ease, border-color 0.2s ease, color 0.2s ease, background 0.2s ease;
}

.social-link svg,
.social-link img {
  width: 22px;
  height: 22px;
  display: block;
}

.social-link i {
  font-size: 22px;
  line-height: 1;
}

.social-link:hover {
  transform: translateY(-1px);
  border-color: rgba(0, 119, 200, 0.35);
  background: rgba(0, 119, 200, 0.05);
  color: var(--color-red);
}

.nav-toggle {
  display: none;
  width: 52px;
  height: 52px;
  border: 1px solid var(--color-border);
  border-radius: 16px;
  background: #fff;
  align-items: center;
  justify-content: center;
  flex-direction: column;
  gap: 0.35rem;
}

.nav-toggle__line {
  width: 20px;
  height: 2px;
  background: var(--color-text);
}

.hero {
  padding: 3rem 0 4rem;
}

.store-status {
  padding: 0.95rem 0;
  border-bottom: 1px solid rgba(214, 221, 229, 0.85);
}

.store-status--temporarily-closed {
  background: linear-gradient(180deg, rgba(238, 58, 67, 0.1), rgba(238, 58, 67, 0.05));
}

.store-status--opening-soon {
  background: linear-gradient(180deg, rgba(250, 171, 83, 0.14), rgba(250, 171, 83, 0.07));
}

.store-status--closed-for-season {
  background: linear-gradient(180deg, rgba(0, 122, 195, 0.14), rgba(0, 122, 195, 0.07));
}

.store-status__inner {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 1rem;
  margin-inline: auto;
}

.store-status__badge {
  flex: 0 0 auto;
  width: 90px;
  height: auto;
}

.store-status__copy {
  min-width: 0;
}

.store-status__copy strong {
  display: block;
  margin-bottom: 0.15rem;
  font-size: 1rem;
}

.store-status__copy p {
  color: var(--color-text);
}

.hero__shell {
  display: grid;
  grid-template-columns: minmax(0, 1.08fr) minmax(320px, 0.92fr);
  gap: 1.25rem;
  align-items: stretch;
}

.hero-copy {
  position: relative;
  overflow: hidden;
  min-width: 0;
  padding: 2.5rem;
  border-radius: var(--radius-lg);
  color: #fff;
  background: linear-gradient(145deg, #e1142f 0%, #ab0d25 100%);
  box-shadow: var(--shadow-soft);
}

.hero-copy::after {
  content: "";
  position: absolute;
  top: 7rem;
  right: -11.5rem;
  width: clamp(460px, 58vw, 640px);
  aspect-ratio: 900 / 810;
  background: url("/images/badges/dq-treats-large-cone.png") no-repeat center / contain;
  opacity: 0.38;
  transform: rotate(14deg);
  transform-origin: top right;
  pointer-events: none;
  z-index: 0;
  -webkit-mask-image: linear-gradient(to bottom, rgba(0, 0, 0, 1) 0%, rgba(0, 0, 0, 1) 46%, rgba(0, 0, 0, 0.94) 60%, rgba(0, 0, 0, 0.5) 76%, rgba(0, 0, 0, 0.16) 90%, transparent 100%);
  mask-image: linear-gradient(to bottom, rgba(0, 0, 0, 1) 0%, rgba(0, 0, 0, 1) 46%, rgba(0, 0, 0, 0.94) 60%, rgba(0, 0, 0, 0.5) 76%, rgba(0, 0, 0, 0.16) 90%, transparent 100%);
}

.hero-copy > * {
  position: relative;
  z-index: 1;
}

.eyebrow {
  margin: 0 0 1rem;
  font-size: var(--type-eyebrow);
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

h1,
h2,
h3,
h4,
p {
  margin: 0;
}

h1 {
  font-size: var(--type-title-xl);
  line-height: 0.98;
  letter-spacing: -0.05em;
}

.hero-title-fun {
  font-family: "Baloo 2", "DM Sans", sans-serif;
  font-weight: 800;
  letter-spacing: -0.015em;
}

.page-title-fun {
  font-family: "Baloo 2", "DM Sans", sans-serif;
  font-weight: 800;
  letter-spacing: -0.015em;
}

h2 {
  font-size: var(--type-title-lg);
  line-height: 1.06;
  letter-spacing: -0.04em;
}

h3 {
  font-size: var(--type-title-md);
  line-height: 1.15;
}

.card-title-script {
  font-family: "Baloo 2", "DM Sans", sans-serif;
  font-size: 1.82rem;
  font-weight: 700;
  line-height: 1.03;
  letter-spacing: -0.01em;
  margin-bottom: 0.55rem;
}

.hero-lede {
  margin-top: 1.2rem;
  max-width: 40rem;
  font-size: 1.1rem;
  line-height: 1.65;
  color: rgba(255, 255, 255, 0.92);
}

.hero-copy__details {
  display: grid;
  gap: 1rem;
  margin-top: 1.75rem;
}

.hero-copy__details--count-1 {
  grid-template-columns: minmax(260px, 420px);
}

.hero-copy__details--compact {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  gap: 0.8rem;
}

.hero-copy__details--count-2 {
  grid-template-columns: repeat(2, minmax(0, 1fr));
  max-width: 780px;
}

.hero-copy__details--count-3 {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.hero-stat {
  padding: 1rem;
  border-radius: var(--radius-md);
  background: rgba(255, 255, 255, 0.1);
}

.hero-copy__details--compact .hero-stat {
  padding: 0.8rem 0.95rem;
  max-width: 420px;
  background: rgba(255, 255, 255, 0.08);
}

.hero-stat strong {
  display: block;
  margin-bottom: 0.35rem;
}

.hero-copy__details--compact .hero-stat strong {
  margin-bottom: 0.2rem;
}

.hero-stat a {
  color: inherit;
  text-decoration: underline;
  text-decoration-thickness: 1px;
  text-underline-offset: 0.14em;
}

.hero-actions {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.85rem;
  margin-top: 1.9rem;
}

.action-row {
  display: flex;
  flex-wrap: wrap;
  gap: 0.85rem;
  margin-top: 1.9rem;
}

.card .action-row {
  width: 100%;
}

.card .action-row .button {
  flex: 1 1 0;
}

.application-form .application-form__actions .button {
  flex: 0 0 auto;
}

.button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: var(--size-button-height);
  padding: var(--size-button-padding-y) var(--size-button-padding-x);
  border-radius: var(--button-radius);
  border: 1px solid transparent;
  background: var(--button-primary-bg);
  color: var(--button-primary-text);
  font-size: var(--type-button);
  font-weight: 700;
  text-align: center;
  transition: transform 0.2s ease, background 0.2s ease, border-color 0.2s ease;
}

.button__icon {
  width: 1.25rem;
  height: 1.25rem;
  flex: 0 0 auto;
  display: block;
}

.button--icon {
  gap: 0.6rem;
}

.button--icon .button__icon {
  filter: brightness(0) invert(1);
}

.button--icon .button__icon--apple {
  width: 1.35rem;
  height: 1.35rem;
}

.button--icon .button__icon--google-play {
  width: 1.15rem;
  height: 1.15rem;
}

.button:hover {
  transform: translateY(-1px);
  background: var(--button-primary-bg-hover);
  color: var(--button-primary-text);
}

.button:focus-visible,
.social-link:focus-visible,
.product-rotator__dot:focus-visible,
.product-rotator__toggle:focus-visible,
.site-nav a:focus-visible,
.footer-bottom a:focus-visible,
.hero-media__card > a:focus-visible {
  outline: 3px solid var(--color-gold);
  outline-offset: 3px;
}

.button--light {
  background: var(--button-on-dark-bg);
  color: var(--button-on-dark-text);
}

.button--outline-light {
  background: transparent;
  border-width: 2px;
  border-color: var(--button-outline-on-dark-border);
  color: var(--button-outline-on-dark-text);
}

.button--light:hover {
  background: var(--button-on-dark-bg-hover);
  color: var(--button-on-dark-text-hover);
}

.button--outline-light:hover {
  background: var(--button-outline-on-dark-bg-hover);
  border-color: var(--button-outline-on-dark-border);
  color: var(--button-outline-on-dark-text);
}

.button--soft {
  background: var(--button-secondary-bg);
  color: var(--button-secondary-text);
}

.button--soft:hover {
  background: var(--button-secondary-bg-hover);
  color: var(--button-secondary-text);
}

.button--ghost {
  background: var(--button-ghost-bg);
  border-color: var(--button-ghost-border);
  color: var(--button-ghost-text);
}

.button--ghost:hover {
  background: var(--button-ghost-bg-hover);
  border-color: var(--button-ghost-border-hover);
  color: var(--button-ghost-text);
}

.hero-media {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 1rem;
}

.hero-media__card {
  position: relative;
  overflow: hidden;
  min-height: 220px;
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-card);
}

.hero-media__card > a {
  display: block;
  width: 100%;
  height: 100%;
}

.hero-media__card:first-child {
  grid-column: 1 / -1;
  min-height: 280px;
}

.hero-media__card img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.hero-media__card--lined {
  background:
    repeating-linear-gradient(
      -35deg,
      rgba(255, 255, 255, 0.24) 0 2px,
      rgba(255, 255, 255, 0) 2px 8px
    ),
    linear-gradient(140deg, #cf102d 0%, #a10e24 100%);
}

.hero-media__card--lined img {
  position: relative;
  z-index: 1;
}

.hero-media__card--cake {
  background:
    radial-gradient(circle at -4% 16%, rgba(255, 255, 255, 0.22) 0 4.5%, rgba(255, 255, 255, 0) 5.5%),
    radial-gradient(circle at 6% 4%, rgba(255, 255, 255, 0.12) 0 2.2%, rgba(255, 255, 255, 0) 3.2%),
    radial-gradient(circle at 18% 8%, rgba(255, 255, 255, 0.24) 0 4%, rgba(255, 255, 255, 0) 5%),
    radial-gradient(circle at 30% 18%, rgba(255, 255, 255, 0.13) 0 2.4%, rgba(255, 255, 255, 0) 3.4%),
    radial-gradient(circle at 44% -3%, rgba(255, 255, 255, 0.18) 0 3.5%, rgba(255, 255, 255, 0) 4.5%),
    radial-gradient(circle at 58% 6%, rgba(255, 255, 255, 0.28) 0 5.4%, rgba(255, 255, 255, 0) 6.4%),
    radial-gradient(circle at 76% 10%, rgba(255, 255, 255, 0.2) 0 4.2%, rgba(255, 255, 255, 0) 5.2%),
    radial-gradient(circle at 88% 2%, rgba(255, 255, 255, 0.12) 0 2.1%, rgba(255, 255, 255, 0) 3.1%),
    radial-gradient(circle at 103% 24%, rgba(255, 255, 255, 0.18) 0 4%, rgba(255, 255, 255, 0) 5%),
    radial-gradient(circle at 8% 42%, rgba(255, 255, 255, 0.15) 0 3.4%, rgba(255, 255, 255, 0) 4.4%),
    radial-gradient(circle at 20% 52%, rgba(255, 255, 255, 0.3) 0 5.8%, rgba(255, 255, 255, 0) 6.8%),
    radial-gradient(circle at 36% 44%, rgba(255, 255, 255, 0.11) 0 1.9%, rgba(255, 255, 255, 0) 2.9%),
    radial-gradient(circle at 48% 34%, rgba(255, 255, 255, 0.17) 0 3%, rgba(255, 255, 255, 0) 4%),
    radial-gradient(circle at 68% 48%, rgba(255, 255, 255, 0.1) 0 1.8%, rgba(255, 255, 255, 0) 2.8%),
    radial-gradient(circle at 92% 44%, rgba(255, 255, 255, 0.16) 0 3.2%, rgba(255, 255, 255, 0) 4.2%),
    radial-gradient(circle at -2% 70%, rgba(255, 255, 255, 0.18) 0 4.1%, rgba(255, 255, 255, 0) 5.1%),
    radial-gradient(circle at 12% 74%, rgba(255, 255, 255, 0.12) 0 2.3%, rgba(255, 255, 255, 0) 3.3%),
    radial-gradient(circle at 24% 86%, rgba(255, 255, 255, 0.17) 0 3.6%, rgba(255, 255, 255, 0) 4.6%),
    radial-gradient(circle at 40% 96%, rgba(255, 255, 255, 0.26) 0 5.1%, rgba(255, 255, 255, 0) 6.1%),
    radial-gradient(circle at 56% 78%, rgba(255, 255, 255, 0.14) 0 3.1%, rgba(255, 255, 255, 0) 4.1%),
    radial-gradient(circle at 70% 66%, rgba(255, 255, 255, 0.12) 0 2.2%, rgba(255, 255, 255, 0) 3.2%),
    radial-gradient(circle at 82% 92%, rgba(255, 255, 255, 0.18) 0 3.9%, rgba(255, 255, 255, 0) 4.9%),
    radial-gradient(circle at 94% 86%, rgba(255, 255, 255, 0.24) 0 4.8%, rgba(255, 255, 255, 0) 5.8%),
    radial-gradient(circle at 104% 74%, rgba(255, 255, 255, 0.16) 0 3.5%, rgba(255, 255, 255, 0) 4.5%),
    linear-gradient(145deg, #0077c8 0%, #005f9f 100%);
}

.hero-media__card--cake img {
  position: relative;
  z-index: 1;
  width: auto;
  height: auto;
  max-width: calc(100% - 1rem);
  max-height: calc(100% - 1rem);
  margin: 0.9rem auto 1.35rem;
  object-fit: contain;
}

.hero-media__label {
  position: absolute;
  left: 1rem;
  bottom: 1rem;
  display: inline-flex;
  align-items: center;
  min-height: 38px;
  padding: 0.4rem 0.85rem;
  border-radius: 999px;
  background: rgba(15, 23, 42, 0.8);
  color: #fff;
  font-size: 0.9rem;
  font-weight: 700;
  z-index: 2;
}

.section {
  padding: 1.75rem 0 4rem;
}

.section-heading {
  display: grid;
  gap: 0.65rem;
  margin-bottom: 1.75rem;
}

.section-heading .eyebrow {
  margin-bottom: 0;
}

.section-heading h2 {
  margin: 0;
}

.section-heading > p:last-child {
  margin-top: 0.1rem;
}

.section-heading p,
.card p,
.feature p,
.footer-copy,
.footer-bottom p {
  color: var(--color-text-muted);
}

.card-grid,
.feature-grid {
  display: grid;
  gap: 1.5rem;
}

.card-grid--three,
.feature-grid {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.card {
  display: flex;
  flex-direction: column;
  gap: 1rem;
  min-width: 0;
  padding: 1.5rem;
  border: 1px solid rgba(214, 221, 229, 0.9);
  border-radius: var(--radius-lg);
  background: var(--surface-card-public);
  box-shadow: var(--shadow-card);
}

.card > .button,
.card > .action-row {
  margin-top: auto;
  align-self: flex-start;
}

.card > .button {
  display: inline-flex;
  min-height: 48px;
}

.card--accent {
  background: var(--surface-card-public-accent);
}

.card--soft {
  background: var(--surface-card-public-soft);
}

.card__art {
  min-height: 180px;
  border-radius: var(--radius-md);
  overflow: hidden;
}

.card__art img {
  width: 100%;
  height: 100%;
  max-height: none;
  object-fit: cover;
}

.card__art--inset {
  display: grid;
  place-items: center;
  padding: 1rem;
  background: linear-gradient(180deg, rgba(0, 119, 200, 0.08), rgba(248, 177, 51, 0.12));
}

.page-food .menu-item-card--enhanced .card__art--inset {
  background:
    radial-gradient(circle at top left, rgba(238, 58, 67, 0.52), transparent 18%),
    radial-gradient(circle at bottom right, rgba(250, 171, 83, 0.34), transparent 22%),
    repeating-linear-gradient(
      -35deg,
      rgba(238, 58, 67, 0.045) 0 2px,
      rgba(238, 58, 67, 0) 2px 18px
    ),
    linear-gradient(180deg, rgba(255, 255, 255, 0.995), rgba(250, 247, 246, 0.995));
}

.page-treats .menu-item-card--enhanced .card__art--inset {
  background:
    radial-gradient(circle at top left, rgba(0, 122, 195, 0.54), transparent 18%),
    radial-gradient(circle at bottom right, rgba(250, 171, 83, 0.3), transparent 22%),
    radial-gradient(circle at -6% 16%, rgba(0, 122, 195, 0.1) 0 2.2%, transparent 3%),
    radial-gradient(circle at 10% 6%, rgba(0, 122, 195, 0.08) 0 1.5%, transparent 2.3%),
    radial-gradient(circle at 24% 20%, rgba(0, 122, 195, 0.09) 0 2%, transparent 2.8%),
    radial-gradient(circle at 43% 9%, rgba(0, 122, 195, 0.07) 0 1.4%, transparent 2.2%),
    radial-gradient(circle at 61% 22%, rgba(0, 122, 195, 0.09) 0 1.8%, transparent 2.6%),
    radial-gradient(circle at 82% 7%, rgba(0, 122, 195, 0.08) 0 1.6%, transparent 2.4%),
    radial-gradient(circle at 104% 20%, rgba(0, 122, 195, 0.1) 0 2.1%, transparent 2.9%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.995), rgba(246, 249, 252, 0.995));
}

.page-drinks .menu-item-card--enhanced .card__art--inset {
  background:
    radial-gradient(circle at top left, rgba(61, 165, 224, 0.52), transparent 18%),
    radial-gradient(circle at bottom right, rgba(0, 122, 195, 0.32), transparent 21%),
    linear-gradient(
      120deg,
      rgba(61, 165, 224, 0.08) 0 10%,
      rgba(61, 165, 224, 0) 10% 22%,
      rgba(61, 165, 224, 0.06) 22% 30%,
      rgba(61, 165, 224, 0) 30% 100%
    ),
    linear-gradient(180deg, rgba(255, 255, 255, 0.995), rgba(245, 250, 253, 0.995));
}

.page-cakes .menu-item-card--enhanced .card__art--inset {
  background:
    radial-gradient(circle at top left, rgba(116, 77, 172, 0.52), transparent 18%),
    radial-gradient(circle at bottom right, rgba(250, 171, 83, 0.3), transparent 22%),
    radial-gradient(circle at -3% 84%, rgba(116, 77, 172, 0.08) 0 2.2%, transparent 3.1%),
    radial-gradient(circle at 15% 94%, rgba(116, 77, 172, 0.06) 0 1.6%, transparent 2.5%),
    radial-gradient(circle at 36% 86%, rgba(116, 77, 172, 0.08) 0 2.1%, transparent 3%),
    radial-gradient(circle at 64% 96%, rgba(116, 77, 172, 0.06) 0 1.7%, transparent 2.6%),
    radial-gradient(circle at 90% 82%, rgba(116, 77, 172, 0.08) 0 2.3%, transparent 3.2%),
    radial-gradient(circle at 103% 92%, rgba(116, 77, 172, 0.07) 0 1.9%, transparent 2.8%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.995), rgba(249, 247, 252, 0.995));
}

.menu-item-card--splash .card__art--inset {
  background:
    radial-gradient(58% 52% at -4% -8%, rgba(255, 64, 82, 0.78) 0 24%, rgba(255, 64, 82, 0) 58%),
    radial-gradient(44% 38% at 104% 0%, rgba(0, 126, 255, 0.72) 0 20%, rgba(0, 126, 255, 0) 56%),
    radial-gradient(54% 44% at 102% 100%, rgba(255, 186, 34, 0.7) 0 18%, rgba(255, 186, 34, 0) 54%),
    radial-gradient(36% 32% at 0% 102%, rgba(92, 46, 196, 0.58) 0 16%, rgba(92, 46, 196, 0) 52%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.995), rgba(249, 251, 253, 0.995));
}

.page-food .menu-item-card--splash .card__art--inset {
  background:
    radial-gradient(60% 54% at -5% -10%, rgba(238, 58, 67, 0.82) 0 24%, rgba(238, 58, 67, 0) 58%),
    radial-gradient(30% 26% at 106% 10%, rgba(255, 102, 24, 0.52) 0 17%, rgba(255, 102, 24, 0) 52%),
    radial-gradient(56% 46% at 102% 100%, rgba(250, 171, 83, 0.78) 0 20%, rgba(250, 171, 83, 0) 55%),
    radial-gradient(20% 18% at 18% 88%, rgba(255, 220, 129, 0.45) 0 12%, rgba(255, 220, 129, 0) 44%),
    radial-gradient(18% 18% at 72% 28%, rgba(255, 255, 255, 0.38) 0 10%, rgba(255, 255, 255, 0) 38%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.995), rgba(250, 249, 248, 0.995));
}

.page-treats .menu-item-card--splash .card__art--inset {
  background:
    radial-gradient(58% 52% at -4% -8%, rgba(0, 122, 195, 0.84) 0 24%, rgba(0, 122, 195, 0) 58%),
    radial-gradient(34% 28% at 102% 12%, rgba(85, 197, 255, 0.58) 0 16%, rgba(85, 197, 255, 0) 50%),
    radial-gradient(54% 44% at 102% 100%, rgba(250, 171, 83, 0.64) 0 18%, rgba(250, 171, 83, 0) 52%),
    radial-gradient(28% 24% at 10% 98%, rgba(0, 92, 169, 0.46) 0 14%, rgba(0, 92, 169, 0) 44%),
    radial-gradient(18% 18% at 78% 24%, rgba(255, 255, 255, 0.34) 0 10%, rgba(255, 255, 255, 0) 36%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.995), rgba(248, 251, 253, 0.995));
}

.page-drinks .menu-item-card--splash .card__art--inset {
  background:
    radial-gradient(56% 50% at -2% -10%, rgba(61, 165, 224, 0.8) 0 23%, rgba(61, 165, 224, 0) 56%),
    radial-gradient(42% 36% at 104% 8%, rgba(0, 122, 195, 0.66) 0 19%, rgba(0, 122, 195, 0) 53%),
    radial-gradient(48% 40% at 104% 100%, rgba(0, 206, 255, 0.5) 0 16%, rgba(0, 206, 255, 0) 50%),
    radial-gradient(28% 24% at 6% 100%, rgba(108, 223, 255, 0.42) 0 14%, rgba(108, 223, 255, 0) 42%),
    radial-gradient(18% 18% at 74% 26%, rgba(255, 255, 255, 0.34) 0 10%, rgba(255, 255, 255, 0) 36%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.995), rgba(247, 251, 253, 0.995));
}

.page-cakes .menu-item-card--splash .card__art--inset {
  background:
    radial-gradient(58% 52% at -4% -8%, rgba(116, 77, 172, 0.84) 0 24%, rgba(116, 77, 172, 0) 58%),
    radial-gradient(36% 30% at 104% 10%, rgba(181, 111, 255, 0.54) 0 17%, rgba(181, 111, 255, 0) 52%),
    radial-gradient(52% 44% at 102% 100%, rgba(250, 171, 83, 0.64) 0 18%, rgba(250, 171, 83, 0) 52%),
    radial-gradient(28% 24% at 8% 100%, rgba(226, 87, 204, 0.42) 0 14%, rgba(226, 87, 204, 0) 44%),
    radial-gradient(18% 18% at 76% 26%, rgba(255, 255, 255, 0.34) 0 10%, rgba(255, 255, 255, 0) 36%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.995), rgba(250, 248, 253, 0.995));
}

.menu-item-card--rainbow .card__art--inset {
  background:
    radial-gradient(44% 36% at -6% -8%, rgba(255, 45, 85, 0.9) 0 20%, rgba(255, 45, 85, 0) 54%),
    radial-gradient(34% 28% at 108% -2%, rgba(255, 170, 0, 0.88) 0 18%, rgba(255, 170, 0, 0) 52%),
    radial-gradient(30% 26% at 102% 102%, rgba(0, 214, 143, 0.82) 0 16%, rgba(0, 214, 143, 0) 48%),
    radial-gradient(28% 24% at -2% 106%, rgba(0, 126, 255, 0.78) 0 14%, rgba(0, 126, 255, 0) 46%),
    radial-gradient(20% 18% at 48% 0%, rgba(162, 56, 255, 0.68) 0 10%, rgba(162, 56, 255, 0) 34%),
    radial-gradient(18% 16% at 78% 36%, rgba(255, 255, 255, 0.26) 0 10%, rgba(255, 255, 255, 0) 34%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.992), rgba(248, 250, 253, 0.992));
}

.menu-item-grid .menu-item-card--rainbow:nth-child(4n + 1) .card__art--inset {
  background:
    radial-gradient(48% 40% at -8% -8%, rgba(255, 52, 97, 0.94) 0 22%, rgba(255, 52, 97, 0) 56%),
    radial-gradient(36% 30% at 104% -2%, rgba(255, 168, 0, 0.9) 0 18%, rgba(255, 168, 0, 0) 52%),
    radial-gradient(34% 30% at 104% 104%, rgba(0, 212, 255, 0.82) 0 17%, rgba(0, 212, 255, 0) 48%),
    radial-gradient(28% 24% at -4% 102%, rgba(73, 85, 255, 0.76) 0 14%, rgba(73, 85, 255, 0) 44%),
    radial-gradient(18% 16% at 44% 2%, rgba(172, 72, 255, 0.72) 0 10%, rgba(172, 72, 255, 0) 34%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.992), rgba(248, 250, 253, 0.992));
}

.menu-item-grid .menu-item-card--rainbow:nth-child(4n + 2) .card__art--inset {
  background:
    radial-gradient(34% 30% at 14% -6%, rgba(255, 59, 48, 0.92) 0 18%, rgba(255, 59, 48, 0) 50%),
    radial-gradient(46% 38% at 106% 14%, rgba(255, 201, 40, 0.9) 0 20%, rgba(255, 201, 40, 0) 56%),
    radial-gradient(30% 26% at 88% 102%, rgba(0, 214, 143, 0.84) 0 15%, rgba(0, 214, 143, 0) 48%),
    radial-gradient(30% 24% at -2% 88%, rgba(0, 122, 255, 0.8) 0 14%, rgba(0, 122, 255, 0) 46%),
    radial-gradient(24% 20% at 56% 0%, rgba(146, 78, 255, 0.74) 0 12%, rgba(146, 78, 255, 0) 36%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.992), rgba(248, 250, 253, 0.992));
}

.menu-item-grid .menu-item-card--rainbow:nth-child(4n + 3) .card__art--inset {
  background:
    radial-gradient(42% 34% at -6% 14%, rgba(255, 94, 58, 0.9) 0 20%, rgba(255, 94, 58, 0) 54%),
    radial-gradient(30% 26% at 100% -6%, rgba(255, 140, 0, 0.84) 0 16%, rgba(255, 140, 0, 0) 48%),
    radial-gradient(42% 36% at 106% 100%, rgba(0, 225, 177, 0.86) 0 18%, rgba(0, 225, 177, 0) 54%),
    radial-gradient(22% 20% at 0% 104%, rgba(39, 102, 255, 0.8) 0 12%, rgba(39, 102, 255, 0) 42%),
    radial-gradient(26% 22% at 52% -4%, rgba(190, 74, 255, 0.74) 0 12%, rgba(190, 74, 255, 0) 38%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.992), rgba(249, 250, 253, 0.992));
}

.menu-item-grid .menu-item-card--rainbow:nth-child(4n + 4) .card__art--inset {
  background:
    radial-gradient(30% 26% at 8% -4%, rgba(255, 47, 109, 0.92) 0 18%, rgba(255, 47, 109, 0) 50%),
    radial-gradient(34% 30% at 106% 6%, rgba(255, 214, 10, 0.88) 0 18%, rgba(255, 214, 10, 0) 52%),
    radial-gradient(36% 32% at 100% 104%, rgba(0, 201, 255, 0.82) 0 17%, rgba(0, 201, 255, 0) 50%),
    radial-gradient(28% 24% at -6% 96%, rgba(0, 132, 255, 0.78) 0 14%, rgba(0, 132, 255, 0) 44%),
    radial-gradient(20% 18% at 58% 2%, rgba(153, 83, 255, 0.72) 0 10%, rgba(153, 83, 255, 0) 34%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.992), rgba(248, 250, 253, 0.992));
}

.card__art--inset img {
  width: auto;
  height: auto;
  max-width: 100%;
  max-height: 200px;
  object-fit: contain;
}

.kicker {
  display: inline-block;
  margin-bottom: 0.7rem;
  color: var(--color-blue);
  font-size: 0.85rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.feature {
  display: grid;
  grid-template-columns: 112px minmax(0, 1fr);
  gap: 1rem;
  min-width: 0;
  padding: 1.2rem;
  border-radius: var(--radius-md);
  background: #fff;
  border: 1px solid rgba(214, 221, 229, 0.9);
  box-shadow: var(--shadow-card);
}

.feature img {
  align-self: center;
}

.feature-grid--cards .feature,
.product-rotator .feature--card {
  grid-template-columns: 1fr;
  align-content: start;
  gap: 1rem;
  padding: 1.5rem;
  border-radius: var(--radius-lg);
}

.feature__art {
  min-height: 220px;
  border-radius: var(--radius-md);
  overflow: hidden;
}

.feature__art img {
  width: 100%;
  height: 100%;
  max-width: none;
  max-height: none;
  object-fit: cover;
}

.feature__art--inset {
  display: grid;
  place-items: center;
  padding: 1rem;
  background: linear-gradient(180deg, rgba(0, 119, 200, 0.08), rgba(248, 177, 51, 0.12));
}

.feature__art--inset img {
  width: auto;
  height: auto;
  max-width: 100%;
  max-height: 260px;
  object-fit: contain;
}

.feature__body {
  display: grid;
  gap: 0.75rem;
  min-width: 0;
}

.feature__body .kicker,
.feature__body .card-title-script {
  margin-bottom: 0;
}

.product-rotator .feature--card {
  grid-template-rows: auto minmax(0, 1fr);
}

.product-rotator .feature__body {
  grid-template-rows: auto auto 1fr auto;
  height: 100%;
}

.product-rotator .feature__body a {
  align-self: end;
}

.product-rotator {
  display: grid;
  gap: 1.25rem;
}

.product-rotator__viewport {
  position: relative;
}

.product-rotator__slide {
  display: none;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 1.5rem;
}

.product-rotator__slide.is-active {
  display: grid;
}

.product-rotator__controls {
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  align-items: center;
  gap: 1rem;
}

.product-rotator__dots {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.6rem;
  grid-column: 2;
}

.product-rotator__dot {
  width: 12px;
  height: 12px;
  padding: 0;
  border: 0;
  border-radius: 999px;
  background: rgba(31, 41, 51, 0.2);
  cursor: pointer;
  transition: transform 0.2s ease, background 0.2s ease;
}

.product-rotator__dot.is-active {
  background: var(--color-red);
  transform: scale(1.15);
}

.product-rotator__toggle {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 24px;
  padding: 0;
  grid-column: 3;
  justify-self: end;
  border: 1px solid rgba(31, 41, 51, 0.16);
  border-radius: 999px;
  background: #fff;
  color: var(--color-text);
  cursor: pointer;
}

.product-rotator__toggle:hover {
  background: rgba(31, 41, 51, 0.06);
}

.product-rotator__toggle-icon {
  display: block;
  position: relative;
  width: 10px;
  height: 10px;
}

.product-rotator__toggle[aria-pressed="false"] .product-rotator__toggle-icon::before,
.product-rotator__toggle[aria-pressed="false"] .product-rotator__toggle-icon::after {
  content: "";
  position: absolute;
  top: 0;
  width: 3px;
  height: 10px;
  border-radius: 999px;
  background: currentColor;
}

.product-rotator__toggle[aria-pressed="false"] .product-rotator__toggle-icon::before {
  left: 1px;
}

.product-rotator__toggle[aria-pressed="false"] .product-rotator__toggle-icon::after {
  right: 1px;
}

.product-rotator__toggle[aria-pressed="true"] .product-rotator__toggle-icon::before {
  content: "";
  position: absolute;
  left: 2px;
  top: 0;
  width: 0;
  height: 0;
  border-top: 5px solid transparent;
  border-bottom: 5px solid transparent;
  border-left: 8px solid currentColor;
}

.feature a,
.card a:not(.button):hover,
.footer-links a:hover,
.footer-bottom a:hover {
  color: var(--color-red);
}

.callout {
  display: grid;
  grid-template-columns: minmax(0, 1.15fr) minmax(260px, 0.85fr);
  gap: 1.75rem;
  align-items: center;
  padding: 2rem;
  border-radius: var(--radius-lg);
  background: linear-gradient(135deg, var(--color-blue-dark), var(--color-blue));
  color: #fff;
  box-shadow: var(--shadow-soft);
}

.callout p {
  margin-top: 0.8rem;
  color: rgba(255, 255, 255, 0.92);
}

.callout img {
  width: 100%;
  border-radius: var(--radius-md);
}

.content-page,
.giftcards-page {
  padding-bottom: 3.5rem;
}

.content-hero,
.giftcards-hero {
  padding-top: 3.5rem;
}

.content-hero__shell,
.giftcards-hero__shell {
  display: grid;
  grid-template-columns: minmax(0, 1.08fr) minmax(260px, 0.92fr);
  gap: 1.5rem;
  align-items: center;
}

.content-copy,
.giftcards-copy {
  padding: 2rem;
  border-radius: var(--radius-lg);
  background: rgba(255, 255, 255, 0.94);
  box-shadow: var(--shadow-soft);
}

.content-copy h1,
.giftcards-copy h2 {
  margin: 0;
  font-size: var(--type-title-lg);
  line-height: 1.05;
}

.content-copy .hero-lede,
.giftcards-copy .hero-lede {
  margin-top: 1rem;
  color: var(--color-text-muted);
}

.content-copy__note,
.giftcards-copy__note {
  margin-top: 1rem;
  font-weight: 700;
}

.content-copy__note a,
.giftcards-copy__note a {
  color: inherit;
  text-decoration: none;
}

.content-copy__note a:hover,
.giftcards-copy__note a:hover,
.content-copy__note a:focus-visible,
.giftcards-copy__note a:focus-visible {
  text-decoration: underline;
  text-underline-offset: 0.16em;
}

.content-copy__note--nav,
.giftcards-copy__note--nav {
  display: flex;
  flex-wrap: wrap;
  gap: 0.45rem;
}

.content-copy__note--nav a,
.giftcards-copy__note--nav a {
  display: inline-flex;
  align-items: center;
  min-height: 1.95rem;
  padding: 0.28rem 0.7rem;
  border-radius: 999px;
  background: rgba(0, 119, 200, 0.08);
  color: var(--color-blue-dark);
  font-size: 0.82rem;
  font-weight: 700;
  line-height: 1.2;
  text-decoration: none;
  box-shadow: inset 0 0 0 1px rgba(0, 119, 200, 0.12);
}

.content-copy__note--nav a:hover,
.giftcards-copy__note--nav a:hover,
.content-copy__note--nav a:focus-visible,
.giftcards-copy__note--nav a:focus-visible {
  background: rgba(0, 119, 200, 0.12);
  text-decoration: none;
}

.giftcards-balance {
  margin-top: 1rem;
  color: var(--color-red-dark);
  font-weight: 700;
}

.giftcards-balance a {
  color: inherit;
}

.content-media,
.giftcards-art {
  border-radius: var(--radius-lg);
  overflow: hidden;
  box-shadow: var(--shadow-card);
}

.content-media img,
.giftcards-art img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.story-grid {
  display: grid;
  gap: 1.5rem;
}

.story-block {
  padding: 1.5rem;
  border: 1px solid rgba(214, 221, 229, 0.9);
  border-radius: var(--radius-lg);
  background: rgba(255, 255, 255, 0.94);
  box-shadow: var(--shadow-card);
}

.story-block__media {
  float: left;
  width: min(46%, 440px);
  aspect-ratio: 4 / 3;
  margin: 0 1.25rem 0.85rem 0;
  border-radius: var(--radius-md);
  overflow: hidden;
}

.story-block__media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.story-block__body {
  display: block;
}

.story-block__body h2 {
  margin: 0 0 0.85rem;
  font-size: var(--type-title-md);
}

.story-block__body p {
  margin: 0;
  color: var(--color-text-muted);
}

.story-block__body > * + * {
  margin-top: 1rem;
}

.story-block__body h2 + * {
  margin-top: 0;
}

.story-block__body p + p {
  margin-top: 1.15rem;
}

.story-block__body::after {
  content: "";
  display: block;
  clear: both;
}

.story-block__actions {
  margin-top: 1.4rem;
}

.story-block__actions .button {
  display: inline-flex;
}

.jobs-values-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 1.25rem;
}

.jobs-value-card {
  text-align: center;
  align-items: center;
}

.jobs-value-card__icon {
  display: grid;
  place-items: center;
  width: 120px;
  aspect-ratio: 1;
  margin: 0 auto 0.25rem;
}

.jobs-value-card__icon img {
  width: 100%;
  height: 100%;
  object-fit: contain;
}

.jobs-value-card h3 {
  margin: 0;
  font-size: 1.2rem;
}

.jobs-value-card p {
  margin-top: 0.75rem;
}

.rewards-benefit-card__art {
  width: min(100%, 263px);
  min-height: 0;
  margin: 0 auto 0.35rem;
  padding: 0;
  aspect-ratio: 263 / 226;
}

.rewards-benefit-card__art img {
  width: 100%;
  height: 100%;
  max-width: 100%;
  max-height: none;
  object-fit: contain;
}

.local-coupon-card__meta {
  color: var(--color-text-muted);
  font-size: 0.95rem;
}

.local-coupon-card__art {
  display: grid;
  place-items: center;
  min-height: 210px;
  padding: 1rem;
}

.local-coupon-card__art img {
  width: auto;
  height: auto;
  max-width: 100%;
  max-height: 100%;
  object-fit: contain;
  position: relative;
  z-index: 1;
}

.local-coupon-card__art--color-red {
  background-color: #b91c1c;
  background-image: linear-gradient(145deg, #d81b36 0%, #a80f28 100%);
}

.local-coupon-card__art--color-blue {
  background-color: #005f9f;
  background-image: linear-gradient(145deg, #0b7fd3 0%, #005f9f 100%);
}

.local-coupon-card__art--color-purple {
  background-color: #5a2394;
  background-image: linear-gradient(145deg, #7f3fbf 0%, #5a2394 100%);
}

.local-coupon-card__art--color-gold {
  background-color: #a16207;
  background-image: linear-gradient(145deg, #d4a017 0%, #a16207 100%);
}

.local-coupon-card__art--pattern-dots {
  background-image:
    radial-gradient(circle at -3% 12%, rgba(255, 255, 255, 0.22) 0 5.5%, transparent 6.4%),
    radial-gradient(circle at 10% 8%, rgba(255, 255, 255, 0.16) 0 2.6%, transparent 3.5%),
    radial-gradient(circle at 22% 18%, rgba(255, 255, 255, 0.28) 0 4.2%, transparent 5.1%),
    radial-gradient(circle at 38% -2%, rgba(255, 255, 255, 0.18) 0 3.8%, transparent 4.7%),
    radial-gradient(circle at 58% 12%, rgba(255, 255, 255, 0.26) 0 5.6%, transparent 6.5%),
    radial-gradient(circle at 79% 9%, rgba(255, 255, 255, 0.14) 0 2.2%, transparent 3.1%),
    radial-gradient(circle at 101% 20%, rgba(255, 255, 255, 0.2) 0 4.6%, transparent 5.5%),
    radial-gradient(circle at 7% 52%, rgba(255, 255, 255, 0.18) 0 3.2%, transparent 4.1%),
    radial-gradient(circle at 26% 64%, rgba(255, 255, 255, 0.3) 0 6%, transparent 6.9%),
    radial-gradient(circle at 44% 46%, rgba(255, 255, 255, 0.12) 0 2%, transparent 2.9%),
    radial-gradient(circle at 64% 58%, rgba(255, 255, 255, 0.2) 0 3.9%, transparent 4.8%),
    radial-gradient(circle at 88% 44%, rgba(255, 255, 255, 0.16) 0 3%, transparent 3.9%),
    radial-gradient(circle at -2% 86%, rgba(255, 255, 255, 0.2) 0 4.8%, transparent 5.7%),
    radial-gradient(circle at 18% 96%, rgba(255, 255, 255, 0.14) 0 2.6%, transparent 3.5%),
    radial-gradient(circle at 42% 86%, rgba(255, 255, 255, 0.24) 0 4.4%, transparent 5.3%),
    radial-gradient(circle at 68% 94%, rgba(255, 255, 255, 0.18) 0 3.3%, transparent 4.2%),
    radial-gradient(circle at 92% 82%, rgba(255, 255, 255, 0.26) 0 5.2%, transparent 6.1%),
    radial-gradient(circle at 104% 90%, rgba(255, 255, 255, 0.16) 0 3.6%, transparent 4.5%);
}

.local-coupon-card__art--pattern-lines-left {
  background-image:
    repeating-linear-gradient(
      -35deg,
      rgba(255, 255, 255, 0.24) 0 2px,
      rgba(255, 255, 255, 0) 2px 10px
    );
}

.local-coupon-card__art--pattern-lines-right {
  background-image:
    repeating-linear-gradient(
      35deg,
      rgba(255, 255, 255, 0.24) 0 2px,
      rgba(255, 255, 255, 0) 2px 10px
    );
}

.local-coupon-card__art--pattern-burst {
  background-image:
    linear-gradient(135deg, rgba(255, 255, 255, 0.16) 0 18%, transparent 18% 100%),
    linear-gradient(160deg, rgba(255, 210, 110, 0.26) 0 22%, transparent 22% 100%),
    repeating-linear-gradient(
      145deg,
      rgba(255, 255, 255, 0.12) 0 3px,
      rgba(255, 255, 255, 0) 3px 12px
    );
}

.local-coupon-card__art--pattern-soft {
  background-image:
    radial-gradient(ellipse at 18% 20%, rgba(255, 255, 255, 0.18) 0 20%, transparent 44%),
    radial-gradient(ellipse at 78% 28%, rgba(255, 255, 255, 0.12) 0 24%, transparent 48%),
    radial-gradient(ellipse at 36% 82%, rgba(255, 255, 255, 0.1) 0 22%, transparent 46%),
    radial-gradient(ellipse at 92% 78%, rgba(255, 255, 255, 0.08) 0 16%, transparent 36%);
}

.coupon-modal__dialog {
  width: min(calc(100% - 2rem), 480px);
  max-height: calc(100vh - 1.5rem);
  overflow: auto;
  padding: 1.1rem;
}

.coupon-sheet {
  display: grid;
  gap: 0.7rem;
  padding: 0.95rem;
  border: 1px dashed rgba(0, 119, 200, 0.45);
  border-radius: var(--radius-lg);
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(248, 250, 252, 0.98));
}

.coupon-sheet__art {
  max-width: 300px;
  margin: 0 auto;
  border-radius: var(--radius-md);
  overflow: hidden;
}

.coupon-sheet__art img {
  width: 100%;
  aspect-ratio: 4 / 3;
  object-fit: cover;
  display: block;
}

.coupon-sheet__barcode {
  width: min(100%, 220px);
  align-self: center;
  padding: 0.3rem 0.4rem 0.25rem;
  border: 1px solid rgba(214, 221, 229, 0.9);
  border-radius: var(--radius-md);
  background: #fff;
}

.coupon-sheet__barcode svg {
  display: block;
  width: 100%;
  height: auto;
}

.coupon-sheet__code {
  display: inline-flex;
  align-self: flex-start;
  padding: 0.45rem 0.75rem;
  border-radius: 999px;
  background: rgba(0, 119, 200, 0.1);
  color: var(--color-blue);
  font-weight: 700;
}

.coupon-sheet__details,
.coupon-sheet__meta {
  color: var(--color-text-muted);
}

.coupon-sheet__meta {
  display: grid;
  gap: 0.35rem;
  padding-top: 0.25rem;
}

.coupon-print-area {
  display: none;
}

.admin-login,
.admin-coupons__form {
  gap: 1rem;
}

.admin-page {
  position: relative;
  background: linear-gradient(180deg, rgba(244, 248, 252, 0.94), rgba(248, 251, 255, 0.98));
}

.admin-page .section:first-child {
  padding-top: 2.2rem;
}

.admin-page .section-heading {
  padding: 1.35rem 1.45rem;
  border: 1px solid rgba(188, 204, 220, 0.88);
  border-radius: calc(var(--radius-lg) + 2px);
  background: linear-gradient(135deg, rgba(246, 250, 255, 0.96), rgba(235, 242, 249, 0.96));
  box-shadow: 0 18px 40px rgba(22, 49, 74, 0.08);
}

.admin-page .section-heading p,
.admin-page .section-heading > p:last-child {
  color: #587085;
}

.admin-page .privacy-card,
.admin-page .card {
  border-color: var(--surface-card-admin-border);
  background: var(--surface-card-admin);
  box-shadow: var(--surface-card-admin-shadow);
}

.admin-page .admin-nav a,
.admin-page .admin-nav__disabled {
  border-color: rgba(168, 188, 206, 0.9);
  background: rgba(247, 250, 253, 0.96);
}

.admin-page .admin-nav a:hover,
.admin-page .admin-nav a:focus-visible {
  border-color: rgba(0, 122, 195, 0.32);
  background: rgba(230, 241, 251, 0.98);
}

.admin-page .admin-nav a[aria-current="page"] {
  border-color: rgba(0, 122, 195, 0.26);
  background: linear-gradient(180deg, rgba(229, 240, 250, 0.98), rgba(214, 232, 247, 0.98));
  color: #0f4f7a;
}

.admin-page .field input[readonly],
.admin-page .field textarea[readonly] {
  background: rgba(239, 244, 248, 0.95);
}

.admin-login__status {
  margin-top: 1rem;
  padding: 0.9rem 1rem;
  border-radius: var(--radius-md);
  font-weight: 700;
}

.admin-login__status--success {
  background: rgba(22, 163, 74, 0.12);
  color: #166534;
}

.admin-login__status--error {
  background: rgba(220, 38, 38, 0.1);
  color: #991b1b;
}

.admin-toast {
  position: fixed;
  left: 50%;
  bottom: 1.5rem;
  transform: translate(-50%, 1rem);
  z-index: 1200;
  min-width: min(22rem, calc(100vw - 2rem));
  max-width: min(34rem, calc(100vw - 2rem));
  padding: 0.95rem 1.25rem;
  border: 1px solid rgba(20, 42, 63, 0.14);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.96);
  box-shadow: 0 16px 36px rgba(20, 42, 63, 0.18);
  color: #102033;
  font-size: 0.98rem;
  font-weight: 700;
  line-height: 1.35;
  text-align: center;
  opacity: 0;
  pointer-events: auto;
  transition:
    opacity 180ms ease,
    transform 180ms ease;
  backdrop-filter: blur(10px);
}

.admin-toast.is-visible {
  opacity: 1;
  transform: translate(-50%, 0);
}

.admin-toast--success {
  border-color: rgba(22, 163, 74, 0.2);
  background: rgba(242, 255, 247, 0.97);
  color: #166534;
}

.admin-toast--error {
  border-color: rgba(220, 38, 38, 0.2);
  background: rgba(255, 245, 245, 0.97);
  color: #991b1b;
}

.admin-form-save-state {
  margin: 0;
  pointer-events: none;
  opacity: 1;
  background: rgba(244, 248, 252, 0.96);
  color: var(--color-blue-dark);
  white-space: nowrap;
  cursor: default;
}

.admin-form-save-state.is-dirty {
  border-color: rgba(238, 58, 67, 0.28);
  background: rgba(255, 244, 242, 0.98);
  color: #b42318;
}

.admin-form-save-state.is-saved {
  border-color: rgba(22, 163, 74, 0.2);
  background: rgba(236, 253, 243, 0.98);
  color: #166534;
}

.admin-form-save-state.is-saving {
  border-color: rgba(0, 119, 200, 0.24);
  background: rgba(236, 246, 253, 0.98);
  color: var(--color-blue);
}

.admin-form-save-meta {
  margin: 0 0 0.15rem;
  color: var(--color-text-muted);
  font-size: 0.9rem;
  line-height: 1.4;
  width: 100%;
}

.admin-coupons {
  display: grid;
  gap: 1.25rem;
}

.admin-coupons code {
  font-size: 0.95em;
}

.admin-coupons__topbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  flex-wrap: wrap;
}

.admin-home {
  display: grid;
  gap: 1.25rem;
}

.admin-home__topbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  flex-wrap: wrap;
}

.admin-home__topbar p,
.admin-coupons__topbar p {
  margin: 0;
}

.admin-nav {
  display: flex;
  flex-wrap: wrap;
  gap: 0.6rem;
  margin-top: 0.55rem;
}

.admin-nav a,
.admin-nav__disabled {
  display: inline-flex;
  align-items: center;
  min-height: 2.3rem;
  padding: 0.45rem 0.8rem;
  border-radius: 999px;
  border: 1px solid rgba(214, 221, 229, 0.95);
  background: rgba(255, 255, 255, 0.94);
  color: var(--color-text);
  font-size: 0.92rem;
  font-weight: 700;
}

.admin-nav a[aria-current="page"] {
  border-color: rgba(0, 122, 195, 0.22);
  background: rgba(0, 122, 195, 0.08);
  color: var(--color-blue-dark);
}

.admin-nav__disabled {
  color: var(--color-text-muted);
  background: rgba(247, 249, 252, 0.94);
}

.admin-home__tools-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.45fr) repeat(2, minmax(250px, 0.85fr));
  gap: 1.2rem;
  margin-top: 0.25rem;
  align-items: start;
}

.admin-home__tool-card {
  display: grid;
  gap: 0.9rem;
  align-content: start;
}

.admin-home__tool-card--primary {
  grid-column: 1 / span 2;
}

.admin-home__tool-card--secondary {
  min-height: 100%;
}

.admin-home__tool-card--support-band {
  grid-column: 1 / -1;
  gap: 0.55rem;
}

.admin-home__support-band {
  display: flex;
  flex-wrap: wrap;
  gap: 0.45rem 1.2rem;
  align-items: center;
}

.admin-home__support-band p {
  margin: 0;
}

.admin-home__tool-card .button {
  justify-self: start;
}

.admin-home__layout {
  align-items: start;
}

.admin-home__form {
  gap: 1.25rem;
}

.admin-home__group {
  display: contents;
}

.admin-home__group--full {
  display: grid;
  grid-column: 1 / -1;
  gap: 0.95rem 1rem;
}

.admin-home__group + .admin-home__group::before {
  content: "";
  grid-column: 1 / -1;
  display: block;
  height: 0;
  margin-top: 0.5rem;
  padding-top: 0.95rem;
}

.admin-home__logo-preview {
  display: flex;
  align-items: center;
  justify-content: flex-start;
  min-height: 72px;
  padding: 0.65rem 0.9rem;
  border: 1px solid var(--surface-preview-border);
  border-radius: var(--radius-md);
  background: var(--surface-preview);
}

.admin-home__logo-preview img {
  display: block;
  width: auto;
  max-width: min(100%, 280px);
  max-height: 58px;
}

.field-note {
  margin: 0.3rem 0 0;
  color: var(--color-text-muted);
  font-size: 0.92rem;
  line-height: 1.5;
}

.admin-home__feature-grid {
  display: grid;
  grid-column: 1 / -1;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 1rem;
}

.admin-home__feature-card {
  display: grid;
  gap: 0.9rem;
  padding: 1rem;
}

.admin-home__feature-preview-wrap {
  gap: 0.5rem;
}

.admin-home__feature-preview {
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 132px;
  padding: 0.55rem;
  border: 1px solid var(--surface-preview-border);
  border-radius: var(--radius-md);
  background: var(--surface-preview);
  overflow: hidden;
}

.admin-home__feature-preview img {
  display: block;
  width: 100%;
  max-width: 100%;
  aspect-ratio: 16 / 10;
  object-fit: cover;
  border-radius: calc(var(--radius-md) - 4px);
}

.admin-home__social-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.9rem;
  margin-bottom: 0.45rem;
}

.admin-home__hours-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.6fr) minmax(0, 1fr) minmax(0, 1fr);
  gap: 0.65rem 0.75rem;
}

.admin-home__hours-heading {
  font-size: 0.82rem;
  font-weight: 700;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: var(--color-text-muted);
}

.admin-home__toggle {
  display: inline-flex;
  align-items: center;
  gap: 0.45rem;
  font-size: 0.92rem;
  font-weight: 600;
  color: var(--ink-soft);
  flex-shrink: 0;
}

.admin-home__toggle input {
  margin: 0;
  width: 0.95rem;
  height: 0.95rem;
  accent-color: rgba(0, 119, 200, 0.82);
}

.admin-home__social-heading {
  display: inline-flex;
  align-items: center;
  gap: 0.55rem;
}

.admin-home__social-heading img {
  display: block;
  width: 0.95rem;
  height: 0.95rem;
  opacity: 0.78;
}

.admin-menu {
  display: grid;
  gap: 1.25rem;
}

.admin-menu__form {
  display: grid;
  gap: 1.25rem;
}

.admin-menu__settings,
.admin-menu__section {
  display: grid;
  gap: 1rem;
}

.admin-menu__section-fields {
  align-content: start;
}

.admin-menu__item-grid {
  display: grid;
  gap: 1rem;
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.admin-menu__item-card {
  position: relative;
  display: flex;
  flex-direction: column;
  align-content: start;
  height: 100%;
}

.admin-menu__item-state {
  position: absolute;
  top: 0.9rem;
  right: 0.9rem;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 1.9rem;
  padding: 0.3rem 0.65rem;
  border: 1px solid rgba(22, 163, 74, 0.18);
  border-radius: 999px;
  background: rgba(236, 253, 243, 0.98);
  color: #166534;
  font-size: 0.78rem;
  font-weight: 700;
  letter-spacing: 0.03em;
  line-height: 1;
  text-transform: uppercase;
}

.admin-menu__item-state.is-hidden {
  border-color: rgba(160, 181, 199, 0.26);
  background: rgba(244, 247, 250, 0.98);
  color: #667785;
}

.admin-menu__item-card.is-hidden {
  opacity: 0.5;
  border-color: rgba(180, 192, 204, 0.95);
  background: linear-gradient(180deg, rgba(243, 246, 249, 0.99), rgba(232, 238, 243, 0.99));
  filter: grayscale(0.35);
}

.admin-menu__item-card.is-just-created {
  border-color: rgba(250, 171, 83, 0.88);
  box-shadow: 0 0 0 3px rgba(250, 171, 83, 0.18), 0 16px 34px rgba(18, 40, 72, 0.12);
}

.admin-menu__section.is-hidden {
  opacity: 0.62;
  filter: grayscale(0.2);
}

.admin-menu__item-fields {
  grid-template-columns: 1fr;
  align-content: start;
}

.admin-menu__brand-field[hidden] {
  display: none !important;
}

.admin-menu__item-card > div:nth-of-type(2) {
  display: grid;
  gap: 0.35rem;
  align-content: start;
  min-height: 0;
}

.admin-menu__section-actions form,
.admin-menu__item-actions form {
  margin: 0;
}

.admin-menu__item-actions {
  display: flex;
  flex-wrap: nowrap;
  gap: 0.45rem;
}

.admin-menu__item-actions .button {
  min-height: 2.15rem;
  padding: 0.45rem 0.7rem;
  font-size: 0.84rem;
  white-space: nowrap;
}

.admin-menu__danger {
  display: grid;
  gap: 0.45rem;
  padding: 0.7rem 0.8rem;
  border: 1px solid rgba(201, 42, 53, 0.22);
  border-radius: 16px;
  background: rgba(255, 244, 245, 0.98);
}

.admin-menu__danger-shell {
  display: grid;
  gap: 0.55rem;
  justify-items: start;
}

.admin-menu__danger-shell[open] {
  gap: 0.7rem;
}

.admin-menu__danger-toggle {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 2.15rem;
  padding: 0.45rem 0.8rem;
  border: 1px solid rgba(201, 42, 53, 0.2);
  border-radius: 999px;
  background: rgba(255, 244, 245, 0.9);
  color: #b42318;
  font-size: 0.84rem;
  font-weight: 700;
  line-height: 1;
  cursor: pointer;
  list-style: none;
}

.admin-menu__danger-toggle::-webkit-details-marker {
  display: none;
}

.admin-menu__danger-title {
  margin: 0;
  color: #a61b25;
  font-size: 0.9rem;
  font-weight: 800;
}

.admin-menu__danger-copy {
  margin: 0;
  color: #7f1d1d;
  font-size: 0.84rem;
  line-height: 1.4;
}

.admin-menu__danger-check {
  padding-top: 0;
  font-size: 0.9rem;
}

.admin-menu__danger-check span {
  font-weight: 700;
}

.admin-menu__danger form {
  display: grid;
  gap: 0.5rem;
  margin: 0;
}

.admin-menu__danger-button {
  justify-self: start;
  min-height: 42px;
  padding: 0.65rem 0.95rem;
  background: #b91c1c;
}

.admin-menu__danger-button:hover {
  background: #991b1b;
}

.admin-menu__danger-shell .admin-menu__danger {
  width: min(100%, 28rem);
}

.admin-users__danger-shell {
  margin-top: 0.85rem;
  justify-items: start;
}

.admin-users__danger-shell .admin-menu__danger-toggle {
  align-self: start;
}

.admin-users__danger-shell .admin-menu__danger {
  max-width: 28rem;
}

.admin-page .story-grid {
  padding-top: 0.35rem;
}

.admin-images__folder-grid {
  display: grid;
  gap: 1.25rem;
  margin-top: 1.25rem;
  padding-top: 0.85rem;
}

.admin-images__form {
  padding-top: 0.85rem;
}

.admin-images__social-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 1rem;
  padding-top: 0.85rem;
}

.admin-images__social-card {
  display: grid;
  gap: 0.7rem;
}

.admin-images__social-card h3,
.admin-images__social-copy {
  margin: 0;
}

.admin-images__social-copy {
  color: var(--color-text-muted);
  font-size: 0.88rem;
  line-height: 1.45;
}

.admin-images__social-preview {
  display: flex;
  align-items: center;
  justify-content: center;
  aspect-ratio: 1.91 / 1;
  overflow: hidden;
  border-radius: 16px;
  border: 1px solid var(--surface-preview-border);
  background: var(--surface-preview);
}

.admin-images__social-preview img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

@media (max-width: 1320px) {
  .admin-images__social-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 860px) {
  .admin-images__social-grid {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 560px) {
  .admin-images__social-grid {
    grid-template-columns: 1fr;
  }
}

.admin-images__folder-card code {
  color: var(--color-text-muted);
}

.admin-images__empty {
  margin: 0;
  color: var(--color-text-muted);
}

.admin-images__item-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(170px, 1fr));
  gap: 0.85rem;
}

.admin-images__item {
  display: grid;
  gap: 0.65rem;
  padding: 0.72rem;
  border: 1px solid rgba(16, 24, 40, 0.08);
  border-radius: 18px;
  background: rgba(248, 250, 252, 0.88);
}

.admin-images__thumb {
  display: flex;
  align-items: center;
  justify-content: center;
  aspect-ratio: 4 / 3;
  overflow: hidden;
  border-radius: 14px;
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(237, 242, 247, 0.98));
}

.admin-images__thumb img {
  width: 100%;
  height: 100%;
  object-fit: contain;
}

.admin-images__meta {
  display: grid;
  gap: 0.35rem;
}

.admin-images__filename-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.5rem;
}

.admin-images__filename,
.admin-images__path {
  margin: 0;
}

.admin-images__filename {
  font-weight: 800;
  font-size: 0.92rem;
}

.admin-images__usage-pill {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0.18rem 0.5rem;
  border-radius: 999px;
  background: rgba(10, 150, 80, 0.12);
  color: #146c43;
  font-size: 0.7rem;
  font-weight: 800;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  white-space: nowrap;
  cursor: help;
}

.admin-images__path code {
  word-break: break-all;
  font-size: 0.74rem;
}

.admin-images__stats {
  display: flex;
  flex-wrap: wrap;
  gap: 0.25rem 0.55rem;
  color: var(--color-text-muted);
  font-size: 0.77rem;
}

.admin-images__actions {
  gap: 0.35rem;
}

.admin-images__actions .button {
  min-height: 2rem;
  padding: 0.42rem 0.62rem;
  font-size: 0.8rem;
}

.admin-advanced__tool-shell {
  margin-top: 0.85rem;
  justify-items: start;
}

.admin-advanced__tool-toggle {
  align-self: start;
}

.admin-advanced__tool-toggle img {
  width: 0.9rem;
  height: 0.9rem;
  display: block;
  flex: 0 0 auto;
  margin-right: 0.35rem;
}

.admin-advanced__tool-toggle span {
  display: inline-block;
}

.admin-advanced__tool-toggle--backup {
  border-color: rgba(160, 181, 199, 0.3);
  background: rgba(247, 250, 252, 0.95);
  color: var(--color-blue-dark);
}

.admin-advanced__tool-toggle--backup:hover {
  border-color: rgba(0, 122, 195, 0.26);
  background: rgba(236, 246, 253, 0.96);
  color: var(--color-blue);
}

.admin-advanced__tool-panel {
  width: min(100%, 40rem);
  gap: 0.7rem;
}

.admin-advanced__tool-panel--backup {
  border-color: rgba(160, 181, 199, 0.22);
  background: rgba(248, 250, 252, 0.98);
}

.admin-advanced__tool-toggle--restore img {
  filter: brightness(0) saturate(100%) invert(19%) sepia(84%) saturate(2913%) hue-rotate(346deg) brightness(88%) contrast(90%);
}

.admin-advanced__tool-title--backup {
  color: var(--color-blue-dark);
}

.admin-advanced__tool-copy--backup {
  color: var(--color-text);
}

.admin-advanced__restore-form {
  display: grid;
  gap: 0.7rem;
  width: 100%;
  margin: 0;
}

.admin-advanced__field {
  margin: 0;
}

.admin-advanced__file-input {
  padding-top: 0.7rem;
  padding-bottom: 0.7rem;
}

.admin-advanced__confirm {
  padding-top: 0.15rem;
}

.admin-advanced__tool-actions {
  margin-top: 0.1rem;
}

.admin-advanced__restore-button {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
}

.admin-advanced__restore-button img {
  width: 0.95rem;
  height: 0.95rem;
  display: block;
  flex: 0 0 auto;
  filter: brightness(0) invert(1);
}

.employee-page__schedule-card,
.privacy-card--full {
  grid-column: 1 / -1;
}

.employee-page {
  align-items: start;
}

.employee-page__announcement {
  background:
    radial-gradient(circle at top right, rgba(0, 119, 200, 0.12), transparent 46%),
    linear-gradient(180deg, rgba(255, 250, 244, 0.96), rgba(255, 255, 255, 0.98));
}

.employee-page__section-kicker {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  margin-bottom: 0.35rem;
  line-height: 1;
}

.employee-page__section-kicker img {
  width: 0.95rem;
  height: 0.95rem;
  display: block;
  flex: 0 0 auto;
}

.employee-page__section-kicker .kicker {
  display: inline-flex;
  align-items: center;
  min-height: 0.95rem;
  margin: 0;
}

.employee-page__schedule-days,
.admin-employee__days {
  display: grid;
  gap: 1rem;
}

.employee-page__day,
.admin-employee__day-card {
  display: grid;
  gap: 0.75rem;
}

.employee-page__day h3,
.admin-employee__link-card h4 {
  margin: 0;
}

.employee-page__schedule-table {
  display: grid;
  grid-template-columns: minmax(120px, 1.2fr) repeat(2, minmax(76px, 0.6fr)) minmax(110px, 0.95fr) minmax(120px, 1.2fr);
  gap: 0;
  border: 1px solid rgba(214, 221, 229, 0.9);
  border-radius: 18px;
  overflow: hidden;
}

.employee-page__schedule-table > div {
  padding: 0.75rem 0.8rem;
  border-right: 1px solid rgba(214, 221, 229, 0.8);
  border-bottom: 1px solid rgba(214, 221, 229, 0.8);
  background: #fff;
  min-width: 0;
}

.employee-page__schedule-table > div:nth-child(5n) {
  border-right: 0;
}

.employee-page__schedule-head {
  background: rgba(236, 246, 253, 0.92) !important;
  font-weight: 800;
  color: var(--color-blue-dark);
}

.employee-page__links,
.admin-employee__links {
  display: grid;
  gap: 0.85rem;
}

.employee-page__resource-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 1rem;
}

.employee-page__resource-panel {
  display: grid;
  gap: 0.85rem;
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(246, 250, 253, 0.98));
}

.employee-page__resource-note {
  margin: 0;
  color: var(--color-text-muted);
}

.employee-page__link-card {
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: start;
  gap: 0.8rem;
  padding: 0.95rem 1rem;
  border: 1px solid rgba(214, 221, 229, 0.9);
  border-radius: 18px;
  background:
    linear-gradient(180deg, rgba(248, 250, 252, 0.98), rgba(238, 245, 251, 0.98));
  color: inherit;
  text-decoration: none;
  transition: transform 160ms ease, box-shadow 160ms ease, border-color 160ms ease;
}

.employee-page__link-card:hover,
.employee-page__link-card:focus-visible {
  transform: translateY(-2px);
  border-color: rgba(0, 119, 200, 0.22);
  box-shadow: 0 16px 28px rgba(20, 42, 63, 0.09);
}

.employee-page__link-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 2.35rem;
  height: 2.35rem;
  border-radius: 999px;
  background: rgba(0, 119, 200, 0.1);
  flex: 0 0 auto;
}

.employee-page__link-icon img,
.employee-page__link-arrow img {
  width: 1rem;
  height: 1rem;
  display: block;
}

.employee-page__link-copy {
  display: grid;
  gap: 0.3rem;
  min-width: 0;
}

.employee-page__link-arrow {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 1.9rem;
  height: 1.9rem;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.92);
  color: var(--color-blue-dark);
  flex: 0 0 auto;
}

.employee-page__link-card strong {
  color: var(--color-blue-dark);
}

.employee-page__link-card span {
  color: var(--color-text-muted);
}

.employee-page__link-copy strong {
  color: var(--color-blue-dark);
}

.employee-page__link-copy span {
  color: var(--color-text-muted);
}

@media (max-width: 860px) {
  .employee-page__resource-grid {
    grid-template-columns: 1fr;
  }

  .employee-page__link-card {
    grid-template-columns: auto 1fr;
  }

  .employee-page__link-arrow {
    display: none;
  }
}

.admin-employee__schedule-editor {
  display: grid;
  gap: 0.7rem;
}

.admin-employee__schedule-grid {
  display: grid;
  grid-template-columns: minmax(140px, 1.15fr) repeat(2, minmax(80px, 0.55fr)) minmax(120px, 0.95fr) minmax(140px, 1.2fr) auto;
  gap: 0.55rem;
  align-items: start;
}

.admin-employee__panel {
  display: grid;
  gap: 1rem;
  padding: 1.1rem;
  border: 1px solid rgba(214, 221, 229, 0.9);
  border-radius: 22px;
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.99), rgba(245, 250, 253, 0.98));
}

.admin-employee__sections {
  padding-top: 0.85rem;
}

.admin-employee__panel--announcements {
  background:
    radial-gradient(circle at top right, rgba(0, 119, 200, 0.12), transparent 42%),
    linear-gradient(180deg, rgba(255, 250, 244, 0.98), rgba(255, 255, 255, 0.99));
}

.admin-employee__panel-head {
  display: grid;
  gap: 0.35rem;
}

.admin-employee__panel-head h3 {
  margin: 0;
}

.admin-employee__schedule-editor input {
  width: 100%;
  min-height: 44px;
  padding: 0.7rem 0.8rem;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  background: #fff;
  color: var(--color-text);
}

.admin-employee__schedule-editor input:focus-visible {
  outline: 3px solid var(--color-gold);
  outline-offset: 2px;
  border-color: transparent;
}

.admin-employee__schedule-head {
  font-size: 0.82rem;
  font-weight: 800;
  color: var(--color-blue-dark);
}

.admin-employee__schedule-head--actions {
  text-align: center;
}

.admin-employee__schedule-rows {
  display: grid;
  gap: 0.55rem;
}

.admin-employee__schedule-row {
  align-items: center;
}

.admin-employee__schedule-delete {
  min-width: 5.75rem;
  align-self: stretch;
}

.admin-employee__schedule-base {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 5.75rem;
  min-height: 44px;
  padding: 0.7rem 0.8rem;
  border: 1px dashed rgba(160, 181, 199, 0.95);
  border-radius: 999px;
  color: var(--color-text-muted);
  background: rgba(244, 248, 252, 0.95);
  font-size: 0.82rem;
  font-weight: 700;
}

.admin-employee__schedule-actions {
  justify-content: flex-start;
}

.admin-employee__link-card {
  display: grid;
  gap: 0.85rem;
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(246, 250, 253, 0.98));
}

.admin-employee__link-head {
  display: flex;
  align-items: center;
  gap: 0.7rem;
}

.admin-employee__link-head h4 {
  margin: 0;
}

.admin-employee__link-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 2.2rem;
  height: 2.2rem;
  border-radius: 999px;
  background: rgba(0, 119, 200, 0.1);
  flex: 0 0 auto;
}

.admin-employee__link-icon img {
  width: 0.95rem;
  height: 0.95rem;
  display: block;
}

.admin-employee__file-meta {
  margin: 0;
  color: var(--color-text-muted);
  font-size: 0.92rem;
}

.admin-employee__file-note {
  margin: -0.15rem 0 0;
  color: var(--color-text-muted);
  font-size: 0.9rem;
}

.admin-home__pdf-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 0.45rem 1rem;
  margin: 0;
  align-items: baseline;
  color: var(--color-text-muted);
  font-size: 0.92rem;
  line-height: 1.35;
}

.admin-home__pdf-meta p {
  margin: 0;
}

.admin-home__pdf-warning {
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  margin: -0.15rem 0 0;
  padding: 0.45rem 0.75rem;
  border-radius: 999px;
  background: rgba(208, 27, 27, 0.08);
  border: 1px solid rgba(208, 27, 27, 0.18);
  color: var(--color-danger);
  font-size: 0.88rem;
  font-weight: 700;
  line-height: 1.2;
}

.admin-home__pdf-warning img {
  width: 0.9rem;
  height: 0.9rem;
  display: block;
  filter: brightness(0) saturate(100%);
  flex: 0 0 auto;
}

.admin-employee__danger-shell {
  margin-top: 0.85rem;
  justify-items: start;
}

.admin-employee__danger-shell .admin-menu__danger-toggle {
  align-self: start;
}

.admin-employee__danger-shell .admin-menu__danger {
  max-width: 28rem;
}

.admin-menu__jump {
  position: fixed;
  right: 1.15rem;
  bottom: 1.35rem;
  z-index: 18;
  display: grid;
  gap: 0.55rem;
  justify-items: end;
}

.admin-menu__jump-spacer {
  display: block;
  width: 2.35rem;
  height: 2.35rem;
}

.admin-menu__jump-button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 2.35rem;
  height: 2.35rem;
  min-width: 2.35rem;
  min-height: 2.35rem;
  padding: 0;
  border-radius: 999px;
  border-color: rgba(160, 181, 199, 0.9);
  background: linear-gradient(180deg, rgba(248, 251, 254, 0.98), rgba(232, 241, 249, 0.98));
  color: var(--color-blue-dark);
  box-shadow: 0 14px 28px rgba(20, 42, 63, 0.14);
}

.admin-menu__jump-button--symbols {
  border-color: rgba(238, 58, 67, 0.24);
  background: linear-gradient(180deg, rgba(255, 249, 247, 0.99), rgba(255, 238, 233, 0.99));
  color: var(--color-red);
}

.admin-menu__jump-button--save {
  border-color: rgba(238, 58, 67, 0.14);
  background: linear-gradient(180deg, rgba(255, 102, 112, 0.98), rgba(238, 58, 67, 0.98));
  color: #fff;
}

.admin-menu__jump-button--save.is-dirty {
  animation: admin-save-pulse 1.8s ease-in-out infinite;
}

.admin-menu__jump-button:hover {
  border-color: rgba(0, 122, 195, 0.34);
  background: linear-gradient(180deg, rgba(236, 246, 253, 0.99), rgba(219, 236, 248, 0.99));
  color: var(--color-blue);
}

.admin-menu__jump-button--save:hover {
  border-color: rgba(201, 42, 53, 0.22);
  background: linear-gradient(180deg, rgba(244, 78, 89, 0.99), rgba(201, 42, 53, 0.99));
  color: #fff;
}

.admin-menu__jump-button--save.is-confirming {
  border-color: rgba(250, 171, 83, 0.28);
  background: linear-gradient(180deg, rgba(255, 194, 111, 0.99), rgba(250, 171, 83, 0.99));
  color: #6b3f00;
}

.admin-menu__jump-button svg {
  width: 0.95rem;
  height: 0.95rem;
  display: block;
}

.admin-menu__jump-popout {
  position: absolute;
  right: calc(100% + 0.7rem);
  bottom: 0;
  width: min(320px, calc(100vw - 3.5rem));
  display: grid;
  gap: 0.55rem;
  padding: 0.8rem 0.9rem;
  border: 1px solid rgba(214, 221, 229, 0.92);
  border-radius: var(--radius-lg);
  background: rgba(255, 255, 255, 0.98);
  box-shadow: 0 18px 36px rgba(10, 24, 54, 0.18);
  backdrop-filter: blur(10px);
  z-index: 2;
}

.admin-menu__jump-popout[hidden] {
  display: none;
}

.admin-menu__jump-actions {
  display: grid;
  gap: 0.38rem;
}

.admin-menu__jump-link {
  justify-content: flex-start;
  min-height: 2.3rem;
  padding-inline: 0.9rem;
  font-size: 0.9rem;
}

@keyframes admin-save-pulse {
  0%,
  100% {
    transform: scale(1);
    box-shadow: 0 14px 28px rgba(20, 42, 63, 0.14);
  }

  40% {
    transform: scale(1.06);
    box-shadow: 0 0 0 0 rgba(238, 58, 67, 0.28), 0 18px 34px rgba(20, 42, 63, 0.16);
  }

  70% {
    transform: scale(1.02);
    box-shadow: 0 0 0 10px rgba(238, 58, 67, 0), 0 16px 30px rgba(20, 42, 63, 0.15);
  }
}

.admin-menu__symbol-popout {
  position: absolute;
  right: calc(100% + 0.7rem);
  top: 0;
  width: min(290px, calc(100vw - 3.5rem));
  display: grid;
  gap: 0.55rem;
  padding: 0.8rem 0.9rem;
  border: 1px solid rgba(214, 221, 229, 0.92);
  border-radius: var(--radius-lg);
  background: rgba(255, 255, 255, 0.98);
  box-shadow: 0 18px 36px rgba(10, 24, 54, 0.18);
  backdrop-filter: blur(10px);
  z-index: 2;
}

.admin-menu__symbol-popout[hidden] {
  display: none;
}

.admin-menu__symbol-popout-label {
  font-size: 0.78rem;
  font-weight: 700;
  color: var(--color-text-muted);
  text-transform: uppercase;
  letter-spacing: 0.06em;
}

.admin-menu__symbol-popout .admin-coupons__symbols-actions {
  gap: 0.35rem;
}

.admin-menu__symbol-popout .admin-coupons__symbol-button {
  min-width: 2.1rem;
  min-height: 2.05rem;
}

.admin-menu__format-button {
  min-width: 2.7rem !important;
  padding-inline: 0.65rem;
}

.menu-item-grid {
  align-items: stretch;
}

.menu-item-card {
  display: flex;
  flex-direction: column;
  gap: 0.8rem;
  height: 100%;
}

.menu-item-card .card__art {
  min-height: clamp(220px, 34vw, 320px);
}

.menu-item-card .card__art--inset {
  padding: 1.1rem;
}

.menu-item-card .card__art--inset img {
  width: 100%;
  height: 100%;
  max-width: 100%;
  max-height: 100%;
  object-fit: contain;
}

.menu-item-card > div:last-child {
  display: grid;
  align-content: start;
  min-height: 0;
}

.menu-item-card .card-title-script {
  margin-bottom: 0;
}

.menu-item-card__prices,
.menu-item-card__calories,
.menu-item-card__note {
  margin: 0;
  color: var(--color-text-muted);
}

.menu-item-card__prices {
  display: grid;
  gap: 0.28rem;
  color: var(--color-blue-dark);
}

.menu-item-card__price-list {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 0.35rem;
  align-items: start;
}

.menu-item-card__price-chip {
  display: grid;
  gap: 0.08rem;
  padding: 0.28rem 0.38rem 0.32rem;
  border-radius: 14px;
  background: rgba(0, 122, 195, 0.06);
  color: var(--color-blue-dark);
  font-weight: 700;
  letter-spacing: 0.01em;
  text-align: center;
  min-width: 0;
}

.menu-item-card__price-chip strong {
  font-size: 0.73rem;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  line-height: 1;
}

.menu-item-card__price-chip span:last-child {
  font-size: 0.94rem;
  line-height: 1.05;
  white-space: nowrap;
}

.menu-item-card__price-note {
  margin: 0;
  font-weight: 700;
  color: var(--color-text-muted);
  font-size: 0.88rem;
  line-height: 1.2;
}

.menu-item-card__calories {
  font-weight: 700;
}

.menu-item-card__description {
  margin: 0;
}

.menu-item-card__note {
  margin-top: 0.4rem;
  font-weight: 700;
  align-self: start;
}

.menu-item-card__choices {
  display: grid;
  gap: 0.75rem;
  margin-top: 0.7rem;
  padding-top: 0.7rem;
  border-top: 1px solid rgba(16, 24, 40, 0.08);
}

.menu-item-card__choice-group {
  display: grid;
  gap: 0.32rem;
}

.menu-item-card__choice-title {
  margin: 0;
  color: var(--color-blue-dark);
  font-size: 0.82rem;
  font-weight: 800;
  letter-spacing: 0.05em;
  text-transform: uppercase;
}

.menu-item-card__choice-pills {
  display: flex;
  flex-wrap: wrap;
  gap: 0.4rem;
  margin: 0;
  padding: 0;
  list-style: none;
}

.menu-item-card__choice-pill {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 1.9rem;
  padding: 0.28rem 0.68rem 0.32rem;
  border: 1px solid rgba(0, 119, 200, 0.12);
  border-radius: 999px;
  background: rgba(0, 119, 200, 0.06);
  color: var(--color-blue-dark);
  font-size: 0.84rem;
  font-weight: 700;
  line-height: 1.2;
}

.menu-item-card__choice-pill em,
.menu-item-card__choice-pill strong,
.menu-item-card__choice-pill u,
.menu-item-card__choice-pill sub,
.menu-item-card__choice-pill sup {
  line-height: 1;
}

.menu-item-card__rule {
  display: block;
  width: 76px;
  height: 2px;
  margin: 0.45rem 0 0.5rem;
  border-radius: 999px;
  background: linear-gradient(90deg, var(--color-red), var(--color-gold));
}

.admin-menu__item-card .card-title-script {
  margin-bottom: 0;
}

.admin-menu__item-summary {
  margin: 0;
}

.admin-menu__kids-preview {
  display: grid;
  gap: 0.3rem;
  margin-top: 0.35rem;
}

.admin-menu__kids-preview p {
  margin: 0;
  color: var(--color-text-muted);
  font-size: 0.82rem;
  line-height: 1.4;
}

.admin-menu__hero-image-row {
  display: grid;
  grid-template-columns: minmax(260px, 420px) minmax(220px, 320px);
  gap: 1rem 1.1rem;
  align-items: start;
  justify-content: start;
}

.admin-menu__hero-preview-wrap {
  gap: 0.55rem;
  align-self: start;
}

.admin-menu__hero-preview {
  display: flex;
  align-items: center;
  justify-content: center;
  aspect-ratio: 4 / 3;
  overflow: hidden;
  border-radius: var(--radius-lg);
  border: 1px solid var(--surface-preview-border);
  box-shadow: var(--shadow-card);
  background: var(--surface-preview);
}

.admin-menu__hero-preview img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.admin-menu__settings,
.admin-menu__section,
.admin-jump-target,
#food-save-area,
#treats-save-area,
#drinks-save-area,
#cakes-save-area {
  scroll-margin-top: 7rem;
}

@media (max-width: 980px) {
  .admin-home__tools-grid {
    grid-template-columns: 1fr;
  }

  .admin-home__tool-card--primary {
    grid-column: auto;
  }
}

@media (max-width: 900px) {
  .admin-menu__hero-image-row {
    grid-template-columns: 1fr;
  }

}

.admin-menu__kids-callout {
  display: grid;
  gap: 0.28rem;
  padding: 0.75rem 0.85rem;
  border: 1px solid rgba(0, 119, 200, 0.12);
  border-radius: 18px;
  background: rgba(246, 249, 252, 0.92);
}

.admin-menu__kids-callout p {
  margin: 0;
  color: var(--color-text-muted);
  font-size: 0.84rem;
  line-height: 1.4;
}

.menu-item-card__band--empty {
  visibility: hidden;
}

.admin-coupons__card-layout {
  display: grid;
  gap: 1.25rem;
}

.admin-coupons__preview-wrap {
  display: grid;
  gap: 0.65rem;
  align-content: start;
}

.admin-coupons__preview {
  align-self: start;
}

.admin-coupons__fields {
  align-content: start;
  grid-auto-flow: row dense;
}

.admin-coupons__symbols {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 0.6rem;
  padding: 0.55rem 0.7rem;
  border: 1px solid rgba(214, 221, 229, 0.82);
  border-radius: 999px;
  background: rgba(247, 249, 252, 0.82);
}

.admin-coupons__symbols-label {
  font-size: 0.82rem;
  font-weight: 700;
  color: var(--color-text-muted);
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

.admin-coupons__symbols-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.4rem;
}

.admin-coupons__symbol-button {
  min-width: 2.15rem;
  min-height: 2rem;
  padding: 0.15rem 0.55rem;
  border-radius: 999px;
  border-color: rgba(31, 41, 51, 0.12);
  background: rgba(255, 255, 255, 0.9);
  font-size: 1rem;
  font-weight: 700;
  line-height: 1;
}

.admin-coupons__status-note {
  margin: 0;
  color: var(--color-text-muted);
  font-size: 0.95rem;
  font-weight: 700;
}

@media (min-width: 860px) {
  .admin-coupons__card-layout {
    grid-template-columns: minmax(280px, 360px) minmax(0, 1fr);
    align-items: start;
  }
}

.application-form {
  gap: 1.5rem;
}

.application-form__header {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 1.5rem;
  align-items: start;
  padding-bottom: 1.25rem;
  border-bottom: 1px solid rgba(214, 221, 229, 0.9);
}

.application-form__header h2 {
  margin: 0;
}

.application-form__header p + p {
  margin-top: 0.6rem;
}

.application-form__meta {
  color: var(--color-text-muted);
  font-size: 0.95rem;
  text-align: right;
}

.application-form__grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 1rem 1.1rem;
}

.field {
  display: grid;
  gap: 0.45rem;
}

.field--full {
  grid-column: 1 / -1;
}

.field span {
  font-weight: 700;
}

.field input,
.field select,
.field textarea {
  width: 100%;
  min-height: 50px;
  padding: 0.8rem 0.95rem;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  background: #fff;
  color: var(--color-text);
}

.field input[readonly] {
  background: #f3f4f6;
  color: #667085;
  border-color: rgba(148, 163, 184, 0.45);
}

.field textarea {
  min-height: 132px;
  resize: vertical;
}

.field input:focus-visible,
.field select:focus-visible,
.field textarea:focus-visible {
  outline: 3px solid var(--color-gold);
  outline-offset: 2px;
  border-color: transparent;
}

.application-form__acknowledgment {
  gap: 0.8rem;
}

.application-form__disclaimer {
  display: grid;
  gap: 0.8rem;
  padding: 1rem 1.05rem;
  border: 1px solid rgba(214, 221, 229, 0.9);
  border-radius: var(--radius-md);
  background: rgba(248, 250, 252, 0.9);
  color: var(--color-text-muted);
}

.field-check {
  display: flex;
  align-items: flex-start;
  gap: 0.75rem;
  padding: 0.1rem 0 0;
}

.field-check input {
  flex: 0 0 auto;
  width: 1rem;
  height: 1rem;
  min-height: 0;
  margin: 0.2rem 0 0;
  accent-color: var(--color-blue);
}

.field-check span {
  font-weight: 400;
  line-height: 1.55;
}

.application-form__footer {
  display: grid;
  gap: 1rem;
  margin-top: 1.35rem;
  padding-top: 1.25rem;
  border-top: 1px solid rgba(214, 221, 229, 0.9);
}

.application-form__note {
  color: var(--color-text-muted);
}

.application-form__actions {
  margin-top: 0;
}

.application-print-brand {
  display: none;
}

.contact-layout {
  display: grid;
  grid-template-columns: minmax(0, 1.55fr) minmax(280px, 0.85fr);
  gap: 1.25rem;
  align-items: start;
}

.contact-card {
  min-width: 0;
}

.contact-form {
  gap: 1.4rem;
}

.contact-hero__media {
  background:
    radial-gradient(circle at 20% 22%, rgba(250, 171, 83, 0.32), transparent 34%),
    radial-gradient(circle at 82% 18%, rgba(0, 122, 195, 0.22), transparent 30%),
    radial-gradient(circle at 78% 82%, rgba(238, 58, 67, 0.16), transparent 28%),
    linear-gradient(160deg, rgba(255, 255, 255, 0.98), rgba(238, 245, 251, 0.96));
  border: 1px solid rgba(214, 221, 229, 0.9);
  box-shadow: var(--shadow-card);
}

.contact-details {
  display: grid;
  gap: 1rem;
  color: var(--color-text-muted);
}

.contact-details p,
.contact-card__note {
  margin: 0;
}

.contact-card__actions {
  margin-top: 1.25rem;
}

.form-status {
  display: none;
  margin: 0;
  padding: 0.85rem 1rem;
  border-radius: var(--radius-md);
  font-weight: 700;
  line-height: 1.5;
}

.form-status.is-visible {
  display: block;
}

.form-status--success {
  border: 1px solid rgba(34, 138, 94, 0.22);
  background: rgba(226, 248, 236, 0.96);
  color: #16603b;
}

.form-status--error {
  border: 1px solid rgba(205, 70, 77, 0.18);
  background: rgba(255, 240, 241, 0.98);
  color: #9e1c26;
}

.field-honeypot {
  position: absolute;
  left: -9999px;
  width: 1px;
  height: 1px;
  min-width: 1px;
  min-height: 1px;
  padding: 0;
  border: 0;
  margin: 0;
  opacity: 0;
  pointer-events: none;
}

.privacy-page {
  padding: 0 0 4.5rem;
}

.privacy-hero {
  padding: 4.5rem 0 2rem;
}

.privacy-hero__shell {
  text-align: left;
}

.privacy-hero h1 {
  margin: 0;
  font-size: var(--type-title-lg);
  line-height: 1.05;
}

.privacy-hero .hero-lede {
  margin-top: 1rem;
  color: var(--color-text-muted);
  max-width: 70ch;
}

.privacy-hero__meta {
  display: flex;
  flex-wrap: wrap;
  gap: 0.75rem 1.25rem;
  margin-top: 1.4rem;
  color: var(--color-text-muted);
  font-weight: 700;
}

.privacy-section {
  padding-top: 1.5rem;
}

.privacy-layout {
  display: grid;
  gap: 1.25rem;
}

.privacy-card {
  padding: 1.6rem;
  border: 1px solid rgba(214, 221, 229, 0.9);
  border-radius: var(--radius-md);
  background: var(--surface-card-public);
  box-shadow: var(--shadow-card);
}

.privacy-card--lede {
  background: linear-gradient(135deg, rgba(0, 122, 195, 0.08), rgba(250, 171, 83, 0.18));
}

.privacy-card h2 {
  margin: 0 0 0.85rem;
  font-size: 1.4rem;
}

.privacy-card p {
  margin: 0;
}

.privacy-card p + p,
.privacy-card p + ul,
.privacy-card ul + p {
  margin-top: 0.9rem;
}

.privacy-list {
  margin: 0;
  padding-left: 1.2rem;
  color: var(--color-text);
}

.privacy-list li + li {
  margin-top: 0.55rem;
}

.privacy-card--contact {
  background: linear-gradient(135deg, rgba(238, 58, 67, 0.06), rgba(255, 245, 223, 0.9));
}

.privacy-address {
  margin-top: 1rem;
  font-style: normal;
  color: var(--color-text-muted);
}

.privacy-address a {
  color: var(--color-blue-dark);
  font-weight: 700;
}

.site-footer {
  margin-top: 2rem;
  padding: 1.05rem 0;
  background: linear-gradient(135deg, var(--color-blue-dark), var(--color-blue));
  color: #fff;
}

.site-scroll-top {
  position: fixed;
  right: max(1rem, calc(env(safe-area-inset-right, 0px) + 1rem));
  bottom: max(0.95rem, calc(env(safe-area-inset-bottom, 0px) + 0.95rem));
  z-index: 70;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 2.35rem;
  height: 2.35rem;
  min-width: 2.35rem;
  min-height: 2.35rem;
  padding: 0;
  border-radius: 999px;
  border: 1px solid rgba(160, 181, 199, 0.9);
  background: linear-gradient(180deg, rgba(248, 251, 254, 0.98), rgba(232, 241, 249, 0.98));
  color: var(--color-blue-dark);
  box-shadow: 0 14px 28px rgba(20, 42, 63, 0.14);
  opacity: 0;
  pointer-events: none;
  transform: translateY(0.35rem);
  box-sizing: border-box;
  flex: 0 0 auto;
  transition:
    opacity 180ms ease,
    transform 180ms ease,
    background-color 180ms ease,
    color 180ms ease,
    box-shadow 180ms ease,
    border-color 180ms ease;
}

.site-scroll-top svg {
  width: 0.95rem;
  height: 0.95rem;
  display: block;
}

.site-scroll-top.is-visible {
  opacity: 0.82;
  pointer-events: auto;
  transform: translateY(0);
}

.site-scroll-top:hover,
.site-scroll-top:focus-visible {
  opacity: 1;
  border-color: rgba(0, 122, 195, 0.34);
  background: linear-gradient(180deg, rgba(236, 246, 253, 0.99), rgba(219, 236, 248, 0.99));
  color: var(--color-blue);
  transform: translateY(0);
}

@media (pointer: coarse) {
  .site-scroll-top {
    width: 3.2rem;
    min-width: 3.2rem;
    max-width: 3.2rem;
    height: 2.85rem;
    min-height: 2.85rem;
    padding: 0;
    border-radius: 1rem;
  }
}

@media (max-width: 540px) {
  .site-scroll-top {
    width: 3.2rem;
    min-width: 3.2rem;
    max-width: 3.2rem;
    height: 2.85rem;
    min-height: 2.85rem;
    padding: 0;
    border-radius: 1rem;
    right: max(1rem, calc(env(safe-area-inset-right, 0px) + 1rem));
    bottom: max(0.9rem, calc(env(safe-area-inset-bottom, 0px) + 0.9rem));
  }
}

.footer-shell {
  display: grid;
  gap: 0.85rem;
}

.footer-top {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 0.9rem;
  align-items: stretch;
}

.footer-panel {
  display: grid;
  gap: 0.55rem;
  align-content: start;
  min-width: 0;
  padding: 0.9rem 1rem;
  border-radius: var(--radius-md);
  background: rgba(255, 255, 255, 0.08);
  border: 1px solid rgba(255, 255, 255, 0.12);
}

.footer-intro {
  min-width: 0;
}

.footer-panel__title {
  margin: 0;
  color: rgba(255, 255, 255, 0.86);
  font-size: 0.96rem;
  font-weight: 700;
  letter-spacing: 0.02em;
}

.footer-lede {
  margin: 0;
  font-size: 0.95rem;
  color: rgba(255, 255, 255, 0.8);
}

.footer-signup {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 0.55rem;
  align-items: start;
}

.footer-signup input {
  min-width: 0;
  height: var(--size-button-height);
  padding: 0 0.95rem;
  border: 0;
  border-radius: calc(var(--button-radius) - 2px);
  background: rgba(255, 255, 255, 0.97);
  color: var(--color-text);
  font: inherit;
}

.footer-signup input::placeholder {
  color: rgba(27, 31, 38, 0.52);
}

.footer-signup input:focus-visible {
  outline: 3px solid rgba(250, 171, 83, 0.8);
  outline-offset: 2px;
}

.footer-signup .button {
  min-height: var(--size-button-height);
  height: var(--size-button-height);
  padding-top: 0;
  padding-bottom: 0;
  align-self: start;
}

.footer-signup__status {
  grid-column: 1 / -1;
  padding: 0.65rem 0.85rem;
  font-size: 0.92rem;
}

.footer-signup__status.form-status--success,
.footer-signup__status.form-status--error {
  border-color: rgba(255, 255, 255, 0.16);
  color: #fff;
}

.footer-signup__status.form-status--success {
  background: rgba(255, 255, 255, 0.13);
}

.footer-signup__status.form-status--error {
  background: rgba(238, 58, 67, 0.2);
}

.footer-link-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 0.45rem 0.9rem;
}

.footer-link-grid a {
  color: #fff;
}

.footer-link-grid a:hover {
  color: rgba(255, 255, 255, 0.82);
}

.footer-link-external {
  display: inline-flex;
  align-items: center;
  gap: 0.28rem;
}

.footer-link-external::after {
  content: "↗";
  font-size: 0.82em;
  line-height: 1;
  opacity: 0.82;
}

.footer-help a {
  color: #fff;
}

.footer-help a:hover {
  color: rgba(255, 255, 255, 0.82);
}

.footer-help__details {
  display: grid;
  gap: 0.45rem;
}

.footer-help__image {
  display: block;
  width: min(100%, 180px);
  height: auto;
  border-radius: calc(var(--radius-md) - 4px);
}

.site-modal[hidden] {
  display: none;
}

.site-modal {
  position: fixed;
  inset: 0;
  z-index: 1000;
  display: grid;
  place-items: center;
  padding: 1.25rem;
}

.site-modal__backdrop {
  position: absolute;
  inset: 0;
  background: rgba(10, 26, 48, 0.56);
  backdrop-filter: blur(8px);
}

.site-modal__dialog {
  position: relative;
  z-index: 1;
  width: min(100%, 31rem);
  padding: 1.6rem;
  border: 1px solid rgba(214, 221, 229, 0.9);
  border-radius: var(--radius-lg);
  background:
    radial-gradient(circle at top right, rgba(250, 171, 83, 0.22), transparent 34%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(238, 245, 251, 0.98));
  box-shadow: var(--shadow-soft);
}

.site-modal__dialog h2 {
  margin: 0;
  font-size: 1.8rem;
}

.site-modal__text {
  margin: 0.9rem 0 1.3rem;
  color: var(--color-text-muted);
}

.site-modal__close {
  position: absolute;
  top: 0.9rem;
  right: 0.9rem;
  width: 2.5rem;
  height: 2.5rem;
  border: 1px solid rgba(214, 221, 229, 0.9);
  border-radius: 999px;
  background: #fff;
  color: var(--color-text);
  cursor: pointer;
  transition: transform 0.2s ease, border-color 0.2s ease;
}

.site-modal__close:hover {
  transform: translateY(-1px);
  border-color: rgba(31, 41, 51, 0.28);
}

@media (min-width: 1081px) {
  .footer-help {
    position: relative;
    padding-right: 148px;
  }

  .footer-help__image {
    position: absolute;
    top: 0.9rem;
    right: 1rem;
    width: 32%;
    min-width: 96px;
    max-width: 136px;
  }
}

@media (min-width: 721px) and (max-width: 1080px) {
  .footer-help {
    position: relative;
    min-height: 168px;
    padding-right: 44%;
  }

  .footer-help__image {
    position: absolute;
    top: 0.9rem;
    right: 1.15rem;
    width: 32%;
    min-width: 102px;
    max-width: 142px;
  }
}

.footer-bottom {
  display: grid;
  gap: 0.35rem;
  padding-top: 0.72rem;
  border-top: 1px solid rgba(255, 255, 255, 0.14);
}

.footer-bottom p {
  margin: 0;
  font-size: 0.84rem;
  color: rgba(255, 255, 255, 0.68);
}

.footer-bottom p:first-child {
  font-size: 0.92rem;
  color: rgba(255, 255, 255, 0.84);
}

.footer-bottom__small {
  color: rgba(255, 255, 255, 0.68);
}

.footer-bottom__tiny {
  margin-top: 0.18rem;
  text-align: left;
  line-height: 1.2;
}

.footer-bottom .footer-bottom__tiny a {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: rgba(255, 255, 255, 0.48);
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.04em;
  line-height: 1;
  text-transform: uppercase;
  text-decoration: none;
}

.footer-bottom .footer-bottom__tiny a:focus-visible {
  color: rgba(214, 233, 255, 0.92);
}

.footer-bottom .footer-bottom__tiny a:hover {
  color: rgba(214, 233, 255, 0.92);
}

.footer-bottom a {
  color: #fff;
}

.footer-bottom a:hover {
  color: rgba(255, 255, 255, 0.82);
}

@media (min-width: 721px) {
  .footer-bottom__tiny {
    justify-self: end;
    text-align: right;
  }
}

.error-page {
  display: grid;
  place-items: center;
  min-height: 70vh;
  text-align: center;
  padding: 2rem 1rem;
}

.error-card {
  width: min(calc(100% - 2rem), 680px);
  padding: 2.35rem;
  border-radius: var(--radius-lg);
  background:
    radial-gradient(circle at 10% 12%, rgba(250, 171, 83, 0.28) 0, transparent 18%),
    radial-gradient(circle at 88% 16%, rgba(238, 58, 67, 0.16) 0, transparent 20%),
    radial-gradient(circle at 78% 84%, rgba(0, 119, 200, 0.16) 0, transparent 24%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.99), rgba(238, 245, 251, 0.97));
  border: 1px solid rgba(214, 221, 229, 0.92);
  box-shadow: var(--shadow-soft);
}

.error-card__spoon {
  width: 230px;
  height: auto;
  display: block;
  margin: 0 auto;
  opacity: 0.92;
}

.error-card__lede {
  color: var(--color-text-muted);
  max-width: 34rem;
  margin-inline: auto;
}

.error-card__actions {
  justify-content: center;
  margin-top: 1.5rem;
}

.error-card__divider {
  margin: 0 auto 1.15rem;
}

/* Responsive layout safeguards
   Keep these grouped and lightly documented. Most exist to protect
   specific content patterns that break or feel cramped at real device widths. */

@media (max-width: 1080px) {
  /* Collapse large multi-panel homepage sections before they become cramped. */
  .hero__shell,
  .callout,
  .content-hero__shell,
  .contact-layout,
  .giftcards-hero__shell,
  .feature-grid,
  .card-grid--three {
    grid-template-columns: 1fr;
  }

  .jobs-values-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .admin-menu__item-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .application-form__header,
  .application-form__grid {
    grid-template-columns: 1fr;
  }

  .application-form__meta {
    text-align: left;
  }

  /* Keep the rotator in a denser 2-up layout before it falls to 1-up on phones. */
  .product-rotator__slide {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

}

@media (max-width: 920px) {
  .site-header {
    transition: transform 220ms ease, box-shadow 220ms ease;
    will-change: transform;
  }

  .site-header.is-mobile-hidden {
    transform: translateY(calc(-100% - 0.5rem));
  }

  /* Hamburger navigation begins here. */
  .nav-toggle {
    display: inline-flex;
    flex: 0 0 52px;
    justify-self: end;
  }

  .nav-shell {
    position: relative;
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    align-items: center;
    gap: 0.85rem;
  }

  .brand {
    min-width: 0;
    max-width: 100%;
  }

  .brand img {
    width: auto;
    height: auto;
    max-width: min(100%, 235px);
    max-height: 72px;
  }

  /* Dropdown menu shell for collapsed nav. */
  .nav-cluster {
    position: absolute;
    left: 1rem;
    right: 1rem;
    top: calc(100% + 0.65rem);
    display: none;
    flex-direction: column;
    align-items: stretch;
    padding: 1rem;
    border-radius: var(--radius-md);
    background: #fff;
    border: 1px solid var(--color-border);
    box-shadow: var(--shadow-soft);
  }

  .nav-cluster.is-open {
    display: flex;
  }

  /* Keep centered dots with the pause/play control docked to the right. */
  .product-rotator__controls {
    grid-template-columns: 1fr auto;
  }

  /* Stack nav links, but keep social icons on one line. */
  .site-nav {
    flex-direction: column;
    align-items: flex-start;
  }

  .socials {
    flex-direction: row;
    align-items: center;
    justify-content: flex-start;
    flex-wrap: nowrap;
  }

  /* Three hero info boxes get too narrow at this width. */
  .hero-copy__details {
    grid-template-columns: 1fr;
  }

  .footer-top {
    grid-template-columns: 1fr;
    align-items: start;
  }

  .footer-title,
  .footer-lede,
  .footer-calories,
  .footer-legal {
    max-width: none;
  }

  .footer-link-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 720px) {
  .jobs-values-grid {
    grid-template-columns: 1fr;
  }

  .admin-menu__item-grid {
    grid-template-columns: 1fr;
  }

  .application-form__actions {
    width: 100%;
  }

  .application-form__actions .button {
    flex: 1 1 100%;
  }

  .story-block__media {
    float: none;
    width: 100%;
    margin: 0 0 1rem;
  }

  /* Keep rotator art panels from overpowering phones. */
  .product-rotator__slide {
    grid-template-columns: 1fr;
  }

  .product-rotator .feature--card {
    width: min(100%, 32rem);
    margin: 0 auto;
  }

  .product-rotator .feature__art {
    min-height: 150px;
    width: min(100%, 21rem);
    margin: 0 auto;
  }

  .product-rotator .feature__art img {
    width: 100%;
    height: 100%;
    max-width: 100%;
    max-height: 100%;
  }

  /* Small-screen spacing and decorative-art tuning. */
  .utility-bar__inner {
    align-items: flex-start;
    flex-direction: column;
    justify-content: center;
    padding: 0.325rem 0;
  }

  .hero-copy,
  .content-copy,
  .card,
  .callout,
  .giftcards-copy,
  .error-card,
  .privacy-card {
    padding: 1.35rem;
  }

  .privacy-hero {
    padding-top: 3.5rem;
  }

  .hero-copy::after {
    top: 5.5rem;
    right: -10.5rem;
    width: clamp(350px, 100vw, 480px);
    opacity: 0.32;
  }

  .feature {
    grid-template-columns: 1fr;
  }

  .feature img {
    max-width: 140px;
  }

  .footer-signup {
    grid-template-columns: 1fr;
  }

  .footer-signup__status {
    grid-column: auto;
  }

  .footer-help {
    position: relative;
    min-height: 0;
    padding-right: 34%;
  }

  .footer-help__image {
    position: absolute;
    top: 0.9rem;
    right: 1rem;
    width: 28%;
    min-width: 92px;
    max-width: 132px;
  }
}

@media print {
  @page {
    size: auto;
    margin: 0.3in;
  }

  .site-header,
  .site-footer,
  .application-hero,
  .application-form__note,
  .application-form__actions,
  .site-modal {
    display: none !important;
  }

  body.is-printing-coupon .site-header,
  body.is-printing-coupon .site-footer,
  body.is-printing-coupon main,
  body.is-printing-coupon .site-modal {
    display: none !important;
  }

  body.is-printing-coupon .coupon-print-area {
    display: block !important;
    position: absolute;
    inset: 0 auto auto 0;
    width: 100%;
  }

  body.is-printing-coupon .coupon-sheet--print {
    width: min(100%, 4.35in);
    margin: 0;
    padding: 0.28in 0.24in;
    gap: 0.32rem;
    border-color: #777;
    background: #fff;
    break-inside: avoid;
    page-break-inside: avoid;
  }

  body.is-printing-coupon .coupon-sheet--print h2 {
    font-size: 1.6rem;
    line-height: 1.05;
  }

  body.is-printing-coupon .coupon-sheet--print .eyebrow {
    margin-bottom: 0;
  }

  body.is-printing-coupon .coupon-sheet--print .coupon-sheet__art {
    max-width: 2.45in;
    margin: 0 auto;
  }

  body.is-printing-coupon .coupon-sheet--print .coupon-sheet__art img {
    aspect-ratio: 4 / 3.1;
  }

  body.is-printing-coupon .coupon-sheet--print .coupon-sheet__barcode {
    width: min(100%, 2.2in);
    padding: 0.12rem 0.18rem 0.1rem;
  }

  body.is-printing-coupon .coupon-sheet--print .coupon-sheet__code {
    padding: 0.2rem 0.42rem;
    font-size: 0.85rem;
  }

  body.is-printing-coupon .coupon-sheet--print h2 {
    font-size: 1.2rem;
  }

  body.is-printing-coupon .coupon-sheet--print .coupon-sheet__details,
  body.is-printing-coupon .coupon-sheet--print .coupon-sheet__meta {
    font-size: 0.82rem;
    line-height: 1.28;
  }

  body.is-printing-coupon .coupon-sheet--print .coupon-sheet__meta {
    gap: 0.2rem;
    padding-top: 0;
  }

  body {
    background: #fff;
  }

  html,
  body {
    width: 100%;
    height: auto;
    margin: 0;
    padding: 0;
    overflow: visible;
  }

  body.is-printing-coupon {
    background: #fff;
  }

  .application-page,
  .section,
  .container {
    padding: 0 !important;
    margin: 0 !important;
  }

  .application-form {
    box-shadow: none;
    border: 0;
    padding: 0;
    background: #fff;
    gap: 0.62rem;
    font-size: 0.75rem;
    line-height: 1.2;
  }

  .application-print-brand {
    display: grid;
    justify-items: start;
    gap: 0.38rem;
    padding: 0 0 0.46rem;
    border-bottom: 1px solid #bbb;
  }

  .application-print-brand img {
    display: block;
    width: auto;
    max-width: 2.35in;
    height: 0.92in;
    max-height: 0.92in;
  }

  .application-print-brand__copy {
    display: grid;
    gap: 0.14rem;
    font-size: 0.69rem;
    line-height: 1.26;
  }

  .application-print-brand__copy strong {
    font-size: 0.8rem;
  }

  .application-form__header,
  .application-form__footer {
    border-color: #bbb;
    padding: 0.08rem 0 0.46rem;
    gap: 0.42rem;
  }

  .application-form__header h2 {
    font-size: 1.08rem;
    margin: 0;
  }

  .application-form__meta {
    display: none;
  }

  .application-form__header p,
  .application-form__meta,
  .application-form__note,
  .application-form__footer,
  .field,
  .field-check span,
  .application-form__disclaimer {
    font-size: 0.68rem;
    line-height: 1.2;
  }

  .application-form__grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.34rem 0.45rem;
  }

  .field {
    gap: 0.16rem;
  }

  .field span {
    font-size: 0.63rem;
  }

  .field input,
  .field select,
  .field textarea {
    border-color: #bbb;
    box-shadow: none;
    min-height: 1.35rem;
    padding: 0.15rem 0.28rem;
    border-radius: 0.18rem;
    font-size: 0.68rem;
  }

  .field textarea {
    min-height: 1.7rem;
    height: 1.7rem;
    resize: none;
  }

  .application-form textarea[name="availability"] {
    min-height: 2.6rem;
    height: 2.6rem;
  }

  .application-form textarea[name="experience"],
  .application-form textarea[name="why_here"] {
    min-height: 3.2rem;
    height: 3.2rem;
  }

  .application-form__disclaimer {
    gap: 0.2rem;
    padding: 0.3rem 0.4rem;
  }

  .application-form__acknowledgment {
    gap: 0.3rem;
  }

  .field-check {
    gap: 0.3rem;
    padding-top: 0;
  }

  .field-check input {
    margin-top: 0.05rem;
  }

  .application-form__meta p,
  .application-print-brand__copy span,
  .application-form__header p {
    margin: 0;
  }

  .application-form__acknowledgment {
    break-inside: avoid;
    page-break-inside: avoid;
  }
}
