:root {
  --bg: oklch(98% 0.004 240);
  --surface: oklch(100% 0 0);
  --fg: oklch(20% 0.02 240);
  --muted: oklch(50% 0.018 240);
  --border: oklch(90% 0.006 240);
  --accent: oklch(56% 0.12 170);
  --coral: oklch(71% 0.12 36);
  --cream: oklch(96% 0.035 88);
  --safe: oklch(63% 0.13 150);
  --warn: oklch(70% 0.13 74);
  --danger: oklch(60% 0.16 30);
  --accent-soft: color-mix(in oklch, var(--accent) 13%, transparent);
  --coral-soft: color-mix(in oklch, var(--coral) 18%, transparent);
  --cream-soft: color-mix(in oklch, var(--cream) 72%, var(--surface));
  --fg-soft: color-mix(in oklch, var(--fg) 6%, transparent);
  --font-display: 'Avenir Next', 'Söhne', -apple-system, BlinkMacSystemFont, system-ui, sans-serif;
  --font-body: -apple-system, BlinkMacSystemFont, 'SF Pro Text', system-ui, sans-serif;
  --font-mono: ui-monospace, 'JetBrains Mono', 'SF Mono', Menlo, monospace;
  --radius-sm: 12px;
  --radius: 18px;
  --radius-lg: 28px;
  --shadow: 0 18px 50px color-mix(in oklch, var(--fg) 9%, transparent);
  --container: 1180px;
}

* { box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; }
body { margin: 0; background: var(--bg); color: var(--fg); font: 16px/1.55 var(--font-body); text-rendering: optimizeLegibility; -webkit-font-smoothing: antialiased; }
a { color: inherit; text-decoration: none; }
button, input, textarea, select { font: inherit; }
button { cursor: pointer; }
h1, h2, h3 { font-family: var(--font-display); letter-spacing: -0.025em; line-height: 1.08; margin: 0; text-wrap: balance; }
h1 { font-size: clamp(42px, 7vw, 86px); }
h2 { font-size: clamp(30px, 4vw, 50px); }
h3 { font-size: 21px; }
p { text-wrap: pretty; }
.app-shell { min-height: 100vh; }
.container { width: min(var(--container), calc(100vw - 40px)); margin: 0 auto; }
.topnav { position: sticky; top: 0; z-index: 30; background: color-mix(in oklch, var(--bg) 92%, transparent); border-bottom: 1px solid var(--border); backdrop-filter: blur(16px); }
.topnav-inner { min-height: 68px; display: flex; align-items: center; justify-content: space-between; gap: 20px; }
.brand { display: inline-flex; align-items: center; gap: 10px; font-family: var(--font-display); font-weight: 760; font-size: 20px; }
.brand-mark { width: 34px; height: 34px; border-radius: 14px; display: grid; place-items: center; background: var(--accent-soft); color: var(--accent); border: 1px solid color-mix(in oklch, var(--accent) 22%, var(--border)); }
.nav-links { display: flex; align-items: center; gap: 22px; color: var(--muted); font-size: 14px; }
.nav-links a:hover { color: var(--fg); }
.section { padding: clamp(42px, 7vw, 88px) 0; }
.section + .section { border-top: 1px solid var(--border); }
.hero-grid { display: grid; grid-template-columns: minmax(0, 1.04fr) minmax(320px, .96fr); gap: clamp(28px, 6vw, 76px); align-items: center; }
.eyebrow { margin: 0 0 16px; font: 700 12px/1 var(--font-mono); letter-spacing: .08em; text-transform: uppercase; color: var(--accent); }
.lead { max-width: 58ch; color: var(--muted); font-size: clamp(18px, 2vw, 21px); margin: 20px 0 0; }
.actions { display: flex; flex-wrap: wrap; gap: 12px; margin-top: 28px; }
.btn { min-height: 44px; border-radius: 999px; border: 1px solid var(--border); padding: 10px 18px; display: inline-flex; align-items: center; justify-content: center; gap: 8px; background: var(--surface); color: var(--fg); font-weight: 700; transition: transform .15s ease, border-color .15s ease, background .15s ease; }
.btn:hover { transform: translateY(-1px); border-color: color-mix(in oklch, var(--fg) 22%, var(--border)); }
.btn-primary { background: var(--accent); border-color: var(--accent); color: var(--surface); }
.btn-coral { background: var(--coral-soft); border-color: color-mix(in oklch, var(--coral) 25%, var(--border)); color: color-mix(in oklch, var(--coral) 72%, var(--fg)); }
.card { background: var(--surface); border: 1px solid var(--border); border-radius: var(--radius-lg); box-shadow: var(--shadow); }
.soft-card { background: var(--cream-soft); border: 1px solid var(--border); border-radius: var(--radius-lg); }
.hero-art { min-height: 460px; padding: 24px; position: relative; overflow: hidden; }
.hero-art::before { content: ''; position: absolute; width: 280px; height: 280px; border-radius: 999px; background: var(--accent-soft); right: -70px; top: -70px; }
.hero-art::after { content: ''; position: absolute; width: 190px; height: 190px; border-radius: 42% 58% 55% 45%; background: var(--coral-soft); left: -48px; bottom: -46px; }
.recipe-stack, .phone-content, .tablet-pane { position: relative; z-index: 1; }
.recipe-card { background: var(--surface); border: 1px solid var(--border); border-radius: var(--radius); padding: 16px; display: grid; gap: 14px; }
.recipe-card.featured { box-shadow: var(--shadow); }
.recipe-thumb { min-height: 132px; border-radius: 20px; background: linear-gradient(135deg, var(--cream-soft), var(--accent-soft)); border: 1px solid var(--border); display: grid; place-items: center; color: var(--muted); font: 700 12px/1 var(--font-mono); letter-spacing: .06em; }
.recipe-title { display: flex; align-items: start; justify-content: space-between; gap: 12px; }
.recipe-title h3 { font-size: 19px; }
.meta { color: var(--muted); font-size: 13px; }
.tag-row { display: flex; flex-wrap: wrap; gap: 8px; }
.tag { display: inline-flex; align-items: center; gap: 6px; padding: 6px 10px; border-radius: 999px; border: 1px solid var(--border); color: var(--muted); background: var(--surface); font-size: 12px; }
.tag.safe { color: color-mix(in oklch, var(--safe) 70%, var(--fg)); background: color-mix(in oklch, var(--safe) 12%, var(--surface)); }
.tag.warn { color: color-mix(in oklch, var(--warn) 76%, var(--fg)); background: color-mix(in oklch, var(--warn) 16%, var(--surface)); }
.tag.danger { color: color-mix(in oklch, var(--danger) 80%, var(--fg)); background: color-mix(in oklch, var(--danger) 11%, var(--surface)); }
.icon-btn { width: 42px; height: 42px; border-radius: 999px; border: 1px solid var(--border); background: var(--surface); display: grid; place-items: center; color: var(--muted); }
.icon-btn.is-saved { color: var(--coral); background: var(--coral-soft); border-color: color-mix(in oklch, var(--coral) 30%, var(--border)); }
.grid-2 { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 22px; }
.grid-3 { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 22px; }
.grid-4 { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 18px; }
.split { display: grid; grid-template-columns: minmax(0, .9fr) minmax(360px, 1.1fr); gap: 28px; align-items: start; }
.toolbar { display: flex; gap: 10px; flex-wrap: wrap; align-items: center; }
.input, .textarea, .select { width: 100%; border: 1px solid var(--border); border-radius: 16px; background: var(--surface); padding: 13px 15px; color: var(--fg); }
.textarea { min-height: 120px; resize: vertical; }
.field { display: grid; gap: 7px; }
.field label { color: var(--muted); font-size: 13px; }
.chip { border: 1px solid var(--border); background: var(--surface); color: var(--muted); border-radius: 999px; padding: 9px 13px; font-size: 14px; }
.chip.is-active { color: color-mix(in oklch, var(--accent) 70%, var(--fg)); background: var(--accent-soft); border-color: color-mix(in oklch, var(--accent) 28%, var(--border)); }
.notice { border-radius: var(--radius); border: 1px solid color-mix(in oklch, var(--warn) 28%, var(--border)); background: color-mix(in oklch, var(--warn) 13%, var(--surface)); padding: 15px; color: color-mix(in oklch, var(--warn) 70%, var(--fg)); }
.comment-panel { display: none; margin-top: 14px; border-top: 1px solid var(--border); padding-top: 14px; }
.comment-panel.is-open { display: grid; gap: 10px; }
.comment { background: var(--fg-soft); border-radius: 16px; padding: 12px; }
.step { display: none; }
.step.is-active { display: grid; gap: 14px; }
.stepper { display: flex; gap: 8px; margin-bottom: 18px; }
.step-dot { flex: 1; height: 6px; border-radius: 999px; background: var(--border); }
.step-dot.is-active { background: var(--accent); }
.screen-frame { border-radius: 34px; border: 1px solid var(--border); background: color-mix(in oklch, var(--surface) 88%, var(--bg)); box-shadow: var(--shadow); overflow: hidden; }
.phone-frame { width: min(390px, calc(100vw - 28px)); min-height: 760px; margin: 26px auto; border-radius: 42px; padding: 12px; background: var(--fg); }
.phone-screen { min-height: 736px; border-radius: 32px; background: var(--bg); overflow: hidden; display: flex; flex-direction: column; }
.statusbar { height: 34px; display: flex; align-items: center; justify-content: space-between; padding: 0 18px; font: 700 12px/1 var(--font-mono); }
.mobile-header { padding: 12px 18px 10px; display: flex; align-items: center; justify-content: space-between; gap: 12px; }
.mobile-main { flex: 1; padding: 12px 18px 92px; display: grid; gap: 16px; align-content: start; }
.bottom-nav { position: absolute; left: 12px; right: 12px; bottom: 12px; height: 72px; border-radius: 28px; background: color-mix(in oklch, var(--surface) 94%, transparent); border: 1px solid var(--border); backdrop-filter: blur(12px); display: grid; grid-template-columns: repeat(4, 1fr); place-items: center; color: var(--muted); font-size: 12px; }
.bottom-nav span:first-child { color: var(--accent); font-weight: 800; }
.android .phone-frame { border-radius: 28px; }
.android .phone-screen { border-radius: 22px; }
.fab { position: absolute; right: 30px; bottom: 92px; width: 56px; height: 56px; border: 0; border-radius: 18px; background: var(--accent); color: var(--surface); font-size: 26px; box-shadow: var(--shadow); }
.tablet-canvas { width: min(1080px, calc(100vw - 28px)); margin: 24px auto; border-radius: 36px; border: 1px solid var(--border); background: var(--surface); box-shadow: var(--shadow); overflow: hidden; }
.tablet-grid { display: grid; grid-template-columns: 280px 1fr 300px; min-height: 720px; }
.tablet-sidebar, .tablet-aside { padding: 22px; background: var(--cream-soft); border-right: 1px solid var(--border); }
.tablet-aside { border-left: 1px solid var(--border); border-right: 0; }
.tablet-main { padding: 24px; display: grid; gap: 18px; align-content: start; }
.launcher-grid { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 18px; }
.screen-list { display: grid; gap: 10px; margin-top: 16px; }
.screen-list a { padding: 12px 14px; border: 1px solid var(--border); border-radius: 14px; background: var(--surface); color: var(--muted); }
.screen-list a:hover { color: var(--fg); border-color: color-mix(in oklch, var(--accent) 30%, var(--border)); }
.empty-state { display: none; padding: 22px; border: 1px dashed var(--border); border-radius: var(--radius); color: var(--muted); }
.is-empty .recipe-results { display: none; }
.is-empty .empty-state { display: block; }
@media (max-width: 1180px) { .launcher-grid, .grid-4 { grid-template-columns: repeat(2, 1fr); } .tablet-grid { grid-template-columns: 230px 1fr; } .tablet-aside { grid-column: 1 / -1; border-left: 0; border-top: 1px solid var(--border); } }
@media (max-width: 920px) { .hero-grid, .grid-2, .grid-3, .split { grid-template-columns: 1fr; } .nav-links { display: none; } .hero-art { min-height: 360px; } }
@media (max-width: 560px) { .container { width: min(100vw - 24px, var(--container)); } .section { padding: 34px 0; } .launcher-grid, .grid-4 { grid-template-columns: 1fr; } .topnav-inner { min-height: 60px; } .brand { font-size: 18px; } }
