:root {
  --flour: #fbf0dc;
  --paper: #fffaf0;
  --paper-deep: #f0dcc0;
  --tomato: #b63825;
  --tomato-dark: #842516;
  --sage: #6f7c4f;
  --sage-dark: #34412d;
  --copper: #b66a3a;
  --espresso: #24150f;
  --bottle: #1f4b3b;
  --muted: #6e5c4d;
  --ring: rgba(36, 21, 15, 0.14);
  --shadow: 0 1px 0 rgba(36, 21, 15, .05), 0 18px 50px rgba(36, 21, 15, .16);
  --radius-xl: 34px;
  --radius-lg: 24px;
  --radius-md: 16px;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  font-family: "Nunito Sans", ui-sans-serif, system-ui, sans-serif;
  color: var(--espresso);
  background:
    linear-gradient(rgba(251, 240, 220, .93), rgba(251, 240, 220, .9)),
    url("./assets/pasta-prep-texture.jpg") center / 540px repeat;
  min-width: 320px;
  overflow-x: hidden;
}

a { color: inherit; }
img { max-width: 100%; display: block; }

.skip-link {
  position: absolute;
  top: 12px;
  left: 12px;
  z-index: 50;
  transform: translateY(-160%);
  background: var(--espresso);
  color: var(--paper);
  padding: .7rem 1rem;
  border-radius: 999px;
}
.skip-link:focus { transform: translateY(0); }

.preview-ribbon {
  display: flex;
  justify-content: center;
  gap: .4rem;
  padding: .58rem 1rem;
  background: var(--espresso);
  color: var(--paper);
  font-size: .86rem;
  text-align: center;
  letter-spacing: .01em;
}
.preview-ribbon strong { color: #ffd7b8; }

.site-header {
  position: sticky;
  top: 0;
  z-index: 20;
  display: grid;
  grid-template-columns: minmax(210px, 1fr) auto minmax(140px, max-content);
  align-items: center;
  gap: 1rem;
  padding: 1rem clamp(1rem, 3vw, 2.4rem);
  background: rgba(255, 250, 240, .86);
  border-bottom: 1px solid var(--ring);
  backdrop-filter: blur(16px);
}
.brand { display: inline-flex; gap: .7rem; align-items: center; text-decoration: none; }
.brand-mark {
  display: grid;
  place-items: center;
  width: 46px;
  height: 46px;
  border-radius: 50%;
  background: radial-gradient(circle at 35% 25%, #fff0d7, var(--tomato));
  color: var(--paper);
  font-family: "Libre Bodoni", serif;
  font-weight: 700;
  font-size: 1.55rem;
  box-shadow: inset 0 -7px 16px rgba(36, 21, 15, .25), 0 10px 24px rgba(132, 37, 22, .22);
}
.brand-name {
  display: block;
  font-family: "Libre Bodoni", serif;
  font-size: 1.32rem;
  font-weight: 700;
  line-height: 1;
}
.brand-sub { display: block; color: var(--muted); font-size: .78rem; margin-top: .18rem; }
.nav { display: flex; gap: .2rem; padding: .28rem; border: 1px solid var(--ring); border-radius: 999px; background: rgba(255,255,255,.54); }
.nav a { text-decoration: none; min-height: 42px; display: grid; place-items: center; padding: 0 .9rem; border-radius: 999px; font-weight: 800; color: var(--sage-dark); }
.nav a:hover, .nav a:focus-visible { background: rgba(111,124,79,.14); outline: none; }
.header-cta { justify-self: end; text-decoration: none; min-height: 44px; display: inline-grid; place-items: center; padding: 0 1.05rem; border-radius: 999px; background: var(--tomato); color: #fffaf4; font-weight: 900; box-shadow: 0 12px 24px rgba(182,56,37,.25); }
.header-cta:hover, .header-cta:focus-visible { background: var(--tomato-dark); outline: 3px solid rgba(182,56,37,.28); }

.hero {
  position: relative;
  isolation: isolate;
  display: grid;
  grid-template-columns: minmax(0, .98fr) minmax(280px, .56fr) minmax(360px, 1.16fr);
  gap: clamp(1rem, 2vw, 1.7rem);
  align-items: stretch;
  padding: clamp(1.2rem, 3vw, 3rem) clamp(1rem, 4vw, 4rem) clamp(1.5rem, 4vw, 4.5rem);
  min-height: calc(100vh - 112px);
}
.hero::before {
  content: "";
  position: absolute;
  inset: 4% 2.5% 8%;
  z-index: -2;
  border: 1px solid rgba(36, 21, 15, .10);
  border-radius: 42px;
  background: linear-gradient(130deg, rgba(255,250,240,.88), rgba(255,250,240,.35));
}
.hero-copy {
  align-self: center;
  padding: clamp(1.2rem, 3vw, 2.4rem);
  border-radius: var(--radius-xl);
  background: rgba(255, 250, 240, .74);
  box-shadow: var(--shadow);
  border: 1px solid rgba(36, 21, 15, .12);
  backdrop-filter: blur(10px);
}
.eyebrow, .section-kicker, .ticket-label, .stamp {
  text-transform: uppercase;
  letter-spacing: .16em;
  font-size: .72rem;
  font-weight: 1000;
  color: var(--tomato);
}
h1, h2, h3 { margin: 0; text-wrap: balance; }
h1 {
  font-family: "Libre Bodoni", Georgia, serif;
  font-size: clamp(3rem, 6.7vw, 6rem);
  line-height: .88;
  letter-spacing: -.035em;
  word-spacing: .045em;
  margin: .5rem 0 1rem;
  max-width: 11.2ch;
}
.hero-sub { font-size: clamp(1.02rem, 1.45vw, 1.28rem); line-height: 1.55; color: var(--muted); max-width: 42rem; margin: 0 0 1.4rem; }
.hero-actions, .map-actions { display: flex; flex-wrap: wrap; gap: .75rem; align-items: center; }
.btn {
  min-height: 46px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: .4rem;
  padding: .82rem 1.05rem;
  border-radius: 999px;
  text-decoration: none;
  font-weight: 950;
  border: 1px solid rgba(36,21,15,.14);
  transition: transform .18s ease, box-shadow .18s ease, background .18s ease;
}
.btn:hover, .btn:focus-visible { transform: translateY(-2px); outline: 3px solid rgba(111,124,79,.24); }
.btn.primary { background: var(--tomato); color: #fff; box-shadow: 0 16px 30px rgba(182,56,37,.24); border-color: transparent; }
.btn.secondary { background: var(--espresso); color: var(--paper); border-color: transparent; }
.btn.ghost { background: rgba(255,250,240,.68); color: var(--bottle); }

.tonight-card {
  align-self: end;
  padding: 1.25rem;
  border-radius: var(--radius-lg);
  background: var(--paper);
  box-shadow: var(--shadow);
  border: 1px solid var(--ring);
  transform: rotate(-1deg);
  min-width: 0;
}
.tonight-card h2 { font-size: clamp(1.35rem, 2vw, 1.8rem); font-family: "Libre Bodoni", serif; margin: .35rem 0 .8rem; }
dl { margin: 0; display: grid; gap: .45rem; }
dl div { display: grid; grid-template-columns: 1fr auto; gap: .8rem; border-bottom: 1px dashed rgba(36,21,15,.22); padding-bottom: .38rem; }
dt { color: var(--muted); font-weight: 900; }
dd { margin: 0; font-weight: 950; text-align: right; }
.micro-note { margin: 1rem 0 0; padding: .8rem; border-radius: 16px; background: rgba(111,124,79,.12); color: var(--sage-dark); font-weight: 850; }
.hero-art { position: relative; margin: 0; min-height: 560px; border-radius: 42px; overflow: hidden; box-shadow: 0 24px 70px rgba(36,21,15,.24); border: 1px solid var(--ring); }
.hero-art picture { display: block; height: 100%; }
.hero-art img { width: 100%; height: 100%; object-fit: cover; object-position: 60% center; }
.hero-art::after { content: ""; position: absolute; inset: 0; background: radial-gradient(circle at 18% 35%, rgba(255,250,240,.32), transparent 38%), linear-gradient(90deg, rgba(36,21,15,.05), rgba(36,21,15,.08)); pointer-events: none; }

.reveal { animation: lift .7s cubic-bezier(.2,.7,.2,1) both; }
.delay-1 { animation-delay: .12s; }
.delay-2 { animation-delay: .22s; }
@keyframes lift { from { opacity: 0; transform: translateY(16px); } to { opacity: 1; transform: translateY(0); } }

.visit-strip {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: .9rem;
  margin: -2rem clamp(1rem, 4vw, 4rem) 2rem;
  position: relative;
  z-index: 3;
}
.visit-strip > div {
  min-height: 128px;
  border-radius: var(--radius-lg);
  background: rgba(255,250,240,.92);
  border: 1px solid var(--ring);
  box-shadow: 0 12px 38px rgba(36,21,15,.1);
  padding: 1.1rem;
}
.visit-strip strong { display: block; margin: .5rem 0 .15rem; font-size: 1.12rem; }
.visit-strip small { color: var(--muted); font-weight: 800; }

.section { padding: clamp(3.2rem, 6vw, 6rem) clamp(1rem, 4vw, 4rem); }
.section-heading-row { display: grid; grid-template-columns: 1fr auto; gap: 1.2rem; align-items: end; margin-bottom: 1.3rem; }
.section h2 { font-family: "Libre Bodoni", serif; font-size: clamp(2.25rem, 5vw, 4.8rem); line-height: .9; letter-spacing: -.028em; word-spacing: .035em; max-width: 12ch; }
.section p { color: var(--muted); font-size: 1.05rem; line-height: 1.65; max-width: 66ch; }
.menu-section { background: linear-gradient(180deg, rgba(31,75,59,.08), rgba(255,250,240,.1)); border-top: 1px solid rgba(36,21,15,.08); border-bottom: 1px solid rgba(36,21,15,.08); }
.menu-grid { display: grid; grid-template-columns: 1.25fr repeat(3, .75fr); gap: 1rem; align-items: stretch; }
.dish-card {
  position: relative;
  min-height: 270px;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  padding: 1.1rem;
  border-radius: var(--radius-lg);
  background: var(--paper);
  border: 1px solid var(--ring);
  box-shadow: 0 10px 34px rgba(36,21,15,.12);
  overflow: hidden;
}
.dish-card::before { content: ""; position: absolute; inset: 10px; border: 1px dashed rgba(36,21,15,.16); border-radius: 18px; pointer-events: none; }
.dish-card:not(.feature-dish)::after { content: ""; position: absolute; width: 150px; height: 150px; right: -44px; top: -42px; border-radius: 50%; background: radial-gradient(circle, rgba(182,56,37,.16), rgba(182,56,37,.08) 44%, transparent 45%), linear-gradient(135deg, rgba(111,124,79,.13), transparent); border: 1px solid rgba(182,106,58,.16); pointer-events: none; }
.dish-card:hover { transform: translateY(-3px) rotate(.2deg); transition: transform .18s ease; }
.dish-card h3 { font-family: "Libre Bodoni", serif; font-size: clamp(1.55rem, 2.4vw, 2.25rem); line-height: .96; margin: .5rem 0; }
.dish-card p { font-size: .98rem; margin: 0 0 .8rem; }
.dish-card strong { font-size: 1.05rem; color: var(--tomato-dark); }
.feature-dish { min-height: 440px; padding: 0; }
.feature-dish img { height: 56%; width: 100%; object-fit: cover; object-position: center; }
.feature-dish > div { padding: 1.2rem; }

.story-panel { display: grid; grid-template-columns: minmax(0, 1.1fr) minmax(310px, .9fr); gap: clamp(1.2rem, 3vw, 2.4rem); align-items: stretch; }
.story-copy, .map-card, .agent-preview {
  border-radius: var(--radius-xl);
  background: rgba(255,250,240,.82);
  border: 1px solid var(--ring);
  box-shadow: var(--shadow);
  padding: clamp(1.3rem, 3vw, 2.4rem);
}
.proof-list { list-style: none; margin: 1.3rem 0 0; padding: 0; display: grid; gap: .8rem; }
.proof-list li { display: grid; grid-template-columns: minmax(130px, .35fr) 1fr; gap: 1rem; padding: 1rem; border-radius: 18px; background: rgba(111,124,79,.10); border: 1px solid rgba(111,124,79,.14); }
.proof-list strong { color: var(--sage-dark); }
.proof-list span { color: var(--muted); line-height: 1.5; }
.map-card { background: var(--espresso); color: var(--paper); display: flex; flex-direction: column; justify-content: flex-end; position: relative; overflow: hidden; }
.map-card::before { content: ""; position: absolute; inset: -20%; background: radial-gradient(circle at 35% 20%, rgba(182,106,58,.36), transparent 30%), url("./assets/pasta-prep-texture.jpg") center/420px; opacity: .32; }
.map-card > * { position: relative; }
.map-card h3 { font-family: "Libre Bodoni", serif; font-size: clamp(2.1rem, 4vw, 4rem); line-height: .9; letter-spacing: -.04em; }
.map-card p { color: #ead7bf; }
.map-card .btn.ghost { background: rgba(255,250,240,.12); color: var(--paper); border-color: rgba(255,250,240,.28); }

.events-section { display: grid; grid-template-columns: minmax(280px, .75fr) minmax(0, 1.25fr); gap: clamp(1.2rem, 3vw, 2.3rem); align-items: center; background: var(--bottle); color: var(--paper); }
.events-section .section-kicker { color: #f6c49e; }
.events-section p { color: #e6d4c0; }
.events-art img { border-radius: 38px; box-shadow: 0 22px 70px rgba(0,0,0,.28); border: 1px solid rgba(255,250,240,.18); transform: rotate(-2deg); }
.package-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: .85rem; margin: 1.4rem 0; }
.package-grid article { padding: 1rem; min-height: 142px; display: flex; flex-direction: column; justify-content: space-between; border-radius: 20px; background: rgba(255,250,240,.10); border: 1px solid rgba(255,250,240,.18); }
.package-grid span { text-transform: uppercase; letter-spacing: .15em; font-size: .72rem; font-weight: 1000; color: #f6c49e; }
.package-grid strong { font-size: 1.3rem; }
.package-grid small { color: #e6d4c0; }

.agent-preview { max-width: none; margin: 0 clamp(1rem, 4vw, 4rem) clamp(2rem, 5vw, 4rem); }
.agent-preview h2 { max-width: 14ch; }
.command-chips { display: flex; flex-wrap: wrap; gap: .75rem; margin-top: 1.3rem; }
.command-chips span { padding: .8rem 1rem; border-radius: 999px; background: rgba(182,56,37,.10); border: 1px solid rgba(182,56,37,.16); color: var(--tomato-dark); font-weight: 900; }

.footer { display: grid; grid-template-columns: 1fr auto; gap: 1.5rem; align-items: center; padding: 2rem clamp(1rem, 4vw, 4rem) 5.8rem; background: var(--espresso); color: var(--paper); }
.footer p { color: #d7c6ad; margin: .35rem 0 0; max-width: 56ch; }
.footer div:last-child { display: flex; flex-wrap: wrap; justify-content: end; gap: .7rem; }
.footer a { color: var(--paper); text-decoration-color: rgba(255,250,240,.45); text-underline-offset: .2em; }

.mobile-ticket { display: none; }

:focus-visible { outline: 3px solid rgba(182,56,37,.45); outline-offset: 3px; }

@media (max-width: 1180px) {
  .hero { grid-template-columns: 1fr 1fr; min-height: auto; }
  .hero-copy { grid-column: 1 / 2; }
  .tonight-card { grid-column: 1 / 2; align-self: start; }
  .hero-art { grid-column: 2; grid-row: 1 / span 2; min-height: 660px; }
  .visit-strip { grid-template-columns: repeat(2, 1fr); margin-top: 0; }
  .menu-grid { grid-template-columns: repeat(2, 1fr); }
}

@media (max-width: 820px) {
  .preview-ribbon { font-size: .76rem; }
  .site-header { grid-template-columns: 1fr auto; gap: .6rem; }
  .nav { display: none; }
  .header-cta { min-height: 42px; padding: 0 .8rem; font-size: .9rem; }
  .brand-mark { width: 42px; height: 42px; }
  .brand-sub { display: none; }
  .hero { display: flex; flex-direction: column; padding: 1rem 1rem 1.3rem; gap: .85rem; }
  .hero::before { inset: .5rem; border-radius: 28px; }
  .hero-copy { padding: 1.08rem; border-radius: 26px; order: 1; }
  h1 { font-size: clamp(3.05rem, 15vw, 4.6rem); max-width: 8.6ch; letter-spacing: -.032em; }
  .hero-sub { font-size: .98rem; line-height: 1.45; }
  .hero-actions .btn { flex: 1 1 100%; }
  .tonight-card { order: 2; transform: none; padding: 1rem; }
  .tonight-card h2 { font-size: 1.45rem; }
  dl div { grid-template-columns: .8fr 1fr; }
  dd { font-size: .92rem; }
  .hero-art { order: 3; min-height: 330px; border-radius: 28px; }
  .hero-art img { object-position: 62% center; }
  .visit-strip { grid-template-columns: 1fr; margin: 0 1rem 1rem; gap: .65rem; }
  .visit-strip > div { min-height: auto; padding: .95rem; }
  .section { padding: 3.5rem 1rem; }
  .section-heading-row { grid-template-columns: 1fr; align-items: start; }
  .section h2 { font-size: clamp(2.55rem, 12vw, 4rem); max-width: 10.8ch; }
  .menu-grid { grid-template-columns: 1fr; }
  .dish-card, .feature-dish { min-height: 250px; }
  .feature-dish img { height: 230px; }
  .story-panel, .events-section { grid-template-columns: 1fr; }
  .proof-list li { grid-template-columns: 1fr; gap: .35rem; }
  .events-section { padding-bottom: 4.4rem; }
  .package-grid { grid-template-columns: 1fr; }
  .agent-preview { margin: 0 1rem 1rem; padding: 1.2rem; }
  .footer { grid-template-columns: 1fr; padding-bottom: 6.2rem; }
  .footer div:last-child { justify-content: start; }
  .mobile-ticket {
    position: fixed;
    z-index: 30;
    left: .7rem;
    right: .7rem;
    bottom: .7rem;
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: .35rem;
    padding: .35rem;
    background: rgba(36,21,15,.92);
    border: 1px solid rgba(255,250,240,.2);
    box-shadow: 0 14px 50px rgba(0,0,0,.32);
    border-radius: 999px;
    backdrop-filter: blur(14px);
  }
  .mobile-ticket a {
    min-height: 46px;
    display: grid;
    place-items: center;
    border-radius: 999px;
    color: var(--paper);
    text-decoration: none;
    font-size: .86rem;
    font-weight: 1000;
  }
  .mobile-ticket a:first-child { background: var(--tomato); }
}

@media (max-width: 420px) {
  .site-header { padding: .75rem; }
  .brand-name { font-size: 1.08rem; }
  .header-cta { font-size: .8rem; }
  .hero { padding-left: .75rem; padding-right: .75rem; }
  h1 { font-size: clamp(2.75rem, 15.5vw, 3.8rem); }
  .hero-sub { font-size: .94rem; }
  .btn { width: 100%; }
  .mobile-ticket { left: .45rem; right: .45rem; }
  .mobile-ticket a { font-size: .78rem; }
}

.config-body {
  min-height: 100vh;
  background:
    linear-gradient(rgba(31,75,59,.88), rgba(36,21,15,.9)),
    url("./assets/pasta-prep-texture.jpg") center / 560px repeat;
  color: var(--paper);
}
.config-shell { padding: clamp(1rem, 4vw, 4rem); display: grid; gap: 1rem; }
.config-hero, .agent-console, .state-grid article {
  border-radius: var(--radius-xl);
  border: 1px solid rgba(255,250,240,.18);
  background: rgba(255,250,240,.10);
  box-shadow: 0 18px 60px rgba(0,0,0,.24);
  backdrop-filter: blur(12px);
}
.config-hero { padding: clamp(1.2rem, 4vw, 3rem); }
.config-hero h1 { color: var(--paper); max-width: 9ch; }
.config-hero p { max-width: 70ch; color: #e9d8bf; font-size: 1.08rem; line-height: 1.65; }
.config-note { display: flex; flex-wrap: wrap; gap: .55rem; margin-top: 1.2rem; align-items: center; }
.config-note strong { margin-right: .4rem; }
.config-note button {
  min-height: 40px;
  border: 1px solid rgba(255,250,240,.22);
  background: rgba(255,250,240,.12);
  color: var(--paper);
  border-radius: 999px;
  padding: .55rem .8rem;
  font-weight: 900;
  cursor: pointer;
}
.config-note button:hover, .config-note button:focus-visible { background: rgba(255,250,240,.22); }
.agent-console { padding: clamp(1rem, 3vw, 2rem); }
.command-form label { display: block; font-weight: 1000; margin-bottom: .55rem; color: #f6c49e; text-transform: uppercase; letter-spacing: .13em; font-size: .76rem; }
.input-row { display: grid; grid-template-columns: 1fr auto; gap: .6rem; }
.input-row input {
  min-height: 52px;
  width: 100%;
  border: 1px solid rgba(255,250,240,.26);
  border-radius: 999px;
  padding: 0 1rem;
  background: rgba(255,250,240,.92);
  color: var(--espresso);
  font: inherit;
  font-weight: 800;
}
.preview-panel { margin-top: 1rem; padding: 1rem; border-radius: 22px; background: rgba(255,250,240,.12); border: 1px dashed rgba(255,250,240,.24); }
.preview-panel h2 { font-family: "Libre Bodoni", serif; font-size: clamp(1.4rem, 4vw, 2.4rem); margin: .4rem 0; }
.preview-panel p { color: #ead7bf; }
.diff-grid { display: grid; grid-template-columns: 1fr 1fr; gap: .7rem; margin: .9rem 0; }
.diff-grid div { border-radius: 16px; background: rgba(255,250,240,.12); padding: .9rem; }
.diff-grid strong { color: #f6c49e; }
.apply-row { display: flex; gap: .65rem; flex-wrap: wrap; margin-top: .9rem; }
.apply-row .btn[disabled] { opacity: .5; cursor: not-allowed; transform: none; }
.state-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 1rem; }
.state-grid article { padding: 1rem; }
.state-grid h2 { color: var(--paper); font-family: "Libre Bodoni", serif; line-height: 1; }
.state-grid dl div { border-bottom-color: rgba(255,250,240,.22); }
.state-grid dt { color: #f6c49e; }
.state-grid dd { color: var(--paper); }
.state-list { display: grid; gap: .55rem; margin-top: .7rem; }
.state-list p { display: grid; gap: .2rem; margin: 0; padding: .72rem; border-radius: 14px; background: rgba(255,250,240,.10); color: #ead7bf; }
.state-list strong { color: var(--paper); }
.audit-card { grid-column: 1 / -1; }
.audit-card ol { margin: .8rem 0 0; padding-left: 1.2rem; display: grid; gap: .55rem; }
.audit-card li { color: #ead7bf; }
.audit-card li strong, .audit-card li span, .audit-card li em { display: block; }
.audit-card li strong { color: #f6c49e; }
.audit-card li em { font-style: normal; opacity: .82; }

@media (max-width: 760px) {
  .config-shell { padding: 1rem; }
  .input-row, .diff-grid, .state-grid { grid-template-columns: 1fr; }
  .config-hero h1 { font-size: clamp(2.8rem, 16vw, 4.2rem); }
}

@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  *, *::before, *::after { animation-duration: .01ms !important; animation-iteration-count: 1 !important; transition-duration: .01ms !important; }
}
