*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--brand-50: #eff6ff;--brand-100: #dbeafe;--brand-200: #bfdbfe;--brand-300: #93c5fd;--brand-500: #3b82f6;--brand-600: #2563eb;--brand-700: #1d4ed8;--brand-800: #1e40af;--brand-900: #1e3a8a;--sidebar-bg: #0f172a;--sidebar-hover: #1e293b;--sidebar-active: #1e40af;--sidebar-text: #94a3b8;--sidebar-heading: #475569;--sidebar-width: 260px;--sidebar-collapsed: 64px;--topbar-height: 56px;--gray-50: #f8fafc;--gray-100: #f1f5f9;--gray-200: #e2e8f0;--gray-300: #cbd5e1;--gray-400: #94a3b8;--gray-500: #64748b;--gray-600: #475569;--gray-700: #334155;--gray-800: #1e293b;--gray-900: #0f172a;--color-success: #16a34a;--color-success-bg: #dcfce7;--color-success-border:#bbf7d0;--color-warning: #d97706;--color-warning-bg: #fef3c7;--color-warning-border:#fde68a;--color-danger: #dc2626;--color-danger-bg: #fee2e2;--color-danger-border: #fca5a5;--color-info: #0891b2;--color-info-bg: #e0f2fe;--color-info-border: #bae6fd;--color-primary: #2563eb;--color-primary-dark: #1d4ed8;--color-gray-50: #f8fafc;--color-gray-100: #f1f5f9;--color-gray-200: #e2e8f0;--color-gray-700: #334155;--color-gray-900: #0f172a;--shadow-xs: 0 1px 2px rgba(0,0,0,.05);--shadow-sm: 0 1px 3px rgba(0,0,0,.1), 0 1px 2px rgba(0,0,0,.06);--shadow-md: 0 4px 6px -1px rgba(0,0,0,.1), 0 2px 4px -1px rgba(0,0,0,.06);--shadow-lg: 0 10px 15px -3px rgba(0,0,0,.1), 0 4px 6px -2px rgba(0,0,0,.05);--shadow-xl: 0 20px 25px -5px rgba(0,0,0,.1), 0 10px 10px -5px rgba(0,0,0,.04);--radius-sm: 4px;--radius-md: 8px;--radius-lg: 12px;--radius-xl: 16px;--radius-full:9999px;font-family:Inter,Segoe UI,system-ui,-apple-system,sans-serif;font-size:14px;line-height:1.5;-webkit-font-smoothing:antialiased}html,body,#root{height:100%;background:var(--gray-50);color:var(--gray-900);overflow-x:hidden}body{min-width:320px;min-height:100svh;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{color:inherit;text-decoration:none}button{font-family:inherit}.app-shell{display:flex;height:100vh;overflow:hidden}.sidebar{width:var(--sidebar-width);min-width:var(--sidebar-width);background:var(--sidebar-bg);display:flex;flex-direction:column;height:100vh;overflow:hidden;transition:width .25s ease,min-width .25s ease;z-index:50;flex-shrink:0}.sidebar.collapsed{width:var(--sidebar-collapsed);min-width:var(--sidebar-collapsed)}.sidebar-brand{display:flex;align-items:center;gap:10px;padding:0 16px;height:var(--topbar-height);border-bottom:1px solid rgba(255,255,255,.06);flex-shrink:0;overflow:hidden}.sidebar-brand-icon{width:32px;height:32px;background:var(--brand-600);border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;font-size:16px;flex-shrink:0;box-shadow:0 2px 8px #2563eb66}.sidebar-brand-text{display:flex;flex-direction:column;overflow:hidden}.sidebar-brand-name{font-size:14px;font-weight:700;color:#fff;white-space:nowrap;letter-spacing:-.01em}.sidebar-brand-tagline{font-size:10px;color:var(--sidebar-text);white-space:nowrap;letter-spacing:.06em;text-transform:uppercase}.sidebar.collapsed .sidebar-brand-text{display:none}.sidebar-nav{flex:1;overflow-y:auto;overflow-x:hidden;padding:12px 0;scrollbar-width:thin;scrollbar-color:rgba(255,255,255,.1) transparent}.sidebar-nav::-webkit-scrollbar{width:4px}.sidebar-nav::-webkit-scrollbar-thumb{background:#ffffff1a;border-radius:2px}.sidebar-section-title{font-size:10px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--sidebar-heading);padding:16px 20px 6px;white-space:nowrap;overflow:hidden}.sidebar.collapsed .sidebar-section-title{opacity:0}.sidebar-item{display:flex;align-items:center;gap:10px;padding:9px 16px;margin:1px 8px;border-radius:var(--radius-md);cursor:pointer;transition:background .15s,color .15s;color:var(--sidebar-text);font-size:13px;font-weight:400;white-space:nowrap;overflow:hidden;border:none;background:none;width:calc(100% - 16px);text-align:left;text-decoration:none}.sidebar-item:hover{background:var(--sidebar-hover);color:#fff}.sidebar-item.active{background:var(--sidebar-active);color:#fff;font-weight:500}.sidebar-item-icon{width:20px;height:20px;display:flex;align-items:center;justify-content:center;flex-shrink:0;opacity:.7}.sidebar-item.active .sidebar-item-icon{opacity:1}.sidebar-item-label{flex:1;overflow:hidden;text-overflow:ellipsis}.sidebar-item-tag{font-size:9px;background:#ffffff1f;color:#94a3b8;padding:1px 5px;border-radius:3px;text-transform:uppercase;letter-spacing:.04em;flex-shrink:0}.sidebar-item-badge{background:var(--brand-600);color:#fff;font-size:10px;font-weight:700;padding:1px 6px;border-radius:var(--radius-full);flex-shrink:0}.sidebar.collapsed .sidebar-item-label,.sidebar.collapsed .sidebar-item-badge,.sidebar.collapsed .sidebar-item-tag{opacity:0;pointer-events:none}.sidebar-group-header{display:flex;align-items:center;gap:10px;padding:9px 16px;margin:1px 8px;border-radius:var(--radius-md);cursor:pointer;transition:background .15s,color .15s;color:var(--sidebar-text);font-size:13px;font-weight:500;white-space:nowrap;overflow:hidden;border:none;background:none;width:calc(100% - 16px);text-align:left}.sidebar-group-header:hover{background:var(--sidebar-hover);color:#fff}.sidebar-group-header.open{color:#fff}.sidebar-group-caret{margin-left:auto;opacity:.5;transition:transform .2s;flex-shrink:0;display:flex;align-items:center}.sidebar-group-header.open .sidebar-group-caret{transform:rotate(180deg)}.sidebar-group-children{overflow:hidden;max-height:0;transition:max-height .25s ease}.sidebar-group-children.open{max-height:500px}.sidebar-group-children .sidebar-item{padding-left:44px;font-size:12.5px}.sidebar-nav>div+div{margin-top:2px}.sidebar-footer{border-top:1px solid rgba(255,255,255,.06);padding:12px;flex-shrink:0}.sidebar-user{display:flex;align-items:center;gap:10px;padding:8px;border-radius:var(--radius-md);cursor:pointer;transition:background .15s;overflow:hidden}.sidebar-user:hover{background:var(--sidebar-hover)}.sidebar-avatar{width:32px;height:32px;border-radius:var(--radius-full);background:var(--brand-600);color:#fff;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;flex-shrink:0}.sidebar-user-info{overflow:hidden;flex:1}.sidebar-user-name{font-size:12px;font-weight:600;color:#fff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar-user-role{font-size:10px;color:var(--sidebar-text);white-space:nowrap;text-transform:capitalize}.sidebar.collapsed .sidebar-user-info{display:none}.main-area{flex:1;display:flex;flex-direction:column;overflow:hidden;min-width:0}.topbar{height:var(--topbar-height);background:#fff;border-bottom:1px solid var(--gray-200);display:flex;align-items:center;padding:0 24px;gap:16px;flex-shrink:0;box-shadow:var(--shadow-xs);z-index:40}.topbar-toggle{background:none;border:none;cursor:pointer;padding:6px;border-radius:var(--radius-md);color:var(--gray-500);font-size:18px;display:flex;align-items:center;justify-content:center;transition:background .15s,color .15s}.topbar-toggle:hover{background:var(--gray-100);color:var(--gray-700)}.breadcrumb{display:flex;align-items:center;gap:6px;font-size:13px;color:var(--gray-500);flex:1;min-width:0}.breadcrumb-sep{color:var(--gray-300)}.breadcrumb-item{color:var(--gray-500);white-space:nowrap}.breadcrumb-item:last-child{color:var(--gray-800);font-weight:500}.breadcrumb-item a{color:var(--brand-600)}.breadcrumb-item a:hover{text-decoration:underline}.topbar-right{display:flex;align-items:center;gap:8px;margin-left:auto}.topbar-user-chip{display:flex;align-items:center;gap:8px;padding:4px 12px 4px 4px;border-radius:var(--radius-full);border:1px solid var(--gray-200);cursor:pointer;transition:background .15s;background:#fff}.topbar-user-chip:hover{background:var(--gray-50)}.topbar-avatar{width:28px;height:28px;border-radius:var(--radius-full);background:var(--brand-600);color:#fff;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;flex-shrink:0}.topbar-user-name{font-size:13px;font-weight:500;color:var(--gray-700)}.topbar-role-badge{font-size:10px;background:var(--brand-50);color:var(--brand-700);padding:1px 6px;border-radius:var(--radius-full);font-weight:600;text-transform:capitalize}.btn-logout{background:none;border:1px solid var(--gray-300);color:var(--gray-600);padding:5px 12px;border-radius:var(--radius-md);cursor:pointer;font-size:12px;font-weight:500;font-family:inherit;transition:all .15s}.btn-logout:hover{background:var(--color-danger-bg);border-color:var(--color-danger-border);color:var(--color-danger)}.page-content{flex:1;overflow-y:auto;padding:28px 32px;background:var(--gray-50)}.page-header{margin-bottom:24px}.page-header-inner{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;flex-wrap:wrap}.page-title{font-size:22px;font-weight:700;color:var(--gray-900);letter-spacing:-.02em;line-height:1.2}.page-subtitle{font-size:13px;color:var(--gray-500);margin-top:4px}.page-actions{display:flex;gap:8px;align-items:center;flex-wrap:wrap}.page-module-tag{display:inline-flex;align-items:center;gap:5px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--brand-700);background:var(--brand-50);border:1px solid var(--brand-200);padding:3px 10px;border-radius:var(--radius-full);margin-bottom:8px}.card{background:#fff;border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);border:1px solid var(--gray-200);overflow:hidden}.card-header{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;border-bottom:1px solid var(--gray-100);background:var(--gray-50)}.card-title{font-size:14px;font-weight:600;color:var(--gray-800)}.card-subtitle{font-size:12px;color:var(--gray-500);margin-top:2px}.card-body{padding:20px}.card-footer{padding:12px 20px;border-top:1px solid var(--gray-100);background:var(--gray-50);display:flex;align-items:center;justify-content:flex-end;gap:8px}.stats-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:16px;margin-bottom:24px}.stat-card{background:#fff;border-radius:var(--radius-lg);padding:20px;box-shadow:var(--shadow-sm);border:1px solid var(--gray-200);border-top:3px solid var(--brand-600);transition:box-shadow .2s,transform .2s;text-decoration:none;display:block;cursor:pointer}.stat-card:hover{box-shadow:var(--shadow-md);transform:translateY(-1px)}.stat-card-icon{width:40px;height:40px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;font-size:18px;margin-bottom:12px}.stat-number{font-size:28px;font-weight:800;color:var(--gray-900);line-height:1;margin-bottom:4px;letter-spacing:-.03em}.stat-label{font-size:11px;color:var(--gray-500);font-weight:600;text-transform:uppercase;letter-spacing:.05em}.stat-trend{display:inline-flex;align-items:center;gap:3px;font-size:11px;font-weight:600;margin-top:6px;padding:2px 6px;border-radius:var(--radius-full)}.stat-trend.up{color:var(--color-success);background:var(--color-success-bg)}.stat-trend.down{color:var(--color-danger);background:var(--color-danger-bg)}.module-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:16px;margin-bottom:28px}.module-card{background:#fff;border:1px solid var(--gray-200);border-radius:var(--radius-lg);padding:20px;cursor:pointer;transition:all .2s;text-decoration:none;display:block;box-shadow:var(--shadow-xs)}.module-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px);border-color:var(--brand-200)}.module-card-icon{width:44px;height:44px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;font-size:20px;margin-bottom:12px}.module-card-title{font-size:14px;font-weight:700;color:var(--gray-800);margin-bottom:4px}.module-card-desc{font-size:12px;color:var(--gray-500);line-height:1.4}.module-card-count{font-size:20px;font-weight:800;color:var(--gray-900);margin-top:12px}.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:7px 14px;border-radius:var(--radius-md);border:1px solid transparent;cursor:pointer;font-size:13px;font-weight:500;font-family:inherit;line-height:1.4;transition:all .15s;white-space:nowrap;text-decoration:none}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--brand-600);color:#fff;border-color:var(--brand-600);box-shadow:0 1px 2px #2563eb33}.btn-primary:hover:not(:disabled){background:var(--brand-700);border-color:var(--brand-700)}.btn-secondary{background:#fff;color:var(--gray-700);border-color:var(--gray-300);box-shadow:var(--shadow-xs)}.btn-secondary:hover:not(:disabled){background:var(--gray-50);border-color:var(--gray-400)}.btn-danger{background:var(--color-danger);color:#fff;border-color:var(--color-danger)}.btn-danger:hover:not(:disabled){background:#b91c1c}.btn-ghost{background:transparent;color:var(--gray-600);border-color:transparent}.btn-ghost:hover:not(:disabled){background:var(--gray-100);color:var(--gray-800)}.btn-success{background:var(--color-success);color:#fff;border-color:var(--color-success)}.btn-sm{padding:5px 10px;font-size:12px}.btn-lg{padding:10px 20px;font-size:15px}.btn-icon{padding:7px}.badge{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;border-radius:var(--radius-full);font-size:11px;font-weight:600;letter-spacing:.02em}.badge-success{background:var(--color-success-bg);color:var(--color-success);border:1px solid var(--color-success-border)}.badge-warning{background:var(--color-warning-bg);color:var(--color-warning);border:1px solid var(--color-warning-border)}.badge-danger{background:var(--color-danger-bg);color:var(--color-danger);border:1px solid var(--color-danger-border)}.badge-info{background:var(--color-info-bg);color:var(--color-info);border:1px solid var(--color-info-border)}.badge-gray{background:var(--gray-100);color:var(--gray-600);border:1px solid var(--gray-200)}.badge-brand{background:var(--brand-50);color:var(--brand-700);border:1px solid var(--brand-200)}.badge:before{content:none}.badge-dot:before{content:"";display:inline-block;width:6px;height:6px;border-radius:var(--radius-full);background:currentColor;flex-shrink:0}.table-container,.table-wrapper{overflow-x:auto}table{width:100%;border-collapse:collapse;font-size:13px}thead tr{background:var(--gray-50);border-bottom:2px solid var(--gray-200)}th{padding:11px 14px;text-align:left;font-weight:600;font-size:11px;text-transform:uppercase;letter-spacing:.05em;color:var(--gray-500);white-space:nowrap}td{padding:12px 14px;border-bottom:1px solid var(--gray-100);color:var(--gray-700);vertical-align:middle}tbody tr:hover td{background:var(--gray-50)}tbody tr:last-child td{border-bottom:none}.row-actions{display:flex;gap:4px;align-items:center}.form-grid{display:grid;gap:16px;grid-template-columns:repeat(auto-fill,minmax(220px,1fr))}.form-group{display:flex;flex-direction:column;gap:5px}.form-group label{font-size:12px;font-weight:600;color:var(--gray-600)}.form-group input:not([type=checkbox]),.form-group select,.form-group textarea,.form-control{width:100%;padding:8px 11px;border:1px solid var(--gray-300);border-radius:var(--radius-md);font-size:13px;font-family:inherit;color:var(--gray-800);background:#fff;outline:none;transition:border-color .15s,box-shadow .15s}.form-group input:focus:not([type=checkbox]),.form-group select:focus,.form-group textarea:focus,.form-control:focus{border-color:var(--brand-500);box-shadow:0 0 0 3px #3b82f626}.form-group input:disabled,.form-group select:disabled,.form-control:disabled{background:var(--gray-50);color:var(--gray-500);cursor:not-allowed}.form-group input::placeholder,.form-control::placeholder{color:var(--gray-400)}.form-section,.section-label{font-size:11px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--gray-500);padding-bottom:10px;border-bottom:1px solid var(--gray-200);margin-bottom:16px;margin-top:8px}.form-actions{display:flex;gap:8px;padding-top:16px;border-top:1px solid var(--gray-100);margin-top:20px;justify-content:flex-end}.form-row{display:flex;gap:12px;flex-wrap:wrap}.form-row .form-group{flex:1;min-width:150px}.checkbox-group{display:flex;align-items:center;gap:8px;cursor:pointer}.checkbox-group input[type=checkbox]{width:15px;height:15px;accent-color:var(--brand-600);cursor:pointer}.filter-bar{display:flex;gap:10px;align-items:center;flex-wrap:wrap;padding:14px 20px;background:#fff;border-bottom:1px solid var(--gray-100)}.search-input-wrap{position:relative}.search-input-wrap .search-icon{position:absolute;left:10px;top:50%;transform:translateY(-50%);color:var(--gray-400);pointer-events:none}.search-input-wrap .form-control{padding-left:32px}.tabs{display:flex;border-bottom:2px solid var(--gray-200);margin-bottom:20px;gap:2px;overflow-x:auto}.tab-btn{padding:9px 16px;border:none;background:none;cursor:pointer;font-size:13px;font-weight:500;color:var(--gray-500);border-bottom:2px solid transparent;margin-bottom:-2px;transition:color .15s,border-color .15s;white-space:nowrap;font-family:inherit;display:flex;align-items:center;gap:6px}.tab-btn:hover{color:var(--gray-800)}.tab-btn--active{color:var(--brand-600);border-bottom-color:var(--brand-600);font-weight:600}.modal-overlay,.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a80;display:flex;align-items:center;justify-content:center;z-index:200;padding:20px;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.modal-backdrop{align-items:flex-start;padding-top:40px;overflow-y:auto}.modal{background:#fff;border-radius:var(--radius-xl);width:100%;max-width:640px;max-height:90vh;overflow-y:auto;box-shadow:var(--shadow-xl)}.modal-box{background:#fff;border-radius:var(--radius-xl);width:100%;box-shadow:var(--shadow-xl);overflow:hidden}.modal-lg{max-width:860px}.modal-sm{max-width:440px}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;border-bottom:1px solid var(--gray-100)}.modal-title{font-size:16px;font-weight:700;color:var(--gray-900)}.modal-close{background:none;border:none;cursor:pointer;color:var(--gray-400);font-size:18px;line-height:1;padding:4px;border-radius:var(--radius-md);transition:background .15s}.modal-close:hover{background:var(--gray-100);color:var(--gray-700)}.modal-body{padding:24px}.modal-footer{padding:16px 24px;border-top:1px solid var(--gray-100);display:flex;gap:8px;justify-content:flex-end;background:var(--gray-50)}.alert{padding:10px 14px;border-radius:var(--radius-md);margin-bottom:12px;font-size:13px;display:flex;align-items:flex-start;gap:8px;border:1px solid transparent}.alert-error,.alert-danger{background:var(--color-danger-bg);color:#7f1d1d;border-color:var(--color-danger-border)}.alert-success{background:var(--color-success-bg);color:#14532d;border-color:var(--color-success-border)}.alert-warning{background:var(--color-warning-bg);color:#713f12;border-color:var(--color-warning-border)}.alert-info{background:var(--color-info-bg);color:#0c4a6e;border-color:var(--color-info-border)}.toast-stack{position:fixed;bottom:24px;right:24px;z-index:500;display:flex;flex-direction:column-reverse;gap:8px;max-width:360px}.toast{display:flex;align-items:center;gap:10px;padding:12px 16px;border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);font-size:13px;font-weight:500;animation:slideInUp .25s ease;border:1px solid transparent;background:#fff}.toast-success{border-color:var(--color-success-border);color:#14532d}.toast-error{border-color:var(--color-danger-border);color:#7f1d1d}.toast-icon{font-size:16px;flex-shrink:0}@keyframes slideInUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.skeleton{background:linear-gradient(90deg,var(--gray-100) 25%,var(--gray-200) 50%,var(--gray-100) 75%);background-size:200% 100%;animation:shimmer 1.4s infinite;border-radius:var(--radius-md)}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;text-align:center}.empty-state-icon{font-size:48px;margin-bottom:16px;opacity:.4}.empty-state-title{font-size:16px;font-weight:600;color:var(--gray-700);margin-bottom:6px}.empty-state-desc{font-size:13px;color:var(--gray-500);max-width:320px}.empty{text-align:center;padding:48px;color:var(--gray-500)}.spinner{display:flex;justify-content:center;padding:48px}.spinner:after{content:"";width:36px;height:36px;border:3px solid var(--gray-200);border-top-color:var(--brand-600);border-radius:50%;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.auth-page{min-height:100vh;display:flex}.auth-left{flex:1;flex-direction:column;align-items:center;justify-content:center;padding:48px;background:linear-gradient(135deg,var(--brand-800) 0%,var(--gray-900) 100%);display:none}@media(min-width:1024px){.auth-left{display:flex}}.auth-right{width:100%;max-width:480px;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px 32px;background:#fff;min-height:100vh}.auth-card{width:100%;max-width:380px}.auth-logo-wrap{display:flex;align-items:center;gap:12px;margin-bottom:32px;justify-content:center}.auth-logo{width:44px;height:44px;background:var(--brand-600);border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;font-size:22px;box-shadow:0 4px 12px #2563eb4d}.auth-app-name{font-size:24px;font-weight:800;color:var(--gray-900);letter-spacing:-.03em}.auth-tagline{font-size:11px;color:var(--gray-400);letter-spacing:.06em;text-transform:uppercase}.auth-title{font-size:20px;font-weight:700;color:var(--gray-900);margin-bottom:4px}.auth-sub{font-size:13px;color:var(--gray-500);margin-bottom:28px}.auth-footer{margin-top:24px;text-align:center;font-size:13px;color:var(--gray-500)}.auth-footer a{color:var(--brand-600);font-weight:500}.auth-footer a:hover{text-decoration:underline}.profile-hero{background:linear-gradient(135deg,var(--brand-800) 0%,var(--brand-600) 100%);border-radius:var(--radius-lg);padding:28px 32px;margin-bottom:24px;color:#fff;display:flex;align-items:center;gap:24px;flex-wrap:wrap}.profile-hero-avatar{width:72px;height:72px;border-radius:var(--radius-full);background:#fff3;border:3px solid rgba(255,255,255,.4);display:flex;align-items:center;justify-content:center;font-size:28px;font-weight:700;flex-shrink:0}.profile-hero-info{flex:1;min-width:0}.profile-hero-name{font-size:22px;font-weight:800;letter-spacing:-.02em}.profile-hero-meta{display:flex;gap:16px;flex-wrap:wrap;margin-top:8px;font-size:13px;opacity:.85}.profile-hero-meta span{display:flex;align-items:center;gap:5px}.profile-hero-actions{display:flex;gap:8px;flex-wrap:wrap}.profile-hero-actions .btn{background:#ffffff26;border-color:#ffffff4d;color:#fff}.profile-hero-actions .btn:hover{background:#ffffff40}.detail-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:0}.detail-item{padding:12px 16px;border-bottom:1px solid var(--gray-100)}.detail-item:nth-child(2n){background:var(--gray-50)}.detail-label{font-size:11px;text-transform:uppercase;letter-spacing:.06em;color:var(--gray-400);font-weight:600;margin-bottom:3px}.detail-value{font-size:13px;color:var(--gray-800);font-weight:500}.profile-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:1.5rem;flex-wrap:wrap;gap:1rem}.profile-title{font-size:1.5rem;font-weight:700}.profile-meta{font-size:.875rem;color:var(--gray-600);margin-top:.25rem;display:flex;gap:1rem;flex-wrap:wrap}.pagination{display:flex;align-items:center;justify-content:space-between;padding:12px 20px;border-top:1px solid var(--gray-100);font-size:12px;color:var(--gray-500)}.pagination-pages{display:flex;gap:4px}.page-btn{min-width:32px;height:32px;padding:0 8px;border:1px solid var(--gray-200);border-radius:var(--radius-md);background:#fff;cursor:pointer;font-size:13px;color:var(--gray-600);display:flex;align-items:center;justify-content:center;transition:all .15s;font-family:inherit}.page-btn:hover{background:var(--gray-50);border-color:var(--gray-300)}.page-btn.active{background:var(--brand-600);border-color:var(--brand-600);color:#fff;font-weight:600}.page-btn:disabled{opacity:.4;cursor:not-allowed}.code-chip{display:inline-block;background:var(--gray-100);color:var(--gray-700);font-family:Menlo,Consolas,monospace;font-size:11px;padding:2px 7px;border-radius:var(--radius-sm);border:1px solid var(--gray-200);font-weight:600}.divider{height:1px;background:var(--gray-100);margin:20px 0}.info-block{background:var(--brand-50);border:1px solid var(--brand-200);border-radius:var(--radius-md);padding:10px 14px;font-size:13px;color:var(--brand-800);display:flex;align-items:flex-start;gap:8px}.dashboard-page{display:flex;flex-direction:column;gap:24px}.dash-welcome{background:#fff;border:1px solid var(--gray-200);border-radius:var(--radius-lg);padding:28px 32px;box-shadow:var(--shadow-sm);border-left:4px solid var(--brand-600)}.dash-welcome-date{font-size:12px;color:var(--gray-400);font-weight:500;letter-spacing:.03em;margin-bottom:6px;text-transform:uppercase}.dash-welcome-heading{font-size:22px;font-weight:800;color:var(--gray-900);letter-spacing:-.025em;margin-bottom:4px}.dash-welcome-sub{font-size:13px;color:var(--gray-500)}.dash-block{display:flex;flex-direction:column;gap:14px}.dash-block-header{display:flex;align-items:center;justify-content:space-between}.dash-block-title{font-size:13px;font-weight:700;color:var(--gray-700);text-transform:uppercase;letter-spacing:.06em}.dash-block-link{font-size:12px;color:var(--brand-600);font-weight:500}.dash-block-link:hover{text-decoration:underline}.kpi-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:12px}.kpi-card{background:#fff;border:1px solid var(--gray-200);border-radius:var(--radius-lg);padding:20px 18px;text-decoration:none;display:block;transition:box-shadow .2s,transform .2s;box-shadow:var(--shadow-xs)}.kpi-card:hover{box-shadow:var(--shadow-md);transform:translateY(-1px);border-color:var(--gray-300)}.kpi-value{font-size:30px;font-weight:800;letter-spacing:-.04em;line-height:1;margin-bottom:6px}.kpi-label{font-size:11px;font-weight:600;color:var(--gray-500);text-transform:uppercase;letter-spacing:.05em}.dash-two-col{display:grid;grid-template-columns:1fr 1fr;gap:16px}.dash-nav-list{padding:0}.dash-nav-row{display:flex;align-items:center;justify-content:space-between;padding:11px 0;border-bottom:1px solid var(--gray-100);font-size:13px;font-weight:500;color:var(--gray-700);text-decoration:none;transition:color .15s}.dash-nav-row:last-child{border-bottom:none}.dash-nav-row:hover{color:var(--brand-600)}.dash-nav-arrow{color:var(--gray-400);font-size:18px;line-height:1}.dash-nav-row:hover .dash-nav-arrow{color:var(--brand-500)}.sys-info-row{display:flex;justify-content:space-between;align-items:center;padding:9px 0;border-bottom:1px solid var(--gray-100);font-size:13px}.sys-info-row:last-child{border-bottom:none}.sys-info-label{color:var(--gray-500);font-weight:500}.sys-info-value{color:var(--gray-800);font-weight:500;text-align:right}.sidebar-backdrop{display:none}@media(max-width:768px){.sidebar{position:fixed;top:0;left:0;height:100%;width:var(--sidebar-width)!important;min-width:var(--sidebar-width)!important;transform:translate(-100%);transition:transform .25s ease;z-index:200}.sidebar:not(.collapsed){transform:translate(0);box-shadow:8px 0 32px #00000073}.sidebar-backdrop{display:block;position:fixed;top:0;right:0;bottom:0;left:0;background:#00000073;z-index:150;cursor:pointer}.main-area{width:100%}.topbar-user-name,.topbar-role-badge{display:none}.page-content{padding:16px}.stats-grid{grid-template-columns:1fr 1fr}.profile-hero{padding:20px}.kpi-grid{grid-template-columns:1fr 1fr}.dash-two-col{grid-template-columns:1fr}.dash-welcome{padding:20px}}.layout{display:contents}.navbar,.nav-group-btn,.nav-dropdown,.nav-dropdown-item,.nav-direct-link{display:none}.bug-fab{position:fixed;bottom:28px;right:28px;z-index:300;display:flex;align-items:center;gap:7px;padding:10px 16px;background:var(--gray-800);color:#fff;border:none;border-radius:var(--radius-full);cursor:pointer;font-size:13px;font-weight:600;font-family:inherit;box-shadow:0 4px 16px #0f172a59;transition:background .18s,box-shadow .18s,transform .15s;white-space:nowrap}.bug-fab:hover{background:var(--brand-700);box-shadow:0 6px 22px #2563eb73;transform:translateY(-2px)}.bug-fab:active{transform:translateY(0)}.bug-fab-label{line-height:1}.bug-modal{max-width:480px}.bug-type-grid{display:flex;flex-direction:column;gap:6px}.bug-type-btn{display:flex;align-items:center;gap:8px;padding:9px 14px;border:1.5px solid var(--gray-200);border-radius:var(--radius-md);background:#fff;cursor:pointer;font-size:13px;font-weight:500;font-family:inherit;color:var(--gray-700);transition:all .15s;text-align:left}.bug-type-btn:hover{border-color:var(--gray-400);background:var(--gray-50)}.bug-type-btn.selected{font-weight:600}.bug-priority-row{display:flex;gap:8px}.bug-priority-btn{flex:1;padding:7px 10px;border:1.5px solid var(--gray-200);border-radius:var(--radius-md);background:#fff;cursor:pointer;font-size:12px;font-weight:500;font-family:inherit;color:var(--gray-700);transition:all .15s;text-align:center}.bug-priority-btn:hover{border-color:var(--gray-400);background:var(--gray-50)}.bug-priority-btn.selected{background:var(--gray-800);border-color:var(--gray-800);color:#fff;font-weight:600}.bug-success{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:24px 16px;text-align:center}.bug-success-icon{margin-bottom:14px}.bug-success-title{font-size:18px;font-weight:700;color:var(--gray-900);margin-bottom:6px}.bug-success-sub{font-size:13px;color:var(--gray-500);max-width:280px;line-height:1.5}@media print{.sidebar,.topbar,.no-print{display:none!important}.main-area{margin:0!important;padding:0!important}.page-content,.page-container{padding:0!important}.card{box-shadow:none!important;border:1px solid #d1d5db!important}.print-only{display:block!important}.data-table{font-size:11px!important}.data-table th,.data-table td{padding:5px 8px!important}body{background:#fff!important;color:#000!important}.card{page-break-inside:avoid}}@media screen{.print-only{display:none}}.portal-shell{display:flex;flex-direction:column;min-height:100vh;background:var(--gray-50)}.portal-topnav{background:var(--sidebar-bg);border-bottom:1px solid rgba(255,255,255,.06);flex-shrink:0;z-index:50;position:sticky;top:0}.portal-topnav-inner{max-width:1200px;margin:0 auto;padding:0 24px;height:60px;display:flex;align-items:center;gap:24px}.portal-brand{display:flex;align-items:center;gap:10px;flex-shrink:0;text-decoration:none}.portal-brand-icon{width:34px;height:34px;background:var(--brand-600);border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;box-shadow:0 2px 8px #2563eb66;flex-shrink:0}.portal-brand-icon span{font-size:11px;font-weight:800;color:#fff;letter-spacing:-.02em}.portal-brand-text{display:flex;flex-direction:column}.portal-brand-name{font-size:15px;font-weight:700;color:#fff;letter-spacing:-.01em;line-height:1.2}.portal-brand-sub{font-size:10px;color:var(--sidebar-text);text-transform:uppercase;letter-spacing:.06em}.portal-nav{display:flex;align-items:center;gap:2px;flex:1}.portal-nav-link{padding:6px 14px;border-radius:var(--radius-md);font-size:13px;font-weight:500;color:var(--sidebar-text);text-decoration:none;transition:background .15s,color .15s;white-space:nowrap}.portal-nav-link:hover{background:var(--sidebar-hover);color:#fff}.portal-nav-link.active{background:var(--brand-600);color:#fff}.portal-topnav-right{display:flex;align-items:center;gap:12px;flex-shrink:0}.portal-user-chip{display:flex;align-items:center;gap:8px}.portal-avatar{width:30px;height:30px;border-radius:var(--radius-full);background:var(--brand-600);color:#fff;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;flex-shrink:0}.portal-user-name{font-size:13px;font-weight:500;color:#fff;white-space:nowrap;max-width:160px;overflow:hidden;text-overflow:ellipsis}.portal-mobile-toggle{display:none;background:none;border:none;cursor:pointer;color:var(--sidebar-text);padding:4px;margin-left:auto}.portal-mobile-nav{background:var(--gray-800);border-top:1px solid rgba(255,255,255,.06);padding:8px;display:flex;flex-direction:column;gap:2px}.portal-mobile-nav-link{display:block;padding:10px 16px;border-radius:var(--radius-md);font-size:14px;font-weight:500;color:var(--sidebar-text);text-decoration:none}.portal-mobile-nav-link.active{background:var(--brand-600);color:#fff}.portal-mobile-logout{margin-top:4px;padding:10px 16px;border-radius:var(--radius-md);font-size:14px;font-weight:500;color:var(--sidebar-text);background:none;border:none;cursor:pointer;text-align:left;width:100%}@media(max-width:768px){.portal-nav,.portal-user-name{display:none}.portal-mobile-toggle{display:block}.portal-topnav-right .btn-logout{display:none}}.portal-content{flex:1;padding:0}.portal-page{max-width:1000px;margin:0 auto;padding:32px 24px 60px}@media(max-width:640px){.portal-page{padding:20px 16px 48px}}.portal-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:14px;min-height:260px;color:var(--gray-500);font-size:14px}.portal-no-profile{text-align:center;padding:60px 24px;color:var(--gray-600)}.portal-no-profile-icon{font-size:52px;margin-bottom:16px}.portal-no-profile h2{font-size:20px;font-weight:700;color:var(--gray-800);margin-bottom:10px}.portal-no-profile p{font-size:14px;line-height:1.65}.portal-empty{text-align:center;padding:52px 24px;background:#fff;border-radius:var(--radius-lg);border:1px solid var(--gray-200)}.portal-empty-icon{font-size:44px;margin-bottom:14px}.portal-empty-text{font-size:16px;font-weight:600;color:var(--gray-700);margin-bottom:6px}.portal-empty-sub{font-size:13px;color:var(--gray-500)}.portal-welcome-card{background:linear-gradient(135deg,var(--brand-700) 0%,var(--brand-600) 60%,#7c3aed 100%);color:#fff;border-radius:var(--radius-xl);padding:28px 32px;display:flex;align-items:flex-start;justify-content:space-between;gap:20px;margin-bottom:24px;box-shadow:var(--shadow-lg)}.portal-welcome-greeting{font-size:14px;opacity:.85;margin-bottom:4px}.portal-welcome-name{font-size:24px;font-weight:700;letter-spacing:-.02em;margin-bottom:10px}.portal-welcome-meta{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.portal-student-number{font-size:13px;background:#ffffff26;padding:3px 10px;border-radius:var(--radius-full);font-family:monospace;letter-spacing:.03em}.portal-welcome-date{font-size:12px;opacity:.75;white-space:nowrap;text-align:right;flex-shrink:0}@media(max-width:600px){.portal-welcome-card{flex-direction:column;padding:22px 20px}.portal-welcome-date{text-align:left}.portal-welcome-name{font-size:20px}}.portal-stat-row{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-bottom:28px}@media(max-width:540px){.portal-stat-row{grid-template-columns:1fr}}.portal-stat-card{background:#fff;border-radius:var(--radius-lg);border:1px solid var(--gray-200);padding:20px 22px;box-shadow:var(--shadow-xs)}.portal-stat-value{font-size:26px;font-weight:700;letter-spacing:-.02em;margin-bottom:4px}.portal-stat-label{font-size:12px;color:var(--gray-500);font-weight:500}.portal-section-title{font-size:13px;font-weight:700;color:var(--gray-500);text-transform:uppercase;letter-spacing:.07em;margin-bottom:14px}.portal-quick-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:32px}@media(max-width:700px){.portal-quick-grid{grid-template-columns:repeat(2,1fr)}}.portal-quick-card{background:#fff;border:1px solid var(--gray-200);border-radius:var(--radius-lg);padding:20px 16px;display:flex;flex-direction:column;gap:8px;text-decoration:none;transition:box-shadow .15s,border-color .15s,transform .15s;box-shadow:var(--shadow-xs)}.portal-quick-card:hover{box-shadow:var(--shadow-md);border-color:var(--brand-300);transform:translateY(-2px)}.portal-quick-emoji{font-size:28px}.portal-quick-label{font-size:14px;font-weight:700;color:var(--gray-800)}.portal-quick-desc{font-size:12px;color:var(--gray-500);line-height:1.4}.portal-program-list{display:flex;flex-direction:column;gap:14px}.portal-program-card{background:#fff;border:1px solid var(--gray-200);border-radius:var(--radius-lg);padding:18px 20px;box-shadow:var(--shadow-xs)}.portal-program-top{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:12px}.portal-program-name{font-size:15px;font-weight:700;color:var(--gray-800);margin-bottom:4px}.portal-program-meta{display:flex;gap:6px;flex-wrap:wrap;font-size:12px;color:var(--gray-500)}.portal-program-modules{display:flex;flex-wrap:wrap;gap:6px}.portal-module-chip{display:flex;align-items:center;gap:4px;background:var(--gray-100);border-radius:var(--radius-sm);padding:3px 8px;font-size:11px;font-weight:600;color:var(--gray-700);border:1px solid var(--gray-200)}.portal-module-chip.portal-module-more{background:var(--gray-50);color:var(--gray-400);font-weight:400}.portal-module-code{font-family:monospace}.portal-page-header{margin-bottom:24px}.portal-page-title{font-size:22px;font-weight:700;color:var(--gray-900);margin-bottom:4px}.portal-page-sub{font-size:13px;color:var(--gray-500)}.portal-course-list{display:flex;flex-direction:column;gap:12px}.portal-course-card{background:#fff;border:1px solid var(--gray-200);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-xs)}.portal-course-header{display:flex;align-items:center;justify-content:space-between;padding:18px 20px;width:100%;background:none;border:none;cursor:pointer;text-align:left;gap:16px;transition:background .15s}.portal-course-header:hover{background:var(--gray-50)}.portal-course-header-left{flex:1;min-width:0}.portal-course-name{font-size:15px;font-weight:700;color:var(--gray-800);margin-bottom:5px}.portal-course-meta{display:flex;gap:8px;flex-wrap:wrap;font-size:12px;color:var(--gray-500)}.portal-course-type-badge{background:var(--brand-50);color:var(--brand-700);border-radius:var(--radius-sm);padding:1px 7px;font-weight:600;font-size:11px}.portal-course-header-right{display:flex;align-items:center;gap:10px;flex-shrink:0}.portal-expand-caret{font-size:10px;color:var(--gray-400)}.portal-module-table-wrap{border-top:1px solid var(--gray-100);padding:16px 20px;background:var(--gray-50)}.portal-module-empty{font-size:13px;color:var(--gray-400);padding:8px 0;font-style:italic}.portal-module-table{width:100%;border-collapse:collapse;font-size:13px}.portal-module-table thead tr{border-bottom:2px solid var(--gray-200)}.portal-module-table th{text-align:left;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--gray-500);padding:8px 12px 8px 0}.portal-module-table td{padding:10px 12px 10px 0;border-bottom:1px solid var(--gray-100);vertical-align:middle;color:var(--gray-700)}.portal-module-table tbody tr:last-child td{border-bottom:none}.portal-module-table tbody tr:hover td{background:#2563eb08}.portal-module-code-cell{font-family:monospace;font-size:12px;color:var(--gray-500);white-space:nowrap;padding-right:16px!important}.portal-table-wrap{background:#fff;border:1px solid var(--gray-200);border-radius:var(--radius-lg);overflow:auto;box-shadow:var(--shadow-xs)}.portal-table-wrap .portal-module-table{margin:0}.portal-table-wrap .portal-module-table th,.portal-table-wrap .portal-module-table td{padding:12px 16px}.portal-credits-bar-wrap{margin-top:16px;padding-top:14px;border-top:1px solid var(--gray-200)}.portal-credits-label{font-size:12px;color:var(--gray-600);margin-bottom:6px}.portal-credits-bar{height:8px;background:var(--gray-200);border-radius:var(--radius-full);overflow:hidden}.portal-credits-fill{height:100%;background:var(--brand-600);border-radius:var(--radius-full);transition:width .4s ease}.portal-grade-pill{display:inline-block;padding:2px 8px;border-radius:var(--radius-full);font-size:11px;font-weight:700;white-space:nowrap}.portal-grade-pill--distinction{background:#dcfce7;color:#15803d}.portal-grade-pill--pass{background:#fef3c7;color:#b45309}.portal-grade-pill--fail{background:#fee2e2;color:#b91c1c}.portal-grade-pill--progress{background:#e0f2fe;color:#0369a1}.portal-grade-pill--na{background:var(--gray-100);color:var(--gray-500)}.portal-letter-badge{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:var(--radius-md);font-size:12px;font-weight:800}.portal-letter-badge--dist{background:#dcfce7;color:#15803d}.portal-letter-badge--pass{background:#fef9c3;color:#854d0e}.portal-letter-badge--fail{background:#fee2e2;color:#b91c1c}.portal-grade-bar-wrap{display:flex;align-items:center;gap:8px}.portal-grade-bar-bg{flex:1;height:6px;background:var(--gray-200);border-radius:var(--radius-full);overflow:hidden}.portal-grade-bar-fill{height:100%;border-radius:var(--radius-full);transition:width .4s ease}.portal-grade-bar-label{font-size:12px;font-weight:700;white-space:nowrap;min-width:36px;text-align:right}.portal-results-block{margin-bottom:28px;background:#fff;border:1px solid var(--gray-200);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-xs)}.portal-results-program-header{display:flex;align-items:center;justify-content:space-between;padding:14px 20px;border-bottom:1px solid var(--gray-100);background:var(--gray-50)}.portal-results-program-name{font-size:14px;font-weight:700;color:var(--gray-800)}.portal-results-program-year{font-size:12px;color:var(--gray-500)}.portal-results-block .portal-module-table th,.portal-results-block .portal-module-table td{padding:11px 16px 11px 20px}.portal-results-block .portal-module-table th:first-child,.portal-results-block .portal-module-table td:first-child{padding-left:20px}.portal-balance-card{border-radius:var(--radius-xl);padding:28px 32px;margin-bottom:8px;box-shadow:var(--shadow-md);text-align:center}.portal-balance-card--owing{background:linear-gradient(135deg,#dc2626,#ef4444);color:#fff}.portal-balance-card--credit{background:linear-gradient(135deg,#16a34a,#22c55e);color:#fff}.portal-balance-card--clear{background:linear-gradient(135deg,var(--gray-700),var(--gray-600));color:#fff}.portal-balance-label{font-size:12px;text-transform:uppercase;letter-spacing:.08em;opacity:.85;margin-bottom:8px}.portal-balance-amount{font-size:36px;font-weight:800;letter-spacing:-.03em;margin-bottom:8px}.portal-balance-sub{font-size:13px;opacity:.85}.portal-tx-type{display:inline-block;padding:2px 8px;border-radius:var(--radius-full);font-size:11px;font-weight:700}.portal-tx-type--charge{background:#fee2e2;color:#b91c1c}.portal-tx-type--payment{background:#dcfce7;color:#15803d}.portal-tx-type--adj{background:#e0f2fe;color:#0369a1}.portal-tx-type--reversal{background:#fef3c7;color:#b45309}.portal-profile-section{background:#fff;border:1px solid var(--gray-200);border-radius:var(--radius-lg);padding:22px 24px;margin-bottom:20px;box-shadow:var(--shadow-xs)}.portal-profile-section-header{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:8px;font-size:14px;font-weight:700;color:var(--gray-800);margin-bottom:18px;padding-bottom:14px;border-bottom:1px solid var(--gray-100)}.portal-profile-readonly-badge{font-size:11px;font-weight:500;color:var(--gray-500);background:var(--gray-100);border-radius:var(--radius-full);padding:3px 10px}.portal-profile-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:2px 0}@media(max-width:540px){.portal-profile-grid{grid-template-columns:1fr}}.portal-profile-row{display:flex;flex-direction:column;padding:10px 0;border-bottom:1px solid var(--gray-50)}.portal-profile-label{font-size:11px;font-weight:600;color:var(--gray-500);text-transform:uppercase;letter-spacing:.05em;margin-bottom:3px}.portal-profile-value{font-size:13px;color:var(--gray-800);font-weight:500;text-transform:capitalize}.portal-profile-form-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}@media(max-width:640px){.portal-profile-form-grid{grid-template-columns:1fr}}.portal-profile-actions{display:flex;align-items:center;justify-content:flex-end;gap:12px;margin-top:18px;padding-top:16px;border-top:1px solid var(--gray-100)}.portal-saved-msg{font-size:13px;font-weight:600;color:var(--color-success)}.ai-shell{display:flex;flex-direction:column;height:calc(100vh - var(--topbar-height) - 2.5rem);background:#fff;border-radius:12px;border:1px solid var(--gray-200);overflow:hidden;box-shadow:0 2px 12px #0000000f}.ai-setup-banner{display:flex;align-items:flex-start;gap:.875rem;padding:.875rem 1.25rem;background:linear-gradient(135deg,#fdf4ff,#eff6ff);border-bottom:1.5px solid #e9d5ff;flex-shrink:0}.ai-setup-banner-icon{font-size:1.4rem;line-height:1;flex-shrink:0;margin-top:1px}.ai-setup-banner-body{flex:1;font-size:.8rem;color:var(--gray-700);line-height:1.55;display:flex;flex-direction:column;gap:.3rem}.ai-setup-banner-body strong{font-size:.85rem;color:#6d28d9;font-weight:700}.ai-setup-banner-body em{font-style:italic;font-weight:600;color:var(--gray-800)}.ai-setup-banner-code{display:inline-block;margin-top:.15rem;font-family:Courier New,monospace;font-size:.72rem;background:#6d28d912;border:1px solid #e9d5ff;border-radius:5px;padding:.25rem .6rem;color:#6d28d9;white-space:pre}.ai-setup-banner-cta{flex-shrink:0;align-self:center;font-size:.75rem;font-weight:700;padding:.4rem .9rem;background:#7c3aed;color:#fff;border-radius:6px;text-decoration:none;white-space:nowrap;transition:background .15s}.ai-setup-banner-cta:hover{background:#6d28d9}.ai-header{display:flex;align-items:center;justify-content:space-between;padding:.875rem 1.25rem;background:#fff;border-bottom:1px solid var(--gray-200);flex-shrink:0}.ai-header-left{display:flex;align-items:center;gap:.75rem}.ai-icon{width:40px;height:40px;background:linear-gradient(135deg,var(--brand-600),var(--brand-800));border-radius:10px;display:grid;place-items:center;font-size:1.25rem;flex-shrink:0}.ai-title{font-size:.95rem;font-weight:700;color:var(--gray-900)}.ai-subtitle{font-size:.72rem;color:var(--gray-500);margin-top:1px}.ai-no-key-badge{font-size:.7rem;padding:.25rem .65rem;background:var(--color-warning-bg);border:1px solid var(--color-warning-border);color:var(--color-warning);border-radius:20px}.ai-no-key-badge code{font-size:.68rem;font-weight:700}.ai-clear-btn{font-size:.75rem;padding:.35rem .8rem;background:transparent;border:1px solid var(--gray-200);border-radius:6px;color:var(--gray-500);cursor:pointer;transition:all .15s}.ai-clear-btn:hover{background:var(--gray-100);color:var(--gray-700)}.ai-suggestions{padding:.75rem 1.25rem;background:var(--gray-50);border-bottom:1px solid var(--gray-200);flex-shrink:0}.ai-suggestions-label{font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--gray-400);margin-bottom:.5rem}.ai-chips{display:flex;flex-wrap:wrap;gap:.4rem}.ai-chip{font-size:.78rem;padding:.35rem .8rem;background:#fff;color:var(--brand-700);border:1px solid var(--brand-200);border-radius:20px;cursor:pointer;transition:all .15s;white-space:nowrap}.ai-chip:hover:not(:disabled){background:var(--brand-50);border-color:var(--brand-400)}.ai-chip:disabled{opacity:.5;cursor:not-allowed}.ai-messages{flex:1;overflow-y:auto;padding:1.25rem;background:var(--gray-50);display:flex;flex-direction:column;gap:.75rem;scroll-behavior:smooth}.ai-row{display:flex;gap:.625rem;align-items:flex-start}.ai-row--user{flex-direction:row-reverse}.ai-avatar{width:30px;height:30px;border-radius:50%;display:grid;place-items:center;font-size:.62rem;font-weight:800;flex-shrink:0;letter-spacing:.02em}.ai-avatar--bot{background:linear-gradient(135deg,var(--brand-600),var(--brand-800));color:#fff}.ai-avatar--user{background:var(--gray-700);color:#fff}.ai-bubble{max-width:min(760px,88%);padding:.75rem 1rem;border-radius:12px;font-size:.875rem;line-height:1.6}.ai-bubble--bot{background:#fff;border:1px solid var(--gray-200);border-top-left-radius:3px;box-shadow:0 1px 4px #0000000d}.ai-bubble--user{background:var(--brand-600);color:#fff;border-top-right-radius:3px}.ai-bubble-text{margin:0;white-space:pre-line}.ai-bubble--user .ai-bubble-text{color:#fff}.ai-empty{font-size:.8rem;color:var(--gray-500);font-style:italic;margin-top:.5rem}.ai-mode-badge{display:inline-block;margin-top:.625rem;font-size:.65rem;padding:.2rem .55rem;background:var(--brand-50);color:var(--brand-700);border:1px solid var(--brand-200);border-radius:20px;font-weight:600}.ai-mode-badge--kw{background:var(--gray-100);color:var(--gray-500);border-color:var(--gray-200)}.ai-dot{display:inline-block;width:8px;height:8px;background:var(--gray-400);border-radius:50%;margin:0 2px;animation:aiDot 1.4s ease-in-out infinite}.ai-dot:nth-child(2){animation-delay:.2s}.ai-dot:nth-child(3){animation-delay:.4s}@keyframes aiDot{0%,80%,to{transform:scale(.75);opacity:.4}40%{transform:scale(1.1);opacity:1}}.ai-result-table{margin-top:.75rem;border:1px solid var(--gray-200);border-radius:8px;overflow:hidden;background:#fff}.ai-table-topbar{display:flex;justify-content:space-between;align-items:center;padding:.45rem .75rem;background:var(--gray-50);border-bottom:1px solid var(--gray-200);flex-wrap:wrap;gap:.4rem}.ai-table-count{font-size:.72rem;color:var(--gray-500);font-weight:600}.ai-table-btns{display:flex;gap:.4rem}.ai-action-btn{font-size:.72rem;padding:.28rem .65rem;background:#fff;border:1px solid var(--gray-200);border-radius:5px;cursor:pointer;color:var(--gray-700);font-weight:500;transition:all .15s;white-space:nowrap}.ai-action-btn:hover{background:var(--gray-100)}.ai-action-btn--ok{background:var(--color-success-bg)!important;border-color:var(--color-success-border)!important;color:var(--color-success)!important}.ai-table-scroll{overflow-x:auto;max-height:300px}.ai-table{width:100%;border-collapse:collapse;font-size:.8rem}.ai-table th{padding:.45rem .75rem;text-align:left;background:var(--gray-50);font-weight:600;color:var(--gray-600);border-bottom:1px solid var(--gray-200);white-space:nowrap;font-size:.7rem;text-transform:uppercase;letter-spacing:.04em;position:sticky;top:0}.ai-table td{padding:.4rem .75rem;border-bottom:1px solid var(--gray-100);color:var(--gray-800);max-width:260px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.ai-table tr:last-child td{border-bottom:none}.ai-table tbody tr:hover td{background:var(--brand-50)}.ai-table-footer{font-size:.7rem;color:var(--gray-500);text-align:center;padding:.4rem;background:var(--gray-50);border-top:1px solid var(--gray-200)}.ai-summary-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(110px,1fr));gap:.5rem;margin-top:.75rem}.ai-summary-card{background:var(--gray-50);border:1px solid var(--gray-200);border-radius:8px;padding:.75rem .5rem;text-align:center}.ai-summary-val{font-size:1.05rem;font-weight:800;color:var(--brand-700);word-break:break-word}.ai-summary-key{font-size:.68rem;color:var(--gray-500);text-transform:capitalize;margin-top:.25rem}.ai-input-area{display:flex;gap:.625rem;padding:.875rem 1.25rem;background:#fff;border-top:1px solid var(--gray-200);flex-shrink:0}.ai-input{flex:1;padding:.625rem .875rem;border:1.5px solid var(--gray-200);border-radius:8px;font-size:.875rem;font-family:inherit;resize:none;line-height:1.5;outline:none;transition:border-color .15s;background:var(--gray-50);max-height:120px;overflow-y:auto}.ai-input:focus{border-color:var(--brand-500);background:#fff}.ai-input:disabled{opacity:.6}.ai-send-btn{width:42px;height:42px;background:var(--brand-600);color:#fff;border:none;border-radius:8px;display:grid;place-items:center;cursor:pointer;transition:background .15s;flex-shrink:0;align-self:flex-end}.ai-send-btn:hover:not(:disabled){background:var(--brand-700)}.ai-send-btn:disabled{background:var(--gray-300);cursor:not-allowed}.sidebar-item--ai{position:relative}.sidebar-item-tag--ai{background:linear-gradient(135deg,#7c3aed,var(--brand-600))!important;color:#fff!important;font-size:.58rem!important;font-weight:800!important;letter-spacing:.06em!important;padding:.1rem .35rem!important;border-radius:4px!important}
