:root{--primary-color:#ff6b35;--secondary-color:#f7931e;--success-color:#2ecc71;--error-color:#e74c3c;--warning-color:#f39c12;--info-color:#3498db;--dark-color:#2c3e50;--light-color:#ecf0f1;--border-color:#bdc3c7;--shadow:0 2px 8px #0000001a;--radius:8px;--spacing:16px}*{box-sizing:border-box;margin:0;padding:0}body{background-color:#f5f5f5;color:#2c3e50;color:var(--dark-color);font-display:swap;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif}.app{display:flex;flex-direction:column;min-height:100vh}.navbar{align-items:center;background-color:#ff6b35;background-color:var(--primary-color);box-shadow:0 2px 8px #0000001a;box-shadow:var(--shadow);color:#fff;display:flex;justify-content:space-between;padding:16px;padding:var(--spacing);position:sticky;top:0;z-index:100}.navbar-brand{font-size:24px;font-weight:700}.navbar-menu{align-items:center;display:flex;gap:16px;gap:var(--spacing)}.user-info{font-size:14px;opacity:.9}.logout-btn,.nav-link{transition:background-color .3s}.logout-btn{background-color:#fff3;border:1px solid #fff;border-radius:8px;border-radius:var(--radius);color:#fff;cursor:pointer;padding:8px 16px}.logout-btn:hover{background-color:#ffffff4d}.nav-link{background-color:#ffffff26;border-radius:8px;border-radius:var(--radius);color:#fff;font-size:14px;font-weight:600;padding:8px 16px;text-decoration:none}.nav-link:hover{background-color:#ffffff4d}main{flex:1 1;margin:0 auto;max-width:1200px;width:100%}.form-section,main{padding:16px;padding:var(--spacing)}.form-section{background:#fff;border-radius:8px;border-radius:var(--radius);box-shadow:0 2px 8px #0000001a;box-shadow:var(--shadow)}.form-section,.form-section h2{margin-bottom:16px;margin-bottom:var(--spacing)}.form-section h2{color:#ff6b35;color:var(--primary-color);font-size:20px}.form-group{margin-bottom:16px;margin-bottom:var(--spacing)}.form-group label{color:#2c3e50;color:var(--dark-color);display:block;font-weight:500}.form-group input,.form-group select,.form-group textarea{border:1px solid #bdc3c7;border:1px solid var(--border-color);border-radius:8px;border-radius:var(--radius);font-family:inherit;font-size:14px;padding:10px;transition:border-color .3s;width:100%}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:#ff6b35;border-color:var(--primary-color);box-shadow:0 0 0 3px #ff6b351a;outline:none}.form-row{grid-gap:16px;grid-gap:var(--spacing);display:grid;gap:16px;gap:var(--spacing);grid-template-columns:1fr 1fr}@media (max-width:768px){.form-row{grid-template-columns:1fr}}.form-actions{display:flex;gap:16px;gap:var(--spacing);margin-top:16px * 2;margin-top:var(--spacing) * 2}.btn-danger,.btn-primary,.btn-secondary,.btn-success{border:none;border-radius:8px;border-radius:var(--radius);cursor:pointer;display:inline-block;font-size:16px;font-weight:600;padding:12px 24px;text-decoration:none;transition:all .3s}.btn-primary{background-color:#ff6b35;background-color:var(--primary-color)}.btn-primary:hover:not(:disabled){background-color:#e55a2b;box-shadow:0 4px 12px #ff6b354d}.btn-secondary{background-color:#ecf0f1;background-color:var(--light-color);border:1px solid #bdc3c7;border:1px solid var(--border-color);color:#2c3e50;color:var(--dark-color)}.btn-secondary:hover{background-color:#bdc3c7;background-color:var(--border-color)}.btn-success{background-color:#2ecc71;background-color:var(--success-color);color:#fff}.btn-success:hover{background-color:#27ae60}.btn-danger{background-color:#e74c3c;background-color:var(--error-color);color:#fff}.btn-danger:hover{background-color:#c0392b}.btn-small{font-size:14px}.btn-remove{align-items:center;background:#e74c3c;background:var(--error-color);border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;font-size:18px;height:32px;justify-content:center;position:absolute;right:8px;top:8px;transition:background-color .3s;width:32px}.btn-remove:hover{background-color:#c0392b}.photo-upload{margin:16px 0;margin:var(--spacing) 0}.dropzone{background-color:#fafafa;border:2px dashed #bdc3c7;border:2px dashed var(--border-color);border-radius:8px;border-radius:var(--radius);cursor:pointer;padding:40px;text-align:center;transition:all .3s}.dropzone.active{background-color:#ff6b350d;border-color:#ff6b35;border-color:var(--primary-color)}.upload-icon{font-size:48px;margin-bottom:16px}.upload-text{color:#2c3e50;color:var(--dark-color);font-size:18px;font-weight:600;margin-bottom:8px}.upload-hint{color:#7f8c8d;font-size:14px}.photos-grid{grid-gap:16px;grid-gap:var(--spacing);display:grid;gap:16px;gap:var(--spacing);grid-template-columns:repeat(auto-fill,minmax(150px,1fr));margin-top:16px;margin-top:var(--spacing)}.photo-item{border-radius:8px;border-radius:var(--radius);box-shadow:0 2px 8px #0000001a;box-shadow:var(--shadow);overflow:hidden;position:relative}.photo-item img{height:150px;object-fit:cover;width:100%}.quote-summary{background:linear-gradient(135deg,#ff6b350d,#f7931e0d);border-left:4px solid #ff6b35;border-left:4px solid var(--primary-color)}.summary-row{display:flex;font-size:16px;justify-content:space-between;padding:8px 0}.summary-row strong{color:#2c3e50;color:var(--dark-color);font-weight:600}.summary-row.quote-amount{border-top:2px solid #0000001a;font-size:20px;margin-top:16px;margin-top:var(--spacing);padding-top:16px;padding-top:var(--spacing)}.summary-row.quote-amount strong{color:#2ecc71;color:var(--success-color);font-size:24px}.quote-note{color:#7f8c8d;font-size:13px;font-style:italic;margin-top:16px;margin-top:var(--spacing)}.error-message{background-color:#e74c3c1a;border-left:4px solid #e74c3c;border-left:4px solid var(--error-color);color:#e74c3c;color:var(--error-color)}.error-message,.success-message{border-radius:8px;border-radius:var(--radius);margin-bottom:16px;margin-bottom:var(--spacing);padding:16px;padding:var(--spacing)}.success-message{background-color:#2ecc711a;border-left:4px solid #2ecc71;border-left:4px solid var(--success-color);color:#2ecc71;color:var(--success-color)}.info-message{background-color:#3498db1a;border-left:4px solid #3498db;border-left:4px solid var(--info-color);border-radius:8px;border-radius:var(--radius);color:#3498db;color:var(--info-color);margin-bottom:16px;margin-bottom:var(--spacing);padding:16px;padding:var(--spacing)}.loading{align-items:center;color:#ff6b35;color:var(--primary-color);display:flex;font-size:18px;height:100vh;justify-content:center}.dashboard{grid-gap:16px;grid-gap:var(--spacing);display:grid;gap:16px;gap:var(--spacing);grid-template-columns:repeat(auto-fit,minmax(300px,1fr))}.card{background:#fff;border-radius:8px;border-radius:var(--radius);box-shadow:0 2px 8px #0000001a;box-shadow:var(--shadow);padding:16px;padding:var(--spacing)}.card:hover{box-shadow:0 4px 16px #00000026}.card h3{color:#ff6b35;color:var(--primary-color);margin-bottom:12px}.card-stat{color:#2c3e50;color:var(--dark-color);font-size:28px;font-weight:700;margin:12px 0}.card-action{margin-top:16px;margin-top:var(--spacing)}.table{background:#fff;border-collapse:collapse;border-radius:8px;border-radius:var(--radius);box-shadow:0 2px 8px #0000001a;box-shadow:var(--shadow);overflow:hidden;width:100%}.table thead{background-color:#ecf0f1;background-color:var(--light-color)}.table th{border-bottom:2px solid #bdc3c7;border-bottom:2px solid var(--border-color);color:#2c3e50;color:var(--dark-color);font-weight:600;padding:12px;text-align:left}.table td{border-bottom:1px solid #bdc3c7;border-bottom:1px solid var(--border-color);padding:12px}.table tbody tr:hover{background-color:#fafafa}.badge{border-radius:20px;display:inline-block;font-size:12px;font-weight:600;padding:4px 12px;text-transform:uppercase}.badge-pending{background-color:#f39c1233;color:#f39c12;color:var(--warning-color)}.badge-success{background-color:#2ecc7133;color:#2ecc71;color:var(--success-color)}.badge-error{background-color:#e74c3c33;color:#e74c3c;color:var(--error-color)}.badge-info{background-color:#3498db33;color:#3498db;color:var(--info-color)}.hole-section{background:#fafafa;border-left:4px solid #f7931e;border-left:4px solid var(--secondary-color);border-radius:8px;border-radius:var(--radius);margin-bottom:16px;margin-bottom:var(--spacing);padding:16px;padding:var(--spacing)}.hole-section h3{color:#f7931e;color:var(--secondary-color);margin-bottom:12px}.capture-options{border-top:1px solid #bdc3c7;border-top:1px solid var(--border-color);margin-top:16px;margin-top:var(--spacing);padding-top:16px;padding-top:var(--spacing)}.btn-camera{background-color:#3498db;background-color:var(--info-color);border:none;border-radius:8px;border-radius:var(--radius);color:#fff;cursor:pointer;font-size:16px;font-weight:600;padding:12px 24px;transition:background-color .3s}.btn-camera:hover{background-color:#2980b9}@media (max-width:768px){.navbar{flex-direction:column;gap:12px}.navbar-menu{justify-content:space-between;width:100%}.form-section,main{padding:12px}.photos-grid{grid-template-columns:repeat(auto-fill,minmax(100px,1fr))}.table{font-size:14px}.table td,.table th{padding:8px}}.dashboard-container{margin:0 auto;max-width:1400px;min-height:calc(100vh - 70px);padding:20px}.dashboard-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:30px}.dashboard-header h1{color:#1a1a1a;font-size:32px;margin:0}.btn-primary{font-size:14px;padding:12px 24px}.btn-primary:hover{opacity:.9;transform:translateY(-2px)}.dashboard-stats{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-bottom:30px}.stat-card{background:#fff;border:1px solid #e0e0e0;border-radius:8px;box-shadow:0 2px 4px #0000000d;padding:20px;text-align:center;transition:transform .2s,box-shadow .2s}.stat-card:hover{box-shadow:0 4px 12px #0000001a;transform:translateY(-4px)}.stat-value{color:#667eea;font-size:32px;font-weight:700;margin-bottom:8px}.stat-label{color:#666;font-size:14px;font-weight:500}.filter-bar{display:flex;flex-wrap:wrap;gap:12px;margin-bottom:24px}.filter-btn{background:#fff;border:2px solid #e0e0e0;border-radius:6px;color:#666;cursor:pointer;font-size:14px;font-weight:500;padding:10px 16px;transition:all .2s}.filter-btn:hover{border-color:#667eea;color:#667eea}.filter-btn.active{background:#667eea;border-color:#667eea;color:#fff}.jobs-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fill,minmax(300px,1fr))}.job-card{background:#fff;border:1px solid #e0e0e0;border-radius:8px;color:inherit;cursor:pointer;padding:20px;text-decoration:none;transition:all .2s}.job-card:hover{box-shadow:0 8px 24px #0000001f;transform:translateY(-4px)}.job-header{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:16px}.job-header h3{flex:1 1;font-size:18px;margin:0}.status-badge{border-radius:20px;color:#fff;font-size:12px;font-weight:600;margin-left:8px;padding:6px 12px;white-space:nowrap}.job-info{margin-bottom:16px}.job-info p{color:#666;font-size:14px;margin:8px 0}.job-footer{align-items:center;border-top:1px solid #e0e0e0;color:#999;display:flex;font-size:14px;justify-content:space-between;padding-top:16px}.arrow{color:#667eea;font-weight:700}.empty-state{color:#999;padding:60px 20px;text-align:center}.empty-state p{font-size:18px;margin-bottom:20px}.crew-stats{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));margin-bottom:30px}.performance-card{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:8px;color:#fff;margin-bottom:30px;padding:24px}.performance-card h3{font-size:18px;margin-bottom:20px;margin-top:0}.performance-metrics{gap:16px}.metric,.performance-metrics{display:flex;flex-direction:column}.metric{gap:8px}.metric span{font-size:14px;font-weight:500}.progress-bar{background:#fff3;border-radius:4px;height:8px;overflow:hidden}.progress-fill{background:#fff;border-radius:4px;height:100%}.assignments-list{display:flex;flex-direction:column;gap:16px}.assignment-card{background:#fff;border:1px solid #e0e0e0;border-radius:8px;color:inherit;padding:20px;text-decoration:none;transition:all .2s}.assignment-card:hover{box-shadow:0 4px 12px #0000001a}.assignment-header{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:16px}.assignment-header h3{font-size:18px;margin:0}.assignment-info{margin-bottom:16px}.assignment-info p{color:#666;font-size:14px;margin:8px 0}.in-progress-note{color:#4caf50!important;font-weight:500}.assignment-actions{display:flex;gap:12px}.btn-small{background:#fff;border:1px solid #e0e0e0;border-radius:6px;color:#666;cursor:pointer;font-size:12px;font-weight:600;padding:8px 16px;transition:all .2s}.btn-small.btn-primary{background:#667eea;border-color:#667eea;color:#fff}.badge-submitted{color:#4caf50;font-size:12px;font-weight:600}.admin-tabs{border-bottom:2px solid #e0e0e0;display:flex;gap:12px;margin-bottom:24px}.tab-btn{background:#0000;border:none;border-bottom:3px solid #0000;color:#666;cursor:pointer;font-size:14px;font-weight:600;padding:12px 20px;transition:all .2s}.tab-btn:hover{color:#667eea}.tab-btn.active{border-bottom-color:#667eea;color:#667eea}.admin-overview{display:flex;flex-direction:column;gap:24px}.overview-section{background:#fff;border:1px solid #e0e0e0;border-radius:8px;padding:24px}.overview-section h3{font-size:16px;margin-bottom:20px;margin-top:0}.metrics-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.metric-box{background:#f9f9f9;border-radius:6px;display:flex;flex-direction:column;gap:8px;padding:16px}.metric-label{color:#999;font-size:12px;font-weight:500;letter-spacing:.5px;text-transform:uppercase}.metric-value{color:#667eea;font-size:24px;font-weight:700}.crew-leaderboard{display:flex;flex-direction:column;gap:12px}.leaderboard-row{grid-gap:16px;align-items:center;background:#f9f9f9;border-radius:6px;display:grid;font-size:14px;gap:16px;grid-template-columns:40px 1fr 120px 100px;padding:12px}.rank{color:#667eea;font-weight:700}.name{font-weight:500}.score{font-weight:600;text-align:center}.jobs{color:#666;text-align:right}.jobs-table{background:#fff;border:1px solid #e0e0e0;border-radius:8px;overflow:hidden}.table-header{background:#f9f9f9;border-bottom:2px solid #e0e0e0;color:#333;font-size:13px;font-weight:600}.table-header,.table-row{grid-gap:16px;display:grid;gap:16px;grid-template-columns:2fr 1.5fr 1fr 1.5fr 1fr 100px;padding:16px}.table-row{align-items:center;border-bottom:1px solid #e0e0e0;font-size:14px}.table-row:hover{background:#f9f9f9}.col{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.action-link{color:#667eea;font-weight:600;text-decoration:none}.action-link:hover{text-decoration:underline}.crew-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fill,minmax(300px,1fr))}.crew-performance-card{background:#fff;border:1px solid #e0e0e0;border-radius:8px;padding:20px}.crew-performance-card h4{font-size:16px;margin:0 0 16px}.crew-stats{display:flex;flex-direction:column;gap:12px;margin-bottom:16px}.crew-stat{align-items:center;border-bottom:1px solid #f0f0f0;display:flex;justify-content:space-between;padding:8px 0}.stat-label{color:#999;font-size:12px}.stat-val{color:#333;font-size:14px;font-weight:600}.crew-actions{display:flex;gap:8px}.loading{color:#999;font-size:16px;padding:40px 20px;text-align:center}@media (max-width:768px){.dashboard-header{align-items:flex-start;flex-direction:column;gap:16px}.dashboard-header h1{font-size:24px}.dashboard-stats{grid-template-columns:repeat(auto-fit,minmax(150px,1fr))}.jobs-grid,.leaderboard-row,.table-header,.table-row{grid-template-columns:1fr}}.auth-container{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;justify-content:center;min-height:100vh;padding:20px}.auth-card{background:#fff;border-radius:12px;box-shadow:0 20px 60px #0000004d;max-width:400px;padding:40px;width:100%}.auth-card h1{color:#1a1a1a;font-size:32px;font-weight:700;margin-bottom:8px;text-align:center}.auth-card .subtitle{color:#666;font-size:14px;margin-bottom:30px;text-align:center}.form-group{display:flex;flex-direction:column;margin-bottom:20px}.form-group label{color:#333;font-size:14px;font-weight:600;margin-bottom:8px}.form-group input,.form-group select{border:1px solid #ddd;border-radius:6px;font-family:inherit;font-size:14px;padding:12px;transition:border-color .2s,box-shadow .2s}.form-group input:focus,.form-group select:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a;outline:none}.form-group small{color:#999;font-size:12px;margin-top:4px}.btn-primary{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:16px;font-weight:600;padding:12px;transition:opacity .2s,transform .2s;width:100%}.btn-primary:hover:not(:disabled){opacity:.9;transform:translateY(-2px)}.btn-primary:disabled{cursor:not-allowed;opacity:.6}.error-message{background:#fee;border-left:4px solid #c33;border-radius:6px;color:#c33;font-size:14px;margin-bottom:20px;padding:12px}.text-center{color:#666;font-size:14px;margin-top:20px;text-align:center}.text-center a{color:#667eea;font-weight:600;text-decoration:none}.text-center a:hover{text-decoration:underline}.test-users{border-top:1px solid #eee;margin-top:30px;padding-top:20px}.test-label{color:#999;font-size:12px;letter-spacing:.5px;margin-bottom:10px;text-align:center;text-transform:uppercase}.test-buttons{grid-gap:8px;display:grid;gap:8px;grid-template-columns:1fr 1fr 1fr}.test-btn{background:#f9f9f9;border:1px solid #ddd;border-radius:4px;color:#666;cursor:pointer;font-size:12px;font-weight:500;padding:8px;transition:all .2s}.test-btn:hover{background:#e9f1ff;border-color:#667eea;color:#667eea}@media (max-width:480px){.auth-card{padding:24px}.auth-card h1{font-size:24px}}