@import"https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&display=swap";:root{--theme-font: "Inter", "PingFang SC", "Microsoft YaHei", sans-serif;--theme-heading-font: "Inter", "PingFang SC", "Microsoft YaHei", sans-serif;--primary-50: #fff7ed;--primary-100: #ffedd5;--primary-500: #c2410c;--primary-600: #9a3412;--primary-700: #7c2d12;--primary-rgb: 194, 65, 12;--accent-from: #b91c1c;--accent-to: #f59e0b;--accent-pink: #fb7185;--bg-base: #120b0a;--bg-surface: rgba(31, 18, 14, .82);--bg-elevated: rgba(49, 28, 20, .9);--bg-card: rgba(36, 22, 16, .82);--bg-hover: rgba(74, 40, 24, .76);--glass-highlight: rgba(255, 244, 214, .06);--border-subtle: rgba(245, 158, 11, .16);--border-default: rgba(251, 191, 36, .22);--border-strong: rgba(220, 38, 38, .22);--text-primary: #fff7ed;--text-secondary: #f4c996;--text-muted: #c89f7a;--success: #10b981;--warning: #f59e0b;--error: #ef4444;--info: #3b82f6;--sidebar-bg: linear-gradient(180deg, rgba(46, 24, 17, .94), rgba(24, 12, 10, .96));--sidebar-border: rgba(251, 191, 36, .16);--sidebar-shadow: 10px 0 32px rgba(0, 0, 0, .34);--nav-hover-bg: rgba(251, 191, 36, .12);--nav-active-bg: linear-gradient(90deg, #b91c1c, #f59e0b);--nav-active-color: #fff8ef;--nav-active-shadow: 0 10px 24px rgba(185, 28, 28, .28);--logo-shadow: 0 6px 18px rgba(245, 158, 11, .24);--body-glow-a: radial-gradient(circle, rgba(220, 38, 38, .18) 0%, transparent 70%);--body-glow-b: radial-gradient(circle, rgba(245, 158, 11, .14) 0%, transparent 70%);--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(245, 158, 11, .18);--shadow-glow-strong: 0 0 48px rgba(220, 38, 38, .24)}[data-theme=forest]{--theme-font: "Inter", "PingFang SC", "Microsoft YaHei", sans-serif;--theme-heading-font: "Inter", "PingFang SC", "Microsoft YaHei", sans-serif;--primary-50: #f0f9f1;--primary-100: #dcf2df;--primary-500: #3d7a4d;--primary-600: #2f6340;--primary-700: #254f34;--primary-rgb: 61, 122, 77;--accent-from: #588157;--accent-to: #9bcf88;--accent-pink: #d6c29d;--bg-base: #edf5ed;--bg-surface: rgba(250, 252, 246, .92);--bg-elevated: #ffffff;--bg-card: rgba(255, 255, 255, .94);--bg-hover: #edf6e7;--glass-highlight: rgba(255, 255, 255, .74);--border-subtle: rgba(99, 139, 111, .18);--border-default: rgba(99, 139, 111, .26);--border-strong: rgba(61, 122, 77, .18);--text-primary: #1f3a2d;--text-secondary: #4f6c56;--text-muted: #7b9580;--sidebar-bg: linear-gradient(180deg, #f8fbf5, #eef6e8);--sidebar-border: rgba(134, 181, 132, .2);--sidebar-shadow: 8px 0 24px rgba(50, 87, 58, .08);--nav-hover-bg: rgba(118, 168, 125, .12);--nav-active-bg: linear-gradient(90deg, #4f7b53, #9bcb8d);--nav-active-color: #ffffff;--nav-active-shadow: 0 8px 20px rgba(75, 127, 82, .18);--logo-shadow: 0 6px 18px rgba(123, 178, 129, .22);--body-glow-a: radial-gradient(circle, rgba(116, 167, 126, .18) 0%, transparent 70%);--body-glow-b: radial-gradient(circle, rgba(211, 232, 192, .2) 0%, transparent 72%);--shadow-card: 0 10px 28px rgba(35, 57, 42, .08);--shadow-glow: 0 12px 40px rgba(123, 178, 129, .12);--shadow-glow-strong: 0 16px 46px rgba(123, 178, 129, .18)}[data-theme=cyberpunk]{--theme-font: "Inter", "Segoe UI", "PingFang SC", sans-serif;--theme-heading-font: "Inter", "Segoe UI", "PingFang SC", sans-serif;--primary-50: #e6fbff;--primary-100: #c4f6ff;--primary-500: #12d6ff;--primary-600: #02b7dd;--primary-700: #0692b0;--primary-rgb: 18, 214, 255;--accent-from: #00f6ff;--accent-to: #ff2fd1;--accent-pink: #8b5cf6;--bg-base: #070812;--bg-surface: rgba(10, 13, 28, .84);--bg-elevated: rgba(18, 22, 45, .92);--bg-card: rgba(18, 21, 40, .88);--bg-hover: rgba(30, 36, 68, .88);--glass-highlight: rgba(255, 255, 255, .04);--border-subtle: rgba(0, 246, 255, .14);--border-default: rgba(125, 90, 255, .24);--border-strong: rgba(255, 47, 209, .22);--text-primary: #f4f8ff;--text-secondary: #9eb2d5;--text-muted: #6e7fa2;--sidebar-bg: linear-gradient(180deg, rgba(11, 14, 29, .96), rgba(25, 8, 40, .96));--sidebar-border: rgba(0, 246, 255, .16);--sidebar-shadow: 10px 0 34px rgba(5, 8, 26, .46);--nav-hover-bg: rgba(0, 246, 255, .1);--nav-active-bg: linear-gradient(90deg, #00eaff, #ff2fd1);--nav-active-color: #07101a;--nav-active-shadow: 0 10px 26px rgba(255, 47, 209, .26);--logo-shadow: 0 0 20px rgba(0, 234, 255, .22);--body-glow-a: radial-gradient(circle, rgba(0, 234, 255, .18) 0%, transparent 70%);--body-glow-b: radial-gradient(circle, rgba(255, 47, 209, .14) 0%, transparent 72%);--shadow-card: 0 18px 42px rgba(0, 0, 0, .3);--shadow-glow: 0 0 28px rgba(0, 234, 255, .18);--shadow-glow-strong: 0 0 52px rgba(255, 47, 209, .2)}[data-theme=inkwash]{--theme-font: "PingFang SC", "Microsoft YaHei", sans-serif;--theme-heading-font: "STKaiti", "KaiTi", "Songti SC", serif;--primary-50: #f6f7f9;--primary-100: #e7ebf0;--primary-500: #4b6177;--primary-600: #374b5f;--primary-700: #273543;--primary-rgb: 75, 97, 119;--accent-from: #26323f;--accent-to: #73879a;--accent-pink: #a7b2bd;--bg-base: #f6f4ef;--bg-surface: rgba(255, 252, 246, .92);--bg-elevated: #fffdfa;--bg-card: rgba(255, 250, 244, .96);--bg-hover: #f0ede6;--glass-highlight: rgba(255, 255, 255, .78);--border-subtle: rgba(96, 112, 129, .16);--border-default: rgba(96, 112, 129, .24);--border-strong: rgba(75, 97, 119, .2);--text-primary: #20262d;--text-secondary: #55606c;--text-muted: #7b8794;--sidebar-bg: linear-gradient(180deg, #fbf8f2, #f1ede5);--sidebar-border: rgba(144, 155, 168, .2);--sidebar-shadow: 8px 0 24px rgba(31, 41, 55, .08);--nav-hover-bg: rgba(75, 97, 119, .08);--nav-active-bg: linear-gradient(90deg, #374151, #708191);--nav-active-color: #ffffff;--nav-active-shadow: 0 10px 22px rgba(55, 65, 81, .14);--logo-shadow: 0 6px 18px rgba(55, 65, 81, .12);--body-glow-a: radial-gradient(circle, rgba(148, 163, 184, .14) 0%, transparent 70%);--body-glow-b: radial-gradient(circle, rgba(216, 212, 201, .22) 0%, transparent 72%);--shadow-card: 0 10px 30px rgba(31, 41, 55, .08);--shadow-glow: 0 12px 36px rgba(112, 129, 145, .1);--shadow-glow-strong: 0 16px 44px rgba(112, 129, 145, .14)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-text-size-adjust:100%}body{margin:0;font-family:var(--theme-font);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:var(--body-glow-a)}body:after{bottom:-10%;right:-10%;width:60vw;height:60vw;background:var(--body-glow-b)}#root{min-height:100vh}a{color:inherit;text-decoration:none}h1,h2,h3,h4{font-family:var(--theme-heading-font);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}select.app-select{appearance:none;-webkit-appearance:none;-moz-appearance:none;padding-right:38px!important;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%2394a3b8' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;background-size:16px 16px;cursor:pointer}select.app-select:hover{border-color:#3b82f673}select.app-select:focus{outline:none}select.app-select option{color:#0f172a;background:#fff}.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 rgba(var(--primary-rgb),.3)}.btn-primary:hover{transform:translateY(-1px);box-shadow:0 4px 20px rgba(var(--primary-rgb),.45)}.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 rgba(var(--primary-rgb),.15)}.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:rgba(var(--primary-rgb),.15);color:var(--primary-500);border-color:rgba(var(--primary-rgb),.28)}.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(var(--primary-rgb),.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:rgba(var(--primary-rgb),.25);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:rgba(var(--primary-rgb),.45)}@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-tone=light] .global-toast{box-shadow:0 12px 24px #0f172a1f}[data-tone=light] .global-toast-success{color:#065f46;background:#ecfdf5f2}[data-tone=light] .global-toast-error{color:#991b1b;background:#fef2f2f2}[data-tone=light] .global-toast-info{color:#1e3a8a;background:#eff6fff2}.anim-login-page{min-height:100vh;display:grid;grid-template-columns:minmax(0,1.18fr) minmax(380px,460px);background:linear-gradient(180deg,#08111c,#0b1625 52%,#0d1828),radial-gradient(circle at top left,rgba(59,130,246,.06),transparent 32%)}.anim-showcase,.anim-login-shell{position:relative}.anim-showcase{overflow:hidden}.anim-showcase:before{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(255,255,255,.04),transparent 24%),linear-gradient(90deg,rgba(255,255,255,.025) 1px,transparent 1px),linear-gradient(rgba(255,255,255,.02) 1px,transparent 1px);background-size:auto,72px 72px,72px 72px;-webkit-mask-image:linear-gradient(to bottom,rgba(0,0,0,.78),transparent 92%);mask-image:linear-gradient(to bottom,rgba(0,0,0,.78),transparent 92%);opacity:.42}.anim-showcase-inner{position:relative;z-index:1;min-height:100vh;display:flex;flex-direction:column;gap:36px;padding:42px 48px 36px;color:#eff6ff}.anim-brand{display:flex;align-items:center;gap:14px}.anim-brand-icon{width:46px;height:46px;border-radius:14px;display:grid;place-items:center;color:#e2e8f0;background:linear-gradient(135deg,#1d4ed83d,#0891b233);border:1px solid rgba(148,163,184,.18);font-size:13px;font-weight:700;letter-spacing:.04em}.anim-brand-icon span{transform:translateY(.5px)}.anim-brand-name{font-size:15px;font-weight:700;letter-spacing:.01em}.anim-brand-sub{margin-top:4px;font-size:12px;color:#e2e8f0b3}.anim-hero-layout{display:grid;grid-template-columns:minmax(0,1fr) minmax(360px,420px);gap:30px;align-items:start}.anim-hero-copy{padding-top:12px;max-width:700px}.anim-hero-badge{width:fit-content;display:inline-flex;align-items:center;min-height:30px;padding:0 12px;border-radius:999px;font-size:12px;letter-spacing:.04em;color:#e2e8f0d1;background:#0f172a66;border:1px solid rgba(148,163,184,.16)}.anim-hero-copy h1{margin-top:18px;max-width:none;font-size:clamp(36px,4.3vw,56px);line-height:1.08;letter-spacing:-.04em;color:#f8fafc}.anim-hero-title-line{display:block;white-space:nowrap}.anim-hero-title-line+.anim-hero-title-line{margin-top:8px}.anim-hero-copy p{margin-top:18px;max-width:620px;font-size:16px;line-height:1.85;color:#e2e8f0b8}.anim-structure-card{padding:22px;border-radius:24px;border:1px solid rgba(148,163,184,.14);background:#0f172a6b;box-shadow:0 18px 46px #0206172e}.anim-structure-head span{display:block;font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:#94a3b8e0}.anim-structure-head strong{display:block;margin-top:8px;font-size:22px;line-height:1.35;color:#f8fafc}.anim-structure-head p{margin-top:10px;font-size:13px;line-height:1.75;color:#e2e8f09e}.anim-structure-list{margin-top:18px;display:grid;gap:10px}.anim-structure-item{display:grid;grid-template-columns:auto 1fr;gap:14px;align-items:start;padding:14px 16px;border-radius:18px;border:1px solid rgba(148,163,184,.12);background:#0206172e}.anim-structure-item em{min-width:34px;height:34px;border-radius:999px;display:inline-flex;align-items:center;justify-content:center;font-style:normal;font-size:12px;font-weight:700;color:#dbeafe;background:#2563eb33}.anim-structure-item strong{display:block;font-size:15px;color:#f8fafc}.anim-structure-item span{display:block;margin-top:4px;font-size:12px;line-height:1.65;color:#e2e8f09e}.anim-capability-grid{margin-top:auto;display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px;max-width:980px}.anim-capability-card{min-height:138px;padding:18px 18px 20px;border-radius:20px;border:1px solid rgba(148,163,184,.12);background:#0f172a47}.anim-capability-card strong{display:block;font-size:15px;line-height:1.5;color:#f8fafc}.anim-capability-card span{display:block;margin-top:10px;font-size:13px;line-height:1.7;color:#e2e8f0ad}.anim-login-shell{display:flex;align-items:center;justify-content:center;padding:30px;background:linear-gradient(180deg,#f5f7fafa,#ecf1f6fa),#eef3f7}.anim-form{width:100%;max-width:408px;padding:34px 30px 30px;border-radius:28px;background:#ffffffe0;border:1px solid rgba(148,163,184,.2);box-shadow:0 24px 56px #0f172a24;backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px)}.anim-login-head-badge{width:fit-content;display:inline-flex;gap:6px;align-items:center;min-height:30px;padding:0 10px;border-radius:999px;color:#0f766e;background:#14b8a61a;border:1px solid rgba(20,184,166,.2);font-size:12px;font-weight:700}.anim-form h2{margin-top:16px;font-size:32px;line-height:1.15;color:#0f172a}.anim-form>p{margin-top:10px;margin-bottom:22px;color:#475569;font-size:14px;line-height:1.7}.anim-form label{display:block;margin:12px 0 8px;font-size:13px;font-weight:600;color:#334155}.anim-input-wrap{position:relative;display:flex;align-items:center}.anim-input-wrap input{width:100%;height:48px;border-radius:14px;border:1px solid rgba(148,163,184,.34);padding:0 42px 0 14px;background:#f8fafcf2;color:#0f172a;font-size:14px;outline:none;transition:border-color .18s ease,box-shadow .18s ease}.anim-input-wrap input:focus{border-color:#0ea5e9d1;box-shadow:0 0 0 4px #0ea5e924}.anim-eye-toggle{position:absolute;right:10px;width:28px;height:28px;display:grid;place-items:center;color:#64748b;border-radius:8px}.anim-eye-toggle:hover{background:#94a3b829;color:#0f172a}.anim-error{margin-top:12px;border-radius:14px;padding:11px 12px;font-size:13px;background:#ef444414;color:#b91c1c;border:1px solid rgba(239,68,68,.18)}.anim-login-options{margin-top:12px}.anim-remember-check{display:inline-flex;align-items:center;gap:8px;color:#475569;font-size:13px}.anim-remember-check input{width:14px;height:14px}.anim-recent-users{margin-top:12px;display:flex;align-items:center;gap:8px;flex-wrap:wrap;color:#64748b;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:#e2e8f0b3;color:#0f172a;font-size:12px}.anim-recent-btn:hover{border-color:#0ea5e966}.anim-submit{margin-top:18px;width:100%;height:50px;border-radius:16px;border:0;display:inline-flex;align-items:center;justify-content:center;gap:8px;color:#eff6ff;font-weight:700;letter-spacing:.01em;background:linear-gradient(135deg,#0f766e,#0284c7);box-shadow:0 14px 32px #0284c73d;transition:transform .18s ease,box-shadow .18s ease,opacity .18s ease}.anim-submit:hover{transform:translateY(-1px);box-shadow:0 18px 36px #0284c747}.anim-submit:disabled{opacity:.65;transform:none;cursor:not-allowed}.anim-signup-hint{margin-top:14px;text-align:center;font-size:13px;color:#64748b;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:#0f172a;font-weight:700;text-decoration:underline;text-underline-offset:2px}.anim-contact-link:hover{color:#0284c7}.anim-contact-backdrop{position:fixed;inset:0;z-index:1000;background:#0206178f;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);display:grid;place-items:center;padding:20px}.anim-contact-modal{width:min(520px,100%);border-radius:24px;background:#fff;border:1px solid rgba(148,163,184,.22);box-shadow:0 24px 70px #0206174d;padding:24px;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:#f8fafc;color:#64748b;display:grid;place-items:center}.anim-contact-close:hover{color:#0f172a;border-color:#0ea5e96b}.anim-contact-title-wrap h3{margin:0;padding-right:48px;font-size:24px;line-height:1.2;color:#0f172a}.anim-contact-title-wrap p{margin:10px 0 0;color:#475569;font-size:14px;line-height:1.6}.anim-contact-qr-wrap{margin-top:18px;border-radius:18px;border:1px solid rgba(148,163,184,.2);background:#f8fafc;padding:16px;display:flex;justify-content:center}.anim-contact-qr{width:min(320px,100%);border-radius:12px;border:1px solid rgba(148,163,184,.22);background:#fff;display:block}@media(max-width:1280px){.anim-login-page{grid-template-columns:1fr}.anim-showcase-inner{min-height:auto}.anim-hero-layout,.anim-capability-grid{grid-template-columns:1fr}}@media(max-width:720px){.anim-showcase-inner,.anim-login-shell{padding:20px}.anim-hero-copy h1{font-size:34px}.anim-hero-title-line{white-space:normal}.anim-form{padding:24px 20px}}.app-layout{display:flex;min-height:100vh;background:var(--bg-base)}.sidebar{width:220px;flex-shrink:0;background:var(--sidebar-bg);border-right:1px solid var(--sidebar-border);box-shadow:var(--sidebar-shadow);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:var(--logo-shadow);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:13px;font-weight:700;color:var(--text-primary);line-height:1.2}.logo-sub{font-size:10px;color:var(--text-muted);line-height:1.2}.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:var(--nav-hover-bg);border-color:var(--border-subtle);color:var(--text-primary);transform:translate(4px)}.nav-item-active{background:var(--nav-active-bg);color:var(--nav-active-color)!important;box-shadow:var(--nav-active-shadow)}.nav-item-active .nav-chevron{opacity:1;color:var(--nav-active-color)}.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}.theme-picker{margin-bottom:10px}.theme-picker-label{display:flex;align-items:center;gap:8px;margin-bottom:8px;color:var(--text-secondary);font-size:12px;font-weight:700}.theme-picker-select{min-height:38px;font-size:12px;padding-top:0;padding-bottom:0}.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-last{margin-bottom:10px}.sidebar-collapsed .sidebar-collapsed-key{margin:0;padding:10px;min-height:38px}.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-tone=light] .role-tag-admin{color:#1d4ed8;background:#3b82f61a}[data-tone=light] .role-tag-member{color:#047857;background:#10b9811a}[data-tone=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-tone=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}.theme-picker{display: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}}.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-tone=light] .modal-overlay{background:#0f172a47}[data-tone=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}.readonly-banner{margin:0 0 16px;padding:12px 16px;border-radius:14px;border:1px solid rgba(245,158,11,.24);background:#f59e0b1a;color:var(--text-primary);font-size:13px}.download-dock{position:fixed;right:22px;bottom:22px;z-index:1150;width:min(360px,calc(100vw - 32px))}.download-dock-toggle{width:100%;display:flex;align-items:center;justify-content:space-between;gap:12px;padding:14px 16px;border-radius:18px;border:1px solid rgba(59,130,246,.22);background:#0f172aeb;color:#e2e8f0;box-shadow:0 18px 40px #0f172a3d;backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px)}.download-dock-toggle-main{display:inline-flex;align-items:center;gap:10px;font-size:13px;font-weight:700}.download-dock-toggle-main strong{color:#93c5fd}.download-dock-chevron{transition:transform var(--transition-fast)}.download-dock-chevron.is-open{transform:rotate(180deg)}.download-dock-panel{margin-top:10px;padding:12px;border-radius:22px;border:1px solid rgba(148,163,184,.18);background:#0f172af0;box-shadow:0 18px 42px #0f172a47;display:grid;gap:10px}.download-dock-item{padding:12px;border-radius:16px;border:1px solid rgba(148,163,184,.16);background:#ffffff0a}.download-dock-item-head{display:flex;align-items:flex-start;justify-content:space-between;gap:8px}.download-dock-item-title{color:#f8fafc;font-size:13px;font-weight:700;line-height:1.5}.download-dock-close{width:24px;height:24px;border-radius:999px;border:1px solid rgba(148,163,184,.18);background:#ffffff0a;color:#cbd5e1;display:inline-flex;align-items:center;justify-content:center}.download-dock-item-meta,.download-dock-progress-text{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-top:8px;font-size:11px;color:#94a3b8}.download-dock-progress{margin-top:10px}.download-dock-progress-bar{width:100%;height:6px;overflow:hidden;border-radius:999px;background:#94a3b82e}.download-dock-progress-fill{height:100%;border-radius:inherit;background:linear-gradient(90deg,#22c55e,#38bdf8)}.download-dock-progress-fill.is-indeterminate{width:42%;animation:downloadDockIndeterminate 1.4s ease-in-out infinite}.download-dock-error{margin-top:8px;color:#fecaca;font-size:11px;line-height:1.5}@keyframes downloadDockIndeterminate{0%{transform:translate(-100%)}to{transform:translate(240%)}}[data-tone=light] .download-dock-toggle{background:#fffffff5;color:#0f172a;border-color:#94a3b83d;box-shadow:0 14px 30px #0f172a24}[data-tone=light] .download-dock-panel{background:#fffffff7;box-shadow:0 16px 32px #0f172a24}[data-tone=light] .download-dock-item{background:#f8fafcf5}[data-tone=light] .download-dock-item-title{color:#0f172a}[data-tone=light] .download-dock-item-meta,[data-tone=light] .download-dock-progress-text{color:#64748b}@media(max-width:960px){.download-dock{right:14px;bottom:14px;width:min(320px,calc(100vw - 20px))}}
