:root{--bg:#f5f7fb;--surface:#fff;--surface-soft:#f8fafc;--text:#0f172a;--muted:#64748b;--line:#e2e8f0;--primary:#dc2626;--primary-dark:#b91c1c;--dark:#0f172a;--shadow:0 18px 50px #0f172a14;--radius-xl:28px;--radius-lg:20px;--radius-md:14px}*{box-sizing:border-box;margin:0;padding:0}html,body{color:var(--text);scroll-behavior:smooth;background:linear-gradient(#f8fafc 0%,#f2f5fa 100%);font-family:Arial,sans-serif}body{min-height:100vh}img{max-width:100%;display:block}button,input,textarea{font:inherit}button{cursor:pointer}.page{min-height:100vh}.container{width:min(1240px,100% - 32px);margin:0 auto}.topbar{z-index:1000;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);background:#ffffffd6;border-bottom:1px solid #e2e8f0e6;position:sticky;top:0}.topbar-inner{justify-content:space-between;align-items:center;min-height:82px;display:flex}.brand{align-items:center;gap:14px;display:flex}.brand-mark{color:#fff;letter-spacing:1px;background:linear-gradient(135deg,#ef4444,#dc2626);border-radius:16px;place-items:center;width:50px;height:50px;font-weight:700;display:grid;box-shadow:0 14px 30px #dc262640}.brand-title{font-size:22px;line-height:1}.brand-subtitle{color:var(--muted);margin-top:4px;font-size:13px}.topbar-actions{align-items:center;gap:12px;display:flex}.cart-button{background:var(--dark);color:#fff;border:none;border-radius:999px;align-items:center;gap:10px;padding:12px 18px;font-weight:700;display:inline-flex;box-shadow:0 12px 26px #0f172a2e}.cart-count{min-width:28px;height:28px;color:var(--dark);background:#fff;border-radius:999px;justify-content:center;align-items:center;padding:0 8px;font-size:13px;display:inline-flex}.cart-button.pulse{animation:.45s pulse}.hero-shell{padding:44px 0 26px}.hero-shell-inner{box-shadow:var(--shadow);background:radial-gradient(circle at 100% 0,#dc26261a,#0000 30%),linear-gradient(135deg,#fff,#f8fafc);border:1px solid #e2e8f0e6;border-radius:34px;padding:44px}.eyebrow{letter-spacing:.2px;border-radius:999px;align-items:center;padding:8px 14px;font-size:12px;font-weight:700;display:inline-flex}.eyebrow.red{color:var(--primary);background:#dc262614}.eyebrow.light{color:#334155;background:#eef2f7}.hero-title{letter-spacing:-1.2px;max-width:760px;margin-top:16px;font-size:clamp(34px,5vw,58px);line-height:1.02}.hero-copy{max-width:720px;color:var(--muted);margin-top:18px;font-size:17px;line-height:1.7}.hero-info-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:18px;margin-top:30px;display:grid}.info-card{border:1px solid var(--line);background:#fff;border-radius:22px;padding:22px;box-shadow:0 10px 30px #0f172a0a}.info-label{color:var(--muted);margin-bottom:10px;font-size:13px;display:block}.content-section{padding:18px 0 70px}.section-header{justify-content:space-between;align-items:end;gap:20px;margin-bottom:24px;display:flex}.section-header h3{margin-top:10px;font-size:36px;line-height:1.1}.section-header p{max-width:420px;color:var(--muted);line-height:1.7}.selection-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:22px;display:grid}.selection-grid.two-col{grid-template-columns:repeat(2,minmax(0,1fr))}.selection-card{text-align:left;border:1px solid var(--line);width:100%;box-shadow:var(--shadow);background:linear-gradient(#fff,#fbfcfe);border-radius:28px;padding:28px;transition:transform .2s,box-shadow .2s,border-color .2s}.selection-card:hover{border-color:#dc262633;transform:translateY(-4px);box-shadow:0 22px 50px #0f172a1a}.selection-tag{color:var(--primary);background:#dc262614;border-radius:999px;margin-bottom:16px;padding:7px 12px;font-size:12px;font-weight:700;display:inline-flex}.selection-card h4{color:var(--text);margin-bottom:10px;font-size:24px}.selection-card p{color:var(--muted);line-height:1.7}.selection-link{color:var(--primary);margin-top:18px;font-weight:700;display:inline-block}.cuisine-card{min-height:240px}.category-card{min-height:180px}.products-clean-list{flex-direction:column;gap:16px;display:flex}.product-row-clean{border:1px solid var(--line);box-shadow:var(--shadow);background:#fff;border-radius:24px;justify-content:space-between;align-items:center;gap:18px;padding:22px;display:flex}.product-row-main{flex:1}.product-row-top{justify-content:space-between;gap:16px;margin-bottom:8px;display:flex}.product-row-top h4{font-size:22px}.product-row-top span{color:var(--primary);white-space:nowrap;font-weight:700}.product-row-clean p{color:var(--muted);max-width:760px;line-height:1.7}.add-button,.primary-button{background:linear-gradient(135deg, var(--primary), #ef4444);color:#fff;border:none;border-radius:14px;padding:13px 18px;font-weight:700;box-shadow:0 14px 28px #dc262629}.back-button{border:1px solid var(--line);color:var(--text);background:#fff;border-radius:14px;padding:12px 16px;font-weight:700}.checkout-section{padding:34px 0 70px}.checkout-header{justify-content:space-between;align-items:end;gap:20px;margin-bottom:24px;display:flex}.checkout-header h2{margin-top:10px;font-size:38px}.checkout-layout{grid-template-columns:minmax(0,1fr) 380px;align-items:start;gap:24px;display:grid}.checkout-main{flex-direction:column;gap:24px;display:flex}.checkout-card{border:1px solid var(--line);box-shadow:var(--shadow);background:#fff;border-radius:26px;padding:24px}.checkout-card h3{margin-bottom:18px;font-size:24px}.sticky-card{position:sticky;top:98px}.empty-state{color:var(--muted)}.cart-list{flex-direction:column;gap:16px;display:flex}.cart-item{border:1px solid var(--line);background:var(--surface-soft);border-radius:18px;padding:16px}.cart-item-header{justify-content:space-between;align-items:start;gap:12px;margin-bottom:14px;display:flex}.cart-item-header h4{margin-bottom:4px;font-size:18px}.cart-item-header small{color:var(--muted)}.quantity-box{border:1px solid var(--line);background:#fff;border-radius:14px;align-items:center;gap:12px;padding:8px;display:inline-flex}.quantity-box button{background:var(--dark);color:#fff;border:none;border-radius:10px;width:34px;height:34px;font-size:20px}.quantity-box span{text-align:center;min-width:22px;font-weight:700}.switch-row{grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;display:grid}.switch-row button{color:#334155;background:#eef2f7;border:none;border-radius:14px;padding:14px;font-weight:700}.switch-row button.active{background:var(--dark);color:#fff}.switch-row button:disabled{opacity:.55;cursor:not-allowed}.helper-box{color:#334155;border:1px solid var(--line);background:#f8fafc;border-radius:16px;margin-top:16px;padding:14px 16px;line-height:1.6}.form-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:16px;display:grid}.form-group{flex-direction:column;gap:8px;margin-top:16px;display:flex}.form-group label{font-size:14px;font-weight:700}.form-group input,.form-group textarea{border:1px solid var(--line);background:#fff;border-radius:16px;outline:none;width:100%;padding:14px 16px}.form-group input:focus,.form-group textarea:focus{border-color:#dc262659;box-shadow:0 0 0 4px #dc262614}.form-group textarea{resize:vertical}.summary-row{color:#334155;justify-content:space-between;gap:12px;margin-bottom:14px;display:flex}.summary-row.total{border-top:1px solid var(--line);color:var(--text);margin-top:18px;padding-top:16px;font-size:18px;font-weight:700}.message{border-radius:16px;margin-top:16px;padding:14px 16px;font-size:14px;line-height:1.5}.message.error{color:#be123c;background:#fff1f2}.message.success{color:#027a48;background:#ecfdf3}.full-width{width:100%;margin-top:18px}@keyframes pulse{0%{transform:scale(1)}50%{transform:scale(1.07)}to{transform:scale(1)}}@media (max-width:1100px){.selection-grid,.selection-grid.two-col,.hero-info-grid,.checkout-layout,.form-grid{grid-template-columns:1fr}.sticky-card{position:static}}@media (max-width:760px){.topbar-inner{min-height:74px}.brand-mark{width:42px;height:42px;font-size:14px}.brand-title{font-size:18px}.hero-shell-inner,.selection-card,.checkout-card,.product-row-clean{border-radius:22px;padding:20px}.section-header,.checkout-header,.product-row-clean,.cart-item-header{flex-direction:column;align-items:flex-start}.hero-title{font-size:36px}.section-header h3,.checkout-header h2{font-size:30px}.product-row-top{flex-direction:column;align-items:flex-start}}.selection-grid.three-col{grid-template-columns:repeat(3,minmax(0,1fr))}.variant-chips{flex-wrap:wrap;gap:10px;margin-top:14px;display:flex}.variant-chip{color:#334155;background:#f1f5f9;border-radius:999px;padding:8px 12px;font-size:13px;font-weight:600;display:inline-flex}@media (max-width:1100px){.selection-grid.three-col{grid-template-columns:1fr}}.modal-backdrop{-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);z-index:2000;background:#0f172a8c;place-items:center;padding:20px;display:grid;position:fixed;inset:0}.product-modal{background:#fff;border-radius:28px;width:min(720px,100%);max-height:90vh;padding:24px;overflow-y:auto;box-shadow:0 30px 80px #0f172a47}.modal-header{justify-content:space-between;align-items:start;gap:16px;display:flex}.modal-header h3{margin-top:12px;font-size:30px;line-height:1.1}.modal-close{background:#f1f5f9;border:none;border-radius:12px;width:42px;height:42px;font-size:28px;line-height:1}.modal-description{color:#64748b;margin-top:14px;line-height:1.7}.modal-section{margin-top:24px}.modal-section h4{margin-bottom:12px;font-size:18px}.modal-choice-list{flex-direction:column;gap:10px;display:flex}.modal-choice{text-align:left;background:#fff;border:1px solid #e2e8f0;border-radius:16px;justify-content:space-between;align-items:center;gap:14px;padding:14px 16px;display:flex}.modal-choice.active{background:#fff5f5;border-color:#dc2626}.modal-footer{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:16px;margin-top:26px;display:flex}.modal-price-box{flex-direction:column;gap:4px;display:flex}.modal-price-box span{color:#64748b;font-size:14px}.modal-price-box strong{font-size:24px}.cart-option-list{flex-wrap:wrap;gap:8px;margin-top:10px;display:flex}.cart-option-pill{color:#334155;background:#eef2f7;border-radius:999px;padding:6px 10px;font-size:12px;font-weight:600;display:inline-flex}@media (max-width:760px){.product-modal{border-radius:22px;padding:18px}.modal-header{align-items:flex-start}.modal-header h3{font-size:24px}.modal-footer{flex-direction:column;align-items:stretch}}
