:root{--color-primary: #772cbb;--color-primary-dark: #5c2290;--color-primary-light: #9b4ed6;--color-bg: #f8fafc;--color-sidebar: #1e293b;--color-sidebar-hover: #334155;--color-text: #1e293b;--color-text-light: #64748b;--color-border: #e2e8f0;--color-white: #ffffff;--color-error: #dc2626;--color-success: #16a34a;--radius: 8px;--shadow: 0 1px 3px rgba(0, 0, 0, .1);--shadow-lg: 0 4px 6px rgba(0, 0, 0, .1)}*{box-sizing:border-box;margin:0;padding:0}body{font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;background:var(--color-bg);color:var(--color-text);line-height:1.5}a{color:var(--color-primary);text-decoration:none}a:hover{text-decoration:underline}button{cursor:pointer;font-family:inherit}input,select,textarea{font-family:inherit;font-size:inherit}.portal-layout{display:flex;min-height:100vh}.sidebar{width:250px;background:var(--color-sidebar);color:var(--color-white);display:flex;flex-direction:column}.sidebar-header{padding:1.5rem;border-bottom:1px solid var(--color-sidebar-hover)}.sidebar-brand{font-size:1.125rem;font-weight:600;color:var(--color-white)}.sidebar-subtitle{font-size:.75rem;color:var(--color-text-light);margin-top:.25rem}.sidebar-nav{flex:1;padding:1rem 0}.nav-link{display:flex;align-items:center;gap:.75rem;padding:.75rem 1.5rem;color:#94a3b8;text-decoration:none;transition:all .15s}.nav-link:hover{background:var(--color-sidebar-hover);color:var(--color-white);text-decoration:none}.nav-link.active{background:var(--color-primary);color:var(--color-white)}.sidebar-footer{padding:1rem 1.5rem;border-top:1px solid var(--color-sidebar-hover)}.user-info{display:flex;align-items:center;gap:.75rem;margin-bottom:.75rem}.user-avatar{width:36px;height:36px;background:var(--color-primary);border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:.875rem}.user-name{font-size:.875rem;font-weight:500}.user-email{font-size:.75rem;color:var(--color-text-light)}.logout-btn{width:100%;padding:.5rem;background:transparent;border:1px solid var(--color-sidebar-hover);color:#94a3b8;border-radius:var(--radius);font-size:.875rem;transition:all .15s}.logout-btn:hover{background:var(--color-sidebar-hover);color:var(--color-white)}.main-content{flex:1;display:flex;flex-direction:column}.top-bar{height:64px;background:var(--color-white);border-bottom:1px solid var(--color-border);display:flex;align-items:center;justify-content:space-between;padding:0 2rem}.page-title{font-size:1.25rem;font-weight:600}.content-area{flex:1;padding:2rem}.card{background:var(--color-white);border-radius:var(--radius);box-shadow:var(--shadow);padding:1.5rem}.card-header{margin-bottom:1rem}.card-title{font-size:1rem;font-weight:600}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.625rem 1.25rem;border-radius:var(--radius);font-weight:500;font-size:.875rem;transition:all .15s;border:none}.btn-primary{background:var(--color-primary);color:var(--color-white)}.btn-primary:hover{background:var(--color-primary-dark)}.btn-secondary{background:var(--color-white);color:var(--color-text);border:1px solid var(--color-border)}.btn-secondary:hover{background:var(--color-bg)}.form-group{margin-bottom:1rem}.form-label{display:block;font-size:.875rem;font-weight:500;margin-bottom:.375rem}.form-input{width:100%;padding:.625rem .875rem;border:1px solid var(--color-border);border-radius:var(--radius);font-size:.875rem;transition:border-color .15s}.form-input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #772cbb1a}.form-error{color:var(--color-error);font-size:.75rem;margin-top:.25rem}.login-container{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:1rem}.login-card{width:100%;max-width:400px;background:var(--color-white);border-radius:var(--radius);box-shadow:var(--shadow-lg);padding:2rem}.login-header{text-align:center;margin-bottom:2rem}.login-logo{font-size:1.5rem;font-weight:700;color:var(--color-primary);margin-bottom:.5rem}.login-subtitle{color:var(--color-text-light);font-size:.875rem}.loading-spinner{display:flex;align-items:center;justify-content:center;padding:2rem}.loading-spinner.full-screen{min-height:100vh}.spinner{width:40px;height:40px;border:3px solid var(--color-border);border-top-color:var(--color-primary);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;margin-bottom:2rem}.stat-card{background:var(--color-white);border-radius:var(--radius);box-shadow:var(--shadow);padding:1.25rem}.stat-label{font-size:.75rem;color:var(--color-text-light);text-transform:uppercase;letter-spacing:.05em}.stat-value{font-size:1.75rem;font-weight:700;margin-top:.25rem}.placeholder-page{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:300px;color:var(--color-text-light)}.placeholder-icon{font-size:3rem;margin-bottom:1rem}.placeholder-text{font-size:1.125rem}.not-found{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:2rem}.not-found h1{font-size:6rem;font-weight:700;color:var(--color-primary);line-height:1}.not-found p{color:var(--color-text-light);margin:1rem 0 2rem}@media (max-width: 1024px){.sidebar{width:200px}.content-area{padding:1.5rem}.stats-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width: 768px){.portal-layout{flex-direction:column}.sidebar{width:100%;position:fixed;bottom:0;left:0;right:0;top:auto;z-index:100;flex-direction:row;padding:0}.sidebar-header,.sidebar-footer{display:none}.sidebar-nav{display:flex;overflow-x:auto;padding:.5rem;gap:.25rem;scrollbar-width:none}.sidebar-nav::-webkit-scrollbar{display:none}.nav-link{padding:.5rem .75rem;flex-direction:column;gap:.25rem;font-size:.6875rem;min-width:fit-content;text-align:center}.main-content{padding-bottom:70px}.content-area{padding:1rem}.top-bar{padding:0 1rem}.stats-grid{grid-template-columns:repeat(2,1fr);gap:.75rem}.stat-card{padding:1rem}.stat-value{font-size:1.5rem}.card{overflow-x:auto}.modal-content{margin:1rem;max-height:calc(100vh - 2rem)}}@media (max-width: 480px){.stats-grid{grid-template-columns:1fr}.nav-link span:last-child{display:none}.nav-link{padding:.75rem}.page-title{font-size:1rem}.btn{padding:.5rem 1rem;font-size:.8125rem}}.table-responsive{overflow-x:auto;-webkit-overflow-scrolling:touch}@media (max-width: 768px){.hide-mobile{display:none!important}}@media (max-width: 1024px){.hide-tablet{display:none!important}}.text-center{text-align:center}.text-right{text-align:right}.text-left{text-align:left}.text-sm{font-size:.875rem}.text-xs{font-size:.75rem}.text-muted{color:var(--color-text-light)}.text-success{color:var(--color-success)}.text-error{color:var(--color-error)}.font-mono{font-family:monospace}.font-bold{font-weight:600}.mt-1{margin-top:.5rem}.mt-2{margin-top:1rem}.mb-1{margin-bottom:.5rem}.mb-2{margin-bottom:1rem}.gap-1{gap:.5rem}.gap-2{gap:1rem}.flex{display:flex}.flex-wrap{flex-wrap:wrap}.items-center{align-items:center}.justify-between{justify-content:space-between}.grid{display:grid}.grid-2{grid-template-columns:repeat(2,1fr)}.grid-3{grid-template-columns:repeat(3,1fr)}.grid-4{grid-template-columns:repeat(4,1fr)}@media (max-width: 768px){.grid-2,.grid-3,.grid-4{grid-template-columns:1fr}}.badge{display:inline-block;padding:.25rem .75rem;border-radius:9999px;font-size:.75rem;font-weight:500}.badge-success{background:#d4edda;color:#155724}.badge-warning{background:#fff3cd;color:#856404}.badge-error{background:#f8d7da;color:#721c24}.badge-info{background:#dbeafe;color:#1e40af}.badge-neutral{background:#e2e3e5;color:#383d41}
