:root {
  --bg: #060608;
  --ink: #f4f4f3;
  --muted: rgba(244, 244, 243, 0.56);
  --faint: rgba(244, 244, 243, 0.34);
  --line: rgba(244, 244, 243, 0.12);
  --line-2: rgba(244, 244, 243, 0.06);
  --accent: #b14bf5;
  --accent-2: #e0654a;
  --warn: #f0a868;
  --maxw: 1240px;
  --ease: cubic-bezier(0.16, 1, 0.3, 1);
  /* Google Sans for titles (Medium) + descriptions (Light), Inter as fallback */
  --font: "Google Sans", "Google Sans Text", "Inter", system-ui, -apple-system, sans-serif;
  --serif: "Google Sans", "Google Sans Text", "Inter", system-ui, sans-serif;
}

* { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; }
@media (prefers-reduced-motion: reduce) { html { scroll-behavior: auto; } }

body {
  font-family: var(--font);
  font-weight: 300;
  background: var(--bg);
  color: var(--ink);
  line-height: 1.55;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  overflow-x: hidden;
}
a { color: inherit; text-decoration: none; }
.visually-hidden { position: absolute; width: 1px; height: 1px; overflow: hidden; clip: rect(0 0 0 0); }
.skip { position: absolute; left: -999px; }
.skip:focus { left: 16px; top: 16px; background: #fff; color: #000; padding: 8px 12px; z-index: 100; border-radius: 6px; }

/* Scroll progress */
.progress {
  position: fixed; top: 0; left: 0; right: 0; height: 2px; z-index: 60;
  background: var(--accent); transform: scaleX(0); transform-origin: 0 50%;
}

/* ---------- Buttons / links ---------- */
.btn {
  display: inline-flex; align-items: center; justify-content: center;
  padding: 11px 20px; border-radius: 999px;
  background: var(--ink); color: #0a0a0c;
  font-weight: 600; font-size: 0.95rem; letter-spacing: -0.01em;
  border: 1px solid var(--ink);
  transition: transform 0.4s var(--ease), background 0.3s, color 0.3s, border-color 0.3s;
}
.btn:hover { transform: translateY(-2px); background: var(--accent); border-color: var(--accent); color: #0a0a0c; }
.btn--lg { padding: 15px 28px; font-size: 1.05rem; }
.btn--block { display: flex; width: 100%; }
.btn--invert { background: transparent; color: var(--ink); border-color: var(--line); }
.btn--invert:hover { background: var(--ink); color: #0a0a0c; border-color: var(--ink); }
/* Magnetic: cursor-tracked translate replaces the lift */
.btn[data-magnetic] { transform: translate(var(--tx, 0), var(--ty, 0)); transition: transform 0.35s var(--ease), background 0.3s, color 0.3s, border-color 0.3s; }
.btn[data-magnetic]:hover { transform: translate(var(--tx, 0), var(--ty, 0)); }
.link-ghost { font-size: 0.95rem; color: var(--muted); transition: color 0.3s; }
.link-ghost:hover { color: var(--ink); }
.link-arrow { font-size: 1.02rem; color: var(--ink); position: relative; }
.link-arrow::after { content: " →"; transition: padding 0.4s var(--ease); }
.link-arrow:hover::after { padding-left: 8px; }

/* Eyebrow / kicker (used once or twice, deliberate — not on every section) */
.kicker {
  display: inline-flex; align-items: center; gap: 8px; font-size: 0.8rem; font-weight: 600; letter-spacing: 0.01em;
  color: var(--accent); margin-bottom: 18px;
}
.kicker--warn { color: var(--warn); }
.kicker--warn::before { content: ""; width: 7px; height: 7px; border-radius: 50%; background: var(--warn); box-shadow: 0 0 10px var(--warn); animation: warn-pulse 1.6s var(--ease) infinite; }
@keyframes warn-pulse { 0%, 100% { opacity: 0.5; transform: scale(0.85); } 50% { opacity: 1; transform: scale(1.1); } }
@media (prefers-reduced-motion: reduce) { .kicker--warn::before { animation: none; } }

/* ---------- Nav ---------- */
.nav {
  position: fixed; inset: 0 0 auto 0; z-index: 50;
  display: grid; grid-template-columns: 1fr auto 1fr; align-items: center; gap: 16px;
  padding: 16px clamp(20px, 4vw, 48px);
  transition: background 0.4s, backdrop-filter 0.4s, border-color 0.4s, padding 0.4s;
  border-bottom: 1px solid transparent;
}
.nav--solid { background: rgba(6, 6, 8, 0.72); backdrop-filter: saturate(1.4) blur(14px); border-bottom-color: var(--line-2); padding-top: 12px; padding-bottom: 12px; }
.nav__brand { justify-self: start; display: inline-flex; align-items: center; gap: 10px; font-weight: 700; font-size: 1.1rem; letter-spacing: -0.02em; }
.nav__logo { width: 30px; height: 30px; object-fit: contain; filter: drop-shadow(0 0 14px rgba(177, 75, 245, 0.5)); }
.nav__links { justify-self: center; display: flex; gap: 30px; }
.nav__links a { font-size: 0.92rem; color: var(--muted); transition: color 0.3s; }
.nav__links a:hover { color: var(--ink); }
.nav__cta { justify-self: end; display: flex; align-items: center; gap: 16px; }
@media (max-width: 820px) { .nav { grid-template-columns: 1fr auto; } .nav__links { display: none; } }

/* ---------- Hero ---------- */
.hero {
  position: relative;
  min-height: 100vh;
  display: grid; grid-template-columns: 1.05fr 0.95fr; align-items: center; gap: 48px;
  max-width: var(--maxw); margin: 0 auto;
  padding: 150px clamp(20px, 4vw, 48px) 90px;
  --mx: 70%; --my: 18%;
}
.hero__bg { position: absolute; inset: -10% -20% 0; z-index: 0; pointer-events: none; overflow: hidden; }
.hero__grid {
  position: absolute; inset: 0;
  background-image: linear-gradient(var(--line-2) 1px, transparent 1px), linear-gradient(90deg, var(--line-2) 1px, transparent 1px);
  background-size: 58px 58px;
  mask-image: radial-gradient(120% 80% at 60% 0%, #000 30%, transparent 75%);
  animation: grid-drift 24s linear infinite;
}
@keyframes grid-drift { to { background-position: 58px 58px; } }
.hero__aurora { position: absolute; border-radius: 50%; filter: blur(70px); opacity: 0.5; }
.hero__aurora--a { width: 44vw; height: 44vw; left: 40%; top: -8%; background: radial-gradient(circle, rgba(177, 75, 245, 0.55), transparent 65%); animation: aurora-a 26s var(--ease) infinite; }
.hero__aurora--b { width: 34vw; height: 34vw; left: 4%; top: 30%; background: radial-gradient(circle, rgba(184, 72, 47, 0.32), transparent 65%); animation: aurora-b 30s var(--ease) infinite; }
@keyframes aurora-a { 0%, 100% { transform: translate(0, 0) scale(1); } 50% { transform: translate(-5rem, 3rem) scale(1.15); } }
@keyframes aurora-b { 0%, 100% { transform: translate(0, 0) scale(1); } 50% { transform: translate(5rem, -2rem) scale(1.2); } }
.hero__spot { position: absolute; inset: 0; background: radial-gradient(420px circle at var(--mx) var(--my), rgba(177, 75, 245, 0.14), transparent 60%); transition: background 0.2s; }
.hero__copy, .hero__stage { position: relative; z-index: 1; }
.hero__eyebrow { font-size: 0.82rem; font-weight: 600; letter-spacing: 0.01em; color: var(--accent); margin-bottom: 22px; }
.hero__title {
  font-family: var(--serif); font-weight: 500; font-size: clamp(2.4rem, 5.6vw, 5.4rem);
  line-height: 1.0; letter-spacing: -0.022em; text-wrap: balance;
}
.cycler { display: inline-block; color: var(--accent); min-width: 4ch; }
.hero__sub { margin-top: 26px; max-width: 31rem; font-size: 1.04rem; color: var(--muted); }
.hero__actions { margin-top: 36px; display: flex; align-items: center; gap: 26px; flex-wrap: wrap; }
.hero__note { margin-top: 22px; font-size: 0.88rem; color: var(--faint); }

/* Hero product stage */
.hero__stage { height: 540px; }
.phone {
  position: absolute; right: 4%; top: 50%; margin-top: -270px;
  width: 264px; height: 540px; border-radius: 38px; rotate: 2deg;
  background: #101014; border: 1px solid rgba(255, 255, 255, 0.1);
  box-shadow: 0 50px 120px -30px rgba(0, 0, 0, 0.9), 0 0 0 7px #08080a;
  padding: 14px; overflow: hidden;
  animation: float-a 7s ease-in-out infinite;
}
.phone__notch { position: absolute; top: 12px; left: 50%; transform: translateX(-50%); width: 90px; height: 22px; background: #08080a; border-radius: 0 0 14px 14px; z-index: 2; }
.phone__screen { height: 100%; border-radius: 26px; background: #fbf8f3; color: #1a1714; padding: 26px 14px 14px; overflow: hidden; }
.m-top { font-weight: 700; font-size: 1.02rem; color: var(--accent-2); text-align: center; margin-bottom: 10px; }
.m-feature { position: relative; height: 96px; border-radius: 14px; overflow: hidden; margin-bottom: 12px; background: url("img/food-pizza.jpg") center / cover; }
.m-feature::after { content: ""; position: absolute; inset: 0; background: linear-gradient(180deg, transparent 40%, rgba(0, 0, 0, 0.55)); }
.m-feature__tag { position: absolute; top: 8px; left: 8px; z-index: 1; background: rgba(255, 255, 255, 0.92); color: #16130f; font-size: 0.58rem; font-weight: 700; letter-spacing: 0.02em; padding: 3px 8px; border-radius: 999px; }
.m-feature__cap { position: absolute; left: 10px; right: 10px; bottom: 8px; z-index: 1; display: flex; justify-content: space-between; align-items: baseline; color: #fff; }
.m-feature__cap b { font-weight: 600; font-size: 0.82rem; }
.m-feature__cap i { font-style: normal; font-weight: 700; font-size: 0.82rem; }
.m-cat { margin: 4px 0 4px; font-weight: 600; font-size: 0.66rem; text-transform: uppercase; letter-spacing: 0.1em; color: var(--accent-2); }
.m-row { display: flex; align-items: center; gap: 10px; padding: 7px 0; border-bottom: 1px solid rgba(0, 0, 0, 0.07); }
.m-thumb { flex: none; width: 40px; height: 40px; border-radius: 9px; background-size: cover; background-position: center; }
.m-thumb--1 { background-image: url("img/food-1.jpg"); }
.m-thumb--2 { background-image: url("img/food-2.jpg"); }
.m-thumb--3 { background-image: url("img/food-3.jpg"); }
.m-name { flex: 1; font-size: 0.8rem; line-height: 1.2; }
.m-row b { font-weight: 700; font-size: 0.82rem; }
.m-order { position: absolute; left: 14px; right: 14px; bottom: 14px; text-align: center; background: var(--accent-2); color: #fff; font-weight: 600; font-size: 0.82rem; padding: 11px; border-radius: 999px; }
.ticket {
  position: absolute; left: 0; top: 16%; width: 230px;
  background: #fff; color: #16130f; border-radius: 16px; padding: 14px 16px;
  box-shadow: 0 30px 60px -22px rgba(0, 0, 0, 0.7); rotate: -3deg;
  animation: float-b 5.5s ease-in-out infinite;
}
.ticket__top { display: flex; justify-content: space-between; font-weight: 600; font-size: 0.82rem; margin-bottom: 8px; }
.ticket__paid { color: #16a34a; }
.ticket__line { font-size: 0.82rem; color: #4b4540; }
.ticket__btn { margin-top: 12px; text-align: center; background: var(--accent); color: #fff; font-weight: 600; font-size: 0.78rem; padding: 8px; border-radius: 8px; }
/* Scannable QR card */
.qr-card {
  position: absolute; left: 2%; bottom: 4%; z-index: 3;
  display: grid; gap: 7px; justify-items: center;
  background: #fbf8f3; color: #16130f; border-radius: 16px; padding: 13px;
  box-shadow: 0 30px 60px -22px rgba(0, 0, 0, 0.7); rotate: -2deg;
  animation: float-c 6.5s ease-in-out infinite;
}
.qr-card__code { width: 84px; height: 84px; display: grid; place-items: center; background: #fff; }
.qr-card__code img { width: 100%; height: 100%; display: block; image-rendering: pixelated; }
.qr-card__tag { font-size: 0.74rem; font-weight: 600; letter-spacing: 0.01em; color: #16130f; }
@keyframes float-a { 0%, 100% { translate: 0 0; } 50% { translate: 0 -16px; } }
@keyframes float-b { 0%, 100% { translate: 0 0; } 50% { translate: 0 -12px; } }
@keyframes float-c { 0%, 100% { translate: 0 0; } 50% { translate: 0 -9px; } }
@media (prefers-reduced-motion: reduce) { .phone, .ticket, .qr-card, .hero__grid, .hero__aurora { animation: none; } }

@media (max-width: 920px) {
  .hero { grid-template-columns: 1fr; gap: 12px; padding-top: 128px; min-height: auto; }
  .hero__stage { height: 470px; order: 2; margin-top: 20px; }
  .phone { right: 50%; margin-right: -132px; animation: none; }
  .ticket { left: 4%; }
}

/* ---------- Connected hub (logo + ops wired by strings) ---------- */
.hub {
  position: relative; z-index: 1; max-width: var(--maxw); margin: 0 auto;
  padding: clamp(60px, 9vh, 110px) clamp(20px, 4vw, 48px);
  display: grid; grid-template-columns: 0.85fr 1.15fr; align-items: center; gap: 40px;
  border-top: 1px solid var(--line);
}
.hub__h { font-family: var(--serif); font-weight: 500; font-size: clamp(1.8rem, 3.2vw, 2.9rem); line-height: 1.04; letter-spacing: -0.018em; text-wrap: balance; }
.hub__p { margin-top: 18px; max-width: 34ch; color: var(--muted); font-size: 1.05rem; }
.hub__stage { position: relative; }
.hub__svg { width: 100%; height: auto; overflow: visible; }
.hub__lines line { stroke-dasharray: 2 8; animation: hub-flow 1.5s linear infinite; }
@keyframes hub-flow { to { stroke-dashoffset: -10; } }
.hub__node circle { fill: var(--accent); filter: drop-shadow(0 0 6px rgba(177, 75, 245, 0.8)); animation: hub-pulse 2.8s var(--ease) infinite; }
.hub__node:nth-child(2n) circle { animation-delay: 0.6s; }
.hub__node:nth-child(3n) circle { animation-delay: 1.2s; }
@keyframes hub-pulse { 0%, 100% { r: 4; opacity: 0.65; } 50% { r: 6; opacity: 1; } }
.hub__node text { fill: var(--ink); font-weight: 500; }
.hub__core { position: absolute; left: 50%; top: 50%; width: 118px; height: 118px; transform: translate(-50%, -50%); display: grid; place-items: center; }
.hub__core img { width: 96px; height: 96px; object-fit: cover; border-radius: 50%; background: #fff; padding: 14px; box-shadow: 0 0 36px rgba(177, 75, 245, 0.45), 0 18px 40px -16px rgba(0, 0, 0, 0.8); position: relative; z-index: 1; }
.hub__ring { position: absolute; inset: 0; border-radius: 50%; border: 1.5px dashed rgba(177, 75, 245, 0.45); animation: hub-spin 18s linear infinite; }
.hub__core::before { content: ""; position: absolute; inset: -14px; border-radius: 50%; background: radial-gradient(circle, rgba(177, 75, 245, 0.22), transparent 70%); }
@keyframes hub-spin { to { transform: rotate(360deg); } }
@media (max-width: 860px) { .hub { grid-template-columns: 1fr; gap: 24px; } }
@media (prefers-reduced-motion: reduce) { .hub__lines line { animation: none; stroke-dasharray: none; } .hub__node circle { animation: none; } .hub__ring { animation: none; } }

/* ---------- Sections ---------- */
.section { position: relative; z-index: 1; max-width: var(--maxw); margin: 0 auto; padding: clamp(80px, 13vh, 168px) clamp(20px, 4vw, 48px); }
.section__h { font-family: var(--serif); font-weight: 500; font-size: clamp(2rem, 4.8vw, 3.9rem); line-height: 1.03; letter-spacing: -0.018em; text-wrap: balance; }
.section__lead { margin-top: 22px; max-width: 38rem; font-size: 1.1rem; color: var(--muted); line-height: 1.6; }

/* Problem — heading, then a timed incident log (left) + real photo (right) */
.problem__head { max-width: 44rem; margin-bottom: clamp(40px, 6vw, 60px); }
.problem__body { display: grid; grid-template-columns: 1.5fr 0.82fr; gap: clamp(28px, 4vw, 56px); align-items: start; }
.problem__photo { position: sticky; top: 92px; border-radius: 18px; overflow: hidden; border: 1px solid var(--line); box-shadow: 0 50px 90px -40px rgba(0, 0, 0, 0.9); }
.problem__photo img { display: block; width: 100%; height: auto; aspect-ratio: 5 / 6; object-fit: cover; filter: saturate(0.92) contrast(1.02); }
.problem__photo::after { content: ""; position: absolute; inset: 0; background: linear-gradient(180deg, transparent 45%, rgba(6, 6, 8, 0.72)); }
.problem__cap { position: absolute; left: 14px; bottom: 14px; z-index: 1; display: inline-flex; align-items: center; gap: 9px; font-size: 0.82rem; font-weight: 500; color: var(--ink); background: rgba(6, 6, 8, 0.55); border: 1px solid var(--line); backdrop-filter: blur(8px); padding: 8px 13px; border-radius: 999px; }
.problem__live { width: 8px; height: 8px; border-radius: 50%; background: var(--accent-2); box-shadow: 0 0 10px var(--accent-2); animation: warn-pulse 1.5s var(--ease) infinite; }
@media (max-width: 860px) { .problem__body { grid-template-columns: 1fr; } .problem__photo { position: static; order: -1; max-width: 480px; } }
@media (prefers-reduced-motion: reduce) { .problem__live { animation: none; } }

.log { list-style: none; border-top: 1px solid var(--line); }
.log__head { display: grid; grid-template-columns: 92px 1fr; padding: 14px 0; font-size: 0.74rem; text-transform: uppercase; letter-spacing: 0.1em; color: var(--faint); border-bottom: 1px solid var(--line); }
.log li:not(.log__head) {
  display: grid; grid-template-columns: 92px 1fr; gap: 8px 24px; align-items: baseline;
  padding: 26px 0; border-bottom: 1px solid var(--line); transition: background 0.4s, padding-left 0.4s var(--ease);
}
.log li:not(.log__head):hover { background: rgba(255, 255, 255, 0.018); padding-left: 12px; }
.log time { font-family: ui-monospace, "SF Mono", Menlo, monospace; font-size: 0.92rem; color: var(--accent-2); font-variant-numeric: tabular-nums; }
.log b { display: block; color: var(--ink); font-weight: 500; font-size: clamp(1.1rem, 1.7vw, 1.35rem); line-height: 1.25; letter-spacing: -0.01em; }
.log span { display: block; margin-top: 6px; color: var(--muted); font-size: 1rem; max-width: 62ch; }
@media (max-width: 600px) { .log__head, .log li:not(.log__head) { grid-template-columns: 64px 1fr; gap: 6px 14px; } }

/* Statement — menu UI (left) + connected thread down the night (right) */
.oneline__head { max-width: 44rem; margin-bottom: clamp(40px, 6vw, 60px); }
.oneline__split { display: grid; grid-template-columns: 1fr 0.92fr; gap: clamp(32px, 5vw, 72px); align-items: center; }
@media (max-width: 920px) { .oneline__split { grid-template-columns: 1fr; gap: 48px; } }

/* Branded menu UI mock (matches the diner app) */
.menu-demo { border-radius: 20px; overflow: hidden; background: #fbf3ea; color: #2a211b; border: 1px solid rgba(0, 0, 0, 0.06); box-shadow: 0 50px 100px -40px rgba(0, 0, 0, 0.85); }
.menu-demo__bar { display: flex; align-items: center; gap: 10px; padding: 14px 16px; background: #fff; border-bottom: 1px solid #efe2d4; }
.menu-demo__brand { display: inline-flex; align-items: center; gap: 8px; font-weight: 700; font-size: 0.92rem; color: var(--accent-2); white-space: nowrap; }
.menu-demo__logo { display: grid; place-items: center; width: 24px; height: 24px; border-radius: 7px; background: var(--accent-2); color: #fff; font-size: 0.8rem; }
.menu-demo__search { flex: 1; font-size: 0.82rem; color: #a08e7e; background: #f6ece1; border: 1px solid #efe2d4; border-radius: 999px; padding: 7px 14px; }
.menu-demo__filter { font-size: 0.8rem; font-weight: 600; color: #fff; background: var(--accent-2); border-radius: 999px; padding: 7px 14px; }
.menu-demo__cats { display: flex; gap: 8px; padding: 14px 16px 2px; overflow: hidden; }
.menu-pill { font-size: 0.78rem; font-weight: 500; color: #6b5a4c; background: #fff; border: 1px solid #efe2d4; border-radius: 999px; padding: 6px 13px; white-space: nowrap; }
.menu-pill--on { color: #fff; background: var(--accent-2); border-color: var(--accent-2); }
.menu-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; padding: 14px 16px; }
.dish { background: #fff; border: 1px solid #efe2d4; border-radius: 14px; padding: 10px; display: flex; flex-direction: column; }
.dish__img { display: block; height: 96px; border-radius: 10px; background-size: cover; background-position: center; margin-bottom: 10px; }
.dish__img--pizza { background-image: url("img/food-pizza.jpg"); }
.dish__img--f1 { background-image: url("img/food-1.jpg"); }
.dish__img--f2 { background-image: url("img/food-2.jpg"); }
.dish__img--f3 { background-image: url("img/food-3.jpg"); }
.dish__row { display: flex; justify-content: space-between; align-items: baseline; gap: 8px; }
.dish__name { font-weight: 600; font-size: 0.86rem; line-height: 1.2; }
.dish__price { font-weight: 700; font-size: 0.86rem; color: var(--accent-2); }
.dish__desc { margin: 4px 0 10px; font-size: 0.76rem; color: #8a7868; line-height: 1.35; }
.dish__foot { margin-top: auto; display: flex; align-items: center; justify-content: space-between; gap: 8px; }
.dish__sizes { display: inline-flex; gap: 5px; }
.dish__sizes i { font-style: normal; font-size: 0.7rem; font-weight: 600; color: #6b5a4c; background: #f6ece1; border-radius: 7px; padding: 4px 8px; }
.dish__sizes i.on { color: #fff; background: var(--accent-2); }
.dish__add { font-size: 0.74rem; font-weight: 700; color: #fff; background: var(--accent-2); border-radius: 8px; padding: 6px 11px; }
.menu-demo__order { display: flex; align-items: center; gap: 12px; padding: 14px 16px; background: #fff; border-top: 1px solid #efe2d4; font-size: 0.86rem; color: #6b5a4c; }
.menu-demo__order b { font-weight: 700; color: #2a211b; }
.menu-demo__place { margin-left: auto; font-weight: 700; color: #fff; background: var(--accent-2); border-radius: 999px; padding: 9px 18px; }
@media (max-width: 420px) { .menu-grid { grid-template-columns: 1fr; } }

.oneline__wrap { position: relative; padding-left: clamp(28px, 4vw, 44px); }
.oneline__rail { position: absolute; left: 6px; top: 8px; bottom: 8px; width: 2px; background: var(--line); border-radius: 2px; overflow: hidden; }
.oneline__fill { position: absolute; inset: 0; background: linear-gradient(180deg, var(--accent), var(--accent-2)); transform: scaleY(0); transform-origin: 50% 0; }
.oneline__items { list-style: none; display: grid; gap: clamp(28px, 4vw, 40px); }
.oneline__items li { position: relative; }
.oneline__items li::before { content: ""; position: absolute; left: calc(-1 * clamp(28px, 4vw, 44px) + 1px); top: 0.55em; width: 12px; height: 12px; border-radius: 50%; background: var(--bg); border: 2px solid var(--accent); transform: translateX(-5px); }
.oneline__sum::before { background: var(--accent-2); border-color: var(--accent-2); box-shadow: 0 0 14px var(--accent-2); }
.oneline__step { display: block; font-size: 0.76rem; font-weight: 600; letter-spacing: 0.08em; text-transform: uppercase; color: var(--accent); margin-bottom: 6px; }
.oneline__items h3 { font-family: var(--serif); font-weight: 500; font-size: clamp(1.7rem, 2.8vw, 2.5rem); line-height: 1.02; letter-spacing: -0.02em; }
.oneline__items p { margin-top: 8px; color: var(--muted); font-size: 1rem; max-width: 36ch; }
.oneline__sum h3 { color: var(--accent-2); }
.oneline__sum h3 { color: var(--accent-2); }
.oneline__sum .oneline__step { color: var(--accent-2); }

/* Features — bento (varied tiles, two live mini-visuals) */
.features__head { margin-bottom: 50px; }
.bento {
  display: grid; grid-template-columns: repeat(6, 1fr); gap: 14px;
}
.tile {
  grid-column: span 2;
  display: flex; flex-direction: column; justify-content: space-between; gap: 22px;
  border: 1px solid var(--line); border-radius: 18px; padding: 30px clamp(22px, 2.4vw, 34px);
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.02), transparent);
  transition: border-color 0.4s, transform 0.5s var(--ease), background 0.4s;
}
.tile:hover { border-color: rgba(177, 75, 245, 0.5); transform: translateY(-4px); }
.tile h3 { font-weight: 500; font-size: clamp(1.25rem, 1.9vw, 1.65rem); line-height: 1.16; letter-spacing: -0.02em; }
.tile p { margin-top: 12px; color: var(--muted); font-size: 1rem; max-width: 46ch; }
.tile__ic { display: inline-grid; place-items: center; width: 42px; height: 42px; border-radius: 12px; border: 1px solid var(--line); background: rgba(177, 75, 245, 0.08); margin-bottom: 18px; }
.tile__ic svg { width: 22px; height: 22px; fill: none; stroke: var(--accent); stroke-width: 1.7; stroke-linecap: round; stroke-linejoin: round; }
.tile:hover .tile__ic { border-color: rgba(177, 75, 245, 0.55); }
/* floor plan: tables, each with a QR dot; some live */
.floorplan { display: grid; grid-template-columns: repeat(3, 1fr); gap: 10px; }
.fp-table { aspect-ratio: 1.3; border: 1px solid var(--line); border-radius: 10px; display: grid; place-items: center; background: rgba(0, 0, 0, 0.2); }
.fp-table i { width: 15px; height: 15px; border-radius: 4px; background: var(--faint); box-shadow: inset 0 0 0 3px var(--bg), inset 0 0 0 4px var(--faint); }
.fp-table--on { border-color: rgba(177, 75, 245, 0.6); background: rgba(177, 75, 245, 0.1); }
.fp-table--on i { background: var(--accent); box-shadow: inset 0 0 0 3px var(--bg), inset 0 0 0 4px var(--accent), 0 0 10px rgba(177, 75, 245, 0.8); animation: fp-blink 2.2s var(--ease) infinite; }
.fp-table:nth-child(6).fp-table--on i { animation-delay: 0.8s; }
@keyframes fp-blink { 0%, 100% { opacity: 0.5; } 50% { opacity: 1; } }
@media (prefers-reduced-motion: reduce) { .fp-table--on i { animation: none; } }
.tile--menu { grid-column: span 4; grid-row: span 2; }
.tile--board { grid-column: span 2; grid-row: span 2; }
.tile--wide { grid-column: span 4; flex-direction: row; align-items: center; }
.tile--wide .tile__body { flex: 1; }
.tile--api { grid-column: span 2; }
@media (max-width: 980px) {
  .bento { grid-template-columns: repeat(2, 1fr); }
  .tile, .tile--menu, .tile--board, .tile--wide, .tile--api { grid-column: span 1; grid-row: auto; }
  .tile--wide { flex-direction: column; align-items: stretch; }
}
@media (max-width: 600px) { .bento { grid-template-columns: 1fr; } }

/* mini menu visual (price change) */
.mini-menu { border: 1px solid var(--line); border-radius: 14px; padding: 16px 18px; background: rgba(0, 0, 0, 0.25); display: grid; gap: 2px; }
.mini-menu__row { display: flex; justify-content: space-between; align-items: baseline; font-size: 0.92rem; color: var(--muted); padding: 8px 0; border-bottom: 1px solid var(--line-2); }
.mini-menu__row b { color: var(--ink); font-weight: 600; }
.mini-menu__row--edit { color: var(--ink); }
.mini-menu__price { position: relative; display: inline-grid; }
.mini-menu__price .old, .mini-menu__price .new { grid-area: 1 / 1; font-style: normal; text-align: right; }
.mini-menu__price .old { color: var(--faint); text-decoration: line-through; animation: price-old 4s var(--ease) infinite; }
.mini-menu__price .new { color: var(--accent); animation: price-new 4s var(--ease) infinite; }
@keyframes price-old { 0%, 35% { opacity: 1; } 50%, 100% { opacity: 0; } }
@keyframes price-new { 0%, 35% { opacity: 0; transform: translateY(4px); } 50%, 100% { opacity: 1; transform: none; } }
.mini-menu__live { margin-top: 8px; font-size: 0.78rem; color: #5fd28a; }
@media (prefers-reduced-motion: reduce) { .mini-menu__price .old { opacity: 0; } .mini-menu__price .new { opacity: 1; transform: none; } }

/* mini orders board */
.mini-board { display: grid; grid-template-columns: repeat(3, 1fr); gap: 8px; }
.mini-board__col { border: 1px solid var(--line); border-radius: 10px; padding: 10px 9px; display: grid; gap: 7px; align-content: start; background: rgba(0, 0, 0, 0.2); }
.mini-board__h { font-size: 0.66rem; text-transform: uppercase; letter-spacing: 0.08em; color: var(--faint); }
.chip { font-style: normal; font-size: 0.72rem; color: var(--ink); background: rgba(177, 75, 245, 0.12); border: 1px solid rgba(177, 75, 245, 0.3); border-radius: 7px; padding: 6px 7px; }
.chip--done { color: #5fd28a; background: rgba(95, 210, 138, 0.1); border-color: rgba(95, 210, 138, 0.3); }

/* import shot row */
.tile__shot { display: inline-flex; align-items: center; gap: 14px; flex-wrap: wrap; }
.shot-chip { font-style: normal; font-size: 0.82rem; color: var(--muted); border: 1px solid var(--line); border-radius: 9px; padding: 9px 13px; background: rgba(0, 0, 0, 0.25); }
.shot-chip--ok { color: #5fd28a; border-color: rgba(95, 210, 138, 0.35); }
.shot-arrow { color: var(--accent); font-style: normal; }
.tile__code { font-family: ui-monospace, "SF Mono", Menlo, monospace; font-size: 0.78rem; color: var(--accent); background: rgba(177, 75, 245, 0.08); border: 1px solid var(--line); border-radius: 9px; padding: 9px 12px; }

/* How — signup-to-service flow infographic (curved dashed arc + numbered capsules) */
.flow { display: grid; grid-template-columns: 0.72fr 1.28fr; gap: clamp(28px, 4vw, 56px); align-items: center; }
.flow__intro { position: relative; }
/* concentric half-disc (3 bands) bulging right, echoing the reference */
/* concentric bands, each thinner than the one before */
.flow__arc { position: absolute; left: -78px; top: 50%; width: 280px; height: 400px; transform: translateY(-50%); pointer-events: none; background: radial-gradient(circle at 0% 50%, rgba(177, 75, 245, 0.55) 0 26px, transparent 26px 52px, rgba(177, 75, 245, 0.46) 52px 71px, transparent 71px 96px, rgba(177, 75, 245, 0.37) 96px 110px, transparent 110px 134px, rgba(177, 75, 245, 0.28) 134px 144px, transparent 144px 167px, rgba(177, 75, 245, 0.19) 167px 174px, transparent 174px 196px, rgba(177, 75, 245, 0.12) 196px 201px, transparent 201px); -webkit-mask: radial-gradient(circle at 0% 50%, #000 99%, transparent 100%); mask: radial-gradient(circle at 0% 50%, #000 99%, transparent 100%); }
.flow__intro > :not(.flow__arc) { position: relative; z-index: 1; }
.flow__diagram { position: relative; }
/* steamy cup, dark photo background blended into the site so it reads transparent */
.flow__tea { position: absolute; right: 446px; top: 50%; transform: translateY(-50%); width: 270px; height: 270px; object-fit: cover; mix-blend-mode: screen; -webkit-mask: radial-gradient(circle at 50% 48%, #000 42%, transparent 68%); mask: radial-gradient(circle at 50% 48%, #000 42%, transparent 68%); pointer-events: none; }
@media (max-width: 980px) { .flow__tea { display: none; } }
/* cards: right edges aligned; left edges fan (middle widest) into a half-circle */
.flow__steps { list-style: none; position: relative; display: grid; gap: 14px; }
.flow__step { display: flex; align-items: center; justify-content: flex-end; min-height: 58px; }
.flow__no { flex: none; width: 44px; height: 44px; border-radius: 50%; background: #08080c; color: #fff; font-weight: 700; font-size: 0.92rem; display: grid; place-items: center; margin-right: -22px; position: relative; z-index: 2; box-shadow: 0 0 0 5px var(--bg), 0 0 0 6.5px rgba(177, 75, 245, 0.55); }
.flow__txt { flex: 1; }
.flow__step:nth-child(1) .flow__card, .flow__step:nth-child(5) .flow__card { width: 486px; }
.flow__step:nth-child(2) .flow__card, .flow__step:nth-child(4) .flow__card { width: 396px; }
.flow__step:nth-child(3) .flow__card { width: 330px; }
/* solid filled capsule, white text — like the reference (compact) */
/* outlined cards: transparent fill, border colour only, uniform height */
.flow__card { flex: none; display: flex; align-items: center; gap: 13px; height: 64px; padding: 0 18px 0 40px; border-radius: 14px; background: rgba(177, 75, 245, 0.05); border: 1px solid rgba(177, 75, 245, 0.5); color: var(--ink); transition: transform 0.5s var(--ease), border-color 0.4s, background 0.4s; }
.flow__step:hover .flow__card { transform: translateX(-4px); border-color: rgba(177, 75, 245, 0.9); background: rgba(177, 75, 245, 0.1); }
.flow__card h3 { font-weight: 600; font-size: 0.95rem; letter-spacing: -0.01em; color: var(--ink); }
.flow__card p { margin-top: 1px; color: var(--muted); font-size: 0.8rem; line-height: 1.3; white-space: nowrap; }
.flow__ic { flex: none; display: grid; place-items: center; width: 42px; height: 42px; border-radius: 50%; background: rgba(177, 75, 245, 0.1); border: 1px solid rgba(177, 75, 245, 0.35); }
.flow__ic svg { width: 21px; height: 21px; fill: none; stroke: var(--accent); stroke-width: 1.8; stroke-linecap: round; stroke-linejoin: round; }
@media (max-width: 860px) {
  .flow { grid-template-columns: 1fr; gap: 36px; }
  .flow__arc, .flow__curve { display: none; }
  .flow__step, .flow__step:nth-child(n) { margin-left: 0; }
  .flow__card { flex-wrap: wrap; }
}

/* Stats — image cards (real food photography) */
.stats__head { text-align: center; margin-bottom: 50px; }
.stats__head .section__h, .stats__head .section__lead { margin-left: auto; margin-right: auto; }
.statg { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; }
.statg__card { position: relative; aspect-ratio: 3 / 4; border-radius: 18px; overflow: hidden; border: 1px solid var(--line); }
.statg__img { position: absolute; inset: 0; background-size: cover; background-position: center; transition: transform 0.7s var(--ease); }
.statg__card:hover .statg__img { transform: scale(1.06); }
.statg__card::after { content: ""; position: absolute; inset: 0; background: linear-gradient(180deg, rgba(6, 6, 8, 0.15) 30%, rgba(6, 6, 8, 0.92)); }
.statg__img--pizza { background-image: url("img/food-pizza.jpg"); }
.statg__img--f1 { background-image: url("img/food-1.jpg"); }
.statg__img--f2 { background-image: url("img/food-2.jpg"); }
.statg__img--rush { background-image: url("img/rush.jpg"); }
.statg__body { position: absolute; left: 0; right: 0; bottom: 0; z-index: 1; padding: 22px clamp(18px, 2vw, 26px); }
.statg__body b { display: block; font-family: var(--serif); font-weight: 500; font-size: clamp(2.2rem, 3.4vw, 3.1rem); line-height: 1; letter-spacing: -0.03em; color: #fff; }
.statg__body span { display: block; margin-top: 10px; color: rgba(244, 244, 243, 0.82); font-size: 0.94rem; line-height: 1.4; }
@media (max-width: 760px) { .statg { grid-template-columns: 1fr 1fr; gap: 12px; } }

/* Loved by — testimonials with real diners */
.quotes { margin-top: 50px; display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px; }
.quote { display: flex; flex-direction: column; gap: 22px; border: 1px solid var(--line); border-radius: 18px; padding: 30px 28px; background: linear-gradient(180deg, rgba(255, 255, 255, 0.02), transparent); transition: border-color 0.4s, transform 0.5s var(--ease); }
.quote:hover { border-color: rgba(177, 75, 245, 0.45); transform: translateY(-4px); }
.quote blockquote { margin: 0; font-family: var(--serif); font-size: clamp(1.2rem, 1.7vw, 1.5rem); line-height: 1.32; letter-spacing: -0.01em; color: var(--ink); }
.quote figcaption { margin-top: auto; display: grid; grid-template-columns: auto 1fr; align-items: center; gap: 4px 13px; }
.quote img { grid-row: span 2; width: 48px; height: 48px; border-radius: 50%; object-fit: cover; border: 1px solid var(--line); }
.quote figcaption span:not(.quote__stars) { font-size: 0.9rem; color: var(--muted); line-height: 1.35; }
.quote figcaption b { display: block; color: var(--ink); font-weight: 600; }
.quote__stars { grid-column: 2; font-size: 0.82rem; color: #f2c94c; letter-spacing: 0.06em; }
@media (max-width: 860px) { .quotes { grid-template-columns: 1fr; } }

/* Pricing */
.plans { margin-top: 56px; display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px; }
.plan { border: 1px solid var(--line); border-radius: 18px; padding: 34px 28px; display: flex; flex-direction: column; transition: border-color 0.4s, transform 0.5s var(--ease); }
.plan:hover { transform: translateY(-4px); border-color: rgba(177, 75, 245, 0.4); }
.plan--feature { border-color: var(--accent); background: linear-gradient(180deg, rgba(177, 75, 245, 0.1), transparent 60%); position: relative; }
.plan__tag { position: absolute; top: -11px; left: 28px; background: var(--accent); color: #0a0a0c; font-size: 0.72rem; font-weight: 700; padding: 3px 11px; border-radius: 999px; letter-spacing: 0.02em; }
.plan h3 { font-weight: 500; font-size: 1.4rem; letter-spacing: -0.02em; }
.plan__price { font-weight: 500; font-size: 2.6rem; letter-spacing: -0.03em; margin-top: 12px; }
.dh { display: inline-block; vertical-align: -0.08em; margin-right: 0.14em; }
.dh svg { width: 0.92em; height: 0.92em; fill: none; stroke: currentColor; stroke-width: 1.9; stroke-linecap: round; stroke-linejoin: round; }
.plan__price span { font-size: 1rem; color: var(--muted); }
.plan__for { color: var(--muted); font-size: 0.96rem; margin-top: 6px; }
.plan ul { list-style: none; margin: 22px 0 26px; display: grid; gap: 10px; }
.plan li { color: var(--muted); font-size: 0.98rem; padding-left: 22px; position: relative; }
.plan li::before { content: ""; position: absolute; left: 0; top: 0.55em; width: 8px; height: 8px; border-radius: 50%; background: var(--accent); }
.plan .btn { margin-top: auto; }
@media (max-width: 860px) { .plans { grid-template-columns: 1fr; } }

/* CTA band + contact form */
.cta__inner { display: grid; grid-template-columns: 1.05fr 0.95fr; gap: clamp(36px, 5vw, 72px); align-items: center; border: 1px solid var(--line); border-radius: 28px; padding: clamp(40px, 5vw, 72px); background: radial-gradient(90% 130% at 0% 0%, rgba(177, 75, 245, 0.14), transparent 60%); }
.cta__h { font-family: var(--serif); font-weight: 500; font-size: clamp(2rem, 4.4vw, 3.6rem); line-height: 1.02; letter-spacing: -0.02em; text-wrap: balance; }
.cta__sub { margin: 18px 0 30px; color: var(--muted); font-size: 1.05rem; line-height: 1.55; max-width: 38ch; }
.contact { background: rgba(255, 255, 255, 0.02); border: 1px solid var(--line); border-radius: 20px; padding: clamp(24px, 3vw, 34px); display: grid; gap: 14px; }
.contact__h { font-family: var(--serif); font-weight: 500; font-size: 1.5rem; letter-spacing: -0.01em; }
.contact__row { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
.contact__field { display: grid; gap: 6px; }
.contact__field span { font-size: 0.82rem; font-weight: 500; color: var(--muted); }
.contact input, .contact textarea { width: 100%; box-sizing: border-box; font-family: inherit; font-size: 0.95rem; color: var(--ink); background: rgba(255, 255, 255, 0.03); border: 1px solid var(--line); border-radius: 10px; padding: 11px 13px; transition: border-color 0.2s var(--ease), background 0.2s var(--ease); }
.contact input::placeholder, .contact textarea::placeholder { color: var(--faint); }
.contact input:focus, .contact textarea:focus { outline: none; border-color: var(--accent); background: rgba(177, 75, 245, 0.06); }
.contact textarea { resize: vertical; min-height: 84px; }
.contact .btn { margin-top: 4px; }
.contact__status { min-height: 1.2em; margin: 0; font-size: 0.88rem; color: var(--muted); }
.contact__status.is-ok { color: #5fd28a; }
.contact__status.is-error { color: #ffb4b4; }
@media (max-width: 860px) { .cta__inner { grid-template-columns: 1fr; } }
@media (max-width: 460px) { .contact__row { grid-template-columns: 1fr; } }

/* Footer */
.foot { border-top: 1px solid var(--line); max-width: var(--maxw); margin: 0 auto; padding: clamp(56px, 7vw, 88px) clamp(20px, 4vw, 48px) 40px; position: relative; z-index: 1; background: radial-gradient(80% 120% at 0% 0%, rgba(177, 75, 245, 0.07), transparent 55%); }
.foot__top { display: grid; grid-template-columns: 1.1fr 1.3fr; gap: clamp(40px, 6vw, 90px); }
.foot__brand { display: inline-flex; align-items: center; gap: 11px; font-weight: 700; font-size: 1.4rem; letter-spacing: -0.02em; color: var(--ink); }
.foot__brand img { filter: drop-shadow(0 0 16px rgba(177, 75, 245, 0.55)); }
.foot__pitch { margin: 20px 0 26px; max-width: 34ch; color: var(--muted); font-size: 1.02rem; line-height: 1.55; }
.foot__cols { display: grid; grid-template-columns: repeat(3, 1fr); gap: 28px; }
.foot__col { display: grid; gap: 12px; align-content: start; }
.foot__h { font-size: 0.78rem; font-weight: 600; text-transform: uppercase; letter-spacing: 0.1em; color: var(--faint); margin-bottom: 2px; }
.foot__col a { color: var(--muted); font-size: 0.95rem; transition: color 0.3s; }
.foot__col a:hover { color: var(--ink); }
.foot__bar { display: flex; align-items: center; justify-content: space-between; gap: 16px; margin-top: clamp(40px, 6vw, 72px); padding-top: 26px; border-top: 1px solid var(--line); color: var(--faint); font-size: 0.86rem; }
.foot__bar b { color: var(--accent); font-weight: 600; }
.foot__legal { display: inline-flex; gap: 22px; }
.foot__legal a { color: var(--faint); transition: color 0.3s; }
.foot__legal a:hover { color: var(--ink); }
@media (max-width: 720px) {
  .foot__top { grid-template-columns: 1fr; gap: 36px; }
  .foot__bar { flex-direction: column; align-items: flex-start; gap: 10px; }
}

/* ---------- Reveal system ----------
   Elements are visible by default. Hiding applies ONLY when the page has
   committed to motion (html.motion, set before paint and removed if the
   engine fails). So no-JS / reduced-motion / CDN-blocked all render fully. */
.motion [data-anim] {
  opacity: 0; transform: translateY(38px);
  transition: opacity 0.85s var(--ease), transform 0.85s var(--ease);
  will-change: opacity, transform;
}
.motion [data-anim="left"] { transform: translateX(-46px); }
.motion [data-anim="right"] { transform: translateX(46px); }
.motion [data-anim="scale"] { transform: translateY(22px) scale(0.96); }
.motion [data-anim].in { opacity: 1; transform: none; }
