@import"https://fonts.googleapis.com/css2?family=DM+Sans:ital,opsz,wght@0,9..40,400;0,9..40,500;0,9..40,600;0,9..40,700&family=JetBrains+Mono:wght@400;500&display=swap";@import"https://fonts.googleapis.com/css2?family=DM+Sans:ital,opsz,wght@0,9..40,400;0,9..40,500;0,9..40,600;0,9..40,700&display=swap";:root{--acct-bg: #f1f5f9;--acct-card: #ffffff;--acct-border: #e2e8f0;--acct-text: #0f172a;--acct-text-muted: #64748b;--acct-primary: #0c4a6e;--acct-primary-hover: #075985;--acct-primary-light: #e0f2fe;--acct-accent: #0369a1;--acct-accent-light: #f0f9ff;--acct-debit: #b91c1c;--acct-debit-bg: #fee2e2;--acct-credit: #047857;--acct-credit-bg: #d1fae5;--acct-success: #059669;--acct-warning: #d97706;--acct-danger: #dc2626;--acct-shadow: 0 1px 3px rgba(0,0,0,.06);--acct-shadow-lg: 0 10px 40px -10px rgba(12, 74, 110, .15);--acct-radius: 12px;--acct-radius-sm: 8px}.accounting-page{font-family:DM Sans,system-ui,sans-serif;background:var(--acct-bg);min-height:100vh;display:flex;flex-direction:column;color:var(--acct-text)}.accounting-header{background:linear-gradient(135deg,var(--acct-primary) 0%,#0e7490 100%);color:#fff;padding:24px 32px;box-shadow:0 4px 20px #0c4a6e40}.accounting-header-inner{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:20px}.accounting-header h1{margin:0;font-size:1.5rem;font-weight:700;letter-spacing:-.02em}.accounting-badge{display:inline-flex;align-items:center;gap:8px;margin-top:6px;padding:6px 12px;background:#fff3;border-radius:6px;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.08em}.accounting-header .header-actions{display:flex;align-items:center;gap:12px;flex-wrap:wrap}.accounting-header .accounting-period input{background:#fffffff2;color:var(--acct-text);border-color:#ffffff80}.accounting-layout{display:flex;flex:1;min-height:calc(100vh - 120px)}.accounting-sidebar{width:240px;min-width:240px;background:var(--acct-card);border-right:1px solid var(--acct-border);padding:20px 0;box-shadow:var(--acct-shadow)}.accounting-nav-item{display:flex;align-items:center;gap:12px;padding:14px 24px;border:none;background:transparent;width:100%;text-align:left;font-size:.9375rem;font-weight:500;color:var(--acct-text-muted);cursor:pointer;transition:all .2s;font-family:inherit;border-left:3px solid transparent}.accounting-nav-item:hover{background:var(--acct-primary-light);color:var(--acct-primary)}.accounting-nav-item.active{background:var(--acct-primary-light);color:var(--acct-primary);border-left-color:var(--acct-primary);font-weight:600}.accounting-nav-icon{font-size:1.125rem;width:24px;text-align:center}.accounting-main{flex:1;padding:28px 32px;overflow-y:auto}.accounting-card{background:var(--acct-card);border-radius:var(--acct-radius);box-shadow:var(--acct-shadow);padding:28px;margin-bottom:24px;border:1px solid var(--acct-border)}.accounting-card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:24px;padding-bottom:20px;border-bottom:2px solid var(--acct-border)}.accounting-card-header h3{margin:0;font-size:1.25rem;font-weight:600;color:var(--acct-text)}.accounting-card-header .card-desc{font-size:.875rem;color:var(--acct-text-muted);margin-top:6px}.kpi-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:20px;margin-bottom:28px}.kpi-card{background:var(--acct-card);border-radius:var(--acct-radius);padding:24px;border:1px solid var(--acct-border);box-shadow:var(--acct-shadow);transition:transform .2s,box-shadow .2s}.kpi-card:hover{transform:translateY(-2px);box-shadow:var(--acct-shadow-lg)}.kpi-card.revenue{border-left:4px solid var(--acct-primary)}.kpi-card.payments{border-left:4px solid var(--acct-credit)}.kpi-card.balance{border-left:4px solid var(--acct-debit)}.kpi-card.payroll{border-left:4px solid var(--acct-warning)}.kpi-card-label{font-size:.75rem;color:var(--acct-text-muted);font-weight:600;text-transform:uppercase;letter-spacing:.06em;margin-bottom:8px}.kpi-card-value{font-size:1.625rem;font-weight:700;color:var(--acct-text);font-variant-numeric:tabular-nums}.kpi-card-hint{font-size:.75rem;color:var(--acct-text-muted);margin-top:8px}.analysis-card{background:var(--acct-card);border-radius:var(--acct-radius);padding:28px;border:1px solid var(--acct-border)}.analysis-card h3{margin:0 0 20px;font-size:1.0625rem;font-weight:600}.progress-bar{height:10px;background:var(--acct-border);border-radius:999px;overflow:hidden;margin-top:8px}.progress-bar-fill{height:100%;background:linear-gradient(90deg,var(--acct-primary),var(--acct-credit));border-radius:999px;transition:width .3s ease}.btn-accounting{padding:10px 20px;border:none;border-radius:var(--acct-radius-sm);font-size:.875rem;font-weight:600;cursor:pointer;font-family:inherit;transition:all .2s}.btn-accounting-primary{background:var(--acct-primary);color:#fff}.btn-accounting-primary:hover:not(:disabled){background:var(--acct-primary-hover)}.btn-accounting-danger{background:var(--acct-danger);color:#fff}.btn-accounting-danger:hover:not(:disabled){background:#b91c1c}.btn-accounting-danger:disabled{opacity:.6;cursor:not-allowed}.btn-accounting-outline{background:transparent;border:2px solid var(--acct-border);color:var(--acct-text)}.btn-accounting-outline:hover{border-color:var(--acct-primary);color:var(--acct-primary)}.accounting-input{padding:12px 14px;border:2px solid var(--acct-border);border-radius:var(--acct-radius-sm);font-size:.9375rem;font-family:inherit;transition:border-color .2s}.accounting-input:focus{outline:none;border-color:var(--acct-primary)}.accounting-input-group{display:flex;gap:8px;flex-wrap:wrap}.accounting-table-wrap{overflow-x:auto;border-radius:var(--acct-radius);border:1px solid var(--acct-border)}.accounting-table{width:100%;border-collapse:collapse;font-size:.875rem}.accounting-table th{background:var(--acct-primary);color:#fff;padding:14px 16px;text-align:left;font-weight:600;font-size:.6875rem;text-transform:uppercase;letter-spacing:.06em}.accounting-table th:last-child{text-align:center}.accounting-table td{padding:14px 16px;border-bottom:1px solid var(--acct-border)}.accounting-table tbody tr{transition:background .15s}.accounting-table tbody tr:hover{background:var(--acct-primary-light)}.accounting-table tbody tr:nth-child(2n){background:#fafbfc}.accounting-table tbody tr:nth-child(2n):hover{background:var(--acct-primary-light)}.accounting-table tfoot tr{background:var(--acct-primary)!important;color:#fff;font-weight:600}.accounting-table tfoot td{padding:14px 16px;border:none}.badge-debit{display:inline-block;padding:5px 10px;background:var(--acct-debit-bg);color:var(--acct-debit);border-radius:6px;font-size:.75rem;font-weight:600;font-family:JetBrains Mono,monospace}.badge-credit{display:inline-block;padding:5px 10px;background:var(--acct-credit-bg);color:var(--acct-credit);border-radius:6px;font-size:.75rem;font-weight:600;font-family:JetBrains Mono,monospace}.manual-entry-form{display:grid;grid-template-columns:120px 1fr 100px 100px 1fr;gap:10px;align-items:center;padding:18px;background:var(--acct-accent-light);border-radius:var(--acct-radius-sm);border:1px dashed var(--acct-border)}@media(max-width:900px){.manual-entry-form{grid-template-columns:1fr 1fr}}.journal-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin:24px 0}.journal-stat{padding:18px;border-radius:var(--acct-radius-sm);color:#fff;font-size:.8125rem}.journal-stat-count{background:linear-gradient(135deg,var(--acct-primary) 0%,var(--acct-accent) 100%)}.journal-stat-debit{background:linear-gradient(135deg,#b91c1c,#dc2626)}.journal-stat-credit{background:linear-gradient(135deg,#047857,#059669)}.journal-stat-balance{background:linear-gradient(135deg,#b45309,#d97706)}.journal-stat-value{font-size:1.25rem;font-weight:700;margin-top:4px}.journal-tfoot-totals td{padding:15px;border-top:2px solid var(--acct-border);vertical-align:middle;background:#fff;color:var(--acct-text)}.journal-tfoot-label{font-size:13px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--acct-text)!important;text-align:left}.journal-tfoot-empty{background:#fff!important;color:var(--acct-text-muted)}.journal-tfoot-debit{text-align:right!important;font-size:15px;font-weight:700;color:var(--acct-debit)!important;background:#fff!important}.journal-tfoot-credit{text-align:right!important;font-size:15px;font-weight:700;color:var(--acct-credit)!important;background:#fff!important}.journal-tfoot-balance{text-align:center!important;font-size:18px;font-weight:700;color:var(--acct-text)!important;background:#fff!important}.journal-tfoot-unbalanced{color:var(--acct-debit)!important}.journal-tfoot-usd{font-size:11px;font-weight:500;color:var(--acct-text-muted)!important;margin-top:3px}.journal-tfoot-message td{padding:12px 15px;text-align:center;font-weight:700;border-top:1px solid var(--acct-border)}.journal-tfoot-message.journal-tfoot-balanced td{background:#ecfdf5;color:#065f46}.journal-tfoot-message.journal-tfoot-unbalanced td{background:#fef2f2;color:#721c24}.plan-search-row{display:flex;gap:12px;margin-bottom:20px;flex-wrap:wrap}.balance-grid,.bilan-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px;max-width:900px;width:100%;margin:0 auto;align-items:stretch}.balance-section{background:var(--acct-card);border-radius:var(--acct-radius);padding:24px;border:1px solid var(--acct-border);display:flex;flex-direction:column;min-height:560px}.balance-list{flex:1;min-height:0}.balance-total{margin-top:16px}.balance-section.actif{border-top:4px solid var(--acct-credit)}.balance-section.passif{border-top:4px solid var(--acct-debit)}.balance-total.actif{background:linear-gradient(135deg,#d1fae5,#a7f3d0);color:#065f46}.balance-total.passif{background:linear-gradient(135deg,#fee2e2,#fecaca);color:#991b1b}.equation-banner.balanced{background:#d1fae5;border:2px solid var(--acct-credit);color:#065f46}.equation-banner.unbalanced{background:#fef3c7;border:2px solid var(--acct-warning);color:#92400e}.empty-state{padding:48px 24px;text-align:center;color:var(--acct-text-muted)}.empty-state-icon{font-size:3rem;margin-bottom:16px;opacity:.5}.empty-state-title{font-size:1.125rem;font-weight:600;color:var(--acct-text);margin-bottom:8px}.accounting-modal-overlay{position:fixed;inset:0;background:#0f172a80;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.accounting-modal{background:var(--acct-card);border-radius:var(--acct-radius);padding:28px;max-width:520px;width:100%;box-shadow:0 25px 50px -12px #00000040}.accounting-modal h3{margin:0 0 20px;font-size:1.25rem}.accounting-modal-actions{display:flex;gap:12px;margin-top:24px;justify-content:flex-end}.action-btns{display:flex;gap:6px;justify-content:center;align-items:center;flex-wrap:wrap}.action-btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:6px 10px;border:none;border-radius:6px;cursor:pointer;font-size:.8125rem;background:transparent;transition:all .2s;white-space:nowrap;line-height:1.1;min-height:30px;min-width:78px}.action-btn.view{border:1px solid var(--acct-primary);color:var(--acct-primary)}.action-btn.edit{border:1px solid var(--acct-warning);color:var(--acct-warning)}.action-btn.delete{border:1px solid var(--acct-debit);color:var(--acct-debit)}.action-btn:hover{transform:translateY(-1px);box-shadow:0 6px 16px #0f172a14;background:#0f172a05}.action-btn:disabled{opacity:.5;cursor:not-allowed;transform:none;box-shadow:none}@media(max-width:520px){.action-btns{justify-content:flex-start}.action-btn{min-width:unset}}@media(max-width:900px){.accounting-layout{flex-direction:column}.accounting-sidebar{width:100%;min-width:100%;border-right:none;border-bottom:1px solid var(--acct-border);padding:12px;display:flex;overflow-x:auto;gap:8px}.accounting-nav-item{flex-shrink:0;padding:12px 18px;border-left:none;border-bottom:3px solid transparent}.accounting-nav-item.active{border-left:none;border-bottom-color:var(--acct-primary)}.accounting-main{padding:20px 16px}.balance-grid,.bilan-grid{grid-template-columns:1fr}.journal-stats{grid-template-columns:repeat(2,1fr)}}:root{--fiscal-bg: #f1f5f9;--fiscal-card: #ffffff;--fiscal-border: #e2e8f0;--fiscal-text: #0f172a;--fiscal-text-muted: #64748b;--fiscal-primary: #1e40af;--fiscal-primary-hover: #1e3a8a;--fiscal-primary-light: #dbeafe;--fiscal-success: #059669;--fiscal-success-bg: #d1fae5;--fiscal-warning: #d97706;--fiscal-warning-bg: #fef3c7;--fiscal-danger: #dc2626;--fiscal-shadow: 0 1px 3px rgba(0,0,0,.06);--fiscal-shadow-lg: 0 10px 40px -10px rgba(30, 64, 175, .12);--fiscal-radius: 12px;--fiscal-radius-sm: 8px}.fiscal-page{font-family:DM Sans,system-ui,sans-serif;background:var(--fiscal-bg);min-height:100vh;display:flex;flex-direction:column;color:var(--fiscal-text)}.fiscal-layout{display:flex;flex:1;gap:0;min-height:calc(100vh - 140px)}.fiscal-sidebar{width:260px;min-width:260px;background:var(--fiscal-card);border-right:1px solid var(--fiscal-border);padding:20px 0;box-shadow:var(--fiscal-shadow)}.fiscal-nav-item{display:flex;align-items:center;gap:12px;padding:14px 24px;border:none;background:transparent;width:100%;text-align:left;font-size:.9375rem;font-weight:500;color:var(--fiscal-text-muted);cursor:pointer;transition:all .2s;font-family:inherit;border-left:3px solid transparent}.fiscal-nav-item:hover{background:var(--fiscal-primary-light);color:var(--fiscal-primary)}.fiscal-nav-item.active{background:var(--fiscal-primary-light);color:var(--fiscal-primary);border-left-color:var(--fiscal-primary);font-weight:600}.fiscal-nav-icon{font-size:1.25rem;width:28px;text-align:center}.fiscal-main{flex:1;padding:24px 32px;overflow-y:auto}.fiscal-header{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:20px;padding:20px 24px;background:var(--fiscal-card);border-bottom:1px solid var(--fiscal-border);box-shadow:var(--fiscal-shadow)}.fiscal-header h1{margin:0;font-size:1.5rem;font-weight:700;color:var(--fiscal-text)}.fiscal-header .subtitle{font-size:.8125rem;color:var(--fiscal-text-muted);margin-top:4px}.fiscal-period{display:flex;align-items:center;gap:12px}.fiscal-period label{font-size:.8125rem;font-weight:500;color:var(--fiscal-text-muted)}.fiscal-input{padding:10px 14px;border:2px solid var(--fiscal-border);border-radius:var(--fiscal-radius-sm);font-size:.9375rem;font-family:inherit;transition:border-color .2s}.fiscal-input:focus{outline:none;border-color:var(--fiscal-primary)}.fiscal-card{background:var(--fiscal-card);border-radius:var(--fiscal-radius);padding:28px;box-shadow:var(--fiscal-shadow);border:1px solid var(--fiscal-border);margin-bottom:24px}.fiscal-card-title{margin:0 0 8px;font-size:1.125rem;font-weight:600;color:var(--fiscal-text)}.fiscal-card-desc{font-size:.875rem;color:var(--fiscal-text-muted);margin-bottom:24px}.fiscal-row{display:flex;justify-content:space-between;align-items:center;padding:14px 16px;background:#f8fafc;border-radius:var(--fiscal-radius-sm);margin-bottom:10px}.fiscal-row.highlight{background:var(--fiscal-primary-light);border:1px solid rgba(30,64,175,.2)}.fiscal-row.success{background:var(--fiscal-success-bg)}.fiscal-row.danger{background:#fee2e2}.fiscal-btn{padding:12px 24px;border:none;border-radius:var(--fiscal-radius-sm);font-size:.9375rem;font-weight:600;cursor:pointer;font-family:inherit;transition:all .2s}.fiscal-btn-primary{background:var(--fiscal-primary);color:#fff}.fiscal-btn-primary:hover{background:var(--fiscal-primary-hover)}.fiscal-btn-success{background:var(--fiscal-success);color:#fff}.fiscal-btn-success:hover{background:#047857}.fiscal-btn-outline{background:transparent;border:2px solid var(--fiscal-border);color:var(--fiscal-text)}.fiscal-btn-outline:hover{border-color:var(--fiscal-primary);color:var(--fiscal-primary)}.fiscal-btn-warning{background:var(--fiscal-warning);color:#fff}.fiscal-btn-warning:hover{background:#b45309}.fiscal-actions{display:flex;gap:12px;flex-wrap:wrap;margin-top:20px}.fiscal-actions-inline{display:flex;gap:12px;flex-wrap:wrap;align-items:center}.fiscal-portal{padding:20px;border-radius:var(--fiscal-radius-sm);margin-bottom:16px;border:1px solid}.fiscal-portal.impots{background:var(--fiscal-primary-light);border-color:var(--fiscal-primary)}.fiscal-portal.enif{background:var(--fiscal-success-bg);border-color:var(--fiscal-success)}.fiscal-portal.export{background:var(--fiscal-warning-bg);border-color:var(--fiscal-warning)}.fiscal-portal h4{margin:0 0 8px;font-size:1rem;font-weight:600}.fiscal-portal p{margin:0 0 14px;font-size:.875rem;color:var(--fiscal-text-muted)}.fiscal-link{display:inline-block;padding:10px 20px;border-radius:var(--fiscal-radius-sm);text-decoration:none;font-weight:600;font-size:.9375rem;transition:all .2s}.fiscal-link.impots{background:var(--fiscal-primary);color:#fff}.fiscal-link.impots:hover{background:var(--fiscal-primary-hover)}.fiscal-link.enif{background:var(--fiscal-success);color:#fff}.fiscal-link.enif:hover{background:#047857}.fiscal-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:24px}.fiscal-footer{padding:16px 24px;background:var(--fiscal-card);border-top:1px solid var(--fiscal-border);font-size:.8125rem;color:var(--fiscal-text-muted)}@media(max-width:900px){.fiscal-layout{flex-direction:column}.fiscal-sidebar{width:100%;min-width:100%;border-right:none;border-bottom:1px solid var(--fiscal-border);padding:12px;display:flex;overflow-x:auto;gap:8px}.fiscal-nav-item{flex-shrink:0;padding:12px 18px;border-left:none;border-bottom:3px solid transparent}.fiscal-nav-item.active{border-left:none;border-bottom-color:var(--fiscal-primary)}.fiscal-main{padding:20px 16px}}.table-actions{display:inline-flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:6px}.btn-action{min-width:36px;width:36px;height:36px;padding:0 8px;display:inline-flex;align-items:center;justify-content:center;gap:4px;border:1px solid transparent;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:background .15s,color .15s,border-color .15s;white-space:nowrap;box-sizing:border-box}.btn-action:disabled{opacity:.5;cursor:not-allowed}.btn-action__icon{line-height:1}.btn-action__label{font-size:12px}.btn-action--primary{background:#3b82f6;color:#fff;border-color:#3b82f6}.btn-action--primary:hover:not(:disabled){background:#2563eb;border-color:#2563eb}.btn-action--secondary{background:#f1f5f9;color:#475569;border-color:#e2e8f0}.btn-action--secondary:hover:not(:disabled){background:#e2e8f0;color:#0f172a}.btn-action--success{background:#10b981;color:#fff;border-color:#10b981}.btn-action--success:hover:not(:disabled){background:#059669;border-color:#059669}.btn-action--info{background:#0ea5e9;color:#fff;border-color:#0ea5e9}.btn-action--info:hover:not(:disabled){background:#0284c7;border-color:#0284c7}.btn-action--warning{background:#f59e0b;color:#fff;border-color:#f59e0b}.btn-action--warning:hover:not(:disabled){background:#d97706;border-color:#d97706}.btn-action--danger{background:#ef4444;color:#fff;border-color:#ef4444}.btn-action--danger:hover:not(:disabled){background:#dc2626;border-color:#dc2626}.table-actions .btn-action:has(.btn-action__label){min-width:88px;width:auto}.table-actions--compact .btn-action{min-width:32px;width:32px;height:32px;padding:0;font-size:13px}@media(max-width:768px){.table-actions{gap:4px}.btn-action{min-width:32px;width:32px;height:32px;font-size:13px}.table-actions .btn-action:has(.btn-action__label) .btn-action__label{display:none}.table-actions .btn-action:has(.btn-action__label){min-width:32px;width:32px}}:root{--hr-bg: #f1f5f9;--hr-card: #ffffff;--hr-border: #e2e8f0;--hr-text: #0f172a;--hr-text-muted: #64748b;--hr-primary: #0ea5e9;--hr-primary-hover: #0284c7;--hr-primary-light: #e0f2fe;--hr-success: #10b981;--hr-success-bg: #d1fae5;--hr-warning: #f59e0b;--hr-warning-bg: #fef3c7;--hr-danger: #ef4444;--hr-danger-bg: #fee2e2;--hr-shadow: 0 1px 3px rgba(0,0,0,.06);--hr-shadow-lg: 0 10px 40px -10px rgba(14, 165, 233, .15);--hr-radius: 12px;--hr-radius-sm: 8px;--hr-sidebar-width: 280px}.hr-page{font-family:DM Sans,system-ui,sans-serif;background:var(--hr-bg);min-height:100vh;display:flex;flex-direction:column;color:var(--hr-text)}.hr-layout{display:flex;flex:1;min-height:calc(100vh - 80px)}.hr-sidebar{width:var(--hr-sidebar-width);min-width:var(--hr-sidebar-width);background:var(--hr-card);border-right:1px solid var(--hr-border);padding:20px 0;box-shadow:var(--hr-shadow);overflow-y:auto}.hr-nav-group{margin-bottom:8px}.hr-nav-group-title{font-size:.6875rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--hr-text-muted);padding:12px 24px 8px}.hr-nav-item{display:flex;align-items:center;gap:12px;padding:12px 24px;border:none;background:transparent;width:100%;text-align:left;font-size:.9375rem;font-weight:500;color:var(--hr-text-muted);cursor:pointer;transition:all .2s;font-family:inherit;border-left:3px solid transparent}.hr-nav-item:hover{background:var(--hr-primary-light);color:var(--hr-primary)}.hr-nav-item.active{background:var(--hr-primary-light);color:var(--hr-primary);border-left-color:var(--hr-primary);font-weight:600}.hr-nav-icon{font-size:1.125rem;width:24px;text-align:center}.hr-main{flex:1;padding:24px 32px;overflow-y:auto}.hr-header{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:20px;padding:20px 24px;background:var(--hr-card);border-bottom:1px solid var(--hr-border);box-shadow:var(--hr-shadow)}.hr-header h1{margin:0;font-size:1.5rem;font-weight:700;color:var(--hr-text)}.hr-header .subtitle{font-size:.8125rem;color:var(--hr-text-muted);margin-top:4px}.hr-card{background:var(--hr-card);border-radius:var(--hr-radius);padding:24px;box-shadow:var(--hr-shadow);border:1px solid var(--hr-border);margin-bottom:24px}.hr-card-title{margin:0 0 8px;font-size:1.125rem;font-weight:600;color:var(--hr-text)}.hr-card-desc{font-size:.875rem;color:var(--hr-text-muted);margin-bottom:20px}.hr-kpi-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:20px;margin-bottom:32px}.hr-kpi-card{background:var(--hr-card);border-radius:var(--hr-radius);padding:24px;box-shadow:var(--hr-shadow);border:1px solid var(--hr-border);transition:transform .2s,box-shadow .2s}.hr-kpi-card:hover{transform:translateY(-2px);box-shadow:var(--hr-shadow-lg)}.hr-kpi-card.primary{border-left:4px solid var(--hr-primary)}.hr-kpi-card.success{border-left:4px solid var(--hr-success)}.hr-kpi-card.warning{border-left:4px solid var(--hr-warning)}.hr-kpi-card.danger{border-left:4px solid var(--hr-danger)}.hr-kpi-label{font-size:.8125rem;color:var(--hr-text-muted);margin-bottom:8px}.hr-kpi-value{font-size:1.75rem;font-weight:700;color:var(--hr-text)}.hr-kpi-hint{font-size:.75rem;color:var(--hr-text-muted);margin-top:6px}.hr-section-card{background:var(--hr-card);border-radius:var(--hr-radius);padding:28px;box-shadow:var(--hr-shadow);border:1px solid var(--hr-border);margin-bottom:24px}.hr-section-title{margin:0 0 20px;font-size:1.125rem;font-weight:600;color:var(--hr-text);padding-bottom:12px;border-bottom:2px solid var(--hr-border)}.hr-table-wrap{overflow-x:auto;border-radius:var(--hr-radius-sm);border:1px solid var(--hr-border)}.hr-table{width:100%;border-collapse:collapse;font-size:.9375rem}.hr-table th{background:#f8fafc;padding:14px 16px;text-align:left;font-weight:600;color:var(--hr-text);border-bottom:2px solid var(--hr-border)}.hr-table td{padding:14px 16px;border-bottom:1px solid var(--hr-border)}.hr-table tbody tr:hover{background:#f8fafc}.hr-table tbody tr:last-child td{border-bottom:none}.hr-badge{display:inline-block;padding:4px 12px;border-radius:999px;font-size:.75rem;font-weight:600}.hr-badge-success{background:var(--hr-success-bg);color:#047857}.hr-badge-warning{background:var(--hr-warning-bg);color:#b45309}.hr-badge-danger{background:var(--hr-danger-bg);color:#b91c1c}.hr-badge-info{background:var(--hr-primary-light);color:var(--hr-primary-hover)}.hr-toolbar{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap;margin-bottom:24px;padding:16px 20px;background:var(--hr-card);border-radius:var(--hr-radius-sm);border:1px solid var(--hr-border)}.hr-toolbar-title{font-weight:600;color:var(--hr-text)}.hr-btn{padding:10px 20px;border:none;border-radius:var(--hr-radius-sm);font-size:.9375rem;font-weight:600;cursor:pointer;font-family:inherit;transition:all .2s}.hr-btn-primary{background:var(--hr-primary);color:#fff}.hr-btn-primary:hover{background:var(--hr-primary-hover)}.hr-btn-success{background:var(--hr-success);color:#fff}.hr-btn-success:hover{background:#059669}.hr-btn-outline{background:transparent;border:2px solid var(--hr-border);color:var(--hr-text)}.hr-btn-outline:hover{border-color:var(--hr-primary);color:var(--hr-primary)}.hr-input{padding:10px 14px;border:2px solid var(--hr-border);border-radius:var(--hr-radius-sm);font-size:.9375rem;font-family:inherit;transition:border-color .2s;width:100%}.hr-input:focus{outline:none;border-color:var(--hr-primary)}.hr-label{display:block;margin-bottom:6px;font-size:.875rem;font-weight:500;color:var(--hr-text)}.hr-form-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:20px}.hr-alert{padding:16px 20px;border-radius:var(--hr-radius-sm);margin-bottom:20px;border-left:4px solid}.hr-alert-warning{background:var(--hr-warning-bg);border-color:var(--hr-warning);color:#92400e}.hr-alert-info{background:var(--hr-primary-light);border-color:var(--hr-primary);color:#0369a1}.hr-alert-success{background:var(--hr-success-bg);border-color:var(--hr-success);color:#047857}.hr-modal-overlay{position:fixed;inset:0;background:#0f172a80;display:flex;align-items:center;justify-content:center;z-index:1000;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.hr-modal{background:var(--hr-card);border-radius:var(--hr-radius);padding:28px;max-width:700px;width:90%;max-height:85vh;overflow-y:auto;box-shadow:0 25px 50px -12px #00000040;border:1px solid var(--hr-border)}.hr-modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px;padding-bottom:16px;border-bottom:2px solid var(--hr-border)}.hr-modal-title{margin:0;font-size:1.25rem;font-weight:600;color:var(--hr-text)}.hr-loading{text-align:center;padding:60px 20px;font-size:1rem;color:var(--hr-text-muted)}@media(max-width:1024px){.hr-sidebar{width:220px;min-width:220px}}@media(max-width:768px){.hr-layout{flex-direction:column}.hr-sidebar{width:100%;min-width:100%;display:flex;flex-wrap:wrap;padding:12px;gap:8px}.hr-nav-group{flex:1;min-width:140px}.hr-nav-group-title{padding:8px 12px 4px}.hr-nav-item{padding:10px 16px}.hr-main{padding:16px}.hr-kpi-grid{grid-template-columns:repeat(2,1fr);gap:12px}.hr-kpi-value{font-size:1.5rem}}.modern-modal-overlay{position:fixed;inset:0;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:10000;padding:1rem;animation:fadeIn .2s ease-out}.modern-modal{background:#fff;border-radius:16px;box-shadow:0 25px 50px -12px #00000040,0 0 0 1px #ffffff1a;max-height:90vh;overflow:hidden;display:flex;flex-direction:column;animation:slideUp .3s ease-out;border:1px solid rgba(255,255,255,.2)}.modern-modal.dragging{cursor:move;-webkit-user-select:none;user-select:none;transform:scale(1.02);box-shadow:0 30px 60px -12px #00000059,0 0 0 1px #3b82f64d}.modal-small{width:min(400px,90vw)}.modal-medium{width:min(600px,90vw)}.modal-large{width:min(800px,90vw)}.modal-wide{width:min(1200px,95vw)}.modal-fullscreen{width:95vw;height:95vh;max-height:95vh}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:1.5rem;border-bottom:1px solid #e5e7eb;background:linear-gradient(135deg,#f8fafc,#f1f5f9);border-radius:16px 16px 0 0}.modal-header.draggable{cursor:move;-webkit-user-select:none;user-select:none}.modal-header.draggable:hover{background:linear-gradient(135deg,#f1f5f9,#e2e8f0)}.modal-title h2{margin:0;font-size:1.5rem;font-weight:700;color:#1f2937;line-height:1.2}.modal-close-btn{display:flex;align-items:center;justify-content:center;width:40px;height:40px;border:none;background:transparent;color:#6b7280;border-radius:8px;cursor:pointer;transition:all .15s ease;flex-shrink:0}.modal-close-btn:hover{background:#f3f4f6;color:#374151;transform:scale(1.05)}.modal-close-btn:active{transform:scale(.95)}.modal-body{flex:1;padding:1.5rem;overflow-y:auto;color:#374151}.modal-body::-webkit-scrollbar{width:6px}.modal-body::-webkit-scrollbar-track{background:#f1f5f9;border-radius:3px}.modal-body::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:3px}.modal-body::-webkit-scrollbar-thumb:hover{background:#94a3b8}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}@media(max-width:768px){.modern-modal-overlay{padding:.5rem}.modal-header{padding:1rem}.modal-title h2{font-size:1.25rem}.modal-close-btn{width:36px;height:36px}.modal-body{padding:1rem}.modal-small,.modal-medium,.modal-large,.modal-wide{width:95vw}.modal-fullscreen{width:100vw;height:100vh;max-height:100vh;border-radius:0}.modal-header{border-radius:0}}@media(max-width:480px){.modal-header{padding:.75rem}.modal-title h2{font-size:1.125rem}.modal-close-btn{width:32px;height:32px}.modal-body{padding:.75rem}}@media(prefers-color-scheme:dark){.modern-modal-overlay{background:#000c}.modern-modal{background:#1f2937;border-color:#374151;box-shadow:0 25px 50px -12px #00000080,0 0 0 1px #ffffff1a}.modal-header{background:linear-gradient(135deg,#111827,#1f2937);border-color:#374151}.modal-header.draggable:hover{background:linear-gradient(135deg,#1f2937,#374151)}.modal-title h2{color:#f9fafb}.modal-close-btn{color:#9ca3af}.modal-close-btn:hover{background:#374151;color:#e5e7eb}.modal-body{color:#e5e7eb}.modal-body::-webkit-scrollbar-track{background:#374151}.modal-body::-webkit-scrollbar-thumb{background:#4b5563}.modal-body::-webkit-scrollbar-thumb:hover{background:#6b7280}}.modal-section{margin-bottom:1.5rem}.modal-section:last-child{margin-bottom:0}.modal-section-title{font-size:1.125rem;font-weight:600;color:#1f2937;margin-bottom:.75rem;display:flex;align-items:center;gap:.5rem}.modal-section-description{color:#6b7280;font-size:.875rem;line-height:1.5;margin-bottom:1rem}.modal-divider{height:1px;background:#e5e7eb;margin:1.5rem 0;border:none}.modal-footer{display:flex;gap:.75rem;justify-content:flex-end;align-items:center;padding:1.5rem;border-top:1px solid #e5e7eb;background:#f8fafc;border-radius:0 0 16px 16px}.modal-footer.center{justify-content:center}.modal-footer.space-between{justify-content:space-between}.modal-loading{display:flex;align-items:center;justify-content:center;padding:2rem;color:#6b7280}.modal-loading-spinner{width:20px;height:20px;border:2px solid #e5e7eb;border-top:2px solid #3b82f6;border-radius:50%;animation:spin 1s linear infinite;margin-right:.5rem}.pin-manager-modal .modal-content{display:flex;flex-direction:column;gap:1.5rem}.modal-header-info{display:flex;align-items:center;gap:1rem;padding:1.25rem;background:linear-gradient(135deg,#f0f9ff,#e0f2fe);border:1px solid #bae6fd;border-radius:12px;color:#0369a1}.security-icon{display:flex;align-items:center;justify-content:center;width:48px;height:48px;background:#0ea5e9;color:#fff;border-radius:50%;flex-shrink:0}.security-icon svg{width:24px;height:24px}.header-text h3{margin:0 0 .5rem;font-size:1.125rem;font-weight:600;color:#0c4a6e}.header-text p{margin:0;font-size:.875rem;color:#0369a1;line-height:1.4}.message{display:flex;align-items:center;gap:.75rem;padding:1rem;border-radius:8px;font-size:.875rem;font-weight:500;animation:slideIn .3s ease}.message-icon{font-size:1.25rem;flex-shrink:0}.message-text{flex:1}.pin-form{display:flex;flex-direction:column;gap:1.5rem}.form-section{display:flex;flex-direction:column;gap:1.25rem}.input-group{display:flex;flex-direction:column;gap:.75rem}.input-label{display:flex;align-items:center;gap:.5rem;font-size:.9375rem;font-weight:600;color:#374151}.input-label svg{width:18px;height:18px;color:#6b7280}.pin-input{width:100%;padding:.875rem 1rem;font-size:1.125rem;font-weight:600;letter-spacing:.25rem;text-align:center;border:2px solid #e5e7eb;border-radius:8px;background:#fff;color:#1f2937;transition:all .2s ease;outline:none}.pin-input::placeholder{color:#9ca3af;letter-spacing:.125rem}.pin-dots{display:flex;justify-content:center;gap:.75rem}.pin-dot{width:12px;height:12px;border-radius:50%;background:#e5e7eb;transition:all .3s ease}.pin-dot.filled{background:#3b82f6;box-shadow:0 0 6px #3b82f666;animation:dotPulse .5s ease}.form-actions{display:flex;gap:1rem;justify-content:space-between;align-items:center}.btn{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.875rem 1.5rem;border:none;border-radius:8px;font-size:.9375rem;font-weight:600;cursor:pointer;transition:all .2s ease;position:relative;overflow:hidden;min-height:48px}.btn:disabled{opacity:.6;cursor:not-allowed;transform:none!important}.btn:not(:disabled):hover{transform:translateY(-1px);box-shadow:0 4px 12px #00000026}.btn:not(:disabled):active{transform:translateY(0)}.btn-primary{background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff;box-shadow:0 2px 8px #3b82f64d}.btn-primary:not(:disabled):hover{background:linear-gradient(135deg,#2563eb,#1d4ed8);box-shadow:0 4px 16px #3b82f666}.btn-danger{background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff;box-shadow:0 2px 8px #ef44444d}.btn-danger:not(:disabled):hover{background:linear-gradient(135deg,#dc2626,#b91c1c);box-shadow:0 4px 16px #ef444466}.btn-content{display:flex;align-items:center;gap:.5rem}.btn-content svg{width:16px;height:16px}.btn-loading{display:flex;align-items:center;gap:.5rem}.spinner{width:16px;height:16px;border:2px solid transparent;border-top:2px solid currentColor;border-radius:50%;animation:spin 1s linear infinite}.security-tips{background:linear-gradient(135deg,#fefce8,#fef3c7);border:1px solid #fde68a;border-radius:8px;padding:1.25rem;color:#92400e}.security-tips h4{margin:0 0 .75rem;font-size:.9375rem;font-weight:600;color:#78350f;display:flex;align-items:center;gap:.5rem}.security-tips ul{margin:0;padding-left:1.25rem;list-style:none}.security-tips li{position:relative;font-size:.8125rem;line-height:1.5;color:#92400e;margin-bottom:.5rem}.security-tips li:last-child{margin-bottom:0}.security-tips li:before{content:"•";position:absolute;left:-1rem;color:#f59e0b;font-weight:700}@media(max-width:768px){.modal-header-info{flex-direction:column;text-align:center;gap:.75rem;padding:1rem}.security-icon{width:40px;height:40px}.security-icon svg{width:20px;height:20px}.header-text h3{font-size:1rem}.header-text p{font-size:.8125rem}.pin-input{font-size:1rem;padding:.75rem .875rem}.form-actions{flex-direction:column;gap:.75rem}.btn{width:100%;padding:.75rem 1.25rem}.security-tips{padding:1rem}.security-tips h4{font-size:.875rem}.security-tips li{font-size:.75rem}}@media(max-width:480px){.modal-header-info{padding:.875rem}.security-icon{width:36px;height:36px}.security-icon svg{width:18px;height:18px}.pin-input{font-size:.9375rem;padding:.625rem .75rem}.pin-dots{gap:.5rem}.pin-dot{width:10px;height:10px}.btn{padding:.625rem 1rem;font-size:.875rem}.btn-content svg{width:14px;height:14px}.security-tips{padding:.875rem}.security-tips h4{font-size:.8125rem}.security-tips li{font-size:.6875rem}}@media(prefers-color-scheme:dark){.modal-header-info{background:linear-gradient(135deg,#1e3a8a,#1e40af);border-color:#3b82f6;color:#93c5fd}.security-icon{background:#2563eb;color:#fff}.header-text h3{color:#dbeafe}.header-text p{color:#93c5fd}.input-label{color:#e5e7eb}.input-label svg{color:#9ca3af}.pin-input{background:#1f2937;border-color:#4b5563;color:#f9fafb}.pin-input:focus{border-color:#3b82f6}.pin-input::placeholder{color:#6b7280}.pin-dot{background:#4b5563}.pin-dot.filled{background:#3b82f6}.security-tips{background:linear-gradient(135deg,#451a03,#78350f);border-color:#92400e;color:#fbbf24}.security-tips h4{color:#fde047}.security-tips li{color:#fbbf24}.security-tips li:before{color:#f59e0b}}:root{--lms-bg: #f1f5f9;--lms-card: #ffffff;--lms-border: #e2e8f0;--lms-text: #0f172a;--lms-text-muted: #64748b;--lms-primary: #7c3aed;--lms-primary-hover: #6d28d9;--lms-primary-light: #ede9fe;--lms-success: #10b981;--lms-success-bg: #d1fae5;--lms-warning: #f59e0b;--lms-warning-bg: #fef3c7;--lms-danger: #ef4444;--lms-danger-bg: #fee2e2;--lms-info: #0ea5e9;--lms-info-bg: #e0f2fe;--lms-shadow: 0 1px 3px rgba(0,0,0,.06);--lms-shadow-md: 0 4px 12px rgba(0,0,0,.08);--lms-shadow-lg: 0 10px 40px -10px rgba(124, 58, 237, .15);--lms-radius: 14px;--lms-radius-sm: 8px;--lms-radius-xs: 6px;--lms-sidebar-width: 280px;--lms-header-height: 72px}.lms-page{font-family:DM Sans,system-ui,-apple-system,sans-serif;background:var(--lms-bg);min-height:100vh;display:flex;flex-direction:column;color:var(--lms-text)}.lms-header{height:var(--lms-header-height);background:linear-gradient(135deg,#7c3aed,#6d28d9 40%,#4f46e5);display:flex;align-items:center;justify-content:space-between;padding:0 32px;color:#fff;box-shadow:0 4px 20px #7c3aed40;position:relative;z-index:10}.lms-header-title{font-size:1.35rem;font-weight:700;letter-spacing:-.02em;display:flex;align-items:center;gap:12px}.lms-header-title-icon{width:38px;height:38px;border-radius:10px;background:#fff3;display:flex;align-items:center;justify-content:center;font-size:1.2rem;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.lms-header-sub{font-size:.8rem;color:#ffffffbf;margin-top:2px;font-weight:400}.lms-header-role{font-size:.75rem;background:#ffffff26;padding:6px 14px;border-radius:20px;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.lms-layout{display:flex;flex:1;min-height:calc(100vh - var(--lms-header-height))}.lms-sidebar{width:var(--lms-sidebar-width);min-width:var(--lms-sidebar-width);background:var(--lms-card);border-right:1px solid var(--lms-border);padding:20px 0;box-shadow:var(--lms-shadow);overflow-y:auto}.lms-nav-group{margin-bottom:8px}.lms-nav-group-title{font-size:.6875rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--lms-text-muted);padding:12px 24px 8px}.lms-nav-item{display:flex;align-items:center;gap:12px;padding:11px 24px;border:none;background:transparent;width:100%;text-align:left;font-size:.875rem;font-weight:500;font-family:inherit;color:var(--lms-text-muted);cursor:pointer;transition:all .15s ease;position:relative}.lms-nav-item:hover{background:var(--lms-primary-light);color:var(--lms-primary)}.lms-nav-item.active{background:var(--lms-primary-light);color:var(--lms-primary);font-weight:600}.lms-nav-item.active:before{content:"";position:absolute;left:0;top:6px;bottom:6px;width:3px;border-radius:0 3px 3px 0;background:var(--lms-primary)}.lms-nav-icon{font-size:1.15rem;width:24px;text-align:center;flex-shrink:0}.lms-main{flex:1;padding:28px 32px;overflow-y:auto;max-height:calc(100vh - var(--lms-header-height))}.lms-kpi-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;margin-bottom:24px}.lms-kpi-card{background:var(--lms-card);border:1px solid var(--lms-border);border-radius:var(--lms-radius);padding:20px;box-shadow:var(--lms-shadow);transition:transform .2s ease,box-shadow .2s ease;position:relative;overflow:hidden}.lms-kpi-card:hover{transform:translateY(-2px);box-shadow:var(--lms-shadow-md)}.lms-kpi-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px}.lms-kpi-card.primary:before{background:var(--lms-primary)}.lms-kpi-card.success:before{background:var(--lms-success)}.lms-kpi-card.warning:before{background:var(--lms-warning)}.lms-kpi-card.danger:before{background:var(--lms-danger)}.lms-kpi-card.info:before{background:var(--lms-info)}.lms-kpi-label{font-size:.75rem;font-weight:600;color:var(--lms-text-muted);text-transform:uppercase;letter-spacing:.04em;margin-bottom:8px}.lms-kpi-value{font-size:1.75rem;font-weight:800;color:var(--lms-text);line-height:1}.lms-kpi-icon{position:absolute;top:16px;right:16px;font-size:1.6rem;opacity:.15}.lms-section-card{background:var(--lms-card);border:1px solid var(--lms-border);border-radius:var(--lms-radius);padding:24px;box-shadow:var(--lms-shadow);margin-bottom:20px}.lms-section-title{font-size:1.05rem;font-weight:700;color:var(--lms-text);margin:0 0 18px;display:flex;align-items:center;gap:10px}.lms-section-title-icon{width:32px;height:32px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:1rem}.lms-section-title-icon.purple{background:var(--lms-primary-light)}.lms-section-title-icon.green{background:var(--lms-success-bg)}.lms-section-title-icon.blue{background:var(--lms-info-bg)}.lms-section-title-icon.orange{background:var(--lms-warning-bg)}.lms-section-title-icon.red{background:var(--lms-danger-bg)}.lms-course-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:18px}.lms-course-card{background:var(--lms-card);border:1px solid var(--lms-border);border-radius:var(--lms-radius);padding:0;box-shadow:var(--lms-shadow);transition:transform .2s ease,box-shadow .2s ease;overflow:hidden;display:flex;flex-direction:column}.lms-course-card:hover{transform:translateY(-3px);box-shadow:var(--lms-shadow-lg)}.lms-course-card-header{padding:20px 20px 0}.lms-course-card-body{padding:12px 20px 20px;flex:1;display:flex;flex-direction:column}.lms-course-card-top{display:flex;justify-content:space-between;align-items:flex-start;gap:10px}.lms-course-title{font-weight:700;font-size:1rem;color:var(--lms-text);line-height:1.3}.lms-course-desc{margin-top:8px;font-size:.825rem;color:var(--lms-text-muted);line-height:1.5;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.lms-course-meta{display:flex;flex-wrap:wrap;gap:10px;margin-top:12px;font-size:.75rem;color:var(--lms-text-muted)}.lms-course-meta-item{display:flex;align-items:center;gap:4px}.lms-course-actions{display:flex;flex-wrap:wrap;gap:8px;margin-top:auto;padding-top:14px}.lms-badge{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;border-radius:20px;font-size:.6875rem;font-weight:600;white-space:nowrap}.lms-badge.primary{background:var(--lms-primary-light);color:var(--lms-primary)}.lms-badge.success{background:var(--lms-success-bg);color:#059669}.lms-badge.warning{background:var(--lms-warning-bg);color:#d97706}.lms-badge.danger{background:var(--lms-danger-bg);color:#dc2626}.lms-badge.info{background:var(--lms-info-bg);color:#0284c7}.lms-badge.neutral{background:#f1f5f9;color:var(--lms-text-muted)}.lms-btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:9px 16px;border-radius:var(--lms-radius-sm);border:none;font-family:inherit;font-size:.8125rem;font-weight:600;cursor:pointer;transition:all .15s ease;white-space:nowrap}.lms-btn.sm{padding:6px 12px;font-size:.75rem}.lms-btn.lg{padding:12px 22px;font-size:.9rem}.lms-btn.primary{background:linear-gradient(135deg,var(--lms-primary),var(--lms-primary-hover));color:#fff;box-shadow:0 2px 8px #7c3aed40}.lms-btn.primary:hover{filter:brightness(1.08);transform:translateY(-1px)}.lms-btn.success{background:linear-gradient(135deg,#10b981,#059669);color:#fff;box-shadow:0 2px 8px #10b98140}.lms-btn.success:hover{filter:brightness(1.08)}.lms-btn.info{background:linear-gradient(135deg,#0ea5e9,#0284c7);color:#fff;box-shadow:0 2px 8px #0ea5e940}.lms-btn.info:hover{filter:brightness(1.08)}.lms-btn.warning{background:linear-gradient(135deg,#f59e0b,#d97706);color:#fff}.lms-btn.warning:hover{filter:brightness(1.08)}.lms-btn.danger{background:#fff;color:#dc2626;border:1px solid #fecaca}.lms-btn.danger:hover{background:#fff1f2}.lms-btn.outline{background:var(--lms-card);color:var(--lms-text);border:1px solid var(--lms-border)}.lms-btn.outline:hover{background:#f8fafc;border-color:#cbd5e1}.lms-btn.ghost{background:transparent;color:var(--lms-primary);border:none;padding:6px 10px}.lms-btn.ghost:hover{background:var(--lms-primary-light)}.lms-btn:disabled{opacity:.5;cursor:not-allowed;transform:none!important}.lms-input{width:100%;padding:10px 14px;border-radius:var(--lms-radius-sm);border:1px solid var(--lms-border);background:var(--lms-card);font-family:inherit;font-size:.875rem;color:var(--lms-text);box-sizing:border-box;transition:border-color .15s ease,box-shadow .15s ease}.lms-input:focus{outline:none;border-color:var(--lms-primary);box-shadow:0 0 0 3px #7c3aed1a}.lms-input::placeholder{color:#94a3b8}.lms-label{display:block;font-size:.75rem;font-weight:600;color:var(--lms-text-muted);margin-bottom:6px}.lms-form-group{margin-bottom:14px}.lms-form-grid{display:grid;gap:14px}.lms-form-grid.cols-2{grid-template-columns:1fr 1fr}.lms-form-grid.cols-3{grid-template-columns:1fr 1fr 1fr}.lms-toggle-card{display:flex;align-items:center;gap:12px;padding:14px;border-radius:10px;border:1px solid var(--lms-border);background:var(--lms-card);cursor:pointer;transition:all .15s ease;-webkit-user-select:none;user-select:none}.lms-toggle-card.active{border-color:var(--lms-primary);border-width:2px;background:var(--lms-primary-light)}.lms-toggle-card.active-green{border-color:var(--lms-success);border-width:2px;background:var(--lms-success-bg)}.lms-toggle-title{font-weight:600;font-size:.8125rem;color:var(--lms-text)}.lms-toggle-sub{font-size:.75rem;color:var(--lms-text-muted);margin-top:2px}.lms-table-wrap{overflow-x:auto;border-radius:var(--lms-radius);border:1px solid var(--lms-border)}.lms-table{width:100%;border-collapse:collapse;font-size:.825rem}.lms-table th{padding:12px 16px;text-align:left;font-weight:600;font-size:.75rem;text-transform:uppercase;letter-spacing:.04em;color:var(--lms-text-muted);background:#f8fafc;border-bottom:2px solid var(--lms-border);white-space:nowrap}.lms-table td{padding:12px 16px;border-bottom:1px solid #f1f5f9;color:var(--lms-text);vertical-align:middle}.lms-table tbody tr:hover{background:#faf5ff}.lms-table tbody tr:last-child td{border-bottom:none}.lms-progress-wrap{margin-top:8px}.lms-progress-label{font-size:.75rem;color:var(--lms-text-muted);margin-bottom:6px}.lms-progress-bar{height:8px;background:#e2e8f0;border-radius:99px;overflow:hidden}.lms-progress-fill{height:100%;border-radius:99px;background:linear-gradient(90deg,var(--lms-primary),#a78bfa);transition:width .4s ease}.lms-progress-fill.success{background:linear-gradient(90deg,var(--lms-success),#34d399)}.lms-alert{padding:14px 18px;border-radius:var(--lms-radius-sm);font-size:.85rem;margin-bottom:16px;display:flex;align-items:flex-start;gap:10px}.lms-alert.danger{background:var(--lms-danger-bg);border:1px solid #fecaca;color:#991b1b}.lms-alert.warning{background:var(--lms-warning-bg);border:1px solid #fde68a;color:#92400e}.lms-alert.success{background:var(--lms-success-bg);border:1px solid #bbf7d0;color:#166534}.lms-alert.info{background:var(--lms-info-bg);border:1px solid #bae6fd;color:#0c4a6e}.lms-alert-module-off{background:var(--lms-danger-bg);border:1px solid #fecaca;color:#991b1b;padding:14px 20px;border-radius:var(--lms-radius-sm);margin-bottom:20px;font-size:.85rem;font-weight:500}.lms-modal-overlay{position:fixed;inset:0;background:#0f172a99;display:flex;align-items:center;justify-content:center;padding:16px;z-index:9999;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.lms-modal{background:var(--lms-card);border-radius:18px;box-shadow:0 25px 60px -15px #00000040;max-height:92vh;overflow-y:auto;padding:28px;width:min(720px,100%)}.lms-modal.lg{width:min(920px,100%)}.lms-modal-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:20px;padding-bottom:16px;border-bottom:1px solid var(--lms-border)}.lms-modal-title{font-size:1.2rem;font-weight:700;color:var(--lms-text);margin:0}.lms-modal-subtitle{font-size:.8rem;color:var(--lms-text-muted);margin-top:4px}.lms-exam-box{padding:16px 20px;border-radius:var(--lms-radius);margin-bottom:16px}.lms-exam-box.success{background:#f0fdf4;border:1px solid #bbf7d0}.lms-exam-box.danger{background:#fff1f2;border:1px solid #fecaca}.lms-exam-box.neutral{background:#f9fafb;border:1px solid var(--lms-border)}.lms-exam-box.review{background:#fffbeb;border:1px solid #fde68a}.lms-exam-title{font-weight:700;font-size:1rem}.lms-question-block{padding:16px;border-radius:var(--lms-radius-sm);border:1px solid var(--lms-border);margin-bottom:14px;background:var(--lms-card)}.lms-question-prompt{font-weight:600;margin-bottom:10px;font-size:.9rem}.lms-question-choice{display:flex;align-items:center;gap:10px;padding:8px 0;cursor:pointer;font-size:.85rem}.lms-section-divider{margin:20px 0 12px;padding:12px 18px;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:10px;color:#fff;font-weight:700;font-size:.9rem;letter-spacing:.03em}.lms-form-section{background:#f8fafc;border:1px solid var(--lms-border);border-radius:var(--lms-radius);padding:18px;margin-bottom:16px}.lms-form-section-title{display:flex;align-items:center;gap:8px;font-weight:700;font-size:.875rem;color:#374151;margin-bottom:14px}.lms-form-section-icon{font-size:1.15rem}.lms-content-tree{margin-top:12px;max-height:420px;overflow-y:auto;border-radius:var(--lms-radius-sm);border:1px solid var(--lms-border);padding:14px;background:#fafbfc}.lms-tree-module{margin-bottom:14px}.lms-tree-module-title{font-weight:700;font-size:.9rem;padding:6px 0;display:flex;align-items:center;gap:8px}.lms-tree-lesson{margin-left:16px;padding:10px 12px;border:1px solid var(--lms-border);border-radius:var(--lms-radius-sm);margin-bottom:8px;background:var(--lms-card)}.lms-tree-lesson-header{display:flex;justify-content:space-between;align-items:center;gap:8px;flex-wrap:wrap}.lms-tree-lesson-title{font-weight:600;font-size:.85rem}.lms-tree-lesson-actions{display:flex;gap:6px;align-items:center}.lms-tree-resource{font-size:.75rem;color:var(--lms-text-muted);margin-top:6px;padding-left:4px}.lms-dashed-box{padding:16px;border:2px dashed #d1d5db;border-radius:var(--lms-radius-sm);margin-top:12px;background:#fafbfc}.lms-dashed-box-title{font-weight:600;font-size:.85rem;margin-bottom:10px;color:var(--lms-text)}.lms-grading-zone{background:#fffbeb;padding:14px;border-radius:var(--lms-radius-sm);border:1px solid #fcd34d;margin-top:10px}.lms-grading-title{font-size:.8rem;font-weight:700;color:#92400e;margin-bottom:12px}.lms-attempt-item{padding:10px 14px;border:1px solid var(--lms-border);border-radius:var(--lms-radius-sm);margin-bottom:8px;font-size:.825rem;display:flex;align-items:center;gap:10px;flex-wrap:wrap}.lms-choice-pill{padding:8px 14px;border-radius:var(--lms-radius-sm);display:flex;align-items:center;gap:8px;margin-bottom:6px;font-size:.825rem}.lms-choice-pill.correct{background:#dcfce7;border:2px solid #16a34a;color:#16a34a}.lms-choice-pill.wrong{background:#fee2e2;border:2px solid #dc2626;color:#dc2626}.lms-choice-pill.expected{background:#f0fdf4;border:1px solid #86efac;color:#16a34a}.lms-choice-pill.default{background:#f9fafb;border:1px solid var(--lms-border);color:#374151}.lms-score-display{display:flex;gap:18px;align-items:center;padding:16px 20px;border-radius:var(--lms-radius);background:#f9fafb;border:1px solid var(--lms-border);margin-bottom:20px}.lms-score-number{font-size:1.75rem;font-weight:800;line-height:1}.lms-score-number.pass{color:var(--lms-success)}.lms-score-number.fail{color:var(--lms-danger)}.lms-empty{text-align:center;padding:48px 24px;color:var(--lms-text-muted)}.lms-empty-icon{font-size:3rem;margin-bottom:12px;opacity:.4}.lms-empty-text{font-size:.9rem;font-weight:500}.lms-loading{text-align:center;padding:24px;color:var(--lms-text-muted);font-size:.85rem}.lms-inline-list{display:flex;flex-wrap:wrap;gap:8px}.lms-manage-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px}.lms-manage-full{grid-column:1 / -1}@media(max-width:1024px){.lms-manage-grid{grid-template-columns:1fr}}@media(max-width:768px){.lms-sidebar{display:none}.lms-main{padding:18px 14px}.lms-header{padding:0 16px}.lms-course-grid{grid-template-columns:1fr}.lms-kpi-grid{grid-template-columns:1fr 1fr}.lms-form-grid.cols-2,.lms-form-grid.cols-3{grid-template-columns:1fr}}.clock-pin-modal .modal-content{display:flex;flex-direction:column;gap:2rem}.clock-pin-modal .modern-modal{max-height:95vh}@media(max-width:768px){.clock-pin-modal .modern-modal{width:min(980px,96vw);max-height:96vh}.clock-pin-modal .modal-content{gap:1.25rem}}@media(max-width:480px){.clock-pin-modal .modern-modal{width:98vw;max-height:98vh}.clock-pin-modal .modal-content{gap:1rem}}.user-section{display:flex;align-items:center;gap:1.5rem;padding:1.5rem;background:linear-gradient(135deg,#f8fafc,#eef2ff);border:1px solid #e2e8f0;border-radius:16px;position:relative;overflow:hidden}.user-section:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,#3b82f6,#8b5cf6,#ec4899)}.user-avatar{position:relative;width:120px;height:120px;border-radius:50%;background:#fff;display:flex;align-items:center;justify-content:center;box-shadow:0 8px 25px #3b82f626;border:4px solid #e0e7ff;overflow:hidden;flex-shrink:0}.user-avatar img{width:100%;height:100%;object-fit:cover;border-radius:50%}.avatar-fallback{display:flex;flex-direction:column;align-items:center;justify-content:center;color:#3b82f6;font-weight:700;font-size:3rem;text-align:center}.avatar-fallback svg{width:48px;height:48px;margin-bottom:.5rem;opacity:.5}.avatar-fallback span{font-size:2.5rem;line-height:1}.user-name{font-size:1.75rem;font-weight:700;color:#1f2937;margin:0 0 .75rem;line-height:1.2}.user-email,.user-department{font-size:.9375rem;color:#64748b;margin-bottom:.5rem;display:flex;align-items:center;gap:.5rem}.welcome-badge{display:inline-flex;align-items:center;gap:.5rem;background:linear-gradient(135deg,#dcfce7,#bbf7d0);color:#16a34a;padding:.75rem 1.25rem;border-radius:24px;font-weight:600;font-size:.9375rem;border:1px solid #86efac;box-shadow:0 2px 8px #22c55e1a;margin-top:1rem}.pin-section{display:flex;flex-direction:column;gap:1rem}.section-header{display:flex;flex-direction:column;gap:.5rem}.pin-label{font-size:1rem;font-weight:600;color:#374151}.schedule-info{font-size:.875rem;color:#6b7280;line-height:1.4}.pin-input-container{position:relative;display:flex;flex-direction:column;align-items:center;gap:1rem}.pin-input{width:100%;max-width:300px;padding:1rem 1.5rem;font-size:1.5rem;font-weight:600;letter-spacing:.5rem;text-align:center;border:2px solid #e5e7eb;border-radius:12px;background:#fff;color:#1f2937;transition:all .2s ease;outline:none}.pin-input:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.pin-input::placeholder{color:#9ca3af;letter-spacing:.25rem}.pin-dots{display:flex;gap:1rem}.pin-dot{width:16px;height:16px;border-radius:50%;background:#e5e7eb;transition:all .3s ease;position:relative}.pin-dot.filled{background:#3b82f6;box-shadow:0 0 8px #3b82f666;animation:dotPulse .5s ease}@keyframes dotPulse{0%{transform:scale(1)}50%{transform:scale(1.2)}to{transform:scale(1)}}.message{padding:.75rem 1rem;border-radius:8px;font-size:.875rem;font-weight:500;text-align:center;animation:slideIn .3s ease}.message.error{background:linear-gradient(135deg,#fef2f2,#fee2e2);color:#dc2626;border:1px solid #fecaca}.message.success{background:linear-gradient(135deg,#f0fdf4,#dcfce7);color:#16a34a;border:1px solid #bbf7d0}@keyframes slideIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.clock-pin-modal .actions-section{display:flex;flex-direction:column;gap:1rem}@media(max-width:768px){.clock-pin-modal .modal-body{padding-bottom:1.25rem}.clock-pin-modal .actions-section{position:sticky;bottom:0;background:#fff;padding-top:.75rem}}.clock-pin-modal .action-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.clock-pin-modal .action-btn{display:flex;align-items:center;justify-content:center;gap:.75rem;padding:1rem 1.5rem;border:none;border-radius:12px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s ease;position:relative;overflow:hidden;min-height:60px;width:300px;max-width:100%;box-sizing:border-box}.clock-pin-modal .action-btn:disabled{opacity:.6;cursor:not-allowed;transform:none!important}.clock-pin-modal .action-btn:not(:disabled):hover{transform:translateY(-2px);box-shadow:0 8px 25px #00000026}.clock-pin-modal .action-btn:not(:disabled):active{transform:translateY(-1px)}.clock-pin-modal .btn-icon{font-size:1.25rem;line-height:1}.clock-pin-modal .btn-text{font-size:.9375rem;line-height:1.2}.clock-pin-modal .clock-in-btn{background:linear-gradient(135deg,#22c55e,#16a34a);color:#fff;box-shadow:0 4px 12px #22c55e4d}.clock-pin-modal .clock-in-btn:not(:disabled):hover{background:linear-gradient(135deg,#16a34a,#15803d);box-shadow:0 6px 20px #22c55e66}.clock-pin-modal .clock-out-btn{background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff;box-shadow:0 4px 12px #ef44444d}.clock-pin-modal .clock-out-btn:not(:disabled):hover{background:linear-gradient(135deg,#dc2626,#b91c1c);box-shadow:0 6px 20px #ef444466}.clock-pin-modal .break-start-btn{background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff;box-shadow:0 4px 12px #3b82f64d}.clock-pin-modal .break-start-btn:not(:disabled):hover{background:linear-gradient(135deg,#2563eb,#1d4ed8);box-shadow:0 6px 20px #3b82f666}.clock-pin-modal .break-end-btn{background:linear-gradient(135deg,#8b5cf6,#7c3aed);color:#fff;box-shadow:0 4px 12px #8b5cf64d}.clock-pin-modal .break-end-btn:not(:disabled):hover{background:linear-gradient(135deg,#7c3aed,#6d28d9);box-shadow:0 6px 20px #8b5cf666}.clock-pin-modal .action-btn.loading:after{content:"";position:absolute;top:50%;left:50%;width:20px;height:20px;margin:-10px 0 0 -10px;border:2px solid transparent;border-top:2px solid currentColor;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media(max-width:768px){.user-section{flex-direction:column;text-align:center;gap:1rem;padding:1.25rem}.user-avatar{width:100px;height:100px}.user-name{font-size:1.5rem}.welcome-badge{margin-top:.75rem;padding:.625rem 1rem;font-size:.875rem}.pin-input{font-size:1.25rem;padding:.875rem 1.25rem}.clock-pin-modal .action-row{grid-template-columns:1fr;gap:.75rem}.clock-pin-modal .action-btn{padding:.875rem 1.25rem;min-height:56px;width:300px;max-width:100%}.clock-pin-modal .btn-icon{font-size:1.125rem}.clock-pin-modal .btn-text{font-size:.875rem}}@media(max-width:480px){.user-section{padding:1rem}.user-avatar{width:80px;height:80px}.avatar-fallback{font-size:2rem}.avatar-fallback svg{width:36px;height:36px}.user-name{font-size:1.25rem}.user-email,.user-department{font-size:.8125rem}.welcome-badge{font-size:.8125rem;padding:.5rem .875rem}.pin-input{font-size:1.125rem;padding:.75rem 1rem;max-width:250px}.pin-dots{gap:.75rem}.pin-dot{width:12px;height:12px}.clock-pin-modal .action-btn{padding:.75rem 1rem;min-height:52px;width:300px;max-width:100%}.clock-pin-modal .btn-icon{font-size:1rem}.clock-pin-modal .btn-text{font-size:.8125rem}}@media(prefers-color-scheme:dark){.user-section{background:linear-gradient(135deg,#1f2937,#111827);border-color:#374151}.user-avatar{background:#374151;border-color:#4b5563}.avatar-fallback{color:#60a5fa}.user-name{color:#f9fafb}.user-email,.user-department{color:#9ca3af}.welcome-badge{background:linear-gradient(135deg,#064e3b,#065f46);color:#34d399;border-color:#047857}.pin-label{color:#e5e7eb}.schedule-info{color:#9ca3af}.pin-input{background:#1f2937;border-color:#4b5563;color:#f9fafb}.pin-input:focus{border-color:#3b82f6}.pin-input::placeholder{color:#6b7280}.pin-dot{background:#4b5563}.pin-dot.filled{background:#3b82f6}}.document-editor-container{background-color:#f0f2f5;padding:40px;min-height:100vh;display:flex;flex-direction:column;align-items:center}.document-editor-toolbar{width:100%;max-width:800px;background:#fff;border:1px solid #ddd;border-radius:4px 4px 0 0;position:sticky;top:0;z-index:10}.document-page{width:210mm;min-height:297mm;padding:20mm;margin:20px auto;background:#fff;box-shadow:0 0 15px #0000001a;border:1px solid #ddd;cursor:text;position:relative;z-index:1;display:flex;flex-direction:column}.doc-section{position:relative}.doc-header-section{margin-bottom:10px;min-height:20px}.doc-footer-section{margin-top:auto;min-height:20px;padding-top:10px}.doc-body-section{flex:1}.doc-section-label{display:flex;justify-content:space-between;align-items:center;padding:4px 8px;background:#f8fafc;border:1px dashed #cbd5e1;border-radius:4px;margin-bottom:8px;opacity:.6;transition:opacity .2s}.doc-section:hover .doc-section-label{opacity:1}.doc-section-label span{font-size:10px;font-weight:700;color:#94a3b8;text-transform:uppercase;letter-spacing:1px}.doc-section-edit-btn{background:none;border:none;cursor:pointer;color:#64748b;padding:2px;display:flex;align-items:center;transition:color .2s}.doc-section-edit-btn:hover{color:#3498db}.doc-header-preview,.doc-footer-preview{cursor:pointer;padding:8px;border-radius:6px;border:1px solid transparent;transition:border-color .2s,background .2s}.doc-header-preview:hover,.doc-footer-preview:hover{border-color:#3498db40;background:#f8fafc}.doc-section-placeholder{display:flex;align-items:center;justify-content:center;gap:8px;padding:12px;border:1px dashed #e2e8f0;border-radius:6px;color:#cbd5e1;font-size:13px;cursor:pointer;transition:all .2s}.doc-section-placeholder:hover{border-color:#3498db;color:#3498db;background:#f8fafc}.doc-section-editor{padding:8px 0}.doc-section-textarea{width:100%;padding:10px 12px;border:1px solid #e2e8f0;border-radius:6px;font-family:Fira Code,Consolas,monospace;font-size:12px;line-height:1.5;resize:vertical;background:#fafbfc;color:#334155;transition:border-color .2s;box-sizing:border-box}.doc-section-textarea:focus{outline:none;border-color:#3498db;box-shadow:0 0 0 3px #3498db1a}.doc-section-actions{display:flex;gap:8px;margin-top:8px;justify-content:flex-end}.doc-section-btn{padding:5px 14px;border-radius:6px;font-size:12px;font-weight:600;cursor:pointer;border:none;transition:all .2s}.doc-section-btn.save{background:#3498db;color:#fff}.doc-section-btn.save:hover{background:#2980b9}.doc-section-btn.cancel{background:#f1f5f9;color:#64748b}.doc-section-btn.cancel:hover{background:#e2e8f0}.ck-editor{width:100%!important}.ck-editor__editable{min-height:200mm!important;border:none!important;box-shadow:none!important}.ck.ck-editor__main>.ck-editor__editable:not(.ck-focused){border:none!important}.ck.ck-toolbar{border:none!important;border-bottom:1px solid #ddd!important;background:#f8f9fa!important}.document-meta-panel{width:100%;max-width:210mm;background:#fff;padding:15px 20px;border-radius:8px;margin-bottom:15px;box-shadow:0 2px 4px #0000000d;border:1px solid #e2e8f0}.variable-tag{background:#e3f2fd;color:#1976d2;padding:3px 8px;border-radius:4px;font-family:Fira Code,monospace;font-size:.85em;margin:0 2px;cursor:pointer;transition:all .2s;border:1px solid transparent}.variable-tag:hover{background:#bbdefb;border-color:#1976d2}@media print{.document-editor-container{padding:0;background:none}.document-meta-panel{display:none!important}.document-page{box-shadow:none;border:none;margin:0;padding:15mm 20mm;width:100%}.doc-section-label,.doc-section-placeholder,.doc-section-editor{display:none!important}.doc-header-preview,.doc-footer-preview{border:none!important;padding:0}.ck.ck-toolbar{display:none!important}}.user-list{padding:.5rem}.user-list.empty{text-align:center;padding:2rem;color:#64748b}.user-item{display:flex;align-items:center;padding:.75rem;border-radius:.5rem;cursor:pointer;transition:all .2s;margin-bottom:.25rem}.user-item:hover{background:#f8fafc}.user-item.online{border-left:3px solid #10b981}.user-item.offline{border-left:3px solid #6b7280}.user-avatar{position:relative;margin-right:.75rem}.user-photo{width:40px;height:40px;border-radius:50%;object-fit:cover}.user-avatar-placeholder{width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:.875rem}.status-indicator{position:absolute;bottom:-2px;right:-2px;width:14px;height:14px;border-radius:50%;border:2px solid white;font-size:.625rem;display:flex;align-items:center;justify-content:center;background:#fff}.user-info{flex:1;min-width:0}.user-name{font-weight:600;color:#1e293b;margin-bottom:.125rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-details{display:flex;align-items:center;gap:.5rem;margin-bottom:.25rem}.user-email{font-size:.75rem;color:#64748b;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:150px}.user-role{font-size:.625rem;background:#e2e8f0;color:#475569;padding:.125rem .375rem;border-radius:.25rem;text-transform:uppercase;font-weight:500}.user-status{font-size:.75rem}.status-text{display:flex;align-items:center;gap:.25rem}.status-text.online{color:#10b981}.status-text.offline{color:#6b7280}.last-seen{color:#9ca3af;font-size:.625rem}@media(max-width:640px){.user-avatar{margin-right:.5rem}.user-photo,.user-avatar-placeholder{width:36px;height:36px}.user-email{display:none}.user-role{font-size:.625rem}}.conversation-list{padding:.5rem}.conversation-list.empty{text-align:center;padding:2rem;color:#64748b}.conversation-item{display:flex;align-items:center;padding:.75rem;border-radius:.5rem;cursor:pointer;transition:all .2s;margin-bottom:.25rem;position:relative}.conversation-item:hover{background:#f8fafc}.conversation-item.selected{background:#eff6ff;border-left:3px solid #3b82f6}.conversation-avatar{position:relative;margin-right:.75rem}.conversation-photo{width:48px;height:48px;border-radius:50%;object-fit:cover}.conversation-avatar-placeholder{width:48px;height:48px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:1rem}.unread-indicator{position:absolute;top:0;right:0;width:12px;height:12px;background:#3b82f6;border-radius:50%;border:2px solid white}.conversation-content{flex:1;min-width:0}.conversation-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.25rem}.conversation-name{margin:0;font-weight:600;color:#1e293b;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.conversation-time{font-size:.75rem;color:#64748b;white-space:nowrap}.conversation-preview{display:flex;justify-content:space-between;align-items:flex-start;gap:.5rem}.last-message{margin:0;font-size:.875rem;color:#64748b;line-height:1.3;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex:1;min-width:0}.unread-badge{background:#3b82f6;color:#fff;font-size:.75rem;font-weight:600;padding:.125rem .5rem;border-radius:1rem;min-width:20px;text-align:center;white-space:nowrap}.conversation-item.selected .conversation-name{color:#3b82f6}.conversation-item.selected .last-message{color:#1e40af}@media(max-width:640px){.conversation-avatar{margin-right:.5rem}.conversation-photo,.conversation-avatar-placeholder{width:40px;height:40px}.conversation-name{font-size:.875rem}.last-message{font-size:.8rem}.unread-badge{font-size:.625rem;padding:.125rem .375rem;min-width:18px}}.message-list{display:flex;flex-direction:column;min-height:100%}.message-list.empty{justify-content:center;align-items:center;text-align:center;color:#64748b}.empty-state p{margin:.5rem 0}.message-group{margin-bottom:1.5rem}.date-separator{display:flex;align-items:center;justify-content:center;margin:1rem 0}.date-label{background:#e2e8f0;color:#64748b;padding:.25rem .75rem;border-radius:1rem;font-size:.75rem;font-weight:500}.message-item{display:flex;margin-bottom:.75rem;max-width:100%}.message-item.own{justify-content:flex-end}.message-item.other{justify-content:flex-start}.message-avatar{margin-right:.5rem;margin-top:.25rem}.message-photo{width:32px;height:32px;border-radius:50%;object-fit:cover}.message-avatar-placeholder{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:.75rem}.message-content{max-width:70%;min-width:0}.message-sender{font-size:.75rem;color:#64748b;margin-bottom:.25rem;margin-left:.5rem}.message-bubble{padding:.75rem 1rem;border-radius:1rem;word-wrap:break-word;position:relative;box-shadow:0 1px 2px #0000000d}.message-bubble.own{background:#3b82f6;color:#fff;border-bottom-right-radius:.25rem}.message-bubble.other{background:#f1f5f9;color:#1e293b;border-bottom-left-radius:.25rem}.message-text{margin:0;line-height:1.4;white-space:pre-wrap}.file-message{display:flex;align-items:center;gap:.5rem}.file-link{color:#3b82f6;text-decoration:none;font-weight:500}.file-link:hover{text-decoration:underline}.image-message{text-align:center}.message-image{max-width:200px;max-height:200px;border-radius:.5rem;margin-bottom:.5rem;cursor:pointer;transition:transform .2s}.message-image:hover{transform:scale(1.02)}.image-caption{margin:0;font-size:.875rem}.message-meta{display:flex;align-items:center;justify-content:flex-end;gap:.5rem;margin-top:.25rem;font-size:.625rem}.message-bubble.own .message-meta{color:#ffffffb3}.message-bubble.other .message-meta{color:#64748b}.message-time{white-space:nowrap}.message-status{display:flex;align-items:center}.message-status.sent{color:#ffffff80}.message-status.read{color:#fffc}.typing-indicator{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;color:#64748b;font-size:.875rem}.typing-dots{display:flex;gap:.25rem}.typing-dots span{width:6px;height:6px;background:#64748b;border-radius:50%;animation:typing 1.4s infinite ease-in-out}.typing-dots span:nth-child(1){animation-delay:-.32s}.typing-dots span:nth-child(2){animation-delay:-.16s}@keyframes typing{0%,80%,to{transform:scale(.8);opacity:.5}40%{transform:scale(1);opacity:1}}.typing-text{font-style:italic}@media(max-width:640px){.message-content{max-width:85%}.message-bubble{padding:.625rem .875rem}.message-avatar{margin-right:.375rem}.message-photo,.message-avatar-placeholder{width:28px;height:28px}.message-image{max-width:150px;max-height:150px}}.modern-message-input{padding:1rem;background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000000a;border:1px solid #e5e7eb}.modern-format-toolbar{display:flex;align-items:center;gap:1.5rem;padding:.75rem 1rem;background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px 8px 0 0;border-bottom:none;margin-bottom:-1px;flex-wrap:wrap}.toolbar-section{display:flex;align-items:center;gap:.5rem}.toolbar-label{font-size:.75rem;font-weight:600;color:#64748b;text-transform:uppercase;letter-spacing:.05em}.toolbar-buttons{display:flex;gap:.25rem}.format-btn{padding:.375rem .625rem;border:1px solid #d1d5db;background:#fff;color:#374151;cursor:pointer;border-radius:6px;font-size:.875rem;font-weight:500;transition:all .15s ease;min-width:32px;height:32px;display:flex;align-items:center;justify-content:center;position:relative}.format-btn:hover:not(:disabled){background:#3b82f6;color:#fff;border-color:#3b82f6;transform:translateY(-1px);box-shadow:0 2px 4px #3b82f633}.format-btn:active:not(:disabled){transform:translateY(0)}.format-btn:disabled{opacity:.5;cursor:not-allowed;background:#f3f4f6}.format-btn.clear-btn{background:#fef2f2;color:#dc2626;border-color:#fecaca}.format-btn.clear-btn:hover:not(:disabled){background:#dc2626;color:#fff;border-color:#dc2626}.input-container{display:flex;align-items:flex-end;gap:.75rem;padding:1rem;background:#fff;border:2px solid #e5e7eb;border-radius:12px;transition:all .2s ease;position:relative}.input-container.focused{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f614}.input-container.disabled{opacity:.6;background:#f9fafb;cursor:not-allowed}.input-actions-left{display:flex;gap:.5rem;align-items:center}.action-btn{padding:.625rem;border:1px solid #e5e7eb;background:#fff;color:#6b7280;cursor:pointer;border-radius:8px;transition:all .15s ease;display:flex;align-items:center;justify-content:center;width:40px;height:40px;position:relative}.action-btn:hover:not(:disabled){background:#f3f4f6;color:#374151;border-color:#d1d5db;transform:translateY(-1px)}.action-btn:active:not(:disabled){transform:translateY(0)}.action-btn:disabled{opacity:.5;cursor:not-allowed}.action-btn.format-toggle.active{background:#3b82f6;color:#fff;border-color:#3b82f6}.action-btn.attach-btn:hover:not(:disabled){color:#059669;border-color:#059669}.input-field-wrapper{flex:1;position:relative;display:flex;flex-direction:column}.modern-textarea{flex:1;border:none;background:transparent;resize:none;outline:none;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-size:.9375rem;line-height:1.5;color:#1f2937;min-height:24px;max-height:120px;padding:.5rem 0;overflow-y:auto}.modern-textarea::placeholder{color:#9ca3af;font-style:italic}.modern-textarea:disabled{opacity:.5;cursor:not-allowed}.modern-textarea:focus{outline:none}.char-counter{position:absolute;bottom:-20px;right:0;font-size:.75rem;color:#9ca3af;padding:.25rem .5rem;border-radius:4px;background:#f9fafb;border:1px solid #e5e7eb;min-width:60px;text-align:center;font-weight:500}.char-counter.warning{color:#f59e0b;background:#fef3c7;border-color:#f59e0b}.char-counter.limit{color:#ef4444;background:#fef2f2;border-color:#ef4444;font-weight:600}.send-btn{padding:.75rem;border:none;background:#e5e7eb;color:#9ca3af;cursor:pointer;border-radius:8px;transition:all .2s ease;display:flex;align-items:center;justify-content:center;width:44px;height:44px;position:relative;overflow:hidden}.send-btn.ready{background:#3b82f6;color:#fff;animation:pulse-soft 2s infinite}.send-btn.ready:hover{background:#2563eb;transform:translateY(-2px) scale(1.05);box-shadow:0 6px 20px #3b82f64d}.send-btn.ready:active{transform:translateY(-1px) scale(1.02)}.send-btn:disabled{background:#e5e7eb;color:#9ca3af;cursor:not-allowed;transform:none}.send-btn svg{transition:transform .2s ease}.send-btn.ready:hover svg{transform:translate(2px)}@keyframes pulse-soft{0%,to{box-shadow:0 0 #3b82f64d}50%{box-shadow:0 0 0 6px #3b82f600}}.input-hints{display:flex;justify-content:center;flex-wrap:wrap;gap:1rem;padding:.75rem 0 0;margin-top:.5rem}.hint-item{font-size:.75rem;color:#9ca3af;display:flex;align-items:center;gap:.25rem;background:#f9fafb;padding:.25rem .5rem;border-radius:6px;border:1px solid #e5e7eb}.hint-item kbd{background:#fff;border:1px solid #d1d5db;border-radius:4px;padding:.125rem .375rem;font-family:SF Mono,Monaco,Inconsolata,Roboto Mono,monospace;font-size:.7rem;font-weight:600;color:#374151;box-shadow:0 1px 2px #0000000d}@media(max-width:768px){.modern-message-input{padding:.75rem;border-radius:8px}.modern-format-toolbar{padding:.5rem .75rem;gap:1rem}.toolbar-section{gap:.375rem}.format-btn{min-width:28px;height:28px;font-size:.8rem;padding:.25rem .5rem}.input-container{padding:.75rem;gap:.5rem}.action-btn{width:36px;height:36px;padding:.5rem}.modern-textarea{font-size:.875rem}.send-btn{width:40px;height:40px;padding:.625rem}.char-counter{font-size:.6875rem;bottom:-18px;min-width:55px}.input-hints{gap:.5rem;padding:.5rem 0 0}.hint-item{font-size:.6875rem;padding:.1875rem .375rem}.hint-item kbd{font-size:.65rem;padding:.1rem .25rem}}@media(max-width:480px){.modern-format-toolbar{flex-direction:column;align-items:stretch;gap:.75rem}.toolbar-section{justify-content:space-between}.toolbar-buttons{gap:.1875rem}.format-btn{min-width:26px;height:26px;font-size:.75rem}.input-container{padding:.5rem;gap:.375rem}.action-btn{width:32px;height:32px;padding:.375rem}.send-btn{width:36px;height:36px;padding:.5rem}}.group-list{padding:.5rem}.group-list.empty{text-align:center;padding:2rem;color:#64748b}.group-item{background:#fff;border:1px solid #e2e8f0;border-radius:.5rem;margin-bottom:.5rem;overflow:hidden;transition:all .2s;cursor:pointer}.group-item:hover{border-color:#d1d5db;box-shadow:0 1px 3px #0000001a}.group-item.selected{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.group-header{padding:.75rem;display:flex;align-items:center}.group-avatar{position:relative;margin-right:.75rem}.group-avatar-placeholder{width:48px;height:48px;border-radius:.5rem;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:1rem}.private-indicator{position:absolute;top:-4px;right:-4px;background:#fff;border-radius:50%;padding:2px;font-size:.75rem;box-shadow:0 1px 3px #0003}.group-info{flex:1;min-width:0}.group-name-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:.25rem}.group-name{margin:0;font-weight:600;color:#1e293b;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex:1}.expand-button{background:none;border:none;cursor:pointer;padding:.25rem;border-radius:.25rem;color:#64748b;transition:all .2s;font-size:.75rem}.expand-button:hover{background:#f1f5f9;color:#374151}.group-details{display:flex;align-items:center;gap:.75rem;margin-bottom:.5rem;flex-wrap:wrap}.group-type{font-size:.75rem;background:#e2e8f0;color:#475569;padding:.125rem .375rem;border-radius:.25rem;text-transform:uppercase;font-weight:500}.member-count{font-size:.75rem;color:#64748b;font-weight:500}.user-role{font-size:.75rem;background:#dbeafe;color:#1e40af;padding:.125rem .375rem;border-radius:.25rem;font-weight:500}.group-description{margin:0;font-size:.875rem;color:#64748b;line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.group-expanded{border-top:1px solid #e2e8f0;background:#f8fafc;padding:1rem}.group-members h5{margin:0 0 .75rem;font-size:.875rem;color:#374151;font-weight:600}.members-list{display:flex;flex-direction:column;gap:.5rem;margin-bottom:1rem}.member-item{display:flex;align-items:center;gap:.5rem;padding:.5rem;background:#fff;border-radius:.375rem}.member-avatar{position:relative}.member-photo{width:32px;height:32px;border-radius:50%;object-fit:cover}.member-avatar-placeholder{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:.75rem}.member-info{flex:1;display:flex;align-items:center;gap:.5rem}.member-name{font-weight:500;color:#1e293b;font-size:.875rem}.member-role{font-size:.625rem;background:#f1f5f9;color:#475569;padding:.125rem .25rem;border-radius:.25rem;font-weight:500}.no-members{color:#64748b;font-style:italic;font-size:.875rem}.group-meta{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:.75rem}.meta-item{display:flex;flex-direction:column;gap:.25rem}.meta-label{font-size:.75rem;color:#64748b;font-weight:500}.meta-value{font-size:.875rem;color:#1e293b;font-weight:500}.group-item.selected .group-name{color:#3b82f6}@media(max-width:640px){.group-header{padding:.625rem}.group-avatar{margin-right:.5rem}.group-avatar-placeholder{width:40px;height:40px;font-size:.875rem}.group-name{font-size:.875rem}.group-details{gap:.5rem}.group-expanded{padding:.75rem}.group-meta{grid-template-columns:1fr;gap:.5rem}}.notification-panel{position:fixed;top:0;right:0;width:400px;height:100vh;background:#fff;border-left:1px solid #e2e8f0;box-shadow:-4px 0 25px #0000001a;z-index:1000;display:flex;flex-direction:column;animation:slideIn .3s ease-out}@keyframes slideIn{0%{transform:translate(100%)}to{transform:translate(0)}}.notification-header{display:flex;justify-content:space-between;align-items:center;padding:1rem;border-bottom:1px solid #e2e8f0;background:#f8fafc}.notification-header h3{margin:0;font-size:1.125rem;color:#1e293b}.header-actions{display:flex;align-items:center;gap:.5rem}.mark-all-read-button{padding:.375rem .75rem;border:1px solid #d1d5db;background:#fff;border-radius:.375rem;cursor:pointer;font-size:.75rem;color:#374151;transition:all .2s}.mark-all-read-button:hover{background:#f9fafb;border-color:#9ca3af}.close-button{padding:.375rem;border:none;background:none;cursor:pointer;border-radius:.375rem;font-size:1.125rem;color:#64748b;transition:all .2s;width:32px;height:32px;display:flex;align-items:center;justify-content:center}.close-button:hover{background:#f1f5f9;color:#374151}.notification-content{flex:1;overflow-y:auto;padding:.5rem}.empty-notifications{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;color:#64748b;text-align:center;padding:2rem}.empty-icon{font-size:3rem;margin-bottom:1rem;opacity:.5}.notifications-list{display:flex;flex-direction:column;gap:.5rem}.notification-item{display:flex;align-items:flex-start;gap:.75rem;padding:.75rem;border-radius:.5rem;cursor:pointer;transition:all .2s;border:1px solid transparent}.notification-item:hover{background:#f8fafc}.notification-item.unread{background:#eff6ff;border-color:#bfdbfe}.notification-item.read{background:#fff;border-color:#e2e8f0}.notification-icon{font-size:1.25rem;margin-top:.125rem;flex-shrink:0}.notification-body{flex:1;min-width:0}.notification-header-row{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:.25rem}.notification-title{margin:0;font-size:.875rem;font-weight:600;color:#1e293b;line-height:1.3}.notification-actions{display:flex;align-items:center;gap:.25rem;margin-left:.5rem}.mark-read-button,.expand-button{padding:.25rem;border:none;background:none;cursor:pointer;border-radius:.25rem;font-size:.75rem;color:#64748b;transition:all .2s;width:24px;height:24px;display:flex;align-items:center;justify-content:center}.mark-read-button:hover,.expand-button:hover{background:#e2e8f0;color:#374151}.notification-message{margin:0 0 .5rem;font-size:.875rem;color:#64748b;line-height:1.4}.notification-meta{display:flex;justify-content:space-between;align-items:center;font-size:.75rem}.notification-time{color:#9ca3af}.notification-status{font-weight:500;padding:.125rem .375rem;border-radius:.25rem}.notification-status.unread{background:#dbeafe;color:#1e40af}.notification-status.read{background:#f3f4f6;color:#6b7280}.notification-expanded{margin-top:.75rem;padding-top:.75rem;border-top:1px solid #e2e8f0}.notification-data{margin-bottom:.75rem}.notification-data h5{margin:0 0 .5rem;font-size:.75rem;color:#374151;font-weight:600}.notification-data pre{background:#f8fafc;border:1px solid #e2e8f0;border-radius:.375rem;padding:.5rem;font-size:.75rem;color:#475569;overflow-x:auto;margin:0}.notification-details{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:.5rem}.detail-item{display:flex;flex-direction:column;gap:.25rem}.detail-label{font-size:.75rem;color:#64748b;font-weight:500}.detail-value{font-size:.75rem;color:#1e293b;font-weight:500}.notification-footer{padding:.75rem 1rem;border-top:1px solid #e2e8f0;background:#f8fafc}.unread-summary{font-size:.875rem;color:#374151;font-weight:500;text-align:center}@media(max-width:640px){.notification-panel{width:100vw;height:100vh;border-left:none}.notification-header{padding:.75rem}.notification-header h3{font-size:1rem}.notification-content{padding:.375rem}.notification-item{padding:.625rem}.notification-details{grid-template-columns:1fr}}.status-indicator{position:relative}.status-display{display:flex;align-items:center;gap:.5rem;padding:.5rem .75rem;background:#fff;border:1px solid #e2e8f0;border-radius:.5rem;cursor:pointer;transition:all .2s;font-size:.875rem;min-width:140px}.status-display:hover{border-color:#d1d5db;box-shadow:0 1px 3px #0000001a}.status-display:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f626}.status-display.open .status-arrow{transform:rotate(180deg)}.status-display.connected{border-left:3px solid #10b981}.status-display.disconnected{border-left:3px solid #ef4444}.status-icon{font-size:1rem}.status-label{flex:1;font-weight:500;color:#374151}.status-arrow{font-size:.625rem;color:#9ca3af;transition:transform .2s}.status-dropdown{position:absolute;top:100%;right:0;left:auto;background:#fff;border:1px solid #e2e8f0;border-radius:.5rem;box-shadow:0 10px 25px #0000001a;z-index:1000;margin-top:.25rem;overflow:hidden;display:flex;flex-direction:column;max-height:360px;min-width:220px}.dropdown-header{padding:.75rem;border-bottom:1px solid #e2e8f0;background:#f8fafc}.connection-status{font-size:.875rem;font-weight:500}.status-options{flex:1;overflow-y:auto}.status-option{display:flex;align-items:center;gap:.75rem;width:100%;padding:.75rem;border:none;background:none;cursor:pointer;transition:background-color .2s;text-align:left;font-size:.875rem}.status-option:hover{background:#f8fafc}.status-option:disabled{opacity:.55;cursor:not-allowed}.status-option:disabled:hover{background:none}.status-option.active{background:#eff6ff;color:#3b82f6}.option-icon{font-size:1rem}.option-label{flex:1;font-weight:500;white-space:nowrap}.option-check{color:#3b82f6;font-weight:600}.dropdown-footer{padding:.5rem .75rem;border-top:1px solid #e2e8f0;background:#f8fafc;text-align:center}.dropdown-footer small{color:#64748b;font-size:.75rem}.dropdown-overlay{position:fixed;inset:0;z-index:999;background:transparent}@media(max-width:640px){.status-display{min-width:120px;padding:.375rem .625rem;font-size:.8rem}.status-icon{font-size:.875rem}.status-option{padding:.625rem .75rem;font-size:.8rem}.dropdown-header,.dropdown-footer{padding:.625rem .75rem}}.chat-container{display:flex;flex-direction:column;height:100vh;background:#f8fafc}.chat-header{display:flex;justify-content:space-between;align-items:center;padding:1rem;background:#fff;border-bottom:1px solid #e2e8f0;box-shadow:0 1px 3px #0000001a}.header-left{display:flex;align-items:center;gap:1rem}.header-title{display:flex;flex-direction:column;gap:.15rem}.header-left h1{margin:0;font-size:1.35rem;color:#0f172a;font-weight:800;letter-spacing:-.02em}.header-subtitle{font-size:.85rem;color:#64748b;font-weight:600}.header-right{display:flex;align-items:center;gap:1rem}.header-connection-pill{display:inline-flex;align-items:center;gap:.5rem;padding:.45rem .75rem;border-radius:999px;border:1px solid #e5e7eb;background:#f8fafc;color:#334155;font-size:.875rem;font-weight:700}.header-connection-pill .pill-dot{width:10px;height:10px;border-radius:999px;background:#9ca3af;box-shadow:0 0 0 3px #94a3b840}.header-connection-pill.online{background:#ecfdf5;border-color:#bbf7d0;color:#065f46}.header-connection-pill.online .pill-dot{background:#10b981;box-shadow:0 0 0 3px #10b9812e}.header-connection-pill.offline{background:#fff7ed;border-color:#fed7aa;color:#9a3412}.header-connection-pill.offline .pill-dot{background:#f59e0b;box-shadow:0 0 0 3px #f59e0b2e}.notification-button{position:relative;display:inline-flex;align-items:center;justify-content:center;border:1px solid #e5e7eb;background:#fff;cursor:pointer;font-size:1.1rem;padding:.5rem;border-radius:.75rem;transition:all .2s;min-width:40px;height:40px}.notification-button:hover{background:#f8fafc;border-color:#cbd5e1;transform:translateY(-1px)}.notification-button:active{transform:translateY(0)}.notification-icon{line-height:1}.notification-badge{position:absolute;top:0;right:0;background:#ef4444;color:#fff;font-size:.75rem;padding:.125rem .375rem;border-radius:1rem;min-width:1.25rem;text-align:center}.chat-content{display:flex;flex:1;overflow:hidden}.chat-sidebar{width:350px;background:#fff;border-right:1px solid #e2e8f0;display:flex;flex-direction:column}.sidebar-tabs{display:flex;border-bottom:1px solid #e2e8f0}.tab-button{flex:1;padding:.75rem;border:none;background:none;cursor:pointer;font-size:.875rem;color:#64748b;transition:all .2s;position:relative}.tab-button:hover{background:#f8fafc;color:#475569}.tab-button.active{color:#3b82f6;background:#eff6ff}.tab-button .unread-count,.tab-button .online-count{font-size:.75rem;background:#ef4444;color:#fff;padding:.125rem .375rem;border-radius:1rem;margin-left:.25rem}.search-container{padding:1rem;border-bottom:1px solid #e2e8f0}.search-input{width:100%;padding:.5rem .75rem;border:1px solid #d1d5db;border-radius:.5rem;font-size:.875rem;outline:none;transition:border-color .2s}.search-input:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.sidebar-content{flex:1;overflow-y:auto}.chat-main{flex:1;display:flex;flex-direction:column;background:#fff}.chat-main-header{display:flex;justify-content:space-between;align-items:center;padding:1rem;border-bottom:1px solid #e2e8f0}.chat-main-header h3{margin:0;color:#1e293b}.chat-actions button{padding:.5rem 1rem;border:1px solid #d1d5db;background:#fff;border-radius:.375rem;cursor:pointer;font-size:.875rem;transition:all .2s}.chat-actions button:hover{background:#f9fafb;border-color:#9ca3af}.messages-container{flex:1;overflow-y:auto;padding:1rem}.message-input-container{border-top:1px solid #e2e8f0;background:#fff}.chat-welcome{display:flex;align-items:center;justify-content:center;flex:1;text-align:center;padding:2rem;background:radial-gradient(1200px 400px at 50% 0%,rgba(59,130,246,.1),transparent 60%),radial-gradient(900px 300px at 20% 40%,rgba(139,92,246,.08),transparent 55%),radial-gradient(900px 300px at 80% 60%,rgba(16,185,129,.06),transparent 55%),#fff}.welcome-panel{width:min(760px,100%);background:#ffffffeb;border:1px solid #e5e7eb;border-radius:1.25rem;box-shadow:0 10px 30px #0f172a14,0 1px #fff9 inset;padding:1.75rem;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.welcome-hero{display:flex;align-items:center;gap:1rem;text-align:left}.welcome-icon{width:64px;height:64px;border-radius:1rem;display:flex;align-items:center;justify-content:center;font-size:1.75rem;background:linear-gradient(135deg,#eff6ff,#eef2ff);border:1px solid #e0e7ff;box-shadow:0 8px 20px #3b82f61f;flex-shrink:0}.welcome-text h2{margin:0;color:#0f172a;font-size:1.5rem;font-weight:800;letter-spacing:-.02em}.welcome-text p{margin:.35rem 0 0;color:#64748b;font-size:.95rem;line-height:1.4}.welcome-status-row{display:flex;flex-wrap:wrap;gap:.75rem;margin-top:1.25rem}.welcome-connection-pill,.welcome-user-pill{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem .75rem;border-radius:999px;font-size:.875rem;font-weight:600;border:1px solid #e5e7eb;background:#f8fafc;color:#334155}.welcome-connection-pill .pill-dot{width:10px;height:10px;border-radius:999px;background:#9ca3af;box-shadow:0 0 0 3px #94a3b840}.welcome-connection-pill.online{background:#ecfdf5;border-color:#bbf7d0;color:#065f46}.welcome-connection-pill.online .pill-dot{background:#10b981;box-shadow:0 0 0 3px #10b9812e}.welcome-connection-pill.offline{background:#fff7ed;border-color:#fed7aa;color:#9a3412}.welcome-connection-pill.offline .pill-dot{background:#f59e0b;box-shadow:0 0 0 3px #f59e0b2e}.welcome-user-pill .pill-label{font-size:.75rem;color:#64748b;font-weight:700;text-transform:uppercase;letter-spacing:.06em}.welcome-user-pill .pill-value{color:#0f172a}.welcome-stats{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:.75rem;margin-top:1.25rem}.stat-card{text-align:left;padding:1rem;border-radius:1rem;border:1px solid #e5e7eb;background:#fff;cursor:pointer;transition:all .2s ease}.stat-card:hover{transform:translateY(-1px);border-color:#cbd5e1;box-shadow:0 10px 24px #0f172a14}.stat-value{font-size:1.4rem;font-weight:800;color:#0f172a;line-height:1}.stat-label{margin-top:.35rem;font-size:.85rem;font-weight:600;color:#64748b}.welcome-actions{display:flex;gap:.75rem;margin-top:1.25rem;flex-wrap:wrap}.welcome-btn{padding:.75rem 1rem;border-radius:.9rem;border:1px solid #d1d5db;background:#fff;color:#0f172a;cursor:pointer;font-weight:700;font-size:.9rem;transition:all .2s ease}.welcome-btn:hover{background:#f8fafc;border-color:#9ca3af;transform:translateY(-1px)}.welcome-btn.primary{background:linear-gradient(135deg,#3b82f6,#2563eb);border-color:transparent;color:#fff;box-shadow:0 10px 20px #3b82f640}.welcome-btn.primary:hover{background:linear-gradient(135deg,#2563eb,#1d4ed8);box-shadow:0 14px 28px #3b82f652}.welcome-hint{margin-top:1rem;padding:.75rem 1rem;border-radius:.9rem;background:#f1f5f9;border:1px solid #e2e8f0;color:#475569;font-size:.875rem;text-align:left}@media(max-width:768px){.chat-sidebar{width:300px}.chat-header h1{font-size:1.25rem}.tab-button{font-size:.75rem;padding:.625rem}}@media(max-width:640px){.chat-content{flex-direction:column}.chat-sidebar{width:100%;height:40vh;border-right:none;border-bottom:1px solid #e2e8f0}.chat-main{height:60vh}.welcome-panel{padding:1.25rem}.welcome-hero{align-items:flex-start}.welcome-stats{grid-template-columns:1fr}}.modern-float-button{position:fixed;bottom:2rem;right:2rem;width:60px;height:60px;background:linear-gradient(135deg,#3b82f6,#2563eb);border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;box-shadow:0 8px 25px #3b82f64d;transition:all .3s ease;z-index:9999;border:3px solid rgba(255,255,255,.2)}.modern-float-button:hover{transform:translateY(-3px) scale(1.05);box-shadow:0 12px 35px #3b82f666}.modern-float-button:active{transform:translateY(-1px) scale(1.02)}.float-button-content{position:relative;display:flex;align-items:center;justify-content:center;color:#fff}.float-button-content svg{width:24px;height:24px}.user-count-badge{position:absolute;top:-8px;right:-8px;background:#ef4444;color:#fff;font-size:.75rem;font-weight:700;padding:.25rem .5rem;border-radius:12px;min-width:20px;text-align:center;border:2px solid white;box-shadow:0 2px 8px #ef44444d}.connection-status{position:absolute;bottom:2px;right:2px;width:12px;height:12px;border-radius:50%;border:2px solid white;transition:all .2s ease}.connection-status.connected{background:#10b981;box-shadow:0 0 8px #10b98180}.connection-status.disconnected{background:#ef4444;box-shadow:0 0 8px #ef444480;animation:pulse-red 2s infinite}@keyframes pulse-red{0%,to{opacity:1}50%{opacity:.5}}.modal-content{display:flex;flex-direction:column;gap:1.5rem}.connection-alert{display:flex;align-items:center;gap:1rem;padding:1rem;background:linear-gradient(135deg,#fef2f2,#fee2e2);border:1px solid #fecaca;border-radius:12px;color:#dc2626}.alert-icon{font-size:1.5rem;flex-shrink:0}.alert-content{flex:1}.alert-title{font-weight:600;font-size:.9375rem;margin-bottom:.25rem}.alert-description{font-size:.875rem;opacity:.8}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem 2rem;text-align:center;color:#6b7280}.empty-icon{width:64px;height:64px;background:#f3f4f6;border-radius:50%;display:flex;align-items:center;justify-content:center;margin-bottom:1.5rem;color:#9ca3af}.empty-icon svg{width:32px;height:32px}.empty-title{font-size:1.125rem;font-weight:600;color:#374151;margin-bottom:.5rem}.empty-description{font-size:.875rem;color:#6b7280;max-width:300px}.users-grid{display:flex;flex-direction:column;gap:.75rem;max-height:400px;overflow-y:auto;padding-right:.5rem}.users-grid::-webkit-scrollbar{width:6px}.users-grid::-webkit-scrollbar-track{background:#f1f5f9;border-radius:3px}.users-grid::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:3px}.users-grid::-webkit-scrollbar-thumb:hover{background:#94a3b8}.modern-user-item{display:flex;align-items:center;gap:1rem;padding:1rem;background:#fff;border:1px solid #e5e7eb;border-radius:12px;transition:all .2s ease;cursor:pointer}.modern-user-item:hover{background:#f8fafc;border-color:#d1d5db;transform:translateY(-1px);box-shadow:0 4px 12px #0000000d}.modern-user-item:active{transform:translateY(0)}.user-avatar-container{flex-shrink:0}.user-avatar{position:relative;width:48px;height:48px;border-radius:50%;overflow:hidden;background:#f3f4f6;border:2px solid #e5e7eb}.user-avatar img{width:100%;height:100%;object-fit:cover}.status-indicator{position:absolute;bottom:2px;right:2px;width:12px;height:12px;border-radius:50%;border:2px solid white;box-shadow:0 2px 4px #0000001a}.user-details{flex:1;min-width:0}.user-name{font-weight:600;font-size:.9375rem;color:#1f2937;margin-bottom:.25rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-meta{display:flex;gap:.5rem;margin-bottom:.25rem;flex-wrap:wrap}.user-role,.user-department{font-size:.75rem;padding:.125rem .5rem;border-radius:12px;background:#f1f5f9;color:#64748b;font-weight:500}.user-status-text{font-size:.8125rem;color:#6b7280;font-weight:500}.user-actions{flex-shrink:0}.modern-action-btn{display:flex;align-items:center;gap:.5rem;padding:.625rem 1rem;background:#3b82f6;color:#fff;border:none;border-radius:8px;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s ease;white-space:nowrap}.modern-action-btn:hover{background:#2563eb;transform:translateY(-1px);box-shadow:0 4px 12px #3b82f64d}.modern-action-btn:active{transform:translateY(0)}.modern-action-btn svg{width:16px;height:16px}@media(max-width:768px){.modern-float-button{bottom:1rem;right:1rem;width:56px;height:56px}.float-button-content svg{width:20px;height:20px}.user-count-badge{font-size:.6875rem;padding:.1875rem .4375rem;min-width:18px}.modern-user-item{padding:.75rem;gap:.75rem}.user-avatar{width:40px;height:40px}.user-name{font-size:.875rem}.modern-action-btn{padding:.5rem .75rem;font-size:.8125rem}.modern-action-btn span{display:none}}@media(max-width:480px){.modern-float-button{width:52px;height:52px}.float-button-content svg{width:18px;height:18px}.modern-user-item{flex-direction:column;align-items:flex-start;text-align:center;padding:1rem}.user-details{width:100%;text-align:center}.user-meta{justify-content:center}.user-actions{width:100%}.modern-action-btn{width:100%;justify-content:center}}@media(prefers-color-scheme:dark){.modern-user-item{background:#1f2937;border-color:#374151;color:#e5e7eb}.modern-user-item:hover{background:#374151;border-color:#4b5563}.user-name{color:#f9fafb}.user-role,.user-department{background:#374151;color:#9ca3af}.user-status-text{color:#9ca3af}.user-avatar{border-color:#4b5563}.empty-icon{background:#374151;color:#6b7280}.empty-title{color:#e5e7eb}.empty-description{color:#9ca3af}.users-grid::-webkit-scrollbar-track{background:#374151}.users-grid::-webkit-scrollbar-thumb{background:#4b5563}.users-grid::-webkit-scrollbar-thumb:hover{background:#6b7280}}:root{--audit-primary: #3b82f6;--audit-primary-dark: #2563eb;--audit-primary-light: rgba(59, 130, 246, .1);--audit-secondary: #1e293b;--audit-success: #10b981;--audit-warning: #f59e0b;--audit-danger: #ef4444;--audit-critical: #991b1b;--audit-info: #0ea5e9;--audit-bg: #f1f5f9;--audit-card-bg: #ffffff;--audit-border: #e2e8f0;--audit-text-main: #334155;--audit-text-muted: #64748b;--audit-shadow: 0 4px 6px -1px rgba(0, 0, 0, .1), 0 2px 4px -1px rgba(0, 0, 0, .06);--audit-shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .1), 0 4px 6px -2px rgba(0, 0, 0, .05)}.audit-container{background-color:var(--audit-bg);min-height:100vh;padding:1.5rem;font-family:Inter,-apple-system,sans-serif;color:var(--audit-text-main)}.animate-slide-up{animation:slideUp .4s ease-out forwards}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.audit-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}.audit-title-section h1{font-size:1.75rem;font-weight:800;color:var(--audit-secondary);margin:0;letter-spacing:-.02em}.audit-title-section p{color:var(--audit-text-muted);font-size:.875rem;margin:.25rem 0 0}.system-status{background:#fff;padding:.5rem 1rem;border-radius:9999px;display:flex;align-items:center;gap:.5rem;font-size:.75rem;font-weight:600;box-shadow:var(--audit-shadow);border:1px solid var(--audit-border)}.status-dot{width:8px;height:8px;background:var(--audit-success);border-radius:50%;animation:pulse 2s infinite}@keyframes pulse{0%{transform:scale(.95);box-shadow:0 0 #10b981b3}70%{transform:scale(1);box-shadow:0 0 0 6px #10b98100}to{transform:scale(.95);box-shadow:0 0 #10b98100}}.audit-tabs-nav{display:flex;gap:.5rem;background:#e2e8f0;padding:.25rem;border-radius:.75rem;margin-bottom:2rem;overflow-x:auto;scrollbar-width:none}.audit-tabs-nav::-webkit-scrollbar{display:none}.audit-tab-btn{display:flex;align-items:center;gap:.5rem;padding:.625rem 1rem;border-radius:.5rem;border:none;background:transparent;color:var(--audit-text-muted);font-weight:600;font-size:.875rem;cursor:pointer;transition:all .2s;white-space:nowrap}.audit-tab-btn:hover{background:#ffffff80;color:var(--audit-text-main)}.audit-tab-btn.active{background:#fff;color:var(--audit-primary-dark);box-shadow:var(--audit-shadow)}.tab-icon{font-size:1.1rem}.audit-stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1.5rem;margin-bottom:2rem}.audit-stat-card{background:#fff;padding:1.5rem;border-radius:1rem;box-shadow:var(--audit-shadow);border-bottom:4px solid transparent;transition:transform .2s}.audit-stat-card:hover{transform:translateY(-4px)}.audit-stat-card.primary{border-color:var(--audit-primary)}.audit-stat-card.danger{border-color:var(--audit-danger)}.audit-stat-card.success{border-color:var(--audit-success)}.audit-stat-card.warning{border-color:var(--audit-warning)}.stat-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem}.stat-label{font-size:.75rem;text-transform:uppercase;font-weight:700;color:var(--audit-text-muted);letter-spacing:.05em}.stat-icon{font-size:1.25rem;opacity:.8}.stat-value{font-size:2rem;font-weight:800;color:var(--audit-secondary);line-height:1.2}.stat-footer{margin-top:.75rem;font-size:.75rem;font-weight:500;color:var(--audit-text-muted)}.audit-grid-2{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem}@media(max-width:1024px){.audit-grid-2{grid-template-columns:1fr}}.audit-data-card{background:#fff;border-radius:1rem;box-shadow:var(--audit-shadow);overflow:hidden;border:1px solid var(--audit-border)}.card-header{padding:1.25rem 1.5rem;border-bottom:1px solid var(--audit-border);display:flex;justify-content:space-between;align-items:center;background:#f8fafc}.card-title h2{font-size:1.1rem;font-weight:700;margin:0;color:var(--audit-secondary)}.card-title p{font-size:.75rem;color:var(--audit-text-muted);margin:.125rem 0 0}.card-body{padding:1.5rem}.audit-table-container{overflow-x:auto}.audit-table{width:100%;border-collapse:collapse}.audit-table th{text-align:left;padding:.75rem 1rem;font-size:.7rem;text-transform:uppercase;font-weight:700;color:var(--audit-text-muted);border-bottom:2px solid var(--audit-border);background:#f8fafc}.audit-table td{padding:1rem;font-size:.875rem;border-bottom:1px solid var(--audit-border)}.audit-table tr:hover td{background:#f8fafc}.badge{display:inline-block;padding:.25rem .625rem;border-radius:9999px;font-size:.7rem;font-weight:700;text-transform:uppercase}.badge-success{background:#dcfce7;color:#166534}.badge-warning{background:#fef9c3;color:#854d0e}.badge-danger{background:#fee2e2;color:#991b1b}.badge-info{background:#e0f2fe;color:#0369a1}.badge-secondary{background:#f1f5f9;color:#475569}.risk-bars-container{display:flex;flex-direction:column;gap:1.25rem}.risk-bar-group{width:100%}.risk-bar-header{display:flex;justify-content:space-between;margin-bottom:.375rem}.risk-bar-title{font-size:.8125rem;font-weight:600}.risk-bar-label{font-size:.65rem;font-weight:800;text-transform:uppercase}.progress-track{width:100%;height:.5rem;background:#f1f5f9;border-radius:9999px;overflow:hidden}.progress-fill{height:100%;border-radius:9999px}.bg-critical{background:var(--audit-critical)}.bg-danger{background:var(--audit-danger)}.bg-warning{background:var(--audit-warning)}.bg-success{background:var(--audit-success)}.btn-primary{background:var(--audit-primary-dark);color:#fff;padding:.5rem 1rem;border-radius:.5rem;border:none;font-weight:600;font-size:.875rem;cursor:pointer;display:flex;align-items:center;gap:.375rem;transition:all .2s}.btn-primary:hover{background:#1d4ed8;transform:translateY(-1px)}.btn-secondary{background:#f1f5f9;color:var(--audit-text-main);padding:.5rem 1rem;border-radius:.5rem;border:1px solid var(--audit-border);font-weight:600;font-size:.875rem;cursor:pointer}.text-btn{background:transparent;border:none;color:var(--audit-primary-dark);font-weight:700;font-size:.8125rem;cursor:pointer}.audit-modal-overlay{position:fixed;inset:0;background:#0f172a80;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:2000}.audit-modal{background:#fff;width:100%;max-width:550px;border-radius:1rem;box-shadow:var(--audit-shadow-lg);max-height:90vh;overflow-y:auto}.modal-content{padding:2rem}.modal-header h3{font-size:1.25rem;font-weight:800;margin:0;color:var(--audit-secondary)}.modal-header p{font-size:.875rem;color:var(--audit-text-muted);margin:.25rem 0 1.5rem}.form-group{margin-bottom:1.25rem}.form-group label{display:block;font-size:.75rem;font-weight:700;text-transform:uppercase;margin-bottom:.375rem;color:var(--audit-text-muted)}.form-input{width:100%;padding:.75rem;border-radius:.5rem;border:1px solid var(--audit-border);font-size:.875rem}.form-input:focus{outline:none;border-color:var(--audit-primary);ring:2px solid var(--audit-primary-light)}.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.modal-footer{display:flex;justify-content:flex-end;gap:.75rem;margin-top:2rem}.audit-list{list-style:none;padding:0;margin:0}.audit-list-item{display:flex;justify-content:space-between;align-items:center;padding:.875rem 1rem;border-radius:.75rem;margin-bottom:.5rem;background:#f8fafc}.item-title{font-weight:700;font-size:.9375rem}.item-subtitle{font-size:.75rem;color:var(--audit-text-muted)}.report-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.5rem}.report-card{background:#fff;border-radius:1rem;border:1px solid var(--audit-border);display:flex;flex-direction:column;transition:all .2s}.report-card:hover{transform:translateY(-4px);border-color:var(--audit-primary)}.report-card-upper{padding:1.5rem;flex-grow:1}.report-badge-row{display:flex;justify-content:space-between;margin-bottom:.75rem}.report-date{font-size:.7rem;color:var(--audit-text-muted)}.report-title{font-size:1.1rem;font-weight:700;margin:0 0 .5rem;line-height:1.3}.report-summary{font-size:.8125rem;color:var(--audit-text-muted);line-height:1.5}.report-card-lower{padding:1rem 1.5rem;background:#f8fafc;display:flex;justify-content:space-between;align-items:center;border-top:1px solid var(--audit-border)}.report-add-card{border:2px dashed #cbd5e1;border-radius:1rem;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2.5rem;cursor:pointer;color:#94a3b8;transition:all .2s}.report-add-card:hover{border-color:var(--audit-primary);color:var(--audit-primary);background:var(--audit-primary-light)}.add-icon{font-size:2rem;font-weight:300}.add-text{font-size:.875rem;font-weight:700;margin-top:.5rem}.text-primary{color:var(--audit-primary-dark)}.font-bold{font-weight:700}.text-muted{color:var(--audit-text-muted)}.empty-state{text-align:center;padding:2rem;color:var(--audit-text-muted);font-size:.875rem}.loading-spinner{display:flex;flex-direction:column;align-items:center;justify-content:center;height:300px}.spinner{width:40px;height:40px;border:4px solid #e2e8f0;border-top-color:var(--audit-primary);border-radius:50%;animation:spin 1s linear infinite}.hash-reveal{font-family:monospace;font-size:9px;color:#cbd5e1;max-width:120px}.empty-row{text-align:center;padding:2rem!important;color:#94a3b8}@keyframes spin{to{transform:rotate(360deg)}}.governance-rdc-spinner{animation:spin .8s linear infinite}body{font-family:Arial,sans-serif;margin:0;background:#f4f6f8}*,*:before,*:after{box-sizing:border-box}input:not([type=checkbox]):not([type=radio]),button{width:100%;padding:8px}input[type=checkbox],input[type=radio]{width:auto;padding:0}input[type=password]::-ms-reveal,input[type=password]::-ms-clear{display:none}input[type=password]::-webkit-textfield-decoration-container,input[type=password]::-webkit-credentials-auto-fill-button,input[type=password]::-webkit-contacts-auto-fill-button{display:none}input[type=password]{-webkit-appearance:none;appearance:none}img{max-width:100%;height:auto}.page-container{padding:20px}.table-wrapper{width:100%;overflow-x:auto}@media print{.no-print,.layout .sidebar,.layout .content>nav,.topbar,nav,button,.sidebar{display:none!important}.print-only{display:block!important}body{background:#fff;margin:0;padding:0}.layout{display:block!important}.layout .content{margin-left:0!important;padding:0!important;width:100%!important}table,tr,td,th{page-break-inside:avoid}@page{margin:1.5cm}}.print-only{display:none}.no-print{display:block}.settings-page{max-width:1200px;margin:0 auto;padding:20px}.page-header{margin-bottom:30px;padding-bottom:20px;border-bottom:2px solid #e0e0e0}.page-header h1{margin:0 0 10px;color:#2c3e50;font-size:28px}.page-header p{margin:0;color:#7f8c8d;font-size:16px}.alert{padding:15px 20px;border-radius:8px;margin-bottom:20px;font-weight:500}.alert-success{background:#d4edda;color:#155724;border:1px solid #c3e6cb}.alert-error{background:#f8d7da;color:#721c24;border:1px solid #f5c6cb}.settings-section{background:#fff;padding:25px;margin-bottom:25px;border-radius:8px;box-shadow:0 2px 8px #00000014}.settings-section h2{margin:0 0 20px;color:#2c3e50;font-size:20px;padding-bottom:10px;border-bottom:2px solid #3498db}.form-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:20px}.form-group{display:flex;flex-direction:column}.form-group.full-width{grid-column:1 / -1}.form-group label{font-weight:600;color:#34495e;margin-bottom:8px;font-size:14px}.form-group input,.form-group select{padding:12px;border:1px solid #ddd;border-radius:6px;font-size:15px;transition:all .3s}.form-group input:focus,.form-group select:focus{outline:none;border-color:#3498db;box-shadow:0 0 0 3px #3498db1a}.form-group input:disabled{background:#ecf0f1;color:#7f8c8d;cursor:not-allowed}.form-group small{color:#7f8c8d;font-size:13px;margin-top:5px;font-style:italic}.form-actions{display:flex;gap:15px;justify-content:flex-end;margin-top:30px;padding-top:20px;border-top:2px solid #e0e0e0}.settings-toggles{display:grid;gap:12px}.settings-toggle{border:1px solid #ddd;border-radius:8px;background:#fff;padding:12px 14px}.settings-toggle__label{display:flex;align-items:flex-start;gap:12px;cursor:pointer}.settings-toggle__checkbox{margin-top:3px;width:18px;height:18px;flex:0 0 auto}.settings-toggle__text{display:flex;flex-direction:column;gap:4px}.settings-toggle__title{font-weight:600;color:#34495e;font-size:14px}.settings-toggle__help{color:#7f8c8d;font-size:13px;font-style:italic}.btn-primary{background:linear-gradient(135deg,#3498db,#2980b9);color:#fff;padding:12px 30px;border:none;border-radius:6px;font-size:16px;font-weight:600;cursor:pointer;transition:all .3s}.btn-primary:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 5px 15px #3498db4d}.btn-primary:disabled{background:#95a5a6;cursor:not-allowed;opacity:.6}.btn-secondary{background:#fff;color:#34495e;padding:12px 30px;border:2px solid #bdc3c7;border-radius:6px;font-size:16px;font-weight:600;cursor:pointer;transition:all .3s}.btn-secondary:hover:not(:disabled){background:#ecf0f1;border-color:#95a5a6}.btn-secondary:disabled{opacity:.5;cursor:not-allowed}.btn{padding:10px 20px;font-size:14px;font-weight:600;border:none;border-radius:6px;cursor:pointer;transition:all .2s ease;display:inline-flex;align-items:center;justify-content:center;gap:8px;text-decoration:none;white-space:nowrap}.btn:hover:not(:disabled){transform:translateY(-2px)}.btn:active:not(:disabled){transform:translateY(0)}.btn:disabled{opacity:.6;cursor:not-allowed}.btn-sm{padding:8px 14px;font-size:12px;font-weight:500;border:none;border-radius:6px;cursor:pointer;transition:all .2s;display:inline-flex;align-items:center;gap:5px;color:#fff}.btn-sm:hover:not(:disabled){transform:translateY(-2px)}.btn-lg{padding:14px 28px;font-size:16px}.btn-primary,.btn-sm.btn-primary{background:linear-gradient(135deg,#3498db,#2980b9);color:#fff;box-shadow:0 3px 8px #3498db4d}.btn-primary:hover:not(:disabled),.btn-sm.btn-primary:hover:not(:disabled){box-shadow:0 5px 15px #3498db66}.btn-success,.btn-sm.btn-success{background:linear-gradient(135deg,#27ae60,#1e8449);color:#fff;box-shadow:0 3px 8px #27ae604d}.btn-success:hover:not(:disabled),.btn-sm.btn-success:hover:not(:disabled){box-shadow:0 5px 15px #27ae6066}.btn-danger,.btn-sm.btn-danger{background:linear-gradient(135deg,#e74c3c,#c0392b);color:#fff;box-shadow:0 3px 8px #e74c3c4d}.btn-danger:hover:not(:disabled),.btn-sm.btn-danger:hover:not(:disabled){box-shadow:0 5px 15px #e74c3c66}.btn-warning,.btn-sm.btn-warning{background:linear-gradient(135deg,#f39c12,#e67e22);color:#fff;box-shadow:0 3px 8px #f39c124d}.btn-warning:hover:not(:disabled),.btn-sm.btn-warning:hover:not(:disabled){box-shadow:0 5px 15px #f39c1266}.btn-info,.btn-sm.btn-info{background:linear-gradient(135deg,#17a2b8,#138496);color:#fff;box-shadow:0 3px 8px #17a2b84d}.btn-info:hover:not(:disabled),.btn-sm.btn-info:hover:not(:disabled){box-shadow:0 5px 15px #17a2b866}.btn-secondary-modern,.btn-sm.btn-secondary-modern{background:linear-gradient(135deg,#95a5a6,#7f8c8d);color:#fff;box-shadow:0 3px 8px #95a5a64d}.btn-secondary-modern:hover:not(:disabled),.btn-sm.btn-secondary-modern:hover:not(:disabled){box-shadow:0 5px 15px #95a5a666}.btn-dark,.btn-sm.btn-dark{background:linear-gradient(135deg,#34495e,#2c3e50);color:#fff;box-shadow:0 3px 8px #34495e4d}.btn-dark:hover:not(:disabled),.btn-sm.btn-dark:hover:not(:disabled){box-shadow:0 5px 15px #34495e66}.btn-purple,.btn-sm.btn-purple{background:linear-gradient(135deg,#9b59b6,#8e44ad);color:#fff;box-shadow:0 3px 8px #9b59b64d}.btn-purple:hover:not(:disabled),.btn-sm.btn-purple:hover:not(:disabled){box-shadow:0 5px 15px #9b59b666}.action-buttons{display:flex;gap:6px;justify-content:center;flex-wrap:wrap}.btn-pill{border-radius:999px!important}.btn-icon{width:34px;height:34px;padding:0!important;border-radius:10px;display:inline-flex;align-items:center;justify-content:center;line-height:1}.btn-sm.btn-icon{width:32px;height:32px;padding:0!important;border-radius:10px;font-size:14px}.action-icon-group{display:flex;gap:8px;justify-content:center;align-items:center;flex-wrap:wrap}.submitted-projects-grid,.projects-list-grid{grid-template-columns:repeat(2,minmax(0,1fr))}@media(max-width:720px){.submitted-projects-grid,.projects-list-grid{grid-template-columns:1fr}}.kanban-grid{grid-template-columns:repeat(4,minmax(260px,1fr))}@media(max-width:980px){.kanban-grid{grid-template-columns:repeat(4,minmax(260px,1fr))}}.has-tooltip{position:relative}.has-tooltip:after{content:attr(data-tooltip);position:absolute;left:50%;top:calc(100% + 8px);transform:translate(-50%);background:#111827f2;color:#fff;padding:6px 10px;border-radius:10px;font-size:12px;line-height:1.2;white-space:nowrap;box-shadow:0 10px 30px #00000040;opacity:0;pointer-events:none;transition:opacity .12s ease,transform .12s ease;z-index:2000}.has-tooltip:hover:after,.has-tooltip:focus-visible:after{opacity:1;transform:translate(-50%) translateY(-2px)}.hr-tabs{display:flex;flex-wrap:wrap;gap:10px;margin-top:20px;padding-bottom:12px;border-bottom:1px solid #ddd}.hr-tab-btn{border:1px solid #e5e7eb;background:#f8f9fa;color:#2c3e50;padding:10px 16px;border-radius:999px;cursor:pointer;font-weight:700;font-size:14px;transition:all .2s ease}.hr-tab-btn:hover{transform:translateY(-1px);box-shadow:0 6px 18px #2c3e501a}.hr-tab-btn.active{border-color:transparent;color:#fff;background:linear-gradient(135deg,#3498db,#2980b9);box-shadow:0 10px 24px #3498db4d}.hr-toolbar{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap;margin-bottom:20px}.hr-toolbar-actions{display:flex;gap:10px;flex-wrap:wrap}@media(max-width:767px){.hr-toolbar{align-items:stretch}.hr-toolbar-actions{width:100%}.hr-toolbar-actions .btn{flex:1}}.loading{text-align:center;padding:60px 20px;font-size:18px;color:#7f8c8d}@media(max-width:767px){.page-container,.settings-page{padding:12px}.page-header h1{font-size:22px}.settings-section{padding:16px}.form-grid{grid-template-columns:1fr}.form-actions{flex-direction:column;justify-content:stretch;align-items:stretch}input,select,textarea,button{font-size:16px}table{display:block;max-width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch}}.app-shell{display:flex;min-height:100vh}.app-mobile-topbar{display:none}.app-content{flex:1;min-width:0}.app-sidebar-overlay{display:none}@media(max-width:767px){.app-shell{display:block}.app-mobile-topbar{display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:1100;height:56px;padding:0 12px;background:#2c3e50;color:#fff;border-bottom:1px solid #34495e}.app-mobile-title{font-weight:700;letter-spacing:.2px}.app-mobile-spacer{width:44px}.app-mobile-menu-btn{width:44px!important;height:40px;padding:0!important;border:1px solid #34495e;border-radius:8px;background:#ffffff0f;color:#fff;cursor:pointer}.app-sidebar{position:fixed;top:0;left:0;height:100vh;max-width:86vw;width:280px!important;transform:translate(-105%);transition:transform .16s ease-out;z-index:1200;box-shadow:8px 0 24px #00000059;-webkit-overflow-scrolling:touch;overscroll-behavior:contain}.app-sidebar.open{transform:translate(0)}.app-sidebar-overlay.open{display:block;position:fixed;top:0;left:0;width:100vw;height:100vh;background:#00000073;z-index:1150}.app-content{padding-top:8px}}
