:root{--color-primary: #3b82f6;--color-primary-hover: #2563eb;--color-primary-light: #eff6ff;--color-primary-ring: rgba(59, 130, 246, .15);--color-success: #22c55e;--color-success-light: #f0fdf4;--color-warning: #f59e0b;--color-warning-light: #fffbeb;--color-danger: #ef4444;--color-danger-light: #fef2f2;--color-info: #6366f1;--color-info-light: #eef2ff;--color-white: #ffffff;--color-gray-50: #f8fafc;--color-gray-100: #f1f5f9;--color-gray-200: #e2e8f0;--color-gray-300: #cbd5e1;--color-gray-400: #94a3b8;--color-gray-500: #64748b;--color-gray-600: #475569;--color-gray-700: #334155;--color-gray-800: #1e293b;--color-gray-900: #0f172a;--color-bg: var(--color-gray-50);--color-surface: var(--color-white);--color-border: var(--color-gray-200);--color-border-hover: var(--color-gray-300);--color-text: var(--color-gray-800);--color-text-secondary: var(--color-gray-500);--color-text-muted: var(--color-gray-400);--font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;--font-mono: "SF Mono", "Fira Code", "Fira Mono", Menlo, Consolas, "DejaVu Sans Mono", monospace;--text-xs: .75rem;--text-sm: .8125rem;--text-base: .875rem;--text-lg: 1rem;--text-xl: 1.25rem;--text-2xl: 1.5rem;--font-normal: 400;--font-medium: 500;--font-semibold: 600;--font-bold: 700;--leading-tight: 1.25;--leading-normal: 1.5;--leading-relaxed: 1.625;--space-1: .25rem;--space-2: .5rem;--space-3: .75rem;--space-4: 1rem;--space-5: 1.25rem;--space-6: 1.5rem;--space-8: 2rem;--space-10: 2.5rem;--space-12: 3rem;--space-16: 4rem;--space-20: 5rem;--radius-sm: 4px;--radius-md: 6px;--radius-lg: 8px;--radius-xl: 12px;--radius-full: 9999px;--shadow-xs: 0 1px 2px rgba(0, 0, 0, .04);--shadow-sm: 0 1px 3px rgba(0, 0, 0, .06), 0 1px 2px rgba(0, 0, 0, .04);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .07), 0 2px 4px -2px rgba(0, 0, 0, .05);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .08), 0 4px 6px -4px rgba(0, 0, 0, .04);--shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, .08), 0 8px 10px -6px rgba(0, 0, 0, .04);--shadow-focus: 0 0 0 3px var(--color-primary-ring);--transition-fast: .1s ease;--transition-normal: .15s ease;--transition-slow: .25s ease;--z-dropdown: 10;--z-sticky: 20;--z-header: 30;--z-overlay: 40;--z-modal: 50;--z-toast: 60;--header-height: 48px;--sidebar-width: 190px;--content-max-width: 1200px}:root{--color-viewer-bg: #ffffff}.dark{--color-bg: #020812;--color-surface: #041025;--color-border: #0b2a44;--color-border-hover: #123254;--color-text: #dbeeff;--color-text-secondary: #9ec7ff;--color-text-muted: #7faed6;--color-white: #071833;--color-primary-light: rgba(59,130,246,.14);--color-primary-ring: rgba(59,130,246,.22);--color-viewer-bg: #0b1220}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-text-size-adjust:100%}body{min-height:100vh;font-family:var(--font-family);font-size:var(--text-base);line-height:var(--leading-normal);color:var(--color-text);background:var(--color-bg);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility}h1,h2,h3,h4,h5,h6{font-weight:var(--font-semibold);line-height:var(--leading-tight);color:var(--color-text)}h1{font-size:var(--text-2xl)}h2{font-size:var(--text-xl)}h3{font-size:var(--text-lg)}p{margin-bottom:var(--space-3)}a{color:var(--color-primary);text-decoration:none;transition:color var(--transition-fast)}a:hover{color:var(--color-primary-hover)}code,pre{font-family:var(--font-mono);font-size:var(--text-sm)}input,select,textarea,button{font-family:inherit;font-size:inherit;line-height:inherit}button{cursor:pointer;border:none;background:none}img,svg{display:block;max-width:100%}ul,ol{list-style:none}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--color-gray-300);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--color-gray-400)}::selection{background:var(--color-primary);color:var(--color-white)}#app{min-height:100vh}.flex{display:flex}.flex-col{flex-direction:column}.flex-wrap{flex-wrap:wrap}.items-center{align-items:center}.justify-between{justify-content:space-between}.justify-center{justify-content:center}.gap-1{gap:var(--space-1)}.gap-2{gap:var(--space-2)}.gap-3{gap:var(--space-3)}.gap-4{gap:var(--space-4)}.gap-6{gap:var(--space-6)}.mt-1{margin-top:var(--space-1)}.mt-2{margin-top:var(--space-2)}.mt-4{margin-top:var(--space-4)}.mb-2{margin-bottom:var(--space-2)}.mb-4{margin-bottom:var(--space-4)}.mb-6{margin-bottom:var(--space-6)}.p-2{padding:var(--space-2)}.p-4{padding:var(--space-4)}.p-6{padding:var(--space-6)}.px-4{padding-left:var(--space-4);padding-right:var(--space-4)}.px-6{padding-left:var(--space-6);padding-right:var(--space-6)}.py-2{padding-top:var(--space-2);padding-bottom:var(--space-2)}.py-4{padding-top:var(--space-4);padding-bottom:var(--space-4)}.text-xs{font-size:var(--text-xs)}.text-sm{font-size:var(--text-sm)}.text-base{font-size:var(--text-base)}.text-lg{font-size:var(--text-lg)}.text-xl{font-size:var(--text-xl)}.font-medium{font-weight:var(--font-medium)}.font-semibold{font-weight:var(--font-semibold)}.font-bold{font-weight:var(--font-bold)}.text-muted{color:var(--color-text-muted)}.text-secondary{color:var(--color-text-secondary)}.text-primary{color:var(--color-primary)}.text-center{text-align:center}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.hidden{display:none}.block{display:block}.inline-flex{display:inline-flex}.w-full{width:100%}.border{border:1px solid var(--color-border)}.border-t{border-top:1px solid var(--color-border)}.border-b{border-bottom:1px solid var(--color-border)}.rounded-md{border-radius:var(--radius-md)}.rounded-lg{border-radius:var(--radius-lg)}.rounded-xl{border-radius:var(--radius-xl)}.rounded-full{border-radius:var(--radius-full)}.shadow-sm{box-shadow:var(--shadow-sm)}.shadow-md{box-shadow:var(--shadow-md)}.shadow-lg{box-shadow:var(--shadow-lg)}@keyframes spin{to{transform:rotate(360deg)}}@keyframes fade-in{0%{opacity:0}to{opacity:1}}@keyframes slide-up{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.animate-spin{animation:spin .8s linear infinite}.animate-fade-in{animation:fade-in .2s ease}.animate-slide-up{animation:slide-up .25s ease}.simple-scrollbar::-webkit-scrollbar{width:6px;height:6px}.simple-scrollbar::-webkit-scrollbar-track{background:transparent}.simple-scrollbar::-webkit-scrollbar-thumb{background:var(--color-gray-300);border-radius:3px}.simple-scrollbar::-webkit-scrollbar-thumb:hover{background:var(--color-gray-400)}.layout-main{scrollbar-width:thin;scrollbar-color:var(--color-gray-300) transparent}.layout-main::-webkit-scrollbar{width:6px}.layout-main::-webkit-scrollbar-track{background:transparent}.layout-main::-webkit-scrollbar-thumb{background:var(--color-gray-300);border-radius:3px}.layout-main::-webkit-scrollbar-thumb:hover{background:var(--color-gray-400)}.dark input,.dark textarea,.dark select{background:var(--color-surface);color:var(--color-text);border:1px solid var(--color-border)}.panel,.card,.project-card,.viewer-area,.projects-list .project-card{background:var(--color-panel, var(--color-surface))}.dark .btn-main{background:var(--color-primary);color:var(--color-white);border:1px solid transparent;padding:8px 14px;border-radius:6px}.dark .btn-main:hover:not(:disabled){background:var(--color-primary-hover)}.dark .btn-sub{background:var(--color-surface);color:var(--color-text);border:1px solid var(--color-border);padding:8px 14px;border-radius:6px}.dark .btn-sub:hover:not(:disabled){background:var(--color-border-hover)}.btn-main,.btn-sub,button,.user-menu-item,.theme-toggle,.logout-btn,.not-signed-in .sign-in,.user-pill{background:transparent;color:var(--color-text);border:1px solid var(--color-white);padding:8px 12px;border-radius:6px}.btn-main:hover:not(:disabled),.btn-sub:hover:not(:disabled),button:hover:not(:disabled){background:#ffffff0a}*{margin:0;padding:0;box-sizing:border-box}.signout-toast{position:fixed;left:50%;top:50%;transform:translate(-50%,-50%);background:#000000d9;color:#fff;padding:12px 18px;border-radius:8px;z-index:9999;font-weight:600;box-shadow:0 6px 18px #0003}.app-header[data-v-91bbccb2]{position:fixed;top:0;left:0;right:0;z-index:1000;height:var(--header-height);background:var(--color-surface);border-bottom:none}.header-inner[data-v-91bbccb2]{display:flex;align-items:center;justify-content:space-between;gap:var(--space-4);height:100%;width:100%;padding:0 var(--space-2) 0 var(--space-3)}.header-left[data-v-91bbccb2]{display:flex;align-items:center;width:var(--sidebar-width);min-width:var(--sidebar-width);flex-shrink:0}.logo[data-v-91bbccb2]{display:flex;align-items:center;gap:var(--space-2);text-decoration:none}.logo-text[data-v-91bbccb2]{font-size:17px;font-weight:var(--font-bold);color:var(--color-text)}.logo-icon[data-v-91bbccb2]{width:48px;height:48px;display:block;object-fit:contain}.header-center[data-v-91bbccb2]{display:flex;align-items:center;flex:1;min-width:0;overflow:hidden}.header-right[data-v-91bbccb2]{display:flex;align-items:center;justify-content:flex-end;gap:var(--space-2);width:var(--sidebar-width);min-width:0;flex-shrink:0;z-index:1001}.header-right[data-v-91bbccb2]{position:relative}.user-avatar[data-v-91bbccb2]{width:30px;height:30px;border-radius:var(--radius-full);background:var(--color-primary);display:flex;align-items:center;justify-content:center;font-size:var(--text-xs);font-weight:var(--font-semibold);color:var(--color-white);cursor:pointer;flex-shrink:0}.user-avatar[data-v-91bbccb2]{order:2;margin-left:6px}.theme-toggle[data-v-91bbccb2]{background:transparent;border:1px solid transparent;padding:6px;border-radius:6px;cursor:pointer;display:inline-flex;align-items:center;justify-content:center}.theme-toggle[data-v-91bbccb2]:hover{background:var(--color-hover)}.theme-icon[data-v-91bbccb2]{width:18px;height:18px;color:var(--color-text);display:block}.header-actions[data-v-91bbccb2]{order:1}.user-pill[data-v-91bbccb2]{display:inline-flex;align-items:center;gap:8px;background:transparent;border:1px solid transparent;padding:6px 10px;border-radius:999px;cursor:pointer;color:var(--color-text);position:relative;z-index:1002}.pill-avatar[data-v-91bbccb2]{width:30px;height:30px;border-radius:50%;background:var(--color-primary);display:flex;align-items:center;justify-content:center;color:var(--color-white);font-weight:600;font-size:12px}.pill-name[data-v-91bbccb2]{font-size:13px;font-weight:600;max-width:140px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.pill-chevron[data-v-91bbccb2]{color:var(--color-text-secondary)}.user-menu[data-v-91bbccb2]{position:absolute;right:12px;top:calc(var(--header-height) + 10px);min-width:140px;background:var(--color-surface);border:1px solid var(--color-border);border-radius:10px;box-shadow:0 8px 20px #02081299;padding:8px;display:flex;flex-direction:column;gap:6px;z-index:1003}.user-menu[data-v-91bbccb2]:before{content:"";position:absolute;right:22px;top:-6px;width:12px;height:12px;transform:rotate(45deg);background:var(--color-surface);border-left:1px solid var(--color-border);border-top:1px solid var(--color-border)}.user-menu-item[data-v-91bbccb2]{display:flex;align-items:center;gap:10px;padding:8px 10px;border-radius:8px;background:transparent;color:var(--color-text);text-align:left;border:none;cursor:pointer}.user-menu-item[data-v-91bbccb2]:hover{background:var(--color-border-hover)}.user-menu-item .menu-icon[data-v-91bbccb2]{width:34px;height:34px;border-radius:50%;display:flex;align-items:center;justify-content:center;background:var(--color-primary);color:var(--color-white);flex-shrink:0}.user-menu-item .menu-label[data-v-91bbccb2]{font-size:14px}.header-actions[data-v-91bbccb2]{display:flex;align-items:center;gap:8px;margin-right:6px}.icon-link[data-v-91bbccb2]{text-decoration:none;font-size:16px}.not-signed-in .sign-in[data-v-91bbccb2]{color:var(--color-primary);text-decoration:none;padding:6px 10px;border-radius:6px;background:transparent}.logout-btn[data-v-91bbccb2]{margin-left:8px;background:transparent;border:none;color:var(--color-text-muted);cursor:pointer;font-size:14px}.logout-btn[data-v-91bbccb2]:hover{color:var(--color-text)}.user-menu-item .icon[data-v-91bbccb2]{width:16px;height:16px;vertical-align:middle;display:inline-block}@media(max-width:1024px){.header-left[data-v-91bbccb2]{width:auto;min-width:auto}.header-right[data-v-91bbccb2]{width:auto}}.sidebar-nav[data-v-2714afb5]{position:relative;width:var(--sidebar-width);min-width:var(--sidebar-width);height:100%;background:var(--color-bg);border-right:1px solid var(--color-border);padding:var(--space-3) var(--space-2);display:flex;flex-direction:column;overflow-y:auto;transition:width .2s ease,min-width .2s ease,padding .2s ease}.sidebar-nav.collapsed[data-v-2714afb5]{width:50px;min-width:50px;padding-left:6px;padding-right:6px}.sidebar-menu[data-v-2714afb5]{display:flex;flex-direction:column;gap:var(--space-6)}.collapse-handle[data-v-2714afb5]{position:absolute;top:50%;right:0;transform:translateY(-50%);width:18px;height:64px;border:1px;background:var(--color-bg);display:flex;align-items:center;justify-content:center;color:var(--color-text-muted);cursor:pointer;z-index:40;padding:0;overflow:visible}.collapse-handle .collapse-icon[data-v-2714afb5]{color:currentColor;display:block}.collapse-handle .collapse-icon polyline[data-v-2714afb5]{stroke:currentColor;stroke-width:2.5}.menu[data-v-2714afb5]{width:125px;height:99%;background:linear-gradient(#ff993a,#ffb773);font-size:20px;float:left;position:fixed;border-radius:15px;margin:.25% 0 0 5px}.menu>a[data-v-2714afb5]{position:relative;top:20px;display:block;text-decoration:none;text-transform:uppercase;width:80%;height:50px;text-align:center;float:right;border-radius:10px 0 0 10px;margin-top:20px;line-height:50px;transition:color .5s;color:#fdfff4}.menu>a[data-v-2714afb5]:target{color:#2a2a2a;background-color:#fdfff4}.collapse-handle[data-v-2714afb5]:after,.collapse-handle[data-v-2714afb5]:before{content:"";position:absolute;top:-20px;right:0;width:20px;height:20px;border-radius:0 0 20px;z-index:-1}.collapse-handle[data-v-2714afb5]:before{top:auto;bottom:-20px;border-radius:0 20px 0 0}.collapse-handle[data-v-2714afb5]:after{box-shadow:0 20px 0 0 var(--color-bg)}.collapse-handle[data-v-2714afb5]:before{box-shadow:0 -20px 0 0 var(--color-bg)}.menu-group[data-v-2714afb5]{display:flex;flex-direction:column;gap:2px}.menu-group-title[data-v-2714afb5]{display:flex;align-items:center;gap:var(--space-2);padding:6px var(--space-2);border:none;background:none;cursor:pointer;font-size:var(--text-xs);font-weight:var(--font-semibold);color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:var(--space-1)}.menu-group-title[data-v-2714afb5]:hover{color:var(--color-text-secondary)}.expand-arrow[data-v-2714afb5]{transition:transform .2s;flex-shrink:0}.expand-arrow.rotated[data-v-2714afb5]{transform:rotate(90deg)}.menu-item[data-v-2714afb5]{display:flex;align-items:center;gap:var(--space-3);padding:8px var(--space-3);border-radius:var(--radius-lg);text-decoration:none;font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--color-text-secondary);transition:all var(--transition-fast);cursor:pointer}.menu-item[data-v-2714afb5]:hover{background:var(--color-gray-100);color:var(--color-text)}.menu-item.active[data-v-2714afb5]{background:var(--color-primary-light);color:var(--color-primary)}.menu-icon[data-v-2714afb5]{flex-shrink:0;opacity:.7}.sidebar-nav.collapsed .menu-group-title[data-v-2714afb5],.sidebar-nav.collapsed .menu-label[data-v-2714afb5],.sidebar-nav.collapsed .external-icon[data-v-2714afb5],.sidebar-nav.collapsed .expand-arrow[data-v-2714afb5]{display:none}.sidebar-nav.collapsed .menu-item[data-v-2714afb5]{justify-content:center;padding-left:6px;padding-right:6px}.sidebar-nav.collapsed .menu-group[data-v-2714afb5]{gap:6px}.menu-item.active .menu-icon[data-v-2714afb5]{opacity:1}.menu-label[data-v-2714afb5]{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.menu-group-items[data-v-2714afb5]{display:flex;flex-direction:column;gap:2px}.external-icon[data-v-2714afb5]{margin-left:auto;opacity:0;transition:opacity var(--transition-fast);flex-shrink:0}.menu-item.external:hover .external-icon[data-v-2714afb5]{opacity:.5}@media(max-width:1024px){.sidebar-nav[data-v-2714afb5]{display:none}}.default-layout[data-v-6c333cc7]{height:100vh;width:100vw;overflow:hidden;display:flex;flex-direction:column;background:var(--color-bg)}.layout-body[data-v-6c333cc7]{height:100vh;width:100vw;overflow:hidden;display:flex;flex-direction:column}.header-spacer[data-v-6c333cc7]{height:var(--header-height);width:100%;flex-shrink:0}.layout-row[data-v-6c333cc7]{position:relative;display:flex;height:calc(100vh - var(--header-height))}.layout-main[data-v-6c333cc7]{flex:1;height:100%;overflow-y:auto;padding:var(--space-6) 0 var(--space-16) 0}.layout-main--full[data-v-6c333cc7]{padding:0;overflow:hidden}.layout-content[data-v-6c333cc7]{max-width:var(--content-max-width);margin:0 auto;padding:0 var(--space-8)}.layout-content-full[data-v-6c333cc7]{width:100%;height:100%}@media(max-width:1024px){.layout-content[data-v-6c333cc7]{padding:0 var(--space-4)}}
