:root{--bg: #2e3034;--surface: #2e3034;--elevated: #111111;--text: #ffffff;--text-muted: #7a7a7a;--border: rgba(255, 255, 255, .08);--bg-primary: #2e3034;--bg-secondary: #111111;--text-primary: #ffffff;--text-secondary: #7a7a7a}*{margin:0;padding:0;box-sizing:border-box}body{background:var(--bg);color:var(--text);font-family:-apple-system,Segoe UI,system-ui,sans-serif;min-height:100vh;-webkit-font-smoothing:antialiased}#root{min-height:100vh}*{scrollbar-width:none;-ms-overflow-style:none}*::-webkit-scrollbar{display:none}.app{max-width:480px;margin:0 auto;min-height:auto;background:var(--bg);position:relative;padding-bottom:var(--nav-h)}.app--admin{padding-bottom:60px}:root{--searchbar-h: 64px;--nav-h: 60px}.search-bar{position:sticky;top:0;z-index:60;background:var(--bg);height:var(--searchbar-h);padding:0 12px;display:flex;align-items:center;gap:10px}.admin-badge{flex-shrink:0;font-size:11px;font-weight:700;letter-spacing:.08em;color:#000;background:#fff;text-transform:uppercase;padding:4px 10px;border-radius:20px;white-space:nowrap;cursor:pointer;display:inline-flex;align-items:center;line-height:1}.search-wrap{flex:1;display:flex;align-items:center;gap:10px;height:44px;padding:0 14px;background:var(--elevated);border-radius:12px;color:var(--text-muted)}.search-icon{display:flex;align-items:center;flex-shrink:0}.search-input{flex:1;background:transparent;border:none;outline:none;color:var(--text);font-size:15px;height:44px;line-height:44px}.search-input::placeholder{color:var(--text-muted)}.banner{width:calc(100% - 24px);height:150px;margin:0 12px 8px;border-radius:12px;overflow:hidden;background:#111}.banner-img{display:block;width:100%;height:100%;object-fit:cover}.cats{position:relative;z-index:50;background:var(--bg);padding:10px 12px 8px;display:flex;gap:8px;overflow-x:auto;scrollbar-width:none}.cats::-webkit-scrollbar{display:none}.cats--stuck{position:sticky;top:var(--searchbar-h);background:var(--bg)}.cat-btn{flex-shrink:0;padding:6px 16px;border:1px solid rgba(255,255,255,.3);border-radius:20px;background:transparent;color:#fff;font-size:11px;font-weight:600;letter-spacing:.07em;cursor:pointer;transition:background .15s,color .15s,border-color .15s}.cat-btn.active{background:#fff;border-color:#fff;color:#000}.cat-section{margin-bottom:8px}.cat-header{padding:12px 12px 8px}.cat-header-label{display:inline-block;background:#fff;color:#000;font-size:12px;font-weight:700;letter-spacing:.05em;padding:6px 14px;border-radius:20px;pointer-events:none}.cat-stuck-bar{position:sticky;top:var(--searchbar-h);z-index:59;background:var(--bg);padding:6px 12px 8px;margin-top:-6px}.cat-stuck-label{display:inline-block;background:#fff;color:#000;font-size:12px;font-weight:700;letter-spacing:.05em;padding:6px 14px;border-radius:20px}.grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;padding:10px 12px 0}.card{background:var(--surface);border-radius:10px;overflow:hidden;display:flex;flex-direction:column;cursor:pointer;transition:opacity .15s}.card:active{opacity:.85}.card-img{width:100%;aspect-ratio:1/1;overflow:hidden;border-radius:10%}.card-img img{width:100%;height:100%;object-fit:cover}.card-img-placeholder{width:100%;height:100%;background:linear-gradient(135deg,#2e2416,#1e1a12)}.card-body{padding:8px;display:flex;flex-direction:column;flex:1;gap:3px}.card-name{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.02em;color:var(--text);line-height:1.3}.card-desc{font-size:10px;color:var(--text-muted);line-height:1.45;flex:1;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.card-desc--full{display:block;-webkit-line-clamp:unset;overflow:visible}.card-price{display:block;font-size:14px;font-weight:700;color:var(--text);margin-top:4px}.card-price-per{font-size:10px;font-weight:400;color:var(--text-muted)}.card-composition{font-size:10px;color:var(--text-muted);margin-top:4px;line-height:1.4}.btn-add{margin-top:6px;width:100%;height:34px;padding:2px 4px;background:#fff;border:none;border-radius:8px;color:#000;font-size:10px;font-weight:700;cursor:pointer;transition:background .15s;letter-spacing:.03em;display:flex;align-items:center;justify-content:center;box-sizing:border-box}.btn-add:active{background:#e0e0e0}.btn-in-cart{margin-top:6px;width:100%;padding:7px 4px;background:#fff;border:none;border-radius:8px;color:#000;font-size:10px;font-weight:700;cursor:pointer;transition:background .15s;letter-spacing:.03em}.btn-in-cart:active{background:#e0e0e0}.qty-row{display:flex;align-items:center;justify-content:space-between;margin-top:6px;gap:4px}.cart-inline-btn{flex-shrink:0;padding:5px 8px;background:#fff;border:1px solid #ffffff;border-radius:6px;color:#000;font-size:9px;font-weight:700;cursor:pointer;white-space:nowrap}.qty-controls{display:flex;align-items:center;justify-content:space-between;width:100%;background:#111;border-radius:8px;padding:2px;margin-top:6px}.qty-btn{width:30px;height:30px;background:#2a2a2a;border:none;color:#fff;font-size:16px;font-weight:400;cursor:pointer;display:flex;align-items:center;justify-content:center;border-radius:6px;transition:background .1s;line-height:1;padding:0}.qty-btn:active{background:#3a3a3a}.qty-label{font-size:12px;font-weight:600;color:#fff;min-width:46px;text-align:center}.cart-fab{position:fixed;bottom:12px;right:16px;width:52px;height:52px;background:#fff;border:none;border-radius:14px;color:#000;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 16px #0006;z-index:100}.cart-fab-badge{position:absolute;top:-6px;right:-6px;min-width:18px;height:18px;background:#222;color:#fff;border-radius:9px;font-size:10px;font-weight:700;display:flex;align-items:center;justify-content:center;padding:0 4px;border:1.5px solid var(--bg)}.admin-footer-nav{position:fixed;bottom:0;left:50%;transform:translate(-50%);width:100%;max-width:480px;height:var(--nav-h);background:var(--elevated);border-top:1px solid rgba(255,255,255,.08);display:flex;align-items:stretch;z-index:200}.footer-nav-btn{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;padding:8px 0 10px;background:transparent;border:none;color:var(--text-muted);font-size:10px;font-weight:500;cursor:pointer;transition:color .15s;letter-spacing:.03em}.footer-nav-btn.active{color:#fff}.cart-view{position:fixed;top:0;left:0;right:0;bottom:var(--nav-h);display:flex;flex-direction:column;background:var(--bg);overflow:hidden}.cart-header{display:flex;align-items:center;gap:12px;padding:14px 16px}.back-btn{background:transparent;border:none;color:var(--text);cursor:pointer;display:flex;align-items:center;padding:4px}.cart-title{font-size:18px;font-weight:700;color:var(--text)}.cart-items{flex:1;overflow-y:auto;padding:0 16px 16px}.cart-empty{color:var(--text-muted);text-align:center;margin-top:60px;font-size:14px}.cart-item{display:flex;gap:12px;padding:14px 0;border-bottom:1px solid var(--border)}.cart-item-img{width:72px;height:72px;border-radius:8px;overflow:hidden;flex-shrink:0}.cart-item-img img{width:100%;height:100%;object-fit:cover}.cart-item-img-ph{width:100%;height:100%;background:linear-gradient(135deg,#2e2416,#1e1a12)}.cart-item-info{display:flex;flex-direction:column;gap:4px;flex:1}.cart-item-name{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.04em;color:var(--text);line-height:1.3}.cart-item-price{font-size:15px;font-weight:700;color:var(--text)}.cart-price-per{font-size:11px;font-weight:400;color:var(--text-muted)}.cart-footer{background:var(--elevated);padding:16px 16px 24px;border-top:1px solid var(--border);border-radius:24px 24px 0 0}.cart-delivery{font-size:12px;color:var(--text-muted);text-align:center;margin-bottom:12px}.cart-total-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:14px;font-size:14px;color:var(--text)}.cart-total-price{font-size:16px;font-weight:700}.btn-checkout{width:100%;padding:14px;background:#e8e8e8;border:none;border-radius:12px;color:#111;font-size:15px;font-weight:600;cursor:pointer;transition:background .15s}.btn-checkout:active{background:#d0d0d0}.btn-checkout:disabled{opacity:.45;cursor:not-allowed}.detail-view{display:flex;flex-direction:column;min-height:100vh;background:var(--bg);max-width:480px;margin:0 auto;padding-bottom:32px}.detail-slider{position:relative;width:100%;aspect-ratio:1/1;overflow:hidden;background:#1a1208}.detail-slides{display:flex;width:100%;height:100%;transition:transform .35s cubic-bezier(.4,0,.2,1)}.detail-slide{flex-shrink:0;width:100%;height:100%}.detail-slide img{width:100%;height:100%;object-fit:cover}.detail-slide-placeholder{width:100%;height:100%;background:linear-gradient(135deg,#2e2416,#1e1a12)}.detail-dots{position:absolute;bottom:12px;left:50%;transform:translate(-50%);display:flex;gap:6px}.detail-dot{width:6px;height:6px;border-radius:50%;background:#ffffff59;border:none;cursor:pointer;padding:0;transition:background .2s,width .2s}.detail-dot.active{background:#fff;width:18px;border-radius:3px}.detail-back-btn{position:absolute;top:12px;left:12px;width:36px;height:36px;background:#00000073;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:none;border-radius:10px;color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center}.detail-content{padding:20px 16px 0;display:flex;flex-direction:column;gap:12px}.detail-name{font-size:20px;font-weight:800;text-transform:uppercase;letter-spacing:.03em;color:var(--text);line-height:1.2}.detail-price-block{background:#1a1a1a;border-radius:14px;padding:16px}.detail-price{font-size:24px;font-weight:700;color:var(--text)}.detail-price-per{font-size:14px;font-weight:400;color:var(--text-muted)}.detail-desc-block{background:#1a1a1a;border-radius:14px;padding:16px}.detail-composition{background:#1a1a1a;border-radius:14px;padding:12px 16px}.detail-composition-title{font-size:11px;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:8px}.detail-composition-item{display:flex;justify-content:space-between;align-items:center;padding:6px 0;border-bottom:1px solid rgba(255,255,255,.06)}.detail-composition-item:last-child{border-bottom:none}.detail-composition-name{font-size:13px;color:var(--text)}.detail-composition-qty{font-size:12px;color:var(--text-muted)}.detail-desc{font-size:14px;color:var(--text-muted);line-height:1.6;margin:0;white-space:pre-wrap}.detail-footer{position:fixed;bottom:var(--nav-h);left:50%;transform:translate(-50%);width:100%;max-width:480px;padding:12px 16px 16px;background:var(--bg);border-top:1px solid var(--border);z-index:100}.detail-add-btn{width:100%;padding:15px;background:#fff;border:none;border-radius:14px;color:#111;font-size:15px;font-weight:700;cursor:pointer;transition:background .15s;letter-spacing:.02em}.detail-add-btn:active{background:#e0e0e0}.detail-cart-row{display:flex;gap:10px;align-items:center}.detail-in-cart-btn{flex:1;padding:15px;background:#fff;border:none;border-radius:14px;color:#000;font-size:14px;font-weight:600;cursor:pointer}.detail-qty{display:flex;align-items:center;background:#ffffff12;border-radius:14px;padding:0 4px;height:52px}.detail-qty-btn{width:40px;height:44px;background:transparent;border:none;color:var(--text);font-size:22px;font-weight:300;cursor:pointer;display:flex;align-items:center;justify-content:center;border-radius:10px;transition:background .1s}.detail-qty-btn:active{background:#ffffff1a}.detail-qty-label{font-size:13px;font-weight:700;color:var(--text);min-width:58px;text-align:center}.admin-panel{display:flex;flex-direction:column;min-height:100vh;background:var(--bg);max-width:480px;margin:0 auto;padding-bottom:80px}.admin-header{display:flex;align-items:center;gap:10px;padding:14px 16px;border-bottom:1px solid var(--border);position:sticky;top:0;background:var(--bg);z-index:10}.admin-title{flex:1;font-size:18px;font-weight:700;color:var(--text)}.admin-add-btn{display:flex;align-items:center;gap:5px;padding:7px 12px;background:#ffffff12;border:1px solid rgba(255,255,255,.15);border-radius:8px;color:var(--text);font-size:12px;font-weight:600;cursor:pointer;transition:background .15s}.admin-list{display:flex;flex-direction:column;padding:8px 0}.admin-empty{color:var(--text-muted);text-align:center;padding:40px 16px;font-size:14px}.admin-item{display:flex;align-items:center;gap:12px;padding:12px 16px;border-bottom:1px solid var(--border);cursor:pointer;transition:background .1s}.admin-item:active{background:#ffffff08}.admin-item-img{width:52px;height:52px;border-radius:8px;overflow:hidden;flex-shrink:0}.admin-item-img img{width:100%;height:100%;object-fit:cover}.admin-item-img-ph{width:100%;height:100%;background:linear-gradient(135deg,#2e2416,#1e1a12)}.admin-item-info{display:flex;flex-direction:column;gap:3px;flex:1;min-width:0}.admin-item-name{font-size:13px;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.admin-item-sub{font-size:11px;color:var(--text-muted)}.admin-item-actions{display:flex;align-items:center;gap:4px;flex-shrink:0}.admin-icon-btn{width:30px;height:30px;background:transparent;border:1px solid rgba(255,255,255,.1);border-radius:7px;color:var(--text-muted);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .1s,color .1s}.admin-icon-btn:hover{color:var(--text);background:#ffffff0f}.admin-icon-btn.danger:hover{color:#e05555;border-color:#e055554d}.admin-icon-btn:disabled{opacity:.25;cursor:default}.form-saving-overlay{position:absolute;inset:-16px -20px;background:#0000008c;border-radius:16px;z-index:10;display:flex;align-items:center;justify-content:center}.form-saving-spinner{width:36px;height:36px;border:3px solid rgba(255,255,255,.15);border-top-color:#fff;border-radius:50%;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.modal-overlay{position:fixed;inset:0;background:#000000b3;z-index:300;display:flex;align-items:flex-end;justify-content:center}.modal-sheet{width:100%;max-width:480px;background:#1a1a1a;border-radius:20px 20px 0 0;padding-bottom:32px;max-height:90vh;overflow-y:auto}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:18px 20px 14px;border-bottom:1px solid var(--border)}.modal-title{font-size:16px;font-weight:700;color:var(--text)}.modal-close{width:30px;height:30px;background:#ffffff12;border:none;border-radius:8px;color:var(--text-muted);font-size:14px;cursor:pointer;display:flex;align-items:center;justify-content:center}.modal-body{padding:16px 20px}.admin-form{display:flex;flex-direction:column;gap:12px}.form-label{font-size:12px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;margin-bottom:-6px}.form-input{width:100%;padding:12px 14px;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:10px;color:var(--text);font-size:14px;outline:none;transition:border-color .15s}.form-input:focus{border-color:#ffffff40}.form-textarea{width:100%;padding:12px 14px;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:10px;color:var(--text);font-size:14px;outline:none;resize:none;font-family:inherit;transition:border-color .15s}.form-textarea:focus{border-color:#ffffff40}.form-image-picker{width:100%;aspect-ratio:16/9;border-radius:10px;overflow:hidden;border:1.5px dashed rgba(255,255,255,.15);cursor:pointer;display:flex;align-items:center;justify-content:center}.form-image-preview{width:100%;height:100%;object-fit:cover}.form-image-placeholder{display:flex;flex-direction:column;align-items:center;gap:8px;color:var(--text-muted);font-size:13px}.form-unit-toggle{display:flex;gap:8px;margin-bottom:12px}.form-unit-btn{flex:1;padding:10px;border-radius:10px;border:1px solid var(--border);background:transparent;color:var(--text-muted);font-size:13px;font-weight:600;cursor:pointer}.form-unit-btn.active{background:var(--accent, #fff);color:#000;border-color:var(--accent, #fff)}.composition-list{display:flex;flex-direction:column;gap:6px;margin-bottom:12px}.composition-item{display:flex;align-items:center;gap:8px;padding:8px 10px;background:var(--card-bg, #1a1a1a);border-radius:10px;border:1px solid var(--border)}.composition-item-name{flex:1;font-size:13px;font-weight:600;color:var(--text)}.composition-item-qty{font-size:12px;color:var(--text-muted);white-space:nowrap}.composition-item-remove{background:none;border:none;color:var(--text-muted);cursor:pointer;font-size:13px;padding:0 2px;line-height:1}.composition-add-btn{display:flex;align-items:center;justify-content:center;gap:6px;padding:10px;border-radius:10px;border:1px dashed var(--border);background:transparent;color:var(--text-muted);font-size:13px;font-weight:600;cursor:pointer;width:100%}.composition-add-btn:active{opacity:.7}.form-actions{display:flex;gap:10px;margin-top:4px}.form-btn-cancel{flex:1;padding:13px;background:transparent;border:1px solid rgba(255,255,255,.12);border-radius:12px;color:var(--text-muted);font-size:14px;font-weight:600;cursor:pointer}.form-btn-save{flex:2;padding:13px;background:#fff;border:none;border-radius:12px;color:#111;font-size:14px;font-weight:700;cursor:pointer;transition:background .15s}.form-btn-save:active{background:#e0e0e0}.form-btn-save:disabled{opacity:.5;cursor:default}.card--row{display:flex;flex-direction:row;align-items:center;gap:10px;padding:10px 12px;min-height:unset}.card--row .card-body{flex:1;min-width:0}.card--row .card-name{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.card-img--sm{width:52px;height:52px;flex-shrink:0;border-radius:8px;overflow:hidden}.card-img--sm img{width:100%;height:100%;object-fit:cover}.btn-add--sm{flex-shrink:0;width:36px;height:36px;border-radius:50%;font-size:20px;display:flex;align-items:center;justify-content:center;margin-left:auto;line-height:1;padding:0}.qty-controls--compact{flex-shrink:0;width:140px;display:flex;align-items:center;justify-content:space-between}.qty-controls--compact .qty-label{width:78px;text-align:center}.constructor-view{display:flex;flex-direction:column;min-height:100vh}.constructor-list{flex:1;padding-bottom:80px;overflow:auto}.constructor-footer{position:fixed;bottom:0;left:0;right:0;padding:12px 16px;background:var(--bg);border-top:1px solid var(--border)}.constructor-view .grid{display:flex;flex-direction:column;gap:10px}.summary-overlay{position:fixed;inset:0;background:#0009;z-index:100;display:flex;align-items:flex-end}.summary-sheet{background:var(--surface);width:100%;border-radius:20px 20px 0 0;padding:20px 16px calc(18px + env(safe-area-inset-bottom,0px));display:flex;flex-direction:column;gap:12px;transform:translateY(16px);opacity:0;animation:summaryUp .3s ease-out forwards}@keyframes summaryUp{0%{transform:translateY(16px);opacity:0}to{transform:translateY(0);opacity:1}}.summary-overlay{animation:summaryFade .3s cubic-bezier(.2,.9,.2,1) forwards}@keyframes summaryFade{0%{background:#0000}to{background:#0009}}.summary-title{font-size:18px;font-weight:700;margin:0}.summary-items{display:flex;flex-direction:column;gap:8px}.summary-item{display:flex;justify-content:space-between;font-size:14px}.summary-item-detail{color:var(--text-muted)}.summary-total{display:flex;justify-content:space-between;font-weight:700;font-size:16px;padding-top:8px;border-top:1px solid var(--border)}.summary-cancel{background:none;border:none;color:var(--text-muted);font-size:14px;padding:8px;cursor:pointer;text-align:center}.card--constructor-entry{border:1px dashed var(--border)}.screen-stage{position:relative;width:100%;min-height:100vh;overflow:hidden}.screen-pane{position:absolute;inset:0;width:100%;height:100%;will-change:transform}.slide-forward .pane-from{transform:translate(0);animation:slideOutLeft .18s ease-out forwards}.slide-forward .pane-to{transform:translate(100%);animation:slideInFromRight .18s ease-out forwards}.slide-back .pane-from{transform:translate(0);animation:slideOutRight .18s ease-out forwards}.slide-back .pane-to{transform:translate(-100%);animation:slideInFromLeft .18s ease-out forwards}@keyframes slideInFromRight{0%{transform:translate(100%)}to{transform:translate(0)}}@keyframes slideOutLeft{0%{transform:translate(0)}to{transform:translate(-100%)}}@keyframes slideInFromLeft{0%{transform:translate(-100%)}to{transform:translate(0)}}@keyframes slideOutRight{0%{transform:translate(0)}to{transform:translate(100%)}}.constructor-view .grid.grid--list{display:flex;flex-direction:column;gap:10px}.cart-empty--padded{padding:24px 16px}.checkout-view{position:fixed;top:0;left:0;right:0;bottom:var(--nav-h);display:flex;flex-direction:column;background:var(--bg);overflow:hidden}.checkout-header{justify-content:center;position:relative;padding:22px 16px 14px}.checkout-header .back-btn{position:absolute;left:12px;top:50%;transform:translateY(-50%)}.checkout-title{font-size:20px;font-weight:800;color:var(--text);text-align:center}.checkout-body{display:flex;flex-direction:column;flex:1;gap:10px;padding:0 16px 16px;overflow-y:auto}.checkout-card{background:linear-gradient(90deg,#ffffff0d,#ffffff08);border-radius:18px;padding:16px}.checkout-section-title,.checkout-label{display:block;font-size:12px;font-weight:800;color:var(--text);margin-bottom:10px}.checkout-radio-row{display:flex;align-items:center;gap:12px;color:var(--text);font-size:15px;margin-bottom:12px;cursor:pointer}.checkout-radio-row input[type=radio]{appearance:none;width:18px;height:18px;margin:0;border-radius:50%;border:2px solid rgba(255,255,255,.22);background:transparent;position:relative;flex-shrink:0}.checkout-radio-row input[type=radio]:checked{border-color:#fff}.checkout-radio-row input[type=radio]:checked:after{content:"";position:absolute;inset:3px;border-radius:50%;background:#fff}.checkout-divider{height:1px;background:var(--border);margin:10px 0 16px}.checkout-field{display:block}.checkout-field+.checkout-field{margin-top:12px}.checkout-input,.checkout-textarea{width:100%;border:1px solid rgba(255,255,255,.16);border-radius:10px;background:#ffffff12;color:var(--text);font-size:14px;outline:none;padding:12px 14px}.checkout-input{height:42px}.checkout-textarea{resize:none;min-height:72px;font-family:inherit}.checkout-hint{display:block;font-size:11px;color:var(--text-muted);margin-top:6px;line-height:1.35}.checkout-footer{flex-shrink:0;width:100%;background:var(--elevated);border-top-left-radius:24px;border-top-right-radius:24px;padding:10px 16px calc(12px + env(safe-area-inset-bottom,0px));border-top:1px solid var(--border)}.checkout-delivery-note{text-align:center;color:var(--text-muted);font-size:12px;margin-bottom:8px}.checkout-delivery-hint{font-size:12px;color:var(--text-muted);margin:6px 0 0;padding:8px 12px;background:var(--elevated);border-radius:8px;line-height:1.4}.checkout-total-row{display:flex;align-items:center;justify-content:space-between;color:var(--text);font-size:15px;padding:10px 0;border-bottom:1px solid var(--border)}.checkout-total-row--final{font-weight:800;border-bottom:none;padding-bottom:14px}.checkout-success-overlay{position:fixed;inset:0;background:#000000a8;display:flex;align-items:center;justify-content:center;z-index:500;padding:20px}.checkout-success-modal{width:100%;max-width:320px;background:#1b1e24;border:1px solid rgba(255,255,255,.08);border-radius:18px;padding:26px 20px 18px;box-shadow:0 20px 50px #00000073}.checkout-success-text{color:var(--text);text-align:center;font-size:16px;line-height:1.5;margin:0 0 18px}.checkout-success-btn{width:100%;height:44px;border:none;border-radius:12px;background:#e8e8e8;color:#111;font-size:15px;font-weight:700;cursor:pointer}.payment-waiting-spinner{width:48px;height:48px;border:4px solid #333;border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite;margin:0 auto}.payment-fail-icon{font-size:46px;color:#f44;line-height:1;margin:0}.payment-cancel-btn{width:100%;height:40px;background:none;border:1px solid #444;border-radius:12px;color:#888;font-size:14px;cursor:pointer}.checkout-submit-error{color:#ff5a5a;font-size:13px;text-align:center;margin:8px 0 0;padding:0 4px}.hero-banner{margin:12px;border-radius:20px;overflow:hidden}.hero-banner-img{display:block;width:100%;height:auto}.form-extra-images{margin-bottom:8px;transition:opacity .2s}.form-extra-hint{font-size:12px;color:var(--text-muted);margin:4px 0 0}.form-extra-images-row{display:flex;flex-wrap:wrap;gap:8px;margin-top:8px}.form-extra-thumb{position:relative;width:72px;height:72px;border-radius:10px;overflow:hidden}.form-extra-thumb--pending{outline:2px dashed var(--accent, #fff);outline-offset:-2px;opacity:.75}.form-extra-thumb img{width:100%;height:100%;object-fit:cover}.form-extra-remove{position:absolute;top:2px;right:2px;background:#0009;color:#fff;border:none;border-radius:50%;width:20px;height:20px;font-size:11px;cursor:pointer;display:flex;align-items:center;justify-content:center}.form-extra-add{width:72px;height:72px;border-radius:10px;border:1px dashed var(--border);display:flex;align-items:center;justify-content:center;color:var(--text-muted);cursor:pointer}.checkout-required{color:#e53e3e}.checkout-input--error{border-color:#e53e3e!important}.checkout-error{color:#e53e3e;font-size:12px;margin-top:4px;display:block}.checkout-pd-row{display:flex;align-items:flex-start;gap:10px;margin-top:8px;cursor:pointer}.checkout-pd-row input[type=checkbox]{flex-shrink:0;margin-top:2px;width:18px;height:18px;accent-color:var(--accent, #fff);cursor:pointer}.checkout-pd-row span{font-size:12px;color:var(--text-muted);line-height:1.4}.checkout-pd-row--error span{color:#e53e3e}.app-loading{display:flex;align-items:center;justify-content:center;min-height:100vh;background:var(--bg)}.app-loading-logo{font-size:28px;font-weight:800;letter-spacing:.12em;color:var(--text);opacity:.35;text-transform:lowercase}.bottom-nav{position:fixed;bottom:0;left:50%;transform:translate(-50%);width:100%;max-width:480px;height:var(--nav-h);background:var(--elevated);border-top:1px solid rgba(255,255,255,.08);display:flex;align-items:stretch;z-index:200}.nav-btn{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;background:transparent;border:none;color:var(--text-muted);font-size:10px;font-weight:500;cursor:pointer;position:relative;padding:8px 0 10px;letter-spacing:.03em;transition:color .15s}.nav-btn.active{color:#fff}.nav-icon-wrap{position:relative;display:flex;align-items:center;justify-content:center}.nav-badge{position:absolute;top:-6px;right:-9px;min-width:16px;height:16px;background:#fff;color:#000;border-radius:8px;font-size:9px;font-weight:700;display:flex;align-items:center;justify-content:center;padding:0 3px;border:1.5px solid var(--elevated)}.gift-title{font-size:22px;font-weight:800;color:#fff;padding:20px 16px 0;margin:0;letter-spacing:.02em}.gift-view{min-height:calc(100vh - var(--nav-h));background:var(--bg);display:flex;flex-direction:column;padding-bottom:calc(var(--nav-h) + 64px)}.gift-intro-card{margin:12px 16px 0;background:#1a1a1a;border-radius:14px;padding:14px 16px}.gift-intro{font-size:14px;color:var(--text-muted);line-height:1.6;margin:0}.gift-examples-list{display:flex;flex-direction:column;padding:12px 16px 0}.gift-examples-list .gift-example-card+.gift-example-card{margin-top:0;border-top:1px solid var(--border);border-radius:0;padding-top:12px}.gift-examples-list .gift-example-card:first-child{border-radius:16px 16px 0 0}.gift-examples-list .gift-example-card:last-child{border-radius:0 0 16px 16px;padding-bottom:10px}.gift-example-card{border-radius:16px;background:var(--surface);padding:10px 10px 0}.gift-example-img{width:100%;aspect-ratio:16/9;object-fit:cover;display:block;border-radius:10px}.gift-example-img-ph{width:100%;aspect-ratio:16/9;background:linear-gradient(135deg,#2e2416,#1e1a12);border-radius:10px}.gift-example-title{padding:10px 14px 14px;font-size:13px;font-weight:600;color:var(--text);font-style:italic}.gift-footer-btn{position:fixed;bottom:var(--nav-h);left:50%;transform:translate(-50%);width:100%;max-width:480px;padding:10px 16px calc(10px + env(safe-area-inset-bottom,0px));background:var(--bg);border-top:1px solid var(--border);z-index:100}.gift-step{min-height:calc(100vh - var(--nav-h));display:flex;flex-direction:column;padding:0 0 calc(var(--nav-h) + 80px);background:var(--bg)}.gift-step-header{display:flex;align-items:center;gap:12px;padding:14px 16px;border-bottom:1px solid var(--border)}.gift-step-title{font-size:18px;font-weight:700;color:var(--text)}.gift-step-body{flex:1;padding:20px 16px}.gift-step-hint{font-size:14px;color:var(--text-muted);margin-bottom:16px;line-height:1.5}.gift-budget-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:10px;margin-bottom:12px}.gift-budget-btn{padding:14px 8px;border-radius:12px;border:1.5px solid rgba(255,255,255,.15);background:transparent;color:var(--text);font-size:14px;font-weight:600;cursor:pointer;transition:background .15s,border-color .15s}.gift-budget-btn.active{background:#fff;color:#000;border-color:#fff}.gift-budget-btn--wide{grid-column:span 3;font-size:13px}.gift-wish-grid{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:14px}.gift-wish-btn{padding:9px 16px;border-radius:20px;border:1.5px solid rgba(255,255,255,.15);background:transparent;color:var(--text);font-size:13px;font-weight:500;cursor:pointer;transition:background .15s,border-color .15s}.gift-wish-btn.active{background:#fff;color:#000;border-color:#fff}.gift-step-footer{position:fixed;bottom:var(--nav-h);left:50%;transform:translate(-50%);width:100%;max-width:480px;padding:10px 16px calc(10px + env(safe-area-inset-bottom,0px));background:var(--bg);border-top:1px solid var(--border);z-index:100}
