:root{--primary: #2b54a3;--primary-hover: #1e3f7a;--navy: #1e3a5f;--success: #059669;--error: #dc2626;--warning: #f59e0b;--bg: #f0f2f5;--bg-white: #ffffff;--bg-secondary: #f9fafb;--info-bg: #dbeafe;--info-text: #1e40af;--text-primary: #1a1a1a;--text-secondary: #666;--text-muted: #737373;--border: #d1d5db;--border-light: #e5e7eb;--radius: 8px;--radius-sm: 4px;--shadow: 0 1px 3px rgba(0, 0, 0, .1);--shadow-md: 0 4px 6px rgba(0, 0, 0, .07);--max-width: 1200px;--font: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font);background:var(--bg);color:var(--text-primary);line-height:1.5}.navbar{background:var(--navy);color:#fff;height:56px;display:flex;align-items:center;justify-content:space-between;padding:0 24px;position:sticky;top:0;z-index:100}.navbar-brand{color:#fff;text-decoration:none;font-weight:700;font-size:16px;display:flex;align-items:center}.navbar-right{display:flex;align-items:center;gap:12px;font-size:14px}.navbar-user-name{opacity:.9}.navbar-avatar{width:32px;height:32px;border-radius:50%}.navbar-logout{background:#ffffff26;color:#fff;border:1px solid rgba(255,255,255,.3);padding:4px 12px;border-radius:4px;font-size:13px;cursor:pointer;transition:background .15s}.navbar-logout:hover{background:#ffffff40}.staff-layout{min-height:100vh;display:flex;flex-direction:column}.staff-layout-body{display:flex;flex:1}.staff-layout-content{flex:1;padding:24px;max-width:var(--max-width);width:100%}.sidebar{width:200px;background:var(--bg-white);border-right:1px solid var(--border-light);padding:16px 0;flex-shrink:0}.sidebar a{display:flex;align-items:center;padding:10px 24px;color:var(--text-secondary);text-decoration:none;font-size:14px;font-weight:500;transition:background .15s,color .15s}.sidebar a:hover{background:var(--bg);color:var(--text-primary)}.sidebar a.active{color:var(--primary);background:#eef2ff;border-right:3px solid var(--primary)}.sidebar-badge{display:inline-flex;align-items:center;justify-content:center;min-width:20px;height:20px;padding:0 6px;border-radius:10px;background:var(--primary);color:#fff;font-size:11px;font-weight:700;margin-left:auto}.btn{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;font-size:14px;font-weight:600;border-radius:var(--radius-sm);border:1px solid transparent;cursor:pointer;transition:background .15s,box-shadow .15s;text-decoration:none;line-height:1.4}.btn-primary{background:var(--primary);color:#fff;border-color:var(--primary)}.btn-primary:hover{background:var(--primary-hover)}.btn-outline{background:var(--bg-white);color:var(--text-primary);border-color:var(--border)}.btn-outline:hover{background:var(--bg)}.btn-danger{background:var(--error);color:#fff;border-color:var(--error)}.btn-danger:hover{background:#b91c1c}.btn-success{background:var(--success);color:#fff;border-color:var(--success)}.btn-success:hover{background:#047857}.btn-sm{padding:4px 10px;font-size:13px}.btn:disabled{opacity:.5;cursor:not-allowed}.stat-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:16px;margin-bottom:24px}.stat-card{background:var(--bg-white);border:1px solid var(--border-light);border-radius:var(--radius);padding:16px}.stat-card-label{font-size:13px;color:var(--text-muted);margin-bottom:4px}.stat-card-value{font-size:28px;font-weight:700;color:var(--navy)}.card{background:var(--bg-white);border:1px solid var(--border-light);border-radius:var(--radius);padding:20px;box-shadow:var(--shadow)}.card h3{font-size:16px;color:var(--navy);margin-bottom:12px}input,select,textarea{font-family:var(--font);font-size:14px;padding:8px 12px;border:1px solid var(--border);border-radius:var(--radius-sm);width:100%;transition:border-color .15s}input:focus,select:focus,textarea:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 2px #2b54a326}label{display:block;font-size:14px;font-weight:600;margin-bottom:4px;color:var(--text-primary)}.form-group{margin-bottom:16px}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}table{width:100%;border-collapse:collapse}th,td{padding:10px 12px;text-align:left;border-bottom:1px solid var(--border-light);font-size:14px}th{font-weight:600;color:var(--text-secondary);font-size:13px;background:#fafafa}tr:hover{background:#f9fafb}.signature-preview table{width:auto;border-collapse:collapse}.signature-preview td,.signature-preview th{padding:0;border:none;border-bottom:none;font-size:inherit}.signature-preview tr:hover{background:transparent}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;display:flex;align-items:center;justify-content:center;z-index:200}.modal{background:var(--bg-white);border-radius:var(--radius);padding:24px;max-width:560px;width:90%;max-height:85vh;overflow-y:auto;box-shadow:0 20px 60px #00000026}.modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.modal-header h2{font-size:18px;color:var(--navy)}.modal-close{background:none;border:none;font-size:20px;cursor:pointer;color:var(--text-muted);padding:4px}.modal-actions{display:flex;gap:8px;justify-content:flex-end;margin-top:20px}.toast-container{position:fixed;top:16px;right:16px;z-index:9999;display:flex;flex-direction:column;gap:8px}.toast{padding:12px 20px;border-radius:var(--radius-sm);color:#fff;font-size:14px;font-weight:500;box-shadow:var(--shadow-md);animation:slideIn .3s ease}.toast-success{background:var(--success)}.toast-error{background:var(--error)}.toast-warning{background:var(--warning);color:#000}@keyframes slideIn{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}.badge{display:inline-block;padding:2px 8px;border-radius:12px;font-size:12px;font-weight:600}.page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px}.page-header h1{font-size:24px;color:var(--navy)}.empty-state{text-align:center;padding:32px 20px;color:var(--text-muted, #64748b)}.empty-state-title{font-size:15px;font-weight:600;color:var(--text-secondary, #475569);margin-bottom:4px}.empty-state-message{font-size:14px;line-height:1.5}.loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px 20px}.loading-spinner{width:32px;height:32px;border:3px solid var(--border-light, #e5e7eb);border-top-color:var(--primary, #2b54a3);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.loading-text{margin-top:12px;font-size:14px;color:var(--text-muted, #64748b)}.login-page{display:flex;align-items:center;justify-content:center;min-height:100vh;background:var(--bg)}.login-card{background:var(--bg-white);padding:48px;border-radius:var(--radius);box-shadow:var(--shadow-md);text-align:center;max-width:400px;width:90%}.login-card h1{color:var(--navy);margin-bottom:8px;font-size:24px}.login-card p{color:var(--text-secondary);margin-bottom:32px;font-size:15px}.home-tiles{margin-bottom:8px}.home-tiles .tool-card{min-width:0}.section-intro{color:var(--text-secondary);font-size:15px;margin-bottom:24px}.card-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:16px}.tool-card{display:flex;flex-direction:column;background:var(--bg-white);border:1px solid var(--border-light);border-radius:var(--radius);padding:20px;text-decoration:none;color:var(--text-primary);transition:box-shadow .15s,border-color .15s}.tool-card:hover{box-shadow:var(--shadow-md);border-color:var(--primary)}.tool-card-icon{font-size:28px;margin-bottom:8px}.tool-card h3{font-size:15px;color:var(--navy);margin-bottom:4px}.tool-card p{font-size:13px;color:var(--text-muted);line-height:1.4}.content-card-list{display:flex;flex-direction:column;gap:12px}.content-card{display:flex;align-items:center;background:var(--bg-white);border:1px solid var(--border-light);border-radius:var(--radius);padding:20px 24px;text-decoration:none;color:var(--text-primary);transition:box-shadow .15s,border-color .15s}.content-card:hover{box-shadow:var(--shadow-md);border-color:var(--primary)}.content-card h3{font-size:16px;color:var(--navy);margin-bottom:2px}.content-card p{font-size:14px;color:var(--text-muted)}.content-card-arrow{margin-left:auto;font-size:20px;color:var(--text-muted);padding-left:16px}.content-page{display:flex;flex-direction:column;gap:20px}.content-page .card h2{font-size:18px;color:var(--navy);margin-bottom:12px}.content-page .card p{font-size:14px;line-height:1.7;margin-bottom:8px}.content-page .card ul,.content-page .card ol{padding-left:24px;font-size:14px;line-height:1.7;margin-bottom:8px}.content-page .card li{margin-bottom:4px}.content-page .card a{color:var(--primary)}.section-heading{font-size:18px;color:var(--navy);margin:24px 0 12px}.event-table-wrap{background:var(--bg-white);border:1px solid var(--border-light);border-radius:var(--radius);overflow:hidden;margin-bottom:24px}.badge-good{background:#d1fae5;color:#065f46}.badge-ok{background:#fef3c7;color:#92400e}.badge-low{background:#fee2e2;color:#991b1b}.analytics-tabs{display:flex;gap:0;border-bottom:2px solid var(--border-light);margin-bottom:24px}.analytics-tab{padding:10px 20px;font-size:14px;font-weight:600;color:var(--text-muted);background:none;border:none;border-bottom:2px solid transparent;margin-bottom:-2px;cursor:pointer;transition:color .15s,border-color .15s}.analytics-tab:hover{color:var(--text-primary)}.analytics-tab.active{color:var(--primary);border-bottom-color:var(--primary)}.analytics-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px}.breakdown-card{overflow:hidden}.breakdown-list{display:flex;flex-direction:column;gap:6px}.breakdown-row{display:flex;align-items:center;gap:10px;font-size:14px}.breakdown-name{width:140px;flex-shrink:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:var(--text-primary)}.breakdown-bar-wrap{flex:1;height:20px;background:var(--bg);border-radius:4px;overflow:hidden}.breakdown-bar{height:100%;background:var(--primary);border-radius:4px;min-width:2px;opacity:.7}.breakdown-count{width:40px;text-align:right;font-weight:600;color:var(--navy);flex-shrink:0}.breadcrumb{display:inline-block;color:var(--primary);text-decoration:none;font-size:14px;margin-bottom:12px}.breadcrumb:hover{text-decoration:underline}.tiptap-wrapper{border:1px solid var(--border);border-radius:var(--radius-sm);min-height:200px;padding:12px}.tiptap-wrapper .tiptap{outline:none;min-height:180px}.tiptap-wrapper .tiptap p{margin-bottom:8px}.tiptap-wrapper .tiptap h2{font-size:18px;margin-bottom:8px}.tiptap-wrapper .tiptap h3{font-size:16px;margin-bottom:6px}.tiptap-wrapper .tiptap ul,.tiptap-wrapper .tiptap ol{padding-left:24px;margin-bottom:8px}.tiptap-wrapper .tiptap a{color:var(--primary);text-decoration:underline}.kb-hero{background:linear-gradient(135deg,var(--navy) 0%,var(--primary) 100%);border-radius:var(--radius);padding:40px 32px;margin-bottom:28px;text-align:center}.kb-hero h1{color:#fff;font-size:28px;margin-bottom:6px}.kb-hero p{color:#fffc;font-size:15px;margin-bottom:20px}.kb-search-wrap{position:relative;max-width:560px;margin:0 auto}.kb-search-input{width:100%;padding:12px 16px 12px 40px;font-size:15px;border:2px solid rgba(255,255,255,.3);border-radius:var(--radius);background:#ffffff26;color:#fff;outline:none;transition:border-color .15s,background .15s;box-sizing:border-box}.kb-search-input::placeholder{color:#fff9}.kb-search-input:focus{border-color:#fff9;background:#fff3}.kb-search-icon{position:absolute;left:14px;top:50%;transform:translateY(-50%);color:#fff9;font-size:16px;pointer-events:none}.kb-search-results{position:absolute;top:calc(100% + 6px);left:0;right:0;background:var(--bg-white);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-md);max-height:360px;overflow-y:auto;z-index:50}.kb-search-result{display:block;padding:10px 16px;text-decoration:none;color:var(--text-primary);border-bottom:1px solid var(--border-light);transition:background .1s}.kb-search-result:last-child{border-bottom:none}.kb-search-result:hover{background:var(--bg-secondary)}.kb-search-result-title{font-weight:600;font-size:14px}.kb-search-result-meta{font-size:12px;color:var(--text-muted);margin-top:2px}.kb-search-result-snippet{font-size:13px;color:var(--text-secondary);margin-top:4px;line-height:1.4}.kb-search-empty{padding:16px;text-align:center;color:var(--text-muted);font-size:14px}.kb-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:16px;margin-bottom:32px}.kb-card{display:flex;flex-direction:column;background:var(--bg-white);border:1px solid var(--border-light);border-radius:var(--radius);overflow:hidden;text-decoration:none;color:var(--text-primary);transition:transform .15s,box-shadow .15s,border-color .15s}.kb-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md);border-color:var(--primary)}.kb-card-img{width:100%;height:140px;object-fit:cover}.kb-card-initial{width:44px;height:44px;border-radius:50%;background:linear-gradient(135deg,var(--navy) 0%,var(--primary) 100%);color:#fff;font-size:20px;font-weight:600;display:flex;align-items:center;justify-content:center;margin-bottom:12px}.kb-card-body{width:100%;padding:16px;text-align:center}.kb-card-body h3{font-size:15px;color:var(--navy);margin-bottom:4px}.kb-card-body p{font-size:13px;color:var(--text-muted);line-height:1.4;margin-bottom:6px}.kb-card-count{display:inline-block;font-size:11px;color:var(--text-muted);background:var(--bg);padding:2px 8px;border-radius:10px}.kb-page-list{display:flex;flex-direction:column;gap:10px}.kb-page-card{display:flex;align-items:center;justify-content:space-between;background:var(--bg-white);border:1px solid var(--border-light);border-radius:var(--radius);padding:16px 20px;text-decoration:none;color:var(--text-primary);transition:border-color .15s,box-shadow .15s}.kb-page-card:hover{border-color:var(--primary);box-shadow:var(--shadow)}.kb-page-card h3{font-size:15px;color:var(--navy);margin-bottom:4px}.kb-page-card-snippet{font-size:13px;color:var(--text-secondary);line-height:1.4}.kb-page-card-meta{font-size:12px;color:var(--text-muted);margin-top:4px}.kb-page-card-arrow{color:var(--text-muted);font-size:18px;flex-shrink:0;margin-left:16px}.kb-page-layout{display:flex;gap:32px;align-items:flex-start}.kb-page-main{flex:1;min-width:0}.kb-page-meta{font-size:13px;color:var(--text-muted);margin-bottom:16px;display:flex;align-items:center;gap:8px}.kb-page-meta-sep{color:var(--border)}.kb-toc{width:220px;flex-shrink:0;position:sticky;top:80px;max-height:calc(100vh - 100px);overflow-y:auto}.kb-toc-title{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);margin-bottom:8px}.kb-toc-list{list-style:none;padding:0;margin:0}.kb-toc-item{display:block;padding:4px 0 4px 12px;font-size:13px;color:var(--text-secondary);text-decoration:none;border-left:2px solid var(--border-light);transition:color .1s,border-color .1s}.kb-toc-item:hover{color:var(--primary);border-color:var(--primary)}.kb-toc-item-h3{padding-left:24px;font-size:12px}.kb-recent{margin-bottom:28px}.kb-recent h2{font-size:16px;color:var(--navy);margin-bottom:12px}.kb-recent-list{display:flex;flex-direction:column}.kb-recent-item{display:flex;align-items:center;justify-content:space-between;padding:10px 0;border-bottom:1px solid var(--border-light);text-decoration:none;color:var(--text-primary)}.kb-recent-item:last-child{border-bottom:none}.kb-recent-item:hover .kb-recent-title{color:var(--primary)}.kb-recent-title{font-size:14px;font-weight:500;transition:color .1s}.kb-recent-cat{font-size:12px;color:var(--text-muted);margin-left:8px}.kb-recent-date{font-size:12px;color:var(--text-muted);flex-shrink:0}.kb-quick-links{margin-bottom:28px}.kb-quick-links h3{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);margin-bottom:10px}.kb-quick-links-grid{display:flex;flex-wrap:wrap;gap:8px}.kb-quick-link{display:inline-flex;align-items:center;gap:4px;padding:6px 14px;font-size:13px;border-radius:20px;border:1px solid var(--border);color:var(--text-primary);text-decoration:none;background:var(--bg-white);transition:border-color .15s,background .15s}.kb-quick-link:hover{border-color:var(--primary);background:var(--info-bg)}.kb-quick-link-arrow{font-size:10px;color:var(--text-muted)}.kb-content{font-size:15px;line-height:1.8}.kb-content p{margin-bottom:12px}.kb-content h2{font-size:20px;color:var(--navy);margin:28px 0 10px}.kb-content h3{font-size:17px;color:var(--navy);margin:20px 0 8px}.kb-content ul,.kb-content ol{padding-left:24px;margin-bottom:12px;line-height:1.8}.kb-content li{margin-bottom:4px}.kb-content a{color:var(--primary)}.kb-content table{width:100%;border-collapse:collapse;margin:16px 0;font-size:14px}.kb-content table th,.kb-content table td{padding:8px 12px;border:1px solid var(--border-light);text-align:left}.kb-content table th{background:var(--bg-secondary);font-weight:600;color:var(--navy)}.kb-content table tr:hover{background:var(--bg-secondary)}.kb-page-nav{display:flex;justify-content:space-between;margin-top:32px;padding-top:16px;border-top:1px solid var(--border-light)}.kb-page-nav a{color:var(--primary);text-decoration:none;font-size:14px}.kb-page-nav a:hover{text-decoration:underline}.breadcrumb-trail{display:flex;align-items:center;gap:6px;margin-bottom:12px}.breadcrumb-trail .breadcrumb{margin-bottom:0}.breadcrumb-sep{color:var(--text-muted);font-size:13px}.breadcrumb-current{font-size:14px;color:var(--text-secondary)}@media(max-width:768px){.kb-hero{padding:28px 20px}.kb-hero h1{font-size:22px}.kb-toc{display:none}.kb-page-layout{flex-direction:column}.kb-grid{grid-template-columns:repeat(auto-fill,minmax(160px,1fr))}.kb-recent-item{flex-direction:column;align-items:flex-start;gap:2px}.kb-recent-date{margin-left:0}}.kb-toolbar{display:flex;gap:4px;flex-wrap:wrap;margin-bottom:8px;padding:8px 0;border-bottom:1px solid var(--border-light)}.kb-manage-category{background:var(--bg-white);border:1px solid var(--border-light);border-radius:var(--radius);margin-bottom:12px;overflow:hidden}.kb-manage-category-header{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;cursor:pointer;background:#fafafa}.kb-manage-category-header:hover{background:#f5f5f5}.kb-manage-page-list{padding:0 16px 12px}.kb-manage-page-item{display:flex;align-items:center;justify-content:space-between;padding:8px 0;border-bottom:1px solid var(--border-light);font-size:14px}.kb-manage-page-item:last-child{border-bottom:none}.pagination{display:flex;align-items:center;gap:4px;justify-content:center;margin-top:16px}.pagination-ellipsis{color:var(--text-muted);padding:0 4px}.school-picker-dropdown{position:absolute;top:100%;left:0;right:0;background:var(--bg-white);border:1px solid var(--border);border-radius:var(--radius-sm);box-shadow:var(--shadow-md);z-index:50;max-height:220px;overflow-y:auto}.school-picker-item{padding:8px 12px;cursor:pointer;font-size:14px}.school-picker-item:hover{background:var(--bg)}@media(max-width:1024px)and (min-width:769px){.sidebar{width:140px}.sidebar a{font-size:13px;padding:8px 14px}.sidebar-group-label{font-size:9px;padding:10px 14px 4px}.sidebar-badge{font-size:10px;min-width:18px;height:18px}.staff-layout-content{padding:20px}.analytics-grid{grid-template-columns:1fr}}.mobile-nav{display:none}@media(max-width:768px){.sidebar{display:none}.staff-layout-content{padding:12px 12px 70px}.mobile-nav{display:flex;position:fixed;bottom:0;left:0;right:0;background:var(--bg-white);border-top:1px solid var(--border-light);z-index:100;justify-content:space-around;padding:6px 0;box-shadow:0 -2px 10px #0000000f}.mobile-nav a{font-size:10px;color:var(--text-muted);text-decoration:none;text-align:center;padding:6px 4px;min-width:44px;min-height:44px;display:flex;flex-direction:column;align-items:center;justify-content:center}.mobile-nav a.active{color:var(--primary);font-weight:600}.form-row{grid-template-columns:1fr}.page-header{flex-direction:column;align-items:flex-start;gap:8px}.page-header h1{font-size:20px}.card{padding:14px}.card-grid,.kb-grid,.analytics-grid{grid-template-columns:1fr}[style*="grid-template-columns: 1fr 1fr"],[style*=gridTemplateColumns]{grid-template-columns:1fr!important}table{font-size:12px}th,td{padding:6px 5px;white-space:nowrap}.card:has(table){overflow-x:auto;-webkit-overflow-scrolling:touch}.btn{min-height:40px;padding:8px 16px}.btn-sm{min-height:36px;padding:6px 12px}select.input,input.input{min-height:40px;font-size:16px}.modal-overlay>div{width:100vw!important;max-width:100vw!important;border-radius:0!important;max-height:100vh!important}input,select,textarea{font-size:16px}.breakdown-name{width:80px;overflow:hidden;text-overflow:ellipsis}[style*="display: flex"][style*=gap]{flex-wrap:wrap}}.skip-link{position:absolute;top:-100px;left:16px;background:var(--primary);color:#fff;padding:8px 16px;border-radius:var(--radius);z-index:1000;font-size:14px;text-decoration:none}.skip-link:focus{top:8px}.sidebar-group{margin-bottom:8px}.sidebar-group-label{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);padding:12px 20px 4px}.sidebar-divider{height:1px;background:var(--border);margin:8px 12px}.sidebar-group-toggle{display:flex;align-items:center;justify-content:space-between;width:100%;border:none;background:none;cursor:pointer}.sidebar-group-toggle:hover{color:var(--text-primary)}.sidebar-chevron{display:inline-block;width:0;height:0;border-left:4px solid transparent;border-right:4px solid transparent;border-top:5px solid currentColor;transition:transform .15s ease}.sidebar-chevron.open{transform:rotate(180deg)}.merge-field-selected{background-color:#dcfce7}.merge-field-same{background-color:var(--bg)}.merge-radio{margin:0;accent-color:var(--success)}.merge-label{color:var(--text-muted);font-size:12px}.merge-side-badge-a{font-size:10px;padding:1px 5px;border-radius:3px;background:#dbeafe;color:#1d4ed8}.merge-side-badge-b{font-size:10px;padding:1px 5px;border-radius:3px;background:#fef3c7;color:#92400e}.merge-fm-badge{font-size:11px;background:#fef3c7;color:#92400e;padding:1px 5px;border-radius:3px}.merge-tag{font-size:12px;padding:2px 8px;background:#e0e7ff;color:#3730a3;border-radius:var(--radius-sm)}.merge-expertise-chip{font-size:11px;padding:1px 5px;background:var(--bg);border-radius:3px}:focus-visible{outline:2px solid var(--primary, #2563eb);outline-offset:2px}input:focus-visible,select:focus-visible,textarea:focus-visible{outline:none}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}.field-error input,.field-error select,.field-error textarea{border-color:var(--error, #dc2626)!important}.field-error-message{color:var(--error, #dc2626);font-size:12px;margin-top:4px}.captions-row:hover{background:var(--bg-secondary)}.captions-row:focus{outline:2px solid var(--primary);outline-offset:-2px}.mobile-app{display:flex;flex-direction:column;min-height:100vh;min-height:100dvh}.mobile-header{position:sticky;top:0;z-index:50;display:flex;align-items:center;justify-content:space-between;padding:0 14px;height:50px;background:#1e3a5f;color:#fff}.mobile-header-left{display:flex;align-items:center;gap:10px}.mobile-header-title{font-size:16px;font-weight:700;letter-spacing:-.3px}.mobile-header-online{display:flex;align-items:center;gap:4px;font-size:11px;color:#fff9}.online-dot{width:6px;height:6px;border-radius:50%;background:#22c55e}.mobile-header-right{display:flex;align-items:center;gap:8px}.mobile-header-btn{background:none;border:none;color:#fffc;padding:8px;cursor:pointer;border-radius:8px;display:flex;align-items:center;-webkit-tap-highlight-color:transparent}.mobile-header-btn:active{background:#ffffff1a}.mobile-header-avatar{width:30px;height:30px;border-radius:50%;cursor:pointer;border:2px solid rgba(255,255,255,.3)}.mobile-search-bar{padding:8px 14px;background:#fff;border-bottom:1px solid #e5e7eb}.mobile-search-bar input{width:100%;padding:10px 14px;font-size:16px;border:1px solid #d1d5db;border-radius:10px;background:#f9fafb;outline:none}.mobile-search-bar input:focus{border-color:#2563eb;background:#fff}.mobile-content{flex:1;padding:14px;padding-bottom:calc(70px + env(safe-area-inset-bottom,0px));overflow-x:hidden;width:100vw;max-width:100%}.mobile-content .page-header{flex-direction:row;align-items:center;justify-content:space-between;margin-bottom:14px}.mobile-content .page-header h1{font-size:20px;margin:0}.mobile-content .card{border-radius:10px;padding:14px;margin-bottom:12px}.mobile-content .card:has(table){overflow-x:auto;-webkit-overflow-scrolling:touch}.mobile-content table{font-size:13px}.mobile-content th,.mobile-content td{padding:8px 6px;white-space:nowrap}.mobile-content .form-row{grid-template-columns:1fr}.mobile-content input,.mobile-content select,.mobile-content textarea{font-size:16px}.mobile-content .btn{min-height:44px;padding:10px 18px;font-size:14px}.mobile-content .btn-sm{min-height:38px;padding:8px 14px;font-size:13px}.mobile-content .modal-overlay>div,.modal-overlay>div{width:100vw!important;max-width:100vw!important;max-height:calc(100dvh - 56px)!important;border-radius:14px 14px 0 0!important;position:fixed!important;bottom:56px!important;left:0!important;right:0!important;top:auto!important;margin:0!important}.mobile-content .event-table-wrap,.mobile-content .card:has(table),.mobile-content .table-responsive{overflow-x:auto;-webkit-overflow-scrolling:touch}.mobile-app{overflow-x:hidden}.mobile-tabs{position:fixed;bottom:0;left:0;right:0;z-index:100;display:flex;align-items:stretch;background:#fff;border-top:1px solid #e5e7eb;padding-bottom:env(safe-area-inset-bottom,0px);box-shadow:0 -2px 10px #0000000f;height:56px}.mobile-tab{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;text-decoration:none;color:#9ca3af;font-size:11px;font-weight:500;min-height:44px;background:none;border:none;cursor:pointer;position:relative;-webkit-tap-highlight-color:transparent;padding:6px 0}.mobile-tab.active{color:#2563eb}.mobile-tab:active{background:#f3f4f6}.mobile-tab svg{width:22px;height:22px}.mobile-tab span{line-height:1}.mobile-tab-badge{position:absolute;top:4px;right:calc(50% - 18px);min-width:16px;height:16px;padding:0 4px;border-radius:8px;background:#dc2626;color:#fff;font-size:9px;font-weight:700;display:flex;align-items:center;justify-content:center}.mobile-sheet-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:99;background:#0006;animation:fadeIn .15s ease}.mobile-sheet{position:absolute;bottom:56px;bottom:calc(56px + env(safe-area-inset-bottom,0px));left:0;right:0;background:#fff;border-radius:16px 16px 0 0;padding:0 0 8px;max-height:70dvh;overflow-y:auto;animation:slideUp .2s ease}.mobile-sheet-handle{width:36px;height:4px;border-radius:2px;background:#d1d5db;margin:10px auto 8px}.mobile-sheet-search{padding:0 14px 10px}.mobile-sheet-search input{width:100%;padding:10px 14px;font-size:16px;border:1px solid #e5e7eb;border-radius:10px;background:#f9fafb;outline:none}.mobile-sheet-section{padding:10px 16px 6px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:#9ca3af}.mobile-sheet-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:4px;padding:0 10px}.mobile-sheet-item{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;padding:14px 6px;border-radius:10px;text-decoration:none;color:#374151;font-size:12px;font-weight:500;background:#f9fafb;-webkit-tap-highlight-color:transparent;min-height:60px}.mobile-sheet-item:active{background:#e5e7eb}.mobile-sheet-item.admin{background:#eff6ff;color:#1e40af}.mobile-sheet-item svg{color:#6b7280;width:20px;height:20px}.mobile-sheet-item.admin svg{color:#3b82f6}.mobile-sheet-logout{display:block;width:calc(100% - 28px);margin:12px 14px 4px;padding:12px;border:1px solid #e5e7eb;border-radius:10px;background:none;color:#dc2626;font-size:14px;font-weight:500;cursor:pointer;text-align:center}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}
