@import"https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&display=swap";:root{--primary-50: #f5f3ff;--primary-100: #ede9fe;--primary-500: #8b5cf6;--primary-600: #7c3aed;--primary-700: #6d28d9;--accent-from: #6366f1;--accent-to: #8b5cf6;--accent-pink: #ec4899;--bg-base: #0a0a0f;--bg-surface: rgba(17, 17, 24, .75);--bg-elevated: rgba(26, 26, 38, .8);--bg-card: rgba(30, 30, 46, .65);--bg-hover: rgba(37, 37, 53, .8);--glass-highlight: rgba(255, 255, 255, .05);--border-subtle: rgba(148, 163, 184, .14);--border-default: rgba(148, 163, 184, .2);--border-strong: rgba(139, 92, 246, .2);--text-primary: #f1f0f9;--text-secondary: #a09ab8;--text-muted: #6b638a;--success: #10b981;--warning: #f59e0b;--error: #ef4444;--info: #3b82f6;--radius-sm: 8px;--radius-md: 14px;--radius-lg: 20px;--radius-xl: 32px;--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;--page-padding-x: 32px;--page-padding-x-mobile: 20px;--page-section-gap: 20px;--control-height: 40px;--control-height-sm: 34px;--control-height-lg: 46px;--font-display: clamp(28px, 3vw, 36px);--font-title-1: clamp(22px, 2.2vw, 30px);--font-title-2: clamp(18px, 1.6vw, 22px);--font-title-3: 16px;--font-body: 14px;--font-caption: 12px;--ease-standard: cubic-bezier(.2, 0, 0, 1);--ease-emphasized: cubic-bezier(.2, 0, 0, 1.1);--ease-decelerate: cubic-bezier(0, 0, 0, 1);--transition-fast: .16s var(--ease-standard);--transition-normal: .26s var(--ease-standard);--transition-slow: .42s var(--ease-standard);--motion-enter: .28s var(--ease-decelerate);--motion-enter-quick: .2s var(--ease-decelerate);--shadow-card: 0 16px 40px rgba(0, 0, 0, .25);--shadow-glow: 0 0 24px rgba(139, 92, 246, .18);--shadow-glow-strong: 0 0 48px rgba(139, 92, 246, .3)}[data-theme=light]{--bg-base: #f4f7fe;--bg-surface: rgba(255, 255, 255, .9);--bg-elevated: #ffffff;--bg-card: rgba(255, 255, 255, .95);--bg-hover: #f1f5f9;--glass-highlight: rgba(255, 255, 255, .6);--border-subtle: rgba(148, 163, 184, .2);--border-default: rgba(148, 163, 184, .28);--border-strong: rgba(139, 92, 246, .15);--text-primary: #0f172a;--text-secondary: #475569;--text-muted: #64748b;--shadow-card: 0px 8px 30px rgba(18, 20, 31, .04);--shadow-glow: 0px 10px 40px rgba(139, 92, 246, .08);--shadow-glow-strong: 0px 14px 48px rgba(139, 92, 246, .12)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-text-size-adjust:100%}body{margin:0;font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;font-size:var(--font-body);line-height:1.6;color:var(--text-primary);background-color:var(--bg-base);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;position:relative;overflow-x:hidden}body:before,body:after{content:"";position:fixed;border-radius:50%;z-index:-1;pointer-events:none;filter:blur(80px)}body:before{top:-10%;left:-10%;width:50vw;height:50vw;background:radial-gradient(circle,rgba(139,92,246,.15) 0%,transparent 70%)}body:after{bottom:-10%;right:-10%;width:60vw;height:60vw;background:radial-gradient(circle,rgba(99,102,241,.1) 0%,transparent 70%)}[data-theme=light] body:before{background:radial-gradient(circle,rgba(139,92,246,.12) 0%,transparent 70%)}[data-theme=light] body:after{background:radial-gradient(circle,rgba(99,102,241,.08) 0%,transparent 70%)}#root{min-height:100vh}a{color:inherit;text-decoration:none}h1,h2,h3,h4{letter-spacing:-.01em;line-height:1.25}h1{font-size:var(--font-title-1);font-weight:800}h2{font-size:var(--font-title-2);font-weight:700}h3{font-size:var(--font-title-3);font-weight:650}p{line-height:1.65}button{cursor:pointer;border:none;background:none;font-family:inherit}input,textarea,select{font-family:inherit;font-size:inherit}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);height:var(--control-height);padding:0 var(--space-4);border-radius:var(--radius-md);font-size:14px;font-weight:600;border:1px solid transparent;transition:color var(--transition-fast),background var(--transition-fast),border-color var(--transition-fast),box-shadow var(--transition-fast),transform var(--transition-fast);white-space:nowrap;-webkit-user-select:none;user-select:none;line-height:1}.btn-primary{background:linear-gradient(135deg,var(--accent-from),var(--accent-to));color:#fff;box-shadow:0 2px 12px #8b5cf64d}.btn-primary:hover{transform:translateY(-1px);box-shadow:0 4px 20px #8b5cf680}.btn-primary:active{transform:translateY(0)}.btn-ghost{color:var(--text-secondary);border:1px solid var(--border-default);background:#94a3b80a}.btn-ghost:hover{color:var(--text-primary);border-color:var(--border-strong);background:var(--bg-hover)}.btn-danger{background:#ef44441a;color:var(--error);border:1px solid rgba(239,68,68,.2)}.btn-danger:hover{background:#ef444433}.btn-sm{height:var(--control-height-sm);padding:0 12px;font-size:13px;border-radius:10px}.btn-lg{height:var(--control-height-lg);padding:0 24px;font-size:15px}.btn-icon{width:var(--control-height);min-width:var(--control-height);padding:0;border-radius:var(--radius-sm)}.btn:focus-visible{outline:none;box-shadow:0 0 0 3px #3b82f633}.btn:disabled{opacity:.5;cursor:not-allowed;transform:none!important}.card{background:var(--bg-card);border-radius:var(--radius-lg);padding:var(--space-6);border:1px solid var(--border-default);backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);box-shadow:var(--shadow-card);transition:transform var(--transition-fast),box-shadow var(--transition-fast)}.card:hover{border-color:var(--border-default);box-shadow:var(--shadow-card)}.card-glow:hover{box-shadow:var(--shadow-glow)}.form-group{display:flex;flex-direction:column;gap:var(--space-2)}.form-label{font-size:13px;font-weight:500;color:var(--text-secondary);letter-spacing:.03em}.form-input{background:var(--bg-elevated);border:1px solid var(--border-default);border-radius:var(--radius-md);min-height:var(--control-height);padding:8px 14px;color:var(--text-primary);font-size:14px;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);transition:border-color var(--transition-fast),box-shadow var(--transition-fast),background var(--transition-fast);outline:none;width:100%}.form-input:focus{border-color:var(--primary-500);box-shadow:0 0 0 3px #8b5cf626}.form-input::placeholder{color:var(--text-muted)}.form-textarea{min-height:100px;height:auto;resize:vertical;line-height:1.55;padding-top:10px;padding-bottom:10px}.badge{display:inline-flex;align-items:center;gap:4px;min-height:22px;padding:2px 10px;border-radius:100px;border:1px solid transparent;font-size:11px;font-weight:600;letter-spacing:.01em}.badge-purple{background:#8b5cf626;color:var(--primary-500);border-color:#8b5cf647}.badge-green{background:#10b9811f;color:var(--success);border-color:#10b98142}.badge-yellow{background:#f59e0b1f;color:var(--warning);border-color:#f59e0b42}.badge-red{background:#ef44441f;color:var(--error);border-color:#ef44443d}.badge-blue{background:#3b82f61f;color:var(--info);border-color:#3b82f63d}.spinner{width:20px;height:20px;border:2px solid rgba(139,92,246,.25);border-top-color:var(--primary-500);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.divider{height:1px;background:var(--border-subtle);margin:var(--space-4) 0}.gradient-text{background:linear-gradient(135deg,var(--accent-from),var(--accent-to),var(--accent-pink));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#8b5cf640;border-radius:3px}::-webkit-scrollbar-thumb:hover{background:#8b5cf673}@keyframes fadeIn{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeInScale{0%{opacity:0;transform:scale(.98)}to{opacity:1;transform:scale(1)}}.animate-fade-in{animation:fadeIn var(--motion-enter) forwards}.animate-scale-in{animation:fadeInScale var(--motion-enter-quick) forwards}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.items-start{align-items:flex-start}.justify-between{justify-content:space-between}.justify-center{justify-content:center}.gap-2{gap:var(--space-2)}.gap-3{gap:var(--space-3)}.gap-4{gap:var(--space-4)}.gap-6{gap:var(--space-6)}.w-full{width:100%}.text-sm{font-size:13px}.text-xs{font-size:12px}.text-muted{color:var(--text-muted)}.text-secondary{color:var(--text-secondary)}.font-semibold{font-weight:600}.font-bold{font-weight:700}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.global-toast-wrap{position:fixed;top:18px;right:18px;z-index:1200;display:flex;flex-direction:column;gap:10px;pointer-events:none}.global-toast{min-height:40px;max-width:min(420px,calc(100vw - 36px));padding:10px 12px;border-radius:12px;border:1px solid transparent;box-shadow:0 14px 32px #0206173d;display:inline-flex;align-items:center;gap:8px;backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);font-size:13px;font-weight:600;line-height:1.4}.global-toast-success{color:#d1fae5;border-color:#10b98157;background:#064e3be0}.global-toast-error{color:#fee2e2;border-color:#ef444457;background:#7f1d1de6}.global-toast-info{color:#dbeafe;border-color:#3b82f657;background:#1e40afe0}[data-theme=light] .global-toast{box-shadow:0 12px 24px #0f172a1f}[data-theme=light] .global-toast-success{color:#065f46;background:#ecfdf5f2}[data-theme=light] .global-toast-error{color:#991b1b;background:#fef2f2f2}[data-theme=light] .global-toast-info{color:#1e3a8a;background:#eff6fff2}.anim-login-page{min-height:100vh;display:grid;grid-template-columns:1fr 1fr;background:var(--bg-base)}.anim-left{position:relative;display:flex;flex-direction:column;justify-content:space-between;padding:36px 42px;color:#f8fafc;background:linear-gradient(135deg,#6d28d9,#7c3aed 44%,#4f46e5);overflow:hidden}.anim-left:before{content:"";position:absolute;inset:0;background-image:radial-gradient(rgba(255,255,255,.1) 1px,transparent 1px);background-size:18px 18px;opacity:.45}.anim-left:after{content:"";position:absolute;width:520px;height:520px;border-radius:999px;left:-140px;bottom:-180px;background:#ffffff14;filter:blur(26px)}.anim-brand,.anim-stage-wrap{position:relative;z-index:1}.anim-brand{display:inline-flex;align-items:center;gap:10px;font-weight:700}.anim-brand-icon{width:34px;height:34px;border-radius:10px;display:grid;place-items:center;background:#ffffff24}.anim-stage-wrap{display:flex;justify-content:center;align-items:end;height:460px}.anim-stage{position:relative;width:550px;height:400px}.eye-row,.dot-eye-row{position:absolute;display:flex;transition:all .7s ease}.anim-eye{border-radius:999px;background:#fff;display:grid;place-items:center;overflow:hidden;transition:height .15s ease}.anim-pupil,.anim-dot-pupil{border-radius:999px;background:#2d2d2d;transition:transform .1s ease-out}.ch-purple,.ch-black,.ch-orange,.ch-yellow{position:absolute;bottom:0;transition:all .7s ease;transform-origin:bottom center}.ch-purple{left:70px;width:180px;height:400px;border-radius:10px 10px 0 0;background:#6c3ff5;z-index:1}.ch-black{left:240px;width:120px;height:310px;border-radius:8px 8px 0 0;background:#2d2d2d;z-index:2}.ch-orange{left:0;width:240px;height:200px;border-radius:120px 120px 0 0;background:#ff9b6b;z-index:3}.ch-yellow{left:310px;width:140px;height:230px;border-radius:70px 70px 0 0;background:#e8d754;z-index:4}.yellow-mouth{position:absolute;width:80px;height:4px;border-radius:999px;background:#2d2d2d;transition:all .2s ease}.anim-right{display:flex;align-items:center;justify-content:center;padding:28px;background:var(--bg-base)}.anim-form{width:100%;max-width:420px;border-radius:22px;border:1px solid rgba(148,163,184,.22);background:linear-gradient(180deg,#ffffff0f,#ffffff08);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);box-shadow:0 16px 42px #0206172e;padding:28px;display:flex;flex-direction:column}.anim-login-head-badge{width:fit-content;display:inline-flex;gap:6px;align-items:center;font-size:12px;border-radius:999px;padding:4px 10px;color:var(--text-secondary);background:#3b82f61f;border:1px solid rgba(59,130,246,.3)}.anim-form h1{margin-top:12px;font-size:30px;line-height:1.15;color:var(--text-primary)}.anim-form>p{color:var(--text-secondary);margin-top:8px;margin-bottom:20px;font-size:14px}.anim-form label{font-size:13px;color:var(--text-secondary);margin:10px 0 8px}.anim-input-wrap{position:relative;display:flex;align-items:center}.anim-input-wrap input{width:100%;height:46px;border-radius:12px;border:1px solid rgba(148,163,184,.34);padding:0 42px 0 12px;background:#0f172a33;color:var(--text-primary);font-size:14px;outline:none}.anim-input-wrap input:focus{border-color:#3b82f6e0;box-shadow:0 0 0 3px #3b82f633}.anim-input-icon{position:absolute;right:12px;color:var(--text-muted);pointer-events:none}.anim-eye-toggle{position:absolute;right:10px;width:28px;height:28px;display:grid;place-items:center;color:var(--text-muted);border-radius:8px}.anim-eye-toggle:hover{background:#94a3b833;color:var(--text-primary)}.anim-error{margin-top:10px;border-radius:12px;padding:10px 12px;font-size:13px;background:#ef44441a;color:#fca5a5;border:1px solid rgba(239,68,68,.22)}.anim-login-options{margin-top:10px}.anim-remember-check{display:inline-flex;align-items:center;gap:8px;font-size:13px;color:var(--text-secondary);margin:0}.anim-remember-check input{width:14px;height:14px}.anim-recent-users{margin-top:10px;display:flex;align-items:center;gap:8px;flex-wrap:wrap;color:var(--text-secondary);font-size:12px}.anim-recent-list{display:inline-flex;flex-wrap:wrap;gap:6px}.anim-recent-btn{min-height:24px;padding:0 8px;border-radius:999px;border:1px solid rgba(148,163,184,.3);background:#94a3b81f;color:var(--text-primary);font-size:12px}.anim-recent-btn:hover{border-color:#3b82f666}.anim-submit{margin-top:16px;height:46px;border-radius:12px;border:0;color:#fff;font-weight:700;letter-spacing:.02em;background:linear-gradient(135deg,#2563eb,#4f46e5);box-shadow:0 8px 20px #2563eb57}.anim-submit:hover{transform:translateY(-1px)}.anim-submit:disabled{opacity:.6;transform:none;cursor:not-allowed}.anim-signup-hint{margin-top:12px;text-align:center;font-size:13px;color:var(--text-secondary);display:flex;align-items:center;justify-content:center;gap:6px}.anim-contact-link{border:0;background:transparent;padding:0;cursor:pointer;font-size:13px;color:var(--text-primary);font-weight:600;text-decoration:underline;text-underline-offset:2px}.anim-contact-link:hover{color:#2563eb}.anim-contact-backdrop{position:fixed;inset:0;z-index:1000;background:#02061780;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);display:grid;place-items:center;padding:20px}.anim-contact-modal{width:min(520px,100%);border-radius:22px;background:var(--bg-card);border:1px solid rgba(148,163,184,.28);box-shadow:0 18px 50px #02061747;padding:22px;position:relative}.anim-contact-close{position:absolute;top:14px;right:14px;width:34px;height:34px;border-radius:10px;border:1px solid rgba(148,163,184,.34);background:var(--bg-base);color:var(--text-secondary);display:grid;place-items:center}.anim-contact-close:hover{color:var(--text-primary);border-color:#3b82f66b}.anim-contact-title-wrap h3{margin:0;padding-right:48px;font-size:24px;line-height:1.2;color:var(--text-primary)}.anim-contact-title-wrap p{margin:10px 0 0;color:var(--text-secondary);font-size:14px;line-height:1.5}.anim-contact-qr-wrap{margin-top:18px;border-radius:16px;border:1px solid rgba(148,163,184,.26);background:var(--bg-base);padding:16px;display:flex;justify-content:center}.anim-contact-qr{width:min(320px,100%);border-radius:12px;border:1px solid rgba(148,163,184,.24);background:#fff;display:block}@media(max-width:1100px){.anim-login-page{grid-template-columns:1fr}.anim-left{display:none}.anim-right{min-height:100vh;padding:18px}.anim-form{max-width:460px}.anim-contact-modal{padding:18px}.anim-contact-title-wrap h3{font-size:20px}}.app-layout{display:flex;min-height:100vh;background:var(--bg-base)}.sidebar{width:220px;flex-shrink:0;background:linear-gradient(180deg,#0f172ad1,#0f172ab8);border-right:1px solid rgba(148,163,184,.2);box-shadow:8px 0 30px #02061738;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);display:flex;flex-direction:column;padding:20px 12px;position:fixed;top:0;left:0;height:100vh;overflow:hidden;z-index:100;transition:width var(--transition-normal)}.sidebar-collapsed .sidebar{width:76px;padding:20px 8px;background:var(--bg-surface)}.sidebar-logo{display:flex;align-items:center;gap:10px;padding:8px 8px 32px;margin-bottom:12px;border-bottom:1px solid var(--border-subtle);min-height:76px;overflow:hidden;white-space:nowrap}.sidebar-collapsed .sidebar-logo{padding:4px;justify-content:center;margin-bottom:24px}.logo-icon{width:36px;height:36px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;flex-shrink:0;box-shadow:0 4px 14px #8b5cf659;transition:transform var(--transition-normal),box-shadow var(--transition-normal),width var(--transition-normal),height var(--transition-normal)}.sidebar-collapsed .logo-icon{width:40px;height:40px;margin:0 auto;box-shadow:none}.logo-title{font-size:14px;font-weight:700;color:var(--text-primary)}.logo-sub{font-size:11px;color:var(--text-muted)}.sidebar-nav{display:flex;flex-direction:column;gap:4px;flex:1;min-height:0;padding-top:8px;overflow-y:auto;overflow-x:hidden;overscroll-behavior:contain;scrollbar-gutter:stable}.nav-item{display:flex;align-items:center;gap:12px;min-height:40px;padding:9px 14px;margin:0 8px;border-radius:99px;border:1px solid transparent;color:var(--text-secondary);font-size:13.5px;font-weight:500;transition:background var(--transition-fast),color var(--transition-fast),border-color var(--transition-fast),transform var(--transition-fast),box-shadow var(--transition-fast);position:relative;overflow:hidden;white-space:nowrap}.sidebar-collapsed .nav-item{padding:12px;margin:0 4px;justify-content:center}.sidebar-collapsed .nav-item:hover{transform:none}.sidebar-collapsed .sidebar-nav{gap:6px}.nav-item:hover{background:#94a3b81f;border-color:var(--border-subtle);color:var(--text-primary);transform:translate(4px)}.nav-item-active{background:linear-gradient(90deg,#3b82f6,#6366f1);color:#fff!important;box-shadow:0 6px 16px #3b82f640}.nav-item-active .nav-chevron{opacity:1;color:#fff}.nav-chevron{margin-left:auto;opacity:.5}.sidebar-footer{padding-top:16px;border-top:1px solid var(--border-subtle);margin:0 8px;flex-shrink:0}.sidebar-mascot{margin-top:auto;height:150px;border-radius:16px;border:1px solid rgba(148,163,184,.22);background:linear-gradient(180deg,#0f172a3d,#0f172a1f);display:flex;align-items:end;justify-content:center;gap:8px;padding:0 10px 12px;overflow:hidden}.sidebar-mascot-char{position:relative;border-radius:10px 10px 0 0;display:flex;justify-content:center;align-items:start;transition:transform var(--transition-fast)}.sidebar-mascot:hover .sidebar-mascot-char{transform:translateY(-2px)}.sidebar-char-a{width:62px;height:112px;background:#6d28d9}.sidebar-char-b{width:48px;height:88px;background:#2d2d2d}.sidebar-char-c{width:56px;height:76px;border-radius:28px 28px 0 0;background:#f59e0b}.sidebar-mascot-eyes{margin-top:14px;display:flex;gap:8px}.sidebar-mini-eye{width:12px;height:12px;border-radius:999px;background:#fff;display:grid;place-items:center;overflow:hidden;transition:height .12s linear}.sidebar-mini-pupil{width:5px;height:5px;border-radius:999px;background:#1f2937;transition:transform .08s linear}.sidebar-footer-btn{margin-bottom:8px}.sidebar-footer-btn-last{margin-bottom:16px}.sidebar-collapsed .sidebar-footer{margin:0 4px;border-top:none;padding-top:8px}.sidebar-collapsed .sidebar-footer-btn{margin-bottom:6px}.sidebar-collapsed .sidebar-footer-btn-last{margin-bottom:10px}.sidebar-collapsed .sidebar-collapsed-key{margin:0;padding:10px;min-height:38px}[data-theme=light] .nav-item-active{background:#eff6ff;color:#1d4ed8!important;box-shadow:none;font-weight:600}[data-theme=light] .nav-item-active .nav-chevron{color:#1d4ed8}[data-theme=light] .sidebar{background:linear-gradient(180deg,#fff,#f8fbff);border-right:1px solid rgba(148,163,184,.22);box-shadow:8px 0 24px #0f172a14}[data-theme=light] .sidebar-logo,[data-theme=light] .sidebar-footer{border-color:#94a3b833}[data-theme=light] .nav-item:hover{background:#f1f5f9}[data-theme=light] .sidebar-mascot{background:linear-gradient(180deg,#fff,#f8fbff);border-color:#94a3b842}.version-tag{font-size:11px;color:var(--text-muted);text-align:center}.role-tag{margin-top:8px;min-height:24px;padding:0 10px;border-radius:999px;border:1px solid transparent;font-size:11px;font-weight:700;text-align:center;display:inline-flex;align-items:center;justify-content:center;width:100%}.role-tag-admin{background:#3b82f624;color:#93c5fd;border-color:#3b82f64d}.role-tag-member{background:#10b98124;color:#6ee7b7;border-color:#10b98147}.role-tag-viewer{background:#f59e0b24;color:#fcd34d;border-color:#f59e0b4d}.access-denied-card{width:min(560px,92vw);border-radius:18px;border:1px solid var(--border-default);background:var(--bg-card);box-shadow:var(--shadow-card);padding:24px;text-align:left}.access-denied-card h2{font-size:24px;color:var(--text-primary)}.access-denied-card p{margin-top:8px;font-size:14px;color:var(--text-secondary)}[data-theme=light] .role-tag-admin{color:#1d4ed8;background:#3b82f61a}[data-theme=light] .role-tag-member{color:#047857;background:#10b9811a}[data-theme=light] .role-tag-viewer{color:#92400e;background:#f59e0b1f}.main-content{flex:1;margin-left:220px;min-height:100vh;padding:var(--page-padding-x);transition:margin-left var(--transition-normal)}.startup-warning-banner{margin-bottom:16px;padding:14px;border-radius:14px;border:1px solid rgba(245,158,11,.35);background:linear-gradient(180deg,#f59e0b24,#f59e0b14)}.startup-warning-title-row{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:10px}.startup-warning-title{display:inline-flex;align-items:center;gap:8px;font-size:14px;font-weight:700;color:var(--text-primary)}.startup-warning-refresh{display:inline-flex;align-items:center;gap:6px;border-radius:999px;border:1px solid var(--border-default);background:var(--bg-card);color:var(--text-secondary);font-size:12px;font-weight:600;padding:6px 10px;cursor:pointer}.startup-warning-refresh:disabled{opacity:.65;cursor:not-allowed}.startup-warning-list{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:8px}.startup-warning-item{border:1px solid var(--border-default);border-radius:12px;background:var(--bg-card);padding:10px 12px}.startup-warning-item.level-critical{border-color:#ef444459}.startup-warning-item.level-warning{border-color:#f59e0b52}.startup-warning-item-title{font-size:13px;font-weight:700;color:var(--text-primary)}.startup-warning-item-message{margin-top:4px;color:var(--text-secondary);font-size:12.5px;line-height:1.55}.startup-warning-item-action{margin-top:4px;color:var(--text-muted);font-size:12px;line-height:1.5}.startup-warning-time{margin-top:8px;font-size:11.5px;color:var(--text-muted)}[data-theme=light] .startup-warning-banner{background:linear-gradient(180deg,#f59e0b1f,#f59e0b0f);border-color:#d977064d}.route-loading{min-height:calc(100vh - 2 * var(--page-padding-x));display:grid;place-items:center;color:var(--text-secondary);font-size:14px}.sidebar-collapsed .main-content{margin-left:76px}.page-header{margin-bottom:var(--space-8)}.page-title{font-size:var(--font-title-1);font-weight:700;color:var(--text-primary);margin-bottom:8px;line-height:1.2}.page-subtitle{font-size:var(--font-body);color:var(--text-muted);line-height:1.65}.section-title{font-size:var(--font-title-3);font-weight:700;line-height:1.3;color:var(--text-primary)}.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:20px}.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}@media(max-width:1024px){.grid-3,.grid-4{grid-template-columns:repeat(2,1fr)}}@media(max-width:768px){.sidebar{width:76px;padding:20px 8px}.logo-title,.logo-sub,.nav-item span{display:none}.sidebar-logo{padding:4px;justify-content:center;margin-bottom:24px}.logo-icon{width:40px;height:40px;margin:0 auto;box-shadow:none}.nav-item{padding:12px;margin:0 4px;justify-content:center}.nav-item-active .nav-chevron,.nav-chevron{display:none}.main-content{margin-left:76px;padding:var(--page-padding-x-mobile)}.grid-2,.grid-3,.grid-4{grid-template-columns:1fr}.version-tag{display:none}}@media(max-height:760px){.sidebar-mascot{display:none}}.stat-card{background:var(--bg-card);border-radius:var(--radius-lg);padding:24px;backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);box-shadow:var(--shadow-card);transition:transform var(--transition-fast),box-shadow var(--transition-fast),border-color var(--transition-fast)}.stat-card:hover{transform:translateY(-4px);box-shadow:0 16px 40px #00000014}.stat-icon{width:40px;height:40px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;margin-bottom:12px}.stat-value{font-size:28px;font-weight:800;color:var(--text-primary);line-height:1;margin-bottom:4px}.stat-label{font-size:13px;color:var(--text-muted)}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;color:var(--text-muted);text-align:center}.empty-icon{width:64px;height:64px;background:var(--bg-elevated);border-radius:50%;display:flex;align-items:center;justify-content:center;margin-bottom:16px;color:var(--text-muted)}.empty-title{font-size:var(--font-title-3);font-weight:700;color:var(--text-secondary);margin-bottom:10px;line-height:1.35}.empty-desc{font-size:var(--font-body);max-width:300px;line-height:1.65}.modal-overlay{position:fixed;inset:0;background:#000000b3;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);z-index:200;display:flex;align-items:center;justify-content:center;padding:20px}.modal{background:var(--bg-card);border:1px solid var(--border-default);border-radius:var(--radius-xl);padding:32px;width:100%;max-width:540px;max-height:90vh;overflow-y:auto;backdrop-filter:blur(32px);-webkit-backdrop-filter:blur(32px);box-shadow:0 24px 70px #02061747;animation:fadeInScale var(--motion-enter-quick) forwards}.modal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px}.modal-title{font-size:var(--font-title-2);font-weight:700;line-height:1.3}.modal-footer{display:flex;justify-content:flex-end;gap:12px;margin-top:24px;padding-top:20px;border-top:1px solid var(--border-subtle)}[data-theme=light] .modal-overlay{background:#0f172a47}[data-theme=light] .modal{background:#fff;box-shadow:0 24px 56px #0f172a29}.auth-page{min-height:100vh;display:grid;place-items:center;position:relative;overflow:hidden;padding:24px}.auth-glow{position:absolute;border-radius:999px;filter:blur(80px);pointer-events:none}.auth-glow-a{width:420px;height:420px;background:#3b82f633;left:-120px;top:-100px}.auth-glow-b{width:360px;height:360px;background:#0ea5e92e;right:-100px;bottom:-80px}.auth-card{width:min(460px,100%);padding:32px;border-radius:24px;background:linear-gradient(160deg,#ffffff1f,#ffffff0a);border:1px solid rgba(148,163,184,.24);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);box-shadow:0 24px 60px #02061747;display:flex;flex-direction:column;gap:10px;position:relative;z-index:1}.auth-badge{display:inline-flex;align-items:center;gap:6px;font-size:12px;color:var(--text-secondary);background:#3b82f61f;border:1px solid rgba(59,130,246,.28);border-radius:999px;padding:4px 10px;width:fit-content}.auth-title{font-size:28px;font-weight:800;margin-top:4px;color:var(--text-primary)}.auth-subtitle{color:var(--text-secondary);font-size:14px;margin-bottom:10px}.auth-label{color:var(--text-secondary);font-size:13px;margin-top:6px}.auth-input{width:100%;border-radius:12px;border:1px solid rgba(148,163,184,.26);background:#0f172a3d;color:var(--text-primary);padding:11px 12px;outline:none}.auth-input:focus{border-color:#3b82f6cc;box-shadow:0 0 0 3px #3b82f633}.auth-submit{width:100%;margin-top:14px;height:42px;font-weight:700}
