:root{--bg: #f3f5f8;--bg-soft: #edf1f6;--surface: #ffffff;--surface-muted: rgba(255, 255, 255, .75);--text: #171a22;--muted: #7d8493;--line: rgba(33, 42, 62, .08);--brand: #3951e9;--brand-strong: #2a40cf;--brand-soft: #e5ebff;--shadow-soft: 0 10px 30px rgba(22, 35, 86, .06);--shadow-card: 0 14px 35px rgba(22, 35, 86, .08);--radius-xl: 28px;--radius-lg: 24px;--radius-md: 20px;--radius-sm: 16px;--font-ui: "Avenir Next", "Helvetica Neue", "Segoe UI", sans-serif}*{box-sizing:border-box}html,body,#root{margin:0;min-height:100%}body{background:linear-gradient(180deg,#f7f9fc,#eff3f7);color:var(--text);font-family:var(--font-ui)}button,input,textarea,select{font:inherit}button{border:0;cursor:pointer}img{display:block}.app-shell{min-height:100vh;padding:14px 14px calc(96px + env(safe-area-inset-bottom))}.app-frame{max-width:760px;margin:0 auto}.loading-card,.error-box,.notice{margin-top:10px;padding:16px 18px;border-radius:var(--radius-md);box-shadow:var(--shadow-soft)}.loading-card,.notice{background:var(--surface)}.error-box{background:#fff1f1;color:#bb4242}.floating-toast{position:fixed;left:50%;bottom:calc(84px + env(safe-area-inset-bottom));transform:translate(-50%);width:min(520px,calc(100% - 32px));padding:12px 16px;border-radius:18px;background:#171c2bf0;color:#fff;text-align:center;box-shadow:0 14px 34px #10131c2e;z-index:20}.hero{margin-bottom:14px}.hero__image-wrap{position:relative;overflow:hidden;height:clamp(240px,48vh,420px);max-height:80svh;border-radius:32px;background:#dbe3f3;box-shadow:var(--shadow-card)}.hero__image{width:100%;height:100%;object-fit:cover;object-position:center}.hero__overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(180deg,#0f16281f,#0f162885),linear-gradient(90deg,rgba(15,22,40,.26),transparent 45%)}.hero__content{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;justify-content:space-between;padding:18px;color:#fff}.hero__topline{display:flex;align-items:flex-start;justify-content:space-between;gap:16px}.hero__brand{display:inline-block;font-size:18px;font-weight:700}.hero__topline p{margin:4px 0 0;color:#ffffffd1;font-size:13px}.hero__profile{width:40px;height:40px;border-radius:50%;background:#ffffffeb;color:var(--text);font-weight:700}.hero__copy{max-width:340px}.section-title__eyebrow,.status-card__eyebrow{display:inline-block;margin-bottom:8px;font-size:12px;text-transform:uppercase;letter-spacing:.14em}.hero__copy h1{margin:0;font-size:clamp(28px,6vw,42px);line-height:1.02;letter-spacing:-.04em}.hero__copy p{margin:10px 0 0;color:#ffffffd9;font-size:14px}.category-strip{display:flex;gap:10px;overflow-x:auto;padding:6px 2px 12px;margin-bottom:10px;scrollbar-width:none;-ms-overflow-style:none}.category-strip::-webkit-scrollbar,.product-rail::-webkit-scrollbar{display:none}.category-chip{white-space:nowrap;padding:10px 14px;border-radius:999px;background:#ffffffa6;color:var(--muted);box-shadow:inset 0 0 0 1px #ffffffd9}.category-chip.is-active{background:var(--surface);color:var(--text);box-shadow:var(--shadow-soft)}.catalog-layout{display:grid;gap:18px}.status-card,.section-block{background:transparent}.catalog-layout>*{min-width:0}.section-block{min-width:0}.section-block--rail{overflow:visible}.section-block--content{width:100%;min-width:0}.status-card{display:flex;align-items:flex-start;justify-content:space-between;gap:18px;padding:18px;border-radius:var(--radius-lg);background:#ffffffc2;box-shadow:var(--shadow-soft)}.status-card__main{display:grid;gap:10px;min-width:0}.status-card strong,.status-card p{display:block}.status-card p{margin:6px 0 0;color:var(--muted)}.status-card__amount{white-space:nowrap}.status-card__items{display:grid;gap:8px}.order-preview-item{display:flex;align-items:center;gap:10px;min-width:0}.order-preview-item__thumb{width:42px;height:42px;overflow:hidden;flex-shrink:0;border-radius:14px;background:linear-gradient(180deg,#fafbfd,#edf1f5)}.order-preview-item__thumb img{width:100%;height:100%;object-fit:cover}.order-preview-item__thumb.is-placeholder{padding:18%;background:linear-gradient(180deg,#fbfcfe,#f1f4f8)}.order-preview-item__thumb.is-placeholder img{object-fit:contain}.order-preview-item__copy{display:grid;gap:2px;min-width:0}.order-preview-item__copy strong{display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;font-size:13px;line-height:1.25}.order-preview-item__copy span{color:var(--muted);font-size:12px}.section-title{display:flex;align-items:flex-end;justify-content:space-between;gap:16px;margin-bottom:12px}.section-title h2{margin:0;font-size:30px;line-height:1.02;letter-spacing:-.03em}.section-title p{max-width:280px;margin:0;color:var(--muted);font-size:14px}.product-rail{display:grid;grid-auto-flow:column;grid-auto-columns:minmax(146px,164px);gap:12px;overflow-x:auto;padding-bottom:4px;align-items:stretch;scrollbar-width:none;-ms-overflow-style:none}.story-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;align-items:stretch}.story-card{position:relative;overflow:hidden;min-height:188px;padding:0;border-radius:24px;background:#dfe5ee;box-shadow:var(--shadow-soft)}.story-card__body{display:block;width:100%;height:100%;padding:0;background:transparent}.story-card img{width:100%;height:100%;object-fit:cover}.story-card img.is-placeholder{padding:16%;object-fit:contain;background:linear-gradient(180deg,#fbfcfe,#eef2f6)}.story-card__overlay{position:absolute;inset:auto 0 0;display:flex;align-items:flex-end;justify-content:space-between;gap:12px;padding:14px;background:linear-gradient(180deg,transparent,rgba(12,15,24,.52));color:#fff;text-align:left}.story-card__overlay strong{max-width:160px;font-size:16px}.story-card__overlay--menu{padding-right:70px}.story-card__details{display:grid;gap:8px;min-width:0}.story-card__details strong{display:-webkit-box;max-width:none;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}.story-card__details span{font-size:15px;font-weight:700}.story-card__add{position:absolute;right:14px;bottom:14px;display:inline-flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:50%;background:#ffffffeb;color:var(--ink);font-size:24px;line-height:1;font-weight:500;box-shadow:0 10px 22px #0c0f182e}.story-card__add:disabled{opacity:.52;cursor:not-allowed}.story-card__soldout{position:absolute;top:10px;right:10px;z-index:2;padding:8px 10px;border-radius:999px;background:#d2d6dfeb;color:#4f5563;font-size:12px;font-weight:600}.menu-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;align-items:stretch;width:100%;min-width:0;overflow:hidden}.product-card{position:relative;display:grid;grid-template-rows:auto auto;gap:10px;align-content:start;min-width:0;width:100%;padding:10px;overflow:hidden;border-radius:24px;background:var(--surface);box-shadow:var(--shadow-soft)}.product-card.is-compact{padding:10px}.product-card__body{display:grid;align-content:start;min-width:0;min-height:0;padding:0;background:transparent;text-align:left}.product-card__image-wrap{position:relative;overflow:hidden;aspect-ratio:1 / 1;margin-bottom:8px;border-radius:18px;background:linear-gradient(180deg,#fafbfd,#edf1f5)}.product-card__image-wrap.is-placeholder{padding:18%;background:linear-gradient(180deg,#fbfcfe,#f1f4f8)}.product-card.is-compact .product-card__image-wrap{aspect-ratio:.95 / 1}.product-card__image{width:100%;height:100%;object-fit:cover}.product-card__image-wrap.is-placeholder .product-card__image{object-fit:contain}.product-card__soldout{position:absolute;top:10px;right:10px;padding:8px 10px;border-radius:999px;background:#d2d6dfeb;color:#4f5563;font-size:12px;font-weight:600}.product-card__meta{display:flex;align-items:flex-start;justify-content:space-between;gap:8px;min-width:0;min-height:56px}.product-card__name{display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;min-width:0;min-height:56px;font-size:15px;font-weight:600;line-height:1.25;align-self:start}.product-card.is-compact .product-card__name{height:3.75em;min-height:3.75em;max-height:3.75em}.product-card__badge{flex-shrink:0;padding:4px 8px;border-radius:999px;background:var(--brand-soft);color:var(--brand-strong);font-size:11px;text-transform:uppercase}.product-card__footer{display:flex;align-items:center;justify-content:space-between;gap:10px;min-width:0;margin-top:auto}.product-card__price{font-size:16px;font-weight:700}.product-card__hint{color:var(--muted);font-size:12px;margin-left:auto}.product-card__add{display:inline-flex;align-items:center;justify-content:center;flex-shrink:0;width:42px;height:42px;border-radius:50%;background:var(--brand);color:#fff;font-size:22px;font-weight:600;box-shadow:0 10px 24px #3951e93d}.product-card.is-compact .product-card__footer{margin-top:0;align-items:center}.product-card.is-compact .product-card__price{display:inline-flex;align-items:center;min-height:40px}.product-card.is-compact .product-card__add{width:40px;height:40px;font-size:24px;line-height:1}.product-card__add:disabled{opacity:.48;cursor:not-allowed}.cart-bar{position:fixed;left:50%;bottom:12px;transform:translate(-50%);display:grid;grid-template-columns:auto auto;align-items:center;gap:14px;justify-content:space-between;width:min(720px,calc(100% - 24px));padding:14px 18px;border-radius:999px;background:var(--brand);color:#fff;box-shadow:0 18px 38px #3951e947}.cart-bar__summary{display:inline-flex;align-items:center;gap:8px;text-align:left}.cart-bar__summary span{font-size:12px;color:#fffc}.cart-bar__total{white-space:nowrap}.cart-overlay{position:fixed;top:0;right:0;bottom:0;left:0;display:flex;align-items:flex-end;justify-content:center;padding:8px;background:#0e122247;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.profile-overlay{position:fixed;top:0;right:0;bottom:0;left:0;display:flex;align-items:flex-start;justify-content:center;padding:16px 12px calc(16px + env(safe-area-inset-bottom));background:#0e122266;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);z-index:30}.profile-sheet{display:grid;grid-template-rows:auto 1fr;width:min(760px,100%);max-height:calc(100dvh - 32px);border-radius:30px;background:#eff3f7;box-shadow:0 30px 70px #111a3f2e;overflow:hidden}.profile-sheet__header{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:20px 18px 12px}.profile-sheet__header span{display:block;color:var(--muted);font-size:12px;letter-spacing:.12em;text-transform:uppercase}.profile-sheet__header strong{display:block;margin-top:4px;font-size:28px;line-height:1.04}.profile-sheet__close{width:42px;height:42px;border-radius:50%;background:var(--surface);color:var(--text);font-size:26px;line-height:1}.profile-sheet__body{overflow:auto;display:grid;gap:16px;padding:0 18px 18px}.profile-card,.profile-history__item{display:grid;gap:14px;padding:16px;border-radius:24px;background:var(--surface);box-shadow:var(--shadow-soft)}.profile-card{gap:18px}.profile-card__identity{display:flex;align-items:center;gap:18px}.profile-card__avatar{display:inline-flex;align-items:center;justify-content:center;width:78px;height:78px;border-radius:50%;background:linear-gradient(180deg,#eef2f7,#d9e0ea);color:#798396;font-size:34px;font-weight:700;flex-shrink:0;box-shadow:inset 0 0 0 1px #212a3e0f}.profile-card__identity-copy{display:grid;gap:6px;min-width:0;flex:1}.profile-card__identity-copy strong{display:block;font-size:34px;line-height:1;letter-spacing:-.03em}.profile-card__identity-copy span{color:var(--muted);font-size:18px}.profile-card__arrow{color:#a8b0bc;font-size:48px;line-height:1;flex-shrink:0}.profile-history,.profile-history__list{display:grid;gap:12px}.profile-history__topline{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}.profile-history__topline strong,.profile-history__meta strong{display:block}.profile-history__topline span,.profile-history__meta span{color:var(--muted);font-size:13px}.profile-history__meta{text-align:right}.profile-history__products{display:grid;gap:8px}.order-preview-item--history .order-preview-item__thumb{width:46px;height:46px}.cart-sheet{display:grid;grid-template-rows:auto 1fr auto;width:min(760px,100%);height:min(calc(100dvh - 16px),980px);border-radius:32px;background:#eff3f7;box-shadow:0 30px 70px #111a3f2e}.cart-sheet__header,.cart-sheet__footer{display:flex;align-items:center;justify-content:space-between;gap:14px;padding:18px}.cart-sheet__icon-button{width:42px;height:42px;border-radius:50%;background:var(--surface);color:var(--text);font-size:26px;line-height:1}.cart-sheet__title{text-align:center}.cart-sheet__title span{display:block;color:var(--muted);font-size:12px;text-transform:uppercase;letter-spacing:.12em}.cart-sheet__meta{min-width:42px;text-align:right;color:var(--muted)}.cart-sheet__body{overflow:auto;padding:0 18px 18px}.cart-items,.cart-form{display:grid;gap:12px}.cart-items{padding-bottom:12px}.cart-item{display:flex;align-items:center;gap:14px;padding:14px;border-radius:22px;background:var(--surface);box-shadow:var(--shadow-soft)}.cart-item__image-wrap{width:60px;height:60px;border-radius:18px;background:var(--bg-soft);overflow:hidden;flex-shrink:0}.cart-item__image{width:100%;height:100%;object-fit:cover}.cart-item__image-wrap.is-placeholder{padding:12px;background:linear-gradient(180deg,#fbfcfe,#eef2f6)}.cart-item__image-wrap.is-placeholder .cart-item__image{object-fit:contain}.cart-item__copy{display:grid;gap:4px;flex:1}.cart-item__copy small{color:var(--muted);font-size:12px}.cart-item__copy span,.order-preview-item__copy span{color:var(--muted);font-size:14px}.cart-item__controls{display:inline-flex;align-items:center;gap:10px}.cart-item__controls button{width:34px;height:34px;border-radius:50%;background:var(--bg-soft)}.field{display:grid;gap:8px}.field--soft{padding:14px;border-radius:22px;background:var(--surface);box-shadow:var(--shadow-soft)}.field span{color:var(--muted);font-size:12px;text-transform:uppercase;letter-spacing:.12em}.field input,.field textarea,.field select{width:100%;padding:14px 16px;border-radius:18px;border:1px solid var(--line);background:var(--surface);box-shadow:var(--shadow-soft)}.field textarea{min-height:104px;resize:vertical}.field--soft input,.field--soft textarea{border:1px solid rgba(33,42,62,.08);box-shadow:none}.time-picker{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:8px}.time-picker__option{min-height:52px;padding:10px 12px;border-radius:16px;background:var(--bg-soft);color:var(--text);font-weight:600}.time-picker__option.is-active{background:var(--brand);color:#fff;box-shadow:0 10px 24px #3951e938}.time-picker__empty{padding:12px 14px;border-radius:16px;background:var(--bg-soft);color:var(--muted);font-size:14px;line-height:1.4}.cart-sheet__footer{position:sticky;bottom:0;background:#eff3f7f0;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-top:1px solid rgba(33,42,62,.06)}.cart-sheet__total{display:grid;gap:2px}.cart-sheet__total span{color:var(--muted);font-size:12px;text-transform:uppercase}.cart-sheet__submit{min-width:220px;padding:16px 22px;border-radius:999px;background:var(--brand);color:#fff;font-weight:700}.cart-sheet__submit:disabled{opacity:.5;cursor:not-allowed}.empty-state{display:grid;gap:6px;padding:18px;border-radius:22px;background:var(--surface);box-shadow:var(--shadow-soft)}.empty-state p{margin:0;font-size:18px;font-weight:700}.empty-state span{color:var(--muted)}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;padding:8px;background:#0e12227a;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.product-modal{position:relative;overflow:hidden;width:min(760px,100%);height:min(calc(100dvh - 16px),920px);border-radius:32px;background:#141a2b;box-shadow:0 30px 80px #131e584d}.product-modal__media,.product-modal__image-wrap,.product-modal__scrim{position:absolute;top:0;right:0;bottom:0;left:0}.product-modal__scrim{background:linear-gradient(180deg,#0d111e80,#0d111e14 28%,#0d111e94),linear-gradient(0deg,#0d111e66,#0d111e66)}.product-modal__image-wrap{overflow:hidden;background:#10162a}.product-modal__image-wrap.is-placeholder{background:radial-gradient(circle at top,#f5f7fb,#dce3ed 62%,#cfd8e5)}.product-modal__image{width:100%;height:100%;object-fit:cover}.product-modal__image-wrap.is-placeholder .product-modal__image{object-fit:contain;padding:12%}.product-modal__topbar{position:absolute;top:18px;left:18px;right:18px;z-index:2;display:grid;grid-template-columns:48px 1fr 48px;align-items:start;gap:14px}.product-modal__icon-button{display:inline-flex;align-items:center;justify-content:center;width:48px;height:48px;border-radius:999px;background:#ffffff2e;color:#fff;font-size:28px;line-height:1;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);box-shadow:inset 0 0 0 1px #ffffff29}.product-modal__icon-button--favorite{padding:0}.product-modal__icon-glyph{display:inline-flex;align-items:center;justify-content:center;width:1em;height:1em;transform:translateY(1px)}.product-modal__icon-button.is-active{background:#ffffff3d}.product-modal__title{padding-top:4px;color:#fff;text-align:center}.product-modal__title h3{margin:0;font-size:clamp(28px,4vw,34px);line-height:1.05}.product-modal__title p{margin:6px 0 0;color:#ffffffd6;font-size:13px}.product-modal__bottom{position:absolute;left:16px;right:16px;bottom:calc(16px + env(safe-area-inset-bottom));z-index:2;display:grid;gap:12px}.product-modal__details-toggle{justify-self:center;padding:8px 14px;border-radius:999px;background:#ffffff29;color:#fff;font-size:14px;font-weight:600;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);box-shadow:inset 0 0 0 1px #ffffff29}.product-modal__details-toggle:after{content:"˅";margin-left:6px}.product-modal__details-toggle.is-open:after{content:"˄"}.product-modal__details-card{display:grid;gap:14px;padding:18px;border-radius:26px;background:#fffffff5;box-shadow:0 20px 40px #0a0e1a29}.product-modal__details-block{display:grid;gap:6px}.product-modal__details-block span{color:var(--muted);font-size:12px;letter-spacing:.08em;text-transform:uppercase}.product-modal__details-block p{margin:0;line-height:1.45}.product-modal__action-bar{display:grid;grid-template-columns:minmax(0,192px) minmax(0,1fr);gap:12px;padding:10px;border-radius:30px;background:#272e468f;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);box-shadow:inset 0 0 0 1px #ffffff1a}.product-modal__action-bar.is-single{grid-template-columns:1fr}.product-modal__size-switch{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:6px;padding:6px;border-radius:999px;background:#ffffff24}.product-modal__size-button{display:grid;justify-items:center;gap:2px;min-height:58px;padding:8px 10px;border-radius:999px;background:transparent;color:#ffffffc7}.product-modal__size-button strong{font-size:18px;line-height:1}.product-modal__size-button span{font-size:11px}.product-modal__size-button.is-active{background:#fff;color:var(--text);box-shadow:0 8px 18px #0e12221f}.product-modal__submit{min-height:70px;padding:16px 22px;border-radius:999px;background:var(--brand);color:#fff;font-size:22px;font-weight:700;box-shadow:0 18px 36px #3951e93d}.product-modal__submit:disabled{opacity:.52;cursor:not-allowed}@media(max-width:640px){.app-shell{padding-inline:10px}.hero__image-wrap{height:clamp(220px,42vh,320px);max-height:80svh}.hero__copy h1{font-size:30px}.section-title{display:grid;gap:8px}.section-title h2{font-size:26px}.menu-grid,.story-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.cart-bar{grid-template-columns:1fr auto;gap:10px}.floating-toast{bottom:calc(76px + env(safe-area-inset-bottom));width:calc(100% - 20px)}.cart-bar__cta{display:none}.cart-sheet__footer{display:grid;gap:12px}.profile-overlay{padding-inline:8px;padding-top:8px}.profile-sheet{max-height:calc(100dvh - 16px);border-radius:26px}.profile-sheet__header strong{font-size:24px}.profile-card__avatar{width:68px;height:68px;font-size:30px}.profile-card__identity-copy strong{font-size:28px}.profile-card__identity-copy span{font-size:16px}.profile-card__arrow{font-size:42px}.cart-sheet__submit{width:100%;min-width:0}.time-picker{grid-template-columns:repeat(2,minmax(0,1fr))}.product-modal{width:100%;height:calc(100dvh - 8px);border-radius:28px}.product-modal__topbar{top:14px;left:14px;right:14px;grid-template-columns:44px 1fr 44px;gap:10px}.product-modal__icon-button{width:44px;height:44px;font-size:24px}.product-modal__title h3{font-size:28px}.product-modal__bottom{left:12px;right:12px;bottom:calc(12px + env(safe-area-inset-bottom))}.product-modal__action-bar{grid-template-columns:1fr}}@media(max-width:420px){.app-shell{padding-inline:8px}.menu-grid,.story-grid{gap:10px}.product-card{padding:9px}.product-card__name{font-size:14px;min-height:52px}.product-card.is-compact .product-card__name{height:3.75em;min-height:3.75em;max-height:3.75em}.product-card__price{font-size:15px}.product-card__hint{font-size:11px}.profile-sheet__header,.profile-sheet__body{padding-inline:14px}.profile-card__identity{gap:14px}.profile-card__avatar{width:60px;height:60px;font-size:26px}.profile-card__identity-copy strong{font-size:24px}.profile-card__identity-copy span{font-size:15px}.profile-card__arrow{font-size:34px}.profile-history__topline{display:grid}}@media(max-width:420px){.product-modal__title h3{font-size:24px}.product-modal__size-button strong{font-size:16px}.product-modal__submit{min-height:64px;font-size:20px}}
