*{margin:0;padding:0;box-sizing:border-box}:root{--primary-color: #3b82f6;--primary-dark: #2563eb;--secondary-color: #64748b;--success-color: #10b981;--warning-color: #f59e0b;--error-color: #ef4444;--background: #F5F5F7;--surface: #ffffff;--surface-hover: #f1f5f9;--border: #e2e8f0;--text-primary: #0f172a;--text-secondary: #64748b;--text-muted: #94a3b8;--shadow-sm: 0 1px 2px 0 rgb(0 0 0 / 0.05);--shadow-md: 0 4px 6px -1px rgb(0 0 0 / 0.1), 0 2px 4px -2px rgb(0 0 0 / 0.1);--shadow-lg: 0 10px 15px -3px rgb(0 0 0 / 0.1), 0 4px 6px -4px rgb(0 0 0 / 0.1);--radius: 8px;--radius-lg: 12px}body{font-family:'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;background-color:var(--background);color:var(--text-primary);line-height:1.6;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#app{min-height:100vh;display:flex;flex-direction:column}.main-content{flex:1;padding-top:80px}.navbar{position:fixed;top:0;left:0;right:0;background:rgba(255,255,255,0.95);backdrop-filter:blur(10px);border-bottom:1px solid var(--border);z-index:1000;height:70px}.nav-container{max-width:1200px;margin:0 auto;padding:0 24px;height:100%;display:flex;align-items:center;justify-content:space-between}.nav-logo{display:flex;align-items:center;gap:12px;text-decoration:none;color:var(--text-primary);font-weight:700;font-size:20px}.nav-logo .logo-icon{width:32px;height:32px;background:var(--primary-color);border-radius:var(--radius);display:flex;align-items:center;justify-content:center;color:white}.nav-links{display:flex;gap:8px}.nav-link{display:flex;align-items:center;gap:8px;padding:8px 16px;border-radius:var(--radius);text-decoration:none;color:var(--text-secondary);font-weight:500;transition:all 0.2s ease}.nav-link:hover{background:var(--surface-hover);color:var(--text-primary)}.nav-link.active{background:var(--primary-color);color:white}.nav-link i{width:18px;height:18px}.profile-dropdown{position:relative}.profile-trigger{display:flex;align-items:center;gap:12px;padding:6px 12px;background:none;border:none;border-radius:var(--radius);cursor:pointer;transition:background 0.2s ease}.profile-trigger:hover{background:var(--surface-hover)}.profile-avatar{width:36px;height:36px;border-radius:50%;overflow:hidden}.profile-avatar img{width:100%;height:100%;object-fit:cover}.avatar-placeholder{width:100%;height:100%;background:var(--primary-color);display:flex;align-items:center;justify-content:center;color:white;font-weight:600;font-size:14px}.profile-name{font-weight:500;color:var(--text-primary)}.dropdown-arrow{width:16px;height:16px;color:var(--text-secondary);transition:transform 0.2s ease}.profile-menu{position:absolute;top:100%;right:0;margin-top:8px;background:white;border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);min-width:200px;opacity:0;visibility:hidden;transform:translateY(-10px);transition:all 0.2s ease}.profile-menu.show{opacity:1;visibility:visible;transform:translateY(0)}.menu-item{display:flex;align-items:center;gap:12px;padding:12px 16px;text-decoration:none;color:var(--text-primary);transition:background 0.2s ease}.menu-item:hover{background:var(--surface-hover)}.menu-item:first-child{border-radius:var(--radius-lg) var(--radius-lg) 0 0}.menu-item:last-child{border-radius:0 0 var(--radius-lg) var(--radius-lg)}.menu-item i{width:18px;height:18px;color:var(--text-secondary)}.container{max-width:1200px;margin:0 auto;padding:0 24px}.page-header{text-align:center;margin-bottom:48px}.page-header h1{font-size:2.5rem;font-weight:700;color:var(--text-primary);margin-bottom:16px}.page-header p{font-size:1.125rem;color:var(--text-secondary);max-width:600px;margin:0 auto}.card{background:white;border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);overflow:hidden;transition:all 0.2s ease}.card:hover{box-shadow:var(--shadow-md)}.card-header{padding:24px;border-bottom:1px solid var(--border)}.card-header h3{font-size:1.25rem;font-weight:600;color:var(--text-primary)}.card-body{padding:24px}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:12px 24px;border:none;border-radius:var(--radius);font-weight:500;text-decoration:none;cursor:pointer;transition:all 0.2s ease;font-size:14px}.btn.btn-primary{background:var(--primary-color);color:white}.btn.btn-primary:hover{background:var(--primary-dark)}.btn.btn-secondary{background:var(--surface);color:var(--text-primary);border:1px solid var(--border)}.btn.btn-secondary:hover{background:var(--surface-hover)}.btn.btn-sm{padding:8px 16px;font-size:13px}.btn.btn-lg{padding:16px 32px;font-size:16px}.form-group{margin-bottom:24px}.form-label{display:block;margin-bottom:8px;font-weight:500;color:var(--text-primary)}.form-input{width:100%;padding:12px 16px;border:1px solid var(--border);border-radius:var(--radius);font-size:14px;transition:border-color 0.2s ease}.form-input:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px rgba(59,130,246,0.1)}.flash-messages{position:fixed;top:80px;right:24px;z-index:1001}.flash-message{padding:16px 20px;border-radius:var(--radius);margin-bottom:12px;box-shadow:var(--shadow-md);animation:slideIn 0.3s ease}.flash-message.notice{background:var(--success-color);color:white}.flash-message.alert{background:var(--error-color);color:white}@keyframes slideIn{from{transform:translateX(100%);opacity:0}to{transform:translateX(0);opacity:1}}@media (max-width: 768px){.nav-container{padding:0 16px}.nav-links{display:none}.container{padding:0 16px}.page-header h1{font-size:2rem}.main-content{padding-top:70px}}.home-page{padding:48px 0}.landing-page{text-align:center}.hero-section{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center;margin-bottom:96px;min-height:500px}@media (max-width: 768px){.hero-section{grid-template-columns:1fr;gap:32px;margin-bottom:64px}}.hero-content{text-align:left}.hero-content h1{font-size:3.5rem;font-weight:800;color:var(--text-primary);margin-bottom:24px;line-height:1.1}@media (max-width: 768px){.hero-content h1{font-size:2.5rem;text-align:center}}.hero-content p{font-size:1.25rem;color:var(--text-secondary);margin-bottom:32px;line-height:1.6}@media (max-width: 768px){.hero-content p{text-align:center}}.hero-actions{display:flex;gap:16px}@media (max-width: 768px){.hero-actions{justify-content:center}}.hero-image{display:flex;justify-content:center;align-items:center}.feature-preview{display:flex;gap:24px;padding:48px;background:linear-gradient(135deg, var(--primary-color), var(--primary-dark));border-radius:24px;box-shadow:var(--shadow-lg)}.feature-preview .feature-icon{width:48px;height:48px;color:white}.features-section h2{font-size:2.5rem;font-weight:700;margin-bottom:48px;color:var(--text-primary)}.features-grid{display:grid;grid-template-columns:repeat(auto-fit, minmax(300px, 1fr));gap:32px;margin-top:48px}.feature-card{text-align:center;padding:32px 24px;background:white;border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);transition:transform 0.2s ease, box-shadow 0.2s ease}.feature-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}.feature-card .feature-icon-wrapper{width:64px;height:64px;background:var(--primary-color);border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 24px}.feature-card .feature-icon-wrapper i{width:32px;height:32px;color:white}.feature-card h3{font-size:1.25rem;font-weight:600;margin-bottom:16px;color:var(--text-primary)}.feature-card p{color:var(--text-secondary);line-height:1.6}.map-section{display:grid;grid-template-columns:1fr 400px;gap:24px;height:600px;margin-top:32px}@media (max-width: 1024px){.map-section{grid-template-columns:1fr;height:auto}}.map-container{position:relative;background:var(--surface);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-md)}.google-map{width:100%;height:100%;min-height:400px}.map-error{width:100%;height:100%;min-height:400px;display:flex;align-items:center;justify-content:center;background:var(--surface);border-radius:var(--radius-lg)}.error-content{text-align:center;padding:48px 24px;max-width:400px}.error-content i{width:64px;height:64px;color:var(--text-muted);margin-bottom:24px}.error-content h3{font-size:1.5rem;font-weight:600;color:var(--text-primary);margin-bottom:16px}.error-content p{color:var(--text-secondary);margin-bottom:24px;line-height:1.6}.error-content .btn{display:inline-flex;align-items:center;gap:8px}.map-controls{position:absolute;top:16px;left:16px;right:16px;display:flex;gap:12px;z-index:10}.search-box{flex:1;position:relative}.search-box i{position:absolute;left:16px;top:50%;transform:translateY(-50%);color:var(--text-secondary);width:18px;height:18px}.search-box input{padding-left:48px;background:white;box-shadow:var(--shadow-md);border:none}.laundromats-sidebar{background:white;border-radius:var(--radius-lg);box-shadow:var(--shadow-md);display:flex;flex-direction:column;overflow:hidden}@media (max-width: 1024px){.laundromats-sidebar{max-height:400px}}.sidebar-header{padding:24px;border-bottom:1px solid var(--border);background:var(--surface)}.sidebar-header h3{font-size:1.25rem;font-weight:600;margin-bottom:8px;color:var(--text-primary)}.results-count{font-size:14px;color:var(--text-secondary)}.laundromats-list{flex:1;overflow-y:auto;padding:16px}.laundromat-item{display:flex;justify-content:space-between;align-items:center;padding:16px;border-radius:var(--radius);cursor:pointer;transition:background 0.2s ease;margin-bottom:8px}.laundromat-item:hover{background:var(--surface-hover)}.laundromat-item:last-child{margin-bottom:0}.laundromat-info{flex:1}.laundromat-info h4{font-size:1rem;font-weight:600;margin-bottom:4px;color:var(--text-primary)}.laundromat-info .address{font-size:14px;color:var(--text-secondary);margin-bottom:4px}.laundromat-info .distance{font-size:12px;color:var(--text-muted);font-weight:500}.laundromat-actions{display:flex;gap:8px;align-items:center}.favorite-btn{width:36px;height:36px;border:none;background:none;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all 0.2s ease;color:var(--text-secondary)}.favorite-btn:hover{background:var(--surface-hover);color:var(--error-color)}.favorite-btn.favorited{color:var(--error-color)}.favorite-btn i{width:18px;height:18px}.loading-state,.error-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:48px 24px;text-align:center;color:var(--text-secondary)}.loading-state i,.error-state i{width:48px;height:48px;margin-bottom:16px}.loading-state p,.error-state p{font-size:16px}.spinning{animation:spin 1s linear infinite}@keyframes spin{from{transform:rotate(0deg)}to{transform:rotate(360deg)}}.info-window{padding:16px;min-width:200px}.info-window h4{font-size:1.1rem;font-weight:600;margin-bottom:8px;color:var(--text-primary)}.info-window p{color:var(--text-secondary);margin-bottom:8px;font-size:14px}.info-window .distance{color:var(--text-muted);font-size:12px;font-weight:500}.info-window .place-details{display:flex;gap:8px;margin-bottom:16px;flex-wrap:wrap}.info-window .place-details span{font-size:12px;padding:2px 6px;border-radius:4px;background:var(--surface-hover)}.info-window .place-details .rating{background:rgba(16,185,129,0.1);color:var(--success-color)}.info-window .place-details .open-status{font-weight:500}.info-window .info-actions{display:flex;gap:8px}.place-meta{display:flex;gap:8px;margin-top:8px;flex-wrap:wrap}.place-meta span{font-size:12px;padding:2px 6px;border-radius:4px;background:var(--surface-hover)}.place-meta .rating{background:rgba(16,185,129,0.1);color:var(--success-color)}.place-meta .open-status{font-weight:500}.scheduling-flow{max-width:800px;margin:0 auto;padding:48px 0}.progress-steps{display:flex;justify-content:center;margin-bottom:48px;position:relative}.progress-steps::before{content:'';position:absolute;top:20px;left:25%;right:25%;height:2px;background:var(--border);z-index:1}.step{display:flex;flex-direction:column;align-items:center;position:relative;z-index:2}.step.active .step-number{background:var(--primary-color);color:white}.step.active .step-label{color:var(--primary-color);font-weight:600}.step-number{width:40px;height:40px;border-radius:50%;background:var(--surface);border:2px solid var(--border);display:flex;align-items:center;justify-content:center;font-weight:600;margin-bottom:8px;transition:all 0.3s ease}.step-label{font-size:14px;color:var(--text-secondary);text-align:center;transition:all 0.3s ease}.step-content{display:none;animation:fadeIn 0.3s ease}.step-content.active{display:block}.step-header{text-align:center;margin-bottom:48px}.step-header h1{font-size:2rem;font-weight:700;color:var(--text-primary);margin-bottom:16px}.step-header p{font-size:1.125rem;color:var(--text-secondary);max-width:600px;margin:0 auto}.selected-location{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:24px;margin-bottom:32px;box-shadow:var(--shadow-sm)}.location-info{display:flex;align-items:center;gap:16px}.location-info i{width:24px;height:24px;color:var(--primary-color)}.location-info h4{font-size:1.125rem;font-weight:600;color:var(--text-primary);margin-bottom:4px}.location-info p{color:var(--text-secondary);margin:0}.datetime-selection{display:grid;grid-template-columns:1fr 1fr;gap:24px;margin-bottom:32px}@media (max-width: 768px){.datetime-selection{grid-template-columns:1fr}}.special-items{display:grid;gap:16px;margin-bottom:32px}.item-quantity{display:flex;align-items:center;justify-content:space-between;padding:20px 24px;background:var(--surface);border:2px solid var(--border);border-radius:var(--radius-lg);transition:all 0.2s ease}.item-quantity:hover{border-color:var(--primary-color);background:rgba(59,130,246,0.05)}.item-info{display:flex;align-items:center;gap:16px;flex:1}.item-info .item-icon{font-size:24px}.item-info .item-details .item-name{font-size:1.125rem;font-weight:600;color:var(--text-primary);margin-bottom:4px}.item-info .item-details .item-price{font-size:14px;color:var(--text-secondary)}.quantity-control{display:flex;align-items:center;gap:8px;background:var(--background);border-radius:var(--radius);padding:4px}.quantity-control .quantity-btn{width:36px;height:36px;border:none;background:var(--surface);color:var(--text-primary);border-radius:6px;font-size:18px;font-weight:600;cursor:pointer;transition:all 0.2s ease;display:flex;align-items:center;justify-content:center}.quantity-control .quantity-btn:hover:not(:disabled){background:var(--primary-color);color:white}.quantity-control .quantity-btn:disabled{opacity:0.4;cursor:not-allowed}.quantity-control .quantity-btn.minus:disabled{opacity:0.2}.quantity-control .quantity-input{width:60px;height:36px;border:1px solid var(--border);border-radius:6px;text-align:center;font-size:16px;font-weight:600;background:var(--surface);color:var(--text-primary)}.quantity-control .quantity-input:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px rgba(59,130,246,0.1)}.quantity-control .quantity-input::-webkit-outer-spin-button,.quantity-control .quantity-input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.quantity-control .quantity-input[type=number]{-moz-appearance:textfield}.confirmation-details{margin-bottom:32px}.detail-section{margin-bottom:32px}.detail-section h3{font-size:1.125rem;font-weight:600;color:var(--text-primary);margin-bottom:12px}.detail-section>div{background:var(--surface);padding:16px 20px;border-radius:var(--radius);border:1px solid var(--border)}.pricing-info p{margin-bottom:8px}.pricing-info p:last-child{margin-bottom:0}.pricing-info .pricing-note{font-size:14px;color:var(--text-muted);font-style:italic;margin-top:12px}.step-actions{display:flex;gap:16px;justify-content:center;margin-top:48px}.step-actions .btn{display:flex;align-items:center;gap:8px}@keyframes fadeIn{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.admin-dashboard{padding:48px 0}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit, minmax(250px, 1fr));gap:24px;margin-bottom:48px}.stat-card{background:white;border:1px solid var(--border);border-radius:var(--radius-lg);padding:24px;display:flex;align-items:center;gap:16px;box-shadow:var(--shadow-sm);transition:all 0.2s ease}.stat-card:hover{box-shadow:var(--shadow-md)}.stat-card.success{border-left:4px solid var(--success-color)}.stat-card.warning{border-left:4px solid var(--warning-color)}.stat-card.error{border-left:4px solid var(--error-color)}.stat-icon{width:48px;height:48px;background:var(--surface);border-radius:var(--radius);display:flex;align-items:center;justify-content:center;color:var(--primary-color)}.success .stat-icon{background:rgba(16,185,129,0.1);color:var(--success-color)}.warning .stat-icon{background:rgba(245,158,11,0.1);color:var(--warning-color)}.error .stat-icon{background:rgba(239,68,68,0.1);color:var(--error-color)}.stat-icon i{width:24px;height:24px}.stat-content h3{font-size:2rem;font-weight:700;color:var(--text-primary);margin-bottom:4px}.stat-content p{color:var(--text-secondary);font-weight:500;margin-bottom:4px}.stat-content small{color:var(--text-muted);font-size:12px}.dashboard-content{display:flex;flex-direction:column;gap:32px}.alert-section .card-header{background:rgba(245,158,11,0.1);border-bottom-color:rgba(245,158,11,0.2)}.alert-section .card-header h3{display:flex;align-items:center;gap:12px;color:var(--warning-color)}.alert-section .card-header .warning-icon{width:20px;height:20px}.recent-section .card-header{display:flex;justify-content:space-between;align-items:center}.appointments-table{overflow-x:auto}.appointments-table table{width:100%;border-collapse:collapse}.appointments-table th,.appointments-table td{text-align:left;padding:12px 16px;border-bottom:1px solid var(--border)}.appointments-table th{font-weight:600;color:var(--text-primary);background:var(--surface);font-size:14px}.appointments-table td{color:var(--text-secondary)}.appointments-table tr:hover{background:var(--surface-hover)}.customer-info strong{display:block;color:var(--text-primary);font-size:14px}.customer-info small{color:var(--text-muted);font-size:12px}.status-badge{display:inline-flex;align-items:center;padding:4px 12px;border-radius:20px;font-size:12px;font-weight:500;text-transform:uppercase;letter-spacing:0.5px}.status-badge.test{background:rgba(245,158,11,0.1);color:var(--warning-color)}.status-badge.pending{background:rgba(59,130,246,0.1);color:var(--primary-color)}.status-badge.confirmed{background:rgba(16,185,129,0.1);color:var(--success-color)}.status-badge.completed{background:rgba(34,197,94,0.1);color:#22c55e}.status-badge.cancelled{background:rgba(239,68,68,0.1);color:var(--error-color)}.action-buttons{display:flex;gap:8px}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:48px 24px;text-align:center;color:var(--text-secondary)}.empty-state i{width:48px;height:48px;margin-bottom:16px;color:var(--text-muted)}.empty-state p{font-size:16px}.auth-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg, var(--primary-color), var(--primary-dark));padding:24px}.auth-container{width:100%;max-width:500px}.auth-card{background:white;border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);overflow:hidden}.auth-header{text-align:center;padding:48px 32px 32px;background:var(--surface)}.auth-header .logo{display:flex;align-items:center;justify-content:center;gap:12px;margin-bottom:24px}.auth-header .logo .logo-icon{width:40px;height:40px;background:var(--primary-color);border-radius:var(--radius);display:flex;align-items:center;justify-content:center;color:white}.auth-header .logo .logo-icon i{width:24px;height:24px}.auth-header .logo .logo-text{font-size:24px;font-weight:700;color:var(--text-primary)}.auth-header h2{font-size:1.75rem;font-weight:700;color:var(--text-primary);margin-bottom:8px}.auth-header p{color:var(--text-secondary);font-size:1rem}.auth-form{padding:32px}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}@media (max-width: 480px){.form-row{grid-template-columns:1fr}}.checkbox-group{display:flex;align-items:center;gap:8px}.form-checkbox{width:18px;height:18px;accent-color:var(--primary-color)}.checkbox-label{margin-bottom:0 !important;font-size:14px;color:var(--text-secondary);cursor:pointer}.form-actions{margin-top:32px}.form-actions .btn{width:100%}.auth-links{text-align:center;padding:0 32px}.auth-links a{color:var(--primary-color);text-decoration:none;font-size:14px}.auth-links a:hover{text-decoration:underline}.auth-footer{text-align:center;padding:24px 32px;background:var(--surface);border-top:1px solid var(--border)}.auth-footer p{color:var(--text-secondary);font-size:14px;margin:0}.auth-footer a{color:var(--primary-color);text-decoration:none;font-weight:500}.auth-footer a:hover{text-decoration:underline}.field_with_errors{display:contents}.field_with_errors .form-input{border-color:var(--error-color);box-shadow:0 0 0 3px rgba(239,68,68,0.1)}#error_explanation{background:rgba(239,68,68,0.1);border:1px solid rgba(239,68,68,0.2);border-radius:var(--radius);padding:16px;margin-bottom:24px}#error_explanation h2{color:var(--error-color);font-size:1rem;font-weight:600;margin-bottom:8px}#error_explanation ul{margin:0;padding-left:20px}#error_explanation ul li{color:var(--error-color);font-size:14px}.no-selection-message{display:flex;align-items:center;justify-content:center;min-height:60vh;padding:40px 20px}.no-selection-message .message-content{text-align:center;max-width:500px}.no-selection-message .message-content .message-icon{width:64px;height:64px;color:var(--primary-color);margin:0 auto 24px}.no-selection-message .message-content h2{font-size:2rem;font-weight:700;color:var(--text-primary);margin-bottom:16px}.no-selection-message .message-content p{font-size:1.125rem;color:var(--text-secondary);margin-bottom:32px;line-height:1.6}.no-selection-message .message-content .message-actions .btn{display:inline-flex;align-items:center;gap:8px}
