.auth-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2);padding:2rem}.auth-card{background:#fff;padding:3rem;border-radius:12px;box-shadow:0 10px 40px #0003;width:100%;max-width:450px}.auth-card h1{color:#2c3e50;font-size:2rem;margin-bottom:.5rem;text-align:center}.auth-card h2{color:#7f8c8d;font-size:1.2rem;font-weight:400;margin-bottom:2rem;text-align:center}.success-message{background-color:#efe;color:#2a7c2a;padding:1rem;border-radius:6px;margin-bottom:1.5rem;border:1px solid #cfc}.resend-link{display:block;margin-top:.75rem;background:none;border:none;color:#667eea;text-decoration:underline;cursor:pointer;font-size:.9rem;padding:0}.resend-link:hover{color:#764ba2}.resend-link:disabled{opacity:.5;cursor:not-allowed}.auth-card .form-group{margin-bottom:1.5rem}.auth-card .form-group label{display:block;margin-bottom:.5rem;color:#2c3e50;font-weight:500}.auth-card .form-group input{width:100%;padding:.75rem;border:2px solid #e0e0e0;border-radius:6px;font-size:1rem;transition:border-color .2s;background-color:#fff;color:#2c3e50}.auth-card .form-group input:focus{outline:none;border-color:#667eea}.auth-card .form-group input:-webkit-autofill,.auth-card .form-group input:-webkit-autofill:hover,.auth-card .form-group input:-webkit-autofill:focus,.auth-card .form-group input:-webkit-autofill:active{-webkit-box-shadow:0 0 0 1000px white inset!important;-webkit-text-fill-color:#2c3e50!important;box-shadow:0 0 0 1000px #fff inset!important;border:2px solid #e0e0e0!important;transition:background-color 5000s ease-in-out 0s}.submit-btn{width:100%;padding:1rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:6px;font-size:1rem;font-weight:600;cursor:pointer;transition:transform .2s,box-shadow .2s}.auth-footer{text-align:center;margin-top:1.5rem;color:#7f8c8d}.auth-footer a{color:#667eea;text-decoration:none;font-weight:600}.auth-footer a:hover{text-decoration:underline}.layout{min-height:100vh;display:flex;flex-direction:column;background-color:#1a1a1a}.header{background-color:#242424;color:#fff;padding:1rem 0;box-shadow:0 2px 8px #0000004d;border-bottom:1px solid #333}.header-content{max-width:1600px;margin:0 auto;padding:0 2rem;display:flex;justify-content:space-between;align-items:center}.logo{font-size:1.5rem;font-weight:700;color:#fff;text-decoration:none}.logo:hover{color:#667eea}.nav{display:flex;gap:1.5rem;align-items:center}.nav-link{color:#fff;text-decoration:none;padding:.5rem 1rem;border-radius:4px;transition:background-color .2s}.nav-link:hover{background-color:#ffffff1a}.logout-btn{background-color:#e74c3c;color:#fff;border:none;padding:.5rem 1rem;border-radius:4px;cursor:pointer;font-size:1rem;transition:background-color .2s}.logout-btn:hover{background-color:#c0392b}.main-content{flex:1;max-width:1600px;width:100%;margin:0 auto;padding:2rem}.dashboard{width:100%}.dashboard-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}.dashboard-header h1{color:#e0e0e0;font-size:2rem}.create-job-btn{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:.75rem 1.5rem;border-radius:6px;text-decoration:none;font-weight:600;transition:transform .2s,box-shadow .2s;display:inline-block}.create-job-btn:hover{transform:translateY(-2px);box-shadow:0 4px 12px #667eea66}.empty-state{text-align:center;padding:4rem 2rem;background:#242424;border-radius:12px;box-shadow:0 2px 8px #0000004d;border:1px solid #333}.empty-state h2{color:#e0e0e0;margin-bottom:.5rem}.empty-state p{color:#999;margin-bottom:2rem}.jobs-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:1.5rem}.job-card{background:#242424;border-radius:12px;padding:1.5rem;box-shadow:0 2px 8px #0000004d;border:1px solid #333;text-decoration:none;color:#e0e0e0;transition:transform .2s,box-shadow .2s,border-color .2s;display:flex;flex-direction:column}.job-card:hover{transform:translateY(-4px);box-shadow:0 8px 24px #00000080;border-color:#667eea}.job-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.job-code{font-family:Courier New,monospace;font-weight:700;font-size:1.1rem;color:#667eea}.status-badge{padding:.25rem .75rem;border-radius:20px;font-size:.85rem;font-weight:600;text-transform:capitalize}.status-active{background-color:#d4edda;color:#155724}.status-completed{background-color:#d1ecf1;color:#0c5460}.status-archived{background-color:#e2e3e5;color:#383d41}.job-client{color:#e0e0e0;font-size:1.3rem;margin-bottom:.5rem}.job-description{color:#999;font-size:.95rem;margin-bottom:1rem;line-height:1.4;overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}.job-stats{display:flex;gap:2rem;padding:1rem 0;border-top:1px solid #333;border-bottom:1px solid #333;margin:1rem 0}.stat{display:flex;flex-direction:column;align-items:center}.stat-value{font-size:1.5rem;font-weight:700;color:#e0e0e0}.stat-label{font-size:.85rem;color:#999;text-transform:uppercase;letter-spacing:.5px}.job-footer{color:#666;font-size:.85rem;margin-top:auto}.job-detail{max-width:100%;margin:0 auto}.job-detail-header{margin-bottom:2rem}.back-btn{background:#242424;color:#667eea;border:2px solid #667eea;padding:.5rem 1rem;border-radius:6px;font-size:1rem;font-weight:600;cursor:pointer;margin-bottom:1rem;transition:background-color .2s,border-color .2s}.back-btn:hover{background-color:#667eea;color:#fff}.job-title-section{display:flex;justify-content:space-between;align-items:center}.job-title-section h1{color:#e0e0e0;font-size:2.5rem}.job-detail-layout{display:grid;grid-template-columns:350px 1fr;gap:2rem;align-items:start}.job-sidebar{display:flex;flex-direction:column;gap:1.5rem;position:sticky;top:2rem}.sidebar-card{background:#242424;padding:1.5rem;border-radius:12px;box-shadow:0 2px 8px #0000004d;border:1px solid #333}.sidebar-card h2{color:#e0e0e0;margin-bottom:1rem;font-size:1.2rem}.job-main-content{min-width:0}.status-badge{padding:.5rem 1rem;border-radius:20px;font-size:.85rem;font-weight:600;text-transform:capitalize}.status-active{background-color:#1b4d1b;color:#4caf50;border:1px solid #2d5a2d}.status-completed{background-color:#1a3a4a;color:#4fc3f7;border:1px solid #2d5a6d}.status-archived{background-color:#2a2a2a;color:#999;border:1px solid #444}.receipts-section,.line-items-section{background:#242424;padding:2rem;border-radius:12px;box-shadow:0 2px 8px #0000004d;border:1px solid #333;margin-bottom:2rem}.line-items-section h2{color:#e0e0e0;margin-bottom:1.5rem;font-size:1.5rem}.receipts-section{background:#242424;padding:2rem;border-radius:12px;box-shadow:0 2px 8px #0000004d;border:1px solid #333}.receipts-section h2{color:#e0e0e0;margin-bottom:1.5rem;font-size:1.5rem}.receipts-group:last-child{margin-bottom:0}.receipts-group h3{color:#999;font-size:1rem;margin-bottom:1rem;text-transform:uppercase;letter-spacing:.5px;font-weight:600}.receipts-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.5rem}.receipt-card{background:#1a1a1a;border:2px solid #333;border-radius:8px;overflow:hidden;transition:all .2s}.receipt-card:hover{border-color:#667eea;transform:translateY(-2px);box-shadow:0 4px 12px #667eea33}.receipt-card.approved{border-color:#2d5a2d}.receipt-card.approved:hover{border-color:#3a6e3a}.receipt-image-container{position:relative;width:100%;height:200px;background:#0a0a0a;overflow:hidden}.receipt-image{width:100%;height:100%;object-fit:contain;cursor:pointer}.receipt-delete-btn{position:absolute;top:8px;left:8px;background:#e74c3ce6;color:#fff;border:none;width:30px;height:30px;border-radius:50%;font-size:24px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s;line-height:1;opacity:0;z-index:10}.receipt-card:hover .receipt-delete-btn{opacity:1}.receipt-delete-btn:hover{background:#c0392b;transform:scale(1.1)}.receipt-status-overlay{position:absolute;top:.5rem;right:.5rem;background:#2d5a2d;color:#fff;padding:.5rem 1rem;border-radius:6px;font-weight:600;font-size:.85rem}.receipt-info{padding:1rem}.receipt-meta{display:flex;flex-direction:column;gap:.5rem;margin-bottom:1rem;color:#999;font-size:.9rem}.receipt-date{font-weight:600;color:#e0e0e0}.receipt-description{color:#667eea;font-weight:500}.receipt-actions{display:flex;gap:.75rem}.approve-btn{flex:1;padding:.75rem;background:#2d5a2d;color:#fff;border:1px solid #3a6e3a;border-radius:6px;font-weight:600;cursor:pointer;transition:all .2s}.approve-btn:hover{background:#3a6e3a;transform:translateY(-1px)}.reject-btn{flex:1;padding:.75rem;background:#5a2d2d;color:#fff;border:1px solid #6e3a3a;border-radius:6px;font-weight:600;cursor:pointer;transition:all .2s}.reject-btn:hover{background:#6e3a3a;transform:translateY(-1px)}.info-row{display:flex;flex-direction:column;margin-bottom:1rem;gap:.25rem}.info-label{color:#999;font-weight:600;font-size:.85rem;text-transform:uppercase;letter-spacing:.5px}.info-value{color:#e0e0e0;font-size:1rem}.status-dropdown{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;padding:.5rem 1rem;border-radius:6px;font-weight:600;cursor:pointer;font-size:.9rem;transition:transform .2s;text-transform:capitalize}.status-dropdown:hover{transform:translateY(-2px)}.status-dropdown option{background:#242424;color:#e0e0e0;padding:.5rem}.code-highlight{color:#667eea;font-family:Courier New,monospace;font-weight:700;font-size:1.1rem}.code-card{text-align:center;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:1px solid #764ba2}.code-card h2{color:#fff;font-size:1.1rem}.code-instructions-text{font-size:.85rem;margin-bottom:.5rem;opacity:.9}.code-example{font-size:.8rem;margin-top:1rem;line-height:1.5;color:#ecf0f1;opacity:.9}.phone-number{font-size:1.2rem;font-weight:700;margin:.75rem 0;font-family:Courier New,monospace}.job-code-box{background:#fff;padding:1.5rem;border-radius:8px;margin:1rem 0}.job-code-large{font-size:2rem;font-weight:700;font-family:Courier New,monospace;color:#667eea;letter-spacing:3px}.receipts-group{margin-bottom:2rem}.receipts-group h3{color:#e0e0e0;margin-bottom:1rem;font-size:1.2rem}.receipts-placeholder{background:#1a1a1a;padding:2rem;border-radius:8px;text-align:center;color:#999;border:2px dashed #333}.empty-receipts{text-align:center;padding:3rem;color:#999;background:#1a1a1a;border-radius:8px}.loading{text-align:center;padding:3rem;color:#999;font-size:1.2rem}.cost-summary-card{background:linear-gradient(135deg,#1b4d1b,#2d5a2d);color:#fff;border:1px solid #2d5a2d}.cost-summary-card h2{color:#fff}.cost-list{display:flex;flex-direction:column;gap:.75rem}.cost-row{display:flex;justify-content:space-between;align-items:center;padding:.75rem;background:#ffffff0d;border-radius:6px}.cost-row.total{background:#ffffff1a;border:2px solid rgba(255,255,255,.2);padding:1rem;margin-top:.5rem}.cost-row .cost-label{font-size:.9rem;text-transform:uppercase;letter-spacing:.5px}.cost-row .cost-value{font-size:1.3rem;font-weight:700;font-family:Courier New,monospace}.cost-row.total .cost-value{font-size:1.8rem}.line-items-section{background:#242424;padding:2rem;border-radius:12px;box-shadow:0 2px 8px #0000004d;border:1px solid #333}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.section-actions{display:flex;gap:.75rem;align-items:center}.export-csv-btn{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;padding:.75rem 1.5rem;border-radius:6px;font-weight:600;cursor:pointer;transition:transform .2s}.export-csv-btn:hover{transform:translateY(-2px)}.filter-buttons{display:flex;gap:.5rem;margin-bottom:1.5rem}.filter-btn{padding:.5rem 1rem;background:#1a1a1a;color:#999;border:2px solid #333;border-radius:6px;font-size:.9rem;font-weight:600;cursor:pointer;transition:all .2s}.filter-btn:hover{border-color:#667eea;color:#e0e0e0}.filter-btn.active{background:#667eea;color:#fff;border-color:#667eea}.add-item-btn{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;padding:.75rem 1.5rem;border-radius:6px;font-weight:600;cursor:pointer;transition:transform .2s}.add-item-btn:hover{transform:translateY(-2px)}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000;padding:2rem}.modal-content{background:#242424;border-radius:12px;border:1px solid #333;box-shadow:0 10px 40px #00000080;max-width:600px;width:100%;max-height:90vh;overflow-y:auto}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;border-bottom:1px solid #333}.modal-header h3{color:#e0e0e0;font-size:1.5rem;margin:0}.modal-close{background:none;border:none;color:#999;font-size:2rem;line-height:1;cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:background-color .2s,color .2s}.modal-close:hover{background:#333;color:#e0e0e0}.add-item-form{padding:1.5rem}.delete-modal{max-width:500px}.modal-body{padding:1.5rem}.modal-body p{color:#e0e0e0;font-size:1rem;margin:0 0 1.5rem}.delete-item-preview{background:#1a1a1a;border:1px solid #333;border-radius:8px;padding:1rem}.preview-row{display:flex;justify-content:space-between;align-items:center;padding:.5rem 0;color:#e0e0e0}.preview-row:not(:last-child){border-bottom:1px solid #333}.preview-label{color:#999;font-weight:500}.preview-amount{font-weight:600;font-size:1.1rem}.modal-footer{display:flex;gap:1rem;padding:1.5rem;border-top:1px solid #333;justify-content:flex-end}.cancel-btn{padding:.75rem 1.5rem;background:#333;color:#e0e0e0;border:1px solid #444;border-radius:6px;cursor:pointer;font-size:1rem;font-weight:500;transition:all .2s}.cancel-btn:hover{background:#3a3a3a;border-color:#555}.delete-btn{padding:.75rem 1.5rem;background:#dc3545;color:#fff;border:1px solid #c82333;border-radius:6px;cursor:pointer;font-size:1rem;font-weight:500;transition:all .2s}.delete-btn:hover{background:#c82333;border-color:#bd2130}.form-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;margin-bottom:1rem}.add-item-form .form-group{margin-bottom:1rem}.add-item-form label{display:block;margin-bottom:.5rem;color:#e0e0e0;font-weight:500;font-size:.9rem}.add-item-form input,.add-item-form select,.add-item-form textarea{width:100%;padding:.75rem;border:2px solid #333;border-radius:6px;font-size:1rem;font-family:inherit;background:#242424;color:#e0e0e0}.add-item-form input:focus,.add-item-form select:focus,.add-item-form textarea:focus{outline:none;border-color:#667eea}.add-item-form .total-display{background:#1a3a1a;font-weight:700;color:#4caf50;border-color:#2d5a2d}.add-item-form .submit-btn{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;padding:.75rem 2rem;border-radius:6px;font-weight:600;cursor:pointer;width:100%;margin-top:1rem}.add-item-form .submit-btn:disabled{opacity:.6;cursor:not-allowed}.line-items-table-container{overflow-x:auto}.line-items-table{width:100%;border-collapse:collapse;background:#242424}.line-items-table thead{background:#1a1a1a;border-bottom:2px solid #333}.line-items-table th{text-align:left;padding:1rem;color:#e0e0e0;font-weight:600;font-size:.9rem;text-transform:uppercase;letter-spacing:.5px}.line-items-table td{padding:1rem;border-bottom:1px solid #333;color:#e0e0e0}.line-items-table tbody tr:hover{background:#2a2a2a}.line-items-table tbody tr:last-child td{border-bottom:none}.item-type-badge{padding:.25rem .75rem;border-radius:20px;font-size:.8rem;font-weight:600;text-transform:capitalize;display:inline-block}.item-type-badge.labor{background-color:#e3f2fd;color:#1565c0}.item-type-badge.materials{background-color:#fff3e0;color:#e65100}.item-description{max-width:300px}.item-notes{color:#999;font-size:.85rem;margin-top:.25rem;font-style:italic}.number-cell{text-align:right;font-family:Courier New,monospace}.total-cell{text-align:right;font-weight:700;color:#4caf50;font-family:Courier New,monospace;font-size:1.05rem}.delete-btn-small{background:#e74c3c;color:#fff;border:none;width:32px;height:32px;border-radius:6px;font-size:1.5rem;line-height:1;cursor:pointer;transition:background-color .2s;display:flex;align-items:center;justify-content:center}.delete-btn-small:hover{background:#c0392b}.empty-line-items{text-align:center;padding:3rem;color:#999;background:#1a1a1a;border-radius:8px;border:2px dashed #333}.receipt-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000e6;display:flex;align-items:center;justify-content:center;z-index:1000;cursor:pointer}.receipt-modal-content{position:relative;display:flex;gap:20px;max-width:95vw;max-height:90vh;cursor:default}.receipt-modal-main{position:relative;flex:1;display:flex;align-items:center;justify-content:center}.receipt-modal-image{max-width:60vw;max-height:90vh;object-fit:contain;border-radius:8px}.receipt-modal-sidebar{width:350px;max-height:90vh;overflow-y:auto;background:#1a1a1a;border:2px solid #333;padding:20px;border-radius:8px;display:flex;flex-direction:column}.sidebar-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px;padding-bottom:8px;border-bottom:2px solid #333}.receipt-modal-sidebar h3{margin:0;color:#ecf0f1;font-size:1.1rem}.create-from-receipt-btn{background:#3498db;color:#fff;border:none;padding:8px 16px;border-radius:6px;cursor:pointer;font-size:.9rem;font-weight:600;transition:background-color .2s}.create-from-receipt-btn:hover{background:#2980b9}.back-to-view-btn{background:#7f8c8d;color:#fff;border:none;padding:8px 16px;border-radius:6px;cursor:pointer;font-size:.9rem;font-weight:600;transition:background-color .2s}.back-to-view-btn:hover{background:#6c7a7b}.linked-items-list{display:flex;flex-direction:column;gap:12px}.linked-item{background:#2a2a2a;padding:12px;border-radius:6px;border-left:3px solid #3498db;border:1px solid #333}.linked-item-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.linked-item-amount{font-weight:700;color:#2ecc71;font-size:1.1rem}.linked-item-description{color:#ecf0f1;margin-bottom:6px;font-size:.95rem}.linked-item-notes{color:#95a5a6;font-size:.85rem;font-style:italic;margin-bottom:6px}.linked-item-details{color:#bdc3c7;font-size:.85rem}.no-linked-items{color:#95a5a6;text-align:center;padding:2rem 1rem;font-style:italic}.receipt-modal-form{display:flex;flex-direction:column;gap:16px}.receipt-modal-form .form-group{display:flex;flex-direction:column;gap:6px}.receipt-modal-form label{color:#ecf0f1;font-size:.9rem;font-weight:600}.receipt-modal-form input,.receipt-modal-form select,.receipt-modal-form textarea{padding:10px;border:1px solid #333;border-radius:6px;background:#2a2a2a;color:#ecf0f1;font-size:.95rem}.receipt-modal-form input:focus,.receipt-modal-form select:focus,.receipt-modal-form textarea:focus{outline:none;border-color:#3498db;background:#333}.receipt-modal-form input:disabled{opacity:.6;cursor:not-allowed}.receipt-modal-form .submit-btn{margin-top:8px;background:#2ecc71;color:#fff;border:none;padding:12px;border-radius:6px;cursor:pointer;font-size:1rem;font-weight:600;transition:background-color .2s}.receipt-modal-form .submit-btn:hover:not(:disabled){background:#27ae60}.receipt-modal-form .submit-btn:disabled{opacity:.6;cursor:not-allowed}.receipt-modal-close{position:absolute;top:-40px;right:0;background:#e74c3c;color:#fff;border:none;width:40px;height:40px;border-radius:50%;font-size:28px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background-color .2s;line-height:1}.receipt-modal-close:hover{background:#c0392b}.receipt-modal-nav{position:absolute;top:50%;transform:translateY(-50%);background:#ffffffe6;color:#2c3e50;border:none;width:50px;height:50px;border-radius:50%;font-size:32px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background-color .2s;line-height:1;font-weight:700}.receipt-modal-nav:hover{background:#fff}.receipt-modal-prev{left:20px}.receipt-modal-next{right:20px}.receipt-modal-counter{position:absolute;bottom:-40px;left:50%;transform:translate(-50%);background:#ffffffe6;color:#2c3e50;padding:8px 16px;border-radius:20px;font-size:14px;font-weight:600}.receipt-cell{text-align:center;padding:8px}.receipt-thumbnail{width:40px;height:40px;border-radius:4px;overflow:hidden;cursor:pointer;border:2px solid #3498db;transition:transform .2s,border-color .2s;display:inline-block}.receipt-thumbnail:hover{transform:scale(1.1);border-color:#2980b9}.receipt-thumbnail img{width:100%;height:100%;object-fit:cover}.no-receipt{color:#7f8c8d;font-size:18px}.action-buttons{display:flex;gap:8px;justify-content:center}.edit-btn-small{background:#3498db;color:#fff;border:none;width:32px;height:32px;border-radius:6px;cursor:pointer;font-size:1.5rem;line-height:1;display:flex;align-items:center;justify-content:center;transition:background-color .2s}.edit-btn-small:hover{background:#2980b9}.modal-footer{display:flex;gap:12px;justify-content:flex-end;margin-top:20px}.modal-footer .cancel-btn{background:#7f8c8d;color:#fff;border:none;padding:12px 24px;border-radius:6px;cursor:pointer;font-size:14px;font-weight:600;transition:background-color .2s}.modal-footer .cancel-btn:hover{background:#6c7a7b}.create-job{max-width:600px;margin:0 auto}.create-job h1{color:#e0e0e0;margin-bottom:2rem}.job-form{background:#242424;padding:2rem;border-radius:12px;box-shadow:0 2px 8px #0000004d;border:1px solid #333}.form-group{margin-bottom:1.5rem}.form-group label{display:block;margin-bottom:.5rem;color:#e0e0e0;font-weight:500}.form-group input,.form-group textarea{width:100%;padding:.75rem;border:2px solid #333;border-radius:6px;font-size:1rem;font-family:inherit;transition:border-color .2s;background:#1a1a1a;color:#e0e0e0}.form-group input:focus,.form-group textarea:focus{outline:none;border-color:#667eea}.form-group textarea{resize:vertical}.form-actions{display:flex;gap:1rem;justify-content:flex-end;margin-top:2rem}.cancel-btn{padding:.75rem 1.5rem;background:#1a1a1a;color:#999;border:2px solid #333;border-radius:6px;font-size:1rem;font-weight:600;cursor:pointer;transition:border-color .2s,color .2s}.cancel-btn:hover{border-color:#666;color:#e0e0e0}.submit-btn{padding:.75rem 1.5rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:6px;font-size:1rem;font-weight:600;cursor:pointer;transition:transform .2s,box-shadow .2s}.submit-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px #667eea66}.submit-btn:disabled{opacity:.6;cursor:not-allowed}.error-message{background-color:#fee;color:#c33;padding:1rem;border-radius:6px;margin-bottom:1.5rem;border:1px solid #fcc}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-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:#1a1a1a;color:#e0e0e0}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}#root{min-height:100vh}
