:root{--color-primary: #1d7af5;--color-primary-hover: #1664cc;--color-primary-light: #e8f2ff;--color-secondary: #6b7280;--color-accent: #ff6b6b;--color-success: #22c55e;--color-warning: #f59e0b;--color-danger: #ef4444;--color-white: #ffffff;--color-black: #000000;--color-gray-50: #f9fafb;--color-gray-100: #f3f4f6;--color-gray-200: #e5e7eb;--color-gray-300: #d1d5db;--color-gray-400: #9ca3af;--color-gray-500: #6b7280;--color-gray-600: #4b5563;--color-gray-700: #374151;--color-gray-800: #1f2937;--color-gray-900: #111827;--color-dark: #1b1b1b;--text-primary: var(--color-gray-900);--text-secondary: var(--color-gray-600);--text-muted: var(--color-gray-500);--text-inverse: var(--color-white);--bg-primary: var(--color-white);--bg-secondary: var(--color-gray-50);--bg-card: #EEF4FF;--bg-hover: var(--color-gray-300);--border-color: var(--color-gray-300);--border-radius-sm: 4px;--border-radius-md: 8px;--border-radius-lg: 16px;--font-family-base: "Inter", system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;--font-family-heading: "Poppins", var(--font-family-base);--font-size-xs: 12px;--font-size-sm: 14px;--font-size-base: 16px;--font-size-lg: 18px;--font-size-xl: 24px;--font-size-2xl: 32px;--font-weight-regular: 400;--font-weight-medium: 500;--font-weight-semibold: 600;--font-weight-bold: 700;--space-1: 4px;--space-2: 8px;--space-3: 12px;--space-4: 16px;--space-5: 20px;--space-6: 24px;--space-8: 32px;--space-10: 40px;--space-12: 48px;--space-16: 64px;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px rgba(0, 0, 0, .1);--shadow-lg: 0 10px 15px rgba(0, 0, 0, .15);--transition-fast: .15s ease;--transition-normal: .3s ease;--transition-slow: .5s ease}body.dark{--text-primary: var(--color-white);--text-secondary: var(--color-gray-200);--text-muted: var(--color-gray-500);--text-inverse: var(--color-black);--bg-primary: var(--color-dark);--bg-secondary: var(--color-gray-900);--bg-card: #121417;--bg-hover: var(--color-gray-600);--border-color: var(--color-gray-700);--color-primary-light: #2a8fff}h1{font-weight:700;line-height:1.2;margin-top:32px;margin-bottom:32px}h2,h3{font-weight:600;line-height:1.3}h4,h5,h6{font-weight:500;line-height:1.3}h1,h2,h3,h4,h5,h6{color:var(--text-primary);font-family:var(--font-family-heading)}body,p,span,a,button,input,textarea,pre{font-family:var(--font-family-base);font-weight:400;font-size:16px;line-height:1.6;color:var(--text-primary)}button{font-weight:500;font-size:16px;line-height:1.4}@media(max-width:768px){body,p,span,a,input,textarea,pre{font-size:14px}}*{box-sizing:border-box;margin:0;padding:0}body{min-height:100vh;width:100%}.loader-overlay{position:fixed;inset:0;background-color:#ffffffb3;display:flex;justify-content:center;align-items:center;z-index:2000}body.dark .loader-overlay{background-color:#0000008c}.loader-container{display:flex;justify-content:center;align-items:center}.loader-image{width:96px;height:96px;animation:loader-pulse 1.1s infinite ease-in-out}@keyframes loader-pulse{0%,to{transform:scale(1);opacity:.85}50%{transform:scale(1.12);opacity:1}}.login-card{background-color:#fff;width:440px;max-width:100%;padding:44px 40px 36px;border-radius:18px;border:1px solid rgba(255,255,255,.6);box-shadow:0 24px 60px -20px #0f172a73,0 8px 24px -12px #0f172a40;box-sizing:border-box;text-align:center;display:flex;flex-direction:column}.login-brand{display:flex;justify-content:center;margin-bottom:20px}.login-logo{width:64px;height:64px;object-fit:contain;border-radius:16px;padding:8px;background:#1d7af5;box-shadow:0 4px 12px #1f7bf22e}.login-title{font-size:24px;font-weight:700;color:#0f172a;margin:0 0 6px;letter-spacing:-.01em}.login-subtitle{font-size:14px;color:#64748b;margin:0 0 28px}.login-form{display:flex;flex-direction:column;gap:18px;text-align:left}.form-group{display:flex;flex-direction:column;gap:8px}.form-label{font-size:13px;font-weight:600;color:#334155;margin-bottom:2px}.input-wrapper{position:relative;display:flex;align-items:center}.form-input{width:100%;padding:13px 44px 13px 16px;background-color:#f8fafc;border:1px solid #e2e8f0;border-radius:10px;font-size:15px;color:#0f172a;outline:none;transition:box-shadow .2s,border-color .2s,background-color .2s;box-sizing:border-box}.form-input:focus{border-color:#1f7bf2;background-color:#fff;box-shadow:0 0 0 3px #1f7bf224}.form-input::placeholder{color:#94a3b8;opacity:1}.input-icon{position:absolute;right:14px;color:#94a3b8;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:color .2s}.input-icon:hover{color:#1f7bf2}.login-error{margin-top:2px;padding:10px 12px;background-color:#fef2f2;color:#b91c1c;border:1px solid #fecaca;border-radius:8px;font-size:13px;line-height:1.4}.submit-btn{margin-top:8px;width:100%;padding:13px;background:linear-gradient(135deg,#1f7bf2,#1664cc);color:#fff;border:none;border-radius:10px;font-size:16px;font-weight:600;cursor:pointer;transition:transform .15s ease,box-shadow .2s ease,opacity .2s;box-shadow:0 8px 20px -8px #1f7bf2b3}.submit-btn:hover:not(:disabled):not(.disabled){transform:translateY(-1px);box-shadow:0 12px 24px -8px #1f7bf2cc}.submit-btn:active:not(:disabled):not(.disabled){transform:translateY(0)}.disabled,.submit-btn:disabled,.submit-btn:disabled:hover,.submit-btn.disabled:hover{background:#cbd5e1;color:#fff;cursor:not-allowed;box-shadow:none;transform:none}.forgot-password{margin-top:16px;font-size:13px;color:#64748b;text-decoration:none;cursor:pointer}.forgot-password:hover{text-decoration:underline;color:#475569}.login-page{min-height:100vh;background:linear-gradient(180deg,#2563eb,#93c5fd 60%,#daeefe);display:flex;flex-direction:column}.login-main{margin-left:260px;margin-top:64px;min-height:calc(100vh - 64px);display:flex;align-items:center;justify-content:center;padding:24px;box-sizing:border-box;width:auto}@media(max-width:768px){.login-main{margin-left:0}.login-card{width:100%;padding:32px 22px 28px;border-radius:16px}}body.dark .login-card{background-color:#1f2937;border-color:#374151;box-shadow:0 24px 60px -20px #000000b3,0 8px 24px -12px #00000080}body.dark .login-logo{background:linear-gradient(135deg,#1e3a5f,#111827);box-shadow:0 4px 12px #0006}body.dark .login-title{color:#fff}body.dark .login-subtitle{color:#9ca3af}body.dark .form-label{color:#e5e7eb}body.dark .form-input{background-color:#111827;color:#fff;border-color:#374151}body.dark .form-input::placeholder{color:#6b7280}body.dark .form-input:focus{border-color:#60a5fa;background-color:#0b1220;box-shadow:0 0 0 3px #60a5fa24}body.dark .input-icon{color:#9ca3af}body.dark .input-icon:hover{color:#60a5fa}body.dark .login-error{background-color:#ef44441f;border-color:#ef444466;color:#f87171}body.dark .forgot-password{color:#9ca3af}body.dark .forgot-password:hover{color:#d1d5db}.dashboard-content{background-color:#fff;padding:24px;font-family:Inter,sans-serif;color:#333;width:100%;box-sizing:border-box}@media(max-width:768px){.dashboard-content{padding:0}}.dashboard-stats-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-bottom:32px}.dashboard-error{margin-bottom:16px;padding:10px 12px;background-color:#fef2f2;color:#b91c1c;border:1px solid #fecaca;border-radius:8px;font-size:13px}.stat-card{background:#fff;border:1px solid #b0d0f7;border-radius:8px;box-shadow:0 4px 12px #0000000d;padding:24px;text-align:center;position:relative;display:flex;flex-direction:column;justify-content:center;align-items:center}.stat-card-title{font-size:14px;color:#64748b;margin-bottom:12px;font-weight:500}.stat-card-number{font-size:32px;font-weight:700;color:#000;margin:0}.stat-card-link{font-size:12px;color:#64748b;position:absolute;bottom:12px;right:16px;text-decoration:none;cursor:pointer}.stat-card-link:hover{color:#1f7bf2}.dashboard-section-card{background:#fff;border:1px solid #bfdbfe;border-radius:8px;box-shadow:0 4px 12px #0000000d;padding:24px;margin-bottom:32px}.section-container{margin-bottom:40px}.section-container:last-child{margin-bottom:0}.section-header{margin-bottom:20px}.section-title{font-size:16px;font-weight:600;color:#1e293b;margin:0 0 12px}.section-divider{height:1px;background-color:#e2e8f0;border:none;margin:0}.status-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}.status-box{background:#fff;border:1px solid #bfdbfe;border-radius:6px;padding:16px;display:flex;justify-content:center;align-items:center;box-shadow:0 1px 2px #00000005}.status-text{font-size:14px;font-weight:500;color:#334155;display:flex;align-items:center;gap:8px}.status-label{color:#475569}.status-value{font-weight:700;color:#000}.activity-card{background:#fff;border:1px solid #bfdbfe;border-radius:8px;box-shadow:0 4px 12px #0000000d;padding:24px}.activity-title{font-size:16px;font-weight:700;color:#1e293b;margin-bottom:16px}.activity-list{list-style:none;padding:0;margin:0}.activity-item{display:flex;justify-content:space-between;align-items:center;padding:12px 0;border-bottom:1px solid #f1f5f9}.activity-item:last-child{border-bottom:none}.activity-name{display:flex;align-items:center;gap:10px;font-size:14px;color:#334155}.activity-bullet{width:8px;height:8px;background-color:#94a3b8;border-radius:50%;display:inline-block}.activity-time{font-size:13px;color:#64748b}@media(max-width:1024px){.dashboard-stats-grid,.status-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:600px){.dashboard-stats-grid{grid-template-columns:1fr;gap:14px;margin-bottom:20px}.status-grid{grid-template-columns:1fr;gap:12px}.stat-card,.dashboard-section-card{padding:18px 16px}.dashboard-section-card{margin-bottom:20px}.section-container{margin-bottom:28px}.stat-card-number{font-size:26px}.stat-card-link{position:static;margin-top:10px;align-self:flex-end}.status-box{padding:12px 14px;justify-content:flex-start}.activity-item{flex-direction:column;align-items:flex-start;gap:4px}.activity-time{align-self:flex-end}}body.dark .dashboard-content{background-color:#111827;color:#f3f4f6}body.dark .stat-card,body.dark .dashboard-section-card,body.dark .status-box,body.dark .activity-card{background:#1f2937;border-color:#374151;box-shadow:0 4px 6px -1px #00000080}body.dark .stat-card-title,body.dark .section-title,body.dark .status-label,body.dark .activity-title{color:#e5e7eb}body.dark .stat-card-number,body.dark .status-value,body.dark .activity-name{color:#fff}body.dark .stat-card-link{color:#9ca3af}body.dark .stat-card-link:hover{color:#60a5fa}body.dark .section-divider,body.dark .activity-item{background-color:transparent;border-color:#374151}body.dark .status-text{color:#d1d5db}body.dark .activity-time{color:#9ca3af}.register-school-container{width:100%;max-width:1200px;margin:0 auto}.register-card{background:#fff;border:1px solid #bfdbfe;border-radius:8px;padding:32px;box-shadow:0 4px 6px #0000000d}.section-title{font-size:18px;font-weight:700;color:#000;margin-bottom:24px}.form-grid{display:flex;flex-direction:column;gap:16px}.form-input-group{display:flex;flex-direction:column}.form-input{width:100%;padding:12px 16px;font-size:14px;color:#333;background-color:#fff;border:1px solid #e2e8f0;border-radius:8px;outline:none;transition:all .2s;box-sizing:border-box;font-weight:500}.form-input::placeholder{color:#94a3b8;font-weight:500}.form-input:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.register-actions{margin-top:32px}.register-btn{width:100%;background-color:#1f7bf2;color:#fff;border:none;border-radius:30px;padding:14px;font-size:16px;font-weight:600;cursor:pointer;transition:background-color .2s}.register-btn:hover{background-color:#1a6bd0}.register-btn:disabled,.register-btn:disabled:hover{background-color:#9ca3af;color:#fff;cursor:not-allowed}body.dark .page-title,body.dark .section-title{color:#fff}body.dark .register-card{background-color:#1f2937;border-color:#374151;box-shadow:0 4px 6px #0000004d}body.dark .form-input{background-color:#111827;color:#fff;border-color:#4b5563}body.dark .form-input::placeholder{color:#9ca3af}body.dark .form-input:focus{border-color:#60a5fa;box-shadow:0 0 0 3px #60a5fa1a}.image-upload-container{width:100%;position:relative}.image-input{display:none}.image-upload-label{display:flex;align-items:center;justify-content:center;width:100%;height:48px;padding:0 16px;background-color:#fff;border:1px solid #e2e8f0;border-radius:8px;cursor:pointer;transition:all .2s;box-sizing:border-box;overflow:hidden}.image-upload-label:hover{border-color:#3b82f6;background-color:#f0f9ff}.upload-placeholder{display:flex;align-items:center;gap:10px;color:#94a3b8;width:100%}.upload-placeholder svg{color:#1f7bf2;width:20px;height:20px}.upload-placeholder span{font-size:14px;font-weight:500}.preview-container{margin-top:12px;width:100%}.file-info-row{display:flex;align-items:center;justify-content:space-between;width:100%;height:48px;padding:0 12px;background-color:#fff;border:1px solid #bfdbfe;border-radius:8px;box-sizing:border-box}.file-info-left{display:flex;align-items:center;gap:12px;overflow:hidden}.mini-preview{height:32px;width:32px;object-fit:cover;border-radius:4px;border:1px solid #e2e8f0}.file-name{font-size:14px;color:#333;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:200px}.remove-file-btn{background:none;border:none;color:#ef4444;font-size:24px;line-height:1;cursor:pointer;padding:0 4px;display:flex;align-items:center;justify-content:center;transition:color .2s}.remove-file-btn:hover{color:#dc2626}body.dark .image-upload-label{background-color:#111827;border-color:#4b5563}body.dark .image-upload-label:hover{border-color:#60a5fa;background-color:#1f7bf21a}body.dark .upload-placeholder{color:#9ca3af}body.dark .file-info-row{background-color:#111827;border-color:#4b5563}body.dark .file-name{color:#e5e7eb}body.dark .mini-preview{border-color:#374151}body.dark .remove-file-btn{color:#fca5a5}body.dark .remove-file-btn:hover{color:#f87171}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}.form-row-label{display:flex;flex-direction:column;gap:6px;font-size:13px;color:#475569;font-weight:500}.form-textarea{min-height:80px;font-family:inherit;resize:vertical}.form-error{padding:10px 12px;background-color:#fef2f2;color:#b91c1c;border:1px solid #fecaca;border-radius:8px;font-size:13px}.form-success{padding:10px 12px;background-color:#ecfdf5;color:#047857;border:1px solid #a7f3d0;border-radius:8px;font-size:13px;display:flex;justify-content:space-between;align-items:center;gap:12px}.form-success-link{background:transparent;border:1px solid #047857;color:#047857;border-radius:6px;padding:4px 10px;cursor:pointer;font-size:12px}body.dark .form-row-label{color:#d1d5db}body.dark .form-error{background-color:#b91c1c29;color:#fecaca;border-color:#7f1d1d}body.dark .form-success{background-color:#0478572e;color:#a7f3d0;border-color:#065f46}body.dark .form-success-link{color:#a7f3d0;border-color:#10b981}body.dark .form-success-link:hover{background:#10b9811f}@media(max-width:600px){.page-title{font-size:20px;margin-bottom:16px}.register-card{padding:20px 16px}.section-title{font-size:16px;margin-bottom:16px}.form-row{grid-template-columns:1fr}.form-success{flex-direction:column;align-items:stretch}}.contacts-container{width:100%;font-family:Inter,sans-serif;color:#000}.contacts-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px}.add-contact-btn{background-color:#1f7bf2;color:#fff;border:none;border-radius:6px;padding:10px 20px;font-size:14px;font-weight:600;cursor:pointer;display:flex;align-items:center;gap:8px;transition:background-color .2s}.add-contact-btn:hover{background-color:#1a6bd0}.add-contact-btn span{color:#fff}.table-container{background:#fff;border:1px solid #bfdbfe;border-radius:8px;overflow:hidden;box-shadow:0 4px 12px #0000000d;margin-bottom:12px;overflow-x:auto}.contacts-table{width:100%;border-collapse:collapse;min-width:900px}.contacts-table thead{background-color:#eaf6ff}.contacts-table th{text-align:left;padding:16px 24px;font-size:14px;font-weight:600;color:#334155;border-bottom:1px solid #bfdbfe;white-space:nowrap}.contacts-table td{padding:16px 24px;font-size:14px;color:#333;border-bottom:1px solid #f1f5f9;white-space:nowrap}.contacts-table tr:last-child td{border-bottom:none}.contacts-table td:has(.contact-card){white-space:normal;vertical-align:top;min-width:280px}.contact-name{font-weight:600;color:#0f172a;margin-bottom:6px}.contact-fields{margin:0;display:grid;grid-template-columns:auto 1fr;column-gap:12px;row-gap:4px}.contact-field{display:contents}.contact-fields dt{font-size:12px;font-weight:600;color:#64748b}.contact-fields dd{margin:0;font-size:13px;color:#334155;word-break:break-word}.contact-raw{font-family:monospace;font-size:12px;color:#64748b;word-break:break-word}body.dark .contact-name{color:#f8fafc}body.dark .contact-fields dt{color:#94a3b8}body.dark .contact-fields dd{color:#e5e7eb}body.dark .contacts-table thead,body.dark .contacts-table th{background-color:#374151;color:#fff;border-bottom-color:#4b5563}body.dark .contacts-table td{color:#e5e7eb;border-bottom-color:#374151}body.dark .contacts-table tbody tr:hover td{background-color:#ffffff0d}.contacts-error{margin:12px 0;padding:10px 12px;background-color:#fef2f2;color:#b91c1c;border:1px solid #fecaca;border-radius:8px;font-size:13px}.contacts-empty{text-align:center;color:#6b7280;padding:24px}@media(max-width:768px){.contacts-header{flex-direction:column;align-items:flex-start;gap:12px}.page-heading{font-size:20px}.filter-bar{flex-direction:column;align-items:stretch;gap:14px;padding:14px 16px}.filter-group{flex-direction:column;gap:12px;width:100%}.filter-select-wrapper{max-width:none;width:100%}}.applied-schools-container{width:100%;font-family:Inter,sans-serif;color:#000}.page-title{font-size:24px;font-weight:700;color:#000;margin-bottom:24px}.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;margin-bottom:32px}.stats-card{background:#fff;border:1px solid #bfdbfe;border-radius:8px;padding:24px;display:flex;flex-direction:column;align-items:center;justify-content:center;box-shadow:0 4px 6px #00000005;text-align:center}.stats-title{font-size:14px;font-weight:500;color:#1e293b;margin-bottom:12px}.stats-count{font-size:20px;font-weight:700;color:#000}.table-container{background:#fff;border:1px solid #bfdbfe;border-radius:8px;box-shadow:0 4px 12px #0000000d;overflow:auto;max-height:calc(100vh - 300px)}.applied-schools-table{width:100%;border-collapse:separate;border-spacing:0;min-width:900px}.applied-schools-table thead{background-color:#eaf6ff;position:sticky;top:0;z-index:10}.applied-schools-table th{text-align:left;padding:16px 24px;font-size:14px;font-weight:600;color:#334155;border-bottom:1px solid #bfdbfe;background-color:#eaf6ff;white-space:nowrap}.applied-schools-table td{padding:16px 24px;font-size:14px;color:#333;border-bottom:1px solid #f1f5f9;white-space:nowrap}.applied-schools-table tr:last-child td{border-bottom:none}body.dark .page-title{color:#fff}body.dark .stats-card{background-color:#1f2937;border-color:#374151;box-shadow:0 4px 6px #0000004d}body.dark .stats-title{color:#9ca3af}body.dark .stats-count{color:#fff}body.dark .applied-schools-table thead,body.dark .applied-schools-table th{background-color:#374151;color:#fff;border-bottom-color:#4b5563}body.dark .applied-schools-table td{color:#e5e7eb;border-bottom-color:#374151}body.dark .applied-schools-table tbody tr:hover td{background-color:#ffffff0d}@media(max-width:1024px){.stats-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:600px){.page-title{font-size:20px;margin-bottom:16px}.stats-grid{grid-template-columns:1fr;gap:14px;margin-bottom:20px}.stats-card{padding:18px 16px}}.detail-modal-backdrop{position:fixed;inset:0;background:#0f172a8c;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.detail-modal{background:#fff;border-radius:12px;width:100%;max-width:600px;max-height:90vh;overflow:hidden;box-shadow:0 20px 50px #00000040;display:flex;flex-direction:column}.detail-modal--wide{max-width:800px}.detail-modal-header{display:flex;align-items:center;gap:16px;padding:18px 24px;border-bottom:1px solid #e2e8f0;flex-shrink:0;background:#fff;position:sticky;top:0;z-index:1}.detail-modal-header h2{margin:0;font-size:18px;line-height:1.3;word-break:break-word;flex:1 1 auto;min-width:0}.detail-modal-header-actions{display:flex;align-items:center;gap:4px}.detail-modal-close{background:transparent;border:none;font-size:24px;cursor:pointer;color:#6b7280;line-height:1;padding:0 4px}.detail-modal-icon-btn{background:transparent;border:1px solid transparent;color:#475569;padding:6px 8px;border-radius:6px;cursor:pointer;display:inline-flex;align-items:center;gap:6px;font-size:13px}.detail-modal-icon-btn:hover{background:#f1f5f9;border-color:#e2e8f0}.detail-modal-footer{flex-shrink:0;padding:14px 24px;border-top:1px solid #e2e8f0;background:#fff;display:flex;justify-content:flex-end;gap:8px;align-items:center}.detail-modal-footer button{padding:8px 14px;border-radius:8px;border:1px solid #d1d5db;background:#fff;cursor:pointer;font-size:13px}.detail-modal-footer button:disabled{opacity:.5;cursor:not-allowed}.detail-modal-footer-spacer{flex:1}.detail-btn-primary{background:#1f7bf2!important;color:#fff!important;border-color:#1f7bf2!important}.detail-btn-danger{color:#b91c1c!important;border-color:#fca5a5!important}body.dark .detail-modal-footer{background:#1f2937;border-top-color:#374151}body.dark .detail-modal-footer button{background:#374151;color:#e5e7eb;border-color:#4b5563}body.dark .detail-btn-primary{background:#1f7bf2!important;color:#fff!important;border-color:#1f7bf2!important}body.dark .detail-btn-danger{color:#fca5a5!important;border-color:#b91c1c!important}body.dark .detail-modal-close{color:#d1d5db}body.dark .detail-modal-icon-btn{color:#e5e7eb}body.dark .detail-modal-icon-btn:hover{background:#374151;border-color:#4b5563}.detail-modal-body{flex:1 1 auto;overflow-y:auto;padding:20px 24px;min-height:0}.detail-fields{display:grid;grid-template-columns:140px 1fr;gap:10px 16px;margin:0;font-size:14px}.detail-fields dt{color:#6b7280;font-weight:500}.detail-fields dd{margin:0;color:#111827;word-break:break-word}.detail-fields .detail-fields-wide{grid-column:1 / -1}.detail-fields-pre{white-space:pre-wrap}.detail-note{margin-top:16px;padding:8px 12px;background:#f3f4f6;color:#6b7280;font-size:12px;border-radius:6px}.detail-image-frame{display:flex;justify-content:center;margin-bottom:16px;padding:16px;background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px}.detail-image-frame img{max-width:220px;max-height:220px;object-fit:contain;border-radius:6px}body.dark .detail-modal{background:#1f2937;color:#e5e7eb}body.dark .detail-modal-header{background:#1f2937;border-bottom-color:#374151}body.dark .detail-fields dd{color:#f3f4f6}body.dark .detail-note{background:#374151;color:#d1d5db}body.dark .detail-image-frame{background:#111827;border-color:#374151}@media(max-width:600px){.detail-modal-backdrop{padding:10px}.detail-modal-header{display:grid;grid-template-columns:1fr auto;grid-template-areas:"title close" "actions close";column-gap:10px;row-gap:8px;align-items:center;padding:14px 16px}.detail-modal-header h2{grid-area:title;font-size:16px}.detail-modal-header-actions{grid-area:actions;flex-wrap:wrap;justify-content:flex-start}.detail-modal-close{grid-area:close;align-self:center;justify-self:end;font-size:32px;padding:0 4px}}.issues-container{width:100%;font-family:Inter,sans-serif;color:#000}.issues-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px}.add-issue-btn{background-color:#3b82f6;color:#fff;border:none;border-radius:8px;padding:12px 24px;font-size:15px;font-weight:600;cursor:pointer;display:flex;align-items:center;gap:10px;box-shadow:0 2px 4px #3b82f64d;transition:all .2s ease}.add-issue-btn:hover{background-color:#2563eb;box-shadow:0 4px 6px #3b82f680;transform:translateY(-1px)}.add-issue-btn span{color:#fff}.table-container{background:#fff;border:1px solid #bfdbfe;border-radius:8px;box-shadow:0 4px 12px #0000000d;margin-bottom:12px;overflow:auto;max-height:calc(100vh - 315px)}.issues-table{width:100%;border-collapse:separate;border-spacing:0;min-width:1000px}.issues-table thead{background-color:#eaf6ff;position:sticky;top:0;z-index:10}.issues-table th{text-align:left;padding:16px 24px;font-size:14px;font-weight:600;color:#334155;border-bottom:1px solid #bfdbfe;background-color:#eaf6ff;white-space:nowrap}.issues-table td{padding:16px 24px;font-size:14px;color:#333;border-bottom:1px solid #f1f5f9;white-space:nowrap}.issues-table tr:last-child td{border-bottom:none}body.dark .issues-table thead,body.dark .issues-table th{background-color:#374151;color:#fff;border-bottom-color:#4b5563}body.dark .issues-table td{color:#e5e7eb;border-bottom-color:#374151}body.dark .issues-table tbody tr:hover td{background-color:#ffffff0d}.issues-error{margin:12px 0;padding:10px 12px;background-color:#fef2f2;color:#b91c1c;border:1px solid #fecaca;border-radius:8px;font-size:13px}.issues-row{cursor:pointer}.issues-empty{text-align:center;color:#6b7280;padding:24px}.issues-pagination{display:flex;gap:12px;align-items:center;justify-content:flex-end;margin-top:16px;font-size:14px;color:#374151}.issues-pagination button{padding:6px 12px;border:1px solid #d1d5db;background:#fff;color:#374151;border-radius:6px;cursor:pointer}.issues-pagination button:disabled{opacity:.5;cursor:not-allowed}body.dark .issues-pagination{color:#d1d5db}body.dark .issues-pagination button{background:#374151;color:#e5e7eb;border-color:#4b5563}body.dark .issues-pagination button:not(:disabled):hover{background:#4b5563}@media(max-width:768px){.issues-header{flex-direction:column;align-items:flex-start;gap:12px}.page-heading{font-size:20px}.filter-bar{flex-direction:column;align-items:stretch;gap:14px;padding:14px 16px}.filter-group{flex-direction:column;gap:12px;width:100%}.filter-select-wrapper{max-width:none;width:100%}}.employees-container{width:100%;font-family:Inter,sans-serif;color:#000}.employees-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px}.add-employee-btn{background-color:#3b82f6;color:#fff;border:none;border-radius:8px;padding:12px 24px;font-size:15px;font-weight:600;cursor:pointer;display:flex;align-items:center;gap:10px;box-shadow:0 2px 4px #3b82f64d;transition:all .2s ease}.add-employee-btn:hover{background-color:#2563eb;box-shadow:0 4px 6px #3b82f680;transform:translateY(-1px)}.add-employee-btn span{color:#fff}.table-container{background:#fff;border:1px solid #bfdbfe;border-radius:8px;box-shadow:0 4px 12px #0000000d;margin-bottom:12px;overflow:auto;max-height:calc(100vh - 250px)}.employees-table{width:100%;border-collapse:separate;border-spacing:0;min-width:1000px}.employees-table thead{background-color:#eaf6ff;position:sticky;top:0;z-index:10}.employees-table th{text-align:left;padding:16px 24px;font-size:14px;font-weight:600;color:#334155;border-bottom:1px solid #bfdbfe;background-color:#eaf6ff;white-space:nowrap}.employees-table td{padding:16px 24px;font-size:14px;color:#333;border-bottom:1px solid #f1f5f9;white-space:nowrap}.employees-table tr:last-child td{border-bottom:none}body.dark .employees-table thead,body.dark .employees-table th{background-color:#374151;color:#fff;border-bottom-color:#4b5563}body.dark .employees-table td{color:#e5e7eb;border-bottom-color:#374151}body.dark .employees-table tbody tr:hover td{background-color:#ffffff0d}.employees-error{margin-bottom:16px;padding:10px 12px;background-color:#ef44441f;border:1px solid rgba(239,68,68,.35);color:#b91c1c;border-radius:8px;font-size:13px}body.dark .employees-error{color:#f87171}@media(max-width:768px){.employees-header{flex-direction:column;align-items:flex-start;gap:12px}.page-heading{font-size:20px}.filter-bar{flex-direction:column;align-items:stretch;gap:14px;padding:14px 16px}.filter-group{flex-direction:column;gap:12px;width:100%}.filter-select-wrapper{max-width:none;width:100%}}.onboarding-container{width:100%;font-family:Inter,sans-serif;color:#000}.onboarding-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px}.page-heading{font-size:24px;font-weight:700;color:#000;margin:0}.add-school-btn{background-color:#1f7bf2;color:#fff;border:none;border-radius:6px;padding:10px 20px;font-size:14px;font-weight:600;cursor:pointer;display:flex;align-items:center;gap:8px;transition:background-color .2s}.add-school-btn:hover{background-color:#1a6bd0}.add-school-btn span{color:#fff}.filter-bar{background-color:#fff;border:1px solid #bfdbfe;border-radius:8px;padding:16px 24px;margin-bottom:24px;display:flex;align-items:center;justify-content:space-between;gap:24px}.filter-group{display:flex;gap:24px;flex:1}.filter-select-wrapper{position:relative;flex:1;max-width:280px}.filter-select{width:100%;padding:10px 36px 10px 16px;font-size:14px;color:#333;background-color:#fff;border:1px solid #bfdbfe;border-radius:6px;outline:none;cursor:pointer;appearance:none;-webkit-appearance:none;font-weight:500}.filter-select-arrow{position:absolute;right:12px;top:50%;transform:translateY(-50%);pointer-events:none;color:#000}.toggle-switch{display:flex;align-items:center}.switch{position:relative;display:inline-block;width:44px;height:24px}.switch input{opacity:0;width:0;height:0}.slider{position:absolute;cursor:pointer;inset:0;background-color:#ccc;transition:.4s;border-radius:24px}.slider:before{position:absolute;content:"";height:18px;width:18px;left:3px;bottom:3px;background-color:#fff;transition:.4s;border-radius:50%}input:checked+.slider{background-color:#1f7bf2}input:checked+.slider:before{transform:translate(20px)}.table-container{background:#fff;border:1px solid #bfdbfe;border-radius:8px;box-shadow:0 4px 12px #0000000d;margin-bottom:12px;overflow:auto;max-height:calc(100vh - 300px)}.onboarding-table{width:100%;border-collapse:separate;border-spacing:0;min-width:1000px}.onboarding-table thead{background-color:#eaf6ff;position:sticky;top:0;z-index:10}.onboarding-table th{text-align:left;padding:16px 24px;font-size:14px;font-weight:600;color:#334155;border-bottom:1px solid #bfdbfe;background-color:#eaf6ff;white-space:nowrap}.onboarding-table td{padding:16px 24px;font-size:14px;color:#333;border-bottom:1px solid #f1f5f9;white-space:nowrap}.onboarding-table tr:last-child td{border-bottom:none}.scroll-hint{text-align:center;font-size:12px;color:#64748b;margin-top:8px}body.dark .page-heading{color:#fff}body.dark .filter-bar{background-color:#1f2937;border-color:#374151}body.dark .filter-select{background-color:#111827;color:#fff;border-color:#4b5563}body.dark .filter-select-arrow{color:#fff}body.dark .table-container{background-color:#1f2937;border-color:#374151;box-shadow:0 4px 12px #0000004d}body.dark .onboarding-table thead,body.dark .onboarding-table th{background-color:#374151;color:#fff;border-bottom-color:#4b5563}body.dark .onboarding-table td{color:#e5e7eb;border-bottom-color:#374151}body.dark .onboarding-table tbody tr:hover td{background-color:#ffffff0d}.onboarding-error{margin:12px 0;padding:10px 12px;background-color:#fef2f2;color:#b91c1c;border:1px solid #fecaca;border-radius:8px;font-size:13px}.onboarding-empty{text-align:center;color:#6b7280;padding:24px}.onboarding-row{cursor:pointer}.onboarding-table tbody tr:hover{background:#1f7bf20a}.school-edit-form{display:flex;flex-direction:column;gap:16px}.school-edit-logo{display:flex;flex-direction:column;align-items:center;gap:8px}.school-edit-logo-empty{padding:24px 16px;background:#f8fafc;border:1px dashed #cbd5e1;border-radius:8px;color:#6b7280;font-size:13px;text-align:center;width:100%;box-sizing:border-box}.school-edit-logo-actions{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.school-edit-logo-input{display:none}.school-edit-logo-btn{padding:6px 12px;border:1px solid #cbd5e1;border-radius:6px;font-size:13px;cursor:pointer;background:#fff;color:#1f7bf2}.school-edit-logo-btn--danger{color:#b91c1c;border-color:#fca5a5}.school-edit-logo-name{font-size:12px;color:#6b7280}.school-edit-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px 16px}.school-edit-grid label{display:flex;flex-direction:column;gap:6px;font-size:13px;color:#475569;font-weight:500}.school-edit-grid .form-input{width:100%;padding:10px 12px;border:1px solid #e2e8f0;border-radius:8px;font-size:14px;box-sizing:border-box;font-family:inherit}.school-edit-grid .form-input:disabled{background:#f8fafc;color:#94a3b8;cursor:not-allowed}.school-edit-hint{margin-left:6px;font-weight:400;color:#94a3b8;font-size:11px}.school-edit-full{grid-column:1 / -1}.school-edit-error{padding:10px 12px;background:#fef2f2;color:#b91c1c;border:1px solid #fecaca;border-radius:8px;font-size:13px}body.dark .school-edit-grid .form-input{background:#1f2937;color:#e5e7eb;border-color:#374151}body.dark .school-edit-grid label{color:#d1d5db}body.dark .school-edit-grid .form-input:disabled{background:#111827;color:#6b7280}body.dark .school-edit-hint,body.dark .school-edit-logo-name{color:#9ca3af}body.dark .school-edit-logo-empty{background:#111827;border-color:#374151;color:#9ca3af}body.dark .school-edit-logo-btn{background:#374151;color:#e5e7eb;border-color:#4b5563}body.dark .school-edit-logo-btn:hover{background:#4b5563}body.dark .school-edit-logo-btn--danger{color:#fca5a5;border-color:#b91c1c}@media(max-width:768px){.onboarding-header{flex-direction:column;align-items:flex-start;gap:12px}.page-heading{font-size:20px}.filter-bar{flex-direction:column;align-items:stretch;gap:14px;padding:14px 16px}.filter-group{flex-direction:column;gap:12px;width:100%}.filter-select-wrapper{max-width:none;width:100%}.school-edit-grid{grid-template-columns:1fr}}.terms-container{width:100%;max-width:1200px;margin:0 auto;padding:24px;box-sizing:border-box}.terms-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.terms-create-btn{background:#1f7bf2;color:#fff;border:none;padding:10px 16px;border-radius:8px;font-weight:600;cursor:pointer}.terms-tabs{display:flex;gap:4px;margin-bottom:16px;border-bottom:1px solid #e2e8f0}.terms-tab{background:transparent;border:none;padding:10px 16px;font-size:14px;font-weight:500;color:#64748b;cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-1px}.terms-tab.active{color:#1f7bf2;border-bottom-color:#1f7bf2}.terms-error{margin:12px 0;padding:10px 12px;background-color:#fef2f2;color:#b91c1c;border:1px solid #fecaca;border-radius:8px;font-size:13px;display:flex;align-items:center;justify-content:space-between;gap:12px}.terms-error-dismiss{background:transparent;border:none;color:#b91c1c;font-size:18px;cursor:pointer}.terms-table{width:100%;border-collapse:collapse;background:#fff;border-radius:8px;overflow:hidden;box-shadow:0 1px 3px #0000000d}.terms-table th,.terms-table td{text-align:left;padding:12px 16px;font-size:14px;border-bottom:1px solid #e2e8f0}.terms-table th{background:#f8fafc;color:#475569;font-weight:600}.terms-row-current{background:#1f7bf20a}.terms-empty{text-align:center;color:#6b7280;padding:24px}.terms-pill{display:inline-block;padding:2px 10px;border-radius:999px;font-size:12px;font-weight:600}.terms-pill-current{background:#ecfdf5;color:#047857}.terms-pill-draft{background:#fef3c7;color:#92400e}.terms-actions{display:flex;gap:8px;flex-wrap:wrap}.terms-actions button{padding:6px 12px;font-size:13px;border-radius:6px;border:1px solid #d1d5db;background:#fff;cursor:pointer}.terms-actions button:disabled{opacity:.5;cursor:not-allowed}.terms-btn-publish{background:#1f7bf2!important;color:#fff!important;border-color:#1f7bf2!important}.terms-btn-danger{color:#b91c1c!important;border-color:#fca5a5!important}.terms-modal-backdrop{position:fixed;inset:0;background:#0f172a8c;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.terms-modal{background:#fff;border-radius:12px;width:100%;max-width:640px;max-height:90vh;overflow:hidden;padding:0;box-shadow:0 20px 50px #00000040;display:flex;flex-direction:column}.terms-preview-modal{max-width:900px}.terms-modal-header{display:flex;justify-content:space-between;align-items:center;padding:18px 24px;border-bottom:1px solid #e2e8f0;flex-shrink:0;background:#fff}.terms-modal-scroll{flex:1 1 auto;overflow-y:auto;padding:20px 24px;min-height:0}.terms-modal-fields{display:flex;flex-direction:column;gap:12px}.terms-modal-fields label{display:flex;flex-direction:column;gap:6px;font-size:13px;color:#475569;font-weight:500}.terms-modal-fields .form-input{width:100%;padding:10px 12px;border:1px solid #e2e8f0;border-radius:8px;font-size:14px;box-sizing:border-box;font-family:inherit}.terms-modal-header h2{margin:0;font-size:18px}.terms-modal-close{background:transparent;border:none;font-size:24px;cursor:pointer;color:#6b7280}.terms-content-textarea{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:12px;resize:vertical}.terms-modal-error{padding:8px 12px;background:#fef2f2;color:#b91c1c;border:1px solid #fecaca;border-radius:8px;font-size:13px}.terms-modal-actions{display:flex;justify-content:flex-end;gap:8px;padding:14px 24px;border-top:1px solid #e2e8f0;background:#fff;flex-shrink:0;align-items:center}.terms-modal-actions button{padding:8px 14px;border-radius:8px;border:1px solid #d1d5db;background:#fff;cursor:pointer;font-size:13px}.terms-btn-primary{background:#1f7bf2!important;color:#fff!important;border-color:#1f7bf2!important}.terms-preview-meta{display:flex;gap:16px;font-size:13px;color:#475569;margin-bottom:12px;padding-bottom:12px;border-bottom:1px solid #e2e8f0;flex-wrap:wrap}.terms-lang-tabs{display:flex;gap:4px;margin-bottom:12px}.terms-lang-tab{background:#f1f5f9;border:none;padding:6px 12px;border-radius:6px;font-size:12px;font-weight:600;cursor:pointer;color:#475569}.terms-lang-tab.active{background:#1f7bf2;color:#fff}.terms-preview-body h3{margin-top:0}.terms-last-updated{color:#6b7280;font-size:13px}.terms-section{margin-top:16px}.terms-section h4{margin:0 0 6px;font-size:14px}.terms-section p,.terms-section li{font-size:13px;line-height:1.5;color:#1f2937}.terms-raw{white-space:pre-wrap;word-break:break-all;background:#f8fafc;padding:12px;border-radius:8px;font-size:12px;max-height:320px;overflow:auto}body.dark .terms-modal,body.dark .terms-table{background:#1f2937;color:#e5e7eb}body.dark .terms-table th{background:#374151;color:#f3f4f6}body.dark .terms-table td{border-bottom-color:#374151}.terms-modal-hint{font-size:13px;color:#475569;background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;padding:10px 12px;margin:0 0 16px;line-height:1.5}.terms-modal-hint code{background:#e2e8f0;padding:1px 6px;border-radius:4px;font-size:12px}.terms-modal-actions-spacer{flex:1}.terms-btn-secondary{background:#fff!important;color:#475569!important;border-color:#cbd5e1!important}body.dark .terms-modal-hint{background:#374151;color:#d1d5db;border-color:#4b5563}body.dark .terms-modal-hint code{background:#4b5563;color:#f3f4f6}body.dark .terms-modal-header{background:#1f2937;border-bottom-color:#374151}body.dark .terms-modal-actions{background:#1f2937;border-top-color:#374151}body.dark .terms-modal-actions button{background:#374151;color:#e5e7eb;border-color:#4b5563}body.dark .terms-modal-fields label{color:#d1d5db}body.dark .terms-modal-fields .form-input{background:#111827;color:#e5e7eb;border-color:#374151}body.dark .terms-modal-close{color:#d1d5db}body.dark .terms-btn-publish,body.dark .terms-btn-primary{background:#1f7bf2!important;color:#fff!important;border-color:#1f7bf2!important}body.dark .terms-btn-secondary{background:#374151!important;color:#e5e7eb!important;border-color:#4b5563!important}body.dark .terms-btn-danger{color:#fca5a5!important;border-color:#b91c1c!important}body.dark .terms-tabs{border-bottom-color:#374151}body.dark .terms-tab{color:#94a3b8}body.dark .terms-tab.active{color:#60a5fa;border-bottom-color:#60a5fa}body.dark .terms-pill-current{background:#10b98126;color:#6ee7b7}body.dark .terms-pill-draft{background:#f59e0b26;color:#fcd34d}body.dark .terms-row-current{background:#1f7bf21f}body.dark .terms-actions button{background:#374151;color:#e5e7eb;border-color:#4b5563}body.dark .terms-raw{background:#111827;color:#d1d5db}body.dark .terms-lang-tab{background:#374151;color:#d1d5db}body.dark .terms-lang-tab.active{background:#1f7bf2;color:#fff}body.dark .terms-section p,body.dark .terms-section li{color:#e5e7eb}body.dark .terms-last-updated,body.dark .terms-preview-meta{color:#94a3b8;border-bottom-color:#374151}@media(max-width:768px){.terms-container{padding:16px 14px}.terms-header{flex-direction:column;align-items:flex-start;gap:12px}.terms-create-btn{width:100%}.terms-tabs{overflow-x:auto;-webkit-overflow-scrolling:touch;white-space:nowrap}.terms-tab{flex:0 0 auto}.terms-table{display:block;overflow-x:auto;white-space:nowrap;-webkit-overflow-scrolling:touch}}.bulk-upload-page{padding:24px;display:flex;flex-direction:column;gap:16px;color:var(--text-primary)}.bulk-header h2{margin:0 0 4px;color:var(--text-primary)}.bulk-subtitle{margin:0;color:var(--text-muted);font-size:14px}.bulk-card{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:8px;padding:20px;display:flex;flex-direction:column;gap:16px}.bulk-row{display:flex;flex-wrap:wrap;gap:16px;align-items:center}.bulk-row label{display:flex;flex-direction:column;gap:6px;font-size:13px;color:var(--text-muted)}.bulk-row select,.bulk-row input[type=text]{padding:8px 10px;border:1px solid var(--border-color);border-radius:6px;min-width:240px;font-size:14px;background:var(--bg-primary);color:var(--text-primary)}.bulk-row select:focus,.bulk-row input[type=text]:focus{outline:none;border-color:var(--color-primary)}.bulk-segment{display:inline-flex;border:1px solid var(--border-color);border-radius:6px;overflow:hidden}.bulk-segment button{padding:8px 16px;border:none;background:transparent;cursor:pointer;font-size:14px;color:var(--text-primary)}.bulk-segment button.active{background:var(--color-primary);color:#fff}.bulk-link-btn{background:none;border:none;color:var(--color-primary);cursor:pointer;padding:4px 0;font-size:14px}.bulk-file-input{display:inline-flex;align-items:center;gap:8px;padding:8px 12px;border:1px dashed var(--border-color);border-radius:6px;cursor:pointer;flex:1;min-width:280px;color:var(--text-secondary)}.bulk-file-input input[type=file]{display:none}.bulk-parsed{justify-content:space-between}.bulk-actions{display:flex;gap:8px}.bulk-actions button{padding:8px 16px;border:1px solid var(--border-color);border-radius:6px;background:var(--bg-primary);color:var(--text-primary);cursor:pointer;font-size:14px}.bulk-actions button:hover:not(:disabled){background:var(--bg-secondary)}.bulk-actions button.primary{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.bulk-actions button.primary:hover:not(:disabled){background:var(--color-primary-hover)}.bulk-actions button:disabled{opacity:.5;cursor:not-allowed}.bulk-summary{display:flex;flex-wrap:wrap;gap:16px;align-items:center;font-size:14px;margin-bottom:8px;color:var(--text-primary)}.bulk-table{width:100%;border-collapse:collapse;font-size:13px;color:var(--text-primary)}.bulk-table th,.bulk-table td{text-align:left;padding:8px 10px;border-bottom:1px solid var(--border-color)}.bulk-table th{background:var(--bg-secondary);font-weight:600;color:var(--text-secondary)}.status{display:inline-block;padding:2px 8px;border-radius:999px;font-size:11px;font-weight:600}.status-ok{background:#f59e0b26;color:#b45309}.status-created{background:#22c55e26;color:#15803d}.status-dup,.status-invalid{background:#ef444426;color:#b91c1c}body.dark .status-ok{color:#fbbf24}body.dark .status-created{color:#4ade80}body.dark .status-dup,body.dark .status-invalid{color:#f87171}.bulk-error{padding:10px 14px;background:#ef44441f;border:1px solid rgba(239,68,68,.35);color:var(--color-danger);border-radius:6px}@media(max-width:768px){.bulk-upload-page{padding:16px 14px}.bulk-card{padding:16px}.bulk-row{flex-direction:column;align-items:stretch;gap:12px}.bulk-row select,.bulk-row input[type=text]{min-width:0;width:100%}.bulk-row label,.bulk-segment{width:100%}.bulk-segment button{flex:1}.bulk-file-input{min-width:0;width:100%;box-sizing:border-box}.bulk-parsed{flex-direction:column;align-items:stretch;gap:12px}.bulk-actions{width:100%}.bulk-actions button{flex:1}.bulk-table{display:block;overflow-x:auto;white-space:nowrap;-webkit-overflow-scrolling:touch}}.structure-page{padding:24px 28px 60px;max-width:1080px;margin:0 auto;font-family:var(--font-family-base);color:var(--text-primary)}.structure-head{display:flex;align-items:flex-start;gap:16px;margin-bottom:20px}.structure-head h1{font-family:var(--font-family-heading);font-size:24px;margin:0}.structure-sub{margin:4px 0 0;color:var(--text-muted);font-size:14px}.structure-back{background:none;border:1px solid var(--border-color);border-radius:8px;padding:8px 12px;cursor:pointer;color:var(--text-primary);font-size:14px}.structure-back:hover{background:var(--bg-secondary)}.structure-error{color:var(--color-danger)}.structure-banner{padding:10px 14px;border-radius:8px;margin-bottom:16px;font-size:14px;border:1px solid transparent}.structure-banner--error{background:#ef44441f;border-color:#ef444459;color:var(--color-danger)}.structure-banner--ok{background:#22c55e1f;border-color:#22c55e59;color:var(--color-success)}.structure-card{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:12px;padding:18px 20px;margin-bottom:22px}.structure-card-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.structure-card-head h2{font-family:var(--font-family-heading);font-size:18px;margin:0}.structure-empty,.structure-hint{color:var(--text-muted);font-size:14px;margin:8px 0}.structure-table{width:100%;border-collapse:collapse;font-size:14px}.structure-table th,.structure-table td{text-align:left;padding:10px 8px;border-bottom:1px solid var(--border-color);vertical-align:middle;color:var(--text-primary)}.structure-table th{color:var(--text-muted);font-weight:600;font-size:12px;text-transform:uppercase;letter-spacing:.4px}.col-action{text-align:right;width:1%;white-space:nowrap}.chip{display:inline-block;background:var(--color-primary-light);color:var(--color-primary);border-radius:999px;padding:2px 10px;font-size:12px;margin:0 4px 4px 0}body.dark .chip{color:var(--text-primary)}.link-readout{display:flex;flex-direction:column;gap:8px}.link-readout-row{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.link-readout-row .chip{min-width:48px;text-align:center;margin:0}.strength{font-size:13px;color:var(--text-secondary);white-space:nowrap}.inline-form{display:flex;gap:10px;align-items:center;flex-wrap:wrap;margin-bottom:14px}.inline-form input,.inline-form select{min-width:200px}.standard-form{border:1px dashed var(--border-color);border-radius:10px;padding:16px;margin-bottom:16px;background:var(--bg-secondary)}.form-row{display:flex;gap:16px;flex-wrap:wrap;margin-bottom:14px}.form-row label,.standard-form label{display:flex;flex-direction:column;gap:6px;font-size:13px;color:var(--text-secondary);min-width:220px}.structure-page input,.structure-page select{border:1px solid var(--border-color);border-radius:8px;padding:8px 10px;font-size:14px;font-family:inherit;background:var(--bg-primary);color:var(--text-primary)}.structure-page input:focus,.structure-page select:focus{outline:none;border-color:var(--color-primary)}.structure-page select option{color:initial}.link-grid-head{font-size:12px;text-transform:uppercase;letter-spacing:.4px;color:var(--text-muted);margin-bottom:8px}.link-row{display:grid;grid-template-columns:160px 1fr 120px;gap:10px;align-items:center;padding:6px 0}.link-row:not(.is-on){opacity:.6}.link-check{display:flex;align-items:center;gap:8px;font-size:14px;color:var(--text-primary);flex-direction:row}.form-actions{display:flex;gap:10px;margin-top:16px}.btn-primary{background:var(--color-primary);color:#fff;border:none;border-radius:8px;padding:8px 16px;font-size:14px;cursor:pointer}.btn-primary:hover{background:var(--color-primary-hover)}.btn-primary:disabled{opacity:.55;cursor:not-allowed}.btn-ghost{background:none;border:1px solid var(--border-color);border-radius:8px;padding:8px 16px;font-size:14px;cursor:pointer;color:var(--text-primary)}.btn-ghost:hover{background:var(--bg-secondary)}.btn-link{background:none;border:none;color:var(--color-primary);cursor:pointer;font-size:14px;padding:4px 6px}.btn-link:hover{text-decoration:underline}.btn-link--danger{color:var(--color-danger)}@media(max-width:768px){.structure-page{padding:16px 14px 48px}.structure-head{flex-wrap:wrap;gap:12px}.structure-head h1{font-size:20px}.structure-card{padding:14px}.structure-card-head{flex-wrap:wrap;gap:10px}.form-row{flex-direction:column;gap:12px}.form-row label,.standard-form label{min-width:0;width:100%}.form-row select,.form-row input,.standard-form input,.standard-form select{width:100%}.inline-form{flex-direction:column;align-items:stretch}.inline-form input,.inline-form select{min-width:0;width:100%}.inline-form .btn-primary,.inline-form .btn-ghost{width:100%}.link-row{grid-template-columns:1fr;gap:8px;padding:10px 0;border-bottom:1px solid var(--border-color)}.link-row select,.link-row input{width:100%}.link-readout-row{gap:8px}.link-readout-row select{flex:1;min-width:0}.form-actions{flex-direction:column}.form-actions .btn-primary,.form-actions .btn-ghost{width:100%}.structure-table{display:block;overflow-x:auto;white-space:nowrap;-webkit-overflow-scrolling:touch}}.app-header{height:64px;background-color:#1f7bf2;display:flex;align-items:center;justify-content:space-between;padding:0 24px;position:fixed;top:0;left:0;width:100%;z-index:1000;box-sizing:border-box;box-shadow:0 2px 4px #0000001a;transition:background-color .3s ease}body.dark .app-header{background-color:#1f2937;box-shadow:0 4px 6px -1px #00000080}.header-menu-btn{display:none;background:none;border:none;color:#fff;cursor:pointer;padding:6px;margin-right:8px;align-items:center;justify-content:center}.header-brand{display:flex;align-items:center;color:#fff}.header-logo-icon{width:60px;height:60px;margin-right:8px;display:flex;align-items:center;justify-content:center}.header-logo-icon img{width:60px!important;height:60px!important;filter:brightness(0) invert(1)}.header-text{display:flex;flex-direction:column}.header-title{font-size:28px;font-weight:700;line-height:1.2;color:#fff}.header-subtitle{font-size:15px;opacity:.95;font-weight:500;color:#fff}.header-actions{display:flex;align-items:center;position:relative}.header-profile{display:flex;align-items:center;gap:12px;cursor:pointer;padding:4px 8px;border-radius:8px;transition:background-color .2s}.header-profile:hover{background-color:#ffffff1a}.profile-info{display:flex;flex-direction:column;align-items:flex-end;color:#fff}.profile-name{font-size:14px;font-weight:700;line-height:1.2;color:#fff}.profile-role{font-size:12px;font-weight:400;opacity:.8;color:#fff}.profile-avatar{width:40px;height:40px;background-color:#e0e0e0;border-radius:8px;display:flex;align-items:center;justify-content:center;overflow:hidden}.profile-avatar img{width:100%;height:100%;object-fit:cover}.profile-dropdown{position:absolute;top:120%;right:0;width:200px;background-color:#e0e0e0;border-radius:8px;padding:8px 0;box-shadow:0 4px 12px #00000026;display:flex;flex-direction:column;z-index:1001;overflow:hidden}.dropdown-item{padding:10px 16px;font-size:14px;font-weight:600;color:#000;cursor:pointer;transition:background-color .2s;background:transparent;border:none;text-align:left}.dropdown-item:hover{background-color:#0000000d}.header-login-btn{background-color:#fff;color:#1f7bf2;border:none;padding:8px 24px;border-radius:6px;font-weight:600;font-size:14px;cursor:pointer;transition:background-color .2s}.header-login-btn:hover{background-color:#f0f9ff}.app-sidebar{width:260px;height:calc(100vh - 64px);background-color:#eaf6ff;position:fixed;top:64px;left:0;padding:24px 16px;box-sizing:border-box;display:flex;flex-direction:column;z-index:900}.sidebar-menu{display:flex;flex-direction:column;gap:16px;flex:1;height:calc(100% - 100px);overflow:auto}.menu-item{display:flex;align-items:center;padding:12px 16px;background-color:transparent;border:1px solid #60a5fa;border-radius:8px;color:#000;text-decoration:none;font-size:14px;font-weight:700;transition:all .2s ease;cursor:pointer}.menu-item:hover,.menu-item.active{background-color:#dbeafe;border-color:#2563eb;color:#000}.menu-icon{width:20px;height:20px;margin-right:12px;display:flex;align-items:center;justify-content:center;color:inherit}.sidebar-footer{margin-top:auto;border-top:1px solid #e0e0e0;padding-top:16px}.school-selector{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;background-color:#fff;border:none;border-radius:8px;font-weight:700;font-size:14px;color:#000;cursor:pointer;box-shadow:0 2px 4px #0000000d}.sidebar-backdrop{display:none}@media(max-width:768px){.app-sidebar{transform:translate(-100%);transition:transform .25s ease;box-shadow:2px 0 12px #00000026;width:78%;max-width:300px}.app-sidebar--open{transform:translate(0)}.sidebar-backdrop{display:block;position:fixed;inset:64px 0 0;background:#00000073;opacity:0;pointer-events:none;transition:opacity .25s ease;z-index:850}.sidebar-backdrop.is-open{opacity:1;pointer-events:auto}}.app-layout{min-height:100vh;display:flex;flex-direction:column}body.dark .app-layout{background-color:#111827}.app-layout.layout-centered{background:linear-gradient(180deg,#2563eb,#93c5fd 60%,#daeefe)}body.dark .app-layout.layout-centered{background:linear-gradient(180deg,#111827,#1f2937)}.app-main{margin-left:260px;margin-top:64px;min-height:calc(100vh - 64px);padding:24px;box-sizing:border-box;width:auto}.app-main.centered{display:flex;align-items:center;justify-content:center}@media(max-width:768px){.app-main{margin-left:0}.header-menu-btn{display:inline-flex}}.app-sidebar{--sidebar-bg: #eaf6ff;--sidebar-border: none;--menu-item-bg: transparent;--menu-item-border: #60a5fa;--menu-item-text: #000000;--menu-item-hover-bg: #dbeafe;--menu-item-hover-border: #2563eb;--menu-item-hover-text: #000000;--menu-icon-color: inherit;--footer-bg: white;--footer-border: none;--footer-text: #000000;--footer-shadow: 0 2px 4px rgba(0, 0, 0, .05);background-color:var(--sidebar-bg)!important;transition:background-color .3s ease,border-color .3s ease,color .3s ease}.app-sidebar[data-theme=dark]{border-right:1px solid #374151!important;--sidebar-bg: #111827;--menu-item-bg: rgba(255, 255, 255, .05);--menu-item-border: #374151;--menu-item-text: #f3f4f6;--menu-item-hover-bg: #1f2937;--menu-item-hover-border: #60a5fa;--menu-item-hover-text: #ffffff;--menu-icon-color: #9ca3af;--footer-bg: #1f2937;--footer-border: 1px solid #374151;--footer-text: #f3f4f6;--footer-shadow: 0 4px 6px -1px rgba(0, 0, 0, .5)}.app-sidebar .menu-item{background-color:var(--menu-item-bg)!important;border:1px solid var(--menu-item-border)!important;color:var(--menu-item-text)!important}.app-sidebar .menu-item:hover,.app-sidebar .menu-item.active{background-color:var(--menu-item-hover-bg)!important;border-color:var(--menu-item-hover-border)!important;color:var(--menu-item-hover-text)!important}.app-sidebar .menu-icon{color:var(--menu-icon-color)!important}.app-sidebar .school-selector{background-color:var(--footer-bg)!important;border:var(--footer-border)!important;color:var(--footer-text)!important;box-shadow:var(--footer-shadow)!important}.app-sidebar .school-selector svg{stroke:currentColor}.theme-toggle-container{background-color:var(--toggle-bg, #f3f4f6);border:1px solid var(--toggle-border, #e5e7eb);border-radius:99px;padding:4px;display:inline-flex;position:relative;width:100%;box-sizing:border-box}[data-theme=dark] .theme-toggle-container{--toggle-bg: #1f2937;--toggle-border: #374151}.theme-toggle-option{flex:1;border:none;background:transparent;color:var(--toggle-text, #6b7280);padding:6px 12px;font-size:13px;font-weight:500;cursor:pointer;border-radius:99px;transition:color .2s ease;z-index:2;text-align:center;outline:none;position:relative}[data-theme=dark] .theme-toggle-option{--toggle-text: #9ca3af}.theme-toggle-option.active{color:var(--toggle-active-text, #ffffff)}.theme-toggle-slider{position:absolute;top:4px;bottom:4px;border-radius:99px;background-color:var(--toggle-active-bg, #3b82f6);transition:transform .2s cubic-bezier(.4,0,.2,1);z-index:1;width:calc((100% - 8px) / 3)}.theme-toggle-option:not(.active):hover{color:var(--toggle-hover-text, #111827)}[data-theme=dark] .theme-toggle-option:not(.active):hover{color:#e5e7eb}#root{height:100%;width:100%}.app-root{min-height:100vh;width:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Open Sans,Helvetica Neue,sans-serif}.app-title{font-size:2rem;font-weight:600;margin:0}.app-subtitle{margin-top:8px;color:#555;font-size:.95rem}
