:root{--brand:#ff4665;--brand-soft:#ff7b86;--ink:#171717;--muted:#8b8b8f;--line:#ececef;--panel:#ffffff;--soft:#f6f6f7}*{box-sizing:border-box}body,html{min-height:100%}body{margin:0;background:#f5f5f6;color:var(--ink);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-size:16px}button,input,select,textarea{font:inherit}button{cursor:pointer}.app-shell{min-height:100vh;padding-bottom:0}.hero{position:relative;min-height:360px;overflow:hidden;background:var(--brand);color:#fff}.pill-menu{position:absolute;right:20px;top:76px;border-radius:999px;background:rgba(135,36,54,.26);padding:12px 22px;font-size:24px}.profile{position:absolute;top:150px;width:130px;text-align:center}.profile.owner{left:max(24px,calc(50% - 500px))}.profile.guest{right:max(24px,calc(50% - 500px))}.avatar{display:grid;width:86px;height:86px;margin:0 auto 8px;place-items:center;border:4px solid rgba(255,255,255,.75);border-radius:50%;background:#fff;color:var(--brand);font-size:30px;font-weight:800}.avatar.dark{background:#3a3a3a;color:#fff}.profile span{display:inline-block;border-radius:8px;background:#fff;color:#df5262;font-size:20px;padding:4px 10px}.profile p{margin:14px 0 0;color:rgba(255,255,255,.88)}.hero-title{position:absolute;left:50%;top:160px;transform:translateX(-50%);text-align:center}.hero-title p{margin:0 0 36px;font-size:28px}.hero-title b{border-radius:999px;background:#fff;color:var(--brand);padding:6px 22px;font-size:18px}.menu-panel{max-width:1100px;margin:0 auto;background:var(--panel);min-height:620px}.page-message{padding:14px 28px;color:#8a5b18;background:#fff8e8}.menu-heading,.page-message{border-bottom:1px solid var(--line)}.menu-heading{display:flex;align-items:center;justify-content:space-between;gap:18px;min-height:116px;padding:24px 28px}.eyebrow{margin:0 0 4px;color:var(--muted);font-size:14px}.menu-heading h1{margin:0;font-size:32px;font-weight:500}.search-box{display:flex;align-items:center;gap:8px;width:min(360px,45%);border-radius:999px;background:var(--soft);padding:12px 16px;color:var(--muted)}.search-box input{width:100%;border:0;outline:0;background:transparent}.menu-layout{display:grid;grid-template-columns:290px 1fr;min-height:520px}.category-rail{overflow:auto;background:#f3f3f4}.category{display:block;width:100%;min-height:112px;border:0;border-bottom:1px solid #fff;background:transparent;color:#101010;text-align:left;padding:18px 28px;font-size:28px}.category.active{background:#fff;font-weight:700}.dish-list{min-width:0;background:#fff;padding-bottom:104px}.dish-card{display:grid;width:100%;grid-template-columns:140px 1fr;grid-gap:22px;gap:22px;align-items:center;min-height:160px;border:0;border-bottom:1px solid var(--line);background:#fff;padding:22px 28px;color:inherit;text-align:left}.dish-card img{width:140px;height:140px;object-fit:cover;border-radius:12px}.dish-info h2{margin:0 0 16px;font-size:24px;font-weight:500}.dish-info p{margin:0 0 24px;color:#b5b5b8;font-size:18px}.dish-info span{display:flex;align-items:center;gap:6px;color:var(--brand);font-size:26px}.empty-state{display:grid;grid-gap:14px;gap:14px;place-items:center;min-height:300px;color:#a5a5aa;text-align:center}.action-bar{display:grid;grid-template-columns:1fr 1fr;grid-gap:28px;gap:28px;padding:22px 28px;background:rgba(255,255,255,.94);border-top:1px solid var(--line)}.danger-outline-action,.outline-action,.primary-action,.secondary-action{display:inline-flex;align-items:center;justify-content:center;gap:10px;min-height:64px;border-radius:12px;border:0;padding:0 24px;font-size:24px}.primary-action{background:#f16667;color:#fff}.secondary-action{background:#f4f4f5;color:#d55b68}.outline-action{background:#fff;color:#e5727d;border:1px solid #f0b2ba}.danger-outline-action{background:#fff;color:#c93245;border:1px solid #ef9aa5}.form-screen{min-height:100vh;background:#fff}.login-screen{min-height:100vh;display:grid;place-items:center;padding:24px;background:linear-gradient(180deg,#ff4665,#ff7b86 46%,#fff 0)}.login-card{width:min(420px,100%);display:grid;grid-gap:18px;gap:18px;border-radius:18px;background:#fff;padding:34px;box-shadow:0 24px 80px rgba(121,20,42,.18)}.login-icon{display:grid;width:58px;height:58px;place-items:center;border-radius:50%;background:#fff0f2;color:var(--brand)}.login-card h1{margin:0;font-size:30px}.login-card p{margin:0 0 8px;color:#74747a}.login-card label{display:grid;grid-gap:8px;gap:8px;color:#55555a;font-size:16px}.login-card .remember-login{display:flex;align-items:center;gap:10px;color:#66666c}.login-card input{min-height:48px;border:1px solid var(--line);border-radius:10px;padding:0 14px;outline:0}.login-card .remember-login input{width:18px;height:18px;min-height:18px;accent-color:var(--brand)}.login-card input:focus{border-color:var(--brand)}.login-card strong{color:#d64252;font-size:15px}.login-card button{min-height:52px;border:0;border-radius:10px;background:#f16667;color:#fff;font-size:18px}.login-card button:disabled{opacity:.7}.top-bar{display:grid;grid-template-columns:72px 1fr 72px;align-items:center;min-height:96px;border-bottom:1px solid var(--line);background:#fff;color:#111}.top-bar.pink{background:var(--brand);color:#fff}.top-bar button{display:grid;place-items:center;width:72px;height:72px;border:0;background:transparent;color:currentColor}.top-bar strong{text-align:center;font-size:28px}.dish-form{max-width:880px;margin:0 auto;padding:28px 24px 44px}.cover-picker{display:grid;justify-items:start;margin-bottom:34px}.cover-picker span{display:flex;align-items:baseline;gap:12px;margin-bottom:22px}.cover-picker b{font-size:28px}.cover-picker b:first-letter,.field-row span:first-letter{color:var(--brand)}.cover-picker em{color:#404046;font-style:normal;font-size:18px}.cover-picker input{position:absolute;width:1px;height:1px;opacity:0}.cover-preview{display:grid;width:160px;height:160px;place-items:center;overflow:hidden;border-radius:6px;background:#f6f7f9;color:#d8d8dc}.cover-preview img{width:100%;height:100%;object-fit:cover}.field-row{display:grid;grid-template-columns:180px 1fr;align-items:center;min-height:88px;border-bottom:1px solid var(--line);font-size:26px}.field-row span{color:#626268}.field-row input,.field-row select{min-width:0;border:0;outline:0;background:#fff;color:#33333a;font-size:26px}.add-category input::placeholder,.field-row input::placeholder,.notes-field textarea::placeholder{color:#c8c8cc}.notes-field{display:grid;grid-gap:12px;gap:12px;padding:24px 0;color:#626268;font-size:22px}.notes-field textarea{min-height:120px;resize:vertical;border:1px solid var(--line);border-radius:10px;padding:14px;outline:0}.form-actions{display:grid;max-width:620px;grid-gap:22px;gap:22px;margin:90px auto 0}.form-message{margin:0;color:#d64252;text-align:center}.outline-action:disabled,.primary-action:disabled,.secondary-action:disabled{cursor:not-allowed;opacity:.68}.hint{margin:0;padding:28px 24px;border-bottom:1px solid var(--line);color:#b9b9bd;font-size:22px}.category-manager{background:#fff}.swipe-row{position:relative;overflow:hidden;border-bottom:1px solid var(--line);background:#f16667}.manager-row{position:relative;display:grid;grid-template-columns:1fr auto;align-items:center;min-height:94px;padding:0 24px;background:#fff;font-size:26px;touch-action:pan-y;transition:transform .18s ease;z-index:1}.manager-row.shifted{transform:translateX(-112px)}.manager-row div{display:flex;gap:18px}.manager-row button{display:grid;width:42px;height:42px;place-items:center;border:0;background:transparent}.manager-row button:disabled{opacity:.2}.delete-reveal{position:absolute;top:0;right:0;bottom:0;z-index:0;width:112px;gap:6px;font-size:18px}.danger-action,.delete-reveal{display:inline-flex;align-items:center;justify-content:center;border:0;background:#f16667;color:#fff}.danger-action{min-height:56px;border-radius:12px;padding:0 22px;font-size:20px}.confirm-layer{position:fixed;inset:0;z-index:10;display:grid;place-items:center;padding:24px;background:rgba(0,0,0,.36)}.confirm-box{width:min(420px,100%);border-radius:14px;background:#fff;padding:24px;box-shadow:0 24px 80px rgba(0,0,0,.18)}.confirm-box h2{margin:0 0 12px;font-size:24px}.confirm-box p{margin:0 0 24px;color:#626268;line-height:1.6}.confirm-box div{display:grid;grid-template-columns:1fr 1fr;grid-gap:12px;gap:12px}.add-category{position:-webkit-sticky;position:sticky;bottom:0;display:grid;grid-template-columns:1fr auto;grid-gap:18px;gap:18px;max-width:820px;margin:40px auto 0;padding:20px 24px;background:rgba(255,255,255,.95)}.add-category input{min-width:0;border:1px solid var(--line);border-radius:12px;padding:0 18px;outline:0;font-size:20px}@media (max-width:720px){.hero{min-height:260px}.pill-menu{top:40px;right:14px;padding:7px 14px;font-size:15px}.profile{top:112px;width:86px}.profile.owner{left:18px}.profile.guest{right:18px}.avatar{width:62px;height:62px;border-width:3px;font-size:24px}.profile span{font-size:14px;padding:3px 8px}.profile p{margin-top:10px;font-size:12px}.hero-title{top:122px}.hero-title p{margin-bottom:18px;font-size:18px;white-space:nowrap}.hero-title b{padding:5px 18px;font-size:14px}.menu-heading{display:block;padding:20px 16px}.menu-heading h1{font-size:24px;font-weight:600}.search-box{width:100%;margin-top:14px;padding:10px 14px;font-size:15px}.menu-layout{grid-template-columns:31% 1fr}.category{min-height:82px;padding:14px 12px;font-size:18px;line-height:1.3}.dish-card{grid-template-columns:96px 1fr;gap:12px;min-height:122px;padding:14px 12px}.dish-card img{width:96px;height:96px;border-radius:8px}.dish-info h2{margin-bottom:10px;font-size:18px;font-weight:600}.dish-info p{margin-bottom:12px;font-size:14px}.dish-info span{font-size:18px}.action-bar{position:-webkit-sticky;position:sticky;bottom:0;gap:12px;padding:14px 16px}.danger-outline-action,.outline-action,.primary-action,.secondary-action{min-height:48px;border-radius:10px;padding:0 12px;font-size:16px}.top-bar{grid-template-columns:56px 1fr 56px;min-height:64px}.top-bar button{width:56px;height:56px}.top-bar strong{font-size:20px}.dish-form{padding:20px 18px 36px}.cover-picker{margin-bottom:24px}.cover-picker span{margin-bottom:16px}.cover-picker b{font-size:20px}.cover-picker em{font-size:14px}.cover-preview{width:128px;height:128px}.field-row{grid-template-columns:96px 1fr;min-height:68px}.field-row,.field-row input,.field-row select,.notes-field{font-size:17px}.notes-field{padding:18px 0}.notes-field textarea{min-height:96px;font-size:16px}.form-actions{gap:14px;margin-top:40px}.hint{padding:20px 18px;font-size:16px}.manager-row{min-height:72px;padding:0 18px;font-size:18px}.danger-action{min-height:48px;font-size:16px}.confirm-box h2{font-size:20px}.add-category{gap:12px;padding:16px 18px}.add-category input{min-height:46px;font-size:16px}.add-category{grid-template-columns:1fr}}