:root{--bg: #f8fafc;--card: #ffffff;--text: #1e293b;--text-secondary: #64748b;--subtle: #94a3b8;--primary: #3b82f6;--primary-600: #2563eb;--primary-700: #1d4ed8;--primary-100: #dbeafe;--primary-50: #eff6ff;--accent: #8b5cf6;--accent-hover: #7c3aed;--success: #10b981;--success-light: #d1fae5;--warning: #f59e0b;--warning-light: #fef3c7;--danger: #ef4444;--danger-light: #fee2e2;--border: #e2e8f0;--border-light: #f1f5f9;--user: #f8fafc;--bot: #ffffff;--chip: #f1f5f9;--sidebar-bg: #ffffff;--sidebar-hover: #f1f5f9;--sidebar-active: #e0e7ff;--shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, .05);--shadow: 0 1px 3px 0 rgba(0, 0, 0, .1), 0 1px 2px -1px rgba(0, 0, 0, .1);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .1), 0 2px 4px -2px rgba(0, 0, 0, .1);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .1), 0 4px 6px -4px rgba(0, 0, 0, .1);--shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, .1), 0 8px 10px -6px rgba(0, 0, 0, .1);--radius-sm: 6px;--radius: 8px;--radius-lg: 12px;--radius-xl: 16px;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,PingFang SC,Hiragino Sans GB,Microsoft YaHei,sans-serif;line-height:1.6;font-weight:400;color-scheme:light;color:var(--text);background-color:var(--bg);font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%;min-width:fit-content}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,PingFang SC,Hiragino Sans GB,Microsoft YaHei,sans-serif;color:var(--text);background:var(--bg);line-height:1.6}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--bg);border-radius:var(--radius-sm)}::-webkit-scrollbar-thumb{background:var(--border);border-radius:var(--radius-sm);transition:background .2s ease}::-webkit-scrollbar-thumb:hover{background:var(--subtle)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;border:1px solid var(--border);background:var(--card);color:var(--text);padding:10px 20px;border-radius:var(--radius);font-size:14px;font-weight:500;cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1);white-space:nowrap;box-shadow:var(--shadow-sm)}.btn:hover{background:var(--sidebar-hover);border-color:var(--primary);box-shadow:var(--shadow);transform:translateY(-1px)}.btn:active{transform:translateY(0);box-shadow:var(--shadow-sm)}.btn-primary{border-color:var(--primary);background:linear-gradient(135deg,var(--primary) 0%,var(--primary-600) 100%);color:#fff;box-shadow:var(--shadow)}.btn-primary:hover{background:linear-gradient(135deg,var(--primary-600) 0%,var(--primary-700) 100%);border-color:var(--primary-600);box-shadow:var(--shadow-md);transform:translateY(-2px)}.btn-primary:disabled{background:var(--subtle);border-color:var(--subtle);color:#fff;cursor:not-allowed;opacity:.6;transform:none;box-shadow:none}.btn-icon{padding:8px;min-width:36px;height:36px;border-radius:var(--radius-sm)}.loader{display:inline-flex;gap:4px;vertical-align:middle}.dot{width:6px;height:6px;border-radius:50%;background:#64748b;opacity:.6;animation:bounce 1s infinite ease-in-out paused}.loader:active .dot,.loader:hover .dot{animation-play-state:running}.dot:nth-child(2){animation-delay:.15s}.dot:nth-child(3){animation-delay:.3s}@keyframes bounce{0%,80%,to{transform:translateY(0);opacity:.5}40%{transform:translateY(-4px);opacity:1}}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}a{font-weight:500;color:var(--primary);text-decoration:inherit}a:hover{color:var(--primary-600)}button{border-radius:var(--radius);border:1px solid var(--border);padding:10px 20px;font-size:14px;font-weight:500;font-family:inherit;background:linear-gradient(135deg,var(--primary) 0%,var(--primary-600) 100%);color:#fff;cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1);box-shadow:var(--shadow)}button:hover{background:linear-gradient(135deg,var(--primary-600) 0%,var(--primary-700) 100%);box-shadow:var(--shadow-md);transform:translateY(-1px)}button:active{transform:translateY(0);box-shadow:var(--shadow-sm)}button:focus,button:focus-visible{outline:2px solid var(--primary-100);outline-offset:2px}body{margin:0;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:var(--bg)}.App{min-height:100vh;background:var(--bg)}.app{display:flex;flex-direction:column;min-height:100vh;min-width:fit-content;height:100dvh;overflow:hidden;background:var(--bg)}.main-layout{display:flex;flex:1;overflow:hidden;width:100%;min-width:fit-content}.main-content{flex:1;display:flex;flex-direction:column;min-width:fit-content;width:100%;transition:all .3s ease;position:relative;z-index:1;overflow-x:auto;background:var(--bg);border-radius:12px 0 0 12px;margin-left:-8px}.home{padding:40px 20px;max-width:1200px;margin:0 auto}.home h1{color:var(--text);text-align:center;font-size:36px;font-weight:700;margin-bottom:16px;background:linear-gradient(135deg,var(--primary) 0%,var(--accent) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.home p{text-align:center;font-size:18px;color:var(--text-secondary);line-height:1.6;margin-bottom:48px}.quick-link-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:24px;text-decoration:none;color:var(--text);transition:all .3s cubic-bezier(.4,0,.2,1);box-shadow:var(--shadow);position:relative;overflow:hidden}.quick-link-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--primary) 0%,var(--accent) 100%);transform:scaleX(0);transition:transform .3s ease}.quick-link-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);border-color:var(--primary-100)}.quick-link-card:hover:before{transform:scaleX(1)}.quick-link-card h3{margin-top:0;margin-bottom:12px;color:var(--primary);font-size:18px;font-weight:600}.quick-link-card p{color:var(--text-secondary);font-size:14px;line-height:1.6;margin:0}.features{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:20px;margin-top:40px}.feature{background:var(--card);border:1px solid var(--border);border-radius:8px;padding:20px}.feature h2{color:var(--primary);margin-top:0}.dashboard{padding:40px 20px;max-width:1200px;margin:0 auto}.dashboard h2{color:var(--text);font-size:28px;font-weight:600;margin-bottom:12px}.dashboard>p{color:var(--text-secondary);font-size:16px;margin-bottom:32px}.dashboard-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:24px;margin-top:32px}.card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:24px;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);box-shadow:var(--shadow);position:relative;overflow:hidden}.card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--primary) 0%,var(--accent) 100%);transform:scaleX(0);transition:transform .3s ease}.card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);border-color:var(--primary-100)}.card:hover:before{transform:scaleX(1)}.card h3{margin-top:0;margin-bottom:12px;color:var(--text);font-size:18px;font-weight:600}.card p{color:var(--text-secondary);font-size:14px;line-height:1.6;margin:0}.profile{padding:20px;max-width:800px;margin:0 auto}.profile-content{background:var(--card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:32px;margin-top:20px;box-shadow:var(--shadow-md)}.profile-card{margin-bottom:32px}.profile-card h3{color:var(--text);border-bottom:2px solid var(--border-light);padding-bottom:12px;margin-top:0;margin-bottom:20px;font-size:18px;font-weight:600}.profile-field{display:flex;margin-bottom:18px;align-items:center}.profile-field label{font-weight:600;width:150px;color:var(--text);font-size:14px}.profile-field span{flex:1;padding:10px 14px;background:linear-gradient(180deg,#f8fafc,#f1f5f9);border-radius:var(--radius);border:1px solid var(--border);color:var(--text);font-size:14px}.profile-actions{display:flex;gap:12px;justify-content:flex-start;margin-top:24px}.training-records,.training-purchases{padding:20px;width:100%;min-width:fit-content;margin:0 auto;overflow-x:auto;box-sizing:border-box}.header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.header-buttons{display:flex;gap:10px}.header h2{margin:0}.record-form,.purchase-form{background:var(--card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:28px;margin-bottom:30px;box-shadow:var(--shadow-md)}.record-form h3,.purchase-form h3{margin-top:0;margin-bottom:24px;color:var(--text);font-size:20px;font-weight:600;padding-bottom:12px;border-bottom:2px solid var(--border-light)}.quick-apply-section{background:linear-gradient(180deg,#f8fafc,#f1f5f9);border:1px solid var(--border);border-radius:var(--radius-lg);padding:20px;margin-bottom:24px;box-shadow:var(--shadow-sm)}.quick-apply-section h4{margin-top:0;margin-bottom:16px;color:var(--text);font-weight:600;font-size:16px;border-bottom:2px solid var(--border);padding-bottom:10px}.form-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:15px;margin-bottom:15px}.form-group{display:flex;flex-direction:column}.form-group label{margin-bottom:5px;font-weight:500}.form-group input,.form-group select{padding:10px 14px;border:1px solid var(--border);border-radius:var(--radius);font-size:14px;transition:all .2s ease;background:var(--card);color:var(--text)}.form-group input:focus,.form-group select:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-50)}.form-group input:hover,.form-group select:hover{border-color:var(--primary-100)}.form-group textarea{padding:10px 14px;border:1px solid var(--border);border-radius:var(--radius);font-size:14px;transition:all .2s ease;background:var(--card);color:var(--text);font-family:inherit;resize:vertical}.form-group textarea:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-50)}.form-group textarea:hover{border-color:var(--primary-100)}.form-actions button{padding:10px 20px}.records-list,.purchases-list{background:var(--card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:28px;box-shadow:var(--shadow-md)}.records-list h3,.purchases-list h3{margin-top:0;margin-bottom:20px;color:var(--text);font-size:20px;font-weight:600;padding-bottom:12px;border-bottom:2px solid var(--border-light)}table{width:100%;border-collapse:separate;border-spacing:0;border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow)}table th,table td{padding:14px 16px;text-align:left;border-bottom:1px solid var(--border-light)}table th{background:linear-gradient(180deg,#f8fafc,#f1f5f9);font-weight:600;color:var(--text);font-size:13px;text-transform:uppercase;letter-spacing:.5px;position:sticky;top:0;z-index:10}table tbody tr{transition:all .2s ease;background:var(--card)}table tbody tr:hover{background:var(--primary-50);transform:scale(1.001)}table tbody tr:last-child td{border-bottom:none}.action-buttons{display:flex;gap:8px;flex-wrap:wrap}.action-buttons button{padding:8px 14px;font-size:13px;font-weight:500;border-radius:var(--radius);cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1);border:1px solid transparent;box-shadow:var(--shadow-sm)}.action-buttons button:first-child{background:linear-gradient(135deg,var(--primary) 0%,var(--primary-600) 100%);color:#fff;border-color:var(--primary)}.action-buttons button:first-child:hover{background:linear-gradient(135deg,var(--primary-600) 0%,var(--primary-700) 100%);box-shadow:var(--shadow-md);transform:translateY(-1px)}.action-buttons button:nth-child(2){background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff;border-color:#ef4444;padding:8px 12px}.action-buttons button:nth-child(2):hover{background:linear-gradient(135deg,#dc2626,#b91c1c);box-shadow:var(--shadow-md);transform:translateY(-1px)}.action-buttons button:nth-child(3){background:linear-gradient(135deg,var(--success) 0%,#059669 100%);color:#fff;border-color:var(--success)}.action-buttons button:nth-child(3):hover{background:linear-gradient(135deg,#059669,#047857);box-shadow:var(--shadow-md);transform:translateY(-1px)}.error-message{background:var(--danger-light);border:1px solid #fecaca;color:#991b1b;padding:14px 18px;border-radius:var(--radius-lg);font-size:14px;margin-bottom:20px;position:relative;word-break:break-word;-webkit-user-select:text;user-select:text;box-shadow:var(--shadow-sm);display:flex;align-items:start;gap:12px}.error-message:before{content:"⚠";font-size:18px;flex-shrink:0}.error-message.error{background:var(--danger-light);border-color:#fecaca;color:#991b1b}.error-message.error:before{content:"❌"}.error-message.warning{background:var(--warning-light);border-color:#fde68a;color:#92400e}.error-message.warning:before{content:"⚠️"}.error-message.information{background:#dbeafe;border-color:#bae6fd;color:#075985}.error-message.information:before{content:"ℹ️"}.error-message strong{margin-right:8px;font-weight:600}.close-error{position:absolute;top:10px;right:10px;background:#0000000d;border:none;font-size:18px;cursor:pointer;color:inherit;padding:0;width:28px;height:28px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius);transition:all .2s ease}.close-error:hover{background:#0000001a;transform:scale(1.1)}.comments-section{background:linear-gradient(180deg,#f8fafc,#f1f5f9);border:1px solid var(--border);border-radius:var(--radius-lg);padding:20px;margin:10px 0;min-height:200px;box-shadow:var(--shadow-sm)}.comments-section h4{margin-top:0;margin-bottom:16px;color:var(--text);font-weight:600;font-size:16px;border-bottom:2px solid var(--border);padding-bottom:10px}.comments-list{max-height:300px;overflow-y:auto;margin-bottom:15px;padding-right:8px}.add-comment{display:flex;flex-direction:column;gap:12px}.add-comment textarea{min-height:80px;resize:vertical;padding:12px 14px;border:1px solid var(--border);border-radius:var(--radius);font-size:14px;transition:all .2s ease;background:var(--card);color:var(--text);font-family:inherit}.add-comment textarea:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-50)}.add-comment button{align-self:flex-start;min-width:120px}.comment{background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:14px;margin-bottom:12px;transition:all .2s ease;box-shadow:var(--shadow-sm)}.comment:hover{box-shadow:var(--shadow);border-color:var(--primary-100)}.comment-header{display:flex;justify-content:space-between;margin-bottom:8px;font-size:13px}.comment-header strong{color:var(--text);font-weight:600}.comment-date{color:var(--text-secondary);font-size:12px}.comment-text{font-size:14px;color:var(--text);line-height:1.6}.summary-row{background:linear-gradient(180deg,#f8fafc,#f1f5f9);font-weight:600}.summary-row td{border-top:2px solid var(--primary);padding:16px;color:var(--text)}.course-total{display:inline-flex;align-items:center;margin-right:16px;padding:8px 14px;background:linear-gradient(135deg,var(--primary-50) 0%,#dbeafe 100%);border:1px solid var(--primary-100);border-radius:var(--radius-lg);font-size:13px;font-weight:600;color:var(--primary);box-shadow:var(--shadow-sm)}.course-total strong{color:var(--primary-700);margin-left:4px}.reports{padding:20px;max-width:1200px;margin:0 auto}.reports h2{margin-top:0;color:var(--text);font-size:28px;font-weight:600}.report-section{margin-bottom:48px;background:var(--card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:28px;box-shadow:var(--shadow-md)}.report-section h3{color:var(--primary);border-bottom:2px solid var(--border-light);padding-bottom:12px;margin-top:0;margin-bottom:24px;font-size:20px;font-weight:600}.report-section h4{color:var(--text);margin-top:24px;margin-bottom:16px;font-size:16px;font-weight:600}.report-section table{width:100%;border-collapse:separate;border-spacing:0;margin-top:16px;background:var(--card);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow)}.report-section table th,.report-section table td{padding:14px 16px;text-align:left;border-bottom:1px solid var(--border-light)}.report-section table th{background:linear-gradient(180deg,#f8fafc,#f1f5f9);font-weight:600;color:var(--text);font-size:13px;text-transform:uppercase;letter-spacing:.5px}.report-section table tbody tr{transition:all .2s ease}.report-section table tbody tr:hover{background:var(--primary-50)}.report-section table tr:last-child td{border-bottom:none}.navbar{display:flex;justify-content:space-between;align-items:center;background-color:#333;padding:1rem 2rem;color:#fff}.nav-brand a{color:#fff;text-decoration:none;font-size:1.5rem;font-weight:700}.nav-links{display:flex;list-style:none}.nav-links li{margin-left:1rem}.nav-links a{color:#fff;text-decoration:none;padding:.5rem 1rem;border-radius:4px;transition:background-color .3s}.nav-links a:hover{background-color:#555}.home,.login,.register,.dashboard,.training-records,.training-purchases{max-width:1200px;margin:2rem auto;padding:2rem;background-color:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a}.quick-links{margin:48px 0}.quick-links h2{margin-bottom:24px;color:var(--text);font-size:24px;font-weight:600}.quick-links-container{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:24px;margin-bottom:48px}.features{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:24px;margin-top:40px}.feature{background:var(--card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:28px;text-align:center;transition:all .3s cubic-bezier(.4,0,.2,1);box-shadow:var(--shadow);position:relative;overflow:hidden}.feature:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--primary) 0%,var(--accent) 100%);transform:scaleX(0);transition:transform .3s ease}.feature:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);border-color:var(--primary-100)}.feature:hover:before{transform:scaleX(1)}.feature h2{color:var(--primary);margin-top:0;margin-bottom:12px;font-size:20px;font-weight:600}.feature p{color:var(--text-secondary);line-height:1.6;margin:0}.form-group{margin-bottom:1rem}.form-group label{display:block;margin-bottom:.5rem;font-weight:700}.form-group input{width:100%;padding:.5rem;border:1px solid #ddd;border-radius:4px;font-size:1rem}.form-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem}button{background-color:#007bff;color:#fff;border:none;padding:.75rem 1.5rem;font-size:1rem;border-radius:4px;cursor:pointer;transition:background-color .3s}button:hover{background-color:#0056b3}table{width:100%;border-collapse:collapse;margin-top:1rem;table-layout:auto}table th,table td{padding:.75rem;text-align:left;border-bottom:1px solid #ddd;vertical-align:top}table th{background-color:#f8f9fa;font-weight:700;white-space:nowrap;min-width:80px}table th:nth-child(1){min-width:120px}table th:nth-child(2){min-width:120px}table th:nth-child(4){min-width:100px}table th:nth-child(5){min-width:80px}table th:nth-child(6){min-width:100px}table th:nth-child(8){min-width:100px}table th:nth-last-child(3){min-width:200px}table th:nth-last-child(2){min-width:150px}.filters{margin-bottom:24px;padding:20px;background:linear-gradient(180deg,#f8fafc,#f1f5f9);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm)}.filter-row{display:flex;gap:16px;flex-wrap:wrap;align-items:end}.filters label{display:flex;flex-direction:column;align-items:flex-start;gap:8px;font-weight:500;color:var(--text);font-size:14px}.filters select,.filters input{padding:10px 14px;border:1px solid var(--border);border-radius:var(--radius);font-size:14px;min-width:150px;height:42px;background:var(--card);color:var(--text);transition:all .2s ease;box-sizing:border-box}.filters select:hover,.filters input:hover{border-color:var(--primary)}.filters select:focus,.filters input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-50)}.filters input{min-width:200px}.trained-status{display:inline-flex;align-items:center;padding:6px 12px;border-radius:var(--radius-lg);font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;box-shadow:var(--shadow-sm)}.trained-status.trained{background:linear-gradient(135deg,var(--success) 0%,#059669 100%);color:#fff;border:none}.trained-status.not-trained{background:linear-gradient(135deg,var(--warning) 0%,#d97706 100%);color:#fff;border:none}table td:not(:nth-last-child(3)):not(:nth-last-child(2)){white-space:nowrap;overflow:hidden;text-overflow:ellipsis}table td:nth-last-child(3){white-space:normal;max-width:200px;word-wrap:break-word;min-height:2.5rem}table td:nth-last-child(2){white-space:normal;min-width:120px;max-width:150px}.action-buttons button{white-space:normal;height:auto;padding:4px 8px;font-size:12px;line-height:1.2}table td:nth-child(6){white-space:nowrap;min-width:120px}table td:nth-child(8){white-space:nowrap;min-width:100px}table td:nth-child(1){min-width:120px}table td:nth-child(2){min-width:120px}table td:nth-child(4){min-width:100px}table td:nth-child(5){min-width:80px}table td:nth-child(7){min-width:100px}.remark-section{margin-top:1rem;padding-top:1rem;border-top:1px solid #dee2e6}.remark-section h4{margin-top:0;color:var(--primary);border-bottom:1px solid #dee2e6;padding-bottom:.5rem}.remark-text{font-size:14px;color:#212529;line-height:1.4;white-space:pre-wrap}.error{color:#dc3545;background-color:#f8d7da;border:1px solid #f5c6cb;padding:.75rem;border-radius:4px;margin-bottom:1rem}.header{display:flex;justify-content:space-between;align-items:center;margin-bottom:32px;padding-bottom:16px;border-bottom:2px solid var(--border-light)}.header h2{margin:0;color:var(--text);font-size:28px;font-weight:600}.header-buttons{display:flex;gap:12px}@media (min-width: 1200px){.training-records,.training-purchases{width:100%}}@media (min-width: 1400px){.training-records,.training-purchases{padding:20px 40px}}@media (max-width: 768px){.navbar{flex-direction:column;padding:1rem}.nav-links{margin-top:1rem;flex-wrap:wrap;justify-content:center}.nav-links li{margin:.25rem}.form-row{grid-template-columns:1fr}.training-records,.training-purchases{padding:10px;width:100vw;max-width:100vw}.filter-row{flex-direction:column;align-items:stretch}.filters select,.filters input{min-width:auto;width:100%}table{font-size:.9rem;width:max-content}table th,table td{padding:.5rem}table td:nth-child(1),table th:nth-child(1){min-width:100px}table td:nth-last-child(3),table th:nth-last-child(3){min-width:150px;max-width:150px}table td:nth-last-child(2),table th:nth-last-child(2){min-width:120px}.action-buttons{flex-direction:column;gap:4px}.action-buttons button{width:100%;padding:6px;font-size:12px}.comments-section{min-height:150px}.add-comment button{min-width:100px;padding:6px 10px;font-size:13px}}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;justify-content:center;align-items:center;z-index:1000;animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-content{background:#fff;border-radius:var(--radius-xl);padding:32px;max-width:500px;width:90%;box-shadow:var(--shadow-xl);position:relative;animation:slideUp .3s cubic-bezier(.4,0,.2,1)}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.modal-content h3{margin-top:0;margin-bottom:16px;color:var(--text);font-size:22px;font-weight:600}.modal-content p{margin-bottom:24px;color:var(--text-secondary);line-height:1.6}.modal-actions{display:flex;gap:12px;justify-content:flex-end}.btn{padding:10px 20px;border-radius:var(--radius);cursor:pointer;font-size:14px;font-weight:500;border:1px solid transparent;transition:all .2s cubic-bezier(.4,0,.2,1);box-shadow:var(--shadow-sm)}.btn-danger{background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff;border-color:#ef4444}.btn-danger:hover{background:linear-gradient(135deg,#dc2626,#b91c1c);box-shadow:var(--shadow-md);transform:translateY(-1px)}.btn-secondary{background:var(--card);color:var(--text);border-color:var(--border)}.btn-secondary:hover{background:var(--sidebar-hover);border-color:var(--subtle);box-shadow:var(--shadow)}.pagination-controls{display:flex;justify-content:space-between;align-items:center;margin:24px 0;padding:16px 0;border-top:1px solid var(--border);border-bottom:1px solid var(--border)}.page-size-selector label{display:flex;align-items:center;gap:10px;font-size:14px;color:var(--text);font-weight:500}.page-size-selector select{padding:8px 12px;border:1px solid var(--border);border-radius:var(--radius);font-size:14px;background:var(--card);color:var(--text);cursor:pointer;transition:all .2s ease}.page-size-selector select:hover{border-color:var(--primary)}.page-size-selector select:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-50)}.pagination{display:flex;justify-content:center;align-items:center;gap:8px;margin:20px 0;flex-wrap:wrap}.pagination-button{padding:8px 14px;border:1px solid var(--border);background-color:var(--card);color:var(--text);border-radius:var(--radius);cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1);min-width:40px;font-weight:500;box-shadow:var(--shadow-sm)}.pagination-button:hover:not(:disabled){background:linear-gradient(135deg,var(--primary) 0%,var(--primary-600) 100%);color:#fff;border-color:var(--primary);box-shadow:var(--shadow);transform:translateY(-1px)}.pagination-button.active{background:linear-gradient(135deg,var(--primary) 0%,var(--primary-600) 100%);color:#fff;border-color:var(--primary);box-shadow:var(--shadow)}.pagination-button:disabled{opacity:.4;cursor:not-allowed;background:var(--sidebar-hover)}.loading-indicator{text-align:center;padding:24px;color:var(--text-secondary);font-style:italic;font-size:14px}.training-courses{padding:20px;width:100%;min-width:fit-content;margin:0 auto;overflow-x:auto;box-sizing:border-box}.training-courses .header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.training-courses .header-buttons{display:flex;gap:10px}.training-courses .courses-list{background:var(--card);border:1px solid var(--border);border-radius:8px;padding:20px}.training-courses .courses-list h3{margin-top:0;color:var(--primary)}.status-badge{display:inline-flex;align-items:center;padding:6px 12px;border-radius:var(--radius-lg);font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;box-shadow:var(--shadow-sm)}.status-badge.active{background:linear-gradient(135deg,var(--success) 0%,#059669 100%);color:#fff}.status-badge.inactive{background:linear-gradient(135deg,var(--subtle) 0%,#64748b 100%);color:#fff}.status-badge.trained{background:linear-gradient(135deg,var(--success) 0%,#059669 100%);color:#fff}.status-badge.not-trained{background:linear-gradient(135deg,var(--warning) 0%,#d97706 100%);color:#fff}.status-badge.pending{background:linear-gradient(135deg,var(--subtle) 0%,#64748b 100%);color:#fff}.checkbox-label{margin-left:8px;font-weight:400;cursor:pointer}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:9999;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);padding:20px;min-height:100vh;min-height:-webkit-fill-available}.modal-content{background:var(--card);border-radius:12px;width:100%;max-width:400px;max-height:calc(100vh - 40px);max-height:-webkit-fill-available;overflow-y:auto;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;border:1px solid var(--border);animation:modalSlideIn .3s ease-out;position:relative;-webkit-overflow-scrolling:touch}@keyframes modalSlideIn{0%{opacity:0;transform:translateY(-20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:24px 24px 0;margin-bottom:20px}.modal-header h2{margin:0;font-size:24px;font-weight:600;color:var(--text)}.close-btn{background:none;border:none;font-size:24px;cursor:pointer;color:var(--subtle);padding:4px;border-radius:4px;transition:all .2s ease;line-height:1}.close-btn:hover{background:var(--sidebar-hover);color:var(--text)}.password-strength{margin-top:5px;font-size:14px;font-weight:700}.password-strength.weak{color:#e74c3c}.password-strength.medium{color:#f39c12}.password-strength.strong{color:#27ae60}.login-form{padding:0 24px}.form-group{margin-bottom:20px}.password-input-container{position:relative;display:flex;align-items:center}.password-input-container input{flex:1;padding-right:35px}.password-hint{position:absolute;right:10px;color:#666;font-size:14px;background:#f5f5f5;width:22px;height:22px;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:help;-webkit-user-select:none;user-select:none}.password-hint:hover{background:#e0e0e0;color:#333}.password-requirements{display:block;margin-top:5px;font-size:12px;color:#666;line-height:1.4}.form-group label{display:block;margin-bottom:8px;font-weight:500;color:var(--text);font-size:14px}.form-group input{width:100%;padding:12px 16px;border:1px solid var(--border);border-radius:8px;font-size:14px;background:var(--bg);color:var(--text);transition:all .2s ease;box-sizing:border-box}.form-group input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #10a37f1a}.form-group input::placeholder{color:var(--subtle)}.login-btn{width:100%;padding:12px 16px;background:var(--primary);color:#fff;border:none;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease;margin-bottom:20px}.login-btn:hover:not(:disabled){background:#0d9488;transform:translateY(-1px)}.login-btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.submit-btn{width:100%;padding:16px 20px;background:var(--primary);color:#fff;border:none;border-radius:10px;font-size:16px;font-weight:600;cursor:pointer;transition:all .3s ease;margin-bottom:20px;box-shadow:0 2px 8px #10a37f33;letter-spacing:.5px}.submit-btn:hover:not(:disabled){background:#0d9488;transform:translateY(-2px);box-shadow:0 4px 12px #10a37f4d}.submit-btn:active:not(:disabled){transform:translateY(0);box-shadow:0 2px 6px #10a37f33}.submit-btn:disabled{opacity:.6;cursor:not-allowed;transform:none;box-shadow:0 2px 8px #10a37f1a}.error-message{background:#fef2f2;border:1px solid #fecaca;color:#dc2626;padding:12px 16px;border-radius:8px;font-size:14px;margin-bottom:20px}.success-message{background:#f0fdf4;border:1px solid #bbf7d0;color:#16a34a;padding:12px 16px;border-radius:8px;font-size:14px;margin-bottom:20px}.modal-footer{padding:20px 24px 24px;text-align:center;border-top:1px solid var(--border);margin-top:20px}.switch-form{color:var(--subtle);font-size:14px}.switch-btn{background:none;border:none;color:var(--primary);cursor:pointer;font-size:14px;font-weight:600;text-decoration:none;transition:all .2s ease;padding:4px 8px;border-radius:4px}.switch-btn:hover{color:#0d9488;background:#10a37f1a}@media (max-width: 480px){.modal-content{max-width:none;width:90%}.modal-header{padding:20px 20px 0}.login-form{padding:0 20px}.modal-footer{padding:0 20px 20px}}.training-templates{padding:20px;max-width:1200px;margin:0 auto}.training-templates .header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;padding-bottom:10px;border-bottom:1px solid #eee}.header-actions{display:flex;align-items:center;gap:15px}.toggle-container{display:flex;align-items:center;gap:5px}.toggle-label{white-space:nowrap}.templates-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:20px;margin-top:20px}.template-card{border:1px solid #ddd;border-radius:8px;padding:15px;background-color:#f9f9f9;box-shadow:0 2px 4px #0000001a;transition:all .2s ease;display:flex;flex-direction:column;height:100%}.template-card:hover{box-shadow:0 4px 8px #00000026}.template-card.inactive{background-color:#f0f0f0;opacity:.7;border-color:#ccc}.template-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px;flex-shrink:0}.template-header h3{margin:0;color:#333;font-size:1.2em}.template-details{margin-bottom:15px;flex-grow:1}.detail-row{display:flex;margin-bottom:5px;font-size:.9em}.label{font-weight:700;color:#555;min-width:80px;margin-right:10px}.value{flex:1;color:#333;word-break:break-word}.template-actions{display:flex;gap:8px;justify-content:flex-end;margin-top:auto;flex-shrink:0}.btn-template{background-color:#28a745;color:#fff;border:none;padding:8px 12px;border-radius:4px;cursor:pointer;font-size:14px;margin-right:8px;margin-bottom:8px}.btn-template:hover{background-color:#218838}.template-buttons{display:flex;flex-wrap:wrap;gap:10px;margin-top:10px}.form-section{margin-bottom:30px;padding:20px;border:1px solid #eee;border-radius:8px;background-color:#f8f9fa}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;display:flex;justify-content:center;align-items:center;z-index:1000}.modal-content{background:#fff;padding:20px;border-radius:8px;max-width:500px;width:90%;max-height:90vh;overflow-y:auto}.modal-content h3{margin-top:0;color:#333}.form-actions{display:flex;gap:10px;margin-top:20px}.form-row{display:flex;gap:15px}@media (max-width: 768px){.form-row{flex-direction:column;gap:10px}}.btn-small{padding:5px 10px;font-size:.8em}.btn-success{background-color:#28a745}.btn-success:hover{background-color:#218838}.btn-danger{background-color:#dc3545}.btn-danger:hover{background-color:#c82333}.status-badge{padding:4px 8px;border-radius:12px;font-size:.8em;font-weight:700}.status-badge.active{background-color:#d4edda;color:#155724}.status-badge.inactive{background-color:#f8d7da;color:#721c24}.no-templates{text-align:center;padding:40px 20px;color:#666;grid-column:1 / -1}.no-templates p{margin-bottom:20px;font-size:1.1em}@media (max-width: 1100px){.templates-grid{grid-template-columns:repeat(auto-fill,minmax(320px,1fr))}}@media (max-width: 992px){.templates-grid{grid-template-columns:repeat(auto-fill,minmax(300px,1fr))}}@media (max-width: 768px){.training-templates .header{flex-direction:column;align-items:stretch;gap:10px}.header-actions{flex-direction:column;align-items:flex-start;gap:10px}.templates-grid{grid-template-columns:1fr}.template-header{flex-direction:column;align-items:stretch;gap:10px}.template-actions{justify-content:flex-end}.form-row{flex-direction:column;gap:10px}.detail-row{flex-direction:column;gap:2px}.label{min-width:unset}}@media (max-width: 576px){.training-templates{padding:15px}.template-card{padding:12px}.templates-grid{gap:15px}}.app-header{display:flex;justify-content:space-between;align-items:center;padding:10px 20px;background-color:#f8f9fa;border-bottom:1px solid #dee2e6}.app-header-logo{display:flex;align-items:center}.logo-icon{width:24px;height:24px;margin-right:10px}.app-header-logo span{font-size:1.2rem;font-weight:700;color:#374151}.app-header-actions{display:flex;gap:12px;align-items:center}.app-header-actions .btn{padding:10px 16px;font-size:15px;font-weight:500;border-radius:8px;min-height:40px;color:#374151}.user-menu{display:flex;align-items:center;gap:12px}.user-info{display:flex;align-items:center;gap:8px;padding:8px 12px;background:#f7f7f8;border-radius:6px;border:1px solid #e5e7eb;cursor:pointer;color:#374151}.user-info:hover{background:#e5e5e5;border-color:#9ca3af}.username{font-weight:500;color:#374151;font-size:14px}.question-count{font-size:12px;color:#9ca3af;font-weight:400}.logout-btn{padding:8px!important;min-width:auto!important}.logout-btn .btn-text{display:none}.main-navbar{background:linear-gradient(180deg,#fff,#f8fafc);border-bottom:1px solid var(--border);padding:0 32px;box-shadow:var(--shadow-sm)}.nav-links{display:flex;list-style:none;margin:0;padding:0;gap:8px}.nav-links li{margin:0}.nav-link{display:block;padding:14px 20px;color:var(--text)!important;text-decoration:none;font-weight:500;font-size:14px;border-radius:var(--radius);transition:all .2s cubic-bezier(.4,0,.2,1);background-color:transparent;position:relative}.nav-link:after{content:"";position:absolute;bottom:8px;left:20px;right:20px;height:2px;background:linear-gradient(90deg,var(--primary) 0%,var(--accent) 100%);transform:scaleX(0);transition:transform .2s ease}.nav-link:hover{background-color:var(--primary-50);color:var(--primary)!important;transform:translateY(-1px)}.nav-link:hover:after{transform:scaleX(1)}.nav-link.active{background:linear-gradient(135deg,var(--primary) 0%,var(--primary-600) 100%);color:#fff!important;box-shadow:var(--shadow)}.nav-link.active:after{display:none}.navbar-container{position:sticky;top:0;z-index:100;background:#fff;box-shadow:var(--shadow-md);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}
