.header{background-color:#fff;box-shadow:0 2px 8px #0000001a;position:sticky;top:0;z-index:1000}.header-container{max-width:1200px;margin:0 auto;padding:16px 20px;display:flex;justify-content:center;align-items:center}.header-logo{text-decoration:none;color:#333}.header-logo-img{display:block;height:50px;width:auto;transition:transform .2s ease}.header-logo:hover .header-logo-img{transform:scale(1.05)}@media (max-width: 768px){.header-container{padding:12px 16px}.header-logo-img{height:40px}}.add-location-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;display:flex;justify-content:center;align-items:center;z-index:2000;padding:20px}.add-location-modal{background:#fff;border-radius:16px;width:100%;max-width:800px;max-height:90vh;overflow-y:auto;box-shadow:0 4px 20px #0000004d;display:flex;flex-direction:column}.add-location-modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;border-bottom:1px solid #e0e0e0}.add-location-modal-header h2{margin:0;font-size:24px;font-weight:700;color:#333}.add-location-modal-close{background:none;border:none;font-size:32px;color:#666;cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:all .2s ease}.add-location-modal-close:hover{background-color:#f0f0f0;color:#333}.add-location-modal-content{padding:24px;flex:1;overflow-y:auto}.add-location-loading,.add-location-permission{text-align:center;padding:40px 20px}.add-location-map-container{position:relative;width:100%;height:400px;min-height:300px;border-radius:12px;overflow:hidden;margin-bottom:24px;border:2px solid #e0e0e0}.add-location-map{width:100%;height:100%;min-height:300px;display:block}.add-location-geocoding-overlay{position:absolute;top:0;left:0;right:0;bottom:0;background-color:#ffffffe6;display:flex;justify-content:center;align-items:center;z-index:10}.add-location-geocoding-loader{text-align:center;padding:20px;background:#fff;border-radius:8px;box-shadow:0 2px 8px #0000001a}.add-location-geocoding-loader p{margin:0;color:#666;font-size:14px}.add-location-form{display:flex;flex-direction:column;gap:20px}.add-location-form .form-group{display:flex;flex-direction:column;gap:8px}.add-location-form label{font-weight:600;color:#333;font-size:14px}.add-location-form .form-control{padding:12px 16px;border:2px solid #e0e0e0;border-radius:8px;font-size:16px;font-family:inherit;transition:all .3s ease}.add-location-form .form-control:focus{outline:none;border-color:#007bff;box-shadow:0 0 0 3px #007bff1a}.add-location-form .form-control:disabled{background-color:#f5f5f5;cursor:not-allowed}.add-location-form .form-help-text{font-size:12px;color:#666;margin-top:4px}.add-location-form .loading-text{color:#007bff;font-weight:500}.add-location-modal-actions{display:flex;gap:12px;justify-content:flex-end;margin-top:8px}.add-location-modal-actions .btn{padding:12px 24px;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:all .3s ease;border:none}.add-location-modal-actions .btn-primary{background-color:#007bff;color:#fff}.add-location-modal-actions .btn-primary:hover:not(:disabled){background-color:#0056b3}.add-location-modal-actions .btn-primary:disabled{background-color:#ccc;cursor:not-allowed;opacity:.6}.add-location-modal-actions .btn-secondary{background-color:#f8f9fa;color:#333;border:2px solid #e0e0e0}.add-location-modal-actions .btn-secondary:hover:not(:disabled){background-color:#e9ecef;border-color:#ccc}.error-message{background-color:#fee;color:#c33;padding:12px 16px;border-radius:8px;border:1px solid #fcc;font-size:14px;margin-bottom:20px}@media (max-width: 768px){.add-location-modal{max-width:100%;max-height:100vh;height:100vh;border-radius:0;display:flex;flex-direction:column}.add-location-modal-overlay{padding:0}.add-location-modal-header{padding:16px;flex-shrink:0}.add-location-modal-content{padding:16px;flex:1;overflow-y:auto;min-height:0}.add-location-map-container{height:300px;min-height:300px;flex-shrink:0}.add-location-map{min-height:300px}.add-location-modal-actions{flex-direction:column;gap:8px}.add-location-modal-actions .btn{width:100%}}.view-locations-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;display:flex;justify-content:center;align-items:center;z-index:2000;padding:20px}.view-locations-modal{background:#fff;border-radius:16px;width:100%;max-width:1200px;max-height:90vh;display:flex;flex-direction:column;box-shadow:0 4px 20px #0000004d}.view-locations-modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;border-bottom:1px solid #e0e0e0}.view-locations-modal-header h2{margin:0;font-size:24px;font-weight:700;color:#333}.view-locations-modal-close{background:none;border:none;font-size:32px;color:#666;cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:all .2s ease}.view-locations-modal-close:hover{background-color:#f0f0f0;color:#333}.view-locations-modal-content{display:flex;flex:1;overflow:hidden;min-height:0}.view-locations-sidebar{width:350px;border-right:1px solid #e0e0e0;display:flex;flex-direction:column;overflow:hidden}.view-locations-list{flex:1;overflow-y:auto;padding:16px}.view-locations-empty{text-align:center;padding:40px 20px;color:#666}.view-location-item{width:100%;padding:16px;border:2px solid #e0e0e0;border-radius:12px;background:#fff;text-align:left;cursor:pointer;transition:all .2s ease;margin-bottom:12px}.view-location-item:hover{border-color:#007bff;background-color:#f8f9fa}.view-location-item.active{border-color:#007bff;background-color:#e7f3ff;box-shadow:0 2px 8px #007bff33}.view-location-item.selected{border-left:4px solid #28a745}.view-location-item-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.view-location-item-name{font-weight:700;color:#333;font-size:16px}.view-location-item-badge{background-color:#28a745;color:#fff;padding:4px 8px;border-radius:4px;font-size:11px;font-weight:600;text-transform:uppercase}.view-location-item-address{color:#666;font-size:14px;margin-bottom:4px;line-height:1.4}.view-location-item-reference{color:#999;font-size:12px;font-style:italic}.view-locations-map-container{flex:1;position:relative;min-width:0;min-height:400px}.view-locations-map{width:100%;height:100%;min-height:400px;display:block}.view-locations-map-loading,.view-locations-map-placeholder{position:absolute;top:0;left:0;right:0;bottom:0;display:flex;justify-content:center;align-items:center;background-color:#f5f5f5;color:#666}.view-locations-map-placeholder p{font-size:16px;text-align:center}.view-locations-modal-footer{display:flex;justify-content:flex-end;gap:12px;padding:20px 24px;border-top:1px solid #e0e0e0}.view-locations-modal-footer .btn{padding:12px 24px;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:all .3s ease;border:none}.view-locations-modal-footer .btn-primary{background-color:#007bff;color:#fff}.view-locations-modal-footer .btn-primary:hover{background-color:#0056b3}.view-locations-modal-footer .btn-secondary{background-color:#f8f9fa;color:#333;border:2px solid #e0e0e0}.view-locations-modal-footer .btn-secondary:hover{background-color:#e9ecef;border-color:#ccc}@media (max-width: 968px){.view-locations-modal-content{flex-direction:column}.view-locations-sidebar{width:100%;border-right:none;border-bottom:1px solid #e0e0e0;max-height:250px;min-height:200px}.view-locations-map-container{min-height:400px;height:400px;flex:none}.view-locations-map{height:100%}}@media (max-width: 768px){.view-locations-modal{max-width:100%;max-height:100vh;height:100vh;border-radius:0;display:flex;flex-direction:column}.view-locations-modal-overlay{padding:0}.view-locations-modal-header{padding:16px;flex-shrink:0}.view-locations-modal-content{flex:1;min-height:0;overflow:hidden}.view-locations-sidebar{width:100%;border-right:none;border-bottom:1px solid #e0e0e0;max-height:200px;min-height:150px;flex-shrink:0}.view-locations-list{padding:12px;overflow-y:auto;height:100%}.view-locations-map-container{flex:1;min-height:300px;height:100%;position:relative}.view-locations-map{width:100%;height:100%;min-height:300px}.view-locations-modal-footer{flex-direction:column;padding:16px;flex-shrink:0;gap:8px}.view-locations-modal-footer .btn{width:100%}}.bottom-nav{position:fixed;bottom:0;left:0;right:0;background-color:#fff;display:flex;justify-content:space-around;align-items:center;padding:8px 0 calc(8px + env(safe-area-inset-bottom));z-index:1000;box-shadow:0 -2px 10px #0000001a;border-top:1px solid #e0e0e0}.bottom-nav-item{display:flex;flex-direction:column;align-items:center;justify-content:center;text-decoration:none;color:#999;padding:6px 12px;position:relative;transition:all .2s ease;flex:1;min-width:0;gap:4px;border:none;outline:none;background:none;cursor:pointer;font-family:inherit}.bottom-nav-item:hover{color:#333}.bottom-nav-item:focus{outline:none;border:none}.bottom-nav-item.active{color:#00d4aa}.bottom-nav-item.active .bottom-nav-icon{transform:scale(1.1)}.bottom-nav-icon{font-size:24px;display:block;transition:transform .2s ease}.bottom-nav-label{font-size:11px;font-weight:500;text-align:center;white-space:nowrap;line-height:1.2;max-width:70px;overflow:hidden;text-overflow:ellipsis}.bottom-nav-badge{position:absolute;top:2px;right:8px;background-color:#e74c3c;color:#fff;border-radius:50%;width:18px;height:18px;display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:700;border:2px solid #fff;box-shadow:0 2px 4px #0003}.bottom-nav-location-wrapper{position:relative;flex:1}.bottom-nav-location-wrapper .bottom-nav-item{width:100%}.bottom-nav-location-wrapper .bottom-nav-item:focus,.bottom-nav-location-wrapper .bottom-nav-item:active{outline:none;border:none;box-shadow:none}.bottom-nav-dropdown-overlay{position:fixed;top:0;left:0;right:0;bottom:80px;z-index:998;background:transparent}.bottom-nav-location-dropdown{position:fixed;bottom:80px;left:0;right:0;background:#fff;border-top:1px solid #e0e0e0;box-shadow:0 -4px 16px #00000026;max-height:50vh;overflow-y:auto;z-index:999;padding:16px}.bottom-nav-location-option{width:100%;padding:16px;border:none;background:none;text-align:left;cursor:pointer;transition:background-color .2s ease;border-bottom:1px solid #f0f0f0;border-radius:12px;margin-bottom:8px}.bottom-nav-location-option:last-of-type{border-bottom:none;margin-bottom:0}.bottom-nav-location-option:hover{background-color:#f8f9fa}.bottom-nav-location-option.active{background-color:#e7f3ff;border-left:4px solid #00d4aa}.bottom-nav-location-name{font-weight:700;color:#333;font-size:15px;margin-bottom:4px}.bottom-nav-location-address{color:#666;font-size:13px}.bottom-nav-location-action{width:100%;padding:14px 16px;border:none;background:none;text-align:left;cursor:pointer;transition:background-color .2s ease;display:flex;align-items:center;gap:12px;color:#00d4aa;font-weight:600;font-size:14px;margin-top:8px;border-radius:12px}.bottom-nav-location-action:hover{background-color:#f0fdfa}.bottom-nav-location-action svg{font-size:20px}@media (max-width: 768px){.main-content{padding-bottom:80px}.bottom-nav-label{font-size:10px;max-width:60px}}.auth-container{min-height:100vh;width:100vw;position:fixed;top:0;left:0;right:0;bottom:0;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#ffe08a,#dfad0d 45%,#c89200);padding:20px;overflow-y:auto}.auth-card{background:#fff;border-radius:16px;padding:40px;width:100%;max-width:450px;box-shadow:0 10px 40px #0003}.auth-header{text-align:center;margin-bottom:32px}.auth-logo{height:100px;width:auto;display:inline-block;margin-bottom:12px}.auth-header h1{font-size:28px;color:#333;margin-bottom:8px}.auth-header p{color:#666;font-size:14px;margin:4px 0}.phone-display{font-weight:600;color:#007bff!important;font-size:16px!important;margin-top:8px!important}.back-button-auth{position:absolute;top:20px;left:20px;background:none;border:none;color:#007bff;font-size:16px;cursor:pointer;padding:8px;display:flex;align-items:center;gap:4px;transition:color .3s ease}.back-button-auth:hover{color:#0056b3}.auth-form{display:flex;flex-direction:column;gap:20px}.form-group{display:flex;flex-direction:column;gap:8px}.form-group label{font-weight:600;color:#333;font-size:14px}.form-control{padding:12px 16px;border:2px solid #e0e0e0;border-radius:8px;font-size:16px;transition:all .3s ease;font-family:inherit}.form-control select{-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%23333' d='M6 9L1 4h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 16px center;padding-right:40px;cursor:pointer}.form-control:focus{outline:none;border-color:#007bff;box-shadow:0 0 0 3px #007bff1a}.country-select{cursor:pointer}.phone-input-group{display:flex;gap:8px;align-items:center}.country-code{padding:12px 16px;background-color:#f8f9fa;border:2px solid #e0e0e0;border-radius:8px;font-weight:600;color:#333;white-space:nowrap}.phone-input{flex:1}.code-inputs{display:flex;gap:12px;justify-content:center;margin:20px 0}.code-input{width:60px;height:60px;text-align:center;font-size:24px;font-weight:700;border:2px solid #e0e0e0;border-radius:8px;transition:all .3s ease}.code-input:focus{outline:none;border-color:#007bff;box-shadow:0 0 0 3px #007bff1a}.btn-auth{width:100%;padding:14px;font-size:16px;font-weight:600;border-radius:8px;margin-top:8px}.btn-link{background:none;border:none;color:#007bff;cursor:pointer;font-size:14px;text-decoration:underline;padding:8px;margin-top:8px}.btn-link:hover{color:#0056b3}.btn-link:disabled{color:#ccc;cursor:not-allowed}.error-message{background-color:#fee;color:#c33;padding:12px 16px;border-radius:8px;border:1px solid #fcc;font-size:14px}.auth-footer{margin-top:24px;text-align:center}.auth-footer p{font-size:12px;color:#999;margin:0}.loading-spinner{text-align:center;padding:40px}.loading-spinner p{color:#666;font-size:16px}.permission-info{text-align:center;padding:20px 0}.permission-info p{color:#666;margin-bottom:20px;line-height:1.6}.location-container{min-height:100vh;width:100vw;background:linear-gradient(135deg,#f5f7fa,#c3cfe2);padding:16px;position:relative}.location-card{max-width:900px;margin:0 auto;background:#fff;border-radius:20px;padding:32px;box-shadow:0 8px 32px #0000001f}.location-header{text-align:center;margin-bottom:32px}.location-header-icon{display:flex;justify-content:center;margin-bottom:16px}.header-icon{font-size:48px;color:#00d4aa;background:linear-gradient(135deg,#00d4aa1a,#00b4961a);padding:16px;border-radius:50%}.location-header h1{font-size:28px;font-weight:700;color:#1a1a1a;margin-bottom:8px;letter-spacing:-.5px;font-family:Inter,sans-serif}.location-header p{color:#666;font-size:15px;line-height:1.5}.map-container{width:100%;height:450px;min-height:350px;margin-bottom:32px;border-radius:16px;overflow:hidden;box-shadow:0 4px 16px #0000001a;position:relative;border:2px solid #e0e0e0}.map{width:100%;height:100%;min-height:350px;border:none;display:block}.map-instructions{position:absolute;bottom:16px;left:50%;transform:translate(-50%);background:#fffffff2;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);padding:10px 16px;border-radius:20px;display:flex;align-items:center;gap:8px;font-size:13px;color:#333;font-weight:600;box-shadow:0 2px 8px #00000026;z-index:10;pointer-events:none}.instruction-icon{font-size:18px;color:#00d4aa}.geocoding-overlay{position:absolute;top:0;left:0;right:0;bottom:0;background:#fffffff2;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;border-radius:16px}.geocoding-loader{text-align:center;padding:24px;background:#fff;border-radius:16px;box-shadow:0 4px 16px #0000001a;display:flex;flex-direction:column;align-items:center;gap:12px}.loader-spinner{width:40px;height:40px;border:3px solid #f0f0f0;border-top-color:#00d4aa;border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.geocoding-loader p{margin:0;color:#666;font-size:14px;font-weight:500}.loading-text{color:#00d4aa;font-weight:600;font-size:11px;margin-left:8px}.form-help-text{display:block;margin-top:6px;font-size:12px;color:#999;line-height:1.4}.location-form{display:flex;flex-direction:column;gap:24px}.form-section{display:flex;flex-direction:column;gap:12px}.form-section-label{display:flex;align-items:center;gap:8px;font-weight:700;color:#1a1a1a;font-size:14px;font-family:Inter,sans-serif}.label-icon{font-size:18px;color:#00d4aa}.required-badge{background:#ffe08a;color:#c89200;padding:2px 8px;border-radius:8px;font-size:10px;font-weight:700;margin-left:8px;text-transform:uppercase}.loading-badge{background:#e7f3ff;color:#00d4aa;padding:2px 8px;border-radius:8px;font-size:10px;font-weight:600;margin-left:8px}.location-type-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}.location-type-card{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;padding:16px;background:#f8f9fa;border:2px solid #e0e0e0;border-radius:12px;cursor:pointer;transition:all .3s ease;position:relative;min-height:90px;font-weight:600;color:#666;font-size:14px}.location-type-card:hover:not(:disabled){border-color:#00d4aa;background:#f0fdfa;transform:translateY(-2px);box-shadow:0 4px 12px #00d4aa33}.location-type-card.selected{background:linear-gradient(135deg,#00d4aa,#00b896);border-color:#00d4aa;color:#fff;box-shadow:0 4px 16px #00d4aa4d}.location-type-card:disabled{opacity:.6;cursor:not-allowed}.type-icon{font-size:24px}.location-type-card.selected .type-icon{color:#fff}.check-icon{position:absolute;top:8px;right:8px;font-size:20px;color:#fff}.input-wrapper{position:relative;display:flex;align-items:center}.input-icon{position:absolute;left:16px;font-size:20px;color:#999;pointer-events:none;z-index:1}.form-control-modern{width:100%;padding:14px 16px 14px 48px;border:2px solid #e0e0e0;border-radius:12px;font-size:15px;color:#1a1a1a;transition:all .3s ease;font-family:Inter,sans-serif;background:#fff}.form-control-modern:focus{outline:none;border-color:#00d4aa;box-shadow:0 0 0 3px #00d4aa1a}.form-control-modern:disabled{background:#f5f5f5;cursor:not-allowed;opacity:.7}.form-control-modern::placeholder{color:#bbb}.error-alert{display:flex;align-items:center;gap:12px;padding:14px 16px;background:#fff5f5;border:2px solid #fed7d7;border-radius:12px;color:#c53030;font-size:14px;font-weight:500;margin-bottom:8px}.error-icon{font-size:20px;flex-shrink:0}.error-close{margin-left:auto;background:none;border:none;color:#c53030;cursor:pointer;padding:4px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:background .2s ease}.error-close:hover{background:#c530301a}.btn-save-location{display:flex;align-items:center;justify-content:center;gap:10px;width:100%;padding:16px;background:linear-gradient(135deg,#00d4aa,#00b896);color:#fff;border:none;border-radius:14px;font-size:16px;font-weight:700;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 16px #00d4aa4d;font-family:Inter,sans-serif;margin-top:8px}.btn-save-location:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px #00d4aa66;background:linear-gradient(135deg,#00b896,#00a085)}.btn-save-location:disabled{opacity:.6;cursor:not-allowed;transform:none}.button-icon{font-size:20px}.button-spinner{width:20px;height:20px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite}@media (max-width: 768px){.location-container{padding:12px}.location-card{padding:20px;border-radius:16px}.location-header h1{font-size:24px}.location-header-icon .header-icon{font-size:40px;padding:12px}.map-container{height:350px;margin-bottom:24px}.location-type-grid{grid-template-columns:repeat(2,1fr);gap:10px}.location-type-card{padding:12px;min-height:80px;font-size:13px}.type-icon{font-size:20px}.map-instructions{font-size:11px;padding:8px 12px}}@media (max-width: 768px){.auth-card{padding:24px}.location-card{padding:16px}.map-container{height:300px;min-height:300px}.map{min-height:300px}.code-input{width:50px;height:50px;font-size:20px}}.closed-store-dialog-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#0009;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.closed-store-dialog{background:#fff;border-radius:24px;padding:32px;max-width:420px;width:100%;box-shadow:0 20px 60px #0000004d;animation:slideUp .3s ease-out}.closed-store-dialog-icon{font-size:64px;text-align:center;margin-bottom:16px;animation:pulse 2s ease-in-out infinite}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}.closed-store-dialog-title{font-size:24px;font-weight:800;color:#1a1a1a;text-align:center;margin:0 0 16px}.closed-store-dialog-message{font-size:16px;color:#555;text-align:center;margin:0 0 12px;line-height:1.5}.closed-store-dialog-message strong{color:#1a1a1a;font-weight:700}.closed-store-dialog-submessage{font-size:14px;color:#888;text-align:center;margin:0 0 24px;line-height:1.5}.closed-store-dialog-actions{display:flex;gap:12px}.closed-store-dialog-btn{flex:1;padding:14px 24px;border:none;border-radius:12px;font-size:16px;font-weight:700;cursor:pointer;transition:all .2s ease}.closed-store-dialog-btn-cancel{background-color:#f5f5f5;color:#555}.closed-store-dialog-btn-cancel:hover{background-color:#e0e0e0;transform:translateY(-1px)}.closed-store-dialog-btn-continue{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;box-shadow:0 4px 12px #667eea66}.closed-store-dialog-btn-continue:hover{transform:translateY(-2px);box-shadow:0 6px 16px #667eea80}.closed-store-dialog-btn-continue:active{transform:translateY(0)}@media (max-width: 480px){.closed-store-dialog{padding:24px;border-radius:20px}.closed-store-dialog-title{font-size:20px}.closed-store-dialog-message{font-size:15px}.closed-store-dialog-submessage{font-size:13px}.closed-store-dialog-actions{flex-direction:column}.closed-store-dialog-btn{width:100%}}.store-list{padding:0 0 100px;max-width:1200px;margin:0 auto;background-color:#f5f5f5;min-height:100vh}.store-filters-container{background:#fff;padding:16px;position:sticky;top:0;z-index:100;box-shadow:0 2px 4px #0000000d}.store-type-selector{display:flex;gap:8px;padding:0;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;margin-bottom:12px}.store-type-selector::-webkit-scrollbar{display:none}.type-btn{padding:10px 18px;border:none;background-color:#fff;border-radius:24px;font-size:14px;font-weight:600;color:#555;cursor:pointer;transition:all .3s ease;white-space:nowrap;display:flex;align-items:center;gap:6px;box-shadow:0 1px 3px #00000014;letter-spacing:-.2px}.type-btn:hover{background-color:#f8f9fa}.type-btn.active{background-color:#00d4aa;color:#fff;box-shadow:0 2px 12px #00d4aa59;font-weight:700}.store-filter-bar-container{position:relative}.store-filter-bar{display:flex;align-items:center;gap:8px;padding:10px 12px;background-color:#f5f5f5;border-radius:10px;font-size:14px;color:#666;cursor:pointer;transition:background-color .2s ease;border:1px solid transparent;position:relative;z-index:10}.store-filter-bar:hover{background-color:#e9ecef;border-color:#ddd}.store-filter-bar:focus-within{background-color:#fff;border-color:#00d4aa;box-shadow:0 2px 8px #00d4aa26}.filter-icon{font-size:20px;color:#999;flex-shrink:0}.filter-input{flex:1;border:none;background:transparent;font-size:14px;color:#666;outline:none;font-family:inherit}.filter-input::placeholder{color:#999}.filter-clear{background:none;border:none;color:#999;font-size:20px;cursor:pointer;padding:4px;border-radius:50%;display:flex;align-items:center;justify-content:center;width:28px;height:28px;flex-shrink:0;transition:all .2s ease}.filter-clear:hover{background-color:#e9ecef;color:#666}.search-suggestions{position:absolute;top:calc(100% + 8px);left:0;right:0;background:#fff;border-radius:12px;box-shadow:0 4px 16px #00000026;max-height:320px;overflow-y:auto;z-index:1000;border:1px solid #e0e0e0;margin-top:4px}.suggestions-header{padding:12px 16px 8px;border-bottom:1px solid #f0f0f0;background:#fafafa;border-radius:12px 12px 0 0}.suggestions-title{font-size:12px;font-weight:600;color:#666;text-transform:uppercase;letter-spacing:.5px;display:flex;align-items:center;gap:6px}.suggestions-title-icon{font-size:16px;color:#ff6b35}.search-suggestions::-webkit-scrollbar{width:6px}.search-suggestions::-webkit-scrollbar-track{background:#f1f1f1;border-radius:12px}.search-suggestions::-webkit-scrollbar-thumb{background:#ccc;border-radius:12px}.search-suggestions::-webkit-scrollbar-thumb:hover{background:#999}.suggestion-item{width:100%;display:flex;align-items:center;gap:12px;padding:12px 16px;border:none;background:none;text-align:left;cursor:pointer;transition:background-color .2s ease;border-bottom:1px solid #f0f0f0;font-size:14px;color:#333}.suggestion-item:last-child{border-bottom:none}.suggestion-item:hover,.suggestion-item.selected{background-color:#f5f5f5}.suggestion-icon{font-size:18px;color:#999;flex-shrink:0;display:flex;align-items:center}.suggestion-item.selected .suggestion-icon{color:#00d4aa}.suggestion-text{flex:1;font-weight:500}.suggestion-item.selected .suggestion-text{color:#00d4aa;font-weight:600}.stores-header{margin:16px 16px 12px}.stores-title{font-size:24px;font-weight:700;color:#1a1a1a;margin:0 0 8px;letter-spacing:-.5px}.stores-stats{display:flex;gap:16px;align-items:center}.stores-open{color:#28a745;font-size:14px;font-weight:600;display:flex;align-items:center;gap:4px}.stores-total{color:#666;font-size:14px}.stores-list{display:flex;flex-direction:column;gap:12px;padding:0 16px}.store-card-horizontal{background:#fff;border-radius:20px;padding:0;display:flex;flex-direction:column;width:100%;text-align:left;font:inherit;box-shadow:0 2px 12px #00000014;transition:all .3s cubic-bezier(.4,0,.2,1);cursor:pointer;position:relative;border:none;overflow:hidden}.store-card-horizontal:focus-visible{outline:3px solid rgba(0,212,170,.35);outline-offset:2px}.store-card-horizontal:hover:not(.store-card-closed){box-shadow:0 8px 24px #0000001f;transform:translateY(-4px)}.store-card-horizontal.store-card-closed{opacity:.6}.store-card-horizontal.store-card-closed .store-logo{filter:grayscale(50%)}.store-image-container{width:100%;height:180px;position:relative;overflow:hidden;background:linear-gradient(135deg,#f5f7fa,#c3cfe2)}.store-image{width:100%;height:100%;object-fit:cover;transition:transform .3s ease}.store-card-horizontal:hover:not(.store-card-closed) .store-image{transform:scale(1.05)}.store-info-container{padding:12px 16px;display:flex;flex-direction:column;gap:6px}.store-name-row{margin-bottom:2px}.store-name{font-size:18px;font-weight:700;color:#1a1a1a;margin:0;line-height:1.2;letter-spacing:-.3px}.store-location-row{display:flex;align-items:center;gap:5px;font-size:13px;color:#666;margin-top:-2px}.store-location-icon{font-size:16px;color:#999;flex-shrink:0}.store-location-district{font-weight:500;color:#666;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.store-location-address{color:#999;font-size:12px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.store-schedule{font-size:12px;color:#999;display:flex;align-items:center;gap:5px;margin-top:-2px}.store-schedule-icon{font-size:14px;color:#999}.store-delivery-info{display:flex;align-items:center;gap:10px;margin-top:2px;flex-wrap:wrap}.delivery-time{font-size:13px;color:#333;font-weight:600;display:flex;align-items:center;gap:5px}.delivery-time-icon{font-size:14px;color:#666}.store-type-badge{font-size:14px;color:#666;background-color:#f5f5f5;padding:5px 10px;border-radius:12px;font-weight:700;display:flex;align-items:center;gap:4px}.delivery-badge-icon{font-size:14px}.store-categories{display:flex;flex-wrap:wrap;gap:5px;margin-top:4px}.store-category-badge{background-color:#00d4aa;color:#fff;font-size:10px;font-weight:600;padding:3px 8px;border-radius:10px;white-space:nowrap;box-shadow:0 2px 4px #00d4aa33}.store-status-badge{position:absolute;top:12px;right:12px;padding:6px 12px;border-radius:20px;font-size:11px;font-weight:700;text-transform:uppercase;color:#fff;z-index:10;box-shadow:0 2px 8px #0003;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.store-status-badge.open{background-color:#28a745f2}.store-status-badge.closed{background-color:#dc3545f2}.store-status-badge.disabled{background-color:#6c757df2}.store-delivery-price{position:absolute;bottom:12px;left:12px;background:linear-gradient(135deg,#00d4aaf2,#00b496f2);color:#fff;padding:6px 12px;border-radius:20px;font-size:13px;font-weight:700;z-index:10;box-shadow:0 2px 8px #00d4aa4d;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}@media (max-width: 768px){.store-list{padding-bottom:100px}.store-filters-container{padding:12px}.stores-header{margin:12px}.type-btn{padding:6px 12px;font-size:13px}.store-image-container{height:160px}.store-info-container{padding:12px}.store-name{font-size:18px}.store-location-row,.store-schedule,.delivery-time{font-size:12px}.store-delivery-info{gap:8px}.store-category-badge{font-size:10px;padding:3px 8px}.search-suggestions{max-height:240px}.suggestion-item{padding:10px 14px;font-size:13px}.suggestion-icon{font-size:14px}}.loading,.error,.empty-state{text-align:center;padding:50px 20px;font-size:1.2rem;color:#555}.error{color:#dc3545;font-weight:700}.cart-store-confirm-dialog-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#0009;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.cart-store-confirm-dialog{background:#fff;border-radius:24px;padding:32px;max-width:420px;width:100%;box-shadow:0 20px 60px #0000004d;animation:slideUp .3s ease-out}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.cart-store-confirm-dialog-icon{font-size:64px;text-align:center;margin-bottom:16px}.cart-store-confirm-dialog-title{font-size:24px;font-weight:800;color:#1a1a1a;text-align:center;margin:0 0 16px}.cart-store-confirm-dialog-message{font-size:16px;color:#555;text-align:center;margin:0 0 12px;line-height:1.5}.cart-store-confirm-dialog-message strong{color:#1a1a1a;font-weight:700}.cart-store-confirm-dialog-submessage{font-size:14px;color:#888;text-align:center;margin:0 0 24px;line-height:1.5}.cart-store-confirm-dialog-submessage strong{color:#667eea;font-weight:700}.cart-store-confirm-dialog-actions{display:flex;gap:12px}.cart-store-confirm-dialog-btn{flex:1;padding:14px 24px;border:none;border-radius:12px;font-size:16px;font-weight:700;cursor:pointer;transition:all .2s ease}.cart-store-confirm-dialog-btn-cancel{background-color:#f5f5f5;color:#555}.cart-store-confirm-dialog-btn-cancel:hover{background-color:#e0e0e0;transform:translateY(-1px)}.cart-store-confirm-dialog-btn-confirm{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;box-shadow:0 4px 12px #667eea66}.cart-store-confirm-dialog-btn-confirm:hover{transform:translateY(-2px);box-shadow:0 6px 16px #667eea80}.cart-store-confirm-dialog-btn-confirm:active{transform:translateY(0)}@media (max-width: 480px){.cart-store-confirm-dialog{padding:24px;border-radius:20px}.cart-store-confirm-dialog-title{font-size:20px}.cart-store-confirm-dialog-message{font-size:15px}.cart-store-confirm-dialog-submessage{font-size:13px}.cart-store-confirm-dialog-actions{flex-direction:column}.cart-store-confirm-dialog-btn{width:100%}}.product-dialog-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#0009;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px;overflow-y:auto}.product-dialog{background:#fff;border-radius:12px;max-width:600px;width:100%;max-height:90vh;overflow-y:auto;position:relative;box-shadow:0 8px 32px #0000004d}.product-dialog-close{position:absolute;top:12px;right:12px;background:#00000080;color:#fff;border:none;border-radius:50%;width:32px;height:32px;font-size:24px;line-height:1;cursor:pointer;z-index:10;display:flex;align-items:center;justify-content:center;transition:all .3s ease}.product-dialog-close:hover{background:#000000b3;transform:scale(1.1)}.product-dialog-header{padding:24px 24px 16px;border-bottom:1px solid #eee}.product-dialog-header h2{margin:0 0 8px;font-size:24px;color:#333}.product-dialog-description{margin:0;color:#666;font-size:14px;line-height:1.5}.product-dialog-image{width:100%;height:250px;overflow:hidden;background-color:#f0f0f0;display:flex;align-items:center;justify-content:center}.product-dialog-image img{width:100%;height:100%;object-fit:cover}.product-store-logo-fallback{width:100%;height:100%;object-fit:contain;padding:20px;background-color:#fff}.product-dialog-content{padding:24px}.product-dialog-loading,.product-dialog-error{padding:40px;text-align:center}.product-options-section{margin-bottom:24px}.product-option-group{margin-bottom:24px;padding-bottom:16px;border-bottom:1px solid #eee}.product-option-group:last-child{border-bottom:none}.option-group-header{display:flex;align-items:center;gap:12px;margin-bottom:8px;flex-wrap:wrap}.option-group-header h4{margin:0;font-size:16px;font-weight:700;color:#333;flex:1}.required-badge{background-color:#dc3545;color:#fff;padding:2px 8px;border-radius:12px;font-size:11px;font-weight:600}.select-limit{background-color:#e7f3ff;color:#007bff;padding:2px 8px;border-radius:12px;font-size:11px;font-weight:600}.option-group-description{font-size:13px;color:#666;margin:0 0 12px}.option-list{display:flex;flex-direction:column;gap:8px}.option-item{display:flex;align-items:center;gap:12px;padding:12px;border:2px solid #e0e0e0;border-radius:8px;cursor:pointer;transition:all .3s ease}.option-item:hover{border-color:#007bff;background-color:#f0f7ff}.option-item input[type=radio]:checked+.option-name,.option-item input[type=checkbox]:checked+.option-name{font-weight:600;color:#007bff}.option-item input[type=radio]:checked~.option-price,.option-item input[type=checkbox]:checked~.option-price{color:#007bff}.option-item.disabled{opacity:.5;cursor:not-allowed}.option-item.disabled:hover{border-color:#e0e0e0;background-color:transparent}.option-item input[type=radio],.option-item input[type=checkbox]{width:18px;height:18px;cursor:pointer}.option-name{flex:1;font-size:14px;color:#333}.option-price{font-size:14px;font-weight:600;color:#28a745}.product-dialog-footer{display:flex;justify-content:space-between;align-items:center;padding:20px 0;border-top:2px solid #eee;border-bottom:2px solid #eee;margin:24px 0}.quantity-selector{display:flex;align-items:center;gap:12px}.quantity-selector label{font-weight:600;color:#333}.price-total{display:flex;align-items:center;gap:12px}.total-label{font-size:16px;color:#666;font-weight:600}.total-price{font-size:24px;font-weight:700;color:#007bff}.btn-add-cart-full{width:100%;padding:16px;font-size:18px;margin-top:16px}.btn-add-cart-full:disabled{opacity:.6;cursor:not-allowed}.validation-message{text-align:center;color:#dc3545;font-size:13px;margin-top:8px;margin-bottom:0}@media (max-width: 768px){.product-dialog{max-width:100%;max-height:100vh;border-radius:0}.product-dialog-overlay{padding:0}.product-dialog-footer{flex-direction:column;gap:16px;align-items:stretch}.price-total{justify-content:space-between}}.store-detail{padding:0 0 100px;max-width:1200px;margin:0 auto;background-color:#f5f5f5;min-height:100vh}.back-button{background:none;border:none;color:#333;font-size:15px;font-weight:600;cursor:pointer;margin:16px 16px 0;padding:10px 0;display:flex;align-items:center;gap:8px;transition:all .2s ease;font-family:Inter,sans-serif}.back-button:hover{color:#00d4aa}.back-button-icon{font-size:20px}.store-detail-header{background:#fff;border-radius:0;overflow:hidden;margin-bottom:16px;box-shadow:0 2px 12px #0000001f}.store-detail-image-container{position:relative;width:100%;height:180px;overflow:hidden;background:linear-gradient(135deg,#f5f7fa,#c3cfe2)}.store-detail-image{width:100%;height:100%;object-fit:cover}.store-closed-overlay{position:absolute;top:0;left:0;right:0;bottom:0;background-color:#000000b3;display:flex;align-items:center;justify-content:center;color:#fff;font-size:24px;font-weight:700}.store-detail-info{padding:14px 16px;background:#fff}.store-header-top{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:10px}.store-detail-info h1{font-size:20px;font-weight:700;color:#1a1a1a;margin:0;letter-spacing:-.4px;font-family:Inter,sans-serif;line-height:1.2;flex:1}.store-time-badge{display:flex;align-items:center;gap:5px;background:linear-gradient(135deg,#00d4aa,#00b896);color:#fff;padding:6px 12px;border-radius:16px;font-size:13px;font-weight:700;white-space:nowrap;box-shadow:0 2px 8px #00d4aa4d}.time-badge-icon{font-size:16px}.store-address{display:flex;align-items:flex-start;gap:8px;margin-bottom:12px;padding:8px 0}.address-icon{font-size:18px;color:#00d4aa;flex-shrink:0;margin-top:2px}.store-address span{font-size:13px;color:#666;line-height:1.4;flex:1}.store-meta-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:10px;padding-top:10px;border-top:1px solid #f0f0f0}.meta-info-item{display:flex;align-items:flex-start;gap:10px;padding:8px;background-color:#f8f9fa;border-radius:10px;transition:background-color .2s ease}.meta-info-item:hover{background-color:#e9ecef}.info-icon{font-size:18px;color:#00d4aa;flex-shrink:0;margin-top:2px}.info-content{display:flex;flex-direction:column;gap:2px;flex:1;min-width:0}.info-label{font-size:10px;color:#999;text-transform:uppercase;font-weight:600;letter-spacing:.5px;line-height:1.2}.info-value{font-size:13px;color:#1a1a1a;font-weight:600;line-height:1.3;word-break:break-word}.products-section{padding:0 16px;margin-top:0}.products-section h2{font-size:22px;font-weight:700;color:#1a1a1a;margin-bottom:16px;letter-spacing:-.3px;font-family:Inter,sans-serif}.products-search-container{margin-bottom:20px}.products-search-bar{position:relative;display:flex;align-items:center;background-color:#fff;border:2px solid #e0e0e0;border-radius:14px;padding:12px 16px;transition:all .2s ease;box-shadow:0 2px 4px #0000000a}.products-search-bar:focus-within{border-color:#00d4aa;box-shadow:0 4px 12px #00d4aa26}.search-icon{font-size:20px;color:#999;margin-right:12px;flex-shrink:0}.products-search-bar:focus-within .search-icon{color:#00d4aa}.products-search-input{flex:1;border:none;outline:none;font-size:15px;color:#1a1a1a;font-family:Inter,sans-serif;background:transparent}.products-search-input::placeholder{color:#999}.clear-search-button{background:none;border:none;padding:4px;cursor:pointer;display:flex;align-items:center;justify-content:center;color:#999;transition:color .2s ease;margin-left:8px;border-radius:50%;width:24px;height:24px}.clear-search-button:hover{color:#666;background-color:#f0f0f0}.clear-icon{font-size:18px}.category-tabs{display:flex;gap:10px;margin-bottom:20px;flex-wrap:nowrap;padding-bottom:12px;border-bottom:1px solid #e0e0e0;overflow-x:auto;overflow-y:hidden;-webkit-overflow-scrolling:touch;scrollbar-width:thin;scrollbar-color:#00d4aa #f0f0f0;padding-right:16px;margin-right:-16px;padding-left:0;margin-left:0}.category-tabs::-webkit-scrollbar{height:6px}.category-tabs::-webkit-scrollbar-track{background:#f0f0f0;border-radius:3px}.category-tabs::-webkit-scrollbar-thumb{background:#00d4aa;border-radius:3px}.category-tabs::-webkit-scrollbar-thumb:hover{background:#00b896}.category-tab{padding:10px 18px;border:none;background-color:#f5f5f5;border-radius:24px;font-size:14px;font-weight:600;color:#666;cursor:pointer;transition:all .2s ease;white-space:nowrap;font-family:Inter,sans-serif;letter-spacing:-.2px;flex-shrink:0;min-width:fit-content}.category-tab:hover{background-color:#e9ecef;color:#333}.category-tab.active{background-color:#00d4aa;color:#fff;box-shadow:0 2px 8px #00d4aa4d;font-weight:700}.products-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:16px}.product-card{background:#fff;border-radius:16px;overflow:hidden;box-shadow:0 2px 8px #00000014;transition:all .3s cubic-bezier(.4,0,.2,1);display:flex;flex-direction:column;border:1px solid #f0f0f0;cursor:pointer}.product-card:hover{transform:translateY(-4px);box-shadow:0 8px 24px #0000001f;border-color:#e0e0e0}.product-image-container{position:relative;width:100%;height:160px;overflow:hidden;background:linear-gradient(135deg,#f5f7fa,#c3cfe2);display:flex;align-items:center;justify-content:center}.product-image-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background-color:#e0e0e0;color:#666;font-size:14px;text-align:center;padding:20px}.product-image{width:100%;height:100%;object-fit:cover;transition:transform .3s ease}.product-card:hover .product-image{transform:scale(1.05)}.product-unavailable{position:absolute;top:12px;right:12px;background-color:#dc3545e6;color:#fff;padding:6px 12px;border-radius:20px;font-size:12px;font-weight:600}.product-info{padding:12px;flex:1;display:flex;flex-direction:column;gap:8px}.product-name{font-size:16px;font-weight:700;color:#1a1a1a;margin:0;line-height:1.3;letter-spacing:-.3px;font-family:Inter,sans-serif}.product-description{font-size:13px;color:#666;margin:0;line-height:1.4;flex:1;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.product-footer{display:flex;justify-content:space-between;align-items:center;padding-top:10px;border-top:1px solid #f0f0f0;gap:8px}.product-price{font-size:18px;font-weight:700;color:#00d4aa;font-family:Inter,sans-serif;letter-spacing:-.3px}.btn-add-cart{padding:8px 14px;font-size:13px;font-weight:600;background-color:#00d4aa;color:#fff;border:none;border-radius:12px;cursor:pointer;transition:all .2s ease;white-space:nowrap;font-family:Inter,sans-serif}.btn-add-cart:hover:not(:disabled){background-color:#00b896;transform:scale(1.05)}.btn-add-cart:disabled{opacity:.5;cursor:not-allowed}.store-detail-skeleton-page{pointer-events:none}.skeleton-block{position:relative;overflow:hidden;background:#e9ecef}.skeleton-block:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;transform:translate(-100%);background:linear-gradient(90deg,transparent,rgba(255,255,255,.75),transparent);animation:skeleton-shimmer 1.4s infinite}.skeleton-inline{display:inline-block;border-radius:999px}.skeleton-button{gap:10px}.skeleton-header{box-shadow:0 2px 12px #00000014}.skeleton-back-icon{width:20px;height:20px}.skeleton-back-text{width:72px;height:16px}.skeleton-title{width:60%;height:28px;border-radius:10px}.skeleton-badge{width:84px;height:32px;border-radius:16px}.skeleton-address-row{align-items:center}.skeleton-icon{width:18px;height:18px;border-radius:50%;flex-shrink:0}.skeleton-address{width:75%;height:16px;border-radius:8px}.skeleton-meta-item{min-height:54px}.skeleton-label{width:45%;height:10px;border-radius:6px}.skeleton-value{width:80%;height:14px;border-radius:7px}.skeleton-section-title{width:140px;height:28px;border-radius:10px;margin-bottom:16px}.skeleton-search-bar{border-color:transparent}.skeleton-search-icon{width:20px;height:20px;border-radius:50%;margin-right:12px}.skeleton-search-input{width:100%;height:16px;border-radius:8px}.skeleton-category-tabs{border-bottom-color:transparent}.skeleton-tab{width:96px;height:38px;border-radius:24px;flex-shrink:0}.skeleton-product-card{cursor:default}.skeleton-product-name{width:78%;height:18px;border-radius:8px}.skeleton-product-description{width:100%;height:13px;border-radius:7px}.skeleton-product-description.short{width:68%}.skeleton-product-footer{align-items:center}.skeleton-product-price{width:62px;height:20px;border-radius:8px}.skeleton-product-button{width:78px;height:34px;border-radius:12px}@keyframes skeleton-shimmer{to{transform:translate(100%)}}@media (max-width: 768px){.store-detail{padding-bottom:100px}.store-detail-image-container{height:180px}.store-detail-info{padding:14px}.store-detail-info h1{font-size:20px}.store-detail-description{font-size:13px;margin-bottom:12px}.meta-item{min-width:100%;padding:8px 10px}.meta-row{gap:8px}.meta-row{flex-direction:column;gap:12px}.meta-item{min-width:100%}.products-grid{grid-template-columns:repeat(2,1fr);gap:12px}.product-image-container{height:140px}.product-name{font-size:15px}.product-price{font-size:16px}.btn-add-cart{padding:6px 12px;font-size:12px}}.cart{padding:20px 0}.cart-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px}.cart-header h2{font-size:28px;color:#333;margin:0}.btn-clear-cart{background:none;border:none;color:#dc3545;font-size:14px;cursor:pointer;padding:8px 16px;border-radius:6px;transition:all .3s ease}.btn-clear-cart:hover{background-color:#fff5f5}.cart-content{display:grid;grid-template-columns:1fr 400px;gap:32px}.cart-items{display:flex;flex-direction:column;gap:16px}.cart-item{background:#fff;border-radius:12px;padding:20px;box-shadow:0 2px 8px #0000001a;display:grid;grid-template-columns:120px 1fr auto;gap:20px;align-items:center}.cart-item-image{width:120px;height:120px;border-radius:8px;overflow:hidden}.cart-item-image img{width:100%;height:100%;object-fit:cover}.cart-item-info{flex:1}.cart-item-name{font-size:18px;font-weight:700;color:#333;margin-bottom:8px}.cart-item-description{font-size:14px;color:#666;margin-bottom:8px}.cart-item-options{margin:8px 0;padding:8px 0;border-top:1px solid #f0f0f0;border-bottom:1px solid #f0f0f0}.cart-option-item{font-size:12px;color:#555;padding:4px 8px;background-color:#f8f9fa;border-radius:4px;display:inline-block;margin-right:8px;margin-bottom:8px}.cart-option-item:last-child{margin-bottom:0}.cart-item-total-label{font-size:11px;color:#007bff;font-weight:600;margin-left:4px}.cart-item-price{font-size:16px;color:#007bff;font-weight:600}.cart-item-controls{display:flex;flex-direction:column;align-items:flex-end;gap:12px}.quantity-controls{display:flex;align-items:center;gap:12px;border:2px solid #e0e0e0;border-radius:8px;padding:4px}.quantity-btn{background:none;border:none;font-size:20px;font-weight:700;color:#333;cursor:pointer;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:all .3s ease}.quantity-btn:hover{background-color:#f0f0f0}.quantity-value{font-size:16px;font-weight:700;min-width:32px;text-align:center}.cart-item-total{font-size:20px;font-weight:700;color:#333}.btn-remove-item{background:none;border:none;font-size:20px;cursor:pointer;padding:8px;border-radius:6px;transition:all .3s ease}.btn-remove-item:hover{background-color:#fff5f5;transform:scale(1.1)}.cart-summary{background:#fff;border-radius:12px;padding:24px;box-shadow:0 2px 8px #0000001a;height:fit-content;position:sticky;top:100px}.summary-header h3{font-size:20px;color:#333;margin-bottom:20px}.summary-details{margin-bottom:24px}.summary-row{display:flex;justify-content:space-between;margin-bottom:12px;font-size:16px}.btn-checkout{width:100%;padding:16px;font-size:18px;margin-bottom:12px}.btn-continue-shopping{width:100%;text-align:center;text-decoration:none;display:block;padding:12px}.cart-empty{padding:60px 20px}@media (max-width: 1024px){.cart-content{grid-template-columns:1fr}.cart-summary{position:static}}@media (max-width: 768px){.cart-item{grid-template-columns:100px 1fr;gap:16px}.cart-item-controls{grid-column:1 / -1;flex-direction:row;justify-content:space-between;align-items:center;margin-top:12px;padding-top:12px;border-top:1px solid #eee}.cart-item-image{width:100px;height:100px}}.checkout{padding:20px 0;max-width:1200px;margin:0 auto}.disabled-input{background-color:#f5f5f5;cursor:not-allowed;opacity:.7}.location-display{background-color:#f9f9f9;padding:12px;border-radius:8px;border:1px solid #e0e0e0}.location-name{font-size:16px;margin-bottom:4px;color:#333}.location-address{font-size:14px;color:#666;margin-bottom:4px}.location-reference{font-size:12px;color:#888;margin-top:4px}.vuelto-display{padding:8px;background-color:#d4edda;border-radius:4px;font-size:14px}.checkout h2{font-size:32px;color:#333;margin-bottom:32px}.checkout-content{display:grid;grid-template-columns:1fr 400px;gap:32px}.checkout-form{background:#fff;border-radius:12px;padding:32px;box-shadow:0 2px 8px #0000001a}.form-section{margin-bottom:32px}.form-section h3{font-size:20px;color:#333;margin-bottom:20px;padding-bottom:12px;border-bottom:2px solid #f0f0f0}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}.form-group{margin-bottom:20px}.form-group label{display:block;font-size:14px;font-weight:600;color:#333;margin-bottom:8px}.form-group input,.form-group textarea{width:100%;padding:12px 16px;border:2px solid #e0e0e0;border-radius:8px;font-size:16px;font-family:inherit;transition:all .3s ease}.form-group input:focus,.form-group textarea:focus{outline:none;border-color:#007bff;box-shadow:0 0 0 3px #007bff1a}.form-group input.error,.form-group textarea.error{border-color:#dc3545}.error-message{display:block;color:#dc3545;font-size:12px;margin-top:4px}.form-group textarea{resize:vertical;min-height:100px}.payment-methods{display:flex;flex-direction:column;gap:12px}.payment-option{display:flex;align-items:center;gap:12px;padding:12px;border:2px solid #e0e0e0;border-radius:8px;cursor:pointer;transition:all .3s ease}.payment-option:hover{border-color:#007bff;background-color:#f0f7ff}.payment-option input[type=radio]{width:20px;height:20px;cursor:pointer}.payment-option input[type=radio]:checked+span{font-weight:700;color:#007bff}.btn-submit{width:100%;padding:16px;font-size:18px;margin-top:24px}.checkout-summary{background:#fff;border-radius:12px;padding:24px;box-shadow:0 2px 8px #0000001a;height:fit-content;position:sticky;top:100px}.checkout-summary h3{font-size:20px;color:#333;margin-bottom:20px}.summary-items{margin-bottom:20px}.summary-item{display:flex;justify-content:space-between;padding:8px 0;font-size:14px;color:#666}.summary-divider{height:1px;background-color:#e0e0e0;margin:16px 0}.summary-totals{display:flex;flex-direction:column;gap:12px}.summary-row{display:flex;justify-content:space-between;font-size:16px}.summary-row span:first-child{color:#666}.summary-row span:last-child{font-weight:600;color:#333}.summary-total{font-size:20px;margin-top:8px}.summary-total span:last-child{color:#007bff;font-size:24px}.checkout-success{display:flex;align-items:center;justify-content:center;min-height:60vh;padding:40px 20px}.success-content{text-align:center;background:#fff;border-radius:12px;padding:48px;box-shadow:0 2px 8px #0000001a;max-width:500px}.success-icon{font-size:64px;margin-bottom:24px}.success-content h2{font-size:28px;color:#28a745;margin-bottom:16px}.success-content p{font-size:16px;color:#666;margin-bottom:16px}.order-id{background-color:#f0f7ff;padding:16px;border-radius:8px;margin:24px 0;font-size:18px;color:#333}.success-message{margin-top:24px;font-size:14px;color:#888}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:2000;padding:16px}.modal-dialog{background:#fff;width:100%;max-width:520px;border-radius:12px;box-shadow:0 10px 30px #0003;overflow:hidden}.modal-header{padding:16px 20px;border-bottom:1px solid #eee}.modal-header h3{margin:0;font-size:18px;color:#333}.modal-body{padding:16px 20px;color:#444;line-height:1.6}.modal-footer{padding:12px 20px;border-top:1px solid #eee;background:#fafafa}@media (max-width: 1024px){.checkout-content{grid-template-columns:1fr}.checkout-summary{position:static}}@media (max-width: 768px){.form-row{grid-template-columns:1fr}.checkout-form{padding:20px}.success-content{padding:32px 20px}}.App{min-height:100vh;display:flex;flex-direction:column}.main-content{flex:1;padding:20px 20px 100px;max-width:1200px;margin:0 auto;width:100%}.container{max-width:1200px;margin:0 auto;padding:0 20px}.btn{padding:12px 24px;border:none;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:all .3s ease;display:inline-flex;align-items:center;gap:8px}.btn-primary{background-color:#007bff;color:#fff}.btn-primary:hover{background-color:#0056b3;transform:translateY(-2px);box-shadow:0 4px 12px #007bff4d}.btn-secondary{background-color:#6c757d;color:#fff}.btn-secondary:hover{background-color:#545b62}.btn-success{background-color:#28a745;color:#fff}.btn-success:hover{background-color:#218838}.btn-danger{background-color:#dc3545;color:#fff}.btn-danger:hover{background-color:#c82333}.btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.loading{text-align:center;padding:40px;font-size:18px;color:#666}.error{background-color:#f8d7da;color:#721c24;padding:16px;border-radius:8px;margin:20px 0;border:1px solid #f5c6cb}.empty-state{text-align:center;padding:60px 20px;color:#666}.empty-state h2{margin-bottom:10px;color:#333}.empty-state p{margin-bottom:20px}@media (max-width: 768px){.main-content{padding:10px}.btn{padding:10px 20px;font-size:14px}}*{margin:0;padding:0;box-sizing:border-box}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#f5f5f5;font-weight:400;letter-spacing:-.01em}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}#root{min-height:100vh}
