@import url(https://fonts.googleapis.com/css2?family=DM+Sans:wght@400;500;600&display=swap);*{box-sizing:border-box;margin:0;padding:0}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:var(--bg-secondary);color:var(--text-primary);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;transition:background-color .3s,color .3s}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}html{scroll-behavior:smooth}::-webkit-scrollbar{height:8px;width:8px}::-webkit-scrollbar-track{background:var(--bg-secondary)}::-webkit-scrollbar-thumb{background:var(--text-tertiary);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--text-secondary)}.dashboard h1{color:var(--text-primary);margin-bottom:30px}.stats-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));margin-bottom:30px}.stat-card{align-items:center;background:var(--bg-primary);border:1px solid var(--border-color);border-radius:12px;box-shadow:var(--shadow);display:flex;gap:20px;padding:20px;transition:all .3s}.stat-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-4px)}.stat-icon{align-items:center;border-radius:12px;color:#fff;display:flex;flex-shrink:0;font-size:24px;height:60px;justify-content:center;width:60px}.stat-icon.users{background:linear-gradient(135deg,#667eea,#764ba2)}.stat-icon.attendance{background:linear-gradient(135deg,#f093fb,#f5576c)}.stat-icon.courses{background:linear-gradient(135deg,#4facfe,#00f2fe)}.stat-icon.messages{background:linear-gradient(135deg,#43e97b,#38f9d7)}.stat-content{flex:1 1;min-width:0}.stat-content h3{color:var(--text-secondary);font-size:14px;font-weight:500;margin-bottom:5px}.stat-number{color:var(--text-primary);font-size:32px;font-weight:700;line-height:1;margin:0}.stat-subtitle{color:var(--text-tertiary);font-size:12px;margin:5px 0 0}.dashboard-section{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:12px;box-shadow:var(--shadow);padding:20px}.dashboard-section h2{color:var(--text-primary);margin-bottom:20px}.recent-attendance{overflow-x:auto}.rate-badge{border-radius:12px;display:inline-block;font-size:12px;font-weight:600;padding:4px 12px}.rate-badge.high{background-color:#16a34a1a;color:var(--success)}.rate-badge.medium{background-color:#f59e0b1a;color:var(--warning)}.rate-badge.low{background-color:#dc26261a;color:var(--danger)}.error,.loading{color:var(--text-secondary);padding:50px;text-align:center}@media (max-width:1024px){.stats-grid{grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}}@media (max-width:768px){.stats-grid{gap:15px;grid-template-columns:1fr}.stat-card{gap:15px;padding:15px}.stat-icon{font-size:20px;height:50px;width:50px}.stat-number{font-size:24px}.dashboard-section{padding:15px}}@media (max-width:480px){.stat-card{gap:12px;padding:12px}.stat-icon{font-size:18px;height:45px;width:45px}.stat-number{font-size:20px}.stat-content h3{font-size:12px}.stat-subtitle{font-size:11px}}.batch-overview-section{margin-bottom:30px}.batch-stats-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));margin-top:15px}.batch-stat-card{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:12px;box-shadow:var(--shadow);display:flex;flex-direction:column;padding:20px;transition:all .3s ease}.batch-stat-card:hover{border-color:#667eea;border-color:var(--primary,#667eea);box-shadow:var(--shadow-lg);transform:translateY(-4px)}.batch-card-header{border-bottom:2px solid var(--border-color);margin-bottom:15px;padding-bottom:12px}.batch-card-header h3{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;background-clip:text;font-weight:600}.batch-card-content{display:flex;flex-direction:column;gap:12px}.batch-stat-item{align-items:center;display:flex;justify-content:space-between;padding:8px 0}.batch-stat-label{color:var(--text-secondary);font-size:14px;font-weight:500}.batch-stat-value{color:var(--text-primary);font-size:16px;font-weight:600}.batch-stat-value.active{color:#22c55e}.batch-stat-value.inactive{color:#ef4444}.attendance-by-batch{overflow-x:auto}.attendance-by-batch .table{border-collapse:collapse;width:100%}.attendance-by-batch .table th{background-color:#f5f5f5;background-color:var(--bg-secondary,#f5f5f5);border-bottom:2px solid #e0e0e0;border-bottom:2px solid var(--border-color,#e0e0e0);color:#333;color:var(--text-primary,#333);font-weight:600;padding:12px;text-align:left}.attendance-by-batch .table td{border-bottom:1px solid #e0e0e0;border-bottom:1px solid var(--border-color,#e0e0e0);color:#333;color:var(--text-primary,#333);padding:12px}.notification-container{gap:16px;left:50%;max-width:420px;padding:0 16px;position:fixed;top:50%;transform:translate(-50%,-50%);z-index:10000}.notification,.notification-container{align-items:center;display:flex;flex-direction:column;width:100%}.notification{animation:popCenter .35s ease-out;background:var(--bg-primary);border:1px solid var(--border-color);border-radius:14px;box-shadow:0 18px 40px #0f172a40;gap:12px;padding:18px 20px;position:relative;text-align:center}@keyframes popCenter{0%{opacity:0;transform:scale(.8)}to{opacity:1;transform:scale(1)}}.notification-icon{flex-shrink:0;font-size:20px}.notification-info .notification-icon{color:var(--active-color)}.notification-success .notification-icon{color:var(--success)}.notification-error .notification-icon{color:var(--danger)}.notification-message{color:var(--text-primary);flex:1 1;font-size:15px;word-break:break-word}.notification-close{align-items:center;background:none;border:none;border-radius:4px;color:var(--text-secondary);cursor:pointer;display:flex;flex-shrink:0;justify-content:center;padding:4px;transition:all .2s}.notification-close:hover{background:var(--hover-bg);color:var(--text-primary)}@media (max-width:600px){.notification-container{left:50%;max-width:90%;top:50%;transform:translate(-50%,-50%)}.notification{padding:16px}}.confirm-dialog-overlay{align-items:center;background-color:#00000080;bottom:0;display:flex;justify-content:center;left:0;padding:20px;position:fixed;right:0;top:0;z-index:2000}.confirm-dialog{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:12px;box-shadow:var(--shadow-lg);max-width:400px;padding:30px;text-align:center;width:100%}.confirm-dialog-icon{color:var(--warning);display:flex;font-size:48px;justify-content:center;margin-bottom:15px}.confirm-dialog h3{color:var(--text-primary);font-size:20px;margin:0 0 10px}.confirm-dialog p{color:var(--text-secondary);font-size:14px;margin:0 0 25px}.confirm-dialog-actions{display:flex;gap:10px;justify-content:center}.confirm-dialog-actions .btn{min-width:100px}@media (max-width:480px){.confirm-dialog{padding:20px}.confirm-dialog-icon{font-size:40px}.confirm-dialog h3{font-size:18px}}.progress-container{margin:15px 0;width:100%}.progress-message{color:var(--text-primary);font-size:14px;font-weight:500;margin-bottom:8px}.progress-bar-wrapper{background-color:var(--bg-tertiary);border-radius:4px;height:8px;overflow:hidden;position:relative;width:100%}.progress-bar-fill{animation:pulse 1.5s ease-in-out infinite;background:linear-gradient(90deg,var(--active-color),#60a5fa);border-radius:4px;height:100%;transition:width .3s ease}.progress-percentage{color:var(--text-secondary);font-size:12px;margin-top:4px;text-align:right}.progress-container.compact{margin:10px 0}.progress-container.compact .progress-message{font-size:12px;margin-bottom:4px}.progress-container.compact .progress-bar-wrapper{height:6px}.progress-container.compact .progress-percentage{font-size:11px;margin-top:2px}.trainees-header{align-items:center;display:flex;flex-wrap:wrap;gap:15px;justify-content:space-between;margin-bottom:20px}.trainees-actions{display:flex;flex-wrap:wrap;gap:10px}.trainees-toolbar{flex-wrap:wrap;gap:15px;justify-content:space-between;margin-bottom:20px}.search-box,.trainees-toolbar{align-items:center;display:flex}.search-box{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:8px;box-shadow:var(--shadow);flex:1 1;gap:10px;max-width:400px;padding:10px 15px}.search-box input{background:#0000;border:none;color:var(--text-primary);flex:1 1;font-size:14px;outline:none}.search-box svg{color:var(--text-secondary);flex-shrink:0}.batch-selector{align-items:center;gap:10px}.batch-selector label{font-weight:500;white-space:nowrap}.batch-select,.batch-selector label{color:var(--text-primary);font-size:14px}.batch-select{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:8px;cursor:pointer;min-width:200px;padding:10px 15px;transition:border-color .3s}.batch-select:focus,.batch-select:hover{border-color:var(--active-color)}.batch-select:focus{box-shadow:0 0 0 3px #3b82f61a;outline:none}.table-container{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:12px;box-shadow:var(--shadow);overflow-x:auto;padding:20px}.table-container .table{min-width:2000px}.table-container .table td,.table-container .table th{font-size:12px;padding:10px 6px;white-space:nowrap}.table-container .table th{font-size:11px;font-weight:600;text-transform:uppercase}.btn-icon{background:none;border:none;border-radius:4px;color:var(--text-secondary);cursor:pointer;font-size:18px;padding:5px;transition:all .3s}.btn-icon:hover{background:var(--hover-bg);color:var(--active-color)}.btn-icon.danger:hover{color:var(--danger)}.status-badge{border-radius:12px;display:inline-block;font-size:12px;font-weight:600;padding:4px 12px;text-transform:capitalize}.status-badge.active{background-color:#16a34a1a;color:var(--success)}.status-badge.inactive{background-color:#dc26261a;color:var(--danger)}.pagination{align-items:center;display:flex;flex-wrap:wrap;gap:15px;justify-content:center;margin-top:20px}.form-row{grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.trainee-form{max-height:80vh;overflow-y:auto;padding-right:10px}.text-truncate{max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.modal-actions{display:flex;flex-wrap:wrap;gap:10px;justify-content:flex-end;margin-top:20px}@media (max-width:1024px){.search-box{max-width:100%}}@media (max-width:768px){.trainees-header{align-items:flex-start;flex-direction:column}.trainees-toolbar{align-items:stretch;flex-direction:column}.trainees-actions{width:100%}.trainees-actions .btn{flex:1 1;justify-content:center}.form-row{grid-template-columns:1fr}.table-container{padding:10px}.table-container .table{font-size:11px;min-width:1800px}.table-container .table td,.table-container .table th{font-size:11px;padding:8px 4px}.modal-actions{flex-direction:column}.modal-actions .btn{width:100%}.trainee-form{max-height:70vh}}@media (max-width:480px){.trainees-header h1{font-size:20px}.search-box{padding:8px 12px}.table-container{padding:5px}}.attendance{position:relative}.attendance-header{gap:15px;justify-content:space-between;margin-bottom:20px}.attendance-header,.attendance-header-left{align-items:center;display:flex;flex-wrap:wrap}.attendance-header-left{gap:20px}.batch-selector{display:flex;flex-direction:column;gap:6px}.batch-selector label{color:var(--text-secondary);font-size:13px;font-weight:600}.batch-selector select{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:8px;color:var(--text-primary);min-width:180px;padding:8px 12px}.operation-progress-overlay{align-items:center;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#00000080;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:10000}.operation-progress-card{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:12px;box-shadow:var(--shadow-lg);max-width:600px;min-width:400px;padding:30px 40px}@media (max-width:768px){.operation-progress-card{min-width:90%;padding:20px}}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(1.2)}}.links-list{grid-gap:20px;display:grid;gap:20px}.link-card{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:12px;box-shadow:var(--shadow);padding:20px;transition:all .3s}.link-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-2px)}.link-header{align-items:flex-start;gap:10px;margin-bottom:15px}.link-header h3{color:var(--text-primary);margin:0 0 5px}.link-date{font-size:14px;margin:0}.link-batch,.link-date{color:var(--text-secondary)}.link-batch{font-size:13px;font-weight:600;margin:2px 0}.session-badge{border-radius:999px;display:inline-block;font-size:12px;font-weight:600;letter-spacing:.3px;margin-top:5px;padding:4px 10px}.session-badge.single{background:#6366f126;color:#6366f1}.session-badge.dual{background:#10b98126;color:#10b981}.link-actions{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:10px}.link-url{border-top:1px solid var(--border-color);color:var(--text-tertiary);font-size:12px;padding-top:10px;word-break:break-all}.empty-state{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:12px;padding:50px}.modal-content.xlarge{max-width:1100px;width:95%}.records-table{max-height:500px;overflow-y:auto}@media (max-width:768px){.attendance-header{align-items:flex-start}.attendance-header,.link-actions{flex-direction:column}.link-actions .btn{width:100%}.link-header{flex-direction:column}}.export-modal-content{max-height:70vh;overflow-y:auto}.export-actions{display:flex;gap:10px;margin-bottom:20px}.export-fields h3{color:var(--text-primary);font-size:16px;margin-bottom:15px}.fields-grid{grid-gap:10px;border:1px solid var(--border-color);border-radius:8px;display:grid;gap:10px;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));margin-bottom:20px;max-height:300px;overflow-y:auto;padding:10px}.field-checkbox{border-radius:4px;transition:background-color .2s}.field-checkbox:hover{background-color:var(--hover-bg)}.checkbox-group{display:flex;flex-direction:column;gap:6px}.checkbox-label input{height:18px;width:18px}.helper-text{font-size:13px}.analytics-button{align-items:center;display:flex;font-weight:600;gap:6px}.analytics-controls{align-items:center;display:flex;flex-wrap:wrap;gap:15px;justify-content:space-between;margin-bottom:15px}.analytics-search{flex:1 1;min-width:240px;position:relative}.analytics-search input{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:8px;color:var(--text-primary);padding:10px 12px 10px 36px;width:100%}.analytics-search-icon{color:var(--text-secondary);font-size:16px;left:12px;position:absolute;top:50%;transform:translateY(-50%)}.analytics-table-wrapper{border:1px solid var(--border-color);border-radius:12px;max-height:70vh;overflow:hidden;overflow-y:auto}.analytics-table{border-collapse:collapse;width:100%}.analytics-table td,.analytics-table th{border-bottom:1px solid var(--border-color);padding:12px 16px;text-align:left}.analytics-table th{background:var(--bg-secondary);font-size:14px;letter-spacing:.4px;position:-webkit-sticky;position:sticky;text-transform:uppercase;top:0;z-index:1}.analytics-table tbody tr:hover{background:var(--hover-bg)}.analytics-sn .sn-tag{background:#6366f126;border-radius:999px;color:#6366f1;display:inline-flex;font-weight:600;padding:3px 8px}.analytics-sn small{color:var(--text-secondary);display:block;margin-top:4px}.analytics-name strong{color:var(--text-primary);display:block}.analytics-name small{color:var(--text-secondary)}.analytics-percentage span{border-radius:8px;display:inline-flex;font-weight:600;padding:4px 10px}.analytics-percentage span.good{background:#10b98126;color:#10b981}.analytics-percentage span.average{background:#f59e0b26;color:#f59e0b}.analytics-percentage span.poor{background:#ef444426;color:#ef4444}.analytics-meta{color:var(--text-secondary);display:flex;flex-direction:column;font-size:13px;gap:4px;min-width:220px;text-align:right}@media (max-width:480px){.link-card{padding:15px}.link-actions .btn{font-size:13px;padding:8px 12px}}.communication-header{align-items:center;flex-wrap:wrap;gap:15px;justify-content:space-between}.communication-header,.tabs{display:flex;margin-bottom:20px}.tabs{-webkit-overflow-scrolling:touch;border-bottom:2px solid var(--border-color);gap:10px;overflow-x:auto;scrollbar-width:none}.tabs::-webkit-scrollbar{display:none}.tab{align-items:center;background:none;border:none;border-bottom:3px solid #0000;color:var(--text-secondary);cursor:pointer;display:flex;font-size:14px;font-weight:500;gap:8px;padding:12px 24px;transition:all .3s;white-space:nowrap}.tab.active,.tab:hover{color:var(--active-color)}.tab.active{border-bottom-color:var(--active-color)}.logs-container{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:12px;box-shadow:var(--shadow);overflow-x:auto;padding:20px}.logs-table{width:100%}.message-cell{max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.form-note{background:var(--active-bg);border:1px solid var(--border-color);border-radius:8px;margin-bottom:20px;padding:12px}.form-note p{color:var(--active-color);font-size:12px;margin:0}.helper-text{color:var(--text-secondary);font-size:12px;margin-top:4px}.target-options{display:flex;flex-direction:column;gap:8px}.target-options label{align-items:center;color:var(--text-primary);display:flex;font-weight:600;gap:10px}.target-options input{cursor:pointer;height:16px;width:16px}.trainee-selector{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:10px;margin-bottom:20px;padding:15px}.selector-header{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:12px}.selector-header input{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:8px;color:var(--text-primary);flex:1 1;min-width:200px;padding:8px 12px}.selector-actions{display:flex;gap:8px}.selector-actions button{background:var(--active-bg);border:none;border-radius:6px;color:var(--active-color);cursor:pointer;font-size:12px;font-weight:600;padding:8px 12px}.selector-actions button:disabled{cursor:not-allowed;opacity:.5}.selector-list{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:8px;max-height:240px;overflow-y:auto}.selector-item{align-items:center;border-bottom:1px solid var(--border-color);display:flex;gap:10px;padding:10px 12px}.selector-item:last-child{border-bottom:none}.selector-item strong{color:var(--text-primary);display:block}.selector-item small{color:var(--text-secondary);display:block}.selector-item input{cursor:pointer;height:16px;width:16px}.selector-footer{color:var(--text-secondary);font-size:13px;margin-top:10px}.chunk-options{background:var(--bg-secondary);border:1px dashed var(--border-color);border-radius:10px;display:flex;flex-direction:column;gap:10px;margin-bottom:20px;padding:12px}.chunk-size-input{align-items:center;color:var(--text-secondary);display:flex;font-size:14px;gap:10px}.chunk-size-input input{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:6px;color:var(--text-primary);padding:6px 8px;text-align:center;width:80px}.checkbox-label{align-items:center;color:var(--text-primary);display:flex;font-weight:600;gap:10px}.checkbox-label input{cursor:pointer;height:16px;width:16px}@media (max-width:768px){.communication-header{align-items:flex-start;flex-direction:column}.tabs{border-bottom:none;flex-direction:row;width:100%}.tab,.tabs{border-left:none}.tab{border-bottom:3px solid #0000;flex:1 1;justify-content:center;padding:10px 15px}.tab.active{border-bottom-color:var(--active-color);border-left:none}.logs-container{padding:15px}}@media (max-width:480px){.tab{font-size:12px;padding:8px 12px}.logs-container{padding:10px}}.analytics h1{color:var(--text-primary);margin-bottom:30px}.analytics-summary{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));margin-bottom:30px}.summary-card{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:12px;box-shadow:var(--shadow);padding:20px;transition:all .3s}.summary-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-2px)}.summary-card h3{color:var(--text-secondary);font-size:14px;font-weight:500;margin-bottom:10px}.summary-number{color:var(--text-primary);font-size:36px;font-weight:700;line-height:1;margin:0 0 5px}.summary-subtitle{color:var(--text-tertiary);font-size:12px;margin:0}.charts-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(500px,1fr))}.chart-card{border-radius:12px;box-shadow:var(--shadow);padding:20px}.chart-card h2{color:var(--text-primary);font-size:18px;margin-bottom:20px}.course-table{overflow-x:auto}@media (max-width:1024px){.charts-grid{grid-template-columns:1fr}}@media (max-width:768px){.analytics-summary{grid-template-columns:1fr}.chart-card,.summary-card{padding:15px}.summary-number{font-size:28px}}@media (max-width:480px){.summary-number{font-size:24px}.chart-card{padding:10px}.chart-card h2{font-size:16px}}.batch-management{padding:20px}.batch-header{justify-content:space-between;margin-bottom:30px}.batch-header,.batch-header h1{align-items:center;display:flex}.batch-header h1{font-size:24px;gap:10px;margin:0}.batches-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fill,minmax(300px,1fr))}.batch-card{background:var(--card-bg);border:1px solid var(--border-color);border-radius:8px;padding:20px;transition:transform .2s,box-shadow .2s}.batch-card:hover{box-shadow:0 4px 12px #0000001a;transform:translateY(-2px)}.batch-card-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:10px}.batch-card-header h3{color:var(--text-primary);font-size:18px;margin:0}.batch-actions{display:flex;gap:8px}.batch-description{color:var(--text-secondary);font-size:14px;margin:10px 0}.batch-meta{border-top:1px solid var(--border-color);color:var(--text-secondary);font-size:12px;margin-top:15px;padding-top:15px}.batch-form{display:flex;flex-direction:column;gap:20px}@media (max-width:768px){.batch-header{align-items:flex-start;flex-direction:column;gap:15px}.batches-grid{grid-template-columns:1fr}}.profile-links{position:relative}.profile-links-header{align-items:center;display:flex;flex-wrap:wrap;gap:20px;justify-content:space-between;margin-bottom:25px}.profile-links-header h1{color:var(--text-primary);margin:0}.profile-links-header p{color:var(--text-secondary);margin:5px 0 0}.profile-links-list{grid-gap:18px;display:grid;gap:18px}.profile-link-card{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:12px;box-shadow:var(--shadow);padding:20px;transition:all .3s}.profile-link-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-2px)}.link-card-header{align-items:center;display:flex;gap:10px;justify-content:space-between;margin-bottom:12px}.link-card-header h3{color:var(--text-primary);margin:0}.link-card-header .link-date{color:var(--text-secondary);font-size:13px;margin:4px 0 0}.link-card-body{border-bottom:1px dashed var(--border-color);border-top:1px dashed var(--border-color);color:var(--text-tertiary);font-size:13px;padding:12px 0;word-break:break-all}.link-card-actions{display:flex;flex-wrap:wrap;gap:10px;margin-top:15px}.profile-link-form .form-group{margin-bottom:20px}.profile-link-form input{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:8px;color:var(--text-primary);padding:12px;width:100%}.field-selection-hint{color:var(--text-secondary);font-size:14px;margin:5px 0 15px}.field-selection-actions{display:flex;gap:10px;margin-bottom:15px}.field-selection-grid{grid-gap:12px;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:8px;display:grid;gap:12px;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));max-height:400px;overflow-y:auto;padding:15px}.field-checkbox{align-items:center;border-radius:6px;cursor:pointer;display:flex;gap:8px;padding:8px;transition:background .2s}.field-checkbox:hover{background:var(--bg-primary)}.field-checkbox input[type=checkbox]{accent-color:var(--primary-color);cursor:pointer;height:18px;width:18px}.field-checkbox span{color:var(--text-primary);font-size:14px;-webkit-user-select:none;user-select:none}.btn-sm{font-size:13px;padding:6px 12px}@media (max-width:768px){.field-selection-grid{grid-template-columns:1fr}}@media (max-width:576px){.link-card-actions .btn{flex:1 1}}.attendance-link{background:linear-gradient(135deg,#667eea,#764ba2);min-height:100vh;padding:20px;transition:all .3s}.attendance-link[data-theme=dark]{background:linear-gradient(135deg,#1f2937,#111827)}.attendance-link-header{color:#fff;margin-bottom:30px;text-align:center}.attendance-link-logo{background:#fff;border-radius:12px;box-shadow:0 6px 20px #00000040;height:auto;margin-bottom:10px;padding:6px;width:90px}.attendance-link-header h1{font-size:32px;margin-bottom:10px;text-shadow:0 2px 4px #0003}.link-info{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff1a;border:1px solid #fff3;border-radius:12px;display:inline-block;margin-top:20px;padding:20px}.link-info h2{font-size:24px;margin:0 0 10px}.link-info p{font-size:16px;margin:0;opacity:.9}.link-session-indicator{background:#fff3;border:1px solid #fff6;border-radius:999px;display:inline-block;font-weight:600;margin-top:12px;padding:6px 14px}.session-toggle{background:#ffffff26;border:1px solid #ffffff40;border-radius:999px;display:flex;gap:5px;margin:0 auto 25px;max-width:500px;padding:5px}.session-btn{background:#0000;border:none;border-radius:999px;color:#fff;cursor:pointer;flex:1 1;font-weight:600;padding:10px 0;transition:all .3s}.session-btn.active{background:#fff;box-shadow:0 4px 12px #00000026;color:#4f46e5}.attendance-search{margin:0 auto 25px;max-width:600px}.attendance-search input{border:none;border-radius:999px;box-shadow:0 6px 20px #00000026;font-size:15px;outline:none;padding:14px 18px;width:100%}.no-results{background:#0003;border-radius:12px;color:#fff;font-weight:600;padding:20px;text-align:center}.trainees-list{grid-gap:15px;display:grid;gap:15px;margin:0 auto;max-width:800px}.trainee-item{align-items:center;background:#fff;border-radius:12px;box-shadow:0 4px 6px #0000001a;display:flex;justify-content:space-between;padding:20px;transition:all .3s}.trainee-item:hover{box-shadow:0 6px 12px #00000026;transform:translateY(-2px)}.trainee-info{align-items:center;display:flex;flex:1 1;gap:15px;min-width:0}.serial-count{color:#4b5563;font-weight:700;min-width:24px;text-align:right}.tag-number{background:#2563eb;border-radius:20px;color:#fff;flex-shrink:0;font-size:14px;font-weight:600;padding:8px 16px;white-space:nowrap}.trainee-name{color:#1f2937;font-size:16px;font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.attendance-buttons{display:flex;flex-shrink:0;gap:10px}.btn-attendance{align-items:center;background:#fff;border:2px solid #e5e7eb;border-radius:8px;cursor:pointer;display:flex;font-size:14px;font-weight:600;gap:8px;padding:10px 20px;transition:all .3s;white-space:nowrap}.btn-attendance.present{color:#16a34a}.btn-attendance.present.active,.btn-attendance.present:hover{background:#16a34a;border-color:#16a34a;color:#fff;transform:scale(1.05)}.btn-attendance.absent{color:#dc2626}.btn-attendance.absent.active,.btn-attendance.absent:hover{background:#dc2626;border-color:#dc2626;color:#fff;transform:scale(1.05)}.btn-attendance:disabled{cursor:not-allowed;opacity:.5;transform:none!important}.attendance-link-error,.attendance-link-loading{align-items:center;color:#fff;display:flex;font-size:24px;justify-content:center;min-height:100vh}@media (max-width:768px){.attendance-link-header h1{font-size:24px}.link-info{padding:15px}.link-info h2{font-size:20px}.link-info p{font-size:14px}.trainee-item{align-items:flex-start;flex-direction:column;gap:15px;padding:15px}.trainee-info{flex-wrap:wrap;width:100%}.attendance-buttons{width:100%}.btn-attendance{flex:1 1;justify-content:center;padding:12px}}@media (max-width:480px){.attendance-link{padding:15px}.attendance-link-header h1{font-size:20px}.trainee-item{padding:12px}.tag-number{font-size:12px;padding:6px 12px}.trainee-name{font-size:14px}.btn-attendance{font-size:12px;padding:10px}}.profile-update-link{align-items:center;background:linear-gradient(135deg,#0f172a,#1e3a8a);display:flex;justify-content:center;min-height:100vh;padding:30px 15px}.profile-update-link[data-theme=light]{background:linear-gradient(135deg,#eef2ff,#dbeafe)}.profile-update-card{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:18px;box-shadow:0 20px 50px #0f172a40;max-width:960px;padding:30px;width:100%}.profile-update-header{margin-bottom:25px;text-align:center}.profile-update-header img{border:2px solid #ffffff4d;border-radius:12px;height:80px;margin-bottom:15px;object-fit:cover;width:80px}.profile-update-header h1{color:var(--text-primary);font-size:26px;margin:0}.profile-update-header p{color:var(--text-secondary);margin:8px 0 0}.fetch-form{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:12px;margin-bottom:30px;padding:20px}.form-row{grid-gap:15px;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));margin-bottom:15px}.form-grid,.form-row{display:grid;gap:15px}.form-grid{grid-gap:15px;grid-template-columns:repeat(auto-fit,minmax(230px,1fr))}.form-group.full-width{grid-column:1/-1}.form-group label{font-size:13px}.form-group input,.form-group select,.form-group textarea{background:var(--bg-tertiary);border-radius:10px;padding:12px}.profile-update-form h2{color:var(--text-primary);margin-bottom:15px}.profile-update-error,.profile-update-loading{align-items:center;color:#fff;display:flex;font-size:20px;justify-content:center;min-height:100vh}@media (max-width:768px){.profile-update-card{padding:20px}.form-grid{grid-template-columns:1fr}}.evaluation-page{color:var(--text-primary);font-family:DM Sans,Segoe UI,Tahoma,Geneva,Verdana,sans-serif;font-family:"DM Sans",var(--font-stack,"Segoe UI",Tahoma,Geneva,Verdana,sans-serif);padding:20px 24px 60px}.evaluation-hero{background:linear-gradient(135deg,#2196f31f,#2196f30d);border:1px solid var(--border-color);border-radius:18px;display:flex;gap:24px;justify-content:space-between;margin-bottom:24px;overflow:hidden;padding:32px}.evaluation-hero h1{font-size:1.9rem;margin:8px 0}.evaluation-hero p{margin:4px 0;max-width:760px}.hero-actions{display:flex;flex-direction:column;gap:10px;min-width:220px}.btn{border:1px solid #0000;border-radius:999px;font-weight:600;justify-content:center;padding:10px 18px;transition:transform .2s ease,background .2s ease}.btn.primary{background:var(--primary-color);box-shadow:0 6px 14px #2196f333;color:#fff}.btn.outline{background:#0000;border-color:var(--border-color);color:var(--text-primary)}.btn.ghost{background:#0000;color:var(--text-secondary)}.btn.danger{background:#f43f5e1a;border-color:#f43f5e33;color:#b91c1c}.btn.small{border-radius:12px;font-size:.85rem;padding:6px 10px}.btn:hover:not(:disabled){transform:translateY(-1px)}.btn:disabled{opacity:.6}.eyebrow{color:#7f8ea3;color:var(--text-tertiary,#7f8ea3);font-size:.78rem;letter-spacing:.08em;margin:0}.evaluation-grid{grid-gap:24px;display:grid;gap:24px;grid-template-columns:2fr 1fr}.builder-panel,.history-panel{display:flex;flex-direction:column;gap:20px}.panel-card{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:16px;box-shadow:0 12px 24px #0f172a0a;overflow:hidden;padding:20px}.panel-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:18px}.panel-header h2{margin:6px 0 0}.field-grid{grid-gap:16px;gap:16px}.form-group{display:flex;flex-direction:column;gap:6px}.form-group.full{grid-column:1/-1}.form-group label{color:var(--text-secondary);font-weight:600}.form-group input,.form-group select,.form-group textarea{background:var(--bg-primary);border-radius:12px;padding:10px 12px}.questions-card .question-stack{display:flex;flex-direction:column;gap:16px}.question-card{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:14px;box-shadow:inset 0 0 0 1px #2196f30d;padding:16px}.question-card header{display:flex;flex-wrap:wrap;gap:12px;justify-content:space-between;margin-bottom:10px}.question-select{align-items:center;display:flex;justify-content:center}.question-select input{height:16px;width:16px}.question-label{align-items:center;display:flex;flex:1 1;gap:10px}.question-label input{background:#0000;border:none;border-bottom:1px dashed var(--border-color);flex:1 1;padding:6px 4px}.question-controls{display:flex;flex-wrap:wrap;gap:6px;width:100%}.question-controls select{border:1px solid var(--border-color);border-radius:12px;flex:1 1;min-width:180px;padding:8px 10px}.question-selection-bar{align-items:center;border:1px dashed var(--border-color);border-radius:12px;display:flex;gap:12px;justify-content:space-between;margin-bottom:14px;padding:10px 14px}.icon-btn{align-items:center;background:#0000;border:1px solid var(--border-color);border-radius:50%;color:var(--text-secondary);cursor:pointer;display:inline-flex;height:34px;justify-content:center;width:34px}.icon-btn:focus-visible{outline:2px solid var(--primary-color);outline-offset:2px}.icon-btn.danger{border-color:#ef444466;color:#ef4444}.options-list{display:flex;flex-direction:column;gap:8px;margin-top:12px}.option-item{align-items:center;display:flex;gap:8px}.option-item input{border:1px solid var(--border-color);border-radius:10px;flex:1 1;padding:8px 10px}.question-footer{align-items:center;display:flex;justify-content:space-between;margin-top:12px}.checkbox{cursor:pointer;gap:8px}.checkbox,.chip{align-items:center;display:inline-flex}.chip{background:#6366f11f;border-radius:999px;color:var(--text-secondary);font-size:.85rem;gap:6px;padding:4px 10px}.builder-actions{display:flex;flex-wrap:wrap;gap:12px}.link-preview{border-top:1px solid var(--border-color);margin-top:18px;padding-top:12px}.link-preview p{color:var(--text-secondary);margin-top:0}.link-row{align-items:center;background:var(--bg-primary);border:1px dashed var(--border-color);border-radius:12px;display:flex;gap:10px;padding:10px 14px}.link-row code{flex:1 1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.forms-list{gap:14px;list-style:none;margin:0;padding:0}.form-item,.forms-list{display:flex;flex-direction:column}.form-item{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:14px;gap:10px;padding:16px}.form-meta h3{margin:0}.chips-row,.form-actions{display:flex;flex-wrap:wrap;gap:8px}.chips-row{margin-top:6px}.status-chip{background:#2196f31f;border-radius:999px;color:#2196f3;color:var(--primary-color,#2196f3);font-size:.85rem;padding:4px 12px;text-transform:capitalize}.status-chip.active{background:#10b9811f;color:#10b981}.status-chip.draft{background:#f973161f;color:#f97316}.status-chip.neutral{background:#6366f11f;color:#4f46e5}.empty-state{border:1px dashed var(--border-color);border-radius:14px;color:var(--text-secondary);padding:20px;text-align:center}.form-search input{border:1px solid var(--border-color);border-radius:12px;margin-bottom:12px;padding:10px 12px;width:100%}.responses-modal{align-items:center;background:#0f172ab3;display:flex;inset:0;justify-content:center;padding:30px;position:fixed;z-index:2000}.responses-content{background:var(--bg-secondary);border-radius:20px;max-height:90vh;overflow:hidden auto;padding:30px;position:relative;width:min(1000px,95vw)}.responses-content header h2{margin:8px 0 2px}.responses-actions{align-items:center;display:flex;flex-wrap:wrap;gap:12px;justify-content:space-between;margin:18px 0 10px}.responses-actions .actions-left{display:flex;flex-wrap:wrap;gap:10px}.close-btn{background:#0000;font-size:1.5rem;position:absolute;right:14px;top:14px}.chart-section{margin-top:16px}.chart-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));margin-top:10px}.chart-card{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:14px;padding:12px}.responses-table{margin-top:24px}.table-scroll{border:1px solid var(--border-color);border-radius:12px;overflow:auto}.table-scroll table{border-collapse:collapse;width:100%}.table-scroll td,.table-scroll th{border-bottom:1px solid var(--border-color);font-size:.92rem;padding:10px 14px}.table-scroll td:first-child,.table-scroll th:first-child{text-align:center;width:40px}.table-scroll td:last-child,.table-scroll th:last-child{text-align:right;width:60px}.response-actions{text-align:right}.individual-section{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:16px;margin-top:28px;padding:18px}.individual-header{align-items:center;display:flex;flex-wrap:wrap;gap:12px;justify-content:space-between}.individual-header select{border:1px solid var(--border-color);border-radius:12px;min-width:220px;padding:8px 10px}.individual-info{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));margin:16px 0}.individual-chart{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:14px;padding:10px}.per-person-answers{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));margin-top:16px}.per-person-answers>div{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:12px;padding:12px}.spin.muted{color:var(--text-secondary)}@media (max-width:1024px){.evaluation-grid{grid-template-columns:1fr}.history-panel{order:-1}.hero-actions{flex-direction:row;flex-wrap:wrap}}@media (max-width:768px){.evaluation-page{padding:16px}.evaluation-hero{flex-direction:column;padding:24px}.field-grid{grid-template-columns:1fr}.question-card header,.question-controls{flex-direction:column}.question-controls select{width:100%}.builder-actions{flex-direction:column}.forms-list .form-item{padding:14px}.responses-content{padding:24px}.responses-actions{align-items:flex-start;flex-direction:column}}@media (max-width:540px){.evaluation-page{padding:12px}.hero-actions .btn{width:100%}.question-card{padding:14px}.option-item{align-items:stretch;flex-direction:column}.option-item .icon-btn{align-self:flex-end}.link-row{align-items:flex-start;flex-direction:column;gap:6px}.forms-list .form-item h3{font-size:1.05rem}}.evaluation-link-page{align-items:center;background:linear-gradient(180deg,#0f172a,#1e293b 65%,#0f172a);color:#0f172a;display:flex;justify-content:center;min-height:100vh;padding:40px 16px}.evaluation-link-card{background:#f8fafc;border-radius:28px;box-shadow:0 30px 60px #0f172a59;padding:36px;width:min(900px,100%)}.evaluation-link-card.error-state,.evaluation-link-card.loading-state{font-size:1.1rem;padding:60px;text-align:center}.evaluation-link-card.error-state{color:#ef4444}.link-header{align-items:center;display:flex;flex-wrap:wrap;gap:20px;justify-content:space-between}.link-header img{border-radius:16px;width:120px}.eyebrow{color:#64748b;font-size:.8rem;letter-spacing:.2em;text-transform:uppercase}.link-header h1{margin:6px 0 10px}.meta-list{color:#475569;display:flex;flex-wrap:wrap;gap:14px;list-style:none;margin:0;padding:0}.meta-list li{display:flex;gap:6px}.form-description{background:#2563eb14;border:1px solid #2563eb33;border-radius:16px;margin:20px 0;padding:16px}.section-card{background:#fff;border:1px solid #0f172a14;border-radius:20px;margin-bottom:20px;padding:22px}.section-card h3{margin-bottom:16px;margin-top:0}.field-grid{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(auto-fit,minmax(220px,1fr))}.field-grid label{color:#475569;display:flex;flex-direction:column;font-weight:600;gap:6px}.field-grid input,.field-grid textarea{border:1px solid #0f172a26;border-radius:12px;font-size:1rem;padding:10px 12px}.field-grid .full{grid-column:1/-1}.question-stack{display:flex;flex-direction:column;gap:16px}.question-block{background:#f1f5f9;border:1px solid #0f172a14;border-radius:16px;padding:16px}.question-title{align-items:flex-start;display:flex;gap:10px;margin-bottom:14px}.question-title span{color:#2563eb;font-weight:700}.required{color:#ef4444}.options-grid{display:flex;flex-wrap:wrap;gap:10px}.option-pill{align-items:center;background:#fff;border:1px solid #0f172a1a;border-radius:999px;cursor:pointer;display:inline-flex;gap:8px;padding:8px 14px}.option-pill input{accent-color:#2563eb}.option-pill.checkbox{border-radius:12px}.question-block textarea{border:1px solid #0f172a1a;border-radius:12px;padding:12px;width:100%}.error-banner{background:#ef44441a;border:1px solid #ef44444d;border-radius:12px;color:#b91c1c;margin-bottom:16px;padding:12px}.error-banner.subtle{margin-top:12px}.blocked-section{border:1px dashed #0f172a33;border-radius:14px;color:#64748b;margin-bottom:16px;padding:16px;text-align:center}.btn.primary.submit-btn{border-radius:16px;font-size:1.1rem;padding:14px;width:100%}.evaluation-link-card .btn{align-items:center;border:none;border-radius:999px;cursor:pointer;display:inline-flex;font-weight:600;gap:8px;justify-content:center}.evaluation-link-card .btn.primary{background:#2563eb;box-shadow:0 12px 24px #2563eb40;color:#fff}.evaluation-link-card .btn:disabled{cursor:not-allowed;opacity:.6}.submission-state{padding:60px 20px;text-align:center}.submission-state svg{color:#22c55e;height:56px;width:56px}.footnote{color:#94a3b8;font-size:.9rem;margin-top:14px;text-align:center}.verify-card .verify-row{display:flex;flex-wrap:wrap;gap:12px}.verify-card input{border:1px solid #0f172a33;border-radius:12px;flex:1 1;font-size:1rem;padding:10px 12px}.success-banner{background:#10b9811f;border:1px solid #10b9814d;border-radius:12px;color:#0f5132;font-weight:600;margin-top:12px;padding:12px}.identity-card .identity-grid{grid-gap:14px;display:grid;gap:14px;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));margin-top:12px}.identity-label{color:#94a3b8;display:block;font-size:.75rem;letter-spacing:.08em;text-transform:uppercase}.spin{animation:spin .9s linear infinite}.already-responded-card{background:linear-gradient(135deg,#10b9811a,#10b9810d);border:2px solid #10b9814d;text-align:center}.already-responded-content{align-items:center;display:flex;flex-direction:column;gap:16px;padding:20px 0}.already-responded-icon{color:#10b981;height:64px;margin-bottom:8px;width:64px}.already-responded-content h3{color:#0f5132;font-size:1.5rem;margin:0}.already-responded-content p{color:#065f46;font-size:1rem;margin:0}.submitted-date{color:#64748b!important;font-size:.9rem!important;font-style:italic;margin-top:8px!important}@media (max-width:768px){.evaluation-link-card{padding:24px}.link-header{align-items:flex-start;flex-direction:column}}.login-container{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;justify-content:center;min-height:100vh;padding:20px;position:relative}.login-container[data-theme=dark]{background:linear-gradient(135deg,#1f2937,#111827)}.login-card{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:16px;box-shadow:0 20px 60px #0000004d;max-width:420px;padding:40px;width:100%}.login-header{margin-bottom:30px;text-align:center}.login-logo-container{align-items:center;background:var(--bg-tertiary);border-radius:12px;box-shadow:var(--shadow);display:flex;height:80px;justify-content:center;margin:0 auto 20px;overflow:hidden;width:80px}.login-logo{display:block;height:100%;object-fit:cover;width:100%}.login-logo-placeholder{align-items:center;background:var(--primary-color);border-radius:12px;color:#fff;display:flex;font-size:18px;font-weight:700;height:100%;justify-content:center;width:100%}.login-header h1{color:var(--text-primary);font-size:28px;font-weight:700;margin:0 0 5px}.login-header h2{color:var(--text-secondary);font-size:14px;font-weight:400;margin:0}.login-subtitle{color:var(--text-tertiary);font-size:12px;margin-top:6px}.error-message{background-color:#dc26261a;border:1px solid #dc262633;border-radius:8px;color:var(--danger);margin-bottom:20px;padding:12px;text-align:center}.login-footer{color:var(--text-tertiary);font-size:12px;margin-top:20px;text-align:center}.login-footer p{margin:0}.login-actions{display:flex;justify-content:flex-end;margin-bottom:10px}.link-btn{background:none;border:none;color:var(--active-color);cursor:pointer;font-size:13px;font-weight:600;padding:0}.forgot-panel{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:12px;padding:20px}.forgot-panel p{color:var(--text-secondary);font-size:14px;margin-top:0}.forgot-actions{display:flex;flex-wrap:wrap;gap:10px;margin:15px 0}.info-message{background:var(--active-bg);border:1px solid var(--border-color);border-radius:8px;color:var(--active-color);font-size:13px;margin-bottom:10px;padding:12px}@media (max-width:480px){.login-card{padding:30px 20px}.login-logo-container{height:60px;width:60px}.login-header h1{font-size:24px}}.layout{background-color:var(--bg-secondary);color:var(--text-primary);display:flex;flex-direction:column;min-height:100vh;transition:background-color .3s,color .3s}.header{background:var(--bg-primary);border-bottom:1px solid var(--border-color);box-shadow:var(--shadow);padding:15px 20px;position:-webkit-sticky;position:sticky;top:0;z-index:100}.header-content{gap:20px;justify-content:space-between;margin:0 auto;max-width:1400px}.header-content,.logo-section{align-items:center;display:flex}.logo-section{flex:1 1;gap:15px;min-width:0}.logo-container{align-items:center;background:var(--bg-tertiary);border-radius:10px;box-shadow:var(--shadow);display:flex;flex-shrink:0;height:60px;justify-content:center;overflow:hidden;width:60px}.logo{height:100%;object-fit:cover;width:100%}.logo-text{min-width:0}.logo-text h1{color:var(--text-primary);font-size:24px;font-weight:700;margin:0}.logo-text h1,.logo-text p{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.logo-text p{color:var(--text-secondary);font-size:12px;margin:2px 0 0}.header-actions{flex-shrink:0;gap:10px}.header-actions,.theme-toggle{align-items:center;display:flex}.theme-toggle{background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:8px;color:var(--text-primary);cursor:pointer;font-size:18px;height:40px;justify-content:center;padding:0;transition:all .3s;width:40px}.theme-toggle:hover{background:var(--hover-bg);transform:scale(1.05)}.logout-btn{align-items:center;background-color:#dc2626;border:none;border-radius:8px;color:#fff;cursor:pointer;display:flex;font-size:14px;font-weight:500;gap:8px;padding:8px 16px;transition:all .3s;white-space:nowrap}.logout-btn:hover{background-color:#b91c1c;box-shadow:var(--shadow-lg);transform:translateY(-1px)}.layout-body{display:flex;flex:1 1;gap:0;margin:0 auto;max-width:1400px;position:relative;width:100%}.sidebar{align-self:flex-start;background:var(--bg-primary);border-right:1px solid var(--border-color);box-shadow:2px 0 4px #0000000d;height:calc(100vh - 90px);overflow-x:hidden;overflow-y:auto;padding:20px 0;position:-webkit-sticky;position:sticky;top:90px;transition:all .3s;width:250px}.nav{display:flex;flex-direction:column;gap:5px;padding:0 10px}.nav-link{align-items:center;border-radius:8px;color:var(--text-secondary);display:flex;font-size:14px;font-weight:500;gap:12px;padding:12px 15px;text-decoration:none;transition:all .3s}.nav-link span{flex:1 1}.nav-link:hover{background-color:var(--hover-bg);color:var(--active-color);transform:translateX(3px)}.nav-link.active{background-color:var(--active-bg);color:var(--active-color);font-weight:600}.nav-link svg{flex-shrink:0;font-size:18px}.main-content{background-color:var(--bg-secondary);flex:1 1;height:calc(100vh - 90px);min-width:0;overflow-x:hidden;overflow-y:auto;padding:30px}@media (max-width:1024px){.logo-text h1{font-size:20px}.logo-text p{font-size:11px}.logo-container{height:50px;width:50px}.sidebar{position:-webkit-sticky;position:sticky;top:90px;width:220px}.main-content,.sidebar{height:calc(100vh - 90px)}}@media (max-width:768px){.header{padding:12px 15px}.header-content{flex-wrap:wrap;gap:10px}.logo-section{flex:1 1 100%;order:1}.logo-container{height:45px;width:45px}.logo-text h1{font-size:18px}.logo-text p{display:none}.header-actions{flex:1 1;justify-content:flex-end;order:2}.logout-btn{font-size:13px;padding:8px 12px}.logout-btn span{display:none}.layout-body{flex-direction:column}.sidebar{border-bottom:1px solid var(--border-color);border-right:none;box-shadow:0 2px 4px #0000000d;overflow-y:visible;padding:10px 0;position:relative;top:0;width:100%}.main-content,.sidebar{height:auto;min-height:auto}.nav{-webkit-overflow-scrolling:touch;flex-direction:row;gap:5px;overflow-x:auto;padding:0 10px;scrollbar-width:none}.nav::-webkit-scrollbar{display:none}.nav-link{flex-direction:column;gap:5px;min-width:80px;padding:10px 15px;text-align:center;white-space:nowrap}.nav-link span{font-size:11px}.nav-link:hover{transform:translateX(0) translateY(-2px)}.main-content{padding:15px}}@media (max-width:480px){.header{padding:10px}.logo-text h1{font-size:16px}.logo-container{height:40px;width:40px}.theme-toggle{font-size:16px;height:36px;width:36px}.logout-btn{padding:6px 10px}.nav-link{min-width:70px;padding:8px 12px}.nav-link span{font-size:10px}.main-content{padding:10px}}:root[data-theme=light]{--bg-primary:#fff;--bg-secondary:#f5f5f5;--bg-tertiary:#f9fafb;--text-primary:#1f2937;--text-secondary:#6b7280;--text-tertiary:#9ca3af;--border-color:#e5e7eb;--shadow:0 1px 3px #0000001a;--shadow-lg:0 4px 6px #0000001a;--hover-bg:#f9fafb;--active-bg:#eff6ff;--active-color:#2563eb;--success:#16a34a;--danger:#dc2626;--warning:#f59e0b}:root[data-theme=dark]{--bg-primary:#1f2937;--bg-secondary:#111827;--bg-tertiary:#374151;--text-primary:#f9fafb;--text-secondary:#d1d5db;--text-tertiary:#9ca3af;--border-color:#374151;--shadow:0 1px 3px #0000004d;--shadow-lg:0 4px 6px #0006;--hover-bg:#374151;--active-bg:#1e3a8a;--active-color:#60a5fa;--success:#22c55e;--danger:#ef4444;--warning:#fbbf24}.App{background-color:var(--bg-secondary);color:var(--text-primary);min-height:100vh;transition:background-color .3s,color .3s}.container{margin:0 auto;max-width:1200px;padding:0 20px}.btn{align-items:center;border:none;border-radius:8px;cursor:pointer;display:inline-flex;font-size:14px;font-weight:500;gap:8px;padding:10px 20px;transition:all .3s;white-space:nowrap}.btn-primary{background-color:var(--active-color);color:#fff}.btn-primary:hover{box-shadow:var(--shadow-lg);opacity:.9;transform:translateY(-1px)}.btn-secondary{background-color:var(--bg-tertiary);border:1px solid var(--border-color);color:var(--text-primary)}.btn-secondary:hover{background-color:var(--hover-bg)}.btn-danger{background-color:var(--danger);color:#fff}.btn-danger:hover{opacity:.9;transform:translateY(-1px)}.btn-success{background-color:var(--success);color:#fff}.btn-success:hover{opacity:.9;transform:translateY(-1px)}.btn:disabled{cursor:not-allowed;opacity:.5;transform:none!important}.form-group{margin-bottom:20px}.form-group label{color:var(--text-primary);display:block;font-weight:500;margin-bottom:5px}.form-group input,.form-group select,.form-group textarea{background-color:var(--bg-primary);border:1px solid var(--border-color);border-radius:8px;color:var(--text-primary);font-size:14px;padding:10px;transition:all .3s;width:100%}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--active-color);box-shadow:0 0 0 3px #2563eb1a;outline:none}.card{border:1px solid var(--border-color);border-radius:8px;box-shadow:var(--shadow);margin-bottom:20px;padding:20px}.card,.table{background:var(--bg-primary)}.table{border-collapse:collapse;margin-top:20px;width:100%}.table td,.table th{border-bottom:1px solid var(--border-color);padding:12px;text-align:left}.table th{background-color:var(--bg-tertiary);color:var(--text-primary);font-weight:600;position:-webkit-sticky;position:sticky;top:0;z-index:10}.table tr:hover{background-color:var(--hover-bg)}.modal{align-items:center;background-color:#00000080;bottom:0;display:flex;justify-content:center;left:0;padding:20px;position:fixed;right:0;top:0;z-index:1000}.modal-content{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:12px;box-shadow:var(--shadow-lg);max-height:90vh;max-width:500px;overflow-y:auto;padding:30px;width:100%}.modal-content.large{max-width:800px}.loading-screen{align-items:center;color:var(--text-secondary);display:flex;flex-direction:column;gap:12px;justify-content:center;min-height:100vh}.loading-screen .spinner{animation:spin .8s linear infinite;border:4px solid var(--border-color);border-radius:50%;border-top-color:var(--active-color);height:48px;width:48px}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.modal-header{align-items:center;border-bottom:1px solid var(--border-color);display:flex;justify-content:space-between;margin-bottom:20px;padding-bottom:15px}.modal-header h2{color:var(--text-primary);margin:0}.close-btn{align-items:center;background:none;border:none;border-radius:6px;color:var(--text-secondary);cursor:pointer;display:flex;font-size:24px;height:32px;justify-content:center;padding:0;transition:all .3s;width:32px}.close-btn:hover{background:var(--hover-bg);color:var(--text-primary)}@media (max-width:768px){.container{padding:0 10px}.table{font-size:12px}.table td,.table th{padding:8px}.modal{padding:10px}.modal-content{padding:20px}.btn{font-size:13px;padding:8px 16px}}@media (max-width:480px){.table{font-size:11px}.table td,.table th{padding:6px}.modal-content{padding:15px}}
/*# sourceMappingURL=main.58dbdcde.css.map*/