.layout{display:flex;min-height:100vh;background:#f5f7fa}.sidebar{width:260px;background:linear-gradient(180deg,#667eea,#764ba2);color:#fff;transition:width .3s ease;display:flex;flex-direction:column;position:fixed;height:100vh;left:0;top:0;z-index:100}.sidebar.closed{width:70px}.sidebar-header{padding:20px;border-bottom:1px solid rgba(255,255,255,.1)}.sidebar-header h1{margin:0;font-size:22px;font-weight:700}.sidebar.closed .sidebar-header h1{font-size:16px}.sidebar-nav{flex:1;overflow-y:auto;padding:20px 0}.nav-item{display:flex;align-items:center;padding:12px 20px;color:#fff;text-decoration:none;transition:background .2s;cursor:pointer;border:none;background:transparent;width:100%;text-align:left;font-size:14px}.nav-item:hover{background:#ffffff1a}.nav-item.active{background:#fff3;border-left:4px solid white}.nav-icon{font-size:20px;min-width:30px}.nav-label{margin-left:10px;white-space:nowrap}.sidebar.closed .nav-label{display:none}.sidebar-footer{border-top:1px solid rgba(255,255,255,.1);padding:10px 0}.logout-btn{color:#ff6b6b}.logout-btn:hover{background:#ff6b6b33}.main-content{flex:1;margin-left:260px;transition:margin-left .3s ease}.sidebar.closed+.main-content{margin-left:70px}.top-header{background:#fff;padding:15px 30px;box-shadow:0 2px 4px #0000001a;display:flex;justify-content:space-between;align-items:center;position:sticky;top:0;z-index:50}.sidebar-toggle{background:none;border:none;font-size:24px;cursor:pointer;color:#333;padding:5px}.sidebar-toggle:hover{color:#667eea}.header-right{display:flex;align-items:center;gap:20px}.user-info{display:flex;flex-direction:column;align-items:flex-end}.user-name{font-weight:600;color:#333;font-size:14px}.user-role{font-size:12px;color:#666;text-transform:uppercase}.content{padding:30px}@media(max-width:768px){.sidebar{width:70px}.sidebar .nav-label{display:none}.main-content{margin-left:70px}}.auth-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2);padding:20px}.auth-card{background:#fff;border-radius:10px;box-shadow:0 10px 40px #0003;width:100%;max-width:450px;overflow:hidden}.auth-header{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:40px 30px;text-align:center}.auth-header h1{margin:0 0 10px;font-size:32px;font-weight:700}.auth-header p{margin:0;font-size:14px;opacity:.9}.auth-form{padding:40px 30px}.auth-form h2{margin:0 0 30px;color:#333;font-size:24px;text-align:center}.form-group{margin-bottom:20px}.form-group label{display:block;margin-bottom:8px;color:#555;font-weight:500;font-size:14px}.form-group input{width:100%;padding:12px 15px;border:2px solid #e0e0e0;border-radius:6px;font-size:14px;transition:border-color .3s;box-sizing:border-box}.form-group input:focus{outline:none;border-color:#667eea}.btn-primary{width:100%;padding:14px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:6px;font-size:16px;font-weight:600;cursor:pointer;transition:transform .2s,box-shadow .2s}.btn-primary:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 5px 15px #667eea66}.btn-primary:disabled{opacity:.6;cursor:not-allowed}.error-message{background:#fee;color:#c33;padding:12px;border-radius:6px;margin-bottom:20px;font-size:14px;border:1px solid #fcc}.auth-links{margin-top:20px;text-align:center}.auth-links a{color:#667eea;text-decoration:none;font-size:14px}.auth-links a:hover{text-decoration:underline}.loading-screen{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;background:#f5f5f5}.loading-spinner{width:50px;height:50px;border:4px solid #f3f3f3;border-top:4px solid #667eea;border-radius:50%;animation:spin 1s linear infinite;margin-bottom:20px}.dashboard{max-width:1400px;margin:0 auto}.dashboard-header{margin-bottom:30px}.dashboard-header h1{margin:0 0 10px;color:#333;font-size:32px}.dashboard-header p{margin:0;color:#666;font-size:16px}.stat-card{background:#fff;border-radius:10px;padding:25px;box-shadow:0 2px 8px #0000001a;display:flex;align-items:center;gap:20px;transition:transform .2s,box-shadow .2s}.stat-card:hover{transform:translateY(-5px);box-shadow:0 5px 15px #00000026}.stat-icon{font-size:48px;line-height:1}.stat-content h3{margin:0 0 8px;color:#666;font-size:14px;font-weight:500;text-transform:uppercase}.stat-value{margin:0;color:#333;font-size:36px;font-weight:700}.dashboard-content{display:grid;grid-template-columns:2fr 1fr;gap:20px}.recent-activity,.quick-actions{background:#fff;border-radius:10px;padding:25px;box-shadow:0 2px 8px #0000001a}.recent-activity h2,.quick-actions h2{margin:0 0 20px;color:#333;font-size:20px}.recent-activity p{color:#666;margin:0}.action-buttons{display:grid;grid-template-columns:1fr;gap:15px}.action-btn{display:flex;align-items:center;gap:15px;padding:15px 20px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:transform .2s,box-shadow .2s}.action-btn:hover{transform:translateY(-2px);box-shadow:0 5px 15px #667eea66}.action-icon{font-size:24px;font-weight:700}.dashboard-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px}.dashboard-loading .loading-spinner{width:50px;height:50px;border:4px solid #f3f3f3;border-top:4px solid #667eea;border-radius:50%;animation:spin 1s linear infinite;margin-bottom:20px}@media(max-width:1024px){.dashboard-content{grid-template-columns:1fr}}@media(max-width:768px){.stats-grid{grid-template-columns:1fr}.dashboard-header h1{font-size:24px}.stat-value{font-size:28px}}.factory-basic-info{max-width:1400px;margin:0 auto}.content-section{background:#fff;border-radius:10px;box-shadow:0 2px 8px #0000001a;margin-bottom:30px;overflow:hidden}.section-header{background:#f8f9fa;padding:15px 25px;display:flex;justify-content:space-between;align-items:center;cursor:pointer;border-left:4px solid #667eea;transition:background .2s}.section-header:hover{background:#e9ecef}.section-title{margin:0;color:#333;font-size:20px;font-weight:600}.header-actions{display:flex;align-items:center;gap:15px}.section-body{padding:25px}.subsection{margin-top:20px;border:1px solid #e0e0e0;border-radius:8px;overflow:hidden}.subsection-header{background:#f8f9fa;padding:10px 15px;display:flex;justify-content:space-between;align-items:center;cursor:pointer;border-left:4px solid #17a2b8}.subsection-header h4{margin:0;color:#333;font-size:16px}.subsection-body{padding:15px}.factory-info-table{width:100%}.factory-info-table td{padding:12px 15px;border-bottom:1px solid #eee}.label-col{width:200px;font-weight:600;color:#555}.value-col{color:#333}.actions-col{width:60px;text-align:center}.table-responsive{overflow-x:auto}.data-table th,.data-table td{padding:12px;text-align:left;border-bottom:1px solid #eee;white-space:nowrap}.data-table th{background:#f8f9fa;font-weight:600;color:#333;font-size:13px;text-transform:uppercase}.empty-state{text-align:center;padding:40px;color:#666}.empty-state p{margin-bottom:20px;font-style:italic}.btn{padding:8px 16px;border:none;border-radius:6px;cursor:pointer;font-size:14px;display:inline-flex;align-items:center;gap:6px;transition:all .2s}.btn-primary{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.btn-primary:hover{transform:translateY(-1px);box-shadow:0 4px 12px #667eea66}.btn-edit{background:#ffc107;color:#333;padding:6px 12px;border:none;border-radius:4px;cursor:pointer}.btn-delete{background:#dc3545;color:#fff;padding:6px 12px;border:none;border-radius:4px;cursor:pointer}.actions{display:flex;gap:6px;white-space:nowrap}.status-badge{padding:4px 10px;border-radius:12px;font-size:12px;font-weight:600}.status-active{background:#d4edda;color:#155724}.status-inactive{background:#f8d7da;color:#721c24}.status-under-maintenance{background:#fff3cd;color:#856404}.status-retired{background:#d1ecf1;color:#0c5460}.text-center{text-align:center}.text-muted{color:#999}.margin-top-15{margin-top:15px}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.modal-content{background:#fff;border-radius:10px;max-width:800px;width:100%;max-height:90vh;overflow-y:auto;box-shadow:0 10px 40px #0003}.modal-header{padding:20px 25px;border-bottom:1px solid #eee;display:flex;justify-content:space-between;align-items:center;position:sticky;top:0;background:#fff;z-index:1}.modal-header h2{margin:0;color:#333;font-size:20px}.btn-close{background:none;border:none;font-size:20px;cursor:pointer;color:#666;padding:5px}.modal-body{padding:25px}.modal-footer{padding:20px 25px;border-top:1px solid #eee;display:flex;justify-content:flex-end;gap:10px;position:sticky;bottom:0;background:#fff}.form-group label{display:block;margin-bottom:8px;font-weight:500;color:#333;font-size:14px}.form-group input,.form-group select,.form-group textarea{width:100%;padding:10px 12px;border:2px solid #e0e0e0;border-radius:6px;font-size:14px;font-family:inherit}.form-group textarea{resize:vertical}.btn-primary{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:10px 24px;border:none;border-radius:6px;cursor:pointer;font-size:14px;font-weight:500}.btn-secondary{background:#6c757d;color:#fff;padding:10px 24px;border:none;border-radius:6px;cursor:pointer;font-size:14px;font-weight:500}@media(max-width:768px){.form-grid{grid-template-columns:1fr}.section-header{padding:12px 15px}.section-body{padding:15px}.data-table th,.data-table td{padding:8px;font-size:13px}}.legal-permits{max-width:1400px;margin:0 auto}.page-header{margin-bottom:30px}.page-header h1{margin:0;color:#333;font-size:32px}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:20px;margin-bottom:30px}.stat-card{background:#fff;border-radius:10px;padding:25px;box-shadow:0 2px 8px #0000001a;display:flex;align-items:center;gap:20px}.stat-active{border-top:4px solid #28a745}.stat-expiring{border-top:4px solid #ffc107}.stat-expired{border-top:4px solid #dc3545}.stat-applied{border-top:4px solid #17a2b8}.stat-icon{font-size:48px}.stat-active .stat-icon{color:#28a745}.stat-expiring .stat-icon{color:#ffc107}.stat-expired .stat-icon{color:#dc3545}.stat-applied .stat-icon{color:#17a2b8}.stat-details h4{margin:0 0 8px;font-size:32px;color:#333}.stat-details p{margin:0;color:#666;font-size:14px}.filters-section{display:flex;gap:15px;margin-bottom:20px;flex-wrap:wrap;align-items:center}.search-box{position:relative;flex:1;min-width:250px}.search-box i{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:#999}.search-box input{width:100%;padding:10px 10px 10px 40px;border:2px solid #e0e0e0;border-radius:6px;font-size:14px}.search-box input:focus{outline:none;border-color:#667eea}.filters-section select{padding:10px 15px;border:2px solid #e0e0e0;border-radius:6px;font-size:14px;cursor:pointer}.filters-section select:focus{outline:none;border-color:#667eea}.btn-primary{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:10px 20px;border:none;border-radius:6px;cursor:pointer;display:flex;align-items:center;gap:8px}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 5px 15px #667eea66}.btn-secondary{background:#6c757d;color:#fff;padding:10px 20px;border:none;border-radius:6px;cursor:pointer;display:flex;align-items:center;gap:8px}.table-container{background:#fff;border-radius:10px;padding:20px;box-shadow:0 2px 8px #0000001a;overflow-x:auto}.data-table{width:100%;border-collapse:collapse}.data-table th,.data-table td{padding:12px;text-align:left;border-bottom:1px solid #eee}.data-table th{background:#f8f9fa;font-weight:600;color:#333}.data-table tbody tr:hover{background:#f8f9fa}.badge{padding:6px 12px;border-radius:20px;font-size:12px;font-weight:600;text-transform:uppercase}.badge-active{background:#d4edda;color:#155724}.badge-expiring{background:#fff3cd;color:#856404}.badge-expired{background:#f8d7da;color:#721c24}.badge-applied{background:#d1ecf1;color:#0c5460}.actions{display:flex;gap:8px}.btn-icon{padding:8px 12px;border:none;border-radius:4px;cursor:pointer;font-size:14px}.btn-edit{background:#ffc107;color:#fff}.btn-delete{background:#dc3545;color:#fff}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.modal-content{background:#fff;border-radius:10px;max-width:700px;width:90%;max-height:90vh;overflow-y:auto}.modal-large{max-width:900px}.modal-header{padding:20px;border-bottom:1px solid #eee;display:flex;justify-content:space-between;align-items:center}.modal-header h2{margin:0;color:#333}.btn-close{background:none;border:none;font-size:20px;cursor:pointer;color:#666}.modal-body{padding:20px}.modal-footer{padding:20px;border-top:1px solid #eee;display:flex;justify-content:flex-end;gap:10px}.form-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:20px}.form-group{margin-bottom:0}.form-group.full-width{grid-column:1 / -1}.form-group label{display:block;margin-bottom:8px;font-weight:500;color:#333}.form-group input,.form-group select,.form-group textarea{width:100%;padding:10px;border:2px solid #e0e0e0;border-radius:6px;font-size:14px}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:#667eea}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px}.spinner{width:50px;height:50px;border:4px solid #f3f3f3;border-top:4px solid #667eea;border-radius:50%;animation:spin 1s linear infinite;margin-bottom:20px}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:#f5f7fa;color:#333;margin:0;min-width:320px;min-height:100vh}#root{width:100%}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}.page{max-width:1400px;margin:0 auto}.page h1{margin-bottom:20px;color:#333}.page p{color:#666;font-size:16px}
