:root{--safe-area-top: env(safe-area-inset-top, 0px);--safe-area-bottom: env(safe-area-inset-bottom, 0px);font-family:Avenir Next,Segoe UI,sans-serif;color:#17302c;background:radial-gradient(circle at top left,rgba(255,236,180,.65),transparent 32%),linear-gradient(180deg,#f7f2e8,#efe2c4);line-height:1.4;font-weight:400}*{box-sizing:border-box}html,body,#root{margin:0;min-height:100%}html{scroll-behavior:smooth}body{min-height:100svh;color:#17302c}button,textarea,input,select{font:inherit}button{cursor:pointer}img{display:block}.menu-shell{min-height:100svh;padding:calc(var(--safe-area-top) + 20px) 16px calc(var(--safe-area-bottom) + 104px)}.hero,.compact-header,.confirmation-card,.cart-card,.modifier-group,.modal-sheet,.category-section,.state-card,.skeleton-card{background:#fffbf2e0;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(23,48,44,.08);box-shadow:0 18px 40px #4c391814}.hero{border-radius:28px;display:grid;grid-template-columns:minmax(0,1fr) clamp(104px,28vw,136px);grid-template-areas:"meta logo" "title logo" "subline subline" "footer footer";align-items:start;gap:14px 16px;padding:20px;margin-bottom:18px}.hero--without-logo{grid-template-columns:minmax(0,1fr);grid-template-areas:"meta" "title" "subline" "footer"}.hero-topline,.category-heading,.dish-header,.dish-footer,.modifier-group-head,.cart-card-head,.checkout-panel,.modal-header,.compact-header,.order-item-head,.skeleton-row{display:flex;justify-content:space-between;gap:12px}.hero-topline,.category-heading,.dish-footer,.modal-header,.compact-header,.order-item-head,.checkout-panel,.modifier-group-head{align-items:center}.hero-logo{width:100%;height:100%;border-radius:22px;object-fit:contain;object-position:center;padding:4px;background:#fff8ea}.hero-title{grid-area:title;min-width:0}.hero h1{font-family:Iowan Old Style,Palatino Linotype,serif;font-size:clamp(1.7rem,4.8vw,2.35rem);line-height:.98;margin:0}.confirmation-card h1{font-family:Iowan Old Style,Palatino Linotype,serif;font-size:clamp(2rem,6vw,3rem);line-height:.95;margin:0 0 10px}.hero p,.confirmation-card p,.cart-card p,.order-item-card p,.state-card p{margin:0;color:#4b5d58}.hero p{font-size:.97rem}.hero-meta{grid-area:meta;display:flex;align-items:center;gap:8px;flex-wrap:wrap;min-width:0}.hero-brandmark{grid-area:logo;align-self:start;justify-self:end;aspect-ratio:1 / 1;min-height:104px;border-radius:24px;overflow:hidden;background:radial-gradient(circle at 25% 20%,rgba(255,255,255,.72),transparent 38%),linear-gradient(160deg,#f5ead3,#e6c98a);box-shadow:inset 0 1px #ffffff75}.hero-subline{grid-area:subline;display:flex;align-items:flex-end;gap:12px;min-width:0}.hero-subline p{flex:1 1 auto;min-width:0;max-width:none}.hero-meta-chip{display:inline-flex;align-items:center;padding:6px 10px;border-radius:999px;background:#17302c14;color:#17302c;font-size:.72rem;font-weight:600;letter-spacing:.04em;text-transform:uppercase}.hero-language{position:relative;display:inline-flex;align-items:center;width:fit-content;max-width:100%;padding:6px 28px 6px 10px;border-radius:999px;background:#17302c0f;border:1px solid rgba(23,48,44,.08);margin-left:auto;flex:0 0 auto}.hero-language:after{content:"▾";position:absolute;right:12px;top:50%;transform:translateY(-48%);color:#516560;font-size:.72rem;pointer-events:none}.hero-language-select{width:auto;min-width:0;border:0;padding:0;background:transparent;color:#17302c;font-size:.72rem;font-weight:600;letter-spacing:.04em;text-transform:uppercase;line-height:1;-webkit-appearance:none;-moz-appearance:none;appearance:none;outline:none;flex:0 0 auto}.hero-actions{display:flex;gap:10px;margin-top:2px;flex-wrap:wrap}.hero-footer{grid-area:footer;display:flex;align-items:center;gap:10px;flex-wrap:wrap;min-width:0}.category-strip,.cart-card-actions{display:flex;gap:8px;flex-wrap:wrap}.cart-card-actions button,.compact-header button,.secondary-action{border:0;border-radius:999px;padding:10px 14px;background:#e9dbc0;color:#17302c}.menu-content{display:grid;gap:18px;min-width:0}.category-strip{position:sticky;top:calc(var(--safe-area-top) + 10px);z-index:4;overflow-x:auto;padding:4px 2px 6px;flex-wrap:nowrap;scrollbar-width:none}.category-strip::-webkit-scrollbar{display:none}.category-strip button{display:inline-flex;align-items:center;gap:10px;white-space:nowrap;border:1px solid rgba(23,48,44,.08);border-radius:999px;padding:8px 14px 8px 10px;background:#fffbf2e6;color:#17302c;box-shadow:0 10px 20px #4c39180f}.category-strip button.active{background:#17302c;color:#fff8ea;border-color:transparent}.category-tab-image{width:28px;height:28px;border-radius:50%;object-fit:cover}.category-section,.cart-card,.confirmation-card,.modifier-group,.compact-header,.state-card,.skeleton-card{border-radius:24px;padding:18px}.category-section{scroll-margin-top:86px;min-width:0}.category-heading{margin-bottom:14px}.category-heading h2,.dish-header h3,.cart-card h3{margin:0}.category-meta{display:inline-flex;margin-top:6px;color:#687874;font-size:.84rem}.menu-grid,.cart-list,.confirmation-card,.order-items,.note-field{display:grid;gap:14px;min-width:0}.dish-card{display:grid;grid-template-columns:92px 1fr;gap:14px;padding:14px;border-radius:22px;background:#fffcf6;min-width:0}.dish-image,.dish-placeholder,.skeleton-image{width:92px;height:92px;border-radius:18px;object-fit:cover}.dish-placeholder{display:grid;place-items:center;background:linear-gradient(135deg,#17302c,#357169);color:#fff8ea;font-size:2rem}.dish-body{display:grid;gap:8px;min-width:0}.dish-controls,.modal-quantity-row{display:flex;align-items:center;gap:10px}.dish-controls{grid-column:1 / -1;width:100%;justify-content:flex-start;flex-wrap:nowrap;min-width:0}.dish-header strong,.dish-weight,.checkout-panel strong,.order-item-head strong,.cart-card-head strong{align-self:start}.dish-weight{color:#687874;font-size:.84rem}.dish-body p{margin:0;color:#5e6a67;overflow-wrap:anywhere}.dish-header h3{overflow-wrap:anywhere}.dish-add-button{flex:0 0 auto;margin-left:auto}.quantity-badge{display:inline-flex;margin-top:8px;padding:6px 10px;border-radius:999px;background:#f1e3c4;color:#17302c;font-size:.78rem}.dish-add-button,.primary-action{display:inline-flex;align-items:center;justify-content:center;border:0;border-radius:18px;min-height:44px;padding:12px 16px;background:linear-gradient(135deg,#17302c,#357169);color:#fff8ea;line-height:1;white-space:nowrap}.primary-action:disabled,.dish-add-button:disabled{opacity:.6;cursor:not-allowed}.quantity-picker{display:inline-flex;align-items:center;gap:8px;flex:0 0 auto;padding:4px;border-radius:999px;background:#17302c14}.quantity-picker button{width:32px;height:32px;min-height:32px;border:0;border-radius:50%;padding:0;background:#17302c;color:#fff8ea;font-size:1rem;line-height:1}.quantity-picker-value{min-width:20px;text-align:center;font-weight:700;color:#17302c}.secondary-action{align-self:center}.cart-bar{position:fixed;left:max(16px,calc(50vw - 460px));right:max(16px,calc(50vw - 460px));bottom:calc(var(--safe-area-bottom) + 16px);display:flex;justify-content:space-between;align-items:center;gap:12px;z-index:3;border:0;border-radius:22px;padding:16px 18px;background:#17302c;color:#fff8ea;box-shadow:0 20px 42px #17302c4d}.cart-bar-copy{display:inline-flex;align-items:center;gap:12px;min-width:0}.cart-bar-icon{display:inline-flex;align-items:center;justify-content:center;width:42px;height:42px;border-radius:50%;background:#fff8ea24;flex:0 0 auto}.cart-bar-icon svg{width:26px;height:26px}.cart-bar-total{flex:0 0 auto}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:4;background:#17302c6b;display:flex;align-items:end;justify-content:center;padding:12px}.modal-sheet{width:min(720px,100%);border-radius:28px 28px 18px 18px;padding:20px}.modifier-group{margin-top:14px}.modifier-option{display:grid;grid-template-columns:auto 1fr auto;gap:12px;align-items:center;padding:10px 0;border-top:1px solid rgba(23,48,44,.08)}.modifier-option:first-of-type{border-top:0}.note-field{gap:10px}.note-field span{font-weight:600}.note-field textarea{min-height:92px;resize:vertical;border:1px solid rgba(23,48,44,.14);border-radius:16px;padding:12px 14px;background:#ffffffbd;color:#17302c}.modal-quantity-row{justify-content:space-between;margin-top:6px}.modal-quantity-row span{font-weight:600}.inline-error,.screen-state.error,.state-card.error p,.state-card.error strong{color:#8a1f1f}.screen-state,.confirmation-screen{min-height:100svh;display:grid;place-items:center;padding:calc(var(--safe-area-top) + 24px) 24px calc(var(--safe-area-bottom) + 24px);text-align:center}.cart-screen,.intro-screen{display:grid;gap:18px}.checkout-panel{position:sticky;bottom:calc(var(--safe-area-bottom) + 12px);padding:16px;border-radius:24px;background:#fffbf2f5;border:1px solid rgba(23,48,44,.08);box-shadow:0 18px 40px #4c391814}.confirmation-summary{display:grid;gap:8px;padding:14px 16px;border-radius:18px;background:#fffcf6;text-align:left}.order-item-card{padding:14px 16px;border-radius:18px;background:#fffcf6;text-align:left}.order-item-card p{margin-top:8px}.order-item-actions{display:flex;justify-content:flex-end;margin-top:12px}.order-section{display:grid;gap:14px}.section-head h2{margin:0}.section-head p{margin-top:6px}.order-preview-headline{display:grid;gap:4px}.order-preview-lines{display:grid;gap:10px;margin-top:14px}.order-preview-line{display:flex;justify-content:space-between;align-items:start;gap:12px;padding-top:10px;border-top:1px solid rgba(23,48,44,.08)}.order-preview-line:first-child{padding-top:0;border-top:0}.order-line-copy{display:grid;gap:4px}.order-line-copy p,.order-customer-note{color:#5e6a67}.order-customer-note{margin-top:12px}.order-empty-state{text-align:left}.compact-header-copy{display:grid;gap:4px}.state-card{display:grid;gap:10px;text-align:center}.empty-menu{padding:28px 20px}.skeleton{position:relative;overflow:hidden;border-radius:999px;background:#17302c14}.skeleton:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;transform:translate(-100%);background:linear-gradient(90deg,transparent,rgba(255,255,255,.5),transparent);animation:skeleton-shimmer 1.35s ease-in-out infinite}.skeleton-pill{width:110px;height:34px}.skeleton-chip{width:136px;height:34px}.skeleton-title{width:min(320px,72%);height:46px;border-radius:18px}.skeleton-heading{width:180px;height:28px;border-radius:14px}.skeleton-count{width:54px;height:20px}.skeleton-text,.skeleton-line-lg,.skeleton-line-sm,.skeleton-line-xs{height:16px;border-radius:10px}.skeleton-text{width:min(360px,88%)}.skeleton-text.short{width:min(260px,62%)}.skeleton-line-lg{width:82%}.skeleton-line-sm{width:120px}.skeleton-line-xs{width:56px}.skeleton-button{width:110px;height:40px;border-radius:16px}.skeleton-button.small{width:72px;height:36px}.skeleton-pill.small{width:90px;height:26px}.skeleton-strip{align-items:center}.skeleton-dish-card{background:#fffdf8}.dish-skeleton-footer{align-items:center;margin-top:8px}@keyframes skeleton-shimmer{to{transform:translate(100%)}}@media (min-width: 860px){.menu-shell{width:min(920px,calc(100vw - 32px));margin:0 auto}.menu-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}
