*{box-sizing:border-box;margin:0;padding:0}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#fafafa;color:#2c3e50;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;line-height:1.8}#root{overflow:hidden;width:100vw}#root,.app{height:100vh}.app{display:flex;flex-direction:column}.container{flex:1 1;overflow:hidden}.btn{background:#007bff;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:16px;font-weight:500;padding:12px 24px;transition:background-color .2s}.btn:hover{background:#0056b3}.btn:disabled{background:#6c757d;cursor:not-allowed}.btn-cancel{background:#f44336}.btn-cancel:hover{background:#d83123}.card{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;margin:8px;padding:16px}.text-center{text-align:center}.mb-2{margin-bottom:8px}.mb-3{margin-bottom:16px}.mt-3{margin-top:16px}.p-3{padding:16px}.flex{display:flex}.flex-column{flex-direction:column}.justify-center{justify-content:center}.align-center{align-items:center}.space-between{justify-content:space-between}.gap-2{gap:8px}.gap-3{gap:16px}.w-100{width:100%}.h-100{height:100%}.overflow-auto{overflow:auto}.overflow-hidden{overflow:hidden}.position-relative{position:relative}.position-absolute{position:absolute}.top-0{top:0}.right-0{right:0}.bottom-0{bottom:0}.left-0{left:0}.z-1{z-index:1}.z-2{z-index:2}.z-3{z-index:3}.map-error-container,.map-loading-container{align-items:center;color:#fff;display:flex;font-size:18px;height:400px;justify-content:center}.map-error-container{flex-direction:column;padding:20px;text-align:center}.map-error-icon{font-size:48px}.map-error-icon,.map-error-message{margin-bottom:16px}.map-error-button{background:#fff3;border:2px solid #ffffff4d;border-radius:12px;color:#fff;cursor:pointer;font-weight:600;padding:12px 24px}.map-error-button:hover{background:#ffffff4d}.map-header-buttons{align-items:center;display:flex;gap:12px}.map-header-button{background:#fff3;border:2px solid #ffffff4d;border-radius:12px;color:#fff;cursor:pointer;font-weight:600;padding:8px 16px;transition:all .3s ease}.map-header-button:hover{background:#ffffff4d;transform:translateY(-1px)}.map-cart-button{position:relative}.map-cart-badge{align-items:center;background:#f44;border:2px solid #fff;border-radius:50%;color:#fff;display:flex;font-size:12px;font-weight:700;height:20px;justify-content:center;position:absolute;right:-8px;top:-8px;width:20px}.map-search-container{margin-top:16px;position:relative}.map-search-wrapper{position:relative}.map-search-input{background:#fffffff2;border:2px solid #ffffff4d;border-radius:12px;box-shadow:0 4px 12px #00000026;color:#333;font-size:16px;outline:none;padding:12px 16px 12px 44px;transition:all .3s ease;width:100%}.map-search-input:focus{border-color:#ffffff80;box-shadow:0 6px 16px #0003}.map-search-icon{font-size:20px;left:16px;pointer-events:none}.map-search-icon,.map-search-loading{position:absolute;top:50%;transform:translateY(-50%)}.map-search-loading{color:#999;font-size:14px;right:16px}.map-search-results{background:#fff;border:1px solid #e0e0e0;border-radius:12px;box-shadow:0 8px 24px #0003;left:0;margin-top:8px;max-height:400px;overflow-y:auto;position:absolute;right:0;top:100%;z-index:1000}.map-search-result-item{align-items:center;border-bottom:1px solid #f0f0f0;cursor:pointer;display:flex;gap:12px;padding:16px;transition:background-color .2s ease}.map-search-result-item:hover{background-color:#f8f9fa}.map-search-result-item:last-child{border-bottom:none}.map-search-result-icon{font-size:24px}.map-search-result-content{flex:1 1}.map-search-result-name{color:#333;font-size:16px;font-weight:600;margin-bottom:4px}.map-search-result-address{color:#666;font-size:14px}.map-search-result-rating{color:#999;font-size:12px;margin-top:4px}.map-search-result-arrow{color:#ccc;font-size:20px}.map-search-empty{background:#fff;border-radius:12px;box-shadow:0 8px 24px #0003;color:#999;left:0;margin-top:8px;padding:20px;position:absolute;right:0;text-align:center;top:100%;z-index:1000}.map-info{margin-top:16px}.nearby-button-container{margin-top:12px}.cart-header-button{background:#fff3;border:2px solid #ffffff4d;border-radius:12px;color:#fff;font-weight:600;padding:8px 12px}.cart-cafe-tabs{display:flex;flex-wrap:wrap;gap:8px;margin-top:16px}.cart-filter-btn{border-radius:999px;font-weight:500;opacity:.8;padding:6px 16px}.cart-filter-btn.active{font-weight:600;opacity:1}.cart-empty-state-padding{padding:40px 0}.cart-item-image-placeholder{align-items:center;background-color:#f0f0f0;border-radius:8px;color:#999;display:flex;flex-direction:column;font-size:12px;height:100%;justify-content:center;padding:5px;text-align:center;width:100%}.cart-item-image-placeholder-icon{font-size:24px;margin-bottom:4px}.cart-item-image img{border-radius:8px}.cart-remove-btn{background:#ff4757!important;border:2px solid #ff4757!important;color:#fff!important;margin-left:8px}.cart-remove-btn:hover{background:#ff3742!important;border-color:#ff3742!important}.cart-remove-btn:active{background:#ff1e2e!important;border-color:#ff1e2e!important}.cart-total{cursor:grab}.cart-total:active{cursor:grabbing}.cart-total.collapsed{bottom:0}.cart-total-summary{margin-bottom:12px}.cart-total.collapsed .cart-total-summary{margin-bottom:0}.cart-total.collapsed .cart-total-summary h3{font-size:18px;margin-bottom:0}.cart-total.collapsed .cart-total-summary .total-price{font-size:24px}.cart-drag-handle{border:2px solid #ffffff4d;border-radius:12px;cursor:grab;margin:0 auto 16px;opacity:.7;padding:6px 0;transition:opacity .2s ease;user-select:none;-webkit-user-select:none;width:40%}.cart-drag-handle:hover{opacity:1}.cart-drag-handle:active{cursor:grabbing}.cart-cafe-info-box{background:#f8f9fa;border-radius:8px;margin-bottom:12px;padding:12px}.cart-cafe-info-text{color:#6c757d;font-size:14px;margin:0 0 4px}.cart-cafe-info-text:last-child{margin:0}.cart-item-info .price-info{align-items:center;display:flex;flex-wrap:wrap;gap:2px;line-height:1.4}.price-calculation{align-items:center;display:inline-flex;flex-shrink:0;white-space:nowrap}.price-item,.price-quantity{white-space:nowrap}.price-separator{margin:0 2px}.price-separator,.price-total{flex-shrink:0;white-space:nowrap}.price-total{font-weight:700}@media (max-width:360px){.cart-item-info .price-info{font-size:14px}.price-calculation{display:inline-flex}.price-info{flex-wrap:wrap}}.app{background:#fafafa;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;height:100%;width:100vw}.header{background:linear-gradient(135deg,#667eea,#764ba2);box-shadow:0 4px 20px #667eea26;left:0;padding:20px 16px 0;position:fixed;right:0;top:0;z-index:1000}.header h1{color:#fff;font-size:28px;font-weight:700;margin:0;text-shadow:0 2px 4px #0000001a}.header .subtitle{color:#ffffffe6;font-size:16px;font-weight:400;margin-top:6px}.nav-tabs{-ms-overflow-style:none;display:flex;gap:10px;overflow-x:auto;padding:8px;scrollbar-width:none;white-space:nowrap;width:100%}.nav-tabs::-webkit-scrollbar{display:none}.nav-tab{background:none;border:none;border-bottom:3px solid #0000;color:#8e8e93;cursor:pointer;flex:1 1;font-size:16px;font-weight:500;padding:16px 20px;position:relative;text-align:center;transition:all .3s ease;white-space:nowrap}.nav-tab,.nav-tab.active{background:#2c2c2c;border-radius:5px;box-shadow:0 2px 8px #0000000d}.nav-tab.active{color:#667eea}.map-container{box-shadow:0 -4px 20px #0000001a;height:100vh;overflow:hidden;padding-top:100px;position:relative}.map-info{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fff;border:1px solid #fff3;border-radius:20px;bottom:20px;box-shadow:0 8px 32px #0000001f;left:20px;padding:20px;position:absolute;right:20px;z-index:1000}.map-info h3{color:#2c3e50;font-size:20px;font-weight:600;margin:0 0 8px}.map-info p{color:#8e8e93;font-size:15px;line-height:1.4;margin:0 0 12px}.map-info .btn{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:12px;box-shadow:0 4px 15px #667eea4d;color:#fff;font-size:16px;font-weight:600;margin-top:12px;padding:14px;transition:all .3s ease;width:100%}.map-info .btn:hover{box-shadow:0 6px 20px #667eea66;transform:translateY(-2px)}.nearby-button-container{bottom:32px;left:50%;position:absolute;transform:translateX(-50%);z-index:1000}.nearby-button{align-items:center;background:#007bff;border:none;border-radius:16px;box-shadow:0 4px 20px #007bff4d;color:#fff;cursor:pointer;display:flex;font-size:16px;font-weight:600;gap:8px;justify-content:center;min-width:200px;padding:16px 24px;transition:all .3s ease}.nearby-button:hover{background:#0056b3;box-shadow:0 6px 25px #007bff66;transform:translateY(-2px)}.nearby-icon{font-size:18px}.menu-container{background:#fafafa;height:100vh;overflow-y:auto;padding:160px 16px 20px}.menu-section{margin-bottom:32px;padding-top:90px}.menu-section h2{color:#2c3e50;font-size:24px;font-weight:700;margin-bottom:20px;text-align:center}.menu-items{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fill,minmax(300px,1fr))}.menu-item{background:#fff;border:1px solid #fff3;border-radius:20px;box-shadow:0 4px 20px #00000014;cursor:pointer;display:flex;flex-direction:column;justify-content:space-around;min-height:400px;overflow:hidden;padding:20px;position:relative;transition:all .3s ease}.menu-item:before{content:"";height:4px;left:0;opacity:0;position:absolute;right:0;top:0;transition:opacity .3s ease}.menu-item:hover{box-shadow:0 8px 32px #0000001f;transform:translateY(-4px)}.menu-item:hover:before{opacity:1}.menu-item-image{align-items:center;background:linear-gradient(135deg,#f5f7fa,#c3cfe2);border-radius:16px;color:#8e8e93;display:flex;font-size:14px;height:250px;justify-content:center;margin-bottom:16px;overflow:hidden;position:relative;width:100%}.menu-item-image img{border-radius:16px;height:100%;object-fit:contain;width:100%}.menu-item h3{color:#2c3e50;font-size:18px;font-weight:600;margin-bottom:8px}.menu-item p{color:#8e8e93;font-size:15px;line-height:1.5;margin-bottom:16px}.menu-item-price{color:#667eea;font-size:22px;font-weight:700;margin-bottom:16px}.menu-item .btn{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:12px;box-shadow:0 4px 15px #667eea4d;color:#fff;font-size:16px;font-weight:600;padding:12px 20px;transition:all .3s ease;width:100%}.menu-item .btn:hover{box-shadow:0 6px 20px #667eea66;transform:translateY(-2px)}.cart-container{background:#fafafa;display:flex;flex-direction:column;height:100vh;padding:160px 16px 20px}.cart-coffee-shop-info{background:#fff;border:1px solid #667eea1f;border-radius:18px;box-shadow:0 8px 26px #667eea1f;display:flex;flex-wrap:wrap;gap:10px;margin:12px 0 20px;padding:14px 16px;position:-webkit-sticky;position:sticky;top:120px;z-index:2}.cart-coffee-shop-info:before{color:#667eea;content:"Кофейни";font-size:14px;font-weight:600;letter-spacing:.4px;width:100%}.cart-coffee-shop-info .filter-btn{background:#667eea14;border:1px solid #667eea40;color:#2c3e50;transition:all .2s ease}.cart-coffee-shop-info .filter-btn:hover{background:#667eea29;border-color:#667eea59}.cart-coffee-shop-info .filter-btn.active{background:linear-gradient(135deg,#667eea,#764ba2);border-color:#0000;box-shadow:0 10px 24px #667eea59;color:#fff}.cart-items{flex:1 1;margin-bottom:20px;overflow-y:auto}.cart-item{align-items:center;background:#fff;border:1px solid #fff3;border-radius:20px;box-shadow:0 4px 20px #00000014;display:flex;gap:16px;margin-bottom:16px;padding:20px;transition:all .3s ease}.cart-item:hover{box-shadow:0 6px 24px #0000001f;transform:translateY(-2px)}.cart-item-image{align-items:center;background:linear-gradient(135deg,#f5f7fa,#c3cfe2);border-radius:16px;color:#8e8e93;display:flex;flex-shrink:0;font-size:12px;height:80px;justify-content:center;overflow:hidden;width:80px}.cart-item-image img{border-radius:16px;height:100%;object-fit:cover;width:100%}.cart-item-info{flex:1 1}.cart-item h4{color:#2c3e50;font-size:18px;font-weight:600;margin-bottom:6px}.cart-item p{color:#8e8e93;font-size:15px;line-height:1.4;margin:0 0 8px}.cart-item .price-info{color:#667eea;font-size:16px;font-weight:600}.cart-item-controls{flex-wrap:wrap;justify-content:flex-end}.cart-item-controls,.quantity-controls{align-items:center;display:flex;flex-direction:row;gap:12px}.quantity-btn{align-items:center;background:#fff;border:2px solid #e9ecef;border-radius:12px;color:#667eea;cursor:pointer;display:flex;font-size:20px;font-weight:600;height:40px;justify-content:center;transition:all .3s ease;width:40px}.quantity-btn:hover{background:#667eea;border-color:#667eea;color:#fff;transform:scale(1.1)}.quantity{color:#b0b0b0;font-size:18px;font-weight:700;min-width:50px;text-align:center}.cart-total{background:#2c3e50;border-bottom-left-radius:0;border-bottom-right-radius:0;border-top-left-radius:20px;border-top-right-radius:20px;bottom:0;box-shadow:0 -8px 32px #0000004d;left:0;padding:20px;position:fixed;right:0;transform:translateY(0);transition:transform .4s cubic-bezier(.4,0,.2,1);-webkit-user-select:none;user-select:none;z-index:1000}.cart-total.collapsed{transform:translateY(calc(100% - 80px))}.cart-total.swiping{transition:none}.cart-total h3{color:#fff;font-size:20px;font-weight:600;margin-bottom:12px}.cart-total .total-price{color:#fff;font-size:28px;font-weight:700}.cart-total .btn{background:#ffffff1a;border:1px solid #ffffff4d;border-radius:12px;color:#fff;cursor:pointer;font-size:16px;font-weight:600;margin-top:10px;padding:12px 20px;transition:all .2s ease;width:100%}.cart-total .btn:last-child{background:linear-gradient(135deg,#667eea,#764ba2);border:none;box-shadow:0 4px 15px #667eea66}.cart-total .btn:hover{background:#fff3}.cart-total .btn:last-child:hover{opacity:.9}.cart-actions{display:flex;gap:16px}.cart-actions .btn{border-radius:12px;flex:1 1;font-size:16px;font-weight:600;padding:16px 20px;transition:all .3s ease}.cart-actions .btn-secondary{background:#f8f9fa;border:2px solid #e9ecef;color:#6c757d}.cart-actions .btn-secondary:hover{background:#e9ecef;color:#495057;transform:translateY(-2px)}.cart-actions .btn:not(.btn-secondary){background:linear-gradient(135deg,#667eea,#764ba2);border:none;box-shadow:0 4px 15px #667eea4d;color:#fff}.cart-actions .btn:not(.btn-secondary):hover{box-shadow:0 6px 20px #667eea66;transform:translateY(-2px)}.empty-state{border-radius:20px;box-shadow:0 4px 20px #00000014;color:#8e8e93}.empty-state h3{color:#2c3e50;font-weight:600;margin-bottom:12px}.empty-state p{font-size:16px;line-height:1.5}.empty-state .btn{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:12px;box-shadow:0 4px 15px #667eea4d;color:#fff;font-size:16px;font-weight:600;padding:14px 28px;transition:all .3s ease}.empty-state .btn:hover{box-shadow:0 6px 20px #667eea66;transform:translateY(-2px)}.floating-cart-btn{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:16px;bottom:20px;box-shadow:0 8px 32px #667eea4d;color:#fff;display:flex;font-size:16px;font-weight:600;gap:8px;justify-content:center;left:20px;padding:16px 20px;position:fixed;right:20px;transition:all .3s ease;z-index:1000}.floating-cart-btn:hover{box-shadow:0 12px 40px #667eea66;transform:translateY(-2px)}.floating-cart-btn .cart-icon{font-size:20px}.modal-overlay{align-items:center;animation:fadeIn .2s ease-out;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0009;bottom:0;display:flex;justify-content:center;left:0;padding:20px;position:fixed;right:0;top:0;z-index:2000}.modal-container{animation:slideUp .3s ease-out;background:#fff;border-radius:24px;box-shadow:0 20px 60px #0000004d;display:flex;flex-direction:column;max-height:90vh;max-width:600px;width:100%}.modal-header{align-items:center;border-bottom:1px solid #e9ecef;display:flex;justify-content:space-between;padding:24px 24px 16px}.modal-header h2{color:#2c3e50;font-size:24px;font-weight:700;margin:0}.modal-close-btn{align-items:center;background:none;border:none;border-radius:50%;color:#8e8e93;cursor:pointer;display:flex;font-size:32px;height:40px;justify-content:center;padding:0;transition:all .2s ease;width:40px}.modal-close-btn:hover{background:#f8f9fa;color:#2c3e50}.modal-body{flex:1 1;overflow-y:auto;padding:24px}.modal-description{color:#6c757d;font-size:15px;line-height:1.5;margin-bottom:24px}.time-slots-grid{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(auto-fill,minmax(140px,1fr))}.time-slot-btn{align-items:center;background:#fff;border:2px solid #e9ecef;border-radius:12px;cursor:pointer;display:flex;flex-direction:column;gap:4px;padding:16px;transition:all .2s ease}.time-slot-btn:hover{background:#667eea0d;border-color:#667eea;transform:translateY(-2px)}.time-slot-btn.selected{background:linear-gradient(135deg,#667eea,#764ba2);border-color:#667eea;box-shadow:0 4px 15px #667eea4d}.time-slot-time{color:#2c3e50;font-size:18px;font-weight:600}.time-slot-btn.selected .time-slot-time{color:#fff}.time-slot-info{color:#8e8e93;font-size:13px}.time-slot-btn.selected .time-slot-info{color:#ffffffe6}.custom-time-input-container{background:#f8f9fa;border-radius:16px;margin-bottom:24px;padding:20px}.custom-time-label{color:#2c3e50;display:block;font-size:16px;font-weight:600;margin-bottom:12px}.custom-time-input{background:#fff;border:2px solid #e9ecef;border-radius:12px;color:#2c3e50;font-size:18px;font-weight:600;padding:14px 16px;transition:all .2s ease;width:100%}.custom-time-input:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a;outline:none}.custom-time-error{background:#fee;border:1px solid #fcc;border-radius:8px;color:#c33}.custom-time-error,.custom-time-success{font-size:14px;margin-top:12px;padding:12px}.custom-time-success{background:#efe;border:1px solid #cfc;border-radius:8px;color:#393;font-weight:600}.time-divider{margin:24px 0;position:relative;text-align:center}.time-divider:before{background:#e9ecef;content:"";height:1px;left:0;position:absolute;right:0;top:50%}.time-divider span{background:#fff;color:#8e8e93;font-size:14px;font-weight:500;padding:0 16px;position:relative}.modal-footer{border-top:1px solid #e9ecef;display:flex;gap:12px;padding:16px 24px 24px}.modal-footer .btn{border:none;border-radius:12px;cursor:pointer;flex:1 1;font-size:16px;font-weight:600;padding:14px 24px;transition:all .2s ease}.modal-footer .btn-secondary{background:#f8f9fa;border:2px solid #e9ecef;color:#6c757d}.modal-footer .btn-secondary:hover{background:#e9ecef;color:#495057}.modal-footer .btn-primary{background:linear-gradient(135deg,#667eea,#764ba2);box-shadow:0 4px 15px #667eea4d;color:#fff}.modal-footer .btn-primary:hover{box-shadow:0 6px 20px #667eea66;transform:translateY(-1px)}.modal-footer .btn-primary:disabled{cursor:not-allowed;opacity:.6;transform:none}.payment-modal .modal-container{max-width:500px}.order-summary{background:#f8f9fa;border-radius:16px;margin-bottom:24px;padding:20px}.order-summary h3{color:#2c3e50;font-size:18px;font-weight:600;margin:0 0 16px}.order-summary h4{color:#2c3e50;font-size:16px;font-weight:600;margin:16px 0 12px}.order-info-item{border-bottom:1px solid #e9ecef;display:flex;justify-content:space-between;margin-bottom:12px;padding-bottom:12px}.order-label{color:#6c757d;font-size:15px}.order-value{color:#2c3e50;font-size:15px;font-weight:600}.order-item-row{color:#495057;font-size:14px;gap:12px;padding:8px 0}.order-total{border-top:2px solid #667eea;color:#2c3e50;display:flex;font-size:18px;font-weight:700;justify-content:space-between;margin-top:16px;padding-top:16px}.total-amount{color:#667eea}.payment-placeholder{background:linear-gradient(135deg,#667eea0d,#764ba20d);border:2px dashed #667eea;border-radius:16px;padding:32px 20px;text-align:center}.payment-icon{font-size:48px;margin-bottom:16px}.payment-notice{color:#667eea;font-size:16px;font-weight:600;margin-bottom:8px}.payment-info{color:#6c757d;font-size:14px;margin:0}.offerta-agreement{background:#f8f9fa;border-radius:8px;border-top:1px solid #e0e0e0;margin-top:20px;padding:15px;text-align:center}.offerta-agreement span{color:#666;font-size:14px}.offerta-agreement a{color:#667eea;text-decoration:underline;transition:color .2s}.offerta-agreement a:hover{color:#764ba2}.app .offerta-container{background-color:#fafafa;color:#333;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;line-height:1.8;margin:0 auto;max-width:900px;min-height:100vh;overflow-y:auto;padding:40px 20px;position:relative}.offerta-container p{margin-bottom:15px;text-align:justify}.offerta-container ul{margin-bottom:20px;padding-left:25px}.offerta-container li{margin-bottom:10px}.offerta-title{font-size:24px;margin-bottom:30px}.offerta-section,.offerta-title{color:#0f4761;font-weight:700;text-align:center}.offerta-section{font-size:20px;margin-bottom:20px;margin-top:30px}.offerta-info-box{background:#f8f9fa;border-radius:8px;margin-top:20px;padding:20px}.offerta-info-box p{margin-bottom:10px}.offerta-footer{border-top:1px solid #ddd;color:#666;font-size:12px;margin-top:40px;padding-top:20px;text-align:center}.order-status-container{background:linear-gradient(135deg,#667eea,#764ba2);height:100vh;overflow-y:auto;padding-top:100px;position:relative}.order-status-content{margin:0 auto;max-width:600px;padding:20px 20px 40px}.order-status-card{background:#fff;border-radius:16px;box-shadow:0 8px 24px #0000001f;margin-bottom:20px;padding:24px}.status-badge{align-items:center;border-radius:24px;box-shadow:0 4px 12px #00000026;color:#fff;display:inline-flex;font-size:18px;font-weight:600;gap:8px;margin-bottom:20px;padding:12px 20px}.status-icon{font-size:24px}.status-label{font-size:16px}.progress-tracker{margin-top:24px}.progress-bar-container{background:#e0e0e0;border-radius:3px;height:6px;margin-bottom:20px;overflow:hidden;width:100%}.progress-bar-fill{border-radius:3px;height:100%;transition:width .5s ease}.progress-steps{align-items:flex-start;display:flex;justify-content:space-between}.progress-step{align-items:center;display:flex;flex:1 1;flex-direction:column;font-size:12px;gap:8px;text-align:center;transition:all .3s ease}.progress-step.active{font-weight:600}.step-icon{font-size:24px;margin-bottom:4px}.step-label{font-size:11px;line-height:1.2}.order-info-card{background:#fff;border-radius:16px;box-shadow:0 8px 24px #0000001f;margin-bottom:20px;padding:24px}.order-info-card h3{color:#333;font-size:18px;font-weight:600;margin:0 0 16px}.cafe-name{color:#333;display:block;font-size:16px;margin-bottom:8px}.cafe-address{color:#666;display:block;font-size:14px;margin-bottom:12px}.time-remaining{background:#667eea1a;border-radius:8px;color:#667eea;font-size:16px;font-weight:600;margin:12px 0;padding:12px;text-align:center}.ready-time{color:#666;font-size:14px;margin-top:8px}.order-items-list{margin-top:16px}.order-item-row{align-items:center;border-bottom:1px solid #f0f0f0;display:flex;justify-content:space-between;padding:12px 0}.order-item-row:last-child{border-bottom:none}.item-info{align-items:center;display:flex;flex:1 1;gap:8px}.item-name{color:#333;font-size:14px}.item-quantity{color:#999;font-size:14px}.item-price{color:#333;font-size:14px;font-weight:600}.order-total-row{align-items:center;border-top:2px solid #e0e0e0;display:flex;font-size:18px;font-weight:700;justify-content:space-between;margin-top:16px;padding-top:16px}.total-label{color:#333}.total-price{color:#667eea}.payment-status{font-size:16px;font-weight:600;margin-bottom:8px}.payment-method{color:#666;font-size:14px}.order-history-container{background:linear-gradient(135deg,#667eea,#764ba2);height:100vh;overflow-y:auto;padding-top:100px;position:relative}.order-history-content{margin:0 auto;max-width:800px;padding:85px 20px}.order-filters{-ms-overflow-style:none;display:flex;gap:8px;overflow-x:auto;padding:12px 0;scrollbar-width:none}.order-filters::-webkit-scrollbar{display:none}.filter-btn{background:#ffffff26;border:2px solid #ffffff4d;border-radius:20px;color:#fff;cursor:pointer;flex-shrink:0;font-size:14px;font-weight:600;padding:10px 16px;transition:all .3s ease;white-space:nowrap}.filter-btn.active{background:#fff;border-color:#fff;color:#667eea}.filter-btn:hover{background:#ffffff40}.filter-btn.active:hover{background:#fff}.order-group{margin-bottom:32px}.order-group-title{color:#fff;font-size:18px;font-weight:700;margin-bottom:12px;padding-left:4px}.order-card{background:#fff;border-radius:16px;box-shadow:0 4px 16px #0000001a;cursor:pointer;margin-bottom:12px;padding:20px;transition:all .3s ease}.order-card:hover{box-shadow:0 8px 24px #00000026;transform:translateY(-2px)}.order-card:active{transform:translateY(0)}.order-card-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:12px}.order-number{color:#333;font-size:16px;font-weight:700}.order-status-badge{align-items:center;border-radius:12px;color:#fff;display:inline-flex;font-size:12px;font-weight:600;gap:4px;padding:6px 12px}.order-cafe-info,.order-card-body{margin-bottom:12px}.order-cafe-info{align-items:center;color:#333;display:flex;font-size:14px;gap:8px}.cafe-icon{font-size:16px}.cafe-name{font-weight:600}.order-details{align-items:center;color:#666;display:flex;font-size:13px;justify-content:space-between;margin-bottom:12px}.order-price,.order-time{align-items:center;display:flex;gap:4px}.order-price{color:#667eea;font-weight:600}.order-items-preview{display:flex;flex-wrap:wrap;gap:8px;margin-top:12px}.order-item-preview{background:#f5f5f5;color:#666}.order-item-preview,.order-items-more{border-radius:8px;font-size:12px;padding:4px 10px}.order-items-more{background:#e0e0e0;color:#999;font-weight:600}.order-card-footer{align-items:center;border-top:1px solid #f0f0f0;display:flex;flex-direction:row-reverse;justify-content:space-between;padding-top:12px}.order-view-link{color:#667eea;font-size:14px;font-weight:600}.btn-cancel{background:#ffecec;border:2px solid #ff6b6b99;border-radius:12px;color:#ff3b3b;font-weight:600;padding:10px 18px;transition:all .2s ease}.btn-cancel:hover{background:#ffd6d6;border-color:#ff6b6be6;color:#ff1f1f}.btn-cancel:disabled{cursor:not-allowed;opacity:.6}.modal-overlay .modal-actions .btn.btn-cancel{min-width:150px}.modal-overlay>.modal-content{animation:slideUp .3s ease-out;border-radius:24px;box-shadow:0 20px 60px #0000004d;color:#fff;position:relative}.order-actions-container{animation:slideUp .3s ease-out;bottom:20px;display:flex;flex-direction:row-reverse;gap:12px;left:20px;margin:0 auto;max-width:600px;position:fixed;right:20px;z-index:1000}.order-payment-btn{align-items:center;background:linear-gradient(135deg,#4caf50,#45a049);border:none;border-radius:16px;box-shadow:0 8px 32px #4caf504d;color:#fff;cursor:pointer;display:flex;font-size:16px;font-weight:600;gap:8px;justify-content:center;padding:16px 20px;position:relative;transition:all .3s ease;width:100%}.order-payment-btn:hover{box-shadow:0 12px 40px #4caf5066;transform:translateY(-2px)}.order-payment-btn:active{transform:translateY(0)}.order-cancel-btn{align-items:center;background:#f44336d9;border:2px solid #f44336;border-radius:16px;box-shadow:0 8px 32px #f4433633;color:#fff;cursor:pointer;display:flex;font-size:16px;font-weight:600;gap:8px;justify-content:center;padding:16px 20px;position:relative;transition:all .3s ease;width:100%}.order-cancel-btn:hover{background:#f44336f2;box-shadow:0 12px 40px #f443364d;transform:translateY(-2px)}.order-cancel-btn:active{transform:translateY(0)}.order-new-order-btn{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:16px;box-shadow:0 8px 32px #667eea4d;color:#fff;cursor:pointer;display:flex;font-size:16px;font-weight:600;gap:8px;justify-content:center;padding:16px 20px;position:relative;transition:all .3s ease;width:100%}.order-new-order-btn:hover{box-shadow:0 12px 40px #667eea66;transform:translateY(-2px)}.order-new-order-btn:active{transform:translateY(0)}.floating-new-order-btn{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:28px;bottom:24px;box-shadow:0 8px 24px #667eea66;color:#fff;cursor:pointer;display:flex;font-size:16px;font-weight:700;justify-content:center;padding:16px 24px;position:fixed;right:24px;transition:all .3s ease;z-index:900}.floating-new-order-btn:hover{box-shadow:0 12px 32px #667eea80;transform:translateY(-2px)}.floating-new-order-btn:active{transform:translateY(0)}.empty-state{align-items:center;background:#fff;border-radius:16px;box-shadow:0 4px 16px #0000001a;display:flex;flex-direction:column;justify-content:center;margin:20px;padding:60px 20px;text-align:center}.empty-state h3{color:#333;font-size:22px;font-weight:700;margin:16px 0 8px}.empty-state p{color:#999;font-size:14px;margin-bottom:24px;max-width:300px}.empty-state .btn{margin-top:16px}.item-customization-modal{max-width:500px}.customization-section{margin-bottom:24px}.section-title{color:#2c3e50;font-size:16px;font-weight:600;margin-bottom:12px}.size-list{display:flex;flex-wrap:wrap;gap:10px}.size-pill{align-items:center;background:#fff;border:2px solid #e0e0e0;border-radius:12px;cursor:pointer;display:flex;flex:1 1;flex-direction:column;gap:4px;min-width:100px;padding:12px 16px;transition:all .2s ease}.size-pill:hover{background:#667eea0d;border-color:#667eea}.size-pill.active{background:linear-gradient(135deg,#667eea,#764ba2);border-color:#667eea;color:#fff}.size-name{font-size:16px;font-weight:600}.size-volume{font-size:12px;opacity:.8}.size-price{font-size:14px;font-weight:600}.addons-list{display:flex;flex-direction:column;gap:8px}.addon-row{align-items:center;background:#fff;border:2px solid #e0e0e0;border-radius:12px;cursor:pointer;display:flex;justify-content:space-between;padding:12px 16px;transition:all .2s ease}.addon-row:hover{background:#667eea0d;border-color:#667eea}.addon-row.selected{background:#667eea1a;border-color:#667eea}.addon-row input[type=checkbox]{accent-color:#667eea;cursor:pointer;height:20px;margin-right:12px;width:20px}.addon-info{display:flex;flex:1 1;flex-direction:column;gap:2px}.addon-name{color:#2c3e50;font-size:15px;font-weight:500}.addon-volume{color:#999;font-size:12px}.addon-price{color:#667eea;font-size:14px;font-weight:600}.quantity-controls-modal{background:#f8f9fa;gap:20px;padding:16px}.quantity-controls-modal,.quantity-controls-modal .quantity-btn{align-items:center;border-radius:12px;display:flex;justify-content:center}.quantity-controls-modal .quantity-btn{background:#fff;border:2px solid #667eea;color:#667eea;cursor:pointer;font-size:20px;font-weight:600;height:44px;transition:all .2s ease;width:44px}.quantity-controls-modal .quantity-btn:hover{background:#667eea;color:#fff}.quantity-controls-modal .quantity{color:#2c3e50;font-size:20px;font-weight:600;min-width:40px;text-align:center}.customization-total{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:12px;display:flex;justify-content:space-between;margin-top:20px;padding:16px}.customization-total .total-label{color:#fff;font-size:18px;font-weight:600}.customization-total .total-price{color:#fff;font-size:24px;font-weight:700}.no-customizations{color:#666;font-size:14px;padding:20px;text-align:center}@keyframes fadeInUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.menu-item{animation:fadeInUp .6s ease-out}.menu-item:first-child{animation-delay:.1s}.menu-item:nth-child(2){animation-delay:.2s}.menu-item:nth-child(3){animation-delay:.3s}.menu-item:nth-child(4){animation-delay:.4s}.menu-item:nth-child(5){animation-delay:.5s}.menu-item:nth-child(6){animation-delay:.6s}@keyframes pulse{0%{transform:scale(1)}50%{transform:scale(1.05)}to{transform:scale(1)}}.btn:hover{animation:pulse .6s ease-in-out}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.loading{animation:spin 1s linear infinite}@keyframes slideInRight{0%{opacity:0;transform:translateX(100%)}to{opacity:1;transform:translateX(0)}}.notification{animation:slideInRight .5s ease-out}@keyframes bounce{0%,20%,50%,80%,to{transform:translateY(0)}40%{transform:translateY(-10px)}60%{transform:translateY(-5px)}}.floating-cart-btn,.order-payment-btn{animation:bounce 2s infinite}@keyframes scaleIn{0%{transform:scale(0)}to{transform:scale(1)}}.cart-badge{animation:scaleIn .3s ease-out}@keyframes slideInLeft{0%{opacity:0;transform:translateX(-50px)}to{opacity:1;transform:translateX(0)}}.cart-item{animation:slideInLeft .5s ease-out}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(50px)}to{opacity:1;transform:translateY(0)}}.modal-overlay{animation:fadeIn .3s ease-out}.modal-content{animation:slideUp .3s ease-out}@keyframes tabSlide{0%{transform:translateX(-100%)}to{transform:translateX(0)}}.nav-tab.active:before{animation:tabSlide .3s ease-out;bottom:0;content:"";height:3px;left:0;position:absolute;right:0}@keyframes mapFadeIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.map-container{animation:mapFadeIn .8s ease-out}@keyframes cardFloat{0%,to{transform:translateY(0)}50%{transform:translateY(-5px)}}.map-info{animation:cardFloat 3s ease-in-out infinite}@keyframes iconRotate{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.icon-spin{animation:iconRotate 1s linear infinite}@keyframes progressFill{0%{width:0}to{width:100%}}.progress-bar{animation:progressFill 2s ease-out}@keyframes textGlow{0%,to{text-shadow:0 0 5px #667eea80}50%{text-shadow:0 0 20px #667eeacc}}.glow-text{animation:textGlow 2s ease-in-out infinite}@keyframes buttonLoading{0%{background-position:0 50%}50%{background-position:100% 50%}to{background-position:0 50%}}.btn-loading{animation:buttonLoading 2s ease infinite;background:linear-gradient(45deg,#667eea,#764ba2,#667eea);background-size:200% 200%}@keyframes successPulse{0%{box-shadow:0 0 0 0 #28a745b3;transform:scale(1)}70%{box-shadow:0 0 0 10px #28a74500;transform:scale(1.05)}to{box-shadow:0 0 0 0 #28a74500;transform:scale(1)}}.success-animation{animation:successPulse .6s ease-out}@keyframes errorShake{0%,to{transform:translateX(0)}10%,30%,50%,70%,90%{transform:translateX(-5px)}20%,40%,60%,80%{transform:translateX(5px)}}.error-animation{animation:errorShake .5s ease-in-out}@keyframes listItemAppear{0%{opacity:0;transform:translateX(-20px)}to{opacity:1;transform:translateX(0)}}.list-item{animation:listItemAppear .4s ease-out}.list-item:first-child{animation-delay:.1s}.list-item:nth-child(2){animation-delay:.2s}.list-item:nth-child(3){animation-delay:.3s}.list-item:nth-child(4){animation-delay:.4s}.list-item:nth-child(5){animation-delay:.5s}@keyframes hoverGlow{0%{box-shadow:0 4px 20px #00000014}to{box-shadow:0 8px 32px #667eea33}}.hover-glow:hover{animation:hoverGlow .3s ease-out forwards}@keyframes pageLoad{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.page-load{animation:pageLoad .6s ease-out}@keyframes scrollIndicator{0%{transform:translateY(0)}50%{transform:translateY(10px)}to{transform:translateY(0)}}.scroll-indicator{animation:scrollIndicator 2s ease-in-out infinite}@media (max-width:768px){.header{padding:16px 12px 12px}.header h1{font-size:24px}.header .subtitle{font-size:14px}.nav-tab{font-size:15px;padding:14px 16px}.menu-section{padding-top:90px}.menu-items{gap:16px;grid-template-columns:1fr}.menu-item{padding:16px}.cart-container,.menu-container{padding:16px 8px}.map-container{border-radius:16px 16px 0 0;margin:0 8px}.map-info{border-radius:16px;left:12px;padding:16px;right:12px}.cart-actions{flex-direction:column}.floating-cart-btn{font-size:15px;left:12px;padding:14px 16px;right:12px}.order-history-content,.order-status-content{padding:65px 16px}.order-info-card,.order-status-card{padding:16px}.status-badge{font-size:16px;padding:10px 16px}.progress-step{font-size:10px}.step-icon{font-size:20px}.order-card{padding:16px}.order-actions-container{bottom:12px;gap:10px;left:12px;right:12px}.order-cancel-btn,.order-new-order-btn,.order-payment-btn{font-size:15px;padding:14px 16px}.floating-new-order-btn{bottom:16px;font-size:14px;padding:12px 20px;right:16px}.search-container{margin-top:12px!important}.search-input{font-size:14px!important;padding:10px 14px 10px 40px!important}.search-results{max-height:300px!important}.search-result-item{padding:12px!important}.btn,.quantity-btn{min-height:44px;min-width:44px}.cart-items,.menu-container{-webkit-overflow-scrolling:touch;overscroll-behavior:contain}.cart-item,.menu-item,.nav-tab{-webkit-tap-highlight-color:transparent;-webkit-touch-callout:none;-webkit-user-select:none;user-select:none}.btn:active,.nav-tab:active,.quantity-btn:active{transform:scale(.95);transition:transform .1s ease}.header h1{font-size:22px}.menu-item h3{font-size:16px}.menu-item-price{font-size:20px}.cart-item-controls{gap:16px}.quantity-btn{font-size:22px;height:44px;width:44px}.floating-cart-btn{border-radius:20px;font-size:16px;padding:18px 20px}.menu-item{margin-bottom:16px}.map-info{border-radius:24px;padding:20px}.map-info h3{font-size:18px}.map-info p{font-size:14px}.menu-item:hover{transform:translateY(-2px)}.cart-item:hover{transform:translateY(-1px)}.menu-item:hover:before{opacity:0}.menu-item:active:before{opacity:1}.map-info p,.menu-item p{color:#555}.btn{font-weight:600;text-shadow:none}.cart-item,.menu-item{border:1px solid #f0f0f0}}@media (max-width:480px){.header{padding:12px 8px 8px}.header h1{font-size:20px}.header .subtitle{font-size:13px}.nav-tab{font-size:14px;padding:12px 8px}.map-container{padding-top:80px}.cart-container,.menu-container{padding:12px 8px}.menu-section{padding-top:70px}.menu-section h2{font-size:20px}.menu-item{padding:16px}.menu-item h3{font-size:15px}.menu-item p{font-size:13px}.menu-item-price{font-size:18px}.cart-item{gap:12px;padding:16px}.cart-coffee-shop-info{gap:8px;margin:12px 0 16px;padding:12px;position:static}.cart-coffee-shop-info:before{font-size:13px}.cart-item-image{height:60px;width:60px}.cart-item h4{font-size:15px}.cart-item p{font-size:13px}.quantity-btn{font-size:20px;height:40px;width:40px}.floating-cart-btn{font-size:15px;padding:16px 18px}.map-info{border-radius:20px;padding:16px}.map-info h3{font-size:16px}.map-info p{font-size:13px}.modal-overlay{padding:10px}.modal-header h2{font-size:20px}.time-slots-grid{gap:10px;grid-template-columns:repeat(auto-fill,minmax(120px,1fr))}.modal-footer{flex-direction:column}}@media (max-width:768px) and (orientation:landscape){.header{padding:8px 12px 6px}.header h1{font-size:18px}.header .subtitle{font-size:12px}.nav-tab{font-size:13px;padding:8px 6px}.map-container{height:100vh;padding-top:70px}.cart-container,.menu-container{height:100vh;padding:130px 8px 12px}.floating-cart-btn{bottom:10px;font-size:14px;padding:12px 16px}.nearby-button{font-size:15px;min-width:180px;padding:14px 20px}}@supports (padding:max(0px)){.header{padding-top:max(20px,env(safe-area-inset-top))}.cart-container,.map-container,.menu-container{padding-top:max(100px,calc(100px + env(safe-area-inset-top)))}.cart-container,.menu-container{padding-bottom:max(20px,env(safe-area-inset-bottom))}.floating-cart-btn{bottom:max(20px,env(safe-area-inset-bottom))}}@media (prefers-color-scheme:dark){.app{background:#1a1a1a}.cart-item,.cart-total,.empty-state,.map-info,.menu-item{background:#2c2c2c;color:#fff}.cart-item h4,.cart-total h3,.empty-state h3,.map-info h3,.menu-item h3{color:#fff}.cart-item p,.empty-state p,.map-info p,.menu-item p{color:#b0b0b0}}@media (max-width:768px){.menu-item:hover{transform:translateY(-2px)}.cart-item:hover{transform:translateY(-1px)}.menu-item:hover:before{opacity:0}.menu-item:active:before{opacity:1}.map-info p,.menu-item p{color:#555}.btn{font-weight:600;text-shadow:none}.cart-item,.menu-item{border:1px solid #f0f0f0}}
/*# sourceMappingURL=main.225bab7a.css.map*/