:root{--primary-color: #536ee4;--primary-color-dark: #3555e4;--secondary-color: #9f9f9f;--gradient-primary: linear-gradient(135deg, #536ee4 0%, #9f9f9f 100%);--gradient-dark: linear-gradient(135deg, #5b77f5 60%, #c6c6c6 100%);--text-dark: #333;--text-gray: #666;--text-light: #999;--bg-light: #f8f9fa;--bg-white: #ffffff;--error-light: #fee;--error-dark: #c33;--success-light: #efe;--success-dark: #3a3;--border-color: #e0e0e0;--shadow-sm: 0 4px 15px rgba(0, 0, 0, .08);--shadow-md: 0 8px 20px rgba(102, 126, 234, .15);--shadow-lg: 0 12px 30px rgba(102, 126, 234, .15);--shadow-xl: 0 15px 30px rgba(0, 0, 0, .2);--settings-container: #00000069;--posted-jobs-hover: #536ee4}[data-theme=dark]{--primary-color: #6b85ff;--primary-color-dark: #4d6ae8;--secondary-color: #b8b8b8;--gradient-primary: linear-gradient(135deg, #3f62ff 0%, #2a2a2a 100%);--gradient-dark: linear-gradient(135deg, #7a92ff 60%, #2a2a2a 100%);--text-dark: #e4e4e4;--text-gray: #b8b8b8;--text-light: #8a8a8a;--bg-light: #1a1a1a;--bg-white: #2a2a2a;--error-light: #4a1a1a;--error-dark: #ff6b6b;--success-light: #1a4a1a;--success-dark: #6bff6b;--border-color: #404040;--shadow-sm: 0 4px 15px rgba(0, 0, 0, .3);--shadow-md: 0 8px 20px rgba(0, 0, 0, .4);--shadow-lg: 0 12px 30px rgba(0, 0, 0, .5);--shadow-xl: 0 15px 30px rgba(0, 0, 0, .6);--settings-container: #131313;--posted-jobs-hover: #3555e4}.pac-container{z-index:3000!important;font-family:inherit;border-radius:8px;margin-top:4px;box-shadow:0 4px 12px #00000026;border:none;background-color:var(--bg-white)}.pac-item{padding:10px 12px;cursor:pointer;font-size:.95rem;border-top:1px solid var(--border-color);line-height:1.4;color:var(--text-dark);background-color:var(--bg-white)}.pac-item:hover,.pac-item-selected{background-color:var(--bg-light)}.pac-item-query{font-size:.95rem;color:var(--text-dark)}*{margin:0;padding:0;box-sizing:border-box}:root{background-color:var(--bg-light)}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.hero{width:100%;min-height:80vh;background:var(--gradient-primary);display:flex;align-items:center;justify-content:center;padding:2rem;position:relative;overflow:hidden}.hero:before{content:"";position:absolute;width:400px;height:400px;background:#ffffff1a;border-radius:50%;top:-100px;right:-100px;animation:float 6s ease-in-out infinite}.hero:after{content:"";position:absolute;width:300px;height:300px;background:#ffffff0d;border-radius:50%;bottom:-50px;left:-50px;animation:float 8s ease-in-out infinite reverse}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(20px)}}.hero-content{position:relative;z-index:1;text-align:center;max-width:600px;color:#fff}.hero-content h1{font-size:3.5rem;font-weight:800;margin-bottom:1rem;animation:slideDown .8s ease-out}.hero-subtitle{font-size:1.8rem;font-weight:600;margin-bottom:1rem;animation:slideDown .8s ease-out .1s backwards}.hero-description{font-size:1.2rem;margin-bottom:2rem;opacity:.95;animation:slideDown .8s ease-out .2s backwards}@keyframes slideDown{0%{opacity:0;transform:translateY(-30px)}to{opacity:1;transform:translateY(0)}}@media(max-width:768px){.hero-content h1{font-size:2.2rem}.hero-subtitle{font-size:1.3rem}.hero-description{font-size:1rem}}.user-section{padding:4rem 2rem}.section-content{display:grid;grid-template-columns:1fr 1fr;gap:3rem;align-items:center;max-width:1200px;margin:0 auto}.customer-section{background:var(--bg-light)}.shoveler-section{background:var(--bg-white)}.section-text h2{font-size:2.2rem;color:var(--text-dark);margin-bottom:1rem}.section-text>p{font-size:1.1rem;color:var(--text-gray);margin-bottom:2rem;line-height:1.6}.section-points{display:flex;flex-direction:column;gap:1rem;margin-bottom:2rem}.point{display:flex;align-items:center;gap:1rem;font-size:1rem;color:var(--text-dark)}.point-icon{font-size:1.5rem;flex-shrink:0}.section-image{display:flex;align-items:center;justify-content:center;height:300px}.placeholder-image{width:100%;height:100%;background:var(--gradient-primary);border-radius:12px;display:flex;align-items:center;justify-content:center;color:#fff;font-size:2rem;font-weight:600}.btn{padding:14px 32px;font-size:1.05rem;font-weight:600;border:none;border-radius:8px;cursor:pointer;transition:all .3s ease;text-transform:uppercase;letter-spacing:.5px}.btn-primary{background-color:var(--bg-white);color:var(--primary-color)}.btn-primary:hover{background-color:var(--bg-light);transform:translateY(-3px);box-shadow:var(--shadow-xl)}@media(max-width:768px){.section-content{grid-template-columns:1fr}.section-text h2{font-size:1.8rem}.section-image{height:200px}}.how-it-works{padding:5rem 2rem;background:var(--bg-white)}.how-it-works h2{font-size:2.5rem;color:var(--text-dark);text-align:center;margin-bottom:3rem}.how-tabs{display:grid;grid-template-columns:1fr 1fr;gap:3rem;max-width:1200px;margin:0 auto}.tab-content{background:var(--bg-light);padding:2rem;border-radius:12px}.tab-title{font-size:1.5rem;color:var(--text-dark);margin-bottom:2rem;text-align:center}.steps{display:grid;grid-template-columns:1fr;gap:1.5rem}.step{background:var(--bg-white);padding:1.5rem;border-radius:8px;display:flex;align-items:flex-start;gap:1.5rem}.step-number{display:flex;align-items:center;justify-content:center;width:45px;height:45px;background:var(--gradient-primary);color:#fff;border-radius:50%;font-size:1.3rem;font-weight:700;flex-shrink:0}.step h4{font-size:1.1rem;color:var(--text-dark);margin-bottom:.3rem}.step p{color:var(--text-gray);font-size:.9rem}@media(max-width:768px){.how-it-works h2{font-size:1.8rem}.how-tabs{grid-template-columns:1fr}}.reviews{padding:5rem 2rem;background:var(--bg-light)}.reviews h2{font-size:2.5rem;color:var(--text-dark);text-align:center;margin-bottom:3rem}.review-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:2rem;max-width:1200px;margin:0 auto}.review-card{background:var(--bg-white);padding:2rem;border-radius:12px;box-shadow:var(--shadow-sm)}.review-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;gap:1rem}.reviewer-info h4{font-size:1.1rem;color:var(--text-dark);margin-bottom:.2rem}.reviewer-info p{color:var(--text-light);font-size:.85rem}.review-stars{color:#ffc107;font-size:.9rem;white-space:nowrap}.review-text{color:var(--text-gray);line-height:1.6;font-size:.95rem}@media(max-width:768px){.reviews h2{font-size:1.8rem}.review-grid{grid-template-columns:1fr}}.service-areas{padding:5rem 2rem;background:var(--bg-white)}.service-areas h2{font-size:2.5rem;color:var(--text-dark);text-align:center;margin-bottom:.5rem}.subtitle{text-align:center;color:var(--text-gray);font-size:1.1rem;margin-bottom:3rem}.areas-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:2rem;max-width:1200px;margin:0 auto}.area-card{background:var(--gradient-primary);color:#fff;padding:2rem;border-radius:12px;text-align:center}.area-card h3{font-size:1.3rem;margin-bottom:.8rem}.area-card p{font-size:.9rem;opacity:.95}@media(max-width:768px){.service-areas h2{font-size:1.8rem}.areas-grid{grid-template-columns:1fr}}.stats{padding:4rem 2rem;background:var(--gradient-primary);color:#fff;display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:2rem;margin:0 auto;text-align:center}.stat h3{font-size:2.5rem;margin-bottom:.5rem;font-weight:700}.stat p{font-size:1rem;opacity:.95}@media(max-width:768px){.stats{grid-template-columns:1fr}}.home{width:100%;height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2rem;background:var(--gradient-primary);padding:2rem}.home img{border-radius:20px;box-shadow:0 20px 60px #0000004d}.home button{width:200px;padding:12px 40px;font-size:1.1rem;font-weight:600;border:none;border-radius:8px;cursor:pointer;transition:all .3s ease;text-transform:uppercase;letter-spacing:1px}.home button:first-of-type{background-color:#fff;color:#667eea}.home button:first-of-type:hover{background-color:#f0f0f0;transform:translateY(-2px);box-shadow:0 10px 20px #0003}.home button:last-of-type{background-color:transparent;color:#fff;border:2px solid #fff}.home button:last-of-type:hover{background-color:#ffffff1a;transform:translateY(-2px);box-shadow:0 10px 20px #0003}.login-signup-buttons{display:flex;gap:1rem!important}.settings-btn{padding:.3rem .6rem;background:var(--settings-container);border:none;border-radius:.4rem;cursor:pointer;font-size:1.25rem;transition:all .3s ease;display:flex;align-items:center;justify-content:center}.settings-btn:hover{transform:translateY(-2px)}.settings-btn:active{transform:translateY(0)}.available-jobs-container{max-width:1200px;margin:0 auto;padding:40px 20px}.jobs-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:30px}.available-jobs-container h1{font-size:2.5rem;margin:0;color:var(--text-dark)}.toggle-map-btn{padding:10px 20px;background-color:#2c7be5;color:#fff;border:none;border-radius:6px;font-size:1rem;cursor:pointer;transition:background-color .3s ease}.toggle-map-btn:hover{background-color:#1e5bb8}.map-container{margin-bottom:30px;border-radius:12px;overflow:hidden;box-shadow:0 4px 12px #0000001a}.job-distance{font-size:.95rem;color:#2c7be5;font-weight:600;margin-bottom:12px;padding:8px 12px;background-color:#e8f2ff;border-radius:6px;display:inline-block}.no-jobs{text-align:center;font-size:1.1rem;color:var(--text-gray);padding:40px;background-color:var(--bg-light);border-radius:8px}.jobs-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:24px;margin-bottom:40px}.job-card{background:var(--bg-white);border:1px solid var(--border-color);border-radius:12px;padding:24px;box-shadow:0 2px 8px #00000014;transition:all .3s ease;display:flex;flex-direction:column}.job-card:hover{box-shadow:0 4px 16px #0000001f;border-color:#2c7be5}.job-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:16px;gap:12px}.job-location{font-size:1.3rem;font-weight:600;color:var(--text-dark);margin:0;flex:1}.job-status{display:inline-block;padding:4px 12px;border-radius:20px;font-size:.85rem;font-weight:600;white-space:nowrap}.job-status.pending{background-color:#fff3cd;color:#856404}.job-details{flex:1;margin-bottom:20px}.detail-row{display:flex;justify-content:space-between;margin-bottom:12px;font-size:.95rem}.detail-row .label{font-weight:600;color:#555;min-width:100px}.detail-row .value{color:#777;text-align:right;flex:1}.accept-btn{padding:12px 24px;background-color:#2c7be5;color:#fff;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease;width:100%}.accept-btn:hover:not(:disabled){background-color:#1f5fa8;transform:translateY(-2px);box-shadow:0 4px 12px #2c7be54d}.accept-btn:disabled,.accept-btn.accepted{background-color:#28a745;cursor:not-allowed;opacity:.9}.earnings-container{max-width:1200px;margin:0 auto;padding:40px 20px}.earnings-container h1{font-size:2.5rem;margin-bottom:30px;color:var(--text-dark);text-align:center}.earnings-summary{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:20px;margin-bottom:40px}.summary-card{background:var(--bg-white);border-radius:12px;padding:24px;box-shadow:0 2px 8px #00000014;text-align:center;border-left:4px solid #2c7be5}.summary-card h3{margin:0 0 12px;font-size:1rem;color:var(--text-gray);font-weight:600;text-transform:uppercase;letter-spacing:.5px}.total-amount,.job-count,.pending-count{margin:0;font-size:2.5rem;font-weight:700;color:#2c7be5}.earnings-list h2{font-size:1.8rem;margin-bottom:20px;color:var(--text-dark)}.earnings-table{width:100%;border-collapse:collapse;background:var(--bg-white);border-radius:12px;overflow:hidden;box-shadow:0 2px 8px #00000014}.earnings-table thead{background-color:var(--bg-light);border-bottom:2px solid var(--border-color)}.earnings-table th{padding:16px;text-align:left;font-weight:600;color:#495057;font-size:.95rem;text-transform:uppercase;letter-spacing:.5px}.earnings-table td{padding:16px;border-bottom:1px solid #dee2e6;color:#555}.earnings-table tbody tr:hover{background-color:var(--bg-light)}.amount{font-weight:600;color:#28a745;font-size:1.05rem}.transaction-id{font-family:Courier New,monospace;font-size:.85rem;color:var(--text-light)}.status{display:inline-block;padding:6px 12px;border-radius:20px;font-size:.85rem;font-weight:600}.status.success{background-color:#d4edda;color:#155724}.status.warning{background-color:#fff3cd;color:#856404}.status.danger{background-color:#f8d7da;color:#721c24}.status.info{background-color:#d1ecf1;color:#0c5460}.no-earnings{text-align:center;font-size:1.1rem;color:var(--text-gray);padding:60px 40px;background-color:var(--bg-light);border-radius:12px}@media(max-width:768px){.earnings-table{font-size:.85rem}.earnings-table th,.earnings-table td{padding:12px 8px}.summary-card{min-width:100%}}.profile-container{max-width:900px;margin:0 auto;padding:40px 20px}.profile-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:30px}.profile-header h1{font-size:2.5rem;margin:0;color:var(--text-dark)}.edit-btn{padding:12px 24px;background-color:#2c7be5;color:#fff;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease}.edit-btn:hover{background-color:#1f5fa8;transform:translateY(-2px);box-shadow:0 4px 12px #2c7be54d}.success-message{background-color:#d4edda;color:#155724;padding:16px;border-radius:8px;border:1px solid #c3e6cb;margin-bottom:20px;text-align:center;font-weight:500}.profile-form{background:var(--bg-white);border-radius:12px;padding:32px;box-shadow:0 2px 8px #00000014}.form-group{margin-bottom:24px}.form-group label{display:block;margin-bottom:8px;font-weight:600;color:var(--text-dark);font-size:.95rem}.form-group input[type=text],.form-group input[type=email],.form-group input[type=tel],.form-group input[type=number],.form-group input[type=time],.form-group select,.form-group textarea{width:100%;padding:12px;border:1px solid #ddd;border-radius:8px;font-size:1rem;font-family:inherit;transition:all .3s ease}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:#2c7be5;box-shadow:0 0 0 3px #2c7be51a}.form-group.checkbox{display:flex;align-items:center;margin-bottom:24px}.form-group.checkbox input[type=checkbox]{width:auto;margin-right:12px;cursor:pointer;accent-color:#2c7be5}.form-group.checkbox label{margin-bottom:0;cursor:pointer}.form-actions{display:flex;gap:12px;margin-top:32px}.save-btn,.cancel-btn{flex:1;padding:14px 24px;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease}.save-btn{background-color:#28a745;color:#fff}.save-btn:hover{background-color:#218838;transform:translateY(-2px);box-shadow:0 4px 12px #28a7454d}.cancel-btn{background-color:#6c757d;color:#fff}.cancel-btn:hover{background-color:#5a6268;transform:translateY(-2px);box-shadow:0 4px 12px #6c757d4d}.profile-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:20px;margin-bottom:40px}.stat-card{background:var(--bg-white);border-radius:12px;padding:24px;text-align:center;box-shadow:0 2px 8px #00000014;border-top:4px solid #2c7be5}.stat-card h3{margin:0 0 12px;font-size:.95rem;color:var(--text-gray);font-weight:600;text-transform:uppercase;letter-spacing:.5px}.stat-value{margin:0;font-size:2rem;font-weight:700;color:var(--text-dark)}.stat-value.available{color:#28a745}.stat-value.unavailable{color:#dc3545}.profile-info{background:var(--bg-white);border-radius:12px;padding:32px;box-shadow:0 2px 8px #00000014}.info-section{margin-bottom:32px}.info-section:last-child{margin-bottom:0}.info-section h3{font-size:1.3rem;margin:0 0 16px;color:var(--text-dark);border-bottom:2px solid var(--border-color);padding-bottom:8px}.info-section p{margin:12px 0;color:var(--text-gray);line-height:1.6}.info-section strong{color:var(--text-dark);font-weight:600}@media(max-width:768px){.profile-header{flex-direction:column;align-items:flex-start;gap:16px}.profile-form{padding:24px}.form-actions{flex-direction:column}.stat-card{min-width:100%}}.modal-overlay{position:fixed;inset:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .2s ease}.modal-content{background:var(--bg-white);border-radius:12px;box-shadow:0 20px 60px #0000004d;max-width:500px;width:90%;max-height:90vh;display:flex;flex-direction:column;animation:slideUp .3s ease}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:0 20px}.modal-header h2{margin:0;font-size:1.5rem;color:var(--text-dark)}.modal-close-btn{background:none;border:none;font-size:1.5rem;color:#999;cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:all .3s ease}.modal-close-btn:hover:not(:disabled){background-color:var(--bg-light);color:var(--text-dark)}.modal-close-btn:disabled{cursor:not-allowed;opacity:.6}.modal-body{padding:24px;overflow-y:auto;flex:1}.job-info p{margin:4px 0;color:var(--text-gray);font-size:.9rem}.job-date{font-weight:600;color:#2c7be5!important}.hours-input-wrapper{display:flex;align-items:center;gap:12px}.hours-input-wrapper input{flex:1;padding:12px;border:1px solid #ddd;border-radius:6px;font-size:1rem;transition:all .3s ease}.hours-input-wrapper input:focus{outline:none;border-color:#2c7be5;box-shadow:0 0 0 3px #2c7be51a}.hours-input-wrapper input:disabled{background-color:var(--bg-light);cursor:not-allowed}.hours-label{font-weight:500;color:var(--text-gray);min-width:50px}.payment-preview{background-color:#d4edda;border:1px solid #c3e6cb;border-radius:8px;padding:16px;margin-bottom:20px}.payment-row{display:flex;justify-content:space-between;margin-bottom:8px;font-size:.95rem;color:#155724}.payment-row:last-child{margin-bottom:0}.payment-row.total{font-weight:600;font-size:1.1rem;border-top:1px solid #c3e6cb;padding-top:8px;margin-top:8px}.modal-footer{display:flex;gap:12px;padding:16px 24px;border-top:1px solid var(--border-color);background-color:var(--bg-light)}@media(max-width:480px){.modal-content{width:95%;max-height:95vh}.modal-header,.modal-body{padding:16px}.modal-footer{padding:12px 16px}}.landing-container{width:100%;overflow-x:hidden}.landing-navbar{display:flex;justify-content:space-between;align-items:center;padding:1rem 2rem;background:var(--gradient-dark);box-shadow:var(--shadow-md);position:sticky;top:0;z-index:100}.navbar-brand{font-size:1.5rem;font-weight:700;color:#fff}.navbar-content{display:flex;align-items:center;gap:2rem}.greeting{color:var(--primary-color-dark);font-size:1.1rem;font-weight:500}.logout-btn{padding:.6rem 1.2rem;background:var(--primary-color);color:#fff;border:none;border-radius:.4rem;cursor:pointer;font-size:1rem;font-weight:500;transition:all .3s ease}.logout-btn:hover{background:var(--secondary-color);box-shadow:var(--shadow-lg);transform:translateY(-2px)}.logout-btn:active{transform:translateY(0)}.shoveler-landing{padding:40px 20px}.shoveler-hero{text-align:center;margin-bottom:60px;padding:60px 20px;background:var(--gradient-primary);color:#fff;border-radius:12px}.shoveler-hero h1{font-size:2.5rem;margin-bottom:10px}.shoveler-hero p{font-size:1.2rem;opacity:.9}.shoveler-content{max-width:1200px;margin:0 auto;display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:30px}.shoveler-section{background:var(--bg-white);border:1px solid var(--border-color);border-radius:12px;padding:30px;box-shadow:var(--shadow-sm);transition:all .3s ease;cursor:pointer}.shoveler-section h2{color:var(--text-dark);font-size:1.5rem;margin-bottom:15px}.shoveler-section p{color:var(--text-gray);line-height:1.6}.accepted-jobs-section{max-width:1200px;margin:40px auto;padding:0 20px}.accepted-jobs-section h2{font-size:1.8rem;color:var(--text-dark);margin-bottom:24px;font-weight:600}.accepted-jobs-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:20px;margin-bottom:40px}.job-tile{background:var(--bg-white);border-radius:10px;padding:20px;box-shadow:0 2px 8px #0000001a;border-left:4px solid #2c7be5;transition:all .3s ease}.job-tile:hover{box-shadow:0 4px 16px #00000026;transform:translateY(-4px)}.job-tile-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:16px;gap:12px}.job-tile-header h3{margin:0;font-size:1.1rem;font-weight:600;color:var(--text-dark);flex:1}.job-status-badge{display:inline-block;padding:4px 12px;background-color:#d4edda;color:#155724;border-radius:20px;font-size:.75rem;font-weight:600;white-space:nowrap}.job-tile-body{display:flex;flex-direction:column;gap:12px}.job-city{margin:0;color:var(--text-gray);font-size:.9rem}.job-details-row{display:flex;align-items:center;gap:12px;font-size:.9rem}.detail-label{color:var(--text-gray);min-width:70px;font-weight:500}.detail-value{color:var(--text-dark);font-weight:600;flex:1}.complete-job-btn{width:100%;padding:12px;background-color:#28a745;color:#fff;border:none;border-radius:8px;font-size:.95rem;font-weight:600;cursor:pointer;margin-top:12px;transition:all .3s ease}.complete-job-btn:hover{background-color:#218838;transform:translateY(-2px);box-shadow:0 4px 12px #28a7454d}.shoveler-page{animation:fadeIn .3s ease}@media(max-width:768px){.shoveler-hero{padding:40px 20px}.shoveler-hero h1{font-size:1.8rem}.shoveler-hero p{font-size:1rem}}@keyframes slideUp{0%{transform:translateY(30px);opacity:0}to{transform:translateY(0);opacity:1}}.job-info{background-color:var(--bg-light);border-radius:8px;padding:16px;margin-bottom:24px}.job-info h3{margin:0 0 8px;font-size:1.1rem;color:var(--text-dark)}.job-info p{margin:6px 0;color:var(--text-gray);font-size:.9rem}.job-date,.shoveler-name,.completed-date{font-weight:600;color:#2c7be5!important}.error-message{background-color:#f8d7da;color:#721c24;border:1px solid #f5c6cb;border-radius:6px;padding:12px;margin-bottom:16px;font-size:.9rem}.form-group{margin-bottom:20px}.form-group label{display:block;font-weight:600;color:var(--text-dark);margin-bottom:8px;font-size:.95rem}.required{color:#dc3545}.amount-input-wrapper{display:flex;align-items:center;gap:8px;position:relative}.currency-symbol{font-size:1.2rem;font-weight:600;color:var(--text-dark)}.amount-display-wrapper{display:flex;align-items:center;gap:8px;padding:6px;background-color:var(--bg-light);border:1px solid var(--border-color);border-radius:6px}.amount-display{font-size:1.5rem;font-weight:700;color:#2c7be5;flex:1}.input-hint{margin:8px 0 0;font-size:.85rem;color:#999;font-style:italic}.amount-input-wrapper input{flex:1;padding:12px;border:1px solid #ddd;border-radius:6px;font-size:1rem;transition:all .3s ease}.amount-input-wrapper input:focus{outline:none;border-color:#2c7be5;box-shadow:0 0 0 3px #2c7be51a}.amount-input-wrapper input:disabled{background-color:var(--bg-light);cursor:not-allowed}.payment-summary{background-color:#d4edda;border:1px solid #c3e6cb;border-radius:8px;padding:16px;margin-bottom:20px}.summary-row{display:flex;justify-content:space-between;margin-bottom:8px;font-size:.95rem;color:#155724}.summary-row:last-child{margin-bottom:0}.summary-row .amount{font-weight:600}.summary-row.total{border-top:2px solid #c3e6cb;padding-top:8px;margin-top:8px;font-weight:700;font-size:1.1rem}.tip-amount{color:#28a745}.summary-row .amount,.summary-row .status{font-weight:600}.form-group textarea{width:100%;padding:12px;border:1px solid #ddd;border-radius:6px;font-size:.95rem;font-family:inherit;resize:vertical;transition:all .3s ease}.payment-notes{min-height:80px!important}.form-group textarea:focus{outline:none;border-color:#2c7be5;box-shadow:0 0 0 3px #2c7be51a}.form-group textarea:disabled{background-color:var(--bg-light);cursor:not-allowed}.info-box{background-color:#cfe2ff;border-left:4px solid #2c7be5;border-radius:6px;padding:12px;margin-bottom:20px}.info-box p{margin:0;color:#084298;font-size:.9rem}.btn-cancel,.btn-submit{flex:1;padding:12px 24px;border:none;border-radius:6px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease}.btn-cancel{background-color:#6c757d;color:#fff}.btn-cancel:hover:not(:disabled){background-color:#5a6268;transform:translateY(-2px)}.btn-cancel:disabled{opacity:.6;cursor:not-allowed}.btn-submit{background-color:#28a745;color:#fff}.btn-submit:hover:not(:disabled){background-color:#218838;transform:translateY(-2px);box-shadow:0 4px 12px #28a7454d}.btn-submit:disabled{background-color:#6c757d;cursor:not-allowed;opacity:.6}.payment-container{display:flex;gap:16px}.base-payment-container,.tip-payment-container{width:50%}.tip-input-hint{margin:8px 0 0 20px;font-size:.85rem;color:#999;font-style:italic}.notes-modal-overlay{position:fixed;inset:0;background-color:#000000b3;display:flex;justify-content:center;align-items:center;z-index:1000;animation:fadeIn .2s ease-in}.notes-modal-content{background:#fff;border-radius:12px;max-width:500px;width:90%;max-height:80vh;overflow:hidden;box-shadow:0 20px 60px #0000004d;animation:slideUp .3s ease-out}.notes-modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;border-bottom:1px solid #e5e7eb}.notes-modal-header h3{margin:0;font-size:1.25rem;font-weight:600;color:#111827}.notes-modal-close{background:none;border:none;font-size:2rem;line-height:1;color:#6b7280;cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:6px;transition:all .2s}.notes-modal-close:hover{background-color:#f3f4f6;color:#111827}.notes-modal-body{padding:24px;max-height:60vh;overflow-y:auto}.notes-modal-body p{margin:0;color:#374151;line-height:1.6;white-space:pre-wrap;word-wrap:break-word}.notes-modal-footer{padding:16px 24px;border-top:1px solid #e5e7eb;display:flex;justify-content:flex-end}.notes-modal-footer .btn-close{padding:10px 24px;background-color:#3b82f6;color:#fff;border:none;border-radius:8px;font-weight:500;cursor:pointer;transition:all .2s}.notes-modal-footer .btn-close:hover{background-color:#2563eb;transform:translateY(-1px);box-shadow:0 4px 12px #3b82f666}.confirm-dialog-overlay{position:fixed;inset:0;background-color:#000000b3;display:flex;justify-content:center;align-items:center;z-index:1000;animation:fadeIn .2s ease-in}.confirm-dialog-content{background:#fff;border-radius:12px;max-width:450px;width:90%;box-shadow:0 20px 60px #0000004d;animation:slideUp .3s ease-out}.confirm-dialog-header{padding:24px 24px 16px}.confirm-dialog-header h3{margin:0;font-size:1.25rem;font-weight:600;color:#111827}.confirm-dialog-body{padding:0 24px 24px}.confirm-dialog-body p{margin:0;color:#6b7280;line-height:1.6}.confirm-dialog-footer{padding:16px 24px;border-top:1px solid #e5e7eb;display:flex;justify-content:flex-end;gap:12px}.confirm-dialog-footer button{padding:10px 20px;border:none;border-radius:8px;font-weight:500;cursor:pointer;transition:all .2s;font-size:.9rem}.btn-cancel{background-color:#f3f4f6;color:#374151}.btn-cancel:hover{background-color:#e5e7eb}.btn-confirm{color:#fff}.btn-confirm.danger{background-color:#ef4444}.btn-confirm.danger:hover{background-color:#dc2626;transform:translateY(-1px);box-shadow:0 4px 12px #ef444466}.btn-confirm.warning{background-color:#f59e0b}.btn-confirm.warning:hover{background-color:#d97706;transform:translateY(-1px);box-shadow:0 4px 12px #f59e0b66}.btn-confirm.info{background-color:#3b82f6}.btn-confirm.info:hover{background-color:#2563eb;transform:translateY(-1px);box-shadow:0 4px 12px #3b82f666}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.customer-jobs-container{padding:40px;background-color:var(--bg-white)}.customer-jobs-container h2{font-size:2rem;color:var(--text-dark);margin-bottom:30px;font-weight:600}.no-jobs{text-align:center;font-size:1.1rem;color:var(--text-gray);padding:60px 40px;background-color:var(--bg-white);border-radius:12px;border:1px solid var(--border-color)}.jobs-table-wrapper{background:transparent;border-radius:12px;overflow:hidden;box-shadow:0 2px 8px #00000014;overflow-x:auto}.jobs-table{width:100%;border-collapse:collapse}.jobs-table thead{background-color:var(--bg-light);border-bottom:2px solid var(--border-color)}.jobs-table th{padding:16px;text-align:left;font-weight:600;color:var(--text-dark);font-size:.9rem;text-transform:uppercase;letter-spacing:.5px;background-color:var(--bg-light)}.jobs-table td{padding:16px;border-bottom:1px solid var(--border-color);color:var(--text-dark);background-color:var(--bg-light)}.jobs-table tbody tr:hover td{background-color:var(--posted-jobs-hover)}.location-info strong{display:block;color:var(--text-dark);font-weight:600;margin-bottom:4px}.location-info p{margin:0;font-size:.85rem;color:var(--text-light)}.date-time{font-size:.9rem;font-weight:500;color:var(--text-dark);line-height:1.5}.shoveler-info strong{display:block;color:var(--text-dark);font-weight:600;margin-bottom:4px}.acceptance-id{margin:0;font-size:.75rem;color:var(--text-light);font-family:monospace}.no-shoveler{color:var(--text-light);font-style:italic}.status-badge{display:inline-block;padding:6px 12px;border-radius:20px;font-size:.8rem;font-weight:600;white-space:nowrap}.status-badge.pending{background-color:#fff3cd;color:#856404}.status-badge.accepted{background-color:#cfe2ff;color:#084298}.status-badge.completed{background-color:#d1ecf1;color:#0c5460}.status-badge.paid{background-color:#d4edda;color:#155724}.status-badge.default{background-color:#e2e3e5;color:#383d41}.action-buttons{display:flex;gap:8px;flex-wrap:wrap}.btn-delete,.btn-payment,.btn-notes{padding:6px 12px;border:none;border-radius:6px;font-size:.85rem;font-weight:600;cursor:pointer;transition:all .3s ease;white-space:nowrap}.btn-delete{background-color:#dc3545;color:#fff}.btn-delete:hover{background-color:#c82333;transform:translateY(-2px);box-shadow:0 4px 8px #dc35454d}.btn-payment{background-color:#28a745;color:#fff}.btn-payment:hover{background-color:#218838;transform:translateY(-2px);box-shadow:0 4px 8px #28a7454d}.btn-notes{background-color:#17a2b8;color:#fff}.btn-notes:hover{background-color:#138496;transform:translateY(-2px);box-shadow:0 4px 8px #17a2b84d}.error{color:#dc3545;padding:20px;background-color:#f8d7da;border-radius:8px;border:1px solid #f5c6cb;text-align:center}.job-row.pending{background-color:#fffbf0}.job-row.accepted{background-color:#f0f7ff}.job-row.completed{background-color:#f0f8f7}.job-row.paid{background-color:#f0fdf4}@media(max-width:1024px){.jobs-table-wrapper{overflow-x:auto}.action-buttons{flex-direction:column;gap:4px}.btn-delete,.btn-payment,.btn-notes{width:100%}}@media(max-width:768px){.customer-jobs-container{padding:20px 10px}.customer-jobs-container h2{font-size:1.5rem;margin-bottom:20px}.jobs-table th,.jobs-table td{padding:12px 8px;font-size:.85rem}.jobs-table th,.location-info p,.acceptance-id{font-size:.75rem}.status-badge{padding:4px 8px;font-size:.7rem}}.booking-container{max-width:700px;margin:40px auto;padding:20px}.booking-header{margin-bottom:40px}.booking-header-text{text-align:center}.back-button{background:none;border:none;color:var(--primary-color);font-size:1rem;font-weight:600;cursor:pointer;padding:8px 0;margin-bottom:20px;transition:color .3s,transform .2s;display:inline-block;text-align:left}.back-button:hover{color:var(--primary-color-dark);transform:translate(-4px)}.booking-header h1{font-size:2.5rem;color:var(--text-dark);margin-bottom:10px}.booking-header p{font-size:1.1rem;color:var(--text-gray)}.booking-form{background:var(--bg-light);border-radius:8px;padding:30px;box-shadow:var(--shadow-md)}.form-section{margin-bottom:30px}.form-section h2{font-size:1.3rem;color:var(--text-dark);margin-bottom:15px;border-bottom:2px solid var(--primary-color);padding-bottom:10px}.form-group{margin-bottom:20px;display:flex;flex-direction:column}.form-group label{font-weight:600;margin-bottom:8px;color:var(--text-dark);font-size:.95rem}.form-group input,.form-group select,.form-group textarea{padding:12px;border:1px solid var(--border-color);border-radius:4px;font-size:1rem;font-family:inherit;transition:border-color .3s,box-shadow .3s}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #536ee41a}.form-group textarea{resize:vertical;min-height:100px}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:15px}@media(max-width:600px){.form-row{grid-template-columns:1fr}.booking-header h1{font-size:1.8rem}.booking-form{padding:20px}}.btn{padding:12px 24px;border:none;border-radius:4px;font-size:1rem;font-weight:600;cursor:pointer;transition:background-color .3s,transform .2s}.btn:hover{transform:translateY(-2px)}.btn-primary{background-color:var(--primary-color);color:var(--bg-white);width:100%}.btn-primary:hover{background-color:var(--primary-color-dark)}.btn-primary:disabled{opacity:.6;cursor:not-allowed}.modal-backdrop{position:fixed;inset:0;background:#0000008c;display:flex;align-items:center;justify-content:center;z-index:2000}.modal-container{background:var(--bg-white);width:95%;max-width:700px;max-height:90vh;overflow-y:auto;border-radius:12px;padding:25px 25px 35px;box-shadow:var(--shadow-lg);animation:fadeIn .2s ease-out;position:relative}@keyframes fadeIn{0%{opacity:0;transform:scale(.97)}to{opacity:1;transform:scale(1)}}.modal-header h1{font-size:2rem;color:var(--text-dark);margin:0}.modal-subtitle{margin-top:4px;margin-bottom:20px;color:var(--text-gray);font-size:1rem}.modal-close-btn{background:none;border:none;font-size:28px;font-weight:600;color:var(--text-dark);cursor:pointer;transition:color .2s}.modal-close-btn:hover{color:var(--primary-color)}.pac-container{z-index:3000!important;font-family:inherit;border-radius:8px;margin-top:4px;box-shadow:0 4px 12px #00000026}.pac-item{padding:10px 12px;cursor:pointer;font-size:.95rem;border-top:1px solid #e5e5e5}.pac-item:first-child{border-top:none}.pac-item:hover{background-color:#f5f5f5}.pac-icon{margin-top:6px}.booking-button-section{padding:5rem 2rem;background:var(--gradient-primary)}.booking-button-container{max-width:600px;margin:0 auto;text-align:center}.booking-button-container h2{font-size:2.5rem;color:#fff;margin-bottom:1rem;font-weight:700}.booking-button-container p{font-size:1.1rem;color:#ffffffe6;margin-bottom:2.5rem;line-height:1.6}.btn-large{padding:18px 48px;font-size:1.2rem;background-color:var(--bg-white);color:var(--primary-color);display:inline-block;box-shadow:0 10px 30px #0003}.btn-large:hover{background-color:var(--bg-light);transform:translateY(-4px);box-shadow:0 15px 40px #0000004d}@media(max-width:768px){.booking-button-section{padding:3rem 1.5rem}.booking-button-container h2{font-size:1.8rem}.booking-button-container p{font-size:1rem}.btn-large{padding:15px 40px;font-size:1.1rem}}.auth-container{width:100%;min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--gradient-primary);padding:2rem}.auth-box{background:var(--bg-white);padding:3rem 2rem;border-radius:12px;box-shadow:0 20px 60px #0000004d;width:100%;max-width:400px}.auth-box h1{text-align:center;margin-bottom:2rem;color:var(--text-dark);font-size:1.8rem}.auth-box form{display:flex;flex-direction:column;gap:1.2rem;margin-bottom:1.5rem}.auth-box input{padding:12px;border:2px solid var(--border-color);border-radius:6px;font-size:1rem;transition:border-color .3s ease}.auth-box input:focus{outline:none;border-color:var(--primary-color)}.auth-box input:disabled{background-color:var(--bg-light);cursor:not-allowed;opacity:.7}.auth-box form button[type=submit]{padding:12px;background-color:var(--primary-color);color:#fff;border:none;border-radius:6px;font-size:1.1rem;font-weight:600;cursor:pointer;transition:all .3s ease;text-transform:uppercase;letter-spacing:1px;display:flex;align-items:center;justify-content:center;gap:8px}.auth-box form button[type=submit]:hover:not(:disabled){background-color:var(--secondary-color);transform:translateY(-2px);box-shadow:0 10px 20px #667eea4d}.auth-box form button[type=submit]:disabled{opacity:.7;cursor:not-allowed}.spinner-container{display:flex;align-items:center;gap:8px}.spinner{display:inline-block;width:16px;height:16px;border:3px solid rgba(255,255,255,.3);border-radius:50%;border-top-color:#fff;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.auth-box p{text-align:center;color:var(--text-gray);font-size:.95rem;margin-bottom:1rem}.link-btn{background:none;border:none;color:var(--primary-color);cursor:pointer;font-weight:600;text-decoration:underline;padding:0;font-size:inherit;transition:color .3s ease}.link-btn:hover:not(:disabled){color:var(--secondary-color)}.link-btn:disabled{opacity:.6;cursor:not-allowed}.back-btn{width:100%;padding:10px;background-color:transparent;color:var(--primary-color);border:2px solid var(--primary-color);border-radius:6px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease}.back-btn:hover:not(:disabled){background-color:var(--primary-color);color:#fff}.back-btn:disabled{opacity:.6;cursor:not-allowed}.error-message{background-color:var(--error-light);color:var(--error-dark);padding:12px;border-radius:6px;margin-bottom:1.5rem;font-size:.95rem;border-left:4px solid var(--error-dark)}.success-message{background-color:var(--success-light);color:var(--success-dark);padding:12px;border-radius:6px;margin-bottom:1.5rem;font-size:.95rem;border-left:4px solid var(--success-dark);font-weight:600}.usertype-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--bg-light) 0%,var(--bg-white) 100%);padding:20px}.usertype-content{max-width:900px;width:100%;text-align:center}.usertype-content h1{font-size:2.5rem;color:var(--text-dark);margin-bottom:10px}.subtitle{font-size:1.1rem;color:var(--text-gray);margin-bottom:40px}.error-message{background-color:var(--error-light);color:var(--error-dark);padding:12px 16px;border-radius:4px;margin-bottom:20px;border-left:4px solid var(--error-dark)}.success-message{background-color:var(--success-light);color:var(--success-dark);padding:12px 16px;border-radius:4px;margin-bottom:20px;border-left:4px solid var(--success-dark)}.usertype-options{display:grid;grid-template-columns:1fr 1fr;gap:30px;margin-bottom:40px}.usertype-card{background:var(--bg-white);border:2px solid var(--border-color);border-radius:12px;padding:40px 30px;cursor:pointer;transition:all .3s ease;text-align:center;position:relative;overflow:hidden}.usertype-card:hover{border-color:var(--primary-color);box-shadow:var(--shadow-md);transform:translateY(-4px)}.usertype-card.selected{border-color:var(--primary-color);background:linear-gradient(135deg,#536ee40d,#536ee405);box-shadow:var(--shadow-lg)}.usertype-card:disabled{opacity:.6;cursor:not-allowed}.card-icon{font-size:3rem;margin-bottom:20px}.usertype-card h2{font-size:1.5rem;color:var(--text-dark);margin-bottom:15px}.usertype-card p{color:var(--text-gray);margin-bottom:20px;line-height:1.6}.card-benefits{list-style:none;padding:0;margin:20px 0;text-align:left}.card-benefits li{color:var(--text-gray);padding:8px 0;display:flex;align-items:center;justify-content:center}.card-benefits li:before{content:"✓";color:var(--primary-color);font-weight:700;margin-right:10px}.spinner-container{display:flex;align-items:center;justify-content:center;gap:8px;margin-top:20px}.spinner{width:20px;height:20px;border:3px solid var(--primary-color);border-top:3px solid transparent;border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media(max-width:768px){.usertype-options{grid-template-columns:1fr;gap:20px}.usertype-content h1{font-size:2rem}.usertype-card{padding:30px 20px}.card-icon{font-size:2.5rem}.usertype-card h2{font-size:1.3rem}}.settings-container{min-height:100vh;background-color:var(--bg-light);padding:2rem}.settings-content{max-width:800px;margin:0 auto;background-color:var(--bg-white);border-radius:12px;padding:2.5rem;box-shadow:var(--shadow-sm)}.settings-header{display:flex;align-items:center;gap:1rem;margin-bottom:2rem}.back-button{padding:.5rem 1rem;background-color:transparent;color:var(--text-dark);border:2px solid var(--border-color);border-radius:8px;cursor:pointer;font-size:.95rem;font-weight:500;transition:all .3s ease;display:flex;align-items:center;gap:.25rem}.back-button:hover{background-color:var(--bg-light);border-color:var(--primary-color);transform:translate(-2px)}.settings-title{font-size:2rem;font-weight:700;color:var(--text-dark);margin:0}.settings-section{margin-bottom:2rem}.section-title{font-size:1.25rem;font-weight:600;color:var(--text-dark);margin-bottom:1.5rem;padding-bottom:.5rem;border-bottom:2px solid var(--border-color)}.theme-selector{margin-bottom:1.5rem}.theme-label{display:block;font-size:1rem;font-weight:500;color:var(--text-dark);margin-bottom:1rem}.theme-options{display:flex;gap:1rem;margin-bottom:1rem}.theme-option{flex:1;display:flex;flex-direction:column;align-items:center;gap:.5rem;padding:1.5rem;background-color:var(--bg-light);border:2px solid var(--border-color);border-radius:12px;cursor:pointer;transition:all .3s ease;font-size:1rem;color:var(--text-dark)}.theme-option:hover{border-color:var(--primary-color);transform:translateY(-2px);box-shadow:var(--shadow-sm)}.theme-option.active{background:var(--gradient-primary);border-color:var(--primary-color);color:#fff}.theme-icon{font-size:2rem}.theme-description{font-size:.875rem;color:var(--text-gray);line-height:1.5;margin-top:.5rem}@media(max-width:768px){.settings-container{padding:1rem}.settings-content{padding:1.5rem}.settings-title{font-size:1.5rem}.theme-options{flex-direction:column}}
