body{margin:0}.login-container{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;justify-content:center;min-height:100vh;overflow:hidden;padding:20px;position:relative}.login-background{bottom:0;left:0;overflow:hidden;position:absolute;right:0;top:0}.login-card{animation:slideUp .6s ease-out;background:#fff;border-radius:20px;box-shadow:0 20px 60px #0000004d;max-width:450px;padding:50px 40px;position:relative;width:100%;z-index:1}.login-header{margin-bottom:30px;text-align:center}.app-title{animation:fadeIn .8s ease-out;font-size:32px}@keyframes fadeIn{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}.welcome-text{margin-bottom:30px;text-align:center}.welcome-text h2{color:#333;font-size:24px;font-weight:600;margin:0 0 10px}.welcome-text p{color:#666;font-size:14px;margin:0}.error-message{align-items:center;animation:shake .5s;background:#fee;border-radius:8px;color:#c33;display:flex;font-size:14px;gap:10px;margin-bottom:20px;padding:12px 16px}.error-icon{font-size:18px}.form-group,.login-form{margin-bottom:20px}.form-group label{font-size:14px;margin-bottom:8px}.input-icon{font-size:16px}.input-wrapper input{font-size:15px;padding:14px 15px 14px 45px;transition:all .3s}.password-toggle{background:none;border:none;color:#999;cursor:pointer;font-size:18px;padding:5px;position:absolute;right:12px;transition:color .2s}.password-toggle:hover:not(:disabled){color:#667eea}.password-toggle:disabled{cursor:not-allowed;opacity:.5}.login-button{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:10px;color:#fff;cursor:pointer;display:flex;font-size:16px;font-weight:600;gap:10px;justify-content:center;margin-top:30px;padding:15px;transition:all .3s;width:100%}.login-button:hover:not(:disabled){box-shadow:0 10px 25px #667eea66;transform:translateY(-2px)}.login-button:active:not(:disabled){transform:translateY(0)}.login-button:disabled{cursor:not-allowed;opacity:.7}.spinner{border:2px solid #ffffff4d;height:16px;width:16px}.login-register{color:#666;font-size:14px;margin-top:16px;text-align:center}.login-register-link{background:none;border:none;color:#667eea;cursor:pointer;font-size:14px;font-weight:600;padding:0;text-decoration:underline}.login-register-link:hover{color:#764ba2}.login-footer{border-top:1px solid #e0e0e0;margin-top:30px;padding-top:20px;text-align:center}.login-footer p{color:#999;font-size:12px;margin:0}@media (max-width:600px){.login-card{border-radius:15px;padding:40px 30px}.app-title{font-size:28px}.welcome-text h2{font-size:20px}.input-wrapper input{padding:12px 15px 12px 45px}.login-button{font-size:15px;padding:13px}}@media (max-width:400px){.login-container{padding:15px}.login-card{padding:30px 20px}.app-title{font-size:24px}}.register-container{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;justify-content:center;min-height:100vh;overflow:hidden;padding:32px 20px;position:relative}.register-background{inset:0;overflow:hidden;position:absolute}.background-shape{border-radius:50%;opacity:.1;position:absolute}.shape-1{background:#fff;height:400px;right:-100px;top:-100px;width:400px}.shape-2{background:#fff;bottom:-50px;height:300px;left:-50px;width:300px}.shape-3{background:#fff;height:200px;left:50%;top:50%;transform:translate(-50%,-50%);width:200px}.register-card{animation:slideUp .6s ease-out;background:#fff;border-radius:20px;box-shadow:0 20px 60px #0000004d;max-width:520px;padding:48px 40px 36px;position:relative;width:100%;z-index:1}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.register-header{margin-bottom:24px;text-align:center}.app-title{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;background-clip:text;font-size:30px;font-weight:700;margin:0}.register-welcome{margin-bottom:24px;text-align:center}.register-welcome h2{color:#333;font-size:22px;font-weight:600;margin:0 0 6px}.register-welcome p{color:#888;font-size:14px;margin:0}.register-error{align-items:center;animation:shake .4s;background:#fee;border-radius:8px;color:#c33;display:flex;font-size:14px;gap:10px;margin-bottom:20px;padding:12px 16px}@keyframes shake{0%,to{transform:translateX(0)}25%{transform:translateX(-8px)}75%{transform:translateX(8px)}}.register-form{margin-bottom:16px}.form-group{margin-bottom:18px}.form-group label{color:#333;display:block;font-size:13px;font-weight:600;margin-bottom:6px}.input-wrapper{align-items:center;display:flex;position:relative}.input-icon{color:#999;font-size:15px;left:12px;pointer-events:none;position:absolute}.input-wrapper input{background:#f8f9fa;border:2px solid #e0e0e0;border-radius:10px;box-sizing:border-box;font-size:14px;padding:13px 14px 13px 42px;transition:all .25s;width:100%}.input-wrapper input:focus{background:#fff;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a;outline:none}.input-wrapper input:disabled{background:#f0f0f0;cursor:not-allowed}.register-row{grid-gap:14px;display:grid;gap:14px;grid-template-columns:1fr 1fr}.register-textarea{background:#f8f9fa;border:2px solid #e0e0e0;border-radius:10px;box-sizing:border-box;font-family:inherit;font-size:14px;line-height:1.5;padding:13px 14px;resize:vertical;transition:all .25s;width:100%}.register-textarea:focus{background:#fff;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a;outline:none}.register-textarea:disabled{background:#f0f0f0;cursor:not-allowed}.register-btn{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:10px;color:#fff;cursor:pointer;display:flex;font-size:15px;font-weight:600;gap:10px;justify-content:center;margin-top:8px;padding:14px;transition:all .3s;width:100%}.register-btn:hover:not(:disabled){box-shadow:0 10px 25px #667eea66;transform:translateY(-2px)}.register-btn:disabled{cursor:not-allowed;opacity:.7}.spinner{animation:spin .8s linear infinite;border:2px solid #ffffff59;border-top-color:#fff;height:15px;width:15px}.register-signin{color:#666;font-size:14px;margin-top:16px;text-align:center}.register-signin-link{background:none;border:none;color:#667eea;cursor:pointer;font-size:14px;font-weight:600;padding:0;text-decoration:underline}.register-signin-link:hover{color:#764ba2}.register-footer{border-top:1px solid #e0e0e0;margin-top:20px;padding-top:16px;text-align:center}.register-footer p{color:#bbb;font-size:12px;margin:0}.register-success-icon{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:50%;color:#fff;display:flex;font-size:30px;height:64px;justify-content:center;margin:0 auto 20px;width:64px}.register-success-title{color:#222;font-size:22px;font-weight:700;margin:0 0 10px;text-align:center}.register-success-msg{color:#666;font-size:14px;line-height:1.6;margin:0 0 24px;text-align:center}@media (max-width:540px){.register-card{padding:36px 24px 28px}.register-row{grid-template-columns:1fr}}@media (max-width:400px){.register-container{padding:20px 12px}}.layout-container{background:#f5f5f5;display:flex;flex-direction:column;min-height:100vh}.top-navbar{align-items:center;background:#fff;box-shadow:0 2px 8px #0000001a;display:flex;justify-content:space-between;padding:15px 30px;position:sticky;top:0;z-index:100}.navbar-brand h1{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;background-clip:text;font-size:24px;font-weight:700;margin:0}.navbar-menu{gap:10px}.nav-item,.navbar-menu{align-items:center;display:flex}.nav-item{background:#0000;border:none;border-radius:8px;color:#666;cursor:pointer;font-size:15px;font-weight:500;gap:8px;padding:10px 20px;transition:all .3s}.nav-item:hover{background:#f0f0f0;color:#667eea}.nav-item.active{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.nav-icon{font-size:18px}.nav-label{font-weight:600}.navbar-user{align-items:center;display:flex;gap:15px}.user-name{color:#333}.logout-btn,.user-name{font-size:14px;font-weight:600}.logout-btn{background:#e74c3c;border:none;border-radius:6px;color:#fff;cursor:pointer;padding:8px 16px;transition:all .3s}.logout-btn:hover{background:#c0392b;box-shadow:0 4px 12px #e74c3c4d;transform:translateY(-2px)}.main-content{flex:1 1;margin:0 auto;max-width:1400px;padding:20px 20px 80px;width:100%}.bottom-navbar{background:#fff;bottom:0;box-shadow:0 -2px 10px #0000001a;display:none;left:0;padding:8px 0;position:fixed;right:0;z-index:100}.bottom-nav-item{align-items:center;background:#0000;border:none;color:#999;cursor:pointer;display:flex;flex:1 1;flex-direction:column;gap:4px;justify-content:center;min-width:0;padding:8px;transition:all .3s}.bottom-nav-item.active{color:#667eea}.bottom-nav-icon{font-size:22px}.bottom-nav-label{font-size:11px;font-weight:600;white-space:nowrap}@media (max-width:768px){.top-navbar{padding:12px 20px}.navbar-brand h1{font-size:20px}.navbar-menu{display:none}.navbar-user{gap:10px}.logout-btn,.user-name{font-size:13px}.logout-btn{padding:6px 12px}.main-content{padding:15px 15px 80px}.bottom-navbar{display:flex}}@media (max-width:480px){.top-navbar{padding:10px 15px}.navbar-brand h1{font-size:18px}.user-name{display:none}.main-content{padding:10px 10px 70px}.bottom-navbar{padding:6px 0}.bottom-nav-icon{font-size:20px}.bottom-nav-label{font-size:10px}}.home-container{margin:0 auto;max-width:1200px;padding:0 16px 32px}.search-wrapper{background:#f5f5f5;padding:18px 0 14px;position:sticky;top:0;transition:padding .25s ease;z-index:50}.search-wrapper--shrunk{padding:8px 0 6px}.search-bar{align-items:center;background:#fff;border:1.5px solid #e0e0e0;border-radius:12px;box-shadow:0 2px 8px #667eea1a;display:flex;gap:10px;padding:12px 16px;transition:padding .25s ease,border-color .2s ease,box-shadow .2s ease}.search-bar:focus-within{border-color:#667eea;box-shadow:0 2px 12px #667eea40}.search-wrapper--shrunk .search-bar{border-radius:8px;padding:7px 14px}.search-icon{color:#999;flex-shrink:0;font-size:18px;transition:font-size .25s ease}.search-wrapper--shrunk .search-icon{font-size:15px}.search-input{background:#0000;border:none;color:#333;flex:1 1;font-size:16px;outline:none;transition:font-size .25s ease}.search-wrapper--shrunk .search-input{font-size:14px}.search-input::placeholder{color:#bbb}.search-clear{background:none;border:none;border-radius:50%;color:#aaa;cursor:pointer;font-size:14px;line-height:1;padding:2px 4px;transition:color .15s,background .15s}.search-clear:hover{background:#f0f0f0;color:#667eea}.state-container{align-items:center;color:#888;display:flex;flex-direction:column;font-size:15px;gap:16px;justify-content:center;padding:60px 20px}.state-error{color:#e74c3c}.state-empty{color:#aaa}.retry-btn{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:14px;padding:10px 24px;transition:opacity .2s}.retry-btn:hover{opacity:.85}.spinner{animation:spin .7s linear infinite;border:3px solid #e0e0e0;border-radius:50%;border-top-color:#667eea;height:36px;width:36px}@keyframes spin{to{transform:rotate(1turn)}}.product-grid{grid-gap:14px;display:grid;gap:14px;grid-template-columns:repeat(2,1fr);margin-top:4px}@media (min-width:600px){.product-grid{gap:18px;grid-template-columns:repeat(3,1fr)}}@media (min-width:960px){.product-grid{gap:20px;grid-template-columns:repeat(4,1fr)}}.product-tile{background:#fff;border-radius:14px;box-shadow:0 2px 8px #00000012;display:flex;flex-direction:column;overflow:hidden;transition:transform .2s ease,box-shadow .2s ease}.product-tile:hover{box-shadow:0 6px 18px #667eea26;transform:translateY(-3px)}.tile-image-wrap{align-items:center;aspect-ratio:2/1;background:#f8f8f8;display:flex;justify-content:center;overflow:hidden;width:100%}.tile-image{height:100%;object-fit:cover;width:100%}.tile-image-placeholder{color:#ccc;font-size:48px}.tile-info{flex:1 1;padding:12px 12px 6px}.tile-name{color:#222;font-size:14px;font-weight:600;line-height:1.3;margin:0 0 5px}.tile-description,.tile-name{-webkit-line-clamp:2;-webkit-box-orient:vertical;display:-webkit-box;overflow:hidden}.tile-description{color:#888;font-size:11.5px;line-height:1.4;margin:0}.tile-price-row{align-items:center;display:flex;gap:6px;justify-content:space-between;margin-top:8px}.tile-price{color:#667eea;font-size:15px;font-weight:700}.tile-cutoff{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:20px;color:#fff;font-size:10.5px;padding:2px 8px;white-space:nowrap}.tile-qty{gap:0;padding:10px 12px 12px}.qty-btn,.tile-qty{align-items:center;display:flex;justify-content:center}.qty-btn{background:#fff;border:1.5px solid #667eea;border-radius:50%;color:#667eea;cursor:pointer;flex-shrink:0;font-size:18px;height:32px;line-height:1;transition:background .15s,color .15s;width:32px}.qty-btn:hover:not(:disabled){background:#667eea;color:#fff}.qty-btn:disabled{background:#f5f5f5;border-color:#e8e8e8;color:#ccc;cursor:default;opacity:.55}.qty-btn--plus{background:linear-gradient(135deg,#667eea,#764ba2);border-color:#0000;color:#fff}.qty-btn--plus:disabled{background:#e8e8e8;border-color:#e8e8e8;color:#ccc}.qty-btn--plus:hover{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;opacity:.85}.qty-value{color:#333;font-size:15px;font-weight:600;min-width:36px;text-align:center;-webkit-user-select:none;user-select:none}.categories-container{padding:0 0 48px}.cat-root-grid{grid-gap:14px;display:grid;gap:14px;grid-template-columns:repeat(2,1fr);padding:16px 12px}@media (min-width:480px){.cat-root-grid{grid-template-columns:repeat(3,1fr)}}@media (min-width:720px){.cat-root-grid{grid-template-columns:repeat(4,1fr)}}.cat-root-tile{align-items:center;background:#fff;border:none;border-radius:16px;box-shadow:0 2px 10px #00000012;cursor:pointer;display:flex;flex-direction:column;gap:10px;padding:16px 12px 18px;text-align:center;transition:box-shadow .2s,transform .15s}.cat-root-tile:hover{box-shadow:0 6px 20px #667eea33;transform:translateY(-2px)}.cat-root-tile:active{transform:translateY(0)}.cat-root-image-wrap{align-items:center;background:#f3f3f3;border-radius:50%;box-shadow:0 2px 8px #667eea26;display:flex;flex-shrink:0;height:80px;justify-content:center;overflow:hidden;width:80px}.cat-root-image{height:100%;object-fit:cover;width:100%}.cat-root-image-placeholder{color:#ccc;font-size:32px}.cat-root-name{color:#333;font-size:13px;font-weight:700;line-height:1.3;margin:0;word-break:break-word}.cat-drill-header{border-bottom:2px solid #f0f0f0;gap:10px;padding:14px 16px 12px}.cat-back-btn,.cat-drill-header{align-items:center;background:#fff;display:flex}.cat-back-btn{border:1.5px solid #e0e0e0;border-radius:50%;color:#555;cursor:pointer;flex-shrink:0;font-size:16px;height:34px;justify-content:center;transition:border-color .2s,color .2s;width:34px}.cat-back-btn:hover{border-color:#667eea;color:#667eea}.cat-drill-title{color:#222;font-size:16px;font-weight:700}.cat-tabrow{-ms-overflow-style:none;background:#fff;border-bottom:2px solid #f0f0f0;display:flex;gap:0;overflow-x:auto;padding:6px 12px;scrollbar-width:none}.cat-tabrow::-webkit-scrollbar{display:none}.cat-tabrow:nth-of-type(2){background:#fafafa;padding-left:24px}.cat-tabrow:nth-of-type(3){background:#f5f5f5;padding-left:36px}.cat-tabrow:nth-of-type(4){background:#f0f0f0;padding-left:48px}.cat-tabrow--loading{align-items:center;justify-content:center;min-height:62px}.cat-tab{align-items:center;background:none;border:none;border-bottom:3px solid #0000;color:#888;cursor:pointer;display:flex;flex-direction:column;flex-shrink:0;gap:4px;min-width:96px;padding:6px 12px 8px;transition:border-color .2s,color .2s}.cat-tab:hover{color:#667eea}.cat-tab--active{border-bottom-color:#667eea;color:#667eea}.cat-tab-icon{align-items:center;background:#f0f0f0;border-radius:50%;display:flex;flex-shrink:0;height:38px;justify-content:center;overflow:hidden;transition:box-shadow .2s;width:38px}.cat-tab--active .cat-tab-icon{box-shadow:0 0 0 2px #667eea}.cat-tab-icon img{height:100%;object-fit:cover;width:100%}.cat-tab-icon--all{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;font-size:15px}.cat-tab-icon--placeholder{color:#bbb;font-size:17px}.cat-tab-label{font-size:11px;font-weight:600;line-height:1.3;max-width:88px;text-align:center;white-space:normal;word-break:break-word}.cat-tab-spinner{animation:cat-spin .7s linear infinite;border:2px solid #e0e0e0;border-radius:50%;border-top-color:#667eea;display:inline-block;height:18px;width:18px}@keyframes cat-spin{to{transform:rotate(1turn)}}.cat-state{align-items:center;color:#bbb;display:flex;flex-direction:column;font-size:15px;gap:12px;justify-content:center;padding:60px 24px}.cat-state--error{color:#e74c3c}.cat-spinner{animation:cat-spin .7s linear infinite;border:3px solid #e0e0e0;border-radius:50%;border-top-color:#667eea;height:28px;width:28px}.cat-product-grid{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(2,1fr);padding:16px 12px}@media (min-width:600px){.cat-product-grid{grid-template-columns:repeat(3,1fr)}}@media (min-width:960px){.cat-product-grid{grid-template-columns:repeat(4,1fr)}}.cat-tile{background:#fff;border-radius:14px;box-shadow:0 2px 8px #0000000f;display:flex;flex-direction:column;overflow:hidden;transition:box-shadow .2s}.cat-tile:hover{box-shadow:0 4px 16px #667eea26}.cat-tile-image-wrap{align-items:center;aspect-ratio:2/1;background:#f5f5f5;display:flex;justify-content:center;overflow:hidden;width:100%}.cat-tile-image{height:100%;object-fit:cover;width:100%}.cat-tile-image-placeholder{color:#ddd;font-size:32px}.cat-tile-info{flex:1 1;padding:10px 12px 6px}.cat-tile-name{color:#222;font-size:13px;font-weight:700;line-height:1.3;margin:0 0 3px}.cat-tile-desc{-webkit-line-clamp:2;-webkit-box-orient:vertical;color:#aaa;display:-webkit-box;font-size:11px;line-height:1.4;margin:0 0 6px;overflow:hidden}.cat-tile-price-row{align-items:center;display:flex;flex-wrap:wrap;gap:6px}.cat-tile-price{color:#667eea;font-size:14px;font-weight:700}.cat-tile-cutoff{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:20px;color:#fff;font-size:10px;font-weight:600;padding:2px 8px}.cat-tile-qty{padding:8px 12px 10px}.cat-tile-qty,.cat-tile-qty .qty-btn{align-items:center;display:flex;justify-content:center}.cat-tile-qty .qty-btn{background:#fff;border:1.5px solid #667eea;border-radius:50%;color:#667eea;cursor:pointer;flex-shrink:0;font-size:17px;height:30px;line-height:1;transition:background .15s,color .15s;width:30px}.cat-tile-qty .qty-btn:hover:not(:disabled){background:#667eea;color:#fff}.cat-tile-qty .qty-btn:disabled{background:#f5f5f5;border-color:#e8e8e8;color:#ccc;cursor:default;opacity:.55}.cat-tile-qty .qty-btn--plus{background:linear-gradient(135deg,#667eea,#764ba2);border-color:#0000;color:#fff}.cat-tile-qty .qty-btn--plus:disabled{background:#e8e8e8;border-color:#e8e8e8;color:#ccc}.cat-tile-qty .qty-value{color:#333;font-size:15px;font-weight:600;min-width:34px;text-align:center;-webkit-user-select:none;user-select:none}.cart-empty{align-items:center;display:flex;flex-direction:column;gap:12px;justify-content:center;padding:80px 24px;text-align:center}.cart-empty-icon{font-size:64px;margin-bottom:8px}.cart-empty h2{color:#333;font-size:22px;font-weight:700;margin:0}.cart-empty p{color:#888;font-size:15px;margin:0}.cart-shop-btn{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:10px;color:#fff;cursor:pointer;font-size:15px;font-weight:600;margin-top:8px;padding:12px 28px;transition:opacity .2s}.cart-shop-btn:hover{opacity:.85}.cart-container{margin:0 auto;max-width:860px;padding:0 16px 40px}.cart-header{align-items:baseline;border-bottom:2px solid #f0f0f0;display:flex;gap:12px;margin-bottom:8px;padding:20px 0 14px}.cart-title{color:#222;font-size:22px;font-weight:700;margin:0}.cart-count{color:#999;font-size:14px}.cart-items{display:flex;flex-direction:column;gap:2px}.cart-row{grid-gap:14px;align-items:center;border-bottom:1px solid #f5f5f5;display:grid;gap:14px;grid-template-columns:72px 1fr auto auto auto 32px;padding:14px 4px;transition:background .15s}.cart-row:hover{background:#fafafa;border-radius:10px}.cart-row-image{align-items:center;background:#f3f3f3;border-radius:10px;display:flex;flex-shrink:0;height:72px;justify-content:center;overflow:hidden;width:72px}.cart-row-image img{height:100%;object-fit:cover;width:100%}.cart-row-image-placeholder{color:#ccc;font-size:28px}.cart-row-info{min-width:0}.cart-row-name{color:#222;font-size:14px;font-weight:600;margin:0 0 3px}.cart-row-desc,.cart-row-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.cart-row-desc{color:#999;font-size:12px;margin:0 0 4px}.cart-row-cutoff{color:#667eea;font-size:11px;font-weight:500;margin:0}.cart-row-cutoff--expired{color:#e74c3c}.cart-row-price{align-items:flex-end;display:flex;flex-direction:column;gap:2px;white-space:nowrap}.cart-row-unit-price{color:#667eea;font-size:14px;font-weight:600}.cart-row-unit-label{color:#bbb;font-size:11px}.cart-row-qty{align-items:center;display:flex;gap:0}.cart-row-qty .qty-btn{align-items:center;background:#fff;border:1.5px solid #667eea;border-radius:50%;color:#667eea;cursor:pointer;display:flex;flex-shrink:0;font-size:17px;height:30px;justify-content:center;line-height:1;transition:background .15s,color .15s;width:30px}.cart-row-qty .qty-btn:hover:not(:disabled){background:#667eea;color:#fff}.cart-row-qty .qty-btn:disabled{background:#f5f5f5;border-color:#e8e8e8;color:#ccc;cursor:default;opacity:.55}.cart-row-qty .qty-btn--plus{background:linear-gradient(135deg,#667eea,#764ba2);border-color:#0000;color:#fff}.cart-row-qty .qty-btn--plus:disabled{background:#e8e8e8;border-color:#e8e8e8;color:#ccc}.cart-row-qty .qty-value{color:#333;font-size:15px;font-weight:600;min-width:34px;text-align:center;-webkit-user-select:none;user-select:none}.cart-row-total{color:#222;font-size:15px;font-weight:700;min-width:64px;text-align:right;white-space:nowrap}.cart-row-remove{align-items:center;background:none;border:none;border-radius:50%;color:#ccc;cursor:pointer;display:flex;flex-shrink:0;font-size:14px;height:28px;justify-content:center;transition:background .15s,color .15s;width:28px}.cart-row-remove:hover{background:#fdecea;color:#e74c3c}.cart-summary{background:#fff;border-radius:14px;box-shadow:0 2px 12px #00000012;display:flex;flex-direction:column;gap:16px;margin-top:24px;padding:20px 24px}.cart-summary-row{align-items:center;color:#555;display:flex;font-size:15px;justify-content:space-between}.cart-summary-total{color:#222;font-size:20px;font-weight:700}.cart-checkout-btn{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:10px;color:#fff;cursor:pointer;font-size:16px;font-weight:600;padding:14px;transition:opacity .2s;width:100%}.cart-checkout-btn:hover{opacity:.88}@media (max-width:600px){.cart-row{gap:8px 10px;grid-template-columns:56px 1fr auto 32px;grid-template-rows:auto auto}.cart-row-image{grid-row:1/3;height:56px;width:56px}.cart-row-info{grid-column:2;grid-row:1}.cart-row-remove{align-self:start;grid-column:4;grid-row:1}.cart-row-price{align-items:center;flex-direction:row;gap:4px;grid-column:2;grid-row:2}.cart-row-qty{grid-column:3;grid-row:2}.cart-row-total{display:none}}.checkout-container{margin:0 auto;max-width:1000px;padding:0 16px 48px}.checkout-header{border-bottom:2px solid #f0f0f0;margin-bottom:24px;padding:20px 0 14px}.checkout-back-link{background:none;border:none;color:#667eea;cursor:pointer;display:block;font-size:14px;font-weight:500;margin-bottom:8px;padding:0}.checkout-back-link:hover{text-decoration:underline}.checkout-title{color:#222;font-size:22px;font-weight:700;margin:0}.checkout-body{grid-gap:24px;align-items:start;display:grid;gap:24px;grid-template-columns:1fr 320px}.checkout-items-panel{background:#fff;border-radius:14px;box-shadow:0 2px 12px #00000012;padding:20px 24px}.checkout-section-title{color:#444;font-size:15px;font-weight:700;letter-spacing:.04em;margin:0 0 16px;text-transform:uppercase}.checkout-items{display:flex;flex-direction:column;gap:2px}.checkout-item-row{grid-gap:14px;align-items:center;border-bottom:1px solid #f5f5f5;display:grid;gap:14px;grid-template-columns:56px 1fr auto auto;padding:12px 4px}.checkout-item-row:last-child{border-bottom:none}.checkout-item-image{align-items:center;background:#f3f3f3;border-radius:8px;display:flex;flex-shrink:0;height:56px;justify-content:center;overflow:hidden;width:56px}.checkout-item-image img{height:100%;object-fit:cover;width:100%}.checkout-item-placeholder{color:#ccc;font-size:22px}.checkout-item-info{min-width:0}.checkout-item-name{color:#222;font-size:14px;font-weight:600}.checkout-item-desc,.checkout-item-name{margin:0 0 2px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.checkout-item-desc{color:#999;font-size:12px}.checkout-item-unit{color:#bbb;font-size:12px;margin:0}.checkout-item-qty{align-items:center;display:flex;flex-direction:column;gap:2px}.checkout-qty-label{color:#bbb;font-size:10px;letter-spacing:.05em;text-transform:uppercase}.checkout-qty-value{color:#333;font-size:16px;font-weight:700;min-width:28px;text-align:center}.checkout-item-total{color:#222;font-size:15px;font-weight:700;min-width:72px;text-align:right;white-space:nowrap}.checkout-summary-panel{display:flex;flex-direction:column;gap:16px}.checkout-card{background:#fff;border-radius:14px;box-shadow:0 2px 12px #00000012;padding:18px 20px}.checkout-card-title{color:#444;font-size:13px;font-weight:700;letter-spacing:.04em;margin:0 0 10px;text-transform:uppercase}.checkout-delivery-date{color:#222;font-size:15px;font-weight:700;margin:0 0 4px}.checkout-delivery-window{color:#667eea;font-size:14px;font-weight:600;margin:4px 0 0}.checkout-lead-note{color:#999;font-size:12px;margin:4px 0 0}.checkout-address-block{display:flex;flex-direction:column;gap:4px}.checkout-address-name{color:#222;font-size:14px;font-weight:700;margin:0}.checkout-address-text{color:#555;font-size:13px;line-height:1.5;margin:0;white-space:pre-line}.checkout-address-missing{color:#bbb;font-size:13px;font-style:italic}.checkout-address-loading{color:#999;font-size:13px;margin:0}.checkout-address-error{color:#e74c3c;font-size:13px;margin:0}.checkout-total-card{border-top:3px solid #667eea}.checkout-total-row{align-items:center;color:#555;display:flex;font-size:15px;justify-content:space-between;margin-bottom:16px}.checkout-total-amount{color:#222;font-size:22px;font-weight:700}.checkout-place-btn{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:10px;color:#fff;cursor:pointer;font-size:16px;font-weight:600;padding:14px;transition:opacity .2s;width:100%}.checkout-place-btn:hover{opacity:.88}.checkout-order-error{color:#e74c3c;font-size:13px;margin:0 0 12px;text-align:center}.checkout-place-btn:disabled{cursor:not-allowed;opacity:.6}.checkout-confirmation{flex-direction:column;gap:16px;padding:80px 24px;text-align:center}.checkout-confirmation,.checkout-confirmation-icon{align-items:center;display:flex;justify-content:center}.checkout-confirmation-icon{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:50%;color:#fff;font-size:32px;height:64px;width:64px}.checkout-confirmation-title{color:#222;font-size:24px;font-weight:700;margin:0}.checkout-confirmation-msg{color:#555;font-size:16px;line-height:1.6;margin:0;max-width:400px}.checkout-empty{align-items:center;display:flex;flex-direction:column;gap:16px;padding:80px 24px;text-align:center}.checkout-back-btn{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:10px;color:#fff;cursor:pointer;font-size:15px;font-weight:600;padding:12px 28px;transition:opacity .2s}.checkout-back-btn:hover{opacity:.85}.checkout-multi-note{color:#764ba2;font-size:13px;font-weight:500;margin:6px 0 0}.checkout-summary-layout{grid-gap:24px;align-items:start;display:grid;gap:24px;grid-template-columns:1fr 320px}.checkout-groups{display:flex;flex-direction:column;gap:16px}.checkout-group-card{background:#fff;border-radius:14px;box-shadow:0 2px 12px #00000012;overflow:hidden}.checkout-group-header{align-items:center;background:linear-gradient(135deg,#f8f4ff,#eef2ff);border-bottom:1px solid #e8e0f8;display:flex;flex-wrap:wrap;gap:10px;padding:12px 20px}.checkout-group-badge{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:20px;color:#fff;font-size:11px;font-weight:700;letter-spacing:.06em;padding:2px 8px;text-transform:uppercase}.checkout-group-date{color:#222;font-size:14px;font-weight:700}.checkout-group-slot{color:#667eea;font-size:13px;font-weight:600}.checkout-items{padding:4px 20px}.checkout-group-subtotal{border-top:1px solid #f0f0f0;color:#333;display:flex;font-size:14px;font-weight:700;justify-content:space-between;padding:10px 20px 14px}.slot-select-body{display:flex;flex-direction:column;gap:16px;max-width:680px}.slot-date-group{background:#fff;border-radius:14px;box-shadow:0 2px 12px #00000012;overflow:hidden}.slot-date-header{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;font-size:14px;font-weight:700;gap:8px}.slot-date-header,.slot-item-row{align-items:center;display:flex;padding:12px 20px}.slot-item-row{border-bottom:1px solid #f5f5f5;gap:16px;justify-content:space-between}.slot-item-row:last-child{border-bottom:none}.slot-item-info{align-items:center;display:flex;gap:10px;min-width:0}.slot-item-img{object-fit:cover}.slot-item-img,.slot-item-placeholder{border-radius:8px;flex-shrink:0;height:40px;width:40px}.slot-item-placeholder{align-items:center;background:#f3f3f3;display:flex;font-size:24px;justify-content:center}.slot-item-name{color:#222;font-size:14px;font-weight:600;max-width:220px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.slot-item-qty{color:#999;flex-shrink:0;font-size:13px;white-space:nowrap}.slot-picker{flex-shrink:0}.slot-select{background:#fff;border:1.5px solid #c5b8f0;border-radius:8px;color:#333;cursor:pointer;font-size:13px;font-weight:600;min-width:130px;outline:none;padding:6px 10px}.slot-select:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea26}.slot-single{background:#eef2ff;border-radius:8px;color:#667eea;font-size:13px;font-weight:600;padding:6px 12px}.slot-none{color:#bbb;font-size:12px;font-style:italic}.slot-actions{display:flex;justify-content:flex-end;padding:8px 0 16px}@media (max-width:700px){.checkout-body,.checkout-summary-layout{grid-template-columns:1fr}.checkout-summary-panel{order:-1}.checkout-item-row{gap:10px;grid-template-columns:48px 1fr auto auto}.slot-item-name{max-width:130px}}.acct-container{margin:0 auto;max-width:720px;padding:0 16px 48px}.acct-header{border-bottom:2px solid #f0f0f0;gap:16px;margin-bottom:0;padding:24px 0 20px}.acct-avatar,.acct-header{align-items:center;display:flex}.acct-avatar{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:50%;color:#fff;flex-shrink:0;font-size:22px;font-weight:700;height:56px;justify-content:center;width:56px}.acct-name{color:#222;font-size:18px;font-weight:700;margin:0 0 3px}.acct-email{color:#999;font-size:13px;margin:0}.acct-tabs{border-bottom:2px solid #f0f0f0;display:flex;gap:0;margin-bottom:24px}.acct-tab{background:none;border:none;border-bottom:3px solid #0000;color:#999;cursor:pointer;font-size:14px;font-weight:600;margin-bottom:-2px;padding:14px 20px;transition:color .2s,border-color .2s}.acct-tab:hover{color:#667eea}.acct-tab--active{border-bottom-color:#667eea;color:#667eea}.acct-error,.acct-loading,.acct-no-lines{color:#999;font-size:14px;padding:16px 0;text-align:center}.acct-error{color:#e74c3c}.acct-empty{color:#bbb;font-size:15px;padding:48px 0;text-align:center}.acct-orders{display:flex;flex-direction:column;gap:10px}.acct-order-card{background:#fff;border-radius:12px;box-shadow:0 2px 10px #0000000f;overflow:hidden}.acct-order-header{align-items:center;background:none;border:none;cursor:pointer;display:flex;gap:12px;justify-content:space-between;padding:14px 18px;text-align:left;width:100%}.acct-order-header:hover{background:#fafafa}.acct-order-meta{display:flex;flex-direction:column;gap:3px}.acct-order-no{color:#222;font-size:14px;font-weight:700}.acct-order-date{color:#aaa;font-size:12px}.acct-order-right{align-items:center;display:flex;flex-shrink:0;gap:12px}.acct-order-status{border-radius:20px;font-size:11px;font-weight:700;letter-spacing:.04em;padding:3px 10px;text-transform:uppercase}.status-placed{background:#eef2ff;color:#667eea}.status-delivered{background:#e8f8f0;color:#27ae60}.status-cancelled{background:#fdecea;color:#e74c3c}.status-default{background:#f5f5f5;color:#888}.acct-order-amount{color:#222;font-size:15px;font-weight:700;white-space:nowrap}.acct-order-chevron{color:#bbb;font-size:10px}.acct-order-body{border-top:1px solid #f5f5f5;padding:0 18px 16px}.acct-delivery-info{color:#667eea;display:flex;font-size:13px;font-weight:500;gap:16px;padding:10px 0 12px}.acct-lines-table{border-collapse:collapse;font-size:13px;width:100%}.acct-lines-table th{border-bottom:1px solid #f0f0f0;color:#aaa;font-size:11px;font-weight:600;letter-spacing:.04em;padding:0 0 8px;text-align:left;text-transform:uppercase}.acct-lines-table td{border-bottom:1px solid #f8f8f8;color:#444;padding:8px 0}.acct-lines-table tfoot td{border-bottom:none;padding-top:10px}.acct-col-num{text-align:right}.acct-total-label{color:#222;font-weight:700;padding-right:0;text-align:right}.acct-total-value{color:#222;font-size:15px;font-weight:700}.acct-details{background:#fff;border-radius:14px;box-shadow:0 2px 10px #0000000f;overflow:hidden}.acct-detail-row{align-items:flex-start;border-bottom:1px solid #f5f5f5;display:flex;gap:16px;justify-content:space-between;padding:16px 20px}.acct-detail-row:last-child{border-bottom:none}.acct-detail-label{color:#888;flex-shrink:0;font-size:13px;font-weight:600;min-width:130px}.acct-detail-value{color:#222;font-size:14px;text-align:right;white-space:pre-line;word-break:break-word}@media (max-width:500px){.acct-order-right{gap:8px}.acct-order-amount{font-size:13px}.acct-detail-row{flex-direction:column;gap:4px}.acct-detail-value{text-align:left}}*{box-sizing:border-box;margin:0;padding:0}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:#f5f5f5;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}#root{min-height:100vh}
/*# sourceMappingURL=main.37186b08.css.map*/