:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;display:flex;place-items:center;min-width:320px;min-height:100vh}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media (prefers-color-scheme: light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}.landing-container{min-height:100vh;width:100vw;display:grid;grid-template-columns:1fr 1fr;background:#fff}.landing-content{display:contents}.brand-section{padding:60px 40px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;display:flex;flex-direction:column;justify-content:center}.brand-title{font-size:2.5rem;font-weight:700;margin-bottom:10px;text-shadow:0 2px 4px rgba(0,0,0,.3)}.brand-subtitle{font-size:1.2rem;margin-bottom:20px;opacity:.9}.brand-description{font-size:1rem;line-height:1.6;opacity:.8}.form-section{padding:60px 40px}.form-toggle{display:flex;margin-bottom:30px;border-radius:8px;overflow:hidden;border:2px solid #e1e5e9}.toggle-btn{flex:1;padding:12px 20px;border:none;background:#fff;color:#6b7280;font-weight:500;cursor:pointer;transition:all .2s ease}.toggle-btn.active{background:#667eea;color:#fff}.toggle-btn:hover:not(.active){background:#f3f4f6}.auth-form{display:flex;flex-direction:column;gap:20px}.form-group label{margin-bottom:8px;font-weight:500;color:#374151}.form-group input{padding:12px 16px;border:2px solid #e1e5e9;border-radius:8px;font-size:1rem;transition:border-color .2s ease}.form-group input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.submit-btn{padding:14px 24px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:transform .2s ease;margin-top:10px}.submit-btn:hover{transform:translateY(-2px);box-shadow:0 4px 12px #667eea66}@media (max-width: 768px){.landing-content{grid-template-columns:1fr;max-width:400px}.brand-section{padding:40px 30px;text-align:center}.brand-title{font-size:2rem}.form-section{padding:40px 30px}}.dashboard-container{min-height:100vh;background:#f8fafc}.dashboard-header{background:#fff;padding:20px 40px;border-bottom:1px solid #e1e5e9;display:flex;justify-content:space-between;align-items:center;box-shadow:0 2px 4px #0000001a}.dashboard-header h1{color:#1f2937;margin:0}.logout-btn{padding:8px 16px;background:#ef4444;color:#fff;border:none;border-radius:6px;cursor:pointer;font-weight:500;transition:background-color .2s ease}.dashboard-main{padding:40px}.dashboard-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:30px;max-width:1200px;margin:0 auto}.dashboard-card{background:#fff;padding:30px;border-radius:12px;box-shadow:0 4px 6px #0000001a;transition:transform .2s ease,box-shadow .2s ease;cursor:pointer}.dashboard-card:hover{transform:translateY(-4px);box-shadow:0 8px 25px #00000026}.dashboard-card h3{color:#1f2937;margin-bottom:10px;font-size:1.5rem}.dashboard-card p{color:#6b7280;margin:0;line-height:1.6}.admin-dashboard{min-height:100vh;width:100vw;background-color:#f8fafc;font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;margin:0;padding:0}.dashboard-header{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:1.5rem 0;box-shadow:0 2px 10px #0000001a;width:100%;margin:0}.header-content{width:100%;padding:0 2rem;display:flex;justify-content:space-between;align-items:center;margin:0;max-width:none}.header-content h1{margin:0;font-size:1.8rem;font-weight:600}.user-info{display:flex;align-items:center;gap:1rem}.user-info span{font-size:.95rem;opacity:.9}.logout-btn{background:#fff3;color:#fff;border:1px solid rgba(255,255,255,.3);padding:.5rem 1rem;border-radius:6px;cursor:pointer;font-size:.9rem;transition:all .2s ease}.logout-btn:hover{background:#ffffff4d;transform:translateY(-1px)}.dashboard-main{width:100%;padding:2rem;margin:0;max-width:none}.dashboard-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.5rem;margin-bottom:3rem}.stat-card{background:#fff;padding:1.5rem;border-radius:12px;box-shadow:0 2px 8px #0000001a;text-align:center;border:1px solid #e2e8f0}.stat-card h3{margin:0 0 .5rem;color:#64748b;font-size:.9rem;font-weight:500;text-transform:uppercase;letter-spacing:.5px}.stat-number{font-size:2.5rem;font-weight:700;color:#1e293b;margin:0}.companies-section{margin-bottom:3rem}.companies-section h2{margin:0 0 1.5rem;color:#1e293b;font-size:1.5rem;font-weight:600}.no-companies{background:#fff;padding:3rem;border-radius:12px;text-align:center;color:#64748b;border:1px solid #e2e8f0}.companies-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:1.5rem}.company-card{background:#fff;padding:1.5rem;border-radius:12px;box-shadow:0 2px 8px #0000001a;border:1px solid #e2e8f0;transition:all .2s ease}.company-card:hover{transform:translateY(-2px);box-shadow:0 4px 16px #00000026}.company-info h3{margin:0 0 .5rem;color:#1e293b;font-size:1.2rem;font-weight:600}.company-email{color:#64748b;font-size:.9rem;margin:0 0 1rem}.company-stats{display:flex;justify-content:space-between;margin-bottom:1.5rem;font-size:.85rem}.user-count{color:#3b82f6;font-weight:500}.last-active{color:#64748b}.company-actions{display:flex;gap:.5rem}.dashboard-btn{flex:1;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;padding:.75rem 1rem;border-radius:8px;cursor:pointer;font-size:.9rem;font-weight:500;transition:all .2s ease}.dashboard-btn:hover{transform:translateY(-1px);box-shadow:0 4px 12px #667eea66}.admin-tools{margin-top:3rem}.admin-tools h2{margin:0 0 1.5rem;color:#1e293b;font-size:1.5rem;font-weight:600}.tools-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem}.tool-btn{background:#fff;border:1px solid #e2e8f0;padding:1.5rem;border-radius:12px;cursor:pointer;display:flex;flex-direction:column;align-items:center;gap:.5rem;transition:all .2s ease;text-decoration:none;color:#64748b}.tool-btn:hover{border-color:#3b82f6;color:#3b82f6;transform:translateY(-2px);box-shadow:0 4px 12px #3b82f626}.tool-btn.featured{background:linear-gradient(135deg,#3b82f6,#1d4ed8);color:#fff;border-color:#3b82f6;box-shadow:0 2px 8px #3b82f64d}.tool-btn.featured:hover{color:#fff;transform:translateY(-2px);box-shadow:0 6px 16px #3b82f666}.tool-icon{font-size:2rem}.tool-btn span:last-child{font-weight:500;font-size:.9rem}.requests-section{margin-top:3rem}.requests-section h2{color:#1e293b;margin-bottom:1.5rem;font-size:1.5rem;font-weight:600}.requests-table{background:#fff;border-radius:12px;box-shadow:0 2px 12px #0000001a;overflow:hidden}.requests-table table{width:100%;border-collapse:collapse}.requests-table th{background:#f8fafc;color:#374151;padding:1rem;text-align:left;font-weight:600;font-size:.9rem;text-transform:uppercase;letter-spacing:.5px;border-bottom:2px solid #e5e7eb}.requests-table td{padding:1rem;border-bottom:1px solid #f3f4f6;vertical-align:top;color:#374151}.requests-table tr:hover{background:#f9fafb}.current-company{display:inline-block;padding:.25rem .75rem;background:#fef3c7;color:#92400e;border-radius:20px;font-size:.8rem;font-weight:500}.requested-company{display:inline-block;padding:.25rem .75rem;background:#dbeafe;color:#1e40af;border-radius:20px;font-size:.8rem;font-weight:500}.request-message{max-width:200px;display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:#6b7280;font-style:italic}.request-actions{display:flex;gap:.5rem;flex-wrap:wrap}.approve-request-btn{background:#10b981;color:#fff;border:none;padding:.5rem 1rem;border-radius:6px;cursor:pointer;font-size:.85rem;font-weight:500;transition:all .2s ease;white-space:nowrap}.approve-request-btn:hover{background:#059669;transform:translateY(-1px)}.reject-request-btn{background:#ef4444;color:#fff;border:none;padding:.5rem 1rem;border-radius:6px;cursor:pointer;font-size:.85rem;font-weight:500;transition:all .2s ease;white-space:nowrap}.reject-request-btn:hover{background:#dc2626;transform:translateY(-1px)}@media (max-width: 768px){.header-content{flex-direction:column;gap:1rem;text-align:center}.dashboard-main{padding:1rem}.companies-grid{grid-template-columns:1fr}.tools-grid{grid-template-columns:repeat(2,1fr)}.requests-table{overflow-x:auto}.request-actions{flex-direction:column}.request-message{max-width:150px}}.company-dashboard{min-height:100vh;width:100vw;background-color:#f5f5f5;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;margin:0;padding:0}.company-header{background:#fff;padding:1rem 2rem;display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid #e0e0e0;width:100%;box-sizing:border-box}.company-brand{display:flex;align-items:center}.company-nav{display:flex;align-items:center;gap:.5rem}.company-main{width:100%;padding:2rem;box-sizing:border-box}.search-filters{background:#fff;padding:1.5rem;border-radius:8px;margin-bottom:2rem;box-shadow:0 1px 3px #0000001a}.search-section{margin-bottom:1.5rem}.company-dashboard .search-input{width:100%!important;max-width:400px!important;padding:.75rem 1rem!important;border:1px solid #d1d5db!important;border-radius:8px!important;font-size:1rem!important;transition:border-color .2s ease!important;box-sizing:border-box!important;background:#fff!important;color:#374151!important}.company-dashboard .search-input:focus{outline:none!important;border-color:#667eea!important;box-shadow:0 0 0 3px #667eea1a!important}.filters-section{display:flex;align-items:end;gap:1.5rem;flex-wrap:wrap}.filter-group{display:flex;flex-direction:column;gap:.5rem}.filter-group label{font-size:.9rem;color:#666;font-weight:500}.company-dashboard .filter-select{padding:12px 40px 12px 16px!important;border:2px solid #e1e5e9!important;border-radius:8px!important;font-size:1rem!important;background:#fff!important;background-image:url("data:image/svg+xml;charset=UTF-8,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23374151' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3e%3cpolyline points='6,9 12,15 18,9'%3e%3c/polyline%3e%3c/svg%3e")!important;background-repeat:no-repeat!important;background-position:right 12px center!important;background-size:20px!important;color:#374151!important;min-width:150px!important;transition:border-color .2s ease!important;appearance:none!important;-webkit-appearance:none!important;-moz-appearance:none!important;cursor:pointer!important}.company-dashboard .filter-select:focus{outline:none!important;border-color:#667eea!important;box-shadow:0 0 0 3px #667eea1a!important}.company-dashboard .filter-select:hover{border-color:#9ca3af!important}.company-dashboard .filter-select option{background:#fff!important;color:#374151!important;padding:8px!important}.company-dashboard .clear-filters{background:#6b7280!important;color:#fff!important;border:none!important;padding:.75rem 1rem!important;border-radius:8px!important;cursor:pointer!important;font-size:.9rem!important;transition:all .2s ease!important;text-decoration:none!important}.company-dashboard .clear-filters:hover{background:#4b5563!important}.procedures-list{display:flex;flex-direction:column;gap:1rem}.procedure-card{background:#fff;border-radius:8px;padding:1.5rem;box-shadow:0 1px 3px #0000001a;transition:box-shadow .2s ease}.procedure-card:hover{box-shadow:0 4px 12px #00000026}.procedure-content{display:flex;align-items:center;gap:1.5rem}.procedure-image{flex-shrink:0;width:120px;height:80px;border-radius:6px;overflow:hidden;background:#f5f5f5}.procedure-image img{width:100%;height:100%;object-fit:cover}.placeholder-image{width:100%;height:100%;background:#f0f0f0;display:flex;align-items:center;justify-content:center;border-radius:6px}.placeholder-icon{font-size:2rem;color:#999}.procedure-info{flex:1}.procedure-title{font-size:1.3rem;font-weight:600;color:#333;margin:0 0 .5rem}.procedure-summary{color:#666;margin:0;line-height:1.5;font-size:.95rem}.procedure-actions{flex-shrink:0}.open-btn{padding:.75rem 1.5rem;background:#666;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:.9rem;transition:background-color .2s ease}.open-btn:hover{background:#555}.no-procedures{text-align:center;padding:3rem;color:#666;background:#fff;border-radius:8px;box-shadow:0 1px 3px #0000001a}@media (max-width: 768px){.company-header{flex-direction:column;gap:1rem;padding:1rem}.company-main{padding:1rem}.filters-section{flex-direction:column;align-items:stretch}.filter-group{width:100%}.filter-select{min-width:100%}.procedure-content{flex-direction:column;text-align:center}.procedure-image{width:100%;max-width:200px;height:120px}}.tank-data{min-height:100vh;width:100vw;background-color:#f8fafc;font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;margin:0;padding:0}.tank-header{background:#fff;padding:1rem 2rem;display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid #e0e0e0;width:100%;box-sizing:border-box}.tank-brand{display:flex;align-items:center}.logo-circle{width:40px;height:40px;background:linear-gradient(135deg,#333,#666);border-radius:50%;position:relative}.logo-circle:before{content:"";position:absolute;top:50%;left:50%;width:20px;height:20px;background:#fff;border-radius:50%;transform:translate(-50%,-50%)}.company-name{font-size:1.5rem;font-weight:600;color:#333}.tank-nav{display:flex;align-items:center;gap:.5rem}.nav-btn{padding:.5rem 1rem;border:2px solid #e1e5e9;background:#fff;color:#6b7280;border-radius:20px;cursor:pointer;font-size:.9rem;font-weight:500;transition:all .2s ease}.nav-btn.active{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border-color:#667eea;box-shadow:0 2px 8px #667eea4d}.nav-btn:hover:not(.active){background:#f8fafc;border-color:#9ca3af;color:#374151}.tank-main{width:100%;padding:2rem;box-sizing:border-box}.tank-controls{background:#fff;padding:1.5rem;border-radius:12px;margin-bottom:2rem;display:flex;justify-content:space-between;align-items:end;flex-wrap:wrap;gap:1rem;box-shadow:0 2px 8px #0000000d;border:1px solid #e5e7eb}.tank-selector{display:flex;flex-direction:column;gap:.5rem}.tank-selector label{font-size:.9rem;color:#374151;font-weight:600}.tank-select{padding:12px 40px 12px 16px;border:2px solid #e1e5e9;border-radius:8px;font-size:1rem;background:#fff;background-image:url("data:image/svg+xml;charset=UTF-8,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23374151' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3e%3cpolyline points='6,9 12,15 18,9'%3e%3c/polyline%3e%3c/svg%3e");background-repeat:no-repeat;background-position:right 12px center;background-size:20px;color:#374151;min-width:200px;transition:border-color .2s ease;appearance:none;-webkit-appearance:none;-moz-appearance:none;cursor:pointer}.tank-select:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.tank-select:hover{border-color:#9ca3af}.tank-select option{background:#fff;color:#374151;padding:8px}.action-buttons{display:flex;gap:1rem}.action-btn{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;padding:.875rem 1.5rem;border-radius:8px;cursor:pointer;font-size:1rem;font-weight:600;transition:all .2s ease;box-shadow:0 2px 8px #667eea4d}.action-btn:hover{transform:translateY(-1px);box-shadow:0 4px 12px #667eea66}.tank-title{text-align:center;margin-bottom:2rem}.tank-title h1{font-size:2.5rem;color:#1e293b;margin:0;font-weight:600}.tank-data-grid{display:grid;grid-template-columns:1fr 1fr;gap:2rem}.data-section{background:#fff;border-radius:12px;padding:1.5rem;box-shadow:0 2px 8px #0000001a;border:1px solid #e2e8f0}.data-section h2{margin:0 0 1.5rem;font-size:1.5rem;color:#1e293b;font-weight:600}.data-table th{background:#374151;color:#fff;padding:1rem;text-align:left;font-size:.9rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.data-table th:first-child{border-radius:8px 0 0}.data-table th:last-child{border-radius:0 8px 0 0}.data-table td{padding:1rem;border-bottom:1px solid #f3f4f6;font-size:.9rem;color:#374151}.load-data-cards{display:flex;flex-direction:column;gap:1rem}.load-card{border:2px solid #e1e5e9;border-radius:12px;overflow:hidden;box-shadow:0 2px 8px #0000000d;transition:box-shadow .2s ease}.load-card:hover{box-shadow:0 4px 12px #0000001a}.load-card-header{display:grid;grid-template-columns:1fr 1fr 1fr;background:#f8fafc;border-bottom:2px solid #e5e7eb}.load-card-header span{padding:1rem;font-size:.9rem;font-weight:600;color:#374151;text-align:center;text-transform:uppercase;letter-spacing:.5px;border-right:1px solid #e5e7eb}.load-card-header span:last-child{border-right:none}.load-card-content{display:grid;grid-template-columns:1fr 1fr 1fr;background:#fff}.load-card-content span{padding:1rem .75rem;font-size:1.1rem;font-weight:600;color:#1e293b;text-align:center;border-right:1px solid #e5e7eb}.load-card-content span:last-child{border-right:none}.no-data{text-align:center;padding:2rem;color:#6b7280;font-style:italic;font-size:1rem}.action-btn:disabled{background:#9ca3af;cursor:not-allowed;transform:none;box-shadow:none}.action-btn:disabled:hover{background:#9ca3af;transform:none;box-shadow:none}.modal-content{background:#fff;border-radius:12px;box-shadow:0 4px 24px #00000026;width:100%;max-width:600px;margin:1rem;max-height:90vh;overflow-y:auto}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem 1.5rem 0;border-bottom:2px solid #e5e7eb;margin-bottom:1.5rem}.modal-header h3{margin:0;color:#1e293b;font-size:1.25rem;font-weight:600}.modal-close{background:none;border:none;font-size:1.5rem;color:#6b7280;cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:all .2s ease}.modal-footer{display:flex;gap:1rem;justify-content:flex-end;padding:1.5rem;border-top:2px solid #e5e7eb;margin-top:1.5rem}.form-input,.form-select,.form-textarea{width:100%;padding:12px 16px;border:2px solid #e1e5e9;border-radius:8px;font-size:1rem;background:#fff;color:#374151;transition:border-color .2s ease;box-sizing:border-box}.form-select{background-image:url("data:image/svg+xml;charset=UTF-8,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23374151' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3e%3cpolyline points='6,9 12,15 18,9'%3e%3c/polyline%3e%3c/svg%3e");background-repeat:no-repeat;background-position:right 12px center;background-size:20px;padding-right:40px;appearance:none;-webkit-appearance:none;-moz-appearance:none;cursor:pointer}.form-textarea{resize:vertical;min-height:80px;font-family:inherit}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-bottom:1rem}.checkbox-label{display:flex;align-items:center;gap:.5rem;cursor:pointer;font-weight:500}.checkbox-label input[type=checkbox]{width:auto;margin:0;cursor:pointer}.cancel-btn{background:#6b7280;color:#fff;border:none;padding:.875rem 1.5rem;border-radius:8px;cursor:pointer;font-size:1rem;font-weight:600;transition:all .2s ease}.cancel-btn:hover{background:#4b5563;transform:translateY(-1px)}.checkbox-label{display:flex;align-items:center;gap:.5rem;font-weight:500;color:#374151;cursor:pointer;padding:.5rem 0}.checkbox-label input[type=checkbox]{width:18px;height:18px;border:2px solid #d1d5db;border-radius:4px;background:#fff;cursor:pointer;position:relative;appearance:none;-webkit-appearance:none;-moz-appearance:none;transition:all .2s ease}.checkbox-label input[type=checkbox]:checked{background:#3b82f6;border-color:#3b82f6}.checkbox-label input[type=checkbox]:checked:after{content:"✓";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);color:#fff;font-size:12px;font-weight:700}.checkbox-label input[type=checkbox]:hover{border-color:#3b82f6}.checkbox-label input[type=checkbox]:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.form-section{background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;padding:1.5rem;margin-bottom:1rem}.form-section h4{margin:0 0 1rem;display:flex;align-items:center;gap:.5rem}.arrival-pending{background:#fef3c7!important;border:2px dashed #f59e0b!important;display:flex;align-items:center;justify-content:center;min-height:120px}.arrival-button-container{text-align:center}.arrival-button-container p{margin:0 0 1rem;color:#92400e;font-weight:500;font-size:.875rem}.arrival-btn{background:#f59e0b;color:#fff;border:none;padding:.75rem 1.5rem;border-radius:8px;font-weight:600;cursor:pointer;transition:all .2s ease;font-size:.875rem}.arrival-btn:hover{background:#d97706;transform:translateY(-1px)}.venting-warning{background:#fecaca;border:1px solid #f87171;border-radius:6px;padding:.75rem;margin-top:.5rem;color:#991b1b;font-size:.875rem;font-weight:600;text-align:center;animation:pulse 2s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.8}}.load-history-section{grid-column:1 / -1;margin-top:2rem}.load-history-list{display:flex;flex-direction:column;gap:1rem}.load-history-item{border:2px solid #e2e8f0;border-radius:12px;background:#fff;transition:all .3s ease;overflow:hidden}.load-history-item:hover{border-color:#cbd5e1;box-shadow:0 4px 12px #0000001a}.load-history-item.expanded{border-color:#667eea;box-shadow:0 4px 16px #667eea33}.load-history-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.5rem;cursor:pointer;transition:background-color .2s ease}.load-history-header:hover{background:#f8fafc}.load-history-summary{display:flex;align-items:center;gap:1rem;flex-wrap:wrap}.load-date{font-weight:600;color:#1e293b;font-size:1rem}.load-status{padding:.25rem .75rem;border-radius:20px;font-size:.875rem;font-weight:500;background:#dcfce7;color:#166534}.load-status.completed{background:#dcfce7;color:#166534}.load-status.in-transit{background:#fef3c7;color:#92400e}.venting-indicator{padding:.25rem .75rem;border-radius:20px;font-size:.875rem;font-weight:600;background:#fecaca;color:#991b1b;animation:pulse 2s infinite}.pressure-gain{font-weight:600;color:#374151;font-size:.875rem}.expand-icon{color:#6b7280;font-size:1.2rem;transition:transform .2s ease}.load-history-item.expanded .expand-icon{transform:rotate(0)}.load-history-details{padding:0 1.5rem 1.5rem;border-top:1px solid #e5e7eb;background:#f8fafc}.load-metrics-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;margin-bottom:1.5rem}.metric-card{background:#fff;border:1px solid #e5e7eb;border-radius:8px;padding:1rem;text-align:center}.metric-label{font-size:.875rem;color:#6b7280;font-weight:500;margin-bottom:.5rem;text-transform:uppercase;letter-spacing:.5px}.metric-value{font-size:1.1rem;font-weight:600;color:#1e293b;margin-bottom:.25rem}.metric-sub{font-size:.75rem;color:#9ca3af;font-weight:500}.vacuum-readings-during-load{margin-top:1.5rem}.vacuum-readings-during-load h4{margin:0 0 .5rem;color:#374151;font-size:1rem;font-weight:600;display:flex;align-items:center;gap:.5rem}.reading-count{font-size:.875rem;color:#6b7280;font-weight:500}.transport-period{margin:0 0 1rem;font-size:.875rem;color:#6b7280;font-style:italic;padding:.5rem;background:#f1f5f9;border-radius:6px;border-left:3px solid #667eea}.vacuum-readings-table{background:#fff;border-radius:8px;overflow:hidden;border:1px solid #e5e7eb}.vacuum-readings-table table{width:100%;border-collapse:collapse}.vacuum-readings-table th{background:#f3f4f6;color:#374151;padding:.75rem;text-align:left;font-size:.875rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid #e5e7eb}.vacuum-readings-table td{padding:.75rem;border-bottom:1px solid #f3f4f6;font-size:.875rem;color:#374151}.vacuum-readings-table tbody tr:last-child td{border-bottom:none}.vacuum-readings-table tbody tr:hover{background:#f9fafb}.vacuum-notes{font-size:.75rem;font-weight:500}.vacuum-section{margin-bottom:1.5rem}.vacuum-section h5{margin:0 0 .75rem;color:#374151;font-size:.875rem;font-weight:600;display:flex;align-items:center;gap:.5rem}.arrival-protocol{background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;padding:1rem;margin:1rem 0}.arrival-protocol h5{margin:0 0 .75rem;color:#1e293b;font-size:.875rem;font-weight:600}.protocol-status p{margin:.25rem 0;font-size:.875rem;color:#374151}.protocol-status strong{color:#1e293b;font-weight:600}.missing-reading-alert{background:#fef3c7;border:1px solid #f59e0b;border-radius:8px;padding:.75rem;margin:1rem 0;color:#92400e}.missing-reading-alert p{margin:0;font-size:.875rem}@media (max-width: 768px){.tank-header{flex-direction:column;gap:1rem;padding:1rem}.tank-main{padding:1rem}.tank-controls{flex-direction:column;align-items:stretch}.action-buttons{justify-content:center}.tank-data-grid{grid-template-columns:1fr}.tank-title h1{font-size:2rem}.modal-content{margin:.5rem;max-width:none}.form-row{grid-template-columns:1fr}.modal-footer{flex-direction:column}.load-history-section{margin-top:1rem}.load-history-header{padding:.75rem 1rem}.load-history-summary{gap:.5rem}.load-date{font-size:.875rem}.load-metrics-grid{grid-template-columns:1fr;gap:.75rem}.metric-card{padding:.75rem}.load-history-details{padding:0 1rem 1rem}.vacuum-readings-table th,.vacuum-readings-table td{padding:.5rem;font-size:.75rem}}.iso-analytics{min-height:100vh;width:100vw;background-color:#f5f5f5;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;margin:0;padding:0}.iso-analytics.loading{display:flex;align-items:center;justify-content:center}.analytics-header{background:#fff;padding:1rem 2rem;display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid #e0e0e0;width:100%;box-sizing:border-box}.analytics-brand{display:flex;align-items:center}.company-logo{display:flex;align-items:center;gap:.75rem}.company-logo-container{width:40px;height:40px;border-radius:8px;position:relative;overflow:hidden;background:#f8fafc;border:2px solid #e2e8f0;display:flex;align-items:center;justify-content:center}.company-logo-image{width:100%;height:100%;object-fit:cover;border-radius:6px}.company-logo-fallback{display:none;width:100%;height:100%;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;font-size:14px;font-weight:600;align-items:center;justify-content:center;border-radius:6px}.analytics-title{display:flex;flex-direction:column;gap:.25rem}.company-name{font-size:1.5rem;font-weight:600;color:#333;line-height:1}.page-subtitle{font-size:.9rem;color:#64748b;font-weight:500}.analytics-nav{display:flex;align-items:center;gap:.5rem}.nav-btn{padding:.5rem 1rem;border:1px solid #ddd;background:#fff;color:#666;border-radius:20px;cursor:pointer;font-size:.9rem;transition:all .2s ease}.nav-btn.active{background:#333;color:#fff;border-color:#333}.nav-btn:hover:not(.active){background:#f5f5f5;border-color:#bbb}.logout-btn{padding:.5rem 1rem;background:#ef4444;color:#fff;border:none;border-radius:20px;cursor:pointer;font-size:.9rem;margin-left:1rem;transition:background-color .2s ease}.analytics-main{width:100%;padding:2rem;box-sizing:border-box}.iso-overview{margin-bottom:3rem}.iso-overview h2{margin:0 0 1.5rem;color:#1e293b;font-size:1.75rem;font-weight:600}.analytics-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.5rem;margin-bottom:2rem}.analytics-card{background:#fff;padding:1.5rem;border-radius:12px;box-shadow:0 1px 3px #0000001a;border:1px solid #e2e8f0;transition:all .2s ease}.analytics-card:hover{transform:translateY(-2px);box-shadow:0 4px 8px #00000026}.analytics-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.analytics-header h3{margin:0;color:#374151;font-size:1rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.analytics-icon{font-size:1.5rem;opacity:.8}.analytics-number{font-size:2.5rem;font-weight:700;color:#1e293b;margin-bottom:.5rem;line-height:1}.analytics-description{color:#64748b;font-size:.9rem;margin-top:.5rem}.analytics-breakdown{display:flex;flex-direction:column;gap:.5rem;margin-top:1rem}.breakdown-value.maintenance{background:#fef3c7;color:#92400e}.total-tanks{border-left:4px solid #3b82f6}.operational-tanks{border-left:4px solid #10b981}.maintenance-status,.recent-readings{border-left:4px solid #f59e0b}.avg-vacuum{border-left:4px solid #8b5cf6}.utilization-rate{border-left:4px solid #06b6d4}.upcoming-inspections{border-left:4px solid #f59e0b}.critical-readings{border-left:4px solid #ef4444}.tank-status-section{margin-top:2rem}.tank-status-section h2{margin:0 0 1.5rem;color:#1e293b;font-size:1.75rem;font-weight:600}.tank-status-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:1rem}.tank-status-card{background:#fff;border:1px solid #e2e8f0;border-radius:8px;padding:1rem;transition:all .2s ease}.tank-status-card.clickable{cursor:pointer}.tank-status-card.clickable:hover{transform:translateY(-2px);box-shadow:0 4px 12px #00000026;border-color:#3b82f6}.tank-status-card:hover{box-shadow:0 2px 8px #0000001a;transform:translateY(-1px)}.tank-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;padding-bottom:.75rem;border-bottom:1px solid #f1f5f9}.tank-header h4{margin:0;color:#1e293b;font-size:1.1rem;font-weight:600}.status-indicator{padding:.25rem .75rem;border-radius:12px;font-size:.8rem;font-weight:500}.status-indicator.operational{background:#dcfce7;color:#166534}.status-indicator.non-operational{background:#fee2e2;color:#991b1b}.tank-details{display:flex;flex-direction:column;gap:.5rem}.tank-detail{display:flex;justify-content:space-between;align-items:center;padding:.25rem 0}.detail-label{color:#64748b;font-size:.875rem;font-weight:500}.detail-value{color:#1e293b;font-size:.875rem;font-weight:600}.detail-value.location-status{font-family:inherit}.no-tanks{grid-column:1 / -1;text-align:center;padding:2rem;color:#64748b;background:#fff;border-radius:8px;border:1px solid #e2e8f0}.leak-check-pass{color:#166534;font-weight:600}.leak-check-fail{color:#dc2626;font-weight:600}.leak-check-review_needed{color:#ea580c;font-weight:600}.leak-check-no_data{color:#64748b;font-weight:600}@media (max-width: 768px){.analytics-header{flex-direction:column;gap:1rem;padding:1rem}.analytics-main{padding:1rem}.analytics-grid,.tank-status-grid{grid-template-columns:1fr}.analytics-number{font-size:2rem}.tank-header{flex-direction:column;align-items:flex-start;gap:.5rem}.admin-nav-content{padding:0 1rem}}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem;width:100vw;height:100vh}.tank-modal{background:#fff;border-radius:12px;width:100%!important;max-width:1200px!important;min-width:800px;max-height:90vh!important;overflow:hidden!important;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;display:flex!important;flex-direction:column!important;position:relative!important}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem 2rem;border-bottom:1px solid #e2e8f0;background:#f8fafc;border-radius:12px 12px 0 0}.modal-header h2{margin:0;color:#1e293b;font-size:1.25rem;font-weight:600}.close-modal{background:none;border:none;font-size:1.5rem;color:#64748b;cursor:pointer;padding:.25rem;border-radius:4px;transition:all .2s ease}.close-modal:hover{background:#e2e8f0;color:#1e293b}.modal-loading{padding:3rem;text-align:center}.tank-modal .modal-content{padding:0!important;width:100%!important;display:block!important;max-width:none!important;overflow-y:auto!important;overflow-x:hidden!important;flex:1!important;height:auto!important;min-height:0!important}.tank-modal .modal-section{padding:2rem;border-bottom:1px solid #d1d5db;width:100%!important;box-sizing:border-box!important;flex-shrink:0;max-width:none!important;margin-bottom:0;position:relative;box-shadow:0 1px 3px #0000000d}.tank-modal .modal-section:nth-child(2n){background:#f9fafb}.tank-modal .modal-section:nth-child(odd){background:#fff}.tank-modal .modal-section:last-child{border-bottom:none;border-radius:0 0 12px 12px;margin-bottom:0}.tank-modal .modal-section h3{margin:0 0 1.5rem;color:#1e293b;font-size:1.2rem;font-weight:600;padding-bottom:.75rem;border-bottom:2px solid #e2e8f0;position:relative}.tank-modal .modal-section h3:before{content:"";position:absolute;bottom:-2px;left:0;width:60px;height:2px;background:#3b82f6;border-radius:1px}.summary-grid{display:grid!important;grid-template-columns:repeat(3,1fr)!important;gap:1rem;width:100%!important;max-width:none!important}.summary-item{display:flex;flex-direction:column;gap:.25rem}.summary-item label{font-size:.875rem;color:#64748b;font-weight:500}.summary-item span{font-size:.95rem;color:#1e293b;font-weight:600}.summary-item span.overdue{color:#ef4444}.status-badge.operational{background:#dcfce7;color:#166534}.status-badge.non-operational{background:#fee2e2;color:#991b1b}.status-badge.in_progress{background:#dbeafe;color:#1e40af}.status-badge.completed{background:#dcfce7;color:#166534}.readings-table,.workflows-table{width:100%!important;margin-top:1rem;overflow-x:auto;max-width:none!important}.readings-table table,.workflows-table table{width:100%!important;border-collapse:collapse;font-size:.875rem;background:#fff;min-width:100%!important;table-layout:fixed!important;max-width:none!important}.readings-table th,.workflows-table th,.readings-table td,.workflows-table td{padding:.75rem;text-align:left;border-bottom:1px solid #f1f5f9;color:#1e293b}.readings-table th,.workflows-table th{background:#f8fafc;font-weight:600;color:#374151;font-size:.8rem;text-transform:uppercase;letter-spacing:.5px}.readings-table tbody tr:nth-child(2n),.workflows-table tbody tr:nth-child(2n){background:#f8fafc}.readings-table tbody tr:hover,.workflows-table tbody tr:hover{background:#f1f5f9}.readings-table td,.workflows-table td{background:inherit}.reading-value.critical{color:#ef4444;font-weight:600;background:#fef2f2;padding:.25rem .5rem;border-radius:4px}.reading-value.normal{color:#059669;font-weight:600}.modal-error{padding:2rem;text-align:center;color:#ef4444}.tank-history{margin-top:1rem;width:100%}.history-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem;margin-bottom:1rem;width:100%}.history-item{display:flex;flex-direction:column;gap:.25rem}.history-item label{font-size:.875rem;color:#64748b;font-weight:500}.history-item span{font-size:.95rem;color:#1e293b;font-weight:600}.history-item span.critical{color:#ef4444}.history-item span.normal{color:#059669}.future-features{padding:1rem;background:#f8fafc;border-radius:8px;border:1px solid #e2e8f0;width:100%;box-sizing:border-box}.future-features p{margin:0;color:#64748b;font-style:italic;text-align:center}.notes-section{margin-top:1rem;width:100%!important;max-width:none!important}.add-note{margin-bottom:1.5rem;padding:1.5rem;background:#f8fafc;border-radius:8px;border:2px solid #e2e8f0;width:100%;box-sizing:border-box;box-shadow:0 1px 3px #0000001a}.note-textarea{width:100%;padding:.75rem;border:2px solid #e2e8f0;border-radius:6px;font-size:.875rem;font-family:inherit;resize:vertical;margin-bottom:.75rem;box-sizing:border-box;background:#fff;color:#374151;transition:border-color .2s ease,box-shadow .2s ease}.note-textarea:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a;background:#fefefe}.add-note-btn{background:#3b82f6;color:#fff;border:none;padding:.5rem 1rem;border-radius:6px;font-size:.875rem;cursor:pointer;transition:background-color .2s ease}.add-note-btn:hover:not(:disabled){background:#2563eb}.add-note-btn:disabled{background:#9ca3af;cursor:not-allowed}.notes-list{display:flex;flex-direction:column;gap:1rem;width:100%}.note-item{display:flex;justify-content:space-between;align-items:flex-start;padding:1rem;background:#fff;border:1px solid #e2e8f0;border-radius:8px;gap:1rem;width:100%;box-sizing:border-box}.note-content{flex:1}.note-content p{margin:0 0 .5rem;color:#1e293b;line-height:1.5}.note-meta{display:flex;gap:1rem;font-size:.75rem;color:#64748b}.note-author{font-weight:500}.delete-note-btn{background:none;border:none;font-size:1rem;cursor:pointer;padding:.25rem;border-radius:4px;transition:background-color .2s ease}.delete-note-btn:hover{background:#fee2e2}.no-notes{text-align:center;color:#64748b;font-style:italic;padding:2rem}.files-section{margin-top:1rem;width:100%!important;max-width:none!important}.upload-file{margin-bottom:1.5rem;padding:1rem;background:#f8fafc;border-radius:8px;border:1px solid #e2e8f0;text-align:center;width:100%;box-sizing:border-box}.upload-btn{display:inline-block;background:#10b981;color:#fff;padding:.75rem 1.5rem;border-radius:6px;cursor:pointer;font-size:.875rem;font-weight:500;transition:background-color .2s ease;margin-bottom:.5rem}.upload-btn:hover{background:#059669}.upload-hint{display:block;font-size:.75rem;color:#64748b}.files-list{display:flex;flex-direction:column;gap:1rem;width:100%}.file-item{display:flex;justify-content:space-between;align-items:center;padding:1rem;background:#fff;border:1px solid #e2e8f0;border-radius:8px;gap:1rem;width:100%;box-sizing:border-box}.file-content{flex:1}.file-info{display:flex;align-items:center;gap:1rem;margin-bottom:.25rem}.file-name{color:#1e293b;font-weight:500;font-size:.875rem}.file-size{color:#64748b;font-size:.75rem;background:#f1f5f9;padding:.125rem .5rem;border-radius:12px}.file-meta{display:flex;gap:1rem;font-size:.75rem;color:#64748b}.file-uploader{font-weight:500}.file-actions{display:flex;gap:.5rem}.download-btn,.delete-file-btn{background:none;border:none;font-size:1rem;cursor:pointer;padding:.25rem;border-radius:4px;transition:background-color .2s ease;text-decoration:none}.download-btn:hover{background:#e0f2fe}.delete-file-btn:hover{background:#fee2e2}.no-files{text-align:center;color:#64748b;font-style:italic;padding:2rem}@media (max-width: 768px){.modal-overlay{padding:.5rem}.tank-modal{max-height:95vh;width:calc(100vw - 1rem);min-width:unset}.modal-header{padding:1rem 1.5rem}.modal-section{padding:1.5rem;width:100%;box-sizing:border-box}.summary-grid,.history-grid{grid-template-columns:1fr}.readings-table,.workflows-table{overflow-x:auto;width:100%}.readings-table table,.workflows-table table{min-width:600px}.note-item,.file-item{flex-direction:column;align-items:flex-start;gap:.75rem}.file-actions{align-self:flex-end}.file-info{flex-direction:column;align-items:flex-start;gap:.25rem}}.analytics-card.clickable{cursor:pointer;transition:transform .2s ease,box-shadow .2s ease}.analytics-card.clickable:hover{transform:translateY(-2px);box-shadow:0 4px 12px #00000026}.list-modal{max-width:800px;max-height:80vh;overflow:hidden}.list-modal .modal-body{padding:0;max-height:calc(80vh - 80px);overflow-y:auto}.modal-tabs{display:flex;border-bottom:2px solid #e2e8f0;background:#f8fafc;margin:0;padding:0}.tab-button{flex:1;padding:1rem 1.5rem;border:none;background:transparent;cursor:pointer;font-size:.875rem;font-weight:600;color:#64748b;transition:all .2s ease;border-bottom:3px solid transparent;margin-right:1px}.tab-button:last-child{margin-right:0}.tab-button:hover{background:#e2e8f0;color:#374151}.tab-button.active{color:#fff;border-bottom-color:currentColor}.tab-button.active:first-child{background:#22c55e;border-bottom-color:#16a34a}.tab-button.active:last-child{background:#ef4444;border-bottom-color:#dc2626}.operational-tanks-content,.non-operational-tanks-content{background:#fff}.status-badge{display:inline-block;padding:.25rem .75rem;border-radius:9999px;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.025em}.status-badge.operational{background:#dcfce7;color:#166534;border:1px solid #bbf7d0}.status-badge.maintenance{background:#fef3c7;color:#92400e;border:1px solid #fde68a}.status-badge.no-status{background:#f1f5f9;color:#64748b;border:1px solid #e2e8f0}.readings-table{width:100%}.readings-header{display:grid;grid-template-columns:1fr 1fr 1fr 1fr;gap:1rem;padding:1rem 1.5rem;background:#f8fafc;border-bottom:2px solid #e2e8f0;font-weight:600;color:#374151;font-size:.875rem;text-transform:uppercase;letter-spacing:.025em}.readings-row{display:grid;grid-template-columns:1fr 1fr 1fr 1fr;gap:1rem;padding:1rem 1.5rem;border-bottom:1px solid #e2e8f0;transition:background-color .2s ease;cursor:pointer}.readings-row:hover{background-color:#f8fafc}.readings-row.clickable:hover{background-color:#e0f2fe}.tank-number{font-weight:600;color:#1e40af}.reading-value.high{color:#dc2626;font-weight:600}.reading-value.low{color:#ea580c;font-weight:600}.reading-date,.inspection-date{color:#6b7280;font-size:.875rem}.reading-status,.inspection-status{font-size:.875rem;font-weight:500}.days-overdue{color:#dc2626;font-weight:600}.recorded-by{color:#6b7280;font-size:.875rem}.no-data{text-align:center;padding:3rem 1.5rem;color:#6b7280;font-style:italic}.main-tabs{display:flex;background:#fff;border-radius:12px;margin:0 2rem 2rem;padding:.5rem;box-shadow:0 2px 8px #0000001a;border:1px solid #e2e8f0}.main-tab-button{flex:1;padding:1rem 1.5rem;border:none;background:transparent;color:#64748b;font-size:1rem;font-weight:500;border-radius:8px;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;gap:.5rem}.main-tab-button:hover{color:#3b82f6;background:#f8fafc}.main-tab-button.active{background:linear-gradient(135deg,#3b82f6,#1d4ed8);color:#fff;box-shadow:0 2px 8px #3b82f640}.weekly-reports-tab-content{padding:0 2rem}.weekly-reports-section{background:#fff;border-radius:12px;padding:2rem;box-shadow:0 2px 8px #0000001a;border:1px solid #e2e8f0}.reports-header{text-align:center;margin-bottom:2rem}.reports-header h2{color:#1e293b;font-size:1.75rem;font-weight:600;margin:0 0 .5rem}.reports-subtitle{color:#64748b;font-size:1rem;margin:0}.reports-loading{display:flex;justify-content:center;align-items:center;padding:4rem 0}.reports-loading .loading-text{font-size:1.1rem;color:#64748b}.no-reports{display:flex;justify-content:center;align-items:center;padding:4rem 0}.no-reports-content{text-align:center;max-width:500px}.no-reports-content h3{color:#374151;font-size:1.25rem;font-weight:600;margin:0 0 1rem}.no-reports-content p{color:#6b7280;font-size:1rem;margin:.5rem 0;line-height:1.5}.reports-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(400px,1fr));gap:1.5rem}.report-card{background:#f8fafc;border:1px solid #e2e8f0;border-radius:12px;padding:1.5rem;transition:all .2s ease}.report-card:hover{border-color:#3b82f6;box-shadow:0 4px 12px #3b82f626}.report-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1.5rem}.report-header h3{color:#1e293b;font-size:1.125rem;font-weight:600;margin:0}.report-date{color:#6b7280;font-size:.875rem;font-style:italic}.report-summary{margin-bottom:1.5rem}.summary-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:1rem;margin-bottom:1.5rem}.stat-item{text-align:center;padding:1rem;background:#fff;border-radius:8px;border:1px solid #e5e7eb}.stat-label{display:block;color:#6b7280;font-size:.75rem;text-transform:uppercase;letter-spacing:.5px;font-weight:500;margin-bottom:.5rem}.stat-value{display:block;color:#1e293b;font-size:1.25rem;font-weight:700}.stat-value.added{color:#10b981}.stat-value.removed{color:#f59e0b}.stat-value.critical{color:#ef4444}.stat-value.warning{color:#f59e0b}.admin-notes{background:#fff;padding:1rem;border-radius:8px;border:1px solid #e5e7eb;margin-top:1rem}.admin-notes h4{color:#374151;font-size:.875rem;font-weight:600;margin:0 0 .5rem;text-transform:uppercase;letter-spacing:.5px}.admin-notes p{color:#6b7280;font-size:.9rem;line-height:1.5;margin:0}.report-actions{display:flex;justify-content:flex-end}.view-details-btn{background:#3b82f6;color:#fff;border:none;padding:.5rem 1rem;border-radius:6px;cursor:pointer;font-size:.875rem;font-weight:500;transition:all .2s ease}.view-details-btn:hover{background:#2563eb;transform:translateY(-1px);box-shadow:0 4px 12px #3b82f640}@media (max-width: 768px){.main-tabs{margin:0 1rem 1.5rem;flex-direction:column;gap:.5rem}.main-tab-button{flex:none}.weekly-reports-tab-content{padding:0 1rem}.weekly-reports-section{padding:1.5rem}.reports-grid{grid-template-columns:1fr;gap:1rem}.report-header{flex-direction:column;gap:.5rem;align-items:flex-start}.summary-stats{grid-template-columns:repeat(2,1fr);gap:.75rem}.stat-item{padding:.75rem}.stat-value{font-size:1.125rem}}@media (max-width: 768px){.list-modal{max-width:calc(100vw - 2rem);max-height:90vh}.readings-header,.readings-row{grid-template-columns:1fr 1fr;gap:.5rem;padding:.75rem 1rem}.readings-header div:nth-child(3),.readings-header div:nth-child(4),.readings-row div:nth-child(3),.readings-row div:nth-child(4){display:none}}.leak-check-list{margin-top:1rem}.assessments-grid{display:flex;flex-direction:column;gap:1rem}.assessment-card{background:#fff;border:1px solid #e5e5e5;border-radius:8px;padding:1rem;box-shadow:0 1px 3px #0000001a;transition:box-shadow .2s;color:#333}.assessment-card:hover{box-shadow:0 2px 8px #00000026}.assessment-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem;padding-bottom:.5rem;border-bottom:1px solid #f0f0f0}.assessment-date{font-weight:600;color:#333;font-size:14px}.assessment-status{padding:3px 8px;border-radius:12px;font-size:11px;font-weight:700;text-transform:uppercase}.status-pass{background-color:#d1edff;color:#0c5460}.status-fail{background-color:#f8d7da;color:#721c24}.status-review_needed{background-color:#fff3cd;color:#856404}.assessment-details{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:.5rem;margin-bottom:.75rem;color:#333}.detail-item{display:flex;flex-direction:column;gap:2px;color:#333}.detail-item span:not(.label){color:#333!important;font-size:13px!important;display:inline-block!important;min-width:20px!important}.assessment-card .leak-count{background-color:#fff!important;padding:1px 3px!important;border-radius:2px!important;min-width:20px!important;text-align:left!important;display:inline-block!important;margin-top:6px!important}.detail-item .label{font-size:11px;color:#666;text-transform:uppercase;font-weight:600}.leak-count{color:#333!important;font-weight:700!important;display:inline-block!important;position:relative!important;z-index:1!important;background:transparent!important;visibility:visible!important;opacity:1!important;font-size:13px!important;line-height:normal!important;width:auto!important;height:auto!important;overflow:visible!important;text-indent:0!important;letter-spacing:normal!important}.leak-count.no-leaks{color:#10b981!important}.leak-count.few-leaks{color:#f59e0b!important}.leak-count.many-leaks{color:#ef4444!important}.assessment-actions{display:flex;justify-content:flex-end}.view-details-btn{padding:6px 12px;background-color:#6366f1;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:12px;font-weight:600;transition:background-color .2s}.view-details-btn:hover{background-color:#5856eb}.show-more-assessments{text-align:center;padding:1rem;border:2px dashed #ddd;border-radius:8px;background-color:#f9f9f9}.show-more-assessments p{margin:0 0 .5rem;color:#666;font-size:14px}.view-all-btn{padding:8px 16px;background-color:#10b981;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:12px;font-weight:600;transition:background-color .2s}.view-all-btn:hover{background-color:#059669}.no-assessments{text-align:center;padding:2rem;border:2px dashed #ddd;border-radius:8px;background-color:#f9f9f9}.no-assessments p{margin:0 0 1rem;color:#666;font-size:14px}.start-assessment-btn{padding:10px 20px;background-color:#6366f1;color:#fff;border:none;border-radius:6px;cursor:pointer;font-size:14px;font-weight:600;transition:background-color .2s}.start-assessment-btn:hover{background-color:#5856eb}.procedure-detail{min-height:100vh;width:100vw;background-color:#fff;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;margin:0;padding:0}.procedure-header{background:#2c3e50;color:#fff;padding:1rem 0}.header-left{display:flex;align-items:center;gap:1rem}.back-button{background:transparent;color:#fff;border:1px solid rgba(255,255,255,.3);padding:.5rem 1rem;border-radius:4px;cursor:pointer;font-size:.9rem;transition:all .2s ease}.back-button:hover{background:#ffffff1a;border-color:#ffffff80}.export-pdf-btn{background:linear-gradient(135deg,#10b981,#059669);color:#fff;border:none;padding:.5rem 1rem;border-radius:6px;cursor:pointer;font-size:.9rem;font-weight:500;transition:all .2s ease;display:flex;align-items:center;gap:.5rem}.export-pdf-btn:hover{background:linear-gradient(135deg,#059669,#047857);transform:translateY(-1px);box-shadow:0 4px 12px #10b9814d}.header-info{display:flex;align-items:center;gap:1rem}.company-name{font-size:1.1rem;font-weight:500}.logout-btn{background:#e74c3c;color:#fff;border:none;padding:.5rem 1rem;border-radius:4px;cursor:pointer;font-size:.9rem;transition:background-color .2s ease}.logout-btn:hover{background:#c0392b}.procedure-main{max-width:1200px;margin:0 auto;padding:3rem 2rem}.procedure-article{background:#fff;line-height:1.7}.article-header{margin-bottom:3rem;padding-bottom:2rem;border-bottom:2px solid #ecf0f1}.procedure-title{font-size:3rem;font-weight:300;color:#2c3e50;margin:0 0 1rem;line-height:1.2}.procedure-summary{font-size:1.2rem;color:#7f8c8d;margin:1.5rem 0;font-style:italic}.procedure-meta{display:flex;justify-content:space-between;align-items:center;margin-top:2rem;flex-wrap:wrap;gap:1rem}.publish-date{color:#95a5a6;font-size:.9rem}.categories{display:flex;gap:.5rem;flex-wrap:wrap}.category-tag{background:#3498db;color:#fff;padding:.25rem .75rem;border-radius:20px;font-size:.8rem;font-weight:500}.cover-image{margin:2rem 0;text-align:center}.cover-image img{max-width:100%;height:auto;border-radius:8px;box-shadow:0 4px 12px #00000026}.procedure-content{font-size:1.1rem;color:#2c3e50}.content-body h1{font-size:2.5rem;color:#2c3e50;margin:3rem 0 1.5rem;font-weight:400;border-bottom:3px solid #3498db;padding-bottom:.5rem}.content-body h2{font-size:2rem;color:#34495e;margin:2.5rem 0 1rem;font-weight:500}.content-body h3{font-size:1.5rem;color:#34495e;margin:2rem 0 1rem;font-weight:600}.content-body p{margin:1.5rem 0;text-align:justify}.content-body ul,.content-body ol{margin:1.5rem 0;padding-left:2rem}.content-body li{margin:.75rem 0;line-height:1.6}.content-body ol li{margin:1rem 0;font-weight:500}.content-body strong{font-weight:600;color:#2c3e50}.content-body em{font-style:italic;color:#7f8c8d}.content-body a{color:#3498db;text-decoration:none;border-bottom:1px solid #3498db;transition:all .2s ease}.content-body a:hover{color:#2980b9;border-bottom-color:#2980b9}.image-container{margin:2rem 0;text-align:center}.content-image{max-width:100%;height:auto;border-radius:8px;box-shadow:0 4px 12px #00000026;cursor:pointer;transition:transform .2s ease}.content-image:hover{transform:scale(1.02)}.content-body pre{background:#2c3e50;color:#ecf0f1;padding:1.5rem;border-radius:8px;overflow-x:auto;margin:2rem 0;font-family:Monaco,Menlo,Ubuntu Mono,monospace;font-size:.9rem;line-height:1.4}.content-body code{background:#ecf0f1;color:#2c3e50;padding:.2rem .4rem;border-radius:4px;font-family:Monaco,Menlo,Ubuntu Mono,monospace;font-size:.9em}.content-body pre code{background:transparent;color:inherit;padding:0;border-radius:0}.content-body blockquote{border-left:4px solid #3498db;background:#f8f9fa;margin:1.5rem 0;padding:1rem 1.5rem;font-style:italic;color:#2c3e50}.content-body hr{border:none;height:2px;background:linear-gradient(to right,#3498db,#transparent);margin:3rem 0}.content-body table{width:100%;border-collapse:collapse;margin:2rem 0;background:#fff;box-shadow:0 2px 8px #0000001a;border-radius:8px;overflow:hidden}.content-body th{background:#34495e;color:#fff;padding:1rem;text-align:left;font-weight:600}.content-body td{padding:1rem;border-bottom:1px solid #ecf0f1}.content-body tr:last-child td{border-bottom:none}.content-body tr:nth-child(2n){background:#f8f9fa}.media-section{margin:3rem 0;padding:2rem;background:#ecf0f1;border-radius:8px}.media-section h3{margin:0 0 1rem;color:#2c3e50}.media-link{display:inline-block;background:#3498db;color:#fff;padding:.75rem 1.5rem;text-decoration:none;border-radius:6px;font-weight:500;transition:background-color .2s ease}.media-link:hover{background:#2980b9}.procedure-footer{margin-top:4rem;padding-top:2rem;border-top:1px solid #ecf0f1}.footer-info{color:#95a5a6;font-size:.9rem}.footer-info p{margin:.5rem 0}.loading-text{font-size:1.2rem;color:#666}.error{display:flex;justify-content:center;align-items:center;height:100vh}.error-content{text-align:center;padding:2rem}.error-content h2{color:#e74c3c;margin-bottom:1rem}.error-content p{color:#666;margin-bottom:2rem}.back-btn{background:#3498db;color:#fff;border:none;padding:.75rem 1.5rem;border-radius:6px;cursor:pointer;font-size:1rem;transition:background-color .2s ease}.back-btn:hover{background:#2980b9}@media (max-width: 768px){.header-content{flex-direction:column;gap:1rem;text-align:center}.procedure-main{padding:2rem 1rem}.procedure-title{font-size:2rem}.content-body h1{font-size:1.8rem}.content-body h2{font-size:1.5rem}.procedure-meta{flex-direction:column;align-items:flex-start}}.pdf-viewer-section{background:#fff;border-radius:8px;padding:1.5rem;border:1px solid #e5e7eb;margin-bottom:2rem}.pdf-viewer-section h3{margin:0 0 1rem;color:#374151;font-size:1.2rem;display:flex;align-items:center;gap:.5rem}.pdf-viewer-section h3:before{content:"📄";font-size:1.5rem}.pdf-viewer{border:1px solid #d1d5db;border-radius:8px;overflow:hidden;background:#f9fafb}.pdf-viewer embed{display:block;width:100%;height:600px;border:none}.pdf-download{padding:1rem;background:#f8fafc;border-top:1px solid #e5e7eb;text-align:center}.pdf-download-btn{display:inline-flex;align-items:center;gap:.5rem;background:#3b82f6;color:#fff;text-decoration:none;padding:.75rem 1.5rem;border-radius:6px;font-weight:500;transition:background .2s ease}.pdf-download-btn:hover{background:#2563eb;color:#fff;text-decoration:none}@media (max-width: 768px){.pdf-viewer embed{height:400px}.pdf-viewer-section{padding:1rem;margin:0 -1rem 1rem}}.procedure-manager{min-height:100vh;width:100vw;background-color:#f8fafc;font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;margin:0;padding:0}.procedure-list-view{padding:2rem;width:100%;box-sizing:border-box}.filter-select{padding:12px 40px 12px 16px;border:2px solid #e1e5e9;border-radius:8px;font-size:1rem;background:#fff;background-image:url("data:image/svg+xml;charset=UTF-8,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23374151' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3e%3cpolyline points='6,9 12,15 18,9'%3e%3c/polyline%3e%3c/svg%3e");background-repeat:no-repeat;background-position:right 12px center;background-size:20px;color:#374151;min-width:150px;transition:border-color .2s ease;appearance:none;-webkit-appearance:none;-moz-appearance:none;cursor:pointer}.procedures-table{background:#fff;border-radius:12px;box-shadow:0 2px 12px #0000001a;overflow:hidden}.procedures-table table{width:100%;border-collapse:collapse}.procedures-table th{background:#f8fafc;color:#374151;padding:1rem;text-align:left;font-weight:600;font-size:.9rem;text-transform:uppercase;letter-spacing:.5px;border-bottom:2px solid #e5e7eb}.procedures-table td{padding:1rem;border-bottom:1px solid #f3f4f6;vertical-align:top;color:#374151}.procedures-table tr:hover{background:#f9fafb}.title-cell strong{color:#1e293b;font-size:1rem}.summary-cell{color:#6b7280;font-size:.9rem;line-height:1.4;max-width:300px}.status-badge.public{background:#dcfce7;color:#166534}.status-badge.private{background:#fef3c7;color:#92400e}.status-badge.client_specific{background:#e0e7ff;color:#5a67d8}.view-btn,.edit-btn,.delete-btn{padding:.375rem .75rem;border:none;border-radius:6px;cursor:pointer;font-size:.85rem;font-weight:500;transition:all .2s ease}.view-btn{background:#64748b;color:#fff}.view-btn:hover{background:#475569}.procedure-editor-view{padding:2rem;width:100%;box-sizing:border-box;max-width:100%}.preview-btn{background:#64748b;color:#fff;border:none;padding:.75rem 1rem;border-radius:6px;cursor:pointer;font-size:.9rem;transition:all .2s ease}.preview-btn.active{background:#667eea}.preview-btn:hover{background:#475569}.preview-btn.active:hover{background:#5a67d8}.form-input,.form-select,.form-textarea{padding:.75rem;border:1px solid #d1d5db;border-radius:6px;font-size:1rem;transition:border-color .2s ease}.form-input:focus,.form-select:focus,.form-textarea:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.form-textarea.summary{resize:vertical;min-height:60px}.category-selection{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:.75rem;margin-top:.5rem}.category-checkbox{display:flex;align-items:center;gap:.75rem;cursor:pointer;padding:.75rem;border:1px solid #e5e7eb;border-radius:6px;transition:all .2s ease;background:#fff}.category-checkbox:hover{border-color:#667eea;background:#f8fafc}.category-checkbox input[type=checkbox]{margin:0;cursor:pointer}.category-label{flex:1;font-size:.9rem;font-weight:500;color:#374151;padding-left:.5rem;transition:color .2s ease}.category-checkbox input[type=checkbox]:checked+.category-label{color:#667eea;font-weight:600}.category-checkbox:has(input[type=checkbox]:checked){border-color:#667eea;background:#667eea0d}.category-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.category-header label{margin-bottom:0}.add-category-btn{background:#10b981;color:#fff;border:none;padding:.5rem 1rem;border-radius:6px;cursor:pointer;font-size:.9rem;font-weight:500;transition:all .2s ease}.add-category-btn:hover{background:#059669;transform:translateY(-1px)}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;justify-content:center;align-items:center;z-index:1000}.modal-content{background:#fff;border-radius:12px;box-shadow:0 4px 24px #00000026;width:100%;max-width:500px;margin:1rem;max-height:90vh;overflow-y:auto}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem 1.5rem 0;border-bottom:1px solid #e5e7eb;margin-bottom:1.5rem}.modal-header h3{margin:0;color:#1e293b;font-size:1.2rem;font-weight:600}.modal-close{background:none;border:none;font-size:1.5rem;color:#6b7280;cursor:pointer;padding:0;width:24px;height:24px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:all .2s ease}.modal-close:hover{background:#f3f4f6;color:#374151}.modal-body{padding:0 1.5rem}.modal-footer{display:flex;gap:1rem;justify-content:flex-end;padding:1.5rem;border-top:1px solid #e5e7eb;margin-top:1.5rem}.color-picker-group{display:flex;align-items:center;gap:1rem}.color-picker{width:50px;height:40px;border:1px solid #d1d5db;border-radius:6px;cursor:pointer;background:none}.color-preview{padding:.5rem 1rem;border-radius:6px;color:#fff;font-size:.85rem;font-weight:500;text-shadow:0 1px 2px rgba(0,0,0,.2);min-width:80px;text-align:center}.editor-section{margin:2rem 0}.editor-toolbar{display:flex;justify-content:space-between;align-items:center;background:#f8fafc;padding:1rem;border-radius:8px 8px 0 0;border:1px solid #e5e7eb;border-bottom:none}.toolbar-label{font-weight:600;color:#374151}.toolbar-buttons{display:flex;gap:.5rem;align-items:center}.toolbar-btn,.upload-btn{background:#64748b;color:#fff;border:1px solid #64748b;padding:.5rem .75rem;border-radius:4px;cursor:pointer;font-size:.9rem;transition:all .2s ease;min-width:32px;height:32px;display:flex;align-items:center;justify-content:center}.toolbar-btn:hover,.upload-btn:hover{background:#475569;border-color:#475569}.toolbar-btn:disabled{background:#e5e7eb;color:#9ca3af;border-color:#e5e7eb;cursor:not-allowed}.toolbar-btn:disabled:hover{background:#e5e7eb;border-color:#e5e7eb;transform:none}.upload-btn{position:relative;overflow:hidden}.toolbar-divider{width:1px;height:24px;background:#d1d5db;margin:0 .5rem}.uploading{font-size:.8rem;color:#6b7280}.editor-content{display:flex;height:600px;border:1px solid #e5e7eb;border-radius:0 0 8px 8px}.editor-content.split-view .editor-pane{width:50%;border-right:1px solid #e5e7eb}.editor-pane{width:100%;display:flex;flex-direction:column}.content-editor{width:100%;height:100%;border:none;padding:1.5rem;font-family:Monaco,Menlo,Ubuntu Mono,monospace;font-size:.9rem;line-height:1.6;resize:none;background:#fafafa;color:#1e293b}.content-editor:focus{outline:none;background:#fff;color:#1e293b}.preview-pane{width:50%;display:flex;flex-direction:column;background:#fff}.preview-header{background:#f8fafc;padding:.75rem 1rem;border-bottom:1px solid #e5e7eb;font-weight:600;color:#374151;font-size:.9rem}.preview-content{flex:1;padding:1.5rem;overflow-y:auto;font-size:1rem;line-height:1.7;color:#1e293b!important}.preview-content h1{font-size:2rem;color:#1e293b;margin:2rem 0 1rem;font-weight:400;border-bottom:3px solid #667eea;padding-bottom:.5rem}.preview-content h2{font-size:1.5rem;color:#374151;margin:1.5rem 0 1rem;font-weight:500}.preview-content h3{font-size:1.25rem;color:#374151;margin:1.25rem 0 .75rem;font-weight:600}.preview-content p{margin:1rem 0;color:#1e293b!important}.preview-content strong{font-weight:600;color:#1e293b}.preview-content em{font-style:italic;color:#6b7280}.preview-content code{background:#f3f4f6;color:#1e293b;padding:.2rem .4rem;border-radius:4px;font-family:Monaco,Menlo,Ubuntu Mono,monospace;font-size:.9em}.preview-content pre{background:#1e293b;color:#f1f5f9;padding:1rem;border-radius:6px;overflow-x:auto;margin:1.5rem 0}.preview-content pre code{background:transparent;color:inherit;padding:0}.preview-content ul,.preview-content ol{margin:1rem 0;padding-left:1.5rem}.preview-content li{margin:.5rem 0}.preview-content a{color:#667eea;text-decoration:none;border-bottom:1px solid #667eea}.preview-content a:hover{color:#5a67d8;border-bottom-color:#5a67d8}.preview-content .image-container{margin:1.5rem 0;text-align:center}.preview-content .content-image{max-width:100%;height:auto;border-radius:6px;box-shadow:0 2px 8px #0000001a}.preview-content blockquote{border-left:4px solid #667eea;background:#f8fafc;margin:1.5rem 0;padding:1rem 1.5rem;font-style:italic;color:#1e293b}.preview-content hr{border:none;height:2px;background:linear-gradient(to right,#667eea,transparent);margin:2rem 0}.preview-content table{width:100%;border-collapse:collapse;margin:1.5rem 0;background:#fff;box-shadow:0 2px 8px #0000001a;border-radius:6px;overflow:hidden}.preview-content th{background:#374151;color:#fff;padding:.75rem;text-align:left;font-weight:600}.preview-content td{padding:.75rem;border-bottom:1px solid #f3f4f6}.preview-content tr:nth-child(2n){background:#f9fafb}.preview-content mark{background:#fef08a;color:#854d0e;padding:.1rem .2rem;border-radius:2px}.preview-content span[style*=color],.preview-content *{color:inherit}.preview-content span[style*=color]{font-weight:500}.preview-content,.preview-content *:not(span[style*=color]){color:#1e293b!important}@media (max-width: 1024px){.editor-content.split-view{flex-direction:column;height:auto}.editor-content.split-view .editor-pane{width:100%;border-right:none;border-bottom:1px solid #e5e7eb}.preview-pane{width:100%;min-height:400px}.content-editor{min-height:400px}}@media (max-width: 768px){.procedure-manager,.procedure-list-view,.procedure-editor-view{padding:1rem}.list-header,.editor-header{flex-direction:column;align-items:stretch;gap:1rem}.form-row{grid-template-columns:1fr}.list-controls{flex-direction:column}.search-bar{min-width:auto}.toolbar-buttons{flex-wrap:wrap}.procedures-table{overflow-x:auto}.actions-cell{flex-direction:column}}.content-type-selector{display:flex;gap:1rem;margin-top:.5rem}.radio-option{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;border:2px solid #e2e8f0;border-radius:6px;cursor:pointer;transition:all .2s ease;background:#fff;color:#374151;font-weight:500}.radio-option:hover{border-color:#3b82f6;background:#f8faff}.radio-option input[type=radio]:checked{accent-color:#3b82f6}.radio-option:has(input[type=radio]:checked){border-color:#3b82f6;background:#eff6ff;color:#1d4ed8}.radio-option input[type=radio]{margin:0;width:16px;height:16px;accent-color:#3b82f6;cursor:pointer}.pdf-upload-section{margin-top:1rem;border:2px dashed #d1d5db;border-radius:8px;background:#fafafa}.pdf-dropzone{padding:3rem 2rem;text-align:center;color:#6b7280}.pdf-dropzone .pdf-icon{font-size:3rem;margin-bottom:1rem;display:block}.pdf-dropzone h3{margin:0 0 .5rem;color:#374151;font-size:1.2rem}.pdf-dropzone p{margin:0 0 1.5rem;color:#6b7280}.pdf-upload-btn{display:inline-block;background:#3b82f6;color:#fff;padding:.75rem 1.5rem;border-radius:6px;cursor:pointer;font-weight:500;transition:background .2s ease}.pdf-upload-btn:hover{background:#2563eb}.uploading-pdf{margin-top:1rem;color:#3b82f6;font-weight:500}.pdf-uploaded{padding:2rem;background:#f0fdf4;border:2px solid #22c55e;border-radius:8px}.pdf-info{display:flex;align-items:center;gap:1rem;margin-bottom:1rem}.pdf-info .pdf-icon{font-size:2rem;color:#22c55e}.pdf-details strong{display:block;color:#166534;font-size:1.1rem;margin-bottom:.25rem}.pdf-details p{color:#16a34a;margin:0}.remove-pdf-btn{background:#ef4444;color:#fff;border:none;padding:.5rem 1rem;border-radius:4px;cursor:pointer;font-size:.9rem;transition:background .2s ease}.remove-pdf-btn:hover{background:#dc2626}.thumbnail-upload-section{border:2px dashed #d1d5db;border-radius:8px;background:#fafafa;margin-top:.5rem}.thumbnail-dropzone{padding:2rem;text-align:center;color:#6b7280}.thumbnail-dropzone .thumbnail-icon{font-size:2rem;margin-bottom:.5rem;display:block}.thumbnail-dropzone p{margin:0 0 1rem;color:#6b7280;font-size:.9rem}.thumbnail-upload-btn{display:inline-block;background:#10b981;color:#fff;padding:.5rem 1rem;border-radius:6px;cursor:pointer;font-weight:500;font-size:.9rem;transition:background .2s ease}.thumbnail-upload-btn:hover{background:#059669}.thumbnail-preview{padding:1rem;background:#fff;border:2px solid #22c55e;border-radius:8px;display:flex;align-items:center;gap:1rem}.thumbnail-image{width:80px;height:60px;object-fit:cover;border-radius:4px;border:1px solid #e5e7eb}.thumbnail-actions{flex:1}.remove-thumbnail-btn{background:#ef4444;color:#fff;border:none;padding:.5rem 1rem;border-radius:4px;cursor:pointer;font-size:.85rem;transition:background .2s ease}.remove-thumbnail-btn:hover{background:#dc2626}.procedure-item{display:flex;align-items:center;gap:.75rem}.procedure-thumbnail{flex-shrink:0;width:48px;height:36px;border-radius:4px;overflow:hidden;border:1px solid #e5e7eb;background:#f9fafb;display:flex;align-items:center;justify-content:center}.procedure-thumbnail-img{width:100%;height:100%;object-fit:cover}.procedure-thumbnail-placeholder{font-size:1.2rem;color:#9ca3af}.procedure-info{flex:1;min-width:0}.procedure-title{display:block;color:#374151;line-height:1.4;font-size:.95rem}.procedure-meta-small{color:#6b7280;font-size:.8rem;margin-top:.25rem;line-height:1.2}.title-cell{min-width:200px;max-width:300px}.user-manager{min-height:100vh;width:100vw;background-color:#f8fafc;font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;margin:0;padding:0}.user-list-view{padding:2rem;width:100%;box-sizing:border-box}.list-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}.header-actions{display:flex;gap:1rem;align-items:center}.list-header h1{margin:0;color:#1e293b;font-size:2rem;font-weight:600}.create-btn{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;padding:.875rem 1.5rem;border-radius:8px;cursor:pointer;font-size:1rem;font-weight:600;transition:all .2s ease;box-shadow:0 2px 8px #667eea4d}.create-btn:hover{transform:translateY(-1px);box-shadow:0 4px 12px #667eea66}.list-controls{display:flex;gap:1rem;margin-bottom:2rem;align-items:center;flex-wrap:wrap}.search-input{width:100%;padding:12px 16px;border:2px solid #e1e5e9;border-radius:8px;font-size:1rem;background:#fff;color:#374151;transition:border-color .2s ease;box-sizing:border-box}.search-input:hover{border-color:#9ca3af}.search-input::placeholder{color:#9ca3af;opacity:1}.filter-controls{display:flex;gap:1rem}.filter-select{padding:12px 40px 12px 16px;border:2px solid #e1e5e9;border-radius:8px;font-size:1rem;background:#fff;background-image:url("data:image/svg+xml;charset=UTF-8,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23374151' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3e%3cpolyline points='6,9 12,15 18,9'%3e%3c/polyline%3e%3c/svg%3e");background-repeat:no-repeat;background-position:right 12px center;background-size:20px;color:#374151;min-width:150px;transition:border-color .2s ease;appearance:none;-webkit-appearance:none;-moz-appearance:none;cursor:pointer}.filter-select:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.filter-select:hover{border-color:#9ca3af}.filter-select option{background:#fff;color:#374151;padding:8px}.clear-filters{background:#6b7280;color:#fff;border:none;padding:.75rem 1rem;border-radius:8px;cursor:pointer;font-size:.9rem;transition:all .2s ease}.clear-filters:hover{background:#4b5563}.users-table{background:#fff;border-radius:12px;box-shadow:0 2px 12px #0000001a;overflow:hidden}.users-table table{width:100%;border-collapse:collapse}.users-table th{background:#f8fafc;color:#374151;padding:1rem;text-align:left;font-weight:600;font-size:.9rem;text-transform:uppercase;letter-spacing:.5px;border-bottom:2px solid #e5e7eb}.users-table td{padding:1rem;border-bottom:1px solid #f3f4f6;vertical-align:top;color:#374151}.users-table tr:hover{background:#f9fafb}.email-cell strong{color:#1e293b;font-size:1rem}.role-badge{padding:.25rem .75rem;border-radius:20px;font-size:.8rem;font-weight:500;text-transform:capitalize}.role-badge.user{background:#dcfce7;color:#166534}.status-badge{padding:.25rem .75rem;border-radius:20px;font-size:.8rem;font-weight:500;text-transform:capitalize}.status-badge.rejected{background:#fee2e2;color:#dc2626}.verification-badge{padding:.25rem .75rem;border-radius:20px;font-size:.8rem;font-weight:500}.verification-badge.verified{background:#dcfce7;color:#166534}.verification-badge.unverified{background:#fee2e2;color:#dc2626}.actions-cell{display:flex;gap:.5rem;flex-wrap:wrap}.edit-btn,.delete-btn,.approve-btn,.approve-company-btn,.reject-btn,.reset-btn,.view-reason-btn{padding:.375rem .75rem;border:none;border-radius:6px;cursor:pointer;font-size:.85rem;font-weight:500;transition:all .2s ease;white-space:nowrap}.edit-btn{background:#667eea;color:#fff}.edit-btn:hover{background:#5a67d8}.delete-btn:hover{background:#dc2626}.approve-btn{background:#10b981;color:#fff}.approve-btn:hover{background:#059669;transform:translateY(-1px);box-shadow:0 2px 8px #10b9814d}.approve-company-btn{background:#3b82f6;color:#fff}.approve-company-btn:hover{background:#2563eb;transform:translateY(-1px);box-shadow:0 2px 8px #3b82f64d}.reject-btn{background:#ef4444;color:#fff}.reject-btn:hover{background:#dc2626;transform:translateY(-1px);box-shadow:0 2px 8px #ef44444d}.reset-btn{background:#f59e0b;color:#fff}.reset-btn:hover{background:#d97706}.view-reason-btn{background:#6b7280;color:#fff}.view-reason-btn:hover{background:#4b5563}.reset-all-btn{background:#f59e0b;color:#fff;border:none;padding:.875rem 1.5rem;border-radius:8px;cursor:pointer;font-size:.9rem;font-weight:600;transition:all .2s ease;white-space:nowrap}.reset-all-btn:hover{background:#d97706;transform:translateY(-1px);box-shadow:0 4px 12px #f59e0b4d}.user-editor-view{padding:2rem;width:100%;box-sizing:border-box;max-width:100%}.editor-header h1{margin:0;color:#1e293b;font-size:2rem;font-weight:600}.editor-actions{display:flex;gap:.75rem;flex-wrap:wrap}.save-btn{background:#10b981;color:#fff;border:none;padding:.75rem 1.5rem;border-radius:6px;cursor:pointer;font-size:.9rem;font-weight:600;transition:all .2s ease}.save-btn:hover{background:#059669}.save-btn.primary{background:linear-gradient(135deg,#10b981,#059669);padding:1rem 2rem;font-size:1rem;box-shadow:0 2px 8px #10b9814d}.cancel-btn{background:#64748b;color:#fff;border:1px solid #64748b;padding:.75rem 1rem;border-radius:6px;cursor:pointer;font-size:.9rem;transition:all .2s ease}.cancel-btn:hover{background:#475569;border-color:#475569}.editor-form{background:#fff;border-radius:12px;padding:2rem;box-shadow:0 2px 12px #0000001a}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem;margin-bottom:1.5rem}.form-group label{font-weight:600;color:#374151;font-size:.9rem}.form-input,.form-select{padding:.75rem;border:1px solid #d1d5db;border-radius:6px;font-size:1rem;transition:border-color .2s ease;color:#374151;background:#fff}.form-input:focus,.form-select:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.form-actions{display:flex;gap:1rem;justify-content:flex-end;margin-top:2rem;padding-top:2rem;border-top:1px solid #e5e7eb}.pending-users-section{background:#fff;border-radius:12px;box-shadow:0 2px 12px #0000001a;margin-bottom:2rem;overflow:hidden;border:2px solid #3b82f6}.pending-header{background:linear-gradient(135deg,#3b82f6,#1d4ed8);color:#fff;padding:1.5rem 2rem;text-align:center}.pending-header h2{margin:0 0 .5rem;font-size:1.5rem;font-weight:600;display:flex;align-items:center;justify-content:center;gap:.5rem}.pending-count{background:#fff3;padding:.25rem .75rem;border-radius:20px;font-size:.9rem;font-weight:500}.pending-header p{margin:0;opacity:.9;font-size:1rem}.pending-users-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(400px,1fr));gap:1.5rem;padding:2rem}.pending-user-card{background:#f8fafc;border:1px solid #e2e8f0;border-radius:12px;padding:1.5rem;transition:all .2s ease;display:flex;flex-direction:column;gap:1rem}.pending-user-card:hover{transform:translateY(-2px);box-shadow:0 4px 16px #3b82f626;border-color:#3b82f6}.pending-user-info{flex:1}.pending-user-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:.75rem;gap:1rem}.pending-user-email{color:#1e293b;font-size:1.1rem;word-break:break-word;flex:1}.pending-user-name{color:#4b5563;font-size:1rem;font-weight:500;margin-bottom:1rem}.pending-user-details{display:flex;flex-direction:column;gap:.5rem}.pending-detail{display:flex;justify-content:space-between;align-items:center;font-size:.9rem;gap:1rem}.detail-label{font-weight:500;color:#6b7280;min-width:120px}.detail-value{color:#374151;font-weight:400;text-align:right;word-break:break-word}.pending-user-actions{display:flex;flex-wrap:wrap;gap:.5rem;padding-top:1rem;border-top:1px solid #e5e7eb}.pending-note{color:#f59e0b;font-size:.85rem;font-weight:500;font-style:italic;padding:.5rem 0;flex:1}@media (max-width: 768px){.user-list-view,.user-editor-view{padding:1rem}.list-header,.editor-header{flex-direction:column;align-items:stretch;gap:1rem}.form-row{grid-template-columns:1fr}.list-controls{flex-direction:column}.search-bar{min-width:auto}.filter-controls{flex-wrap:wrap}.users-table{overflow-x:auto}.actions-cell{flex-direction:column}.pending-users-grid{grid-template-columns:1fr;padding:1rem}.pending-header{padding:1rem}.pending-header h2{font-size:1.25rem;flex-direction:column;gap:.25rem}.pending-user-card{padding:1rem}.pending-user-header{flex-direction:column;align-items:flex-start;gap:.5rem}.pending-detail{flex-direction:column;align-items:flex-start;gap:.25rem}.detail-label{min-width:auto}.detail-value{text-align:left}.pending-user-actions{flex-direction:column}}.admin-assets{min-height:100vh;width:100vw;background-color:#f8fafc;font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;margin:0;padding:0}.viewing-as{font-size:1.1rem;font-weight:600;color:#cbd5e1}.tank-search{padding:0 1rem;margin-bottom:1rem}.search-input{width:100%;padding:.75rem;border:1px solid #d1d5db;border-radius:6px;font-size:.9rem;background:#fff;transition:border-color .2s ease}.search-input::placeholder{color:#9ca3af}.modal-content{background:#fff;border-radius:8px;max-width:500px;width:90%;max-height:90vh;overflow-y:auto;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a}.modal-form{padding:2rem}.modal-form h3{margin:0 0 1.5rem;font-size:1.25rem;font-weight:600;color:#1f2937}.form-group{margin-bottom:1rem}.form-group input[type=text],.form-group input[type=number],.form-group textarea,.form-group select,.form-select{width:100%;padding:.75rem;border:1px solid #d1d5db;border-radius:6px;font-size:.9rem;transition:border-color .2s ease}.form-group input[type=text]:focus,.form-group input[type=number]:focus,.form-group textarea:focus,.form-group select:focus,.form-select:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.form-group input[type=checkbox]{margin-right:.5rem;width:auto;appearance:none;-webkit-appearance:none;-moz-appearance:none;width:18px;height:18px;border:2px solid #d1d5db;border-radius:4px;background:#fff;cursor:pointer;position:relative;vertical-align:middle}.form-group input[type=checkbox]:checked{background:#3b82f6;border-color:#3b82f6}.form-group input[type=checkbox]:checked:after{content:"✓";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);color:#fff;font-size:12px;font-weight:700}.form-group input[type=checkbox]:focus{outline:none;box-shadow:0 0 0 3px #3b82f61a}.form-group textarea{resize:vertical;min-height:80px}.form-actions{display:flex;gap:.75rem;justify-content:flex-end;margin-top:1.5rem;padding-top:1rem;border-top:1px solid #e5e7eb}.form-actions button{padding:.5rem 1rem;border-radius:6px;font-size:.9rem;font-weight:500;cursor:pointer;transition:all .2s ease}.form-actions button[type=button]{background:#fff;color:#6b7280;border:1px solid #d1d5db}.form-actions button[type=button]:hover{background:#f9fafb;border-color:#9ca3af}.form-actions button[type=submit]{background:#3b82f6;color:#fff;border:1px solid #3b82f6}.form-actions button[type=submit]:hover:not(:disabled){background:#2563eb;border-color:#2563eb}.form-actions button:disabled{opacity:.5;cursor:not-allowed}.assets-content{display:flex;height:calc(100vh - 80px)}.assets-sidebar{width:400px;background:#fff;border-right:1px solid #e2e8f0;overflow-y:auto}.sidebar-section{padding:1.5rem;border-bottom:1px solid #e2e8f0}.sidebar-section h3{margin:0 0 1rem;color:#1e293b;font-size:1.1rem;font-weight:600}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.section-header h3{margin:0}.create-btn{background:#10b981;color:#fff;border:none;padding:.5rem 1rem;border-radius:6px;cursor:pointer;font-size:.875rem;font-weight:500;transition:all .2s ease}.create-btn:hover{background:#059669;transform:translateY(-1px)}.customer-list,.tank-list{display:flex;flex-direction:column;gap:.5rem}.customer-item,.tank-item{padding:1rem;border:2px solid #e2e8f0;border-radius:8px;cursor:pointer;transition:all .2s ease;background:#fff}.customer-item:hover,.tank-item:hover{border-color:#cbd5e1;transform:translate(2px)}.customer-item.active,.tank-item.active{border-color:#3b82f6;background:#eff6ff;transform:translate(4px)}.customer-name,.tank-number{font-weight:600;color:#1e293b;margin-bottom:.25rem}.customer-details,.tank-details{display:flex;flex-direction:column;gap:.25rem}.tank-count,.data-counts{font-size:.875rem;color:#6b7280;font-weight:500}.customer-email{font-size:.75rem;color:#9ca3af}.status{font-size:.75rem;padding:.25rem .5rem;border-radius:12px;font-weight:500;width:fit-content}.status.operational{background:#dcfce7;color:#166534}.status.inactive{background:#fee2e2;color:#991b1b}.assets-main{flex:1;padding:2rem;overflow-y:auto}.no-selection{text-align:center;padding:4rem 2rem;color:#6b7280}.no-selection h2{margin:0 0 1rem;color:#374151}.customer-overview{width:100%}.customer-overview h2{margin:0 0 2rem;color:#1e293b;font-size:1.75rem}.overview-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:1.5rem;margin-bottom:2rem}.stat-card{background:#fff;padding:1.5rem;border-radius:12px;border:1px solid #e2e8f0;text-align:center;box-shadow:0 1px 3px #0000001a}.stat-number{font-size:2rem;font-weight:700;color:#1e293b;margin-bottom:.5rem}.stat-label{font-size:.875rem;color:#6b7280;font-weight:500;text-transform:uppercase;letter-spacing:.5px}.tank-details{width:100%}.tank-details-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;padding-bottom:1rem;border-bottom:2px solid #e2e8f0}.tank-details-header h2{margin:0;color:#1e293b;font-size:1.75rem}.tank-actions{display:flex;gap:1rem}.edit-btn{background:#3b82f6;color:#fff;border:none;padding:.75rem 1.5rem;border-radius:8px;cursor:pointer;font-weight:500;transition:all .2s ease}.edit-btn:hover{background:#2563eb;transform:translateY(-1px)}.delete-btn{background:#ef4444;color:#fff;border:none;padding:.75rem 1.5rem;border-radius:8px;cursor:pointer;font-weight:500;transition:all .2s ease}.tank-info{background:#fff;padding:1.5rem;border-radius:12px;border:1px solid #e2e8f0;margin-bottom:2rem}.info-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1rem}.info-item{display:flex;flex-direction:column;gap:.25rem}.info-item label{font-size:.875rem;font-weight:600;color:#6b7280;text-transform:uppercase;letter-spacing:.5px}.info-item span{font-size:1rem;color:#1e293b;font-weight:500}.data-section{background:#fff;border-radius:12px;border:1px solid #e2e8f0;margin-bottom:2rem;overflow:hidden}.data-section .section-header{background:#f8fafc;padding:1rem 1.5rem;border-bottom:1px solid #e2e8f0}.data-section .section-header h3{color:#1e293b;font-size:1.1rem}.data-table{overflow-x:auto}.data-table table{width:100%;border-collapse:collapse}.data-table th{background:#374151;color:#fff;padding:1rem;text-align:left;font-size:.875rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.data-table td{padding:1rem;border-bottom:1px solid #f3f4f6;font-size:.875rem;color:#374151}.data-table tbody tr:hover{background:#f9fafb}.vacuum-value{font-weight:600;font-family:Courier New,monospace}.notes-cell{max-width:200px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.actions-cell{display:flex;gap:.5rem}.edit-small-btn{background:#3b82f6;color:#fff;border:none;padding:.25rem .75rem;border-radius:4px;cursor:pointer;font-size:.75rem;font-weight:500;transition:all .2s ease}.edit-small-btn:hover{background:#2563eb}.delete-small-btn{background:#ef4444;color:#fff;border:none;padding:.25rem .75rem;border-radius:4px;cursor:pointer;font-size:.75rem;font-weight:500;transition:all .2s ease}.delete-small-btn:hover{background:#dc2626}.no-data{text-align:center;padding:2rem;color:#6b7280;font-style:italic}.loading{display:flex;justify-content:center;align-items:center;height:100vh}.loading-text{font-size:1.2rem;color:#6b7280}@media (max-width: 768px){.assets-content{flex-direction:column;height:auto}.assets-sidebar{width:100%;height:auto}.tank-actions{flex-direction:column}.overview-stats{grid-template-columns:repeat(2,1fr)}.info-grid{grid-template-columns:1fr}}.manage-companies{min-height:100vh;width:100vw;background-color:#f8fafc;font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;margin:0;padding:0}.manage-companies.loading{display:flex;align-items:center;justify-content:center}.companies-list-view{padding:2rem;width:100%;box-sizing:border-box}.list-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;flex-wrap:wrap;gap:1rem}.list-header h1{margin:0;color:#1e293b;font-size:2rem;font-weight:700}.create-btn{background:linear-gradient(135deg,#10b981,#059669);color:#fff;border:none;padding:.75rem 1.5rem;border-radius:8px;cursor:pointer;font-weight:600;transition:all .2s ease;box-shadow:0 2px 4px #10b98133}.create-btn:hover{transform:translateY(-1px);box-shadow:0 4px 8px #10b9814d}.list-controls{display:flex;gap:1rem;margin-bottom:2rem;flex-wrap:wrap;align-items:center}.search-bar{flex:1;min-width:300px}.search-input{width:100%;padding:.75rem 1rem;border:1px solid #d1d5db;border-radius:8px;font-size:1rem;transition:border-color .2s ease,box-shadow .2s ease}.search-input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.filter-controls{display:flex;gap:1rem;align-items:center}.filter-select{padding:.75rem 1rem;border:1px solid #d1d5db;border-radius:8px;font-size:1rem;background:#fff;cursor:pointer;transition:border-color .2s ease}.filter-select:focus{outline:none;border-color:#667eea}.clear-filters{background:#f3f4f6;color:#374151;border:1px solid #d1d5db;padding:.75rem 1rem;border-radius:8px;cursor:pointer;transition:all .2s ease}.clear-filters:hover{background:#e5e7eb}.companies-table{background:#fff;border-radius:12px;overflow:hidden;box-shadow:0 1px 3px #0000001a}.companies-table table{width:100%;border-collapse:collapse}.companies-table th,.companies-table td{padding:1rem;text-align:left;border-bottom:1px solid #f1f5f9}.companies-table th{background:#f8fafc;font-weight:600;color:#475569;font-size:.875rem;text-transform:uppercase;letter-spacing:.05em}.companies-table tr:hover{background:#f8fafc}.company-name-cell strong{color:#1e293b;font-weight:600}.count-badge{background:#e0e7ff;color:#3730a3;padding:.25rem .75rem;border-radius:12px;font-size:.875rem;font-weight:500}.status-badge{padding:.25rem .75rem;border-radius:12px;font-size:.875rem;font-weight:500;text-transform:capitalize}.status-badge.active{background:#dcfce7;color:#166534}.status-badge.inactive{background:#fee2e2;color:#991b1b}.actions-cell{display:flex;gap:.5rem;align-items:center}.dashboard-btn{background:#667eea;color:#fff;border:none;padding:.5rem .75rem;border-radius:6px;cursor:pointer;font-size:.875rem;transition:all .2s ease}.dashboard-btn:hover{background:#5a67d8;transform:translateY(-1px)}.edit-btn{background:#f59e0b;color:#fff;border:none;padding:.5rem .75rem;border-radius:6px;cursor:pointer;font-size:.875rem;transition:all .2s ease}.edit-btn:hover{background:#d97706;transform:translateY(-1px)}.delete-btn{background:#ef4444;color:#fff;border:none;padding:.5rem .75rem;border-radius:6px;cursor:pointer;font-size:.875rem;transition:all .2s ease}.no-companies{text-align:center;padding:3rem;color:#64748b;background:#fff;border-radius:12px;box-shadow:0 1px 3px #0000001a}.company-editor-view{padding:2rem;width:100%;box-sizing:border-box}.editor-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;flex-wrap:wrap;gap:1rem}.editor-header h1{margin:0;color:#1e293b;font-size:2rem;font-weight:700}.editor-actions{display:flex;gap:1rem}.save-btn{background:linear-gradient(135deg,#10b981,#059669);color:#fff;border:none;padding:.75rem 1.5rem;border-radius:8px;cursor:pointer;font-weight:600;transition:all .2s ease;box-shadow:0 2px 4px #10b98133}.save-btn:hover{transform:translateY(-1px);box-shadow:0 4px 8px #10b9814d}.cancel-btn{background:#f3f4f6;color:#374151;border:1px solid #d1d5db;padding:.75rem 1.5rem;border-radius:8px;cursor:pointer;font-weight:600;transition:all .2s ease}.editor-form{background:#fff;padding:2rem;border-radius:12px;box-shadow:0 1px 3px #0000001a}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-bottom:1.5rem}.form-group label{display:block;margin-bottom:.5rem;font-weight:600;color:#374151}.form-input,.form-textarea,.form-select{width:100%;padding:.75rem 1rem;border:1px solid #d1d5db;border-radius:8px;font-size:1rem;transition:border-color .2s ease,box-shadow .2s ease}.form-input:focus,.form-textarea:focus,.form-select:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.form-textarea{resize:vertical;min-height:80px}.form-actions{display:flex;gap:1rem;padding-top:1rem;border-top:1px solid #e5e7eb;margin-top:2rem}.save-btn.primary{background:linear-gradient(135deg,#667eea,#764ba2)}@media (max-width: 768px){.list-header{flex-direction:column;align-items:stretch}.list-controls{flex-direction:column}.search-bar{min-width:auto}.filter-controls{flex-wrap:wrap}.companies-table{overflow-x:auto}.companies-table table{min-width:600px}.actions-cell{flex-direction:column;gap:.25rem}.form-row{grid-template-columns:1fr}.editor-header{flex-direction:column;align-items:stretch}.editor-actions{justify-content:stretch}.editor-actions button{flex:1}.form-actions{flex-direction:column}}.view-reports{min-height:100vh;width:100vw;background-color:#f8fafc;font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;margin:0;padding:0}.view-reports.loading{display:flex;align-items:center;justify-content:center}.admin-nav-header{background:#1e293b;color:#fff;padding:.75rem 0;border-bottom:1px solid #334155}.admin-nav-content{width:100%;padding:0 2rem;display:flex;justify-content:space-between;align-items:center}.back-to-admin-btn{background:transparent;color:#fff;border:1px solid #475569;padding:.5rem 1rem;border-radius:6px;cursor:pointer;font-size:.9rem;transition:all .2s ease}.back-to-admin-btn:hover{background:#475569;border-color:#64748b}.viewing-as{font-size:.9rem;color:#cbd5e1}.reports-content{padding:2rem;width:100%;box-sizing:border-box}.reports-header{margin-bottom:3rem}.reports-header h1{margin:0 0 .5rem;color:#1e293b;font-size:2.5rem;font-weight:700}.reports-subtitle{margin:0;color:#64748b;font-size:1.1rem}.platform-overview{margin-bottom:3rem}.platform-overview h2{margin:0 0 1.5rem;color:#1e293b;font-size:1.75rem;font-weight:600}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.5rem;margin-bottom:2rem}.stat-card{background:#fff;padding:1.5rem;border-radius:12px;box-shadow:0 1px 3px #0000001a;border:1px solid #e2e8f0;transition:all .2s ease}.stat-card:hover{transform:translateY(-2px);box-shadow:0 4px 8px #00000026}.stat-card.clickable{cursor:pointer;transition:all .2s ease}.stat-card.clickable:hover{transform:translateY(-3px);box-shadow:0 6px 12px #00000026}.stat-card.clickable:active{transform:translateY(-1px);box-shadow:0 2px 4px #0000001a}.stat-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.stat-header h3{margin:0;color:#374151;font-size:1rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.stat-icon{font-size:1.5rem;opacity:.8}.stat-main-number{font-size:2.5rem;font-weight:700;color:#1e293b;margin-bottom:.5rem;line-height:1}.stat-description{color:#64748b;font-size:.9rem;margin-top:.5rem}.stat-breakdown{display:flex;flex-direction:column;gap:.5rem;margin-top:1rem}.breakdown-item{display:flex;justify-content:space-between;align-items:center;padding:.25rem 0}.breakdown-label{color:#64748b;font-size:.875rem}.breakdown-value{font-weight:600;font-size:.875rem;padding:.25rem .5rem;border-radius:4px}.breakdown-value.approved{background:#dcfce7;color:#166534}.breakdown-value.pending{background:#fef3c7;color:#92400e}.breakdown-value.rejected{background:#fee2e2;color:#991b1b}.breakdown-value.operational{background:#dcfce7;color:#166534}.breakdown-value.non-operational{background:#fee2e2;color:#991b1b}.users-card{border-left:4px solid #3b82f6}.companies-card{border-left:4px solid #10b981}.assets-card{border-left:4px solid #f59e0b}.queue-card{border-left:4px solid #ef4444}.quick-action-btn{background:#ef4444;color:#fff;border:none;padding:.5rem 1rem;border-radius:6px;cursor:pointer;font-size:.875rem;font-weight:500;margin-top:1rem;transition:all .2s ease}.quick-action-btn:hover{background:#dc2626;transform:translateY(-1px)}.recent-activity h2{margin:0 0 1.5rem;color:#1e293b;font-size:1.75rem;font-weight:600}.activity-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(350px,1fr));gap:1.5rem}.activity-card{background:#fff;border-radius:12px;box-shadow:0 1px 3px #0000001a;border:1px solid #e2e8f0;overflow:hidden}.activity-header{background:#f8fafc;padding:1rem 1.5rem;border-bottom:1px solid #e2e8f0;display:flex;justify-content:space-between;align-items:center}.activity-header h3{margin:0;color:#374151;font-size:1rem;font-weight:600}.activity-count{background:#e0e7ff;color:#3730a3;padding:.25rem .75rem;border-radius:12px;font-size:.875rem;font-weight:600}.activity-list{padding:0;max-height:300px;overflow-y:auto}.activity-item{padding:1rem 1.5rem;border-bottom:1px solid #f1f5f9;display:flex;justify-content:space-between;align-items:center;transition:background-color .2s ease}.activity-item:last-child{border-bottom:none}.activity-item:hover{background:#f8fafc}.activity-main{display:flex;flex-direction:column;gap:.25rem;flex:1}.activity-main strong{color:#1e293b;font-weight:600;font-size:.9rem}.activity-company,.reading-value,.activity-user{color:#64748b;font-size:.8rem}.reading-value{font-family:Courier New,monospace;font-weight:600}.activity-meta{display:flex;flex-direction:column;align-items:flex-end;gap:.25rem}.activity-date{color:#9ca3af;font-size:.75rem}.status-badge{padding:.25rem .5rem;border-radius:12px;font-size:.75rem;font-weight:500;text-transform:capitalize}.status-badge.pending{background:#fef3c7;color:#92400e}.status-badge.email_verified{background:#dbeafe;color:#1e40af}.status-badge.rejected{background:#fee2e2;color:#991b1b}.no-activity{padding:2rem 1.5rem;text-align:center;color:#9ca3af;font-style:italic;font-size:.9rem}@media (max-width: 768px){.reports-content{padding:1rem}.reports-header h1{font-size:2rem}.stats-grid,.activity-grid{grid-template-columns:1fr}.activity-item{flex-direction:column;align-items:flex-start;gap:.5rem}.activity-meta{align-items:flex-start;flex-direction:row;gap:1rem}.stat-main-number{font-size:2rem}}@media (max-width: 480px){.admin-nav-content{padding:0 1rem}.breakdown-item{font-size:.8rem}.activity-header,.activity-item{padding:.75rem 1rem}}.email-verification{min-height:100vh;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;align-items:center;justify-content:center;padding:2rem;font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif}.verification-container{width:100%;max-width:500px}.verification-card{background:#fff;border-radius:16px;padding:3rem;box-shadow:0 20px 40px #0000001a;text-align:center}.verification-loading{display:flex;flex-direction:column;align-items:center;gap:1.5rem}.loading-spinner{width:60px;height:60px;border:4px solid #f3f4f6;border-top:4px solid #667eea;border-radius:50%;animation:spin 1s linear infinite}.verification-success,.verification-error{display:flex;flex-direction:column;align-items:center;gap:1.5rem}.success-icon{width:80px;height:80px;background:linear-gradient(135deg,#10b981,#059669);border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-size:2.5rem;font-weight:700}.error-icon{width:80px;height:80px;background:linear-gradient(135deg,#ef4444,#dc2626);border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-size:2.5rem;font-weight:700}.verification-card h2{margin:0;color:#1e293b;font-size:1.8rem;font-weight:600}.verification-loading h2{color:#667eea}.verification-card p{margin:0;color:#64748b;font-size:1.1rem;line-height:1.6}.next-steps{background:#f8fafc;border:1px solid #e2e8f0;border-radius:12px;padding:1.5rem;text-align:left;width:100%}.next-steps h3{margin:0 0 1rem;color:#1e293b;font-size:1.1rem;font-weight:600}.next-steps ul{margin:0;padding-left:1.5rem;color:#64748b;line-height:1.6}.next-steps li{margin-bottom:.5rem}.verification-actions{display:flex;flex-direction:column;gap:1rem;width:100%}.login-btn{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;padding:1rem 2rem;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s ease;text-decoration:none;display:inline-block}.login-btn:hover{transform:translateY(-2px);box-shadow:0 8px 20px #667eea4d}.login-btn.secondary{background:#64748b;color:#fff}.login-btn.secondary:hover{background:#475569;box-shadow:0 8px 20px #64748b4d}.resend-btn{background:#10b981;color:#fff;border:none;padding:1rem 2rem;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s ease}.resend-btn:hover{background:#059669;transform:translateY(-2px);box-shadow:0 8px 20px #10b9814d}@media (max-width: 768px){.email-verification{padding:1rem}.verification-card{padding:2rem}.verification-card h2{font-size:1.5rem}.success-icon,.error-icon{width:60px;height:60px;font-size:2rem}}.admin-settings{min-height:100vh;width:100vw;background-color:#f5f5f5;padding:2rem;margin:0;box-sizing:border-box}.settings-header{display:flex;align-items:center;gap:2rem;margin-bottom:2rem;background:#fff;padding:1.5rem;border-radius:8px;box-shadow:0 2px 4px #0000001a;width:100%;box-sizing:border-box}.settings-header h1{margin:0;color:#1e293b;font-size:1.75rem}.back-button{padding:.5rem 1rem;background:transparent;border:1px solid #e2e8f0;border-radius:6px;color:#64748b;cursor:pointer;transition:all .2s ease}.back-button:hover{background:#f8fafc;border-color:#cbd5e1;color:#475569}.error-message,.success-message{padding:1rem;margin-bottom:1rem;border-radius:6px;font-size:.875rem}.error-message{background:#fee2e2;color:#991b1b;border:1px solid #fecaca}.success-message{background:#dcfce7;color:#166534;border:1px solid #bbf7d0}.settings-tabs{display:flex;gap:.5rem;margin-bottom:2rem;background:#fff;padding:.5rem;border-radius:8px;box-shadow:0 2px 4px #0000001a;width:100%;box-sizing:border-box}.tab-btn{flex:1;padding:.75rem 1.5rem;background:transparent;border:none;border-radius:6px;color:#64748b;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s ease}.tab-btn:hover{background:#f8fafc;color:#475569}.tab-btn.active{background:#3b82f6;color:#fff}.settings-content{background:#fff;padding:2rem;border-radius:8px;box-shadow:0 2px 4px #0000001a;width:100%;box-sizing:border-box}.company-selector{display:flex;align-items:center;gap:1rem;margin-bottom:2rem;padding-bottom:2rem;border-bottom:1px solid #e2e8f0}.company-selector label{font-weight:500;color:#374151}.company-dropdown{min-width:200px;padding:.5rem 1rem;border:1px solid #e2e8f0;border-radius:6px;font-size:.875rem;background:#fff;cursor:pointer}.loading{text-align:center;padding:3rem;color:#64748b}.no-settings{text-align:center;padding:3rem;color:#64748b;font-style:italic}.settings-list{display:flex;flex-direction:column;gap:1.5rem}.setting-item{padding:1.5rem;background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;transition:all .2s ease}.setting-item:hover{border-color:#cbd5e1;box-shadow:0 2px 8px #0000000d}.setting-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.setting-header h4{margin:0;color:#1e293b;font-size:1rem;font-weight:600}.save-btn{padding:.5rem 1rem;background:#3b82f6;color:#fff;border:none;border-radius:6px;font-size:.875rem;cursor:pointer;transition:all .2s ease}.save-btn:disabled{background:#94a3b8;cursor:not-allowed}.setting-description{margin:0 0 1rem;color:#64748b;font-size:.875rem;line-height:1.5}.setting-control{display:flex;align-items:center}.setting-input,.setting-textarea{width:100%;max-width:400px;padding:.5rem 1rem;border:1px solid #e2e8f0;border-radius:6px;font-size:.875rem;font-family:inherit;transition:all .2s ease}.setting-input:focus,.setting-textarea:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.setting-textarea{resize:vertical;min-height:100px}.setting-toggle{display:flex;align-items:center;gap:1rem}.toggle-switch{position:relative;display:inline-block;width:50px;height:24px}.toggle-switch input{opacity:0;width:0;height:0}.toggle-slider{position:absolute;cursor:pointer;inset:0;background-color:#cbd5e1;transition:.4s;border-radius:24px}.toggle-slider:before{position:absolute;content:"";height:18px;width:18px;left:3px;bottom:3px;background-color:#fff;transition:.4s;border-radius:50%}.toggle-switch input:checked+.toggle-slider{background-color:#3b82f6}.toggle-switch input:checked+.toggle-slider:before{transform:translate(26px)}.toggle-label{color:#64748b;font-size:.875rem;font-weight:500}.working-hours-inputs{display:flex;align-items:center;gap:1rem}.working-hours-inputs input[type=time],.working-hours-inputs select{padding:.5rem 1rem;border:1px solid #e2e8f0;border-radius:6px;font-size:.875rem}.working-hours-inputs span{color:#64748b;font-size:.875rem}@media (max-width: 768px){.admin-settings{padding:1rem}.settings-header{flex-direction:column;align-items:flex-start;gap:1rem}.settings-tabs{flex-direction:column}.tab-btn{width:100%;text-align:left}.company-selector{flex-direction:column;align-items:stretch}.setting-header{flex-direction:column;align-items:flex-start;gap:.5rem}.working-hours-inputs{flex-wrap:wrap}}.user-settings{min-height:100vh;width:100vw;background-color:#f5f5f5;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;margin:0;padding:0}.user-settings.loading,.user-settings.error{display:flex;align-items:center;justify-content:center}.loading-text,.error-text{font-size:1.1rem;color:#64748b}.error-text{color:#ef4444}.settings-header{background:#fff;border-bottom:1px solid #e0e0e0;padding:1rem 0;width:100%;box-sizing:border-box}.settings-header-content{width:100%;padding:0 2rem;display:flex;justify-content:space-between;align-items:center}.settings-title h1{margin:0;color:#1e293b;font-size:1.75rem;font-weight:600}.settings-title p{margin:.25rem 0 0;color:#64748b;font-size:.9rem}.settings-nav{display:flex;align-items:center;gap:1rem}.nav-btn{padding:.5rem 1rem;border:1px solid #ddd;background:#fff;color:#666;border-radius:6px;cursor:pointer;font-size:.9rem;transition:all .2s ease;text-decoration:none}.nav-btn:hover{background:#f5f5f5;border-color:#bbb}.logout-btn{padding:.5rem 1rem;background:#ef4444;color:#fff;border:none;border-radius:6px;cursor:pointer;font-size:.9rem;transition:background-color .2s ease}.logout-btn:hover{background:#dc2626}.settings-main{width:100%;padding:2rem;box-sizing:border-box}.settings-container{width:100%;background:#fff;border-radius:12px;box-shadow:0 1px 3px #0000001a;overflow:hidden}.settings-tabs{display:flex;border-bottom:2px solid #e2e8f0;background:#f8fafc}.tab-btn{flex:1;padding:1rem 1.5rem;border:none;background:transparent;cursor:pointer;font-size:.9rem;font-weight:600;color:#64748b;transition:all .2s ease;border-bottom:3px solid transparent}.tab-btn:hover{background:#e2e8f0;color:#374151}.tab-btn.active{color:#3b82f6;background:#fff;border-bottom-color:#3b82f6}.message{margin:1.5rem 2rem;padding:1rem;border-radius:6px;font-size:.9rem;font-weight:500}.message.success{background:#dcfce7;color:#166534;border:1px solid #bbf7d0}.message.error{background:#fee2e2;color:#991b1b;border:1px solid #fecaca}.settings-content{padding:2rem}.settings-section h2{margin:0 0 1.5rem;color:#1e293b;font-size:1.25rem;font-weight:600}.profile-form,.security-form{width:100%}.form-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:2rem;margin-bottom:2rem}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-group label{font-size:.9rem;font-weight:500;color:#374151}.form-group input,.form-group select{padding:.75rem;border:2px solid #e2e8f0;border-radius:6px;font-size:.9rem;background:#fff;color:#374151;transition:border-color .2s ease,box-shadow .2s ease;-webkit-appearance:none;-moz-appearance:none;appearance:none}.form-group select{background-image:url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 20 20'%3e%3cpath stroke='%236b7280' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='M6 8l4 4 4-4'/%3e%3c/svg%3e");background-position:right .75rem center;background-repeat:no-repeat;background-size:1.5em 1.5em;padding-right:2.5rem;cursor:pointer}.form-group input:focus,.form-group select:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a;background:#fefefe}.form-group select:focus{background-image:url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 20 20'%3e%3cpath stroke='%233b82f6' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='M6 8l4 4 4-4'/%3e%3c/svg%3e")}.disabled-input{background:#f8fafc!important;color:#64748b!important;cursor:not-allowed!important}.disabled-input:focus{border-color:#e2e8f0!important;box-shadow:none!important}.security-form{max-width:600px}.security-form .form-grid{grid-template-columns:1fr;max-width:400px}.save-btn{background:#3b82f6;color:#fff;border:none;padding:.75rem 1.5rem;border-radius:6px;font-size:.9rem;font-weight:500;cursor:pointer;transition:background-color .2s ease}.info-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.5rem;max-width:600px}.info-item{display:flex;flex-direction:column;gap:.5rem}.info-item label{font-size:.9rem;font-weight:500;color:#64748b}.info-item span{font-size:.95rem;color:#1e293b;font-weight:600}.role-badge{padding:.25rem .75rem;border-radius:12px;font-size:.8rem;font-weight:500;text-transform:uppercase;letter-spacing:.025em;display:inline-block}.role-badge.admin{background:#fef3c7;color:#92400e}.role-badge.user{background:#e0f2fe;color:#0369a1}.status-badges{display:flex;gap:.5rem}.status-badge{padding:.25rem .75rem;border-radius:12px;font-size:.8rem;font-weight:500;display:inline-block}.status-badge.verified{background:#dcfce7;color:#166534}.status-badge.unverified{background:#fef3c7;color:#92400e}.status-badge.approved{background:#dcfce7;color:#166534}.status-badge.pending{background:#fee2e2;color:#991b1b}@media (max-width: 1024px){.form-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width: 768px){.settings-header-content{flex-direction:column;gap:1rem;padding:0 1rem}.settings-main{padding:1rem}.settings-content{padding:1.5rem}.form-grid{grid-template-columns:repeat(3,1fr)}.info-grid{grid-template-columns:1fr}.settings-tabs{flex-direction:column}.tab-btn{flex:none;text-align:left}.status-badges{flex-direction:column;align-items:flex-start}}@media (max-width: 480px){.settings-header-content{padding:0 .5rem}.settings-main{padding:.5rem}.settings-content{padding:1rem}.form-group input,.form-group select{padding:.5rem}.form-grid{grid-template-columns:1fr}}.weekly-update-notes{min-height:100vh;width:100vw;background-color:#f8fafc;font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;margin:0;padding:0}.header-container{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:1.5rem 2rem;box-shadow:0 2px 10px #0000001a;width:100%;margin:0 0 2rem;display:flex;justify-content:space-between;align-items:center}.header-container h1{margin:0;font-size:1.8rem;font-weight:600}.back-button{background:#fff3;color:#fff;border:1px solid rgba(255,255,255,.3);padding:.5rem 1rem;border-radius:6px;cursor:pointer;font-size:.9rem;transition:all .2s ease;text-decoration:none;font-weight:500}.back-button:hover{background:#ffffff4d;transform:translateY(-1px)}.controls{padding:0 2rem;display:flex;align-items:center;justify-content:space-between;gap:1.5rem;margin-bottom:2rem}.company-selector{display:flex;align-items:center;gap:.75rem}.company-selector label{font-weight:600;color:#374151;font-size:.95rem}.company-selector select{padding:.5rem 1rem;border:1px solid #e2e8f0;border-radius:6px;font-size:.9rem;background:#fff;color:#374151;cursor:pointer;transition:border-color .2s ease}.company-selector select:hover{border-color:#3b82f6}.tab-buttons{display:flex;gap:.5rem}.tab-button{background:#fff;color:#6b7280;border:1px solid #e2e8f0;padding:.5rem 1.25rem;border-radius:6px;cursor:pointer;font-size:.9rem;font-weight:500;transition:all .2s ease}.tab-button:hover{background:#f9fafb;color:#374151;border-color:#d1d5db}.tab-button.active{background:linear-gradient(135deg,#3b82f6,#1d4ed8);color:#fff;border-color:#3b82f6}.generate-section{padding:0 2rem}.generate-card{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;border:1px solid #e2e8f0;padding:2rem;margin-bottom:2rem}.generate-card h2{margin:0 0 .5rem;color:#1e293b;font-size:1.5rem;font-weight:600}.generate-card>p{color:#64748b;margin-bottom:2rem;line-height:1.6}.generate-form{margin-bottom:2rem}.date-inputs{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem;margin-bottom:2rem}.generate-report-btn{background:linear-gradient(135deg,#3b82f6,#1d4ed8);color:#fff;border:none;padding:1rem 2rem;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s ease;width:100%;max-width:500px;display:block;margin:0 auto}.generate-report-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 16px #3b82f64d}.generate-report-btn:disabled{opacity:.6;cursor:not-allowed}.report-preview{background:#f8fafc;border-radius:8px;padding:1.5rem;border:1px solid #e2e8f0}.report-preview h3{margin:0 0 1rem;color:#1e293b;font-size:1.1rem;font-weight:600}.report-preview ul{list-style:none;padding:0;margin:0}.report-preview li{color:#475569;margin-bottom:.5rem;font-size:.95rem}.generate-modal{max-width:600px}.generate-info{background:#f8fafc;border-radius:8px;padding:1rem;margin-bottom:1.5rem;border:1px solid #e2e8f0}.generate-info h3{margin:0 0 .5rem;color:#1e293b;font-size:1.1rem;font-weight:600}.generate-info p{margin:.25rem 0;color:#475569;font-size:.9rem}.admin-notes-section{margin-bottom:2rem}.admin-notes-section h3{margin:0 0 .5rem;color:#1e293b;font-size:1.1rem;font-weight:600}.admin-notes-section>p{color:#64748b;margin-bottom:1rem;font-size:.9rem}.admin-notes-textarea{width:100%;padding:.75rem;border:1px solid #e2e8f0;border-radius:6px;font-size:.9rem;font-family:inherit;transition:border-color .2s ease;resize:vertical;min-height:120px}.admin-notes-textarea:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.generate-actions{display:flex;gap:1rem;justify-content:flex-end}.confirm-generate-btn,.cancel-generate-btn{padding:.75rem 1.5rem;border:none;border-radius:6px;cursor:pointer;font-size:.9rem;font-weight:500;transition:all .2s ease}.confirm-generate-btn{background:linear-gradient(135deg,#10b981,#059669);color:#fff}.confirm-generate-btn:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 12px #10b98140}.confirm-generate-btn:disabled{opacity:.6;cursor:not-allowed}.cancel-generate-btn{background:#f3f4f6;color:#6b7280;border:1px solid #e5e7eb}.cancel-generate-btn:hover:not(:disabled){background:#e5e7eb;color:#374151}.add-button,.generate-button{background:#fff;color:#3b82f6;border:1px solid #3b82f6;padding:.5rem 1.25rem;border-radius:6px;cursor:pointer;font-size:.9rem;font-weight:500;transition:all .2s ease}.add-button:hover,.generate-button:hover{background:#3b82f6;color:#fff;transform:translateY(-1px);box-shadow:0 4px 12px #3b82f640}.generate-button{background:linear-gradient(135deg,#3b82f6,#1d4ed8);color:#fff;border-color:#3b82f6}.note-form{background:#fff;padding:2rem;margin:0 2rem 2rem;border-radius:12px;box-shadow:0 2px 8px #0000001a;border:1px solid #e2e8f0}.note-form h2{margin:0 0 1.5rem;color:#1e293b;font-size:1.25rem;font-weight:600}.form-group label{display:block;margin-bottom:.5rem;font-weight:600;color:#374151;font-size:.9rem}.form-group input,.form-group textarea{width:100%;padding:.75rem;border:1px solid #e2e8f0;border-radius:6px;font-size:.9rem;font-family:inherit;transition:border-color .2s ease}.form-group input:focus,.form-group textarea:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.form-group textarea{resize:vertical;min-height:200px}.form-actions{display:flex;gap:1rem;margin-top:1.5rem}.save-button,.cancel-button{padding:.5rem 1.5rem;border:none;border-radius:6px;cursor:pointer;font-size:.9rem;font-weight:500;transition:all .2s ease}.save-button{background:#10b981;color:#fff}.save-button:hover{background:#059669;transform:translateY(-1px);box-shadow:0 4px 12px #10b98140}.cancel-button{background:#f3f4f6;color:#6b7280;border:1px solid #e5e7eb}.cancel-button:hover{background:#e5e7eb;color:#374151}.notes-list{background:#fff;margin:0 2rem 2rem;padding:2rem;border-radius:12px;box-shadow:0 2px 8px #0000001a;border:1px solid #e2e8f0}.notes-list h2{margin:0 0 1.5rem;color:#1e293b;font-size:1.25rem;font-weight:600}.notes-list table{width:100%;border-collapse:collapse}.notes-list th{background:#f8fafc;color:#374151;padding:1rem;text-align:left;font-weight:600;font-size:.9rem;text-transform:uppercase;letter-spacing:.5px;border-bottom:2px solid #e5e7eb}.notes-list td{padding:1rem;color:#374151;font-size:.9rem;border-bottom:1px solid #f3f4f6}.notes-list tr:hover{background:#fafbfc}.note-preview{max-width:400px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:#6b7280}.actions{display:flex;gap:.5rem}.edit-button,.delete-button{padding:.375rem .75rem;border:none;border-radius:4px;cursor:pointer;font-size:.8rem;font-weight:500;transition:all .2s ease}.edit-button{background:#3b82f6;color:#fff}.edit-button:hover{background:#2563eb;transform:translateY(-1px)}.delete-button{background:#ef4444;color:#fff}.delete-button:hover{background:#dc2626;transform:translateY(-1px)}.reports-section{padding:0 2rem}.reports-section h2{margin:0 0 1.5rem;color:#1e293b;font-size:1.25rem;font-weight:600}.no-reports{background:#fff;padding:3rem;border-radius:12px;text-align:center;color:#6b7280;border:1px solid #e2e8f0}.no-reports p{margin:.5rem 0;font-size:.95rem}.reports-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:1.5rem;margin-bottom:2rem}.report-card{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;border:1px solid #e2e8f0;overflow:hidden;transition:transform .2s ease,box-shadow .2s ease}.report-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #00000026}.report-header{background:linear-gradient(135deg,#f8fafc,#f1f5f9);padding:1.25rem;border-bottom:1px solid #e2e8f0}.report-header h3{margin:0 0 .5rem;color:#1e293b;font-size:1.1rem;font-weight:600}.report-date{color:#64748b;font-size:.85rem}.report-summary{padding:1.25rem}.summary-row{display:flex;justify-content:space-between;align-items:center;padding:.5rem 0;border-bottom:1px solid #f3f4f6;font-size:.9rem}.summary-row:last-child{border-bottom:none}.summary-row span{color:#6b7280}.summary-row strong{color:#1e293b;font-weight:600}.summary-row strong.warning{color:#f59e0b}.summary-row strong.positive{color:#10b981}.summary-row strong.negative{color:#ef4444}.admin-notes-preview{margin-top:1rem;padding-top:1rem;border-top:1px solid #e2e8f0}.admin-notes-preview span{display:block;color:#6b7280;font-size:.85rem;font-weight:600;margin-bottom:.5rem}.admin-notes-preview p{color:#374151;font-size:.85rem;line-height:1.5;margin:0}.report-actions{padding:1rem 1.25rem;background:#f8fafc;border-top:1px solid #e2e8f0;display:flex;gap:.5rem}.view-btn,.regenerate-btn,.delete-btn{flex:1;padding:.5rem;border:none;border-radius:6px;cursor:pointer;font-size:.85rem;font-weight:500;transition:all .2s ease}.view-btn{background:#3b82f6;color:#fff}.view-btn:hover{background:#2563eb;transform:translateY(-1px)}.regenerate-btn{background:#f59e0b;color:#fff}.regenerate-btn:hover{background:#d97706;transform:translateY(-1px)}.delete-btn{background:#ef4444;color:#fff}.delete-btn:hover{background:#dc2626;transform:translateY(-1px)}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;justify-content:center;align-items:center;z-index:1000;padding:2rem}.modal-content{background:#fff;border-radius:12px;max-width:900px;width:100%;max-height:90vh;overflow:hidden;display:flex;flex-direction:column}.report-modal{animation:slideIn .3s ease}@keyframes slideIn{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.modal-header{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:1.5rem;display:flex;justify-content:space-between;align-items:center}.modal-header h2{margin:0;font-size:1.25rem;font-weight:600}.close-modal{background:#fff3;color:#fff;border:none;width:32px;height:32px;border-radius:50%;font-size:1.5rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s ease}.close-modal:hover{background:#ffffff4d}.modal-body{padding:2rem;overflow-y:auto;flex:1}.report-detail-header{margin-bottom:2rem}.report-detail-header h3{margin:0 0 .5rem;color:#1e293b;font-size:1.5rem;font-weight:600}.report-detail-header p{color:#64748b;font-size:.9rem;margin:.25rem 0}.report-sections{display:flex;flex-direction:column;gap:2rem}.report-section{background:#f8fafc;border-radius:8px;padding:1.5rem;border:1px solid #e2e8f0}.report-section h4{margin:0 0 1rem;color:#1e293b;font-size:1.1rem;font-weight:600}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem}.stat{background:#fff;padding:1rem;border-radius:6px;border:1px solid #e2e8f0}.stat label{display:block;color:#6b7280;font-size:.85rem;margin-bottom:.25rem}.stat span{color:#1e293b;font-size:1.1rem;font-weight:600}.stat span.warning{color:#f59e0b}.stat span.positive{color:#10b981}.stat span.negative{color:#ef4444}.admin-notes-full{background:#fff;padding:1rem;border-radius:6px;border:1px solid #e2e8f0;color:#374151;line-height:1.6;white-space:pre-wrap}.detail-table{width:100%;background:#fff;border-radius:6px;overflow:hidden;border:1px solid #e2e8f0}.detail-table thead{background:#f1f5f9}.detail-table th{padding:.75rem;text-align:left;font-weight:600;font-size:.85rem;color:#475569;text-transform:uppercase;letter-spacing:.5px}.detail-table td{padding:.75rem;color:#374151;font-size:.9rem;border-top:1px solid #e2e8f0}.detail-table td.warning{color:#f59e0b;font-weight:600}.error-message{background-color:#fee;color:#dc2626;padding:1rem;border-radius:6px;margin:0 2rem 1.5rem;border:1px solid #fecaca;font-size:.9rem}.loading{display:flex;justify-content:center;align-items:center;height:50vh;font-size:1.2rem;color:#64748b}@media (max-width: 768px){.header-container{flex-direction:column;gap:1rem;text-align:center}.controls{flex-direction:column;align-items:stretch;gap:1rem}.company-selector{justify-content:space-between}.tab-buttons{width:100%;justify-content:stretch}.tab-button{flex:1}.date-inputs{grid-template-columns:1fr}.generate-actions{flex-direction:column}.confirm-generate-btn,.cancel-generate-btn{width:100%}.reports-grid{grid-template-columns:1fr}.notes-list{overflow-x:auto}.notes-list table{min-width:600px}.form-actions{flex-direction:column}.save-button,.cancel-button{width:100%}.modal-content{max-width:100%;margin:1rem}.stats-grid{grid-template-columns:1fr}}.teacher-dashboard{min-height:100vh;width:100vw;background-color:#f8fafc;font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;margin:0;padding:0}.teacher-dashboard.loading{display:flex;align-items:center;justify-content:center}.dashboard-header{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:2rem 0;box-shadow:0 2px 10px #0000001a}.header-content{max-width:1200px;margin:0 auto;padding:0 2rem;display:flex;justify-content:space-between;align-items:center}.teacher-info h1{margin:0 0 .5rem;font-size:2rem;font-weight:600}.school-info{margin:0;font-size:1rem;opacity:.9}.header-actions{display:flex;gap:1rem}.settings-btn,.logout-btn{background:#fff3;color:#fff;border:1px solid rgba(255,255,255,.3);padding:.5rem 1rem;border-radius:6px;cursor:pointer;font-size:.9rem;transition:all .2s ease}.settings-btn:hover,.logout-btn:hover{background:#ffffff4d;transform:translateY(-1px)}.dashboard-main{max-width:1200px;margin:0 auto;padding:2rem;display:grid;grid-template-columns:1fr;gap:2rem}.quick-actions h2{color:#1e293b;font-size:1.5rem;font-weight:600;margin:0 0 1.5rem}.actions-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem}.action-btn{background:#fff;border:1px solid #e2e8f0;border-radius:12px;padding:1.5rem;cursor:pointer;display:flex;flex-direction:column;align-items:center;gap:.75rem;transition:all .2s ease;text-decoration:none}.action-btn:hover{border-color:#3b82f6;transform:translateY(-2px);box-shadow:0 4px 12px #3b82f626}.action-icon{font-size:2rem}.action-text{font-weight:500;color:#374151;text-align:center}.action-btn.create-lesson:hover{border-color:#10b981;box-shadow:0 4px 12px #10b98126}.action-btn.ai-assistant{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.action-btn.ai-assistant .action-text{color:#fff}.action-btn.ai-assistant:hover{transform:translateY(-2px);box-shadow:0 6px 16px #667eea66}.todays-schedule h2{color:#1e293b;font-size:1.5rem;font-weight:600;margin:0 0 1.5rem}.no-events{background:#fff;border-radius:12px;padding:2rem;text-align:center;border:1px solid #e2e8f0}.no-events p{color:#6b7280;margin:0 0 1rem}.schedule-btn{background:#3b82f6;color:#fff;border:none;padding:.5rem 1rem;border-radius:6px;cursor:pointer;font-size:.9rem;transition:all .2s ease}.schedule-btn:hover{background:#2563eb;transform:translateY(-1px)}.events-list{display:grid;gap:1rem}.event-card{background:#fff;border-radius:12px;padding:1.5rem;border:1px solid #e2e8f0;display:flex;align-items:center;gap:1rem;transition:all .2s ease}.event-card:hover{border-color:#3b82f6;box-shadow:0 2px 8px #3b82f61a}.event-time{font-weight:600;color:#3b82f6;min-width:120px}.event-content{flex:1}.event-content h3{margin:0 0 .5rem;color:#1e293b;font-size:1rem}.subject-tag{display:inline-block;padding:.25rem .75rem;border-radius:12px;color:#fff;font-size:.75rem;font-weight:500}.view-lesson-btn{background:#f3f4f6;color:#374151;border:1px solid #e5e7eb;padding:.375rem .75rem;border-radius:4px;cursor:pointer;font-size:.8rem;transition:all .2s ease}.view-lesson-btn:hover{background:#e5e7eb}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.section-header h2{color:#1e293b;font-size:1.5rem;font-weight:600;margin:0}.view-all-btn{background:#f3f4f6;color:#374151;border:1px solid #e5e7eb;padding:.5rem 1rem;border-radius:6px;cursor:pointer;font-size:.9rem;transition:all .2s ease}.view-all-btn:hover{background:#e5e7eb}.no-lessons{background:#fff;border-radius:12px;padding:2rem;text-align:center;border:1px solid #e2e8f0}.no-lessons p{color:#6b7280;margin:0 0 1rem}.create-first-btn{background:#10b981;color:#fff;border:none;padding:.5rem 1rem;border-radius:6px;cursor:pointer;font-size:.9rem;transition:all .2s ease}.create-first-btn:hover{background:#059669;transform:translateY(-1px)}.lessons-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1rem}.lesson-card{background:#fff;border-radius:12px;padding:1.5rem;border:1px solid #e2e8f0;transition:all .2s ease}.lesson-card:hover{border-color:#3b82f6;box-shadow:0 2px 8px #3b82f61a}.lesson-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1rem;gap:1rem}.lesson-header h3{margin:0;color:#1e293b;font-size:1rem;flex:1}.lesson-meta{display:flex;justify-content:space-between;margin-bottom:1rem;font-size:.8rem;color:#6b7280}.lesson-actions{display:flex;gap:.5rem}.view-btn,.edit-btn{flex:1;padding:.375rem .75rem;border-radius:4px;cursor:pointer;font-size:.8rem;transition:all .2s ease}.view-btn{background:#f3f4f6;color:#374151;border:1px solid #e5e7eb}.view-btn:hover{background:#e5e7eb}.edit-btn{background:#3b82f6;color:#fff;border:1px solid #3b82f6}.edit-btn:hover{background:#2563eb}.subjects-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem}.subject-card{background:#fff;border-radius:12px;padding:1.5rem;border:1px solid #e2e8f0;display:flex;align-items:center;gap:1rem;transition:all .2s ease}.subject-card:hover{border-color:#3b82f6;box-shadow:0 2px 8px #3b82f61a}.subject-color{width:12px;height:40px;border-radius:6px}.subject-info{flex:1}.subject-info h3{margin:0 0 .25rem;color:#1e293b;font-size:1rem}.subject-info p{margin:0;color:#6b7280;font-size:.8rem}.view-subject-btn{background:#f3f4f6;color:#374151;border:1px solid #e5e7eb;padding:.375rem .75rem;border-radius:4px;cursor:pointer;font-size:.8rem;transition:all .2s ease}.view-subject-btn:hover{background:#e5e7eb}@media (max-width: 768px){.header-content{flex-direction:column;gap:1rem;text-align:center}.dashboard-main{padding:1rem}.actions-grid{grid-template-columns:repeat(2,1fr)}.lessons-grid,.subjects-grid{grid-template-columns:1fr}.event-card{flex-direction:column;align-items:flex-start;gap:.75rem}.event-time{min-width:auto}}.template-manager{min-height:100vh;width:100vw!important;background-color:#f8fafc;font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif}.template-manager.loading{display:flex;align-items:center;justify-content:center}.loading-text{font-size:1.1rem;color:#64748b}.teacher-nav-header{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:1rem 0;box-shadow:0 2px 10px #0000001a}.teacher-nav-content{max-width:1200px;margin:0 auto;padding:0 2rem;display:flex;justify-content:space-between;align-items:center}.back-to-teacher-btn{background:#fff3;color:#fff;border:1px solid rgba(255,255,255,.3);padding:.5rem 1rem;border-radius:6px;cursor:pointer;font-size:.9rem;transition:all .2s ease}.back-to-teacher-btn:hover{background:#ffffff4d;transform:translateY(-1px)}.viewing-as{font-size:1.1rem;font-weight:500}.template-manager-content{max-width:1200px!important;margin:0 auto!important;padding:2rem}.template-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}.template-header h1{color:#1e293b;font-size:2rem;font-weight:600;margin:0}.template-actions{display:flex;gap:1rem}.preset-btn,.create-btn{padding:.75rem 1.5rem;border-radius:8px;border:none;font-weight:500;cursor:pointer;transition:all .2s ease;text-decoration:none;display:inline-flex;align-items:center;gap:.5rem}.preset-btn{background:#f3f4f6;color:#374151;border:1px solid #e5e7eb}.preset-btn:hover{background:#e5e7eb;transform:translateY(-1px)}.create-btn{background:#3b82f6;color:#fff}.create-btn:hover{background:#2563eb;transform:translateY(-1px)}.preset-btn.large{padding:1rem 2rem;font-size:1.1rem}.templates-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:1.5rem}.no-templates{grid-column:1 / -1;text-align:center;padding:4rem 2rem;background:#fff;border-radius:12px;border:1px solid #e2e8f0}.no-templates h3{color:#1e293b;font-size:1.5rem;margin:0 0 1rem}.no-templates p{color:#6b7280;margin:0 0 2rem}.template-card{background:#fff;border-radius:12px;padding:1.5rem;border:1px solid #e2e8f0;transition:all .2s ease}.template-card:hover{border-color:#3b82f6;box-shadow:0 4px 12px #3b82f626;transform:translateY(-2px)}.template-card .template-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1rem;gap:1rem}.template-card .template-header h3{margin:0;color:#1e293b;font-size:1.25rem;flex:1}.default-badge{background:#10b981;color:#fff;padding:.25rem .75rem;border-radius:12px;font-size:.75rem;font-weight:500;white-space:nowrap}.template-description{color:#6b7280;margin:0 0 1.5rem;line-height:1.5}.template-meta{margin-bottom:1.5rem}.meta-item{margin-bottom:.5rem;font-size:.9rem;color:#6b7280}.meta-item strong{color:#374151}.template-card .template-actions{display:flex;gap:.5rem;margin:0}.edit-btn,.use-btn,.delete-btn{flex:1;padding:.5rem .75rem;border-radius:6px;border:1px solid;font-size:.8rem;cursor:pointer;transition:all .2s ease;text-align:center}.edit-btn{background:#f3f4f6;color:#374151;border-color:#e5e7eb}.edit-btn:hover{background:#e5e7eb}.use-btn{background:#10b981;color:#fff;border-color:#10b981}.use-btn:hover{background:#059669}.delete-btn{background:#fee2e2;color:#dc2626;border-color:#fecaca}.delete-btn:hover{background:#fecaca}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.modal{background:#fff;border-radius:12px;max-width:500px;width:90%;max-height:90vh;overflow-y:auto;box-shadow:0 10px 30px #0003}.modal.large{max-width:800px}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;border-bottom:1px solid #e2e8f0}.modal-header h2{margin:0;color:#1e293b}.close-btn{background:none;border:none;font-size:1.5rem;cursor:pointer;color:#6b7280;padding:0;width:2rem;height:2rem;display:flex;align-items:center;justify-content:center;border-radius:4px}.close-btn:hover{background:#f3f4f6;color:#374151}.modal-content{padding:1.5rem}.form-group{margin-bottom:1.5rem}.form-group label{display:block;margin-bottom:.5rem;font-weight:500;color:#374151}.form-input,.form-textarea{width:100%;padding:.75rem;border:1px solid #e5e7eb;border-radius:6px;font-size:1rem;transition:border-color .2s ease}.form-input:focus,.form-textarea:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.modal-actions{display:flex;gap:1rem;padding:1.5rem;border-top:1px solid #e2e8f0;justify-content:flex-end}.save-btn,.cancel-btn{padding:.75rem 1.5rem;border-radius:6px;border:none;font-weight:500;cursor:pointer;transition:all .2s ease}.save-btn{background:#3b82f6;color:#fff}.save-btn:hover:not(:disabled){background:#2563eb}.cancel-btn{background:#f3f4f6;color:#374151;border:1px solid #e5e7eb}.cancel-btn:hover{background:#e5e7eb}.presets-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1rem}.preset-card{background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;padding:1.5rem;transition:all .2s ease}.preset-card:hover{border-color:#3b82f6;box-shadow:0 2px 8px #3b82f61a}.preset-card h3{margin:0 0 .5rem;color:#1e293b;font-size:1.1rem}.preset-card p{margin:0 0 1rem;color:#6b7280;font-size:.9rem;line-height:1.4}.preset-meta{margin-bottom:1rem;font-size:.8rem;color:#6b7280}.preset-meta div{margin-bottom:.25rem}.use-preset-btn{width:100%;padding:.75rem;background:#3b82f6;color:#fff;border:none;border-radius:6px;font-weight:500;cursor:pointer;transition:all .2s ease}.use-preset-btn:hover{background:#2563eb;transform:translateY(-1px)}@media (max-width: 768px){.template-manager-content{padding:1rem}.template-header{flex-direction:column;gap:1rem;align-items:stretch}.template-actions{justify-content:center}.templates-grid{grid-template-columns:1fr}.modal{width:95%;margin:1rem}.modal-actions{flex-direction:column}.presets-grid{grid-template-columns:1fr}}.lesson-create-container{min-height:100vh;width:100vw;background-color:#f8fafc;font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;padding:20px;box-sizing:border-box}.required-indicator{color:#ef4444;font-weight:400;font-size:18px;margin-left:4px}.lesson-create-loading{display:flex;justify-content:center;align-items:center;height:100vh;font-size:18px;color:#64748b}.lesson-create-header{text-align:center;margin-bottom:40px}.lesson-create-header h1{font-size:32px;font-weight:700;color:#1e293b;margin-bottom:8px}.lesson-create-header p{font-size:16px;color:#64748b;margin-bottom:20px}.change-template-btn{background:#f1f5f9;color:#475569;border:1px solid #cbd5e1;padding:8px 16px;border-radius:6px;font-size:14px;cursor:pointer;transition:all .2s}.change-template-btn:hover{background:#e2e8f0}.templates-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:20px;margin-bottom:40px;max-width:1200px;margin-left:auto;margin-right:auto}.template-card{background:#fff;border:1px solid #e2e8f0;border-radius:12px;padding:24px;cursor:pointer;transition:all .2s;position:relative}.template-card:hover{border-color:#3b82f6;box-shadow:0 4px 12px #3b82f61a;transform:translateY(-2px)}.template-card h3{font-size:20px;font-weight:600;color:#1e293b;margin-bottom:8px}.template-card p{color:#64748b;margin-bottom:20px;line-height:1.5}.select-template-btn{background:#3b82f6;color:#fff;border:none;padding:10px 20px;border-radius:6px;font-weight:500;cursor:pointer;transition:background .2s;width:100%}.select-template-btn:hover{background:#2563eb}.lesson-details-section{background:#fff;border-radius:12px;padding:32px;margin-bottom:32px;box-shadow:0 1px 3px #0000001a;max-width:1200px;margin-left:auto;margin-right:auto}.lesson-details-section h2{font-size:24px;font-weight:600;color:#1e293b;margin-bottom:24px}.lesson-form{display:flex;flex-direction:column;gap:20px}.form-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:20px}.form-group input,.form-group select{padding:12px;border:1px solid #d1d5db;border-radius:6px;font-size:16px;transition:border-color .2s}.lesson-sections{max-width:1200px;margin:0 auto 40px}.lesson-sections h2{font-size:24px;font-weight:600;color:#1e293b;margin-bottom:8px}.sections-help{color:#64748b;margin-bottom:24px;font-size:14px}.lesson-section{background:#fff;border:1px solid #e2e8f0;border-radius:12px;padding:24px;margin-bottom:16px;transition:all .2s}.lesson-section.section-disabled{opacity:.6;background:#f8fafc}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.section-header h3{font-size:18px;font-weight:600;color:#1e293b;margin:0}.include-checkbox{display:flex;align-items:center;font-size:14px;color:#64748b;cursor:pointer}.include-checkbox input{margin-right:8px;cursor:pointer}.section-content textarea{width:100%;padding:12px;border:1px solid #d1d5db;border-radius:6px;font-size:14px;font-family:inherit;resize:vertical;min-height:100px}.section-content textarea:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.lesson-create-actions{display:flex;justify-content:center;gap:16px;max-width:1200px;margin:0 auto;padding:20px 0}.cancel-btn{background:#f1f5f9;color:#475569;border:1px solid #cbd5e1;padding:12px 24px;border-radius:6px;font-size:16px;font-weight:500;cursor:pointer;transition:all .2s}.cancel-btn:hover{background:#e2e8f0}.save-btn{background:#059669;color:#fff;border:none;padding:12px 24px;border-radius:6px;font-size:16px;font-weight:500;cursor:pointer;transition:background .2s}.save-btn:hover:not(:disabled){background:#047857}.save-btn:disabled{background:#9ca3af;cursor:not-allowed}.lesson-attachments-section{background:#fff;border-radius:12px;padding:32px;margin-bottom:32px;box-shadow:0 1px 3px #0000001a;max-width:1200px;margin-left:auto;margin-right:auto}.lesson-attachments-section h2{font-size:24px;font-weight:600;color:#1e293b;margin-bottom:8px}.attachments-help{color:#64748b;margin-bottom:24px;font-size:14px}.file-upload-label{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px 20px;border:2px dashed #cbd5e1;border-radius:12px;background:#f8fafc;cursor:pointer;transition:all .2s;text-align:center}.upload-icon{font-size:32px;margin-bottom:12px}.upload-text{font-size:16px;color:#374151;margin-bottom:8px}.upload-hint{font-size:12px;color:#64748b}.attachments-list{border-top:1px solid #e2e8f0;padding-top:24px}.attachments-list h3{font-size:18px;font-weight:600;color:#1e293b;margin-bottom:16px}.attachment-item{position:relative;border:1px solid #e2e8f0;border-radius:8px;padding:20px;margin-bottom:16px;background:#f8fafc;transition:all .2s}.attachment-info{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.attachment-name{display:flex;align-items:center;font-weight:500;color:#1e293b;gap:8px}.file-icon{font-size:16px}.attachment-size{font-size:12px;color:#64748b}.attachment-details{margin-bottom:8px}.attachment-details .form-group{margin-bottom:0}.attachment-details .form-group label{font-size:12px;margin-bottom:4px}.attachment-details .form-group input,.attachment-details .form-group select{padding:8px 12px;font-size:14px}.remove-attachment-btn{position:absolute;top:12px;right:12px;background:#fef2f2;color:#dc2626;border:1px solid #fecaca;border-radius:4px;width:24px;height:24px;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:12px;transition:all .2s}@media (max-width: 768px){.lesson-create-container{padding:16px}.lesson-create-header h1{font-size:24px}.templates-grid,.form-row{grid-template-columns:1fr}.section-header{flex-direction:column;align-items:flex-start;gap:12px}.lesson-create-actions{flex-direction:column}.attachment-info{flex-direction:column;align-items:flex-start;gap:8px}.attachment-details .form-row{grid-template-columns:1fr}.file-upload-label{padding:30px 16px}.upload-icon{font-size:24px}}.lesson-plans-container{min-height:100vh;width:100vw;background-color:#f8fafc;font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;padding:20px;box-sizing:border-box}.lesson-plans-loading{display:flex;justify-content:center;align-items:center;height:100vh;font-size:18px;color:#64748b}.lesson-plans-header{max-width:1200px;margin:0 auto 32px}.header-content{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px}.header-content h1{font-size:32px;font-weight:700;color:#1e293b;margin:0}.create-lesson-btn{background:#059669;color:#fff;border:none;padding:12px 24px;border-radius:8px;font-size:16px;font-weight:500;cursor:pointer;transition:background .2s;display:flex;align-items:center;gap:8px}.create-lesson-btn:hover{background:#047857}.plus-icon{font-size:20px;font-weight:300}.lesson-plans-filters{display:flex;gap:16px;align-items:center}.search-box{flex:1;max-width:400px}.search-input{width:100%;padding:10px 16px;border:1px solid #d1d5db;border-radius:8px;font-size:16px;background:#fff}.search-input:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.subject-select{padding:10px 16px;border:1px solid #d1d5db;border-radius:8px;font-size:16px;background:#fff;cursor:pointer;min-width:150px}.subject-select:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.no-lesson-plans{text-align:center;max-width:500px;margin:80px auto;padding:40px;background:#fff;border-radius:16px;box-shadow:0 1px 3px #0000001a}.no-plans-icon{font-size:64px;margin-bottom:24px}.no-lesson-plans h3{font-size:24px;font-weight:600;color:#1e293b;margin-bottom:12px}.no-lesson-plans p{color:#64748b;line-height:1.6;margin-bottom:32px}.create-first-lesson-btn{background:#3b82f6;color:#fff;border:none;padding:14px 28px;border-radius:8px;font-size:16px;font-weight:500;cursor:pointer;transition:background .2s}.create-first-lesson-btn:hover{background:#2563eb}.lesson-plans-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:24px;max-width:1200px;margin:0 auto}.lesson-plan-card{background:#fff;border:1px solid #e2e8f0;border-radius:12px;overflow:hidden;transition:all .2s;cursor:pointer}.lesson-plan-card:hover{border-color:#3b82f6;box-shadow:0 4px 12px #3b82f61a;transform:translateY(-2px)}.lesson-plan-header{display:flex;justify-content:space-between;align-items:center;padding:16px 20px 12px}.lesson-plan-subject{color:#fff;padding:4px 12px;border-radius:16px;font-size:12px;font-weight:500;text-transform:uppercase;letter-spacing:.5px}.lesson-plan-actions{display:flex;gap:8px}.action-btn{background:none;border:none;padding:6px;border-radius:6px;cursor:pointer;font-size:14px;transition:background .2s}.action-btn:hover{background:#f1f5f9}.delete-btn:hover{background:#fef2f2}.lesson-plan-content{padding:0 20px 20px}.lesson-plan-title{font-size:18px;font-weight:600;color:#1e293b;margin-bottom:12px;line-height:1.4}.lesson-plan-meta{display:flex;gap:16px;margin-bottom:16px}.meta-item{display:flex;gap:4px;font-size:14px}.meta-label{color:#64748b}.meta-value{color:#1e293b;font-weight:500}.lesson-plan-preview{margin-bottom:16px;font-size:14px}.lesson-plan-preview strong{color:#374151;display:block;margin-bottom:4px}.lesson-plan-preview p{color:#64748b;line-height:1.5;margin:0}.lesson-plan-footer{display:flex;justify-content:space-between;align-items:center;padding-top:16px;border-top:1px solid #f1f5f9}.lesson-plan-date{font-size:12px;color:#64748b}.view-lesson-btn{background:#f8fafc;color:#475569;border:1px solid #e2e8f0;padding:6px 12px;border-radius:6px;font-size:12px;font-weight:500;cursor:pointer;transition:all .2s}.view-lesson-btn:hover{background:#e2e8f0;border-color:#cbd5e1}.lesson-plans-footer{max-width:1200px;margin:40px auto 0;text-align:center}.back-to-dashboard-btn{background:#f1f5f9;color:#475569;border:1px solid #cbd5e1;padding:12px 24px;border-radius:8px;font-size:16px;font-weight:500;cursor:pointer;transition:all .2s}.back-to-dashboard-btn:hover{background:#e2e8f0}@media (max-width: 768px){.lesson-plans-container{padding:16px}.header-content{flex-direction:column;gap:16px;align-items:stretch}.header-content h1{text-align:center;font-size:24px}.lesson-plans-filters{flex-direction:column;gap:12px}.lesson-plans-grid{grid-template-columns:1fr}.lesson-plan-meta{flex-direction:column;gap:8px}.lesson-plan-footer{flex-direction:column;gap:12px;align-items:flex-start}}.lesson-view-container{min-height:100vh;width:100vw;background-color:#f8fafc;font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;padding:20px;box-sizing:border-box}.lesson-view-loading{display:flex;justify-content:center;align-items:center;height:100vh;font-size:18px;color:#64748b}.lesson-view-error{text-align:center;max-width:500px;margin:100px auto;padding:40px;background:#fff;border-radius:12px;box-shadow:0 1px 3px #0000001a}.lesson-view-error h2{color:#dc2626;margin-bottom:16px}.lesson-view-error p{color:#64748b;margin-bottom:24px}.lesson-view-header{background:#fff;border-radius:12px;padding:32px;margin-bottom:24px;box-shadow:0 1px 3px #0000001a;max-width:1200px;margin-left:auto;margin-right:auto}.header-content{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:24px}.lesson-title-section{flex:1}.lesson-title{font-size:32px;font-weight:700;color:#1e293b;margin:0;line-height:1.2}.action-btn{display:flex;align-items:center;gap:8px;padding:10px 16px;border:1px solid #e2e8f0;border-radius:8px;background:#fff;color:#64748b;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s}.action-btn:hover{border-color:#cbd5e1;background:#f8fafc}.edit-btn:hover{border-color:#3b82f6;color:#3b82f6}.print-btn:hover{border-color:#059669;color:#059669}.delete-btn:hover{border-color:#dc2626;color:#dc2626;background:#fef2f2}.lesson-metadata{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:24px;padding-top:24px;border-top:1px solid #f1f5f9}.metadata-item{display:flex;flex-direction:column;gap:4px}.metadata-label{font-size:12px;font-weight:500;color:#64748b;text-transform:uppercase;letter-spacing:.5px}.metadata-value{font-size:16px;font-weight:500;color:#1e293b}.lesson-content{max-width:1200px;margin:0 auto 32px}.lesson-section{background:#fff;border-radius:12px;padding:32px;margin-bottom:20px;box-shadow:0 1px 3px #0000001a}.section-title{font-size:20px;font-weight:600;color:#1e293b;margin:0 0 16px;padding-bottom:8px;border-bottom:2px solid #f1f5f9}.section-content{color:#374151;line-height:1.7}.section-content p{margin:0 0 12px}.section-content p:last-child{margin-bottom:0}.no-content{background:#fff;border-radius:12px;padding:60px 32px;text-align:center;box-shadow:0 1px 3px #0000001a}.no-content p{color:#64748b;font-size:16px;margin-bottom:24px}.add-content-btn{background:#3b82f6;color:#fff;border:none;padding:12px 24px;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:background .2s}.add-content-btn:hover{background:#2563eb}.lesson-view-footer{display:flex;justify-content:space-between;align-items:center;max-width:1200px;margin:0 auto;padding:20px 0}.back-to-list-btn{background:#f1f5f9;color:#475569;border:1px solid #cbd5e1;padding:12px 20px;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s}.back-to-list-btn:hover{background:#e2e8f0}.edit-lesson-btn{background:#3b82f6;color:#fff;border:none;padding:12px 20px;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:background .2s}.edit-lesson-btn:hover{background:#2563eb}.lesson-attachments{background:#fff;border-radius:12px;padding:32px;margin-bottom:24px;box-shadow:0 1px 3px #0000001a;max-width:1200px;margin-left:auto;margin-right:auto}.attachments-title{font-size:24px;font-weight:600;color:#1e293b;margin-bottom:24px;border-bottom:2px solid #f1f5f9;padding-bottom:8px}.attachments-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:20px}.attachment-card{border:1px solid #e2e8f0;border-radius:8px;padding:20px;background:#f8fafc;transition:all .2s}.file-icon{font-size:24px;flex-shrink:0}.attachment-meta{display:flex;gap:8px;font-size:12px;color:#64748b}.attachment-description{color:#64748b;font-size:14px;margin-bottom:16px;line-height:1.4}.attachment-footer{display:flex;justify-content:space-between;align-items:flex-end;gap:12px}.uploaded-info{display:flex;flex-direction:column;font-size:11px;color:#64748b;flex:1}.upload-date{margin-top:2px}.download-btn{background:#3b82f6;color:#fff;border:none;padding:6px 12px;border-radius:6px;font-size:11px;font-weight:500;cursor:pointer;transition:background .2s;white-space:nowrap}@media print{.lesson-view-container{background:#fff;padding:0}.lesson-actions,.lesson-view-footer{display:none}.lesson-view-header,.lesson-section{box-shadow:none;border:1px solid #e2e8f0;margin-bottom:16px;padding:24px}.lesson-title{font-size:24px}.section-title{font-size:18px}}@media (max-width: 768px){.lesson-view-container{padding:16px}.lesson-view-header{padding:24px}.header-content{flex-direction:column;gap:20px;align-items:stretch}.lesson-title{font-size:24px}.lesson-actions{justify-content:center}.metadata-item{text-align:center}.lesson-section{padding:24px 20px}.lesson-view-footer{flex-direction:column;gap:16px}.attachments-grid{grid-template-columns:1fr}.attachment-footer{flex-direction:column;align-items:stretch;gap:12px}.download-btn{text-align:center}}.lesson-edit-container{min-height:100vh;width:100vw;background-color:#f8fafc;font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;padding:20px;box-sizing:border-box}.lesson-edit-loading{display:flex;justify-content:center;align-items:center;height:100vh;font-size:18px;color:#64748b}.lesson-edit-error{text-align:center;max-width:500px;margin:100px auto;padding:40px;background:#fff;border-radius:12px;box-shadow:0 1px 3px #0000001a}.lesson-edit-error h2{color:#dc2626;margin-bottom:16px}.lesson-edit-error p{color:#64748b;margin-bottom:24px}.lesson-edit-header{background:#fff;border-radius:12px;padding:32px;margin-bottom:24px;box-shadow:0 1px 3px #0000001a;max-width:1200px;margin-left:auto;margin-right:auto}.header-content{display:flex;justify-content:space-between;align-items:flex-start}.lesson-title-section h1{font-size:28px;font-weight:700;color:#1e293b;margin:0}.lesson-subject-badge{display:inline-block;color:#fff;padding:6px 16px;border-radius:20px;font-size:12px;font-weight:500;text-transform:uppercase;letter-spacing:.5px;margin-bottom:12px}.lesson-actions{display:flex;gap:12px;flex-shrink:0}.lesson-edit-form{max-width:1200px;margin:0 auto 32px}.form-section{background:#fff;border-radius:12px;padding:32px;margin-bottom:20px;box-shadow:0 1px 3px #0000001a}.form-section h2{font-size:20px;font-weight:600;color:#1e293b;margin:0 0 24px;padding-bottom:8px;border-bottom:2px solid #f1f5f9}.form-section h3{font-size:18px;font-weight:600;color:#1e293b;margin:0 0 16px}.form-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:20px}.form-group input,.form-group select{padding:12px;border:1px solid #d1d5db;border-radius:6px;font-size:16px;transition:border-color .2s,box-shadow .2s}.form-group input:focus,.form-group select:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}textarea{width:100%;padding:12px;border:1px solid #d1d5db;border-radius:6px;font-size:14px;font-family:inherit;resize:vertical;min-height:120px;transition:border-color .2s,box-shadow .2s;box-sizing:border-box}textarea:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}textarea::placeholder{color:#9ca3af;font-style:italic}.lesson-edit-footer{display:flex;justify-content:center;gap:16px;max-width:1200px;margin:0 auto;padding:20px 0}.footer-btn{padding:12px 24px;border-radius:8px;font-size:16px;font-weight:500;cursor:pointer;transition:all .2s;border:1px solid transparent}.footer-btn.cancel-btn{background:#f1f5f9;color:#475569;border-color:#cbd5e1}.footer-btn.cancel-btn:hover:not(:disabled){background:#e2e8f0}.footer-btn.view-btn{background:#f8fafc;color:#475569;border-color:#e2e8f0}.footer-btn.view-btn:hover{background:#e2e8f0;border-color:#cbd5e1}.footer-btn.save-btn{background:#9ca3af;color:#fff;border:none}.footer-btn.save-btn.has-changes{background:#059669}.footer-btn.save-btn.has-changes:hover:not(:disabled){background:#047857}.footer-btn:disabled{cursor:not-allowed;opacity:.6}.section-description{color:#64748b;margin-bottom:24px;font-size:14px}.existing-attachments{margin-bottom:32px}.existing-attachments h3{font-size:18px;font-weight:600;color:#1e293b;margin-bottom:16px}.attachments-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px}.attachment-card{border:1px solid #e2e8f0;border-radius:8px;padding:16px;background:#f8fafc;transition:all .2s}.attachment-card:hover{border-color:#cbd5e1;box-shadow:0 2px 8px #0000001a}.attachment-card.existing{background:#f1f5f9}.attachment-header{display:flex;align-items:flex-start;gap:12px;margin-bottom:12px}.file-icon{font-size:20px;flex-shrink:0}.attachment-info{flex:1;min-width:0}.attachment-name{font-weight:600;color:#1e293b;font-size:14px;word-break:break-word;margin-bottom:4px}.attachment-meta{display:flex;gap:8px;font-size:11px;color:#64748b}.file-size{padding:2px 6px;background:#e2e8f0;border-radius:4px}.file-category{padding:2px 6px;background:#dbeafe;color:#1e40af;border-radius:4px;text-transform:capitalize}.attachment-description{color:#64748b;font-size:12px;margin-bottom:12px;line-height:1.4}.attachment-actions{display:flex;gap:8px}.download-btn,.delete-btn{padding:4px 8px;border-radius:4px;font-size:10px;font-weight:500;cursor:pointer;transition:all .2s;border:none}.download-btn{background:#3b82f6;color:#fff}.download-btn:hover{background:#2563eb}.delete-btn{background:#fef2f2;color:#dc2626;border:1px solid #fecaca}.delete-btn:hover{background:#fee2e2;border-color:#fca5a5}.file-upload-section h3{font-size:16px;font-weight:600;color:#1e293b;margin-bottom:16px}.file-upload-area{position:relative;margin-bottom:24px}.file-input{position:absolute;opacity:0;width:100%;height:100%;cursor:pointer}.file-upload-label{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:32px 20px;border:2px dashed #cbd5e1;border-radius:8px;background:#f8fafc;cursor:pointer;transition:all .2s;text-align:center}.file-upload-label:hover{border-color:#3b82f6;background:#eff6ff}.upload-icon{font-size:24px;margin-bottom:8px}.upload-text{font-size:14px;color:#374151;margin-bottom:4px}.upload-hint{font-size:11px;color:#64748b}.new-attachments h4{font-size:14px;font-weight:600;color:#1e293b;margin-bottom:16px}.attachment-item{position:relative;border:1px solid #e2e8f0;border-radius:6px;padding:16px;margin-bottom:12px;background:#fffbeb;transition:all .2s}.attachment-item.new{border-color:#f59e0b;background:#fffbeb}.attachment-item:hover{border-color:#cbd5e1;box-shadow:0 2px 4px #0000001a}.attachment-size{font-size:11px;color:#64748b}.attachment-details{margin-top:12px}.remove-attachment-btn{position:absolute;top:8px;right:8px;background:#fef2f2;color:#dc2626;border:1px solid #fecaca;border-radius:4px;width:20px;height:20px;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:10px;transition:all .2s}.remove-attachment-btn:hover{background:#fee2e2;border-color:#fca5a5}@media (max-width: 768px){.lesson-edit-container{padding:16px}.lesson-edit-header{padding:24px}.header-content{flex-direction:column;gap:20px;align-items:stretch}.lesson-title-section h1{font-size:24px}.lesson-actions{justify-content:center}.form-section{padding:24px 20px}.form-grid{grid-template-columns:1fr}.lesson-edit-footer{flex-direction:column}.attachments-grid{grid-template-columns:1fr}.attachment-actions{flex-direction:column;gap:8px}.file-upload-label{padding:24px 16px}.upload-icon{font-size:20px}}.template-editor-container{min-height:100vh;width:100vw;background-color:#f8fafc;font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;padding:20px;box-sizing:border-box}.ai-config-section{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:20px;border-radius:8px;margin-top:15px;border:1px solid rgba(255,255,255,.2)}.ai-config-section h4{margin:0 0 15px;font-size:16px;font-weight:600}.ai-config-section label{color:#fff;font-weight:500}.ai-config-section input[type=checkbox]{margin-right:8px}.ai-config-section textarea,.ai-config-section select{background:#ffffffe6;border:1px solid rgba(255,255,255,.3);color:#1e293b}.ai-config-section textarea:focus,.ai-config-section select:focus{background:#fff;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.ai-config-section small{color:#fffc;font-size:12px;font-style:italic}.section-type-help{display:block;color:#64748b;font-size:12px;margin-top:4px;font-style:italic}.template-editor-loading{display:flex;justify-content:center;align-items:center;height:100vh;font-size:18px;color:#64748b}.template-editor-error{text-align:center;max-width:500px;margin:100px auto;padding:40px;background:#fff;border-radius:12px;box-shadow:0 1px 3px #0000001a}.template-editor-error h2{color:#dc2626;margin-bottom:16px}.template-editor-header{background:#fff;border-radius:12px;padding:32px;margin-bottom:24px;box-shadow:0 1px 3px #0000001a;max-width:1200px;margin-left:auto;margin-right:auto}.header-content{display:flex;justify-content:space-between;align-items:center}.header-content h1{font-size:28px;font-weight:700;color:#1e293b;margin:0}.template-actions{display:flex;gap:12px}.action-btn{padding:10px 20px;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s;border:1px solid transparent}.cancel-btn{background:#f1f5f9;color:#475569;border-color:#cbd5e1}.cancel-btn:hover:not(:disabled){background:#e2e8f0}.save-btn{background:#9ca3af;color:#fff;border:none}.save-btn.has-changes{background:#059669}.save-btn.has-changes:hover:not(:disabled){background:#047857}.save-btn:disabled{cursor:not-allowed;opacity:.6}.unsaved-changes-notice{display:flex;align-items:center;gap:8px;margin-top:16px;padding:12px 16px;background:#fef3c7;color:#92400e;border-radius:8px;font-size:14px;font-weight:500}.notice-icon{font-size:16px}.template-editor-content{max-width:1200px;margin:0 auto}.editor-section{background:#fff;border-radius:12px;padding:32px;margin-bottom:24px;box-shadow:0 1px 3px #0000001a}.editor-section h2{font-size:20px;font-weight:600;color:#1e293b;margin:0 0 24px;padding-bottom:8px;border-bottom:2px solid #f1f5f9}.template-details-form{display:flex;flex-direction:column;gap:20px}.form-row{display:grid;grid-template-columns:1fr auto;gap:20px;align-items:start}.checkbox-group{display:flex;align-items:center;justify-content:center}.checkbox-label{display:flex;align-items:center;gap:8px;font-size:14px;color:#64748b;cursor:pointer;margin-bottom:8px}.checkbox-label input[type=checkbox]{margin:0;cursor:pointer}.multi-select{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:8px;max-height:200px;overflow-y:auto;border:1px solid #d1d5db;border-radius:6px;padding:12px}.subject-color{width:12px;height:12px;border-radius:50%;display:inline-block}.sections-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px}.add-section-btn{background:#3b82f6;color:#fff;border:none;padding:10px 16px;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:background .2s}.add-section-btn:hover{background:#2563eb}.sections-list{display:flex;flex-direction:column;gap:16px}.section-item{border:1px solid #e2e8f0;border-radius:8px;background:#f8fafc;transition:all .2s;cursor:move}.section-item:hover{border-color:#cbd5e1;box-shadow:0 2px 4px #0000001a}.section-item.dragging{opacity:.5;transform:scale(.98)}.section-header{display:flex;align-items:center;gap:12px;padding:16px;border-bottom:1px solid #e2e8f0}.drag-handle{color:#9ca3af;cursor:move;font-size:16px;-webkit-user-select:none;user-select:none}.section-info{flex:1}.section-info h4{font-size:16px;font-weight:600;color:#1e293b;margin:0 0 4px}.section-type{font-size:12px;color:#64748b;background:#e2e8f0;padding:2px 8px;border-radius:12px;text-transform:uppercase;letter-spacing:.5px}.section-controls{display:flex;align-items:center;gap:16px}.remove-btn{background:#fef2f2;color:#dc2626;border:1px solid #fecaca;padding:6px 8px;border-radius:4px;font-size:12px;cursor:pointer;transition:all .2s}.remove-btn:hover{background:#fee2e2;border-color:#fca5a5}.section-details{padding:16px;display:flex;flex-direction:column;gap:16px}.add-section-form{border:2px dashed #cbd5e1;border-radius:8px;padding:24px;background:#f8fafc;margin-top:16px}.add-section-form h3{font-size:18px;font-weight:600;color:#1e293b;margin:0 0 20px}.form-actions{display:flex;gap:12px;justify-content:flex-end;margin-top:20px}.add-btn{background:#059669;color:#fff;border:none;padding:10px 20px;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:background .2s}.add-btn:hover{background:#047857}.back-btn{background:#f1f5f9;color:#475569;border:1px solid #cbd5e1;padding:12px 20px;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s}.back-btn:hover{background:#e2e8f0}@media (max-width: 768px){.template-editor-container{padding:16px}.template-editor-header{padding:24px}.header-content{flex-direction:column;gap:16px;align-items:stretch}.header-content h1{text-align:center;font-size:24px}.template-actions{justify-content:center}.editor-section{padding:24px 20px}.form-row,.multi-select{grid-template-columns:1fr}.section-header,.section-controls{flex-wrap:wrap;gap:8px}.form-actions{flex-direction:column}}.ai-lesson-assistant{min-height:100vh;width:100vw;background-color:#f8fafc;font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;color:#1e293b;box-sizing:border-box;overflow-x:auto}.ai-lesson-loading{display:flex;justify-content:center;align-items:center;height:100vh;font-size:18px;color:#64748b}.ai-lesson-header{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:24px 0;box-shadow:0 2px 8px #0000001a}.header-content{width:100%;margin:0;padding:0 40px;display:flex;justify-content:space-between;align-items:center}.header-content h1{margin:0;font-size:28px;font-weight:700}.back-btn{background:#fff3;color:#fff;border:1px solid rgba(255,255,255,.3);padding:8px 16px;border-radius:6px;cursor:pointer;transition:all .2s;font-size:14px}.back-btn:hover{background:#ffffff4d}.step-indicator{background:#fff3;padding:8px 16px;border-radius:20px;font-size:14px;font-weight:500}.ai-lesson-content{width:100%;margin:0;padding:32px 40px}.step-content h2{font-size:24px;font-weight:600;color:#1e293b;margin:0 0 8px}.step-content p{color:#64748b;margin:0 0 32px;font-size:16px;line-height:1.6}.templates-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:20px;margin-top:24px}.template-card{background:#fff;border-radius:12px;padding:24px;box-shadow:0 1px 3px #0000001a;transition:all .2s;border:1px solid #e2e8f0}.template-card.clickable{cursor:pointer}.template-card:hover{box-shadow:0 4px 12px #00000026;transform:translateY(-2px)}.template-card h3{margin:0 0 12px;font-size:18px;font-weight:600;color:#1e293b}.template-card p{color:#64748b;margin:0 0 16px;font-size:14px;line-height:1.5}.template-meta{font-size:12px;color:#64748b;margin-bottom:16px}.template-meta div{margin-bottom:4px}.select-btn{background:#3b82f6;color:#fff;border:none;padding:10px 20px;border-radius:6px;cursor:pointer;font-weight:500;transition:all .2s;width:100%}.select-btn:hover{background:#2563eb}.context-form{background:#fff;border-radius:12px;padding:32px;box-shadow:0 1px 3px #0000001a}.form-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:20px;margin-bottom:20px}.form-group{display:flex;flex-direction:column}.form-group label{font-weight:500;color:#374151;margin-bottom:6px;font-size:14px}.form-group input,.form-group select,.form-group textarea{padding:12px;border:1px solid #d1d5db;border-radius:6px;font-size:16px;transition:border-color .2s,box-shadow .2s}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.form-actions{display:flex;justify-content:space-between;margin-top:32px;gap:16px}.continue-btn{background:#059669;color:#fff;border:none;padding:12px 24px;border-radius:6px;cursor:pointer;font-weight:500;transition:all .2s}.continue-btn:hover{background:#047857}.generation-summary{background:#fff;border-radius:12px;padding:24px;box-shadow:0 1px 3px #0000001a;margin-bottom:24px}.summary-item{display:flex;margin-bottom:12px;font-size:16px}.summary-item strong{min-width:100px;color:#374151}.generation-actions{display:flex;justify-content:center;gap:16px;margin-bottom:32px}.generate-btn{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;padding:16px 32px;border-radius:8px;cursor:pointer;font-weight:600;font-size:16px;transition:all .2s;box-shadow:0 2px 8px #667eea4d}.generate-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px #667eea66}.generate-btn:disabled{opacity:.7;cursor:not-allowed;transform:none}.generation-progress{text-align:center;padding:40px;background:#fff;border-radius:12px;box-shadow:0 1px 3px #0000001a}.progress-spinner{width:40px;height:40px;border:4px solid #e5e7eb;border-top:4px solid #3b82f6;border-radius:50%;animation:spin 1s linear infinite;margin:0 auto 16px}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.lesson-preview{background:#fff;border-radius:12px;padding:32px;box-shadow:0 1px 3px #0000001a}.lesson-header h3{margin:0 0 8px;font-size:24px;font-weight:600;color:#1e293b}.lesson-meta{color:#64748b;margin-bottom:32px;font-size:14px}.lesson-sections{margin-bottom:32px}.lesson-section{margin-bottom:24px;border:1px solid #e2e8f0;border-radius:8px;overflow:hidden}.section-header{background:#f8fafc;padding:16px;display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid #e2e8f0}.section-header h4{margin:0;font-size:16px;font-weight:600;color:#374151}.regenerate-btn{background:#f3f4f6;border:1px solid #d1d5db;border-radius:4px;padding:4px 8px;cursor:pointer;font-size:12px;transition:all .2s}.regenerate-btn:hover{background:#e5e7eb}.section-content{width:100%;padding:16px;border:none;resize:vertical;font-family:inherit;font-size:14px;line-height:1.5}.section-content:focus{outline:none;background:#fafbfc}.review-actions{display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap}.regenerate-all-btn{background:#f59e0b;color:#fff;border:none;padding:12px 24px;border-radius:6px;cursor:pointer;font-weight:500;transition:all .2s}.regenerate-all-btn:hover{background:#d97706}.save-btn{background:#059669;color:#fff;border:none;padding:12px 24px;border-radius:6px;cursor:pointer;font-weight:500;transition:all .2s}.save-btn:hover{background:#047857}@media (max-width: 768px){.ai-lesson-content{padding:20px 16px}.header-content{padding:0 16px}.header-content{flex-direction:column;gap:16px;text-align:center}.form-row{grid-template-columns:1fr}.form-actions,.generation-actions,.review-actions{flex-direction:column}.templates-grid{grid-template-columns:1fr}}.no-sections{text-align:center;padding:40px;background:#fef3c7;border:1px solid #f59e0b;border-radius:8px;color:#92400e}.ai-lesson-assistant *{color:inherit}.ai-lesson-assistant .step-content,.ai-lesson-assistant .lesson-preview,.ai-lesson-assistant .context-form,.ai-lesson-assistant .generation-summary{color:#1e293b}.ai-lesson-assistant input,.ai-lesson-assistant select,.ai-lesson-assistant textarea{color:#1e293b;background:#fff}.ai-lesson-assistant .generation-progress p{color:#64748b}.tank-diagram-container{display:flex;flex-direction:column;align-items:center;padding:20px;background:#fff;border-radius:8px;box-shadow:0 2px 8px #0000001a;margin:20px 0}.diagram-header{text-align:center;margin-bottom:20px;position:relative;min-height:80px}.diagram-header h3{margin:0 0 10px;color:#333;font-size:1.5rem}.instruction-text{color:#666;font-size:.9rem;margin:5px 0;font-style:italic}.zone-tooltip{background:#333;color:#fff;padding:8px 12px;border-radius:6px;font-size:.85rem;position:absolute;top:45px;left:50%;transform:translate(-50%);white-space:nowrap;z-index:10;box-shadow:0 2px 8px #00000026;border:1px solid #555}.tank-diagram{max-width:100%;height:auto;border:2px solid #ddd;border-radius:8px;background:#fff;cursor:default}.weld-zone{cursor:pointer;transition:all .2s ease;filter:drop-shadow(0 2px 4px rgba(0,0,0,.1))}.weld-zone:hover{filter:drop-shadow(0 4px 8px rgba(255,107,53,.4));stroke-width:6!important}.weld-zone.hovered{stroke:#ff4500!important;stroke-width:6!important;animation:pulse 1.5s infinite}@keyframes pulse{0%{stroke-opacity:1}50%{stroke-opacity:.6}to{stroke-opacity:1}}.tank-label{font-family:Arial,sans-serif;font-size:14px;font-weight:700;fill:#333;-webkit-user-select:none;user-select:none;pointer-events:none}.valve-label{font-family:Arial,sans-serif;font-weight:700;fill:#333;-webkit-user-select:none;user-select:none;pointer-events:none}.leak-marker{cursor:pointer;filter:drop-shadow(0 2px 4px rgba(255,0,0,.3));animation:leakPulse 2s infinite}@keyframes leakPulse{0%{r:8;fill-opacity:1}50%{r:10;fill-opacity:.7}to{r:8;fill-opacity:1}}.leak-marker:hover{filter:drop-shadow(0 4px 8px rgba(255,0,0,.5))}@media (max-width: 768px){.tank-diagram-container{padding:10px;margin:10px 0}.diagram-header h3{font-size:1.2rem}.tank-diagram{width:100%;max-width:400px}}.weld-zone[stroke="#4a90e2"]{stroke:#4a90e2}.leak-marker.repaired{fill:#28a745}.leak-marker.pending{fill:#ffc107}.leak-marker.failed{fill:#dc3545}.weld-legend{display:flex;justify-content:center;gap:20px;margin-top:15px;padding:10px;background:#f8f9fa;border-radius:6px;font-size:.85rem}.legend-item{display:flex;align-items:center;gap:5px}.legend-color{width:12px;height:12px;border-radius:2px;border:1px solid #ccc}.leak-check-review{min-height:100vh;background:#f5f5f5;padding:20px}.review-header{background:#fff;padding:20px;border-radius:8px;margin-bottom:20px;box-shadow:0 2px 4px #0000001a}.review-header h1{margin:10px 0;color:#333}.back-btn{background:#6366f1;color:#fff;border:none;padding:8px 16px;border-radius:4px;cursor:pointer;margin-bottom:10px}.back-btn:hover{background:#4f46e5}.assessment-info{display:flex;gap:20px;color:#666;font-size:14px}.status-badge{padding:2px 8px;border-radius:4px;font-weight:600}.status-badge.pass{background:#dcfce7;color:#166534}.status-badge.fail{background:#fee2e2;color:#dc2626}.status-badge.review_needed{background:#fed7aa;color:#ea580c}.review-layout{display:grid;grid-template-columns:1fr 400px;gap:20px}.diagram-section{background:#fff;padding:20px;border-radius:8px;box-shadow:0 2px 4px #0000001a}.view-selector{display:flex;gap:10px;margin-bottom:20px;flex-wrap:wrap}.view-btn{padding:8px 16px;border:1px solid #ddd;background:#fff;border-radius:4px;cursor:pointer;position:relative;transition:all .2s}.view-btn:hover{background:#f0f0f0}.view-btn.active{background:#6366f1;color:#fff;border-color:#6366f1}.leak-count{position:absolute;top:-8px;right:-8px;background:#dc2626;color:#fff;border-radius:50%;width:20px;height:20px;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700}.tank-diagram-container{min-height:400px;border:2px solid #e5e7eb;border-radius:8px;padding:20px;background:#fafafa}.leak-legend{display:flex;gap:20px;margin-top:20px;padding-top:20px;border-top:1px solid #e5e7eb}.legend-item{display:flex;align-items:center;gap:8px;font-size:14px;color:#333}.leak-marker{width:16px;height:16px;border-radius:50%;border:2px solid #333}.leak-marker.unrepaired{background:#dc2626}.leak-marker.repaired{background:#16a34a}.leak-marker.selected{background:#3b82f6;box-shadow:0 0 0 3px #3b82f64d}.control-panel{display:flex;flex-direction:column;gap:20px}.repair-section,.vacuum-test-section,.leak-list{background:#fff;padding:20px;border-radius:8px;box-shadow:0 2px 4px #0000001a}.repair-section h2,.vacuum-test-section h2,.leak-list h2{margin-top:0;margin-bottom:15px;color:#333;font-size:18px}.repair-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-bottom:20px}.stat{text-align:center;padding:10px;background:#f5f5f5;border-radius:4px}.stat-label{display:block;font-size:12px;color:#666;margin-bottom:4px}.stat-value{display:block;font-size:24px;font-weight:700;color:#333}.stat-value.success{color:#16a34a}.stat-value.warning{color:#ea580c}.repair-controls{display:flex;flex-direction:column;gap:15px}.select-all-btn{padding:10px;background:#f3f4f6;border:1px solid #d1d5db;border-radius:4px;cursor:pointer;font-weight:500}.select-all-btn:hover{background:#e5e7eb}.repair-form{display:flex;flex-direction:column;gap:12px}.repair-form label{display:flex;flex-direction:column;gap:4px;font-size:14px;color:#333}.repair-form select,.repair-form textarea,.repair-form input{padding:8px;border:1px solid #d1d5db;border-radius:4px;font-size:14px}.repair-form textarea{min-height:60px;resize:vertical}.mark-repaired-btn{padding:12px;background:#16a34a;color:#fff;border:none;border-radius:4px;font-weight:600;cursor:pointer}.mark-repaired-btn:hover:not(:disabled){background:#15803d}.mark-repaired-btn:disabled{opacity:.5;cursor:not-allowed}.test-setup,.test-monitoring,.test-complete{display:flex;flex-direction:column;gap:15px}.test-setup p{margin:0;color:#666;font-size:14px}.start-test-btn{padding:12px;background:#3b82f6;color:#fff;border:none;border-radius:4px;font-weight:600;cursor:pointer}.start-test-btn:hover:not(:disabled){background:#2563eb}.test-status{background:#f0f9ff;padding:15px;border-radius:4px;border-left:4px solid #3b82f6}.test-status h3{margin-top:0;margin-bottom:10px;color:#1e40af}.test-status p{margin:5px 0;color:#333}.test-actions{display:grid;grid-template-columns:1fr 1fr;gap:10px}.test-pass-btn,.test-fail-btn{padding:12px;border:none;border-radius:4px;font-weight:600;cursor:pointer;color:#fff}.test-pass-btn{background:#16a34a}.test-pass-btn:hover:not(:disabled){background:#15803d}.test-fail-btn{background:#dc2626}.test-fail-btn:hover:not(:disabled){background:#b91c1c}.test-result{padding:20px;text-align:center;font-size:24px;font-weight:700;border-radius:4px}.test-result.passed{background:#dcfce7;color:#166534}.test-result.failed{background:#fee2e2;color:#dc2626}.test-details{margin-top:15px;padding:15px;background:#f5f5f5;border-radius:4px}.test-details p{margin:5px 0;color:#333}.leak-table{display:flex;flex-direction:column;gap:8px;max-height:400px;overflow-y:auto}.leak-item{padding:12px;background:#f9fafb;border:1px solid #e5e7eb;border-radius:4px;cursor:pointer;transition:all .2s}.leak-item:hover:not(.repaired){background:#f3f4f6;border-color:#9ca3af}.leak-item.selected{background:#dbeafe;border-color:#3b82f6}.leak-item.repaired{background:#f0fdf4;border-color:#86efac;cursor:default}.leak-info{display:flex;gap:15px;align-items:center}.leak-number{font-weight:700;color:#333}.leak-view{padding:2px 8px;background:#9ca3af;color:#1f2937;border-radius:4px;font-size:12px;text-transform:uppercase}.leak-location{color:#666;font-size:14px}.repair-info{margin-top:8px;padding-top:8px;border-top:1px solid #e5e7eb;display:flex;gap:10px;align-items:center}.repair-badge{padding:2px 8px;background:#16a34a;color:#fff;border-radius:4px;font-size:12px;font-weight:600}.repair-note{color:#666;font-size:13px;font-style:italic}.loading,.error{display:flex;align-items:center;justify-content:center;min-height:100vh;font-size:18px;color:#666}@media (max-width: 1200px){.review-layout{grid-template-columns:1fr}}*{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}.App{min-height:100vh}
