.landing-page{min-height:100vh;background:linear-gradient(135deg,#1e3a8a,#475569);display:flex;align-items:center;justify-content:center;padding:2rem 1rem}.landing-container{max-width:1200px;width:100%;background:#fff;border-radius:20px;box-shadow:0 20px 60px #0000004d;overflow:hidden}.landing-header{background:#fff;color:#2c3e50;padding:3rem 2rem;text-align:center;border-bottom:3px solid #3b82f6}.logo-section .company-logo{max-width:350px;width:100%;height:auto;margin:0 auto 1rem;display:block;background:#fff;padding:1rem}.logo-section .company-name{font-size:3rem;font-weight:700;margin:0 0 .5rem;letter-spacing:-1px}.logo-section .tagline{font-size:1.25rem;color:#6c757d;margin:0;font-weight:400}.landing-main{padding:3rem 2rem}.hero-section{text-align:center;margin-bottom:3rem}.hero-section h2{font-size:2rem;color:#2c3e50;margin:0 0 1rem;font-weight:600}.hero-description{font-size:1.125rem;color:#6c757d;max-width:700px;margin:0 auto;line-height:1.6}.service-areas{margin-bottom:3rem}.service-areas h3{text-align:center;font-size:1.75rem;color:#2c3e50;margin:0 0 2rem}.areas-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.5rem;max-width:800px;margin:0 auto}.area-card{background:#f8f9fa;padding:2rem;border-radius:12px;text-align:center;border:2px solid #e9ecef;transition:all .3s ease}.area-card:hover{transform:translateY(-5px);box-shadow:0 10px 25px #0000001a;border-color:#3b82f6}.area-icon{font-size:2.5rem;display:block;margin-bottom:.75rem}.area-card h4{margin:0;color:#2c3e50;font-size:1.125rem;font-weight:600}.contact-section{margin-bottom:3rem;max-width:700px;margin-left:auto;margin-right:auto}.contact-section h3{text-align:center;font-size:1.75rem;color:#2c3e50;margin:0 0 .5rem}.contact-description{text-align:center;color:#6c757d;margin-bottom:2rem}.contact-form{background:#f8f9fa;padding:2rem;border-radius:12px;border:2px solid #e9ecef}.contact-form .form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-bottom:1rem}.contact-form .form-group{margin-bottom:1rem}.contact-form label{display:block;margin-bottom:.5rem;color:#495057;font-weight:500;font-size:.95rem}.contact-form input,.contact-form textarea{width:100%;padding:.75rem;border:1px solid #ced4da;border-radius:8px;font-size:1rem;font-family:inherit;transition:border-color .2s}.contact-form input:focus,.contact-form textarea:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.contact-form textarea{resize:vertical}.form-success{padding:1rem;background:#d4edda;border:1px solid #c3e6cb;border-radius:8px;color:#155724;margin-bottom:1rem;text-align:center;font-weight:500}.btn-submit{width:100%;margin-top:.5rem}.cta-section{max-width:600px;margin:0 auto}.cta-card{background:linear-gradient(135deg,#1e3a8a,#3b82f6);color:#fff;padding:2.5rem;border-radius:12px;text-align:center;box-shadow:0 10px 30px #1e3a8a4d}.cta-card h3{margin:0 0 .75rem;font-size:1.75rem;font-weight:600}.cta-card p{margin:0 0 1.5rem;font-size:1.05rem;opacity:.95}.btn-primary{background:#fff;color:#1e3a8a;border:none;padding:.875rem 2rem;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease}.btn-primary:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 10px 20px #0003}.btn-primary:disabled{opacity:.6;cursor:not-allowed}.btn-large{font-size:1.125rem;padding:1rem 2.5rem}.landing-footer{background:#f8f9fa;padding:2rem;text-align:center;border-top:1px solid #e9ecef;display:flex;flex-direction:column;gap:1rem;align-items:center}.landing-footer p{margin:0;color:#6c757d;font-size:.9rem}.footer-links{display:flex;gap:1.5rem;align-items:center;flex-wrap:wrap;justify-content:center}.admin-link{background:transparent;border:none;color:#6c757d;font-size:.875rem;cursor:pointer;padding:.5rem 1rem;transition:color .2s;text-decoration:underline}.admin-link:hover{color:#3b82f6}@media (max-width: 768px){.landing-page{padding:1rem}.logo-section .company-logo{max-width:250px}.logo-section .company-name{font-size:2rem}.logo-section .tagline{font-size:1rem}.hero-section h2{font-size:1.5rem}.hero-description{font-size:1rem}.areas-grid,.contact-form .form-row{grid-template-columns:1fr}.landing-main,.cta-card{padding:2rem 1.5rem}}.job-chat-container{display:flex;flex-direction:column;height:600px;background:#fff;border-radius:8px;overflow:hidden}.chat-header{padding:1.5rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border-bottom:1px solid #e0e0e0}.chat-header h3{margin:0 0 .5rem;font-size:1.25rem}.chat-subtitle{margin:0;font-size:.875rem;opacity:.9}.assigned-trades-list{margin-top:.75rem;padding-top:.75rem;border-top:1px solid rgba(255,255,255,.2);font-size:.85rem;opacity:.95}.assigned-trades-list strong{margin-right:.5rem}.chat-loading,.chat-empty{display:flex;align-items:center;justify-content:center;height:100%;color:#999;font-style:italic}.chat-messages{flex:1;overflow-y:auto;padding:1rem;background:#f5f5f5}.chat-message{margin-bottom:1rem;max-width:70%;animation:slideIn .2s ease-out}@keyframes slideIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.own-message{margin-left:auto}.other-message{margin-right:auto}.message-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.25rem;gap:.5rem}.message-sender{font-weight:600;font-size:.875rem;color:#333;display:flex;align-items:center;gap:.5rem}.admin-badge{display:inline-block;padding:.125rem .5rem;background:#667eea;color:#fff;border-radius:12px;font-size:.7rem;font-weight:500}.sending-badge{display:inline-block;padding:.125rem .5rem;background:#ffc107;color:#333;border-radius:12px;font-size:.7rem;font-weight:500;animation:pulse 1s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.6}}.chat-message.sending{opacity:.8}.chat-message.sending .message-content{background:#e8eaf6!important;color:#666!important}.edited-badge{display:inline-block;padding:.125rem .5rem;background:#e0e0e0;color:#666;border-radius:12px;font-size:.7rem;font-weight:400;font-style:italic}.message-actions{display:flex;gap:.25rem;margin-top:.25rem;opacity:0;transition:opacity .2s}.chat-message:hover .message-actions{opacity:1}.message-action-btn{padding:.25rem .5rem;background:#ffffffe6;border:1px solid #ddd;border-radius:4px;cursor:pointer;font-size:.85rem;transition:all .2s}.message-action-btn:hover{background:#f0f0f0;transform:scale(1.05)}.message-action-btn.delete:hover{background:#ffebee;border-color:#ef5350}.message-edit-form{margin-top:.5rem}.message-edit-input{width:100%;padding:.5rem;border:2px solid #667eea;border-radius:8px;font-size:.95rem;outline:none;margin-bottom:.5rem}.message-edit-actions{display:flex;gap:.5rem;justify-content:flex-end}.btn-save-edit,.btn-cancel-edit{padding:.375rem .75rem;border:none;border-radius:6px;font-size:.85rem;font-weight:500;cursor:pointer;transition:all .2s}.btn-save-edit{background:#28a745;color:#fff}.btn-save-edit:hover:not(:disabled){background:#218838}.btn-save-edit:disabled{opacity:.5;cursor:not-allowed}.btn-cancel-edit{background:#6c757d;color:#fff}.btn-cancel-edit:hover{background:#5a6268}.message-time{font-size:.75rem;color:#999}.message-content{padding:.75rem 1rem;border-radius:12px;word-wrap:break-word;white-space:pre-wrap;line-height:1.5}.own-message .message-content{background:#667eea;color:#fff;border-bottom-right-radius:4px}.other-message .message-content{background:#fff;color:#333;border:1px solid #e0e0e0;border-bottom-left-radius:4px}.chat-input-form{display:flex;gap:.5rem;padding:1rem;background:#fff;border-top:1px solid #e0e0e0}.chat-input{flex:1;padding:.75rem 1rem;border:1px solid #ddd;border-radius:24px;font-size:.95rem;outline:none;transition:border-color .2s}.chat-input:focus{border-color:#667eea}.chat-input:disabled{background:#f5f5f5;cursor:not-allowed}.chat-send-btn{padding:.75rem 1.5rem;background:#667eea;color:#fff;border:none;border-radius:24px;font-size:.95rem;font-weight:500;cursor:pointer;transition:all .2s;white-space:nowrap}.chat-send-btn:hover:not(:disabled){background:#5568d3;transform:translateY(-1px);box-shadow:0 2px 8px #667eea66}.chat-send-btn:disabled{opacity:.5;cursor:not-allowed;transform:none}.chat-messages::-webkit-scrollbar{width:8px}.chat-messages::-webkit-scrollbar-track{background:#f1f1f1}.chat-messages::-webkit-scrollbar-thumb{background:#ccc;border-radius:4px}.chat-messages::-webkit-scrollbar-thumb:hover{background:#999}.typing-indicator{display:flex;align-items:center;gap:.5rem;padding:.75rem 1rem;margin-bottom:.5rem;background:#fff;border-radius:12px;border:1px solid #e0e0e0;max-width:150px;animation:fadeIn .2s ease-out}.typing-dots{display:flex;gap:.25rem}.typing-dots span{width:8px;height:8px;background:#999;border-radius:50%;animation:bounce 1.4s infinite ease-in-out both}.typing-dots span:nth-child(1){animation-delay:-.32s}.typing-dots span:nth-child(2){animation-delay:-.16s}@keyframes bounce{0%,80%,to{transform:scale(0)}40%{transform:scale(1)}}.typing-text{font-size:.8rem;color:#999;font-style:italic}.mentions-popup{position:absolute;bottom:100%;left:0;right:0;background:#fff;border:1px solid #ddd;border-radius:8px;box-shadow:0 -4px 12px #00000026;max-height:200px;overflow-y:auto;margin-bottom:.5rem;z-index:1000}.mentions-header{padding:.5rem 1rem;font-size:.75rem;font-weight:600;color:#666;background:#f5f5f5;border-bottom:1px solid #e0e0e0}.mention-option{padding:.75rem 1rem;cursor:pointer;transition:background .2s;font-size:.9rem}.mention-option:hover{background:#f0f0f0}.mention-option strong{color:#667eea}.message-content .mention{background:#e3f2fd;color:#1976d2;padding:.125rem .25rem;border-radius:3px;font-weight:500}.chat-input-form{position:relative}.online-users-panel{background:#ffffff1a;border-radius:8px;padding:.75rem;min-width:180px;max-width:220px;margin-left:1rem}.online-users-header{display:flex;align-items:center;gap:.5rem;font-size:.85rem;font-weight:600;margin-bottom:.5rem;color:#fff}.online-indicator{width:8px;height:8px;background:#4caf50;border-radius:50%;animation:pulse-green 2s ease-in-out infinite}@keyframes pulse-green{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(1.1)}}.online-users-list{display:flex;flex-direction:column;gap:.5rem}.online-user{display:flex;align-items:center;gap:.5rem;padding:.375rem;background:#ffffff26;border-radius:6px;font-size:.8rem}.user-status-dot{width:6px;height:6px;background:#4caf50;border-radius:50%;flex-shrink:0}.user-name{flex:1;color:#fff;font-size:.85rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.user-type-badge{padding:.125rem .375rem;background:#ffffff40;border-radius:8px;font-size:.65rem;font-weight:500;color:#fff;white-space:nowrap}.board-container{padding:1rem;max-width:2000px;margin:0 auto}.board-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}.board-header h1{color:#2c3e50;margin:0}.board-columns{display:grid;grid-template-columns:repeat(5,1fr);gap:1.5rem;align-items:start}.board-column{background:#f8f9fa;border-radius:8px;padding:1rem;min-height:500px}.column-header{display:flex;align-items:center;gap:.75rem;margin-bottom:1rem;padding-bottom:.75rem;border-bottom:2px solid #e0e0e0}.column-header h2{font-size:1.1rem;margin:0;color:#2c3e50;flex:1}.column-badge{background:#95a5a6;color:#fff;padding:.25rem .75rem;border-radius:12px;font-size:.85rem;font-weight:700}.column-pending .column-badge{background:#95a5a6}.column-upcoming .column-badge{background:#3b82f6}.column-in-progress .column-badge{background:#17a2b8}.column-rts_required .column-badge{background:#ff9800}.column-completed .column-badge{background:#28a745}.job-cards{display:flex;flex-direction:column;gap:1rem}.job-card{background:#fff;border-radius:8px;padding:1rem;box-shadow:0 2px 4px #0000001a;cursor:pointer;transition:all .2s;border-left:4px solid #3b82f6}.job-card:hover{box-shadow:0 4px 8px #00000026;transform:translateY(-2px)}.job-card.dragging{opacity:.5}.job-card-header{display:flex;justify-content:space-between;align-items:start;margin-bottom:.75rem}.job-number{font-size:1.1rem;font-weight:700;color:#2c3e50;margin:0}.job-company{font-size:.85rem;color:#7f8c8d;background:#ecf0f1;padding:.25rem .5rem;border-radius:4px}.job-type{color:#555;font-size:.9rem;margin:.5rem 0}.job-trades{display:flex;flex-wrap:wrap;gap:.5rem;margin:.75rem 0}.trade-badge{background:#e3f2fd;color:#1976d2;padding:.25rem .5rem;border-radius:4px;font-size:.8rem;font-weight:500}.job-footer{display:flex;justify-content:space-between;align-items:center;margin-top:.75rem;padding-top:.75rem;border-top:1px solid #e0e0e0;font-size:.85rem;color:#7f8c8d}.job-date{display:flex;align-items:center;gap:.25rem}.empty-state{text-align:center;padding:2rem;color:#95a5a6}.modal-content{background:#fff;border-radius:8px;max-width:800px;width:100%;max-height:90vh;overflow-y:auto;box-shadow:0 4px 16px #0003}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;border-bottom:1px solid #e0e0e0}.modal-header h2{margin:0;color:#2c3e50}.close-button{background:none;border:none;font-size:1.5rem;cursor:pointer;color:#7f8c8d;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:background-color .2s}.close-button:hover{background-color:#ecf0f1}.modal-tabs{display:flex;border-bottom:2px solid #e0e0e0;background:#f8f9fa}.modal-tab{flex:1;padding:1rem 1.5rem;background:none;border:none;font-size:1rem;font-weight:500;color:#7f8c8d;cursor:pointer;transition:all .2s;border-bottom:3px solid transparent}.modal-tab:hover{background:#ecf0f1;color:#2c3e50}.modal-tab.active{color:#3b82f6;border-bottom-color:#3b82f6;background:#fff}.modal-body{padding:1.5rem}.modal-form{display:flex;flex-direction:column;gap:1.25rem}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.modal-footer{display:flex;gap:1rem;justify-content:flex-end;padding:1.5rem;border-top:1px solid #e0e0e0}.btn-danger{background-color:#e74c3c;color:#fff;padding:.75rem 1.5rem;border:none;border-radius:4px;cursor:pointer;font-size:1rem;transition:background-color .2s}.btn-danger:hover{background-color:#c0392b}.btn-danger:disabled{opacity:.6;cursor:not-allowed}@media (max-width: 1200px){.board-columns{grid-template-columns:1fr}.board-column{min-height:auto}}@media (max-width: 640px){.board-container{padding:1rem}.form-row{grid-template-columns:1fr}.modal-content{max-height:100vh;border-radius:0}}.cards-view-container{padding:2rem;max-width:1800px;margin:0 auto}.cards-view-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}.cards-view-header h1{color:#2c3e50;margin:0;display:flex;align-items:center;gap:.75rem}.status-badge-large{padding:.5rem 1rem;border-radius:20px;font-size:1rem;font-weight:700;color:#fff}.status-badge-large.pending{background:#f39c12}.status-badge-large.in-progress{background:#3498db}.status-badge-large.completed{background:#27ae60}.view-tabs{display:flex;gap:.5rem}.view-tab{padding:.75rem 1.5rem;border:2px solid #ddd;background:#fff;border-radius:8px;cursor:pointer;font-weight:500;transition:all .2s;color:#555}.view-tab:hover{border-color:#3498db;background:#f0f8ff}.view-tab.active{border-color:#3498db;background:#3498db;color:#fff}.playing-cards-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:2rem;margin-top:2rem}.playing-card{background:#fff;border-radius:12px;padding:1.5rem;box-shadow:0 4px 12px #00000026;cursor:pointer;transition:all .3s;border:3px solid #e0e0e0;min-height:380px;display:flex;flex-direction:column;position:relative;overflow:hidden}.playing-card:before{content:"";position:absolute;top:-2px;left:-2px;right:-2px;bottom:-2px;background:linear-gradient(135deg,#3498db1a,#9b59b61a);border-radius:12px;z-index:-1;opacity:0;transition:opacity .3s}.playing-card:hover{transform:translateY(-8px);box-shadow:0 8px 24px #0003;border-color:#3498db}.playing-card:hover:before{opacity:1}.card-corner-badge{position:absolute;top:1rem;right:1rem;background:#ecf0f1;color:#7f8c8d;padding:.35rem .75rem;border-radius:6px;font-size:.85rem;font-weight:600;border:2px solid #bdc3c7}.card-main-content{flex:1;display:flex;flex-direction:column;gap:1rem}.card-job-number{font-size:1.5rem;font-weight:700;color:#2c3e50;margin:0;padding-right:5rem;line-height:1.2}.card-divider{height:2px;background:linear-gradient(to right,#3498db,transparent);margin:.5rem 0}.card-job-type{color:#34495e;font-size:1.05rem;font-weight:500;line-height:1.4}.card-client-section{margin-top:.5rem;padding:.75rem;background:#f8f9fa;border-radius:8px;border-left:3px solid #3498db}.card-client-name{font-weight:600;color:#2c3e50;font-size:1.05rem;margin-bottom:.25rem}.card-client-details{font-size:.9rem;color:#7f8c8d;line-height:1.4}.card-trades-section{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:.75rem}.card-trade-badge{background:linear-gradient(135deg,#3b82f6,#1e3a8a);color:#fff;padding:.4rem .75rem;border-radius:6px;font-size:.85rem;font-weight:600;box-shadow:0 2px 4px #0000001a}.card-footer{display:flex;justify-content:space-between;align-items:center;margin-top:auto;padding-top:1rem;border-top:2px solid #e0e0e0}.card-date{display:flex;align-items:center;gap:.5rem;color:#7f8c8d;font-weight:500;font-size:.95rem}.card-date-icon{font-size:1.2rem}.card-status-indicator{width:12px;height:12px;border-radius:50%;border:2px solid #e0e0e0}.card-status-indicator.pending{background:#f39c12;box-shadow:0 0 8px #f39c1280}.card-status-indicator.in-progress{background:#3498db;box-shadow:0 0 8px #3498db80}.card-status-indicator.completed{background:#27ae60;box-shadow:0 0 8px #27ae6080}.empty-cards-state{text-align:center;padding:4rem 2rem;color:#95a5a6}.empty-cards-state h3{font-size:1.5rem;margin-bottom:1rem}.empty-cards-state p{font-size:1.1rem}@media (max-width: 1200px){.playing-cards-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.5rem}}@media (max-width: 768px){.cards-view-container{padding:1rem}.playing-cards-grid{grid-template-columns:1fr;gap:1rem}.playing-card{min-height:auto}.cards-view-header{flex-direction:column;gap:1rem;align-items:flex-start}.view-tabs{width:100%;flex-direction:column}.view-tab{width:100%}}.wizard-container{max-width:800px;margin:0 auto}.pdf-import-section{text-align:center;padding:1.5rem;background:#f0f8ff;border-radius:8px;margin-bottom:2rem;border:2px dashed #3498db}.pdf-import-section .helper-text{margin-bottom:1rem;color:#2c3e50;font-weight:500}.pdf-import-section .btn{cursor:pointer}.pdf-import-section .btn.disabled{opacity:.6;cursor:not-allowed}.wizard-progress{display:flex;align-items:center;justify-content:center;margin:2rem 0;gap:0}.wizard-progress .step{width:40px;height:40px;border-radius:50%;background-color:#e0e0e0;color:#666;display:flex;align-items:center;justify-content:center;font-weight:700;transition:all .3s}.wizard-progress .step.active{background-color:#3498db;color:#fff}.wizard-progress .line{width:60px;height:2px;background-color:#e0e0e0}.wizard-content{background:#fff;border-radius:8px;padding:2rem;box-shadow:0 2px 8px #0000001a;min-height:400px}.wizard-step h3{color:#2c3e50;margin-bottom:1.5rem;font-size:1.5rem}.helper-text{color:#666;font-size:.95rem;margin-bottom:1.5rem}.button-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;margin-bottom:2rem}.option-button{padding:1.5rem;border:2px solid #ddd;border-radius:8px;background:#fff;cursor:pointer;font-size:1rem;font-weight:500;transition:all .2s;color:#333}.option-button:hover{border-color:#3498db;background-color:#f0f8ff}.option-button.selected{border-color:#3498db;background-color:#3498db;color:#fff}.large-input{width:100%;padding:1rem;font-size:1.2rem;border:2px solid #ddd;border-radius:8px;text-align:center}.large-input:focus{outline:none;border-color:#3498db}.wizard-buttons{display:flex;gap:1rem;justify-content:space-between;margin-top:2rem}.btn-secondary{background-color:#95a5a6;color:#fff;padding:.75rem 1.5rem;border:none;border-radius:4px;cursor:pointer;font-size:1rem;transition:background-color .2s}.btn-secondary:hover{background-color:#7f8c8d}.summary-box{background:#f8f9fa;border-radius:8px;padding:1.5rem;margin-top:2rem;border-left:4px solid #3498db}.summary-box h4{margin-top:0;margin-bottom:1rem;color:#2c3e50}.summary-box p{margin:.5rem 0;color:#555}.checkbox-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:1rem;margin-bottom:2rem}.checkbox-option{display:flex;align-items:center;padding:1rem;border:2px solid #ddd;border-radius:8px;cursor:pointer;transition:all .2s;background:#fff}.checkbox-option:hover{border-color:#3498db;background-color:#f0f8ff}.checkbox-option input[type=checkbox]{width:20px;height:20px;margin-right:.75rem;cursor:pointer}.checkbox-option span{font-size:1rem;font-weight:500;color:#333;transition:color .2s}.checkbox-option span.checked{color:#3498db}.checkbox-option:has(input:checked){border-color:#3498db;background-color:#f0f8ff}.upload-area{text-align:center;padding:2rem;border:2px dashed #ddd;border-radius:8px;background-color:#f9f9f9;margin-bottom:1.5rem;transition:all .2s}.upload-area:hover{border-color:#3498db;background-color:#f0f8ff}.upload-area.dragging{border-color:#2980b9;background-color:#e3f2fd;border-style:solid;transform:scale(1.02)}.upload-button{display:inline-block;padding:1rem 2rem;background-color:#3498db;color:#fff;border-radius:4px;cursor:pointer;font-size:1rem;font-weight:500;transition:background-color .2s}.upload-button:hover{background-color:#2980b9}.upload-hint{margin-top:.75rem;color:#666;font-size:.9rem}.file-list{background:#f8f9fa;border-radius:8px;padding:1rem;margin-bottom:1.5rem}.file-list h4{margin-top:0;margin-bottom:1rem;color:#2c3e50;font-size:1rem}.file-item{display:flex;align-items:center;gap:.75rem;padding:.75rem;background:#fff;border-radius:4px;margin-bottom:.5rem}.file-item:last-child{margin-bottom:0}.file-name{flex:1;font-weight:500;color:#333}.file-size{color:#666;font-size:.9rem}.remove-file-btn{padding:.25rem .75rem;background-color:#e74c3c;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:.85rem;transition:background-color .2s}.remove-file-btn:hover{background-color:#c0392b}@media (max-width: 640px){.button-grid,.checkbox-grid{grid-template-columns:1fr}.wizard-progress .line{width:40px}.wizard-progress .step{width:35px;height:35px;font-size:.9rem}}.trades-container{padding:2rem;max-width:1800px;margin:0 auto}.trades-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}.trades-header h1{color:#2c3e50;margin:0}.trades-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.5rem}.trade-card{background:#fff;border-radius:12px;padding:1.5rem;box-shadow:0 4px 12px #0000001a;cursor:pointer;transition:all .3s;border:3px solid #e0e0e0;position:relative;min-height:200px}.trade-card:hover{transform:translateY(-4px);box-shadow:0 8px 20px #00000026;border-color:#9b59b6}.trade-type-badge{position:absolute;top:1rem;right:1rem;padding:.4rem .8rem;border-radius:20px;font-size:.8rem;font-weight:600;color:#fff}.trade-type-installer{background:linear-gradient(135deg,#3b82f6,#1e3a8a)}.trade-type-plumber{background:linear-gradient(135deg,#3498db,#2980b9)}.trade-type-electrician{background:linear-gradient(135deg,#f39c12,#e67e22)}.trade-type-tiler{background:linear-gradient(135deg,#e74c3c,#c0392b)}.trade-type-gyprocker{background:linear-gradient(135deg,#1abc9c,#16a085)}.trade-type-other{background:linear-gradient(135deg,#95a5a6,#7f8c8d)}.trade-name{font-size:1.5rem;font-weight:700;color:#2c3e50;margin:0 0 .5rem;padding-right:5rem}.trade-contact{display:flex;flex-direction:column;gap:.5rem;margin-top:1rem}.trade-contact-item{display:flex;align-items:center;gap:.5rem;color:#7f8c8d;font-size:.9rem}.trade-contact-item a{color:#3498db;text-decoration:none}.trade-contact-item a:hover{text-decoration:underline}.empty-trades{text-align:center;padding:4rem 2rem;color:#95a5a6}.empty-trades h3{font-size:1.5rem;margin-bottom:1rem}.trade-modal-form{display:flex;flex-direction:column;gap:1.25rem}.trade-type-selector{display:grid;grid-template-columns:repeat(3,1fr);gap:.75rem}.trade-type-option{padding:1rem;border:2px solid #ddd;border-radius:8px;background:#fff;cursor:pointer;text-align:center;font-weight:500;transition:all .2s;color:#555}.trade-type-option:hover{border-color:#9b59b6;background:#f8f4fc}.trade-type-option.selected{border-color:#9b59b6;background:#9b59b6;color:#fff}@media (max-width: 768px){.trades-grid,.trade-type-selector{grid-template-columns:1fr}}.card-editor-container{min-height:100vh;background:#f5f7fa;padding:2rem}.card-editor-header{margin-bottom:2rem}.card-editor-header h1{font-size:2rem;color:#2c3e50;margin-top:1rem}.btn-back{background:#fff;border:1px solid #ddd;padding:.75rem 1.5rem;border-radius:8px;cursor:pointer;font-size:1rem;color:#666;transition:all .2s}.btn-back:hover{background:#f8f9fa;border-color:#bbb}.editor-layout{display:grid;grid-template-columns:1fr 1fr;gap:2rem;max-width:1400px;margin:0 auto}.editor-form{background:#fff;padding:2rem;border-radius:12px;box-shadow:0 2px 8px #0000001a}.editor-form h2{margin-bottom:1.5rem;color:#2c3e50}.form-group{margin-bottom:1.5rem}.form-group label{display:block;margin-bottom:.5rem;font-weight:600;color:#555}.form-group input[type=text],.form-group input[type=url],.form-group textarea{width:100%;padding:.75rem;border:1px solid #ddd;border-radius:6px;font-size:1rem;font-family:inherit;transition:border-color .2s}.form-group input:focus,.form-group textarea:focus{outline:none;border-color:#3b82f6}.form-group textarea{resize:vertical}.form-group small{display:block;margin-top:.25rem;color:#888;font-size:.85rem}.logo-upload-section{display:flex;align-items:center;gap:1rem}.logo-preview{width:100px;height:100px;border-radius:8px;overflow:hidden;background:#f5f7fa;display:flex;align-items:center;justify-content:center}.logo-preview img{width:100%;height:100%;object-fit:cover}.btn-upload{display:inline-flex;align-items:center;padding:.75rem 1.5rem;background:#3b82f6;color:#fff;border-radius:6px;cursor:pointer;font-weight:500;transition:background .2s}.btn-upload:hover{background:#5568d3}.slug-input-wrapper{display:flex;align-items:center;border:1px solid #ddd;border-radius:6px;overflow:hidden;transition:border-color .2s}.slug-input-wrapper:focus-within{border-color:#3b82f6}.slug-prefix{padding:.75rem;background:#f5f7fa;color:#666;font-size:1rem;white-space:nowrap}.slug-input-wrapper input{border:none;padding:.75rem;flex:1;font-size:1rem}.slug-input-wrapper input:focus{outline:none}.color-picker{width:100px;height:50px;border:1px solid #ddd;border-radius:6px;cursor:pointer}.checkbox-label{display:flex;align-items:center;gap:.5rem;cursor:pointer;font-weight:400}.checkbox-label input[type=checkbox]{width:20px;height:20px;cursor:pointer}.form-actions{margin-top:2rem;padding-top:2rem;border-top:1px solid #eee}.btn-primary{width:100%;padding:1rem;background:#28a745;color:#fff;border:none;border-radius:8px;font-size:1.1rem;font-weight:600;cursor:pointer;transition:background .2s}.btn-primary:hover{background:#218838}.btn-primary:disabled{background:#ccc;cursor:not-allowed}.card-preview-section{position:sticky;top:2rem}.card-preview-section h2{margin-bottom:1.5rem;color:#2c3e50}.preview-card{background:#3b82f6;padding:2rem;border-radius:12px;color:#fff;box-shadow:0 8px 24px #00000026;text-align:center}.preview-logo{width:120px;height:120px;margin:0 auto 1.5rem;border-radius:50%;overflow:hidden;background:#fff;display:flex;align-items:center;justify-content:center}.preview-logo img{width:100%;height:100%;object-fit:cover}.preview-name{font-size:1.8rem;margin-bottom:.5rem;font-weight:700}.preview-trade-type{font-size:1.1rem;margin-bottom:1rem;opacity:.9}.preview-tagline{font-size:1rem;margin-bottom:1.5rem;opacity:.85;font-style:italic}.preview-contact{background:#fff3;padding:1rem;border-radius:8px;margin-bottom:1rem}.preview-contact-item{display:flex;align-items:center;justify-content:center;gap:.5rem;margin-bottom:.5rem;font-size:1rem}.preview-contact-item:last-child{margin-bottom:0}.preview-social{display:flex;justify-content:center;gap:1rem;font-size:1.5rem}.error-message{background:#f8d7da;color:#721c24;padding:1rem;border-radius:8px;margin-bottom:1rem}.success-message{background:#d4edda;color:#155724;padding:1rem;border-radius:8px;margin-bottom:1rem}@media (max-width: 768px){.editor-layout{grid-template-columns:1fr}.card-preview-section{position:static}}.public-card-container{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2rem;background:linear-gradient(135deg,#3b82f6,#1e3a8a)}.loading{color:#fff;font-size:1.2rem;text-align:center}.error-card{background:#fff;padding:3rem;border-radius:16px;text-align:center;box-shadow:0 10px 40px #0003;max-width:400px}.error-card h2{color:#e74c3c;margin-bottom:1rem}.error-card p{color:#666}.public-card{background:#fff;border-radius:20px;padding:3rem 2rem;max-width:500px;width:100%;box-shadow:0 20px 60px #0000004d;text-align:center;animation:slideUp .5s ease-out}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.card-logo{width:150px;height:150px;margin:0 auto 2rem;border-radius:50%;overflow:hidden;background:#f5f7fa;display:flex;align-items:center;justify-content:center;border:4px solid #3b82f6}.card-logo img{width:100%;height:100%;object-fit:cover}.card-name{font-size:2rem;color:#2c3e50;margin-bottom:.5rem;font-weight:700}.card-trade-type{font-size:1.2rem;color:#3b82f6;margin-bottom:.5rem;font-weight:600}.card-trading-name{font-size:1rem;color:#888;margin-bottom:1.5rem}.card-tagline{font-size:1rem;color:#666;font-style:italic;margin-bottom:2rem;padding:0 1rem}.card-contact-section{display:flex;flex-direction:column;gap:.75rem;margin-bottom:2rem}.contact-link{display:flex;align-items:center;justify-content:center;gap:.75rem;padding:1rem;border-radius:10px;text-decoration:none;font-size:1.1rem;font-weight:500;transition:all .2s}.contact-link.phone{background:#e8f5e9;color:#28a745}.contact-link.phone:hover{background:#c8e6c9;transform:translateY(-2px)}.contact-link.email{background:#e3f2fd;color:#007bff}.contact-link.email:hover{background:#bbdefb;transform:translateY(-2px)}.card-social-section{display:grid;grid-template-columns:repeat(2,1fr);gap:.75rem;margin-bottom:2rem}.social-link{display:flex;flex-direction:column;align-items:center;gap:.5rem;padding:1rem;background:#f5f7fa;border-radius:10px;text-decoration:none;color:#555;font-size:.9rem;font-weight:500;transition:all .2s}.social-link:hover{background:#e8ecef;transform:translateY(-2px)}.social-link span:first-child{font-size:1.5rem}.card-actions{display:flex;flex-direction:column;gap:1rem;margin-bottom:1.5rem}.btn-action{display:flex;align-items:center;justify-content:center;gap:.75rem;padding:1rem;border:none;border-radius:10px;font-size:1.1rem;font-weight:600;cursor:pointer;transition:all .2s}.btn-save-contact{background:#3b82f6;color:#fff}.btn-save-contact:hover{background:#5568d3;transform:translateY(-2px)}.btn-share{background:#f5f7fa;color:#555}.btn-share:hover{background:#e8ecef;transform:translateY(-2px)}.share-section{padding-top:1.5rem;border-top:2px solid #f0f0f0;animation:fadeIn .3s ease-out}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.qr-code{margin-bottom:1.5rem}.qr-code img{width:200px;height:200px;border-radius:10px;border:2px solid #ddd}.qr-code p{margin-top:.5rem;color:#888;font-size:.9rem}.share-buttons{display:grid;grid-template-columns:repeat(2,1fr);gap:.75rem}.share-btn{padding:.75rem;background:#f5f7fa;border:1px solid #ddd;border-radius:8px;font-size:.95rem;font-weight:500;cursor:pointer;transition:all .2s}.share-btn:hover{background:#e8ecef;border-color:#bbb;transform:translateY(-2px)}.card-footer{margin-top:2rem;text-align:center}.card-footer p{color:#fffc;font-size:.85rem}@media (max-width: 600px){.public-card{padding:2rem 1.5rem}.card-name{font-size:1.6rem}.card-trade-type{font-size:1rem}.card-social-section{grid-template-columns:1fr}.qr-code img{width:150px;height:150px}}.directory-container{min-height:100vh;background:linear-gradient(135deg,#f5f7fa,#e8ecf1)}.directory-hero{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:4rem 2rem;text-align:center}.directory-hero h1{font-size:3rem;margin:0 0 1rem;font-weight:800;text-shadow:0 2px 4px rgba(0,0,0,.2)}.hero-subtitle{font-size:1.2rem;opacity:.95;max-width:600px;margin:0 auto}.directory-controls{max-width:1400px;margin:0 auto;padding:2rem 2rem 1rem}.search-box{position:relative;margin-bottom:1.5rem}.search-icon{position:absolute;left:1rem;top:50%;transform:translateY(-50%);font-size:1.2rem;color:#999}.search-box input{width:100%;padding:1rem 1rem 1rem 3rem;font-size:1.1rem;border:2px solid #e0e0e0;border-radius:50px;background:#fff;box-shadow:0 2px 8px #00000014;transition:all .3s}.search-box input:focus{outline:none;border-color:#667eea;box-shadow:0 4px 12px #667eea26}.filter-tabs{display:flex;gap:.75rem;flex-wrap:wrap}.filter-tab{padding:.75rem 1.5rem;background:#fff;border:2px solid #e0e0e0;border-radius:25px;cursor:pointer;font-size:1rem;font-weight:600;color:#555;transition:all .3s;display:flex;align-items:center;gap:.5rem}.filter-tab:hover{border-color:#667eea;background:#f8f9fe;transform:translateY(-2px)}.filter-tab.active{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border-color:#667eea;box-shadow:0 4px 12px #667eea4d}.filter-tab .count{font-size:.85rem;opacity:.8}.results-info{max-width:1400px;margin:0 auto;padding:1rem 2rem;color:#666;font-weight:500}.directory-grid{max-width:1400px;margin:0 auto;padding:0 2rem 4rem;display:grid;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:2rem}.directory-card{background:#fff;border-radius:16px;padding:2rem;box-shadow:0 4px 12px #00000014;cursor:pointer;transition:all .3s;border-top:4px solid #3b82f6;position:relative;overflow:hidden}.directory-card:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,#667eea,#764ba2);opacity:0;transition:opacity .3s}.directory-card:hover{transform:translateY(-8px);box-shadow:0 12px 24px #00000026}.directory-card:hover:before{opacity:1}.featured-badge{position:absolute;top:1rem;right:1rem;background:linear-gradient(135deg,#f093fb,#f5576c);color:#fff;padding:.4rem .8rem;border-radius:20px;font-size:.75rem;font-weight:700;box-shadow:0 2px 8px #f5576c4d}.directory-card-logo{width:100px;height:100px;margin:0 auto 1.5rem;border-radius:50%;overflow:hidden;background:#f5f7fa;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 12px #0000001a}.directory-card-logo img{width:100%;height:100%;object-fit:cover}.directory-card-content{text-align:center}.directory-card-name{font-size:1.5rem;font-weight:700;color:#2c3e50;margin:0 0 .5rem}.directory-card-type{font-size:1rem;color:#667eea;font-weight:600;margin:0 0 1rem;text-transform:uppercase;letter-spacing:.5px}.directory-card-tagline{font-size:.95rem;color:#666;margin:0 0 1.5rem;line-height:1.5;font-style:italic;min-height:3em}.directory-card-contact{background:#f8f9fa;padding:1rem;border-radius:12px;margin-bottom:1rem}.contact-item{display:flex;align-items:center;justify-content:center;gap:.5rem;color:#555;font-size:.9rem;margin-bottom:.5rem}.contact-item:last-child{margin-bottom:0}.contact-item .truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:250px}.directory-card-social{display:flex;justify-content:center;gap:.75rem;margin-bottom:1.5rem;font-size:1.3rem}.directory-card-social span{width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:#f8f9fa;border-radius:50%;transition:all .3s;cursor:pointer}.directory-card-social span:hover{background:#667eea;transform:scale(1.1)}.view-card-btn{width:100%;padding:.75rem 1.5rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:25px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s;box-shadow:0 4px 12px #667eea4d}.view-card-btn:hover{transform:translateY(-2px);box-shadow:0 6px 16px #667eea66}.no-results{max-width:1400px;margin:0 auto;padding:4rem 2rem;text-align:center}.no-results p{font-size:1.2rem;color:#999}.loading{max-width:1400px;margin:0 auto;padding:4rem 2rem;text-align:center;font-size:1.2rem;color:#666}.error-message{max-width:1400px;margin:2rem auto;padding:1rem 2rem;background:#f8d7da;color:#721c24;border-radius:8px;text-align:center}.directory-footer{background:#fff;border-top:1px solid #e0e0e0;padding:3rem 2rem;margin-top:2rem}.footer-content{max-width:1400px;margin:0 auto;text-align:center}.footer-content h3{font-size:1.8rem;color:#2c3e50;margin:0 0 1rem}.footer-content p{font-size:1.1rem;color:#666;margin:0 0 1.5rem;max-width:600px;margin-left:auto;margin-right:auto}.footer-link{display:inline-block;padding:1rem 2rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;text-decoration:none;border-radius:25px;font-weight:600;font-size:1.1rem;transition:all .3s;box-shadow:0 4px 12px #667eea4d}.footer-link:hover{transform:translateY(-2px);box-shadow:0 6px 16px #667eea66}@media (max-width: 768px){.directory-hero h1{font-size:2rem}.hero-subtitle{font-size:1rem}.directory-grid{grid-template-columns:1fr;gap:1.5rem;padding:0 1rem 2rem}.directory-controls{padding:1.5rem 1rem 1rem}.filter-tabs{gap:.5rem}.filter-tab{padding:.6rem 1rem;font-size:.9rem}.results-info{padding:1rem;font-size:.9rem}.directory-card{padding:1.5rem}.directory-footer{padding:2rem 1rem}.footer-content h3{font-size:1.5rem}.footer-content p{font-size:1rem}}.trade-users-container{padding:2rem;max-width:1400px;margin:0 auto;min-height:100vh;background:#f5f7fa}.trade-users-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;gap:2rem}.trade-users-header h1{color:#2c3e50;margin:0 0 .5rem;font-size:2rem}.subtitle{color:#6c757d;margin:0;font-size:1rem}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.5rem;margin-bottom:2rem}.stat-card{background:#fff;padding:1.5rem;border-radius:12px;box-shadow:0 2px 8px #00000014;text-align:center}.stat-icon{font-size:2.5rem;margin-bottom:.5rem}.stat-value{font-size:2.5rem;font-weight:700;color:#3b82f6;margin-bottom:.25rem}.stat-label{font-size:.9rem;color:#6c757d;font-weight:500}.users-list{background:#fff;border-radius:12px;padding:2rem;box-shadow:0 2px 8px #00000014}.users-list h2{color:#2c3e50;margin:0 0 1.5rem;font-size:1.5rem}.users-table{display:flex;flex-direction:column;gap:1rem}.user-row{display:flex;justify-content:space-between;align-items:center;padding:1.25rem;background:#f8f9fa;border-radius:8px;transition:all .2s}.user-row:hover{background:#e9ecef;transform:translate(4px)}.user-info{flex:1}.user-trade{display:flex;align-items:center;gap:.75rem;margin-bottom:.5rem}.user-trade strong{font-size:1.1rem;color:#2c3e50}.trade-type{padding:.25rem .75rem;background:#667eea;color:#fff;border-radius:12px;font-size:.75rem;font-weight:600}.user-email{color:#6c757d;font-size:.95rem;margin-bottom:.5rem}.user-meta{display:flex;gap:1rem;align-items:center;font-size:.85rem}.role-badge{padding:.35rem .75rem;border-radius:12px;font-weight:600;font-size:.8rem}.role-badge.owner{background:gold;color:#8b6914}.role-badge.staff{background:#e3f2fd;color:#1976d2}.user-date{color:#999}.user-actions{display:flex;gap:.75rem}.btn-action{padding:.5rem 1rem;border:none;border-radius:6px;font-size:.85rem;font-weight:600;cursor:pointer;transition:all .2s;white-space:nowrap}.btn-reset{background:#3b82f6;color:#fff}.btn-reset:hover{background:#2563eb;transform:translateY(-2px)}.btn-delete{background:#fee;color:#c33;border:1px solid #fcc}.btn-delete:hover{background:#fcc;transform:translateY(-2px)}.btn-primary{padding:.75rem 1.5rem;background:#28a745;color:#fff;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s}.btn-primary:hover{background:#218838;transform:translateY(-2px)}.btn-primary:disabled{background:#ccc;cursor:not-allowed;transform:none}.btn-secondary{padding:.75rem 1.5rem;background:#fff;color:#6c757d;border:1px solid #ddd;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s}.btn-secondary:hover{background:#f8f9fa;border-color:#bbb}.empty-state{text-align:center;padding:3rem;color:#999}.empty-state p{font-size:1.1rem}.loading{text-align:center;padding:3rem;color:#6c757d;font-size:1.1rem}.error-message{background:#fee;color:#c33;padding:1rem;border-radius:8px;margin-bottom:1rem;border:1px solid #fcc}.success-message{background:#d4edda;color:#155724;padding:1rem;border-radius:8px;margin-bottom:1rem;border:1px solid #c3e6cb}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.modal-content{background:#fff;border-radius:12px;padding:2rem;max-width:500px;width:100%;max-height:90vh;overflow-y:auto;box-shadow:0 20px 60px #0000004d}.modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.modal-header h2{margin:0;color:#2c3e50;font-size:1.5rem}.modal-close{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 .2s}.modal-close:hover{background:#f8f9fa;color:#333}.form-group{margin-bottom:1.25rem}.form-group label{display:block;margin-bottom:.5rem;font-weight:600;color:#495057}.form-group input,.form-group select{width:100%;padding:.75rem;border:2px solid #e0e0e0;border-radius:6px;font-size:1rem;transition:border-color .2s}.form-group input:focus,.form-group select:focus{outline:none;border-color:#3b82f6}.form-group small{display:block;margin-top:.25rem;color:#6c757d;font-size:.85rem}.form-actions{display:flex;gap:1rem;margin-top:2rem}.form-actions button{flex:1}@media (max-width: 768px){.trade-users-header{flex-direction:column;align-items:flex-start}.trade-users-header>div:last-child{width:100%}.trade-users-header>div:last-child button{width:100%}.stats-grid{grid-template-columns:repeat(2,1fr)}.user-row{flex-direction:column;align-items:flex-start;gap:1rem}.user-actions{width:100%;flex-direction:column}.btn-action{width:100%}.form-actions{flex-direction:column}}.games-page{min-height:100vh;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;align-items:center;justify-content:center;padding:20px}.games-container{background:#fff;border-radius:15px;padding:30px;max-width:600px;width:100%;box-shadow:0 10px 40px #0000004d}.games-container h1{text-align:center;color:#667eea;margin-bottom:20px;font-size:2em}.maze-container{display:flex;flex-direction:column;gap:2px;background:#333;padding:2px;border-radius:10px;margin:0 auto 20px;width:fit-content;max-width:95%}.maze-row{display:flex;gap:2px;justify-content:center}.maze-cell{width:30px;height:30px;display:flex;align-items:center;justify-content:center;font-size:1.5em;transition:all .2s;flex-shrink:0}.maze-row:has(>:nth-child(20)) .maze-cell{width:20px;height:20px;font-size:1em}.maze-row:has(>:nth-child(25)) .maze-cell{width:18px;height:18px;font-size:.9em}.maze-cell.wall{background:#34495e}.maze-cell.path{background:#ecf0f1}.maze-cell.player{background:#3498db;border-radius:50%}.maze-cell.goal{background:#f39c12;border-radius:50%}.maze-cell.star{background:#ecf0f1}.maze-cell.treasure{background:#34495e;box-shadow:inset 0 0 5px #ffd70026;animation:treasure-hint 4s ease-in-out infinite}@keyframes treasure-hint{0%,to{box-shadow:inset 0 0 5px #ffd7001a}50%{box-shadow:inset 0 0 8px #ffd70040}}.maze-cell.treasure-found{background:linear-gradient(135deg,#f39c12,#e67e22);animation:treasureOpen .5s ease;box-shadow:0 0 15px #f39c1299}.maze-cell.transporter{background:linear-gradient(135deg,#9b59b6,#8e44ad);animation:pulse 2s ease-in-out infinite}@keyframes treasureOpen{0%{transform:scale(1);background:#34495e}50%{transform:scale(1.3);background:#f39c12}to{transform:scale(1);background:#e67e22}}@keyframes pulse{0%,to{opacity:.7;transform:scale(1)}50%{opacity:1;transform:scale(1.05)}}.confetti-container{position:fixed;top:0;left:0;width:100%;height:100%;pointer-events:none;z-index:9999;overflow:hidden}.confetti{position:absolute;width:10px;height:10px;top:-10px;opacity:0;animation:confetti-fall 3s linear forwards}@keyframes confetti-fall{0%{top:-10px;opacity:1;transform:translate(0) rotate(0)}25%{transform:translate(30px) rotate(180deg)}50%{transform:translate(-30px) rotate(360deg)}75%{transform:translate(20px) rotate(540deg)}to{top:110vh;opacity:.5;transform:translate(-20px) rotate(720deg)}}.confetti:nth-child(odd){border-radius:50%}.confetti:nth-child(2n){border-radius:0}.confetti:nth-child(3n){animation-timing-function:ease-in-out}.confetti:nth-child(5n){animation-timing-function:cubic-bezier(.68,-.55,.265,1.55)}.game-controls{display:flex;flex-direction:column;align-items:center;gap:10px;margin:20px auto;max-width:200px}.control-row{display:flex;gap:10px}.control-btn{background:#667eea;color:#fff;border:none;border-radius:12px;font-size:2em;padding:15px 20px;cursor:pointer;min-width:60px;min-height:60px;box-shadow:0 4px 6px #0003;transition:all .2s}.control-btn:active{background:#764ba2;transform:scale(.95);box-shadow:0 2px 3px #0003}.skip-btn,.scores-btn{padding:10px 20px;border:none;border-radius:8px;font-size:.9em;font-weight:700;cursor:pointer;box-shadow:0 3px 5px #0003;transition:all .2s}.skip-btn{background:#e74c3c;color:#fff}.skip-btn:active{background:#c0392b;transform:scale(.95)}.scores-btn{background:#667eea;color:#fff}.scores-btn:active{background:#764ba2;transform:scale(.95)}.modal-content h2{color:#667eea;margin-bottom:20px}.modal-content input{width:100%;padding:12px;font-size:1.1em;border:2px solid #667eea;border-radius:8px;margin:15px 0;font-family:inherit}.score-rank{font-weight:700;color:#667eea;margin-right:10px}@media (max-width: 600px){.games-container{padding:15px}.games-container h1{font-size:1.5em}.maze-cell{width:25px;height:25px;font-size:1.2em}.maze-row:has(>:nth-child(10)) .maze-cell{width:22px;height:22px;font-size:1.1em}.maze-row:has(>:nth-child(12)) .maze-cell{width:20px;height:20px;font-size:1em}.maze-row:has(>:nth-child(20)) .maze-cell{width:14px;height:14px;font-size:.8em}.maze-row:has(>:nth-child(25)) .maze-cell{width:12px;height:12px;font-size:.7em}.control-btn{font-size:1.5em;padding:12px 15px;min-width:50px;min-height:50px}.modal-content{padding:20px}}.snake-page{min-height:100vh;background:linear-gradient(135deg,#27ae60,#229954);display:flex;align-items:center;justify-content:center;padding:20px;overscroll-behavior:none;-webkit-overflow-scrolling:touch;touch-action:none;user-select:none;-webkit-user-select:none}.snake-container{background:#fff;border-radius:15px;padding:30px;max-width:600px;width:100%;box-shadow:0 10px 40px #0000004d}.snake-container h1{text-align:center;color:#27ae60;margin-bottom:20px;font-size:2em}.game-info{display:flex;justify-content:space-around;margin-bottom:20px;font-size:1.2em;font-weight:700;color:#333}.game-board{margin:0 auto 20px;-webkit-user-select:none;user-select:none;touch-action:none}.cell{transition:background-color .1s}.snake-head{position:relative}.snake-head:after{content:"👁️";position:absolute;font-size:8px;top:3px;left:3px}.game-message{text-align:center;font-size:1.3em;color:#2ecc71;font-weight:700;height:40px;line-height:40px;margin:10px 0;animation:bounce .5s ease}@keyframes bounce{0%,to{transform:scale(1)}50%{transform:scale(1.1)}}.game-controls{display:flex;flex-direction:column;align-items:center;gap:10px;margin:20px auto}.start-btn,.restart-btn{background:#27ae60;color:#fff;border:none;border-radius:12px;font-size:1.5em;padding:15px 40px;cursor:pointer;box-shadow:0 4px 6px #0003;transition:all .2s;font-weight:700}.start-btn:hover,.restart-btn:hover{transform:scale(1.05);box-shadow:0 6px 10px #0000004d}.start-btn:active,.restart-btn:active{background:#229954;transform:scale(.95);box-shadow:0 2px 3px #0003}.restart-btn{background:#e74c3c}.restart-btn:active{background:#c0392b}.game-instructions{text-align:center;color:#666;font-size:.9em;margin:15px 0}.game-buttons{display:flex;gap:10px;justify-content:center;margin-top:20px}.scores-btn{padding:10px 20px;border:none;border-radius:8px;font-size:.9em;font-weight:700;cursor:pointer;box-shadow:0 3px 5px #0003;transition:all .2s;background:#27ae60;color:#fff}.scores-btn:hover{transform:scale(1.05)}.scores-btn:active{background:#229954;transform:scale(.95)}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000c;display:flex;align-items:center;justify-content:center;z-index:1000}.modal-content{background:#fff;padding:30px;border-radius:15px;max-width:400px;width:90%;text-align:center}.modal-content h2{color:#27ae60;margin-bottom:20px}.modal-content input{width:100%;padding:12px;font-size:1.1em;border:2px solid #27ae60;border-radius:8px;margin:15px 0;font-family:inherit}.submit-btn,.close-btn{background:#2ecc71;color:#fff;border:none;border-radius:8px;font-size:1.1em;padding:12px 30px;cursor:pointer;margin:10px 5px;font-weight:700}.submit-btn:active{background:#27ae60;transform:scale(.95)}.close-btn{background:#95a5a6}.close-btn:active{background:#7f8c8d;transform:scale(.95)}.high-scores-list{margin-top:20px;text-align:left;max-height:400px;overflow:hidden;position:relative}.high-scores-list p{text-align:center;color:#666;margin-top:20px}.scores-scroll-container{animation:scroll 30s linear infinite}.scores-scroll-container:hover{animation-play-state:paused}@keyframes scroll{0%{transform:translateY(0)}to{transform:translateY(-50%)}}.score-item{padding:10px;margin:5px 0;background:#f8f9fa;border-radius:5px;display:flex;justify-content:space-between;transition:all .3s ease}.score-item:hover{transform:scale(1.02);background:#e9ecef}.score-item.first-place{background:linear-gradient(135deg,gold,#ffed4e);border:3px solid #ff8c00;box-shadow:0 0 20px #ffd70080;font-size:1.2em;font-weight:700;animation:pulse-glow 2s ease-in-out infinite;position:relative;z-index:10}@keyframes pulse-glow{0%,to{box-shadow:0 0 20px #ffd70080}50%{box-shadow:0 0 30px #ffd700cc}}.score-rank{font-weight:700;color:#27ae60;margin-right:10px}.first-place .score-rank{color:#8b4513}@media (max-width: 600px){.snake-container{padding:15px}.snake-container h1{font-size:1.5em}.game-board{transform:scale(.9)}.start-btn,.restart-btn{font-size:1.2em;padding:12px 30px}.modal-content{padding:20px}}.memory-page{min-height:100vh;background:linear-gradient(135deg,#667eea,#764ba2);padding:20px;display:flex;justify-content:center;align-items:flex-start;font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif}.memory-container{background:#fffffffa;border-radius:20px;padding:30px;box-shadow:0 10px 40px #0000004d;max-width:800px;width:100%;margin:20px}.difficulty-selection{text-align:center;padding:20px}.difficulty-selection h2{color:#764ba2;font-size:2em;margin-bottom:30px}.difficulty-buttons{display:flex;flex-direction:column;gap:20px;max-width:400px;margin:0 auto}.difficulty-btn{background:#fff;border:3px solid #667eea;border-radius:15px;padding:20px;cursor:pointer;transition:all .3s;box-shadow:0 4px 6px #0000001a}.difficulty-btn:hover{transform:translateY(-5px);box-shadow:0 8px 15px #0003}.difficulty-btn.easy-btn{border-color:#27ae60}.difficulty-btn.easy-btn:hover{background:linear-gradient(135deg,#27ae60,#2ecc71);color:#fff}.difficulty-btn.medium-btn{border-color:#f39c12}.difficulty-btn.medium-btn:hover{background:linear-gradient(135deg,#f39c12,#f1c40f);color:#fff}.difficulty-btn.hard-btn{border-color:#e74c3c}.difficulty-btn.hard-btn:hover{background:linear-gradient(135deg,#e74c3c,#c0392b);color:#fff}.difficulty-icon{font-size:3em;margin-bottom:10px}.difficulty-name{font-size:1.5em;font-weight:700;margin-bottom:5px}.difficulty-desc{font-size:.9em;opacity:.8}.view-scores-btn{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:10px;padding:12px 30px;font-size:1.1em;font-weight:700;cursor:pointer;transition:all .2s;box-shadow:0 4px 6px #0003}.view-scores-btn:hover{transform:scale(1.05);box-shadow:0 6px 12px #0000004d}.game-info{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:15px;border-radius:10px;display:flex;justify-content:space-around;flex-wrap:wrap;gap:10px;box-shadow:0 4px 6px #0000001a}.game-message{text-align:center;font-size:1.3em;font-weight:700;color:#764ba2;min-height:40px;display:flex;align-items:center;justify-content:center}.cards-grid{perspective:1000px}.memory-card{position:relative;cursor:pointer;transition:transform .2s}.memory-card:hover{transform:scale(1.05)}.memory-card.matched{cursor:default;opacity:.6}.memory-card.matched:hover{transform:none}.card-inner{position:relative;width:100%;height:100%;text-align:center;transition:transform .6s;transform-style:preserve-3d}.memory-card.flipped .card-inner{transform:rotateY(180deg)}.card-front,.card-back{position:absolute;width:100%;height:100%;backface-visibility:hidden;display:flex;align-items:center;justify-content:center;border-radius:10px;box-shadow:0 4px 8px #0003;font-size:2.5em}.card-front{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;font-weight:700;font-size:3em}.card-back{background:#fff;transform:rotateY(180deg);border:3px solid #764ba2}.memory-card.matched .card-back{background:linear-gradient(135deg,#2ecc71,#27ae60);border-color:#27ae60}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000b3;display:flex;justify-content:center;align-items:center;z-index:1000;padding:20px}.modal-content{background:#fff;border-radius:20px;padding:30px;max-width:500px;width:100%;max-height:90vh;overflow-y:auto;box-shadow:0 10px 40px #0000004d;animation:modalSlideIn .3s ease-out}@keyframes modalSlideIn{0%{transform:translateY(-50px);opacity:0}to{transform:translateY(0);opacity:1}}.modal-content h2{color:#764ba2;text-align:center;margin-bottom:20px}.modal-content input{width:100%;padding:10px;border:2px solid #764ba2;border-radius:8px;font-size:1em;box-sizing:border-box}.submit-btn,.close-btn{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:10px;padding:12px 30px;font-size:1em;font-weight:700;cursor:pointer;transition:all .2s;margin-top:10px;box-shadow:0 4px 6px #0003}.submit-btn:hover,.close-btn:hover{transform:scale(1.05);box-shadow:0 6px 12px #0000004d}.high-scores-list{margin-top:20px;max-height:400px;overflow-y:auto}.scores-scroll-container{display:flex;flex-direction:column;gap:10px}.score-item{display:flex;justify-content:space-between;padding:12px 15px;background:#f8f9fa;border-radius:8px;border-left:4px solid #764ba2;transition:all .2s}.score-item:hover{background:#e9ecef;transform:translate(5px)}.score-item.first-place{background:linear-gradient(135deg,#f39c12,#f1c40f);color:#fff;font-weight:700;border-left:4px solid #d68910;box-shadow:0 4px 8px #0003}.score-rank{font-weight:700;margin-right:8px}@media (max-width: 600px){.memory-container{padding:15px;margin:10px}.difficulty-selection h2{font-size:1.5em}.difficulty-buttons{max-width:100%}.difficulty-icon{font-size:2em}.difficulty-name{font-size:1.2em}.game-info{font-size:.85em;padding:10px}.card-front,.card-back{border-radius:8px}.modal-content{padding:20px}}.react-flow{direction:ltr}.react-flow__container{position:absolute;width:100%;height:100%;top:0;left:0}.react-flow__pane{z-index:1;cursor:-webkit-grab;cursor:grab}.react-flow__pane.selection{cursor:pointer}.react-flow__pane.dragging{cursor:-webkit-grabbing;cursor:grabbing}.react-flow__viewport{transform-origin:0 0;z-index:2;pointer-events:none}.react-flow__renderer{z-index:4}.react-flow__selection{z-index:6}.react-flow__nodesselection-rect:focus,.react-flow__nodesselection-rect:focus-visible{outline:none}.react-flow .react-flow__edges{pointer-events:none;overflow:visible}.react-flow__edge-path,.react-flow__connection-path{stroke:#b1b1b7;stroke-width:1;fill:none}.react-flow__edge{pointer-events:visibleStroke;cursor:pointer}.react-flow__edge.animated path{stroke-dasharray:5;-webkit-animation:dashdraw .5s linear infinite;animation:dashdraw .5s linear infinite}.react-flow__edge.animated path.react-flow__edge-interaction{stroke-dasharray:none;-webkit-animation:none;animation:none}.react-flow__edge.inactive{pointer-events:none}.react-flow__edge.selected,.react-flow__edge:focus,.react-flow__edge:focus-visible{outline:none}.react-flow__edge.selected .react-flow__edge-path,.react-flow__edge:focus .react-flow__edge-path,.react-flow__edge:focus-visible .react-flow__edge-path{stroke:#555}.react-flow__edge-textwrapper{pointer-events:all}.react-flow__edge-textbg{fill:#fff}.react-flow__edge .react-flow__edge-text{pointer-events:none;-webkit-user-select:none;-moz-user-select:none;user-select:none}.react-flow__connection{pointer-events:none}.react-flow__connection .animated{stroke-dasharray:5;-webkit-animation:dashdraw .5s linear infinite;animation:dashdraw .5s linear infinite}.react-flow__connectionline{z-index:1001}.react-flow__nodes{pointer-events:none;transform-origin:0 0}.react-flow__node{position:absolute;-webkit-user-select:none;-moz-user-select:none;user-select:none;pointer-events:all;transform-origin:0 0;box-sizing:border-box;cursor:-webkit-grab;cursor:grab}.react-flow__node.dragging{cursor:-webkit-grabbing;cursor:grabbing}.react-flow__nodesselection{z-index:3;transform-origin:left top;pointer-events:none}.react-flow__nodesselection-rect{position:absolute;pointer-events:all;cursor:-webkit-grab;cursor:grab}.react-flow__handle{position:absolute;pointer-events:none;min-width:5px;min-height:5px;width:6px;height:6px;background:#1a192b;border:1px solid white;border-radius:100%}.react-flow__handle.connectionindicator{pointer-events:all;cursor:crosshair}.react-flow__handle-bottom{top:auto;left:50%;bottom:-4px;transform:translate(-50%)}.react-flow__handle-top{left:50%;top:-4px;transform:translate(-50%)}.react-flow__handle-left{top:50%;left:-4px;transform:translateY(-50%)}.react-flow__handle-right{right:-4px;top:50%;transform:translateY(-50%)}.react-flow__edgeupdater{cursor:move;pointer-events:all}.react-flow__panel{position:absolute;z-index:5;margin:15px}.react-flow__panel.top{top:0}.react-flow__panel.bottom{bottom:0}.react-flow__panel.left{left:0}.react-flow__panel.right{right:0}.react-flow__panel.center{left:50%;transform:translate(-50%)}.react-flow__attribution{font-size:10px;background:#ffffff80;padding:2px 3px;margin:0}.react-flow__attribution a{text-decoration:none;color:#999}@-webkit-keyframes dashdraw{0%{stroke-dashoffset:10}}@keyframes dashdraw{0%{stroke-dashoffset:10}}.react-flow__edgelabel-renderer{position:absolute;width:100%;height:100%;pointer-events:none;-webkit-user-select:none;-moz-user-select:none;user-select:none}.react-flow__edge.updating .react-flow__edge-path{stroke:#777}.react-flow__edge-text{font-size:10px}.react-flow__node.selectable:focus,.react-flow__node.selectable:focus-visible{outline:none}.react-flow__node-default,.react-flow__node-input,.react-flow__node-output,.react-flow__node-group{padding:10px;border-radius:3px;width:150px;font-size:12px;color:#222;text-align:center;border-width:1px;border-style:solid;border-color:#1a192b;background-color:#fff}.react-flow__node-default.selectable:hover,.react-flow__node-input.selectable:hover,.react-flow__node-output.selectable:hover,.react-flow__node-group.selectable:hover{box-shadow:0 1px 4px 1px #00000014}.react-flow__node-default.selectable.selected,.react-flow__node-default.selectable:focus,.react-flow__node-default.selectable:focus-visible,.react-flow__node-input.selectable.selected,.react-flow__node-input.selectable:focus,.react-flow__node-input.selectable:focus-visible,.react-flow__node-output.selectable.selected,.react-flow__node-output.selectable:focus,.react-flow__node-output.selectable:focus-visible,.react-flow__node-group.selectable.selected,.react-flow__node-group.selectable:focus,.react-flow__node-group.selectable:focus-visible{box-shadow:0 0 0 .5px #1a192b}.react-flow__node-group{background-color:#f0f0f040}.react-flow__nodesselection-rect,.react-flow__selection{background:#0059dc14;border:1px dotted rgba(0,89,220,.8)}.react-flow__nodesselection-rect:focus,.react-flow__nodesselection-rect:focus-visible,.react-flow__selection:focus,.react-flow__selection:focus-visible{outline:none}.react-flow__controls{box-shadow:0 0 2px 1px #00000014}.react-flow__controls-button{border:none;background:#fefefe;border-bottom:1px solid #eee;box-sizing:content-box;display:flex;justify-content:center;align-items:center;width:16px;height:16px;cursor:pointer;-webkit-user-select:none;-moz-user-select:none;user-select:none;padding:5px}.react-flow__controls-button:hover{background:#f4f4f4}.react-flow__controls-button svg{width:100%;max-width:12px;max-height:12px}.react-flow__controls-button:disabled{pointer-events:none}.react-flow__controls-button:disabled svg{fill-opacity:.4}.react-flow__minimap{background-color:#fff}.react-flow__minimap svg{display:block}.react-flow__resize-control{position:absolute}.react-flow__resize-control.left,.react-flow__resize-control.right{cursor:ew-resize}.react-flow__resize-control.top,.react-flow__resize-control.bottom{cursor:ns-resize}.react-flow__resize-control.top.left,.react-flow__resize-control.bottom.right{cursor:nwse-resize}.react-flow__resize-control.bottom.left,.react-flow__resize-control.top.right{cursor:nesw-resize}.react-flow__resize-control.handle{width:4px;height:4px;border:1px solid #fff;border-radius:1px;background-color:#3367d9;transform:translate(-50%,-50%)}.react-flow__resize-control.handle.left{left:0;top:50%}.react-flow__resize-control.handle.right{left:100%;top:50%}.react-flow__resize-control.handle.top{left:50%;top:0}.react-flow__resize-control.handle.bottom{left:50%;top:100%}.react-flow__resize-control.handle.top.left,.react-flow__resize-control.handle.bottom.left{left:0}.react-flow__resize-control.handle.top.right,.react-flow__resize-control.handle.bottom.right{left:100%}.react-flow__resize-control.line{border-color:#3367d9;border-width:0;border-style:solid}.react-flow__resize-control.line.left,.react-flow__resize-control.line.right{width:1px;transform:translate(-50%);top:0;height:100%}.react-flow__resize-control.line.left{left:0;border-left-width:1px}.react-flow__resize-control.line.right{left:100%;border-right-width:1px}.react-flow__resize-control.line.top,.react-flow__resize-control.line.bottom{height:1px;transform:translateY(-50%);left:0;width:100%}.react-flow__resize-control.line.top{top:0;border-top-width:1px}.react-flow__resize-control.line.bottom{border-bottom-width:1px;top:100%}*{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:#f5f5f5}.app{min-height:100vh}.header{background-color:#2c3e50;color:#fff;padding:1rem 2rem;box-shadow:0 2px 4px #0000001a}.header-content{display:flex;align-items:center;justify-content:space-between;max-width:1400px;margin:0 auto}.header h1{font-size:1.5rem}.logout-btn{padding:.5rem 1rem;background:#dc3545;color:#fff;border:none;border-radius:6px;cursor:pointer;font-size:.9rem;font-weight:500;transition:background .2s}.logout-btn:hover{background:#c82333}.nav{display:flex;gap:1rem;margin-top:.5rem}.nav a{color:#fff;text-decoration:none;padding:.5rem 1rem;border-radius:4px;transition:background-color .2s}.nav a:hover{background-color:#ffffff1a}.nav a.active{background-color:#fff3}.container{max-width:1200px;margin:0 auto;padding:2rem}.card{background:#fff;border-radius:8px;padding:1.5rem;box-shadow:0 1px 3px #0000001a;margin-bottom:1rem}.form-group{margin-bottom:1rem}.form-group label{display:block;margin-bottom:.5rem;font-weight:500;color:#333}.form-group input,.form-group textarea,.form-group select{width:100%;padding:.75rem;border:1px solid #ddd;border-radius:4px;font-size:1rem}.form-group textarea{min-height:100px;resize:vertical}.btn{padding:.75rem 1.5rem;border:none;border-radius:4px;font-size:1rem;cursor:pointer;transition:background-color .2s}.btn-primary{background-color:#3b82f6;color:#fff}.btn-primary:hover{background-color:#1e3a8a}.btn-primary:disabled{background-color:#95a5a6;cursor:not-allowed}.jobs-grid{display:grid;gap:1rem}.job-card{background:#fff;border-radius:8px;padding:1.5rem;box-shadow:0 1px 3px #0000001a;border-left:4px solid #3b82f6}.job-card h3{margin-bottom:.5rem;color:#2c3e50}.job-card p{margin:.25rem 0;color:#666}.job-meta{display:flex;gap:1rem;margin-top:.5rem;font-size:.9rem}.status-badge{display:inline-block;padding:.25rem .75rem;border-radius:12px;font-size:.85rem;font-weight:500}.status-pending{background-color:#fff3cd;color:#856404}.status-in-progress{background-color:#d1ecf1;color:#0c5460}.status-completed{background-color:#d4edda;color:#155724}.error-message{background-color:#f8d7da;color:#721c24;padding:1rem;border-radius:4px;margin-bottom:1rem}.success-message{background-color:#d4edda;color:#155724;padding:1rem;border-radius:4px;margin-bottom:1rem}.loading{text-align:center;padding:2rem;color:#666}
