:root{--portal-bg: #f8f9fb;--portal-sidebar-bg: #1e293b;--portal-sidebar-text: #cbd5e1;--portal-sidebar-active: #3b82f6;--portal-sidebar-hover: rgba(255,255,255,.08);--portal-sidebar-width: 260px;--portal-sidebar-collapsed: 72px;--portal-card-bg: #ffffff;--portal-text: #1e293b;--portal-text-muted: #64748b;--portal-border: #e2e8f0;--portal-radius: 12px;--portal-shadow: 0 1px 3px rgba(0,0,0,.06);--portal-transition: .2s ease;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}body{background:var(--portal-bg);color:var(--portal-text);font-size:14px;line-height:1.5;-webkit-font-smoothing:antialiased}.login-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#1e293b,#334155);padding:20px}.login-card{background:var(--portal-card-bg);border-radius:16px;padding:48px 40px;width:100%;max-width:400px;box-shadow:0 20px 60px #0000004d;text-align:center}.login-logo{font-size:48px;margin-bottom:8px}.login-title{font-size:24px;font-weight:700;color:var(--portal-text);margin-bottom:4px}.login-subtitle{font-size:14px;color:var(--portal-text-muted);margin-bottom:32px}.login-form{display:flex;flex-direction:column;gap:16px}.login-field{text-align:left}.login-field label{display:block;font-size:13px;font-weight:600;color:var(--portal-text-muted);margin-bottom:6px}.login-field input{width:100%;padding:12px 16px;border:1px solid var(--portal-border);border-radius:8px;font-size:15px;transition:border var(--portal-transition);outline:none}.login-field input:focus{border-color:var(--portal-sidebar-active);box-shadow:0 0 0 3px #3b82f626}.login-error{background:#fef2f2;color:#dc2626;padding:10px 14px;border-radius:8px;font-size:13px}.login-btn{padding:14px;background:var(--portal-sidebar-active);color:#fff;border:none;border-radius:8px;font-size:15px;font-weight:600;cursor:pointer;transition:background var(--portal-transition)}.login-btn:hover{background:#2563eb}.login-btn:disabled{opacity:.6;cursor:not-allowed}.portal-layout{display:flex;min-height:100vh}.portal-hamburger{display:none;align-items:center;justify-content:center;background:var(--portal-sidebar-bg);color:#fff;border:none;border-radius:8px;width:40px;height:40px;font-size:20px;cursor:pointer}.portal-sidebar{width:var(--portal-sidebar-width);background:var(--portal-sidebar-bg);color:var(--portal-sidebar-text);display:flex;flex-direction:column;position:fixed;top:0;left:0;bottom:0;z-index:1000;transition:width var(--portal-transition);overflow:hidden}.portal-sidebar.collapsed{width:var(--portal-sidebar-collapsed)}.sidebar-header{display:flex;align-items:center;gap:12px;padding:20px 16px;border-bottom:1px solid rgba(255,255,255,.08);cursor:pointer}.sidebar-logo{font-size:28px;flex-shrink:0}.sidebar-title{font-size:18px;font-weight:700;color:#fff;white-space:nowrap}.sidebar-nav{flex:1;padding:12px 8px;display:flex;flex-direction:column;gap:4px;overflow-y:auto}.sidebar-module{display:flex;align-items:center;gap:12px;padding:12px 14px;border:none;border-radius:10px;background:transparent;color:var(--portal-sidebar-text);font-size:14px;font-weight:500;cursor:pointer;transition:all var(--portal-transition);text-align:left;white-space:nowrap}.sidebar-module:hover{background:var(--portal-sidebar-hover);color:#fff}.sidebar-module.active{background:var(--portal-sidebar-active);color:#fff;font-weight:600}.module-icon{font-size:20px;flex-shrink:0;width:24px;text-align:center}.module-name{overflow:hidden;text-overflow:ellipsis}.sidebar-footer{padding:12px;border-top:1px solid rgba(255,255,255,.08);display:flex;flex-direction:column;gap:4px}.sidebar-user{display:flex;justify-content:space-between;align-items:center;padding:8px 10px;font-size:13px}.user-name{color:#fff;font-weight:600}.user-level{background:#ffffff1f;padding:2px 8px;border-radius:6px;font-size:11px;font-weight:700}.sidebar-action{display:flex;align-items:center;gap:8px;padding:8px 14px;border:none;border-radius:8px;background:transparent;color:var(--portal-sidebar-text);font-size:13px;cursor:pointer;transition:all var(--portal-transition);white-space:nowrap}.sidebar-action:hover{background:var(--portal-sidebar-hover);color:#fff}.sidebar-action.logout:hover{background:#ef444433;color:#f87171}.viewas-bar{position:fixed;top:0;left:0;right:0;z-index:9999;background:linear-gradient(90deg,#f59e0b,#d97706);color:#1f2937;padding:6px 16px;display:flex;align-items:center;justify-content:center;gap:12px;font-size:13px;font-weight:600;box-shadow:0 2px 8px #0003}.viewas-btn{padding:3px 12px;border-radius:6px;font-size:12px;font-weight:700;cursor:pointer;border:1px solid rgba(0,0,0,.2);background:#ffffff4d;color:#1f2937;transition:all .15s}.viewas-btn.active{background:#1f2937;color:#f59e0b}.viewas-btn.exit{background:#1f2937;color:#fbbf24}.sidebar-search-desktop{padding:8px;border-bottom:1px solid rgba(255,255,255,.06)}.portal-topbar-search-mobile{display:none}@media(max-width:768px){.sidebar-search-desktop{display:none}.portal-topbar-search-mobile{display:block}}.portal-main{flex:1;margin-left:var(--portal-sidebar-width);transition:margin-left var(--portal-transition);min-height:100vh}.portal-sidebar.collapsed~.portal-main{margin-left:var(--portal-sidebar-collapsed)}.sidebar-overlay{display:none}.portal-dashboard{padding:32px;max-width:1200px;margin:0 auto}.dashboard-header{margin-bottom:32px}.dashboard-header h1{font-size:28px;font-weight:700;color:var(--portal-text)}.dashboard-header p{font-size:15px;color:var(--portal-text-muted);margin-top:4px}.dashboard-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:20px}.dashboard-card{display:flex;align-items:center;gap:20px;padding:28px 24px;background:var(--portal-card-bg);border:1px solid var(--portal-border);border-radius:var(--portal-radius);box-shadow:var(--portal-shadow);cursor:pointer;transition:all var(--portal-transition);text-align:left;border-left:4px solid var(--card-color, var(--portal-sidebar-active))}.dashboard-card:hover{transform:translateY(-2px);box-shadow:0 8px 24px #00000014}.card-icon{font-size:36px}.card-info h3{font-size:16px;font-weight:600;color:var(--portal-text)}.card-info p{font-size:13px;color:var(--portal-text-muted);margin-top:4px}.dashboard-empty{text-align:center;padding:60px 20px;color:var(--portal-text-muted)}.portal-setup{padding:32px;max-width:900px;margin:0 auto}.portal-setup h2{font-size:24px;font-weight:700;margin-bottom:24px}.setup-section{background:var(--portal-card-bg);border:1px solid var(--portal-border);border-radius:var(--portal-radius);padding:24px}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.section-header h3{font-size:18px;font-weight:600}.btn-primary{padding:8px 16px;background:var(--portal-sidebar-active);color:#fff;border:none;border-radius:8px;font-size:13px;font-weight:600;cursor:pointer;transition:background var(--portal-transition)}.btn-primary:hover{background:#2563eb}.btn-small{padding:4px 10px;background:var(--portal-bg);border:1px solid var(--portal-border);border-radius:6px;font-size:12px;cursor:pointer;transition:all var(--portal-transition)}.btn-small:hover{background:var(--portal-border)}.btn-small.primary{background:var(--portal-sidebar-active);color:#fff;border-color:transparent}.user-form{background:var(--portal-bg);padding:20px;border-radius:10px;margin-bottom:20px;display:flex;flex-direction:column;gap:14px}.form-row label{display:block;font-size:13px;font-weight:600;color:var(--portal-text-muted);margin-bottom:6px}.form-row input,.form-row select{width:100%;padding:10px 14px;border:1px solid var(--portal-border);border-radius:8px;font-size:14px;outline:none}.form-row input:focus,.form-row select:focus{border-color:var(--portal-sidebar-active)}.module-checkboxes{display:flex;flex-wrap:wrap;gap:12px}.checkbox-label{display:flex;align-items:center;gap:6px;font-size:13px;cursor:pointer}.users-table{display:flex;flex-direction:column;gap:2px}.users-header,.users-row{display:grid;grid-template-columns:1.5fr 1fr 2fr 1fr 2fr;gap:8px;padding:10px 12px;align-items:center;font-size:13px}.users-header{font-weight:700;color:var(--portal-text-muted);border-bottom:2px solid var(--portal-border)}.users-row{border-bottom:1px solid var(--portal-border)}.users-row.disabled{opacity:.5}.user-cell-actions{display:flex;flex-wrap:wrap;gap:6px;align-items:center}.password-change{display:flex;gap:4px;margin-top:4px}.password-change input{padding:4px 8px;border:1px solid var(--portal-border);border-radius:6px;font-size:12px;width:120px}.module-wrapper{width:100%;min-height:100vh}@keyframes slideIn{0%{transform:translate(100px);opacity:0}to{transform:translate(0);opacity:1}}@media(max-width:768px){.portal-sidebar{transform:translate(-100%);width:var(--portal-sidebar-width)}.portal-sidebar.mobile-open{transform:translate(0)}.portal-sidebar.collapsed{width:var(--portal-sidebar-width)}.sidebar-overlay{display:block;position:fixed;inset:0;background:#00000080;z-index:999}.portal-main{margin-left:0!important;padding-top:56px}.portal-dashboard{padding:16px}.dashboard-header h1{font-size:22px}.users-header,.users-row{grid-template-columns:1fr;gap:4px}.users-header{display:none}}.portal-topbar{display:none}@media(min-width:769px){.portal-topbar{display:none}}@media(max-width:768px){.portal-topbar{display:flex;align-items:center;justify-content:space-between;position:fixed;top:0;left:0;right:0;z-index:1001;background:var(--portal-sidebar-bg);padding:8px 12px;height:52px}.portal-topbar .portal-hamburger{display:flex;position:static;align-items:center;justify-content:center}}.ps-trigger{display:flex;align-items:center;gap:8px;padding:8px 14px;background:#ffffff14;border:1px solid rgba(255,255,255,.12);border-radius:10px;color:var(--portal-sidebar-text);font-size:13px;cursor:pointer;transition:all var(--portal-transition);white-space:nowrap}.ps-trigger:hover{background:#ffffff24;border-color:#fff3;color:#fff}@media(min-width:769px){.ps-trigger{background:var(--portal-card-bg);border:1px solid var(--portal-border);color:var(--portal-text-muted);box-shadow:var(--portal-shadow);min-width:240px}.ps-trigger:hover{border-color:var(--portal-sidebar-active);color:var(--portal-text);background:var(--portal-card-bg)}}.ps-trigger-text{flex:1;text-align:left}@media(max-width:768px){.ps-trigger-text{display:none}.ps-trigger{padding:8px 10px;min-width:auto}}.ps-trigger-kbd{background:#0000000f;border:1px solid rgba(0,0,0,.1);border-radius:4px;padding:1px 6px;font-size:11px;font-family:inherit;color:inherit;opacity:.6}@media(max-width:768px){.ps-trigger-kbd{display:none}}.ps-overlay{position:fixed;inset:0;background:#00000080;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:10000;display:flex;align-items:flex-start;justify-content:center;padding-top:min(20vh,140px);animation:psFadeIn .15s ease}@keyframes psFadeIn{0%{opacity:0}to{opacity:1}}.ps-modal{width:100%;max-width:560px;background:var(--portal-card-bg);border-radius:16px;box-shadow:0 24px 80px #00000040;overflow:hidden;display:flex;flex-direction:column;max-height:70vh;animation:psSlideIn .15s ease}@keyframes psSlideIn{0%{transform:translateY(-12px) scale(.98);opacity:0}to{transform:translateY(0) scale(1);opacity:1}}@media(max-width:768px){.ps-modal{max-width:calc(100vw - 24px);max-height:80vh}.ps-overlay{padding-top:60px}}.ps-input-row{display:flex;align-items:center;gap:10px;padding:16px 20px;border-bottom:1px solid var(--portal-border)}.ps-input-icon{color:var(--portal-text-muted);flex-shrink:0}.ps-input{flex:1;border:none;outline:none;font-size:16px;color:var(--portal-text);background:transparent;font-family:inherit}.ps-input::placeholder{color:var(--portal-text-muted);opacity:.7}.ps-esc-badge{background:var(--portal-bg);border:1px solid var(--portal-border);border-radius:4px;padding:2px 8px;font-size:11px;color:var(--portal-text-muted);font-family:inherit}.ps-results{flex:1;overflow-y:auto;padding:8px}.ps-section-label{font-size:11px;font-weight:700;color:var(--portal-text-muted);text-transform:uppercase;letter-spacing:.5px;padding:8px 12px 4px}.ps-no-results{padding:32px 20px;text-align:center;color:var(--portal-text-muted);font-size:14px}.ps-no-results.ps-hint{opacity:.6}.ps-result{display:flex;align-items:center;gap:12px;width:100%;padding:10px 14px;border:none;border-radius:10px;background:transparent;color:var(--portal-text);font-size:14px;cursor:pointer;text-align:left;transition:background .1s ease}.ps-result:hover,.ps-result.selected{background:var(--portal-bg)}.ps-result.selected{background:#eff6ff}.ps-result-icon{font-size:20px;width:28px;text-align:center;flex-shrink:0}.ps-result-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:1px}.ps-result-name{font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.ps-result-meta{font-size:12px;color:var(--portal-text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.ps-recent-badge{font-size:10px;background:#3b82f61a;color:var(--portal-sidebar-active);padding:2px 8px;border-radius:6px;font-weight:600}.ps-enter-hint{font-size:16px;color:var(--portal-text-muted);opacity:.5}.ps-footer{display:flex;align-items:center;gap:16px;padding:10px 20px;border-top:1px solid var(--portal-border);font-size:12px;color:var(--portal-text-muted)}.ps-footer kbd{display:inline-block;background:var(--portal-bg);border:1px solid var(--portal-border);border-radius:4px;padding:1px 5px;font-size:11px;font-family:inherit;margin-right:2px}.portal-main .app-shell{display:flex;min-height:100vh;position:relative}.portal-main .sidebar{position:sticky!important;top:0!important;left:auto!important;height:100vh;z-index:50;flex-shrink:0}.portal-main .main-content{margin-left:0!important;max-width:100%!important;flex:1;min-width:0}.portal-main .module-wrapper{width:100%;min-height:100vh;position:relative}.portal-main .sidebar.collapsed-desktop~.main-content{margin-left:0!important}.portal-main .mobile-hamburger,.portal-main .hamburger-btn{display:none!important}@media(max-width:768px){.portal-main .sidebar{display:none!important}.portal-main .sidebar.expanded{display:flex!important;position:fixed!important;top:0!important;left:0!important;bottom:0!important;z-index:200!important}.portal-main .mobile-hamburger,.portal-main .hamburger-btn{display:flex!important}.portal-main .main-content{padding-top:0!important}}
