*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:Noto Sans,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:#f8f9fb;color:#1a1a2e;line-height:1.5;min-height:100vh}a{color:#2463eb;text-decoration:none}a:hover{text-decoration:underline}:focus-visible{outline:2px solid hsl(221,83%,53%);outline-offset:2px}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#ccc;border-radius:3px}::-webkit-scrollbar-thumb:hover{background:#aaa}.portal-layout{display:flex;min-height:100vh}.portal-sidebar{width:260px;background:#fff;border-right:1px solid #e5e7eb;display:flex;flex-direction:column;position:fixed;top:0;left:0;bottom:0;z-index:100}.portal-sidebar-brand{display:flex;align-items:center;gap:12px;padding:20px 20px 16px;border-bottom:1px solid #e5e7eb}.portal-brand-text{display:flex;flex-direction:column}.portal-brand-name{font-weight:700;font-size:.95rem;color:#1a1a2e}.portal-brand-sub{font-size:.72rem;color:#6b7280;text-transform:uppercase;letter-spacing:.05em}.portal-nav{flex:1;padding:12px 10px;display:flex;flex-direction:column;gap:2px}.portal-nav-item{display:flex;align-items:center;gap:10px;padding:10px 14px;border-radius:8px;color:#4b5563;font-size:.875rem;font-weight:500;text-decoration:none;transition:background .15s,color .15s}.portal-nav-item:hover{background:#f3f4f6;color:#1a1a2e;text-decoration:none}.portal-nav-item.active{background:#ecf2fd;color:#2463eb}.portal-sidebar-user{display:flex;align-items:center;gap:10px;padding:16px 20px;border-top:1px solid #e5e7eb}.portal-user-avatar{width:34px;height:34px;border-radius:50%;background:#2463eb;color:#fff;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:.8rem;flex-shrink:0}.portal-user-info{display:flex;flex-direction:column;overflow:hidden}.portal-user-name{font-size:.8rem;font-weight:600;color:#1a1a2e;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.portal-user-email{font-size:.7rem;color:#9ca3af;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.portal-main{flex:1;margin-left:260px;display:flex;flex-direction:column;min-height:100vh}.portal-header{background:#fff;border-bottom:1px solid #e5e7eb;padding:20px 32px;position:sticky;top:0;z-index:50}.portal-page-title{font-size:1.25rem;font-weight:700;color:#1a1a2e}.portal-content{flex:1;padding:24px 32px 80px;overflow-y:auto}.portal-card{background:#fff;border:1px solid #e5e7eb;border-radius:12px;padding:24px}.portal-card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.portal-card-title{font-size:.95rem;font-weight:600;color:#1a1a2e}.portal-card-subtitle{font-size:.8rem;color:#6b7280}.portal-metrics-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:16px;margin-bottom:24px}.portal-metric-card{background:#fff;border:1px solid #e5e7eb;border-radius:12px;padding:20px}.portal-metric-label{font-size:.75rem;font-weight:500;color:#6b7280;text-transform:uppercase;letter-spacing:.04em;margin-bottom:6px}.portal-metric-value{font-size:1.5rem;font-weight:700;color:#1a1a2e}.portal-metric-sub{font-size:.75rem;color:#9ca3af;margin-top:4px}.portal-table-wrap{overflow-x:auto}.portal-table{width:100%;border-collapse:collapse;font-size:.85rem}.portal-table th{text-align:left;padding:10px 14px;font-weight:600;color:#6b7280;font-size:.75rem;text-transform:uppercase;letter-spacing:.04em;border-bottom:1px solid #e5e7eb;white-space:nowrap}.portal-table td{padding:12px 14px;border-bottom:1px solid #f3f4f6;color:#374151}.portal-table tr:last-child td{border-bottom:none}.portal-table tr:hover td{background:#f8f9fb}.portal-badge{display:inline-flex;align-items:center;padding:2px 10px;border-radius:9999px;font-size:.72rem;font-weight:600;text-transform:uppercase;letter-spacing:.03em}.portal-badge-blue{background:#e8eefd;color:#1450d2}.portal-badge-green{background:#ecfdf5;color:#065f46}.portal-badge-amber{background:#fffbeb;color:#92400e}.portal-badge-gray{background:#f3f4f6;color:#4b5563}.portal-badge-red{background:#fef2f2;color:#991b1b}.portal-doc-list{display:flex;flex-direction:column;gap:8px}.portal-doc-item{display:flex;align-items:center;gap:14px;padding:14px 16px;background:#fff;border:1px solid #e5e7eb;border-radius:10px;transition:border-color .15s;cursor:pointer}.portal-doc-item:hover{border-color:#81a5f3}.portal-doc-icon{width:40px;height:40px;border-radius:8px;background:#e8eefd;color:#2463eb;display:flex;align-items:center;justify-content:center;flex-shrink:0}.portal-doc-info{flex:1;min-width:0}.portal-doc-title{font-size:.875rem;font-weight:600;color:#1a1a2e;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.portal-doc-desc{font-size:.75rem;color:#6b7280;margin-top:2px}.portal-doc-date{font-size:.72rem;color:#9ca3af;white-space:nowrap}.portal-update-list{display:flex;flex-direction:column;gap:20px}.portal-update-card{background:#fff;border:1px solid #e5e7eb;border-radius:12px;overflow:hidden}.portal-update-header{padding:20px 24px 14px;border-bottom:1px solid #f3f4f6}.portal-update-title{font-size:1rem;font-weight:700;color:#1a1a2e;margin-bottom:4px}.portal-update-date{font-size:.75rem;color:#9ca3af}.portal-update-body{padding:20px 24px;font-size:.875rem;line-height:1.7;color:#374151;white-space:pre-wrap}.portal-welcome{background:linear-gradient(135deg,#2463eb,#1147bb);border-radius:12px;padding:32px;color:#fff;margin-bottom:24px}.portal-welcome h2{font-size:1.35rem;font-weight:700;margin-bottom:8px}.portal-welcome p{font-size:.9rem;opacity:.9}.portal-profile-header{display:flex;align-items:center;gap:20px;margin-bottom:32px}.portal-profile-avatar{width:64px;height:64px;border-radius:50%;background:#2463eb;color:#fff;display:flex;align-items:center;justify-content:center;font-size:1.5rem;font-weight:700;flex-shrink:0}.portal-profile-name{font-size:1.25rem;font-weight:700;color:#1a1a2e}.portal-profile-email{font-size:.85rem;color:#6b7280}.portal-field-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:20px}.portal-field{display:flex;flex-direction:column}.portal-field-label{font-size:.72rem;font-weight:600;color:#6b7280;text-transform:uppercase;letter-spacing:.04em;margin-bottom:4px}.portal-field-value{font-size:.9rem;color:#1a1a2e;font-weight:500}.portal-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100vh;gap:16px;color:#6b7280;font-size:.9rem}.portal-loading-spinner{width:36px;height:36px;border:3px solid #e5e7eb;border-top-color:#2463eb;border-radius:50%;animation:portal-spin .8s linear infinite}@keyframes portal-spin{to{transform:rotate(360deg)}}.portal-error{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100vh;gap:12px;text-align:center;padding:24px}.portal-error-icon{width:48px;height:48px;border-radius:50%;background:#fef2f2;color:#dc2626;display:flex;align-items:center;justify-content:center;font-size:1.5rem;font-weight:700}.portal-error h2{font-size:1.2rem;color:#1a1a2e}.portal-error p{font-size:.875rem;color:#6b7280;max-width:400px}.portal-error-link{margin-top:8px;padding:10px 20px;background:#2463eb;color:#fff;border-radius:8px;font-size:.85rem;font-weight:600;text-decoration:none}.portal-error-link:hover{background:#1450d2;text-decoration:none}.portal-section-loading{display:flex;align-items:center;justify-content:center;padding:48px 0;color:#9ca3af;font-size:.85rem;gap:10px}.portal-section-spinner{width:20px;height:20px;border:2px solid #e5e7eb;border-top-color:#2463eb;border-radius:50%;animation:portal-spin .8s linear infinite}.portal-empty{text-align:center;padding:48px 24px;color:#9ca3af;font-size:.875rem}.portal-mobile-nav{display:none;position:fixed;bottom:0;left:0;right:0;background:#fff;border-top:1px solid #e5e7eb;z-index:200;padding:6px 0 env(safe-area-inset-bottom,6px)}.portal-mobile-item{display:flex;flex-direction:column;align-items:center;gap:2px;padding:6px 0;color:#9ca3af;font-size:.65rem;text-decoration:none}.portal-mobile-item.active{color:#2463eb}.portal-filters{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:20px}.portal-filter-btn{padding:6px 14px;border:1px solid #e5e7eb;border-radius:9999px;background:#fff;color:#4b5563;font-size:.78rem;font-weight:500;cursor:pointer;transition:all .15s;font-family:inherit}.portal-filter-btn:hover{border-color:#81a5f3;color:#2463eb}.portal-filter-btn.active{background:#2463eb;border-color:#2463eb;color:#fff}@media (max-width: 768px){.portal-sidebar{display:none}.portal-main{margin-left:0}.portal-header{padding:16px 20px}.portal-content{padding:16px 16px 100px}.portal-mobile-nav{display:flex;justify-content:space-around}.portal-metrics-grid{grid-template-columns:repeat(2,1fr)}.portal-welcome{padding:24px 20px}.portal-welcome h2{font-size:1.1rem}.portal-profile-header{flex-direction:column;text-align:center}.portal-field-grid{grid-template-columns:1fr}}
