:root{--text:#6b6375;--text-h:#08060d;--bg:#fff;--border:#e5e4e7;--code-bg:#f4f3ec;--accent:#aa3bff;--accent-bg:#aa3bff1a;--accent-border:#aa3bff80;--social-bg:#f4f3ec80;--shadow:#0000001a 0 10px 15px -3px, #0000000d 0 4px 6px -2px;--sans:system-ui, "Segoe UI", Roboto, sans-serif;--heading:system-ui, "Segoe UI", Roboto, sans-serif;--mono:ui-monospace, Consolas, monospace;font:18px/145% var(--sans);letter-spacing:.18px;--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light dark;color:var(--text);background:var(--bg);font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}@media (prefers-color-scheme:dark){:root{--lightningcss-light: ;--lightningcss-dark:initial}}@media (width<=1024px){:root{font-size:16px}}@media (prefers-color-scheme:dark){:root{--text:#9ca3af;--text-h:#f3f4f6;--bg:#16171d;--border:#2e303a;--code-bg:#1f2028;--accent:#c084fc;--accent-bg:#c084fc26;--accent-border:#c084fc80;--social-bg:#2f303a80;--shadow:#0006 0 10px 15px -3px, #00000040 0 4px 6px -2px}#social .button-icon{filter:invert()brightness(2)}}body{margin:0}#root{text-align:center;border-inline:1px solid var(--border);box-sizing:border-box;flex-direction:column;width:1126px;max-width:100%;min-height:100svh;margin:0 auto;display:flex}h1,h2{font-family:var(--heading);color:var(--text-h);font-weight:500}h1{letter-spacing:-1.68px;margin:32px 0;font-size:56px}@media (width<=1024px){h1{margin:20px 0;font-size:36px}}h2{letter-spacing:-.24px;margin:0 0 8px;font-size:24px;line-height:118%}@media (width<=1024px){h2{font-size:20px}}p{margin:0}code,.counter{font-family:var(--mono);color:var(--text-h);border-radius:4px;display:inline-flex}code{background:var(--code-bg);padding:4px 8px;font-size:15px;line-height:135%}*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--bg:#fff;--bg-secondary:#f7f7f8;--bg-tertiary:#efefef;--surface:#fff;--border:#e5e5e5;--border-light:#f0f0f0;--text:#111;--text-secondary:#666;--text-muted:#999;--accent:#2563eb;--accent-hover:#1d4ed8;--accent-light:#eff6ff;--success:#22c55e;--danger:#ef4444;--danger-light:#fef2f2;--warning:#f59e0b;--sidebar-w:240px;--header-h:56px;--radius:8px;--radius-lg:12px;--shadow:0 1px 3px #00000014;--shadow-lg:0 4px 16px #0000001a;--font:"Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif}html{font-size:14px}body{font-family:var(--font);background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;line-height:1.5}a{color:inherit;text-decoration:none}button{cursor:pointer;background:0 0;border:none;font-family:inherit}input,select{font-family:inherit;font-size:inherit}img{max-width:100%}.landing{background:var(--bg);min-height:100vh}.landing-header{z-index:100;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-bottom:1px solid var(--border);background:#ffffffe6;position:sticky;top:0}.landing-header-inner{justify-content:space-between;align-items:center;max-width:1100px;height:60px;margin:0 auto;padding:0 24px;display:flex}.landing-logo{letter-spacing:-.02em;align-items:center;gap:8px;font-size:1.1rem;font-weight:700;display:flex}.landing-logo-icon{width:28px;height:28px;color:var(--accent)}.landing-logo-icon svg{width:100%;height:100%}.landing-nav{align-items:center;gap:32px;display:flex}.landing-nav a{color:var(--text-secondary);font-size:.9rem;transition:color .15s}.landing-nav a:hover{color:var(--text)}.landing-btn-outline{border:1px solid var(--border);border-radius:var(--radius);color:var(--text);padding:8px 16px;font-size:.875rem;font-weight:500;transition:all .15s}.landing-btn-outline:hover{border-color:var(--text);background:var(--bg-secondary)}.landing-hero{max-width:1100px;margin:0 auto;padding:100px 24px 80px}.landing-hero-badge{background:var(--accent-light);color:var(--accent);border-radius:100px;align-items:center;gap:6px;margin-bottom:24px;padding:6px 12px;font-size:.8rem;font-weight:600;display:inline-flex}.landing-hero-title{letter-spacing:-.03em;color:var(--text);margin-bottom:20px;font-size:clamp(2.2rem,5vw,3.5rem);font-weight:700;line-height:1.1}.landing-hero-subtitle{color:var(--text-secondary);max-width:540px;margin-bottom:36px;font-size:1.1rem;line-height:1.7}.landing-hero-actions{flex-wrap:wrap;gap:16px;display:flex}.landing-btn-primary{background:var(--accent);color:#fff;border-radius:var(--radius);align-items:center;gap:8px;padding:12px 24px;font-size:.95rem;font-weight:600;transition:background .15s;display:inline-flex}.landing-btn-primary:hover{background:var(--accent-hover)}.landing-btn-primary svg{width:16px;height:16px}.landing-btn-ghost{color:var(--text-secondary);align-items:center;gap:8px;padding:12px 20px;font-weight:500;transition:color .15s;display:inline-flex}.landing-btn-ghost:hover{color:var(--text)}.landing-logos{border-top:1px solid var(--border);border-bottom:1px solid var(--border);padding:24px 0;overflow:hidden}.landing-logos-track{white-space:nowrap;justify-content:center;gap:48px;animation:20s linear infinite scroll-logos;display:flex}.landing-logos-track span{color:var(--text-muted);letter-spacing:.05em;text-transform:uppercase;font-size:.85rem;font-weight:600}@keyframes scroll-logos{0%{transform:translate(0)}to{transform:translate(-50%)}}.landing-services{max-width:1100px;margin:0 auto;padding:80px 24px}.landing-section-label{text-transform:uppercase;letter-spacing:.1em;color:var(--accent);margin-bottom:12px;font-size:.75rem;font-weight:700}.landing-section-title{letter-spacing:-.02em;margin-bottom:48px;font-size:clamp(1.6rem,3vw,2.2rem);font-weight:700;line-height:1.2}.landing-services-grid{grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:24px;display:grid}.landing-service-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:28px;transition:box-shadow .2s}.landing-service-card:hover{box-shadow:var(--shadow-lg)}.landing-service-icon{width:40px;height:40px;color:var(--accent);margin-bottom:16px}.landing-service-icon svg{width:100%;height:100%}.landing-service-card h3{margin-bottom:8px;font-size:1rem;font-weight:600}.landing-service-card p{color:var(--text-secondary);font-size:.9rem;line-height:1.6}.landing-why{grid-template-columns:1fr 1fr;align-items:start;gap:80px;max-width:1100px;margin:0 auto;padding:80px 24px;display:grid}.landing-why-text{color:var(--text-secondary);margin-bottom:32px;line-height:1.7}.landing-why-stats{gap:32px;display:flex}.landing-why-stat-value{letter-spacing:-.02em;color:var(--text);font-size:2rem;font-weight:700}.landing-why-stat-label{color:var(--text-muted);font-size:.8rem;font-weight:500}.landing-feature-list{flex-direction:column;gap:20px;display:flex}.landing-feature{align-items:flex-start;gap:14px;display:flex}.landing-feature-check{width:20px;min-width:20px;height:20px;color:var(--success);margin-top:2px}.landing-feature-check svg{width:100%;height:100%}.landing-feature strong{margin-bottom:2px;font-size:.9rem;font-weight:600;display:block}.landing-feature p{color:var(--text-secondary);font-size:.85rem}.landing-cta{background:var(--bg-secondary);border-top:1px solid var(--border);text-align:center;padding:80px 24px}.landing-cta-content{max-width:500px;margin:0 auto}.landing-cta h2{letter-spacing:-.02em;margin-bottom:12px;font-size:1.8rem;font-weight:700}.landing-cta p{color:var(--text-secondary);margin-bottom:28px}.landing-footer{border-top:1px solid var(--border);padding:32px 24px}.landing-footer-content{justify-content:space-between;align-items:center;max-width:1100px;margin:0 auto;display:flex}.landing-footer p{color:var(--text-muted);font-size:.8rem}.landing-footer-logo{align-items:center;gap:8px;font-weight:700;display:flex}.login-page{min-height:100vh;display:flex}.login-split-left{background:var(--bg-secondary);border-right:1px solid var(--border);flex-direction:column;flex:1;justify-content:space-between;padding:48px;display:flex}.login-brand{align-items:center;gap:8px;font-size:1rem;font-weight:700;display:flex}.login-brand-logo{width:28px;height:28px;color:var(--accent)}.login-brand-logo svg{width:100%;height:100%}.login-left-content h1{letter-spacing:-.02em;margin-bottom:12px;font-size:2rem;font-weight:700}.login-left-content>p{color:var(--text-secondary);max-width:340px;margin-bottom:32px;line-height:1.6}.login-left-features{flex-direction:column;gap:12px;display:flex}.login-left-feature{color:var(--text-secondary);align-items:center;gap:10px;font-size:.9rem;display:flex}.login-left-feature svg{width:16px;height:16px;color:var(--success);flex-shrink:0}.login-split-right{flex:1;justify-content:center;align-items:center;padding:48px;display:flex}.login-card{width:100%;max-width:380px}.login-card-header{margin-bottom:32px}.login-card-header h2{letter-spacing:-.02em;margin-bottom:6px;font-size:1.5rem;font-weight:700}.login-card-header p{color:var(--text-secondary);font-size:.9rem}.login-form{flex-direction:column;gap:20px;display:flex}.login-field{flex-direction:column;gap:6px;display:flex}.login-field label{color:var(--text-secondary);font-size:.8rem;font-weight:600}.login-field input{border:1px solid var(--border);border-radius:var(--radius);padding:11px 14px;font-size:.95rem;transition:border-color .15s}.login-field input:focus{border-color:var(--accent);outline:none}.login-error{background:var(--danger-light);color:var(--danger);border-radius:var(--radius);padding:10px 14px;font-size:.85rem}.login-submit{background:var(--accent);color:#fff;border-radius:var(--radius);margin-top:4px;padding:12px;font-size:.95rem;font-weight:600;transition:background .15s}.login-submit:hover{background:var(--accent-hover)}.login-submit:disabled{opacity:.7;cursor:not-allowed}.login-back{text-align:center;margin-top:24px}.login-back a{color:var(--text-muted);cursor:pointer;font-size:.85rem;transition:color .15s}.login-back a:hover{color:var(--text)}.dashboard{background:var(--bg-secondary);min-height:100vh;display:flex}.sidebar{width:var(--sidebar-w);background:var(--surface);border-right:1px solid var(--border);z-index:50;flex-direction:column;min-height:100vh;transition:transform .25s;display:flex;position:fixed;top:0;left:0}.sidebar-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:20px 16px;display:flex}.sidebar-logo{align-items:center;gap:8px;font-size:.95rem;font-weight:700;display:flex}.sidebar-logo-icon{width:24px;height:24px;color:var(--accent)}.sidebar-logo-icon svg{width:100%;height:100%}.sidebar-close{color:var(--text-muted);padding:4px;display:none}.sidebar-close svg{width:18px;height:18px}.sidebar-nav{flex-direction:column;flex:1;gap:2px;padding:12px 8px;display:flex}.sidebar-nav-link{border-radius:var(--radius);color:var(--text-secondary);cursor:pointer;align-items:center;gap:10px;padding:10px 12px;font-size:.9rem;font-weight:500;transition:all .15s;display:flex}.sidebar-nav-link svg{flex-shrink:0;width:18px;height:18px}.sidebar-nav-link:hover{background:var(--bg-secondary);color:var(--text)}.sidebar-nav-link.active{background:var(--accent-light);color:var(--accent)}.sidebar-footer{border-top:1px solid var(--border);padding:16px}.sidebar-status{color:var(--text-muted);align-items:center;gap:8px;margin-bottom:12px;font-size:.8rem;display:flex}.sidebar-status-dot{background:var(--success);border-radius:50%;width:8px;height:8px}.sidebar-logout{color:var(--text-muted);align-items:center;gap:8px;width:100%;padding:8px 0;font-size:.85rem;transition:color .15s;display:flex}.sidebar-logout svg{width:16px;height:16px}.sidebar-logout:hover{color:var(--danger)}.main{margin-left:var(--sidebar-w);flex-direction:column;flex:1;min-height:100vh;display:flex}.main-header{height:var(--header-h);background:var(--surface);border-bottom:1px solid var(--border);z-index:40;align-items:center;gap:16px;padding:0 20px;display:flex;position:sticky;top:0}.main-header-menu{color:var(--text-secondary);padding:6px;display:none}.main-header-menu svg{width:20px;height:20px}.main-header-title{flex:1;font-size:1rem;font-weight:600}.main-header-actions{gap:8px;display:flex}.main-body{flex:1;padding:24px}.icon-btn{border-radius:var(--radius);width:32px;height:32px;color:var(--text-secondary);justify-content:center;align-items:center;transition:all .15s;display:flex}.icon-btn svg{width:16px;height:16px}.icon-btn:hover{background:var(--bg-tertiary);color:var(--text)}.icon-btn.danger:hover{background:var(--danger-light);color:var(--danger)}.stats-grid{grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:28px;display:grid}.stat-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:20px}.stat-header{justify-content:space-between;align-items:center;margin-bottom:12px;display:flex}.stat-label{text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);font-size:.75rem;font-weight:600}.stat-icon{width:20px;height:20px;color:var(--text-muted)}.stat-icon svg{width:100%;height:100%}.stat-value{letter-spacing:-.02em;margin-bottom:8px;font-size:1.8rem;font-weight:700}.stat-bar{background:var(--bg-tertiary);border-radius:2px;height:4px;margin-bottom:8px;overflow:hidden}.stat-bar-fill{background:var(--accent);border-radius:2px;height:100%;transition:width .5s}.stat-detail{color:var(--text-muted);font-size:.75rem}.section-title{margin-bottom:16px;font-size:1rem;font-weight:600}.home-section{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);margin-bottom:20px;padding:20px}.containers-list{flex-direction:column;gap:2px;display:flex}.container-row{border-radius:var(--radius);align-items:center;gap:12px;padding:10px 12px;transition:background .15s;display:flex}.container-row:hover{background:var(--bg-secondary)}.container-status{border-radius:50%;flex-shrink:0;width:8px;height:8px}.container-name{flex:1;font-size:.875rem;font-weight:500}.container-state{color:var(--text-muted);text-transform:capitalize;font-size:.75rem}.docker-list{grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:16px;display:grid}.docker-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:16px}.docker-card-header{align-items:center;gap:10px;margin-bottom:12px;display:flex}.docker-status-dot{border-radius:50%;width:8px;height:8px}.docker-name{font-size:.9rem;font-weight:600}.docker-card-body{flex-direction:column;gap:4px;display:flex}.docker-info{color:var(--text-secondary);font-size:.8rem}.docker-info span{color:var(--text-muted);font-weight:500}.projects-header{justify-content:space-between;align-items:center;margin-bottom:20px;display:flex}.projects-grid{grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:16px;display:grid}.project-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);cursor:pointer;padding:24px;transition:all .15s}.project-card:hover{border-color:var(--accent);box-shadow:var(--shadow)}.project-card-icon{width:36px;height:36px;color:var(--accent);margin-bottom:12px}.project-card-icon svg{width:100%;height:100%}.project-card-name{margin-bottom:4px;font-size:.9rem;font-weight:600}.project-card-meta{color:var(--text-muted);font-size:.75rem}.project-detail-header{flex-wrap:wrap;align-items:center;gap:16px;margin-bottom:20px;display:flex}.back-btn{color:var(--text-secondary);padding:6px 0;font-size:.85rem;transition:color .15s}.back-btn:hover{color:var(--accent)}.project-detail-title{flex:1;font-size:1rem;font-weight:600}.project-detail-actions{gap:8px;display:flex}.upload-btn{background:var(--accent);color:#fff;border-radius:var(--radius);cursor:pointer;align-items:center;gap:6px;padding:8px 12px;font-size:.8rem;font-weight:500;transition:background .15s;display:flex}.upload-btn:hover{background:var(--accent-hover)}.upload-btn svg{width:14px;height:14px}.project-breadcrumbs{flex-wrap:wrap;align-items:center;gap:4px;margin-bottom:16px;display:flex}.breadcrumb-sep{color:var(--text-muted);margin:0 2px}.breadcrumb-item{color:var(--text-secondary);font-size:.85rem;transition:color .15s}.breadcrumb-item:hover{color:var(--accent)}.project-toolbar{flex-wrap:wrap;align-items:center;gap:12px;margin-bottom:16px;display:flex}.search-box{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);flex:1;align-items:center;gap:8px;min-width:200px;padding:8px 12px;display:flex}.search-box svg{width:16px;height:16px;color:var(--text-muted);flex-shrink:0}.search-box input{background:0 0;border:none;outline:none;flex:1;font-size:.875rem}.sort-controls{align-items:center;gap:6px;display:flex}.sort-controls select{border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);padding:6px 10px;font-size:.8rem}.upload-progress{background:var(--accent-light);border-radius:var(--radius);color:var(--accent);justify-content:space-between;margin-bottom:16px;padding:12px 16px;font-size:.85rem;display:flex}.files-list{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden}.file-row{border-bottom:1px solid var(--border-light);align-items:center;gap:12px;padding:12px 16px;transition:background .15s;display:flex}.file-row:last-child{border-bottom:none}.file-row:hover{background:var(--bg-secondary)}.file-icon{width:20px;height:20px;color:var(--text-muted);flex-shrink:0}.file-icon svg{width:100%;height:100%}.file-info{flex:1;min-width:0}.file-name{white-space:nowrap;text-overflow:ellipsis;cursor:pointer;font-size:.875rem;font-weight:500;overflow:hidden}.file-meta{color:var(--text-muted);font-size:.75rem}.file-actions{opacity:0;gap:4px;transition:opacity .15s;display:flex}.file-row:hover .file-actions{opacity:1}.shared-header{justify-content:space-between;align-items:center;margin-bottom:20px;display:flex}.images-grid{grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:16px;display:grid}.image-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden}.image-preview{aspect-ratio:1;background:var(--bg-tertiary);overflow:hidden}.image-preview img{object-fit:cover;width:100%;height:100%}.image-footer{justify-content:space-between;align-items:center;padding:10px 12px;display:flex}.image-name{color:var(--text-secondary);white-space:nowrap;text-overflow:ellipsis;max-width:120px;font-size:.75rem;overflow:hidden}.loading{text-align:center;color:var(--text-muted);padding:40px}.mobile-overlay{z-index:45;background:#0006;display:none;position:fixed;inset:0}@media (width<=768px){.sidebar{transform:translate(-100%)}.sidebar.open{transform:translate(0)}.sidebar.open~.mobile-overlay{display:block}.sidebar-close{display:flex}.main{margin-left:0}.main-header-menu{display:flex}.mobile-overlay.active{display:block}.stats-grid{grid-template-columns:repeat(2,1fr)}.landing-nav{gap:16px}.landing-nav a{display:none}.landing-why{grid-template-columns:1fr;gap:40px}.landing-hero{padding:60px 20px 48px}.landing-services,.landing-why{padding:60px 20px}.login-page{flex-direction:column}.login-split-left{display:none}.login-split-right{padding:32px 24px}}
