@import"https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&family=JetBrains+Mono:wght@400;500&display=swap";:root{--bg-primary: #0a0a0a;--bg-secondary: #111111;--bg-card: #171717;--bg-card-hover: #1f1f1f;--bg-elevated: #222222;--bg-input: #1a1a1a;--glass-bg: rgba(255, 255, 255, .03);--glass-border: rgba(255, 255, 255, .08);--glass-hover: rgba(255, 255, 255, .06);--text-primary: #ededed;--text-secondary: #a1a1a1;--text-muted: #666666;--text-inverse: #0a0a0a;--accent: #3b82f6;--accent-hover: #2563eb;--accent-subtle: rgba(59, 130, 246, .12);--status-pending: #f59e0b;--status-building: #8b5cf6;--status-deploying: #3b82f6;--status-ready: #10b981;--status-failed: #ef4444;--border: #262626;--border-hover: #404040;--border-focus: #3b82f6;--radius-sm: 6px;--radius-md: 10px;--radius-lg: 14px;--radius-xl: 18px;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .3);--shadow-md: 0 4px 12px rgba(0, 0, 0, .4);--shadow-lg: 0 8px 30px rgba(0, 0, 0, .5);--shadow-glow: 0 0 20px rgba(59, 130, 246, .15);--transition-fast: .15s cubic-bezier(.4, 0, .2, 1);--transition-base: .25s cubic-bezier(.4, 0, .2, 1);--transition-slow: .4s cubic-bezier(.4, 0, .2, 1);--font-sans: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-mono: "JetBrains Mono", "Fira Code", monospace;--header-bg: rgba(10, 10, 10, .85);--log-bg: #0d0d0d;--log-text: #c0c0c0;--header-shadow: 0 8px 24px rgba(0, 0, 0, .22);--nav-link-bg-hover: rgba(255, 255, 255, .04);--nav-link-bg-active: transparent;--nav-link-border: transparent;--nav-link-text: #aab4c5;--nav-link-text-active: #f2f7ff;--nav-link-underline: #3b82f6}[data-theme=light]{--bg-primary: #f4f6fb;--bg-secondary: #ffffff;--bg-card: #ffffff;--bg-card-hover: #f7f9fc;--bg-elevated: #eef2ff;--bg-input: #ffffff;--glass-bg: rgba(255, 255, 255, .88);--glass-border: rgba(15, 23, 42, .09);--glass-hover: rgba(37, 99, 235, .08);--text-primary: #0f172a;--text-secondary: #334155;--text-muted: #64748b;--text-inverse: #ffffff;--accent: #2563eb;--accent-hover: #1d4ed8;--accent-subtle: rgba(37, 99, 235, .15);--border: #dbe2ee;--border-hover: #c8d3e6;--border-focus: #2563eb;--shadow-sm: 0 1px 2px rgba(15, 23, 42, .05);--shadow-md: 0 8px 20px rgba(15, 23, 42, .08);--shadow-lg: 0 16px 36px rgba(15, 23, 42, .12);--shadow-glow: 0 0 20px rgba(37, 99, 235, .2);--header-bg: rgba(255, 255, 255, .92);--log-bg: #f8fafc;--log-text: #334155;--header-shadow: 0 6px 16px rgba(15, 23, 42, .06);--nav-link-bg-hover: rgba(148, 163, 184, .1);--nav-link-bg-active: transparent;--nav-link-border: transparent;--nav-link-text: #334155;--nav-link-text-active: #0f172a;--nav-link-underline: #2563eb}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:var(--font-sans);background-color:var(--bg-primary);color:var(--text-primary);line-height:1.6;min-height:100vh;transition:background-color var(--transition-base),color var(--transition-base)}#root{min-height:100vh;display:flex;flex-direction:column}a{color:var(--accent);text-decoration:none;transition:color var(--transition-fast)}a:hover{color:var(--accent-hover)}.app-layout{display:flex;flex-direction:column;min-height:100vh}.app-header{position:sticky;top:0;z-index:100;background:var(--header-bg);-webkit-backdrop-filter:blur(20px) saturate(180%);backdrop-filter:blur(20px) saturate(180%);border-bottom:1px solid var(--glass-border);padding:0;height:62px}.app-header-inner{max-width:1440px;width:100%;margin:0 auto;height:100%;padding:0 24px;display:flex;align-items:center;justify-content:space-between;gap:16px}.app-header-left,.app-header-right{display:flex;align-items:center}.app-header-right{gap:8px}.app-header{box-shadow:var(--header-shadow)}.theme-toggle{min-width:84px;justify-content:center}.app-header .logo{display:flex;align-items:center;gap:10px;font-weight:700;font-size:1.1rem;color:var(--text-primary);letter-spacing:-.03em}.app-header .logo svg{color:var(--accent);padding:2px;border-radius:6px;background:var(--accent-subtle)}.header-nav{display:flex;align-items:center;gap:2px;margin-left:18px}.header-nav a{position:relative;padding:8px 10px;border-radius:8px;color:var(--nav-link-text);font-size:.9rem;font-weight:500;transition:all var(--transition-fast);border:1px solid transparent}.header-nav a:hover,.header-nav a.active{color:var(--nav-link-text-active);border-color:var(--nav-link-border)}.header-nav a:hover{background:var(--nav-link-bg-hover)}.header-nav a.active{background:var(--nav-link-bg-active);box-shadow:none}.header-nav a.active:after{content:"";position:absolute;left:10px;right:10px;bottom:4px;height:2px;border-radius:100px;background:var(--nav-link-underline)}.header-nav a svg{margin-right:4px;vertical-align:middle}.header-auth-guest,.header-auth-user{display:flex;align-items:center;gap:8px}.header-account-link{display:inline-flex;align-items:center;gap:7px;padding:7px 10px;border-radius:10px;border:1px solid var(--border);color:var(--text-secondary);background:var(--bg-card);font-size:.85rem}.header-account-sep{color:var(--text-muted);font-size:.75rem}.header-account-link:hover{color:var(--text-primary);border-color:var(--border-hover);background:var(--glass-hover)}.header-admin-badge{background:#ef444424;color:var(--status-failed);font-size:.72rem;border-radius:6px;border:1px solid rgba(239,68,68,.3);padding:2px 6px}.main-content{flex:1;max-width:1440px;width:100%;margin:0 auto;padding:32px 24px}.dashboard-overview-grid{display:grid;grid-template-columns:repeat(4,minmax(140px,1fr));gap:14px;margin-bottom:22px}.dashboard-overview-card{padding:16px 18px;display:flex;flex-direction:column;gap:6px}.dashboard-overview-label{color:var(--text-muted);font-size:.78rem;text-transform:uppercase;letter-spacing:.04em}.dashboard-overview-value{font-size:1.4rem;font-weight:700;color:var(--text-primary)}.dashboard-empty-layout{display:grid;grid-template-columns:1.1fr 1fr;gap:16px;align-items:start}.dashboard-empty-card{min-height:340px;display:flex;align-items:center;justify-content:center}.dashboard-roadmap-card{min-height:340px}.dashboard-feature-list{display:grid;gap:10px}.dashboard-feature-item{display:grid;grid-template-columns:18px 1fr;gap:10px;padding:10px 12px;border:1px solid var(--border);border-radius:var(--radius-md);background:var(--bg-card-hover)}.dashboard-feature-item svg{color:var(--accent);margin-top:3px}.dashboard-feature-item strong{font-size:.9rem;color:var(--text-primary)}.dashboard-feature-item p{font-size:.82rem;color:var(--text-secondary)}.card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:24px;transition:all var(--transition-base)}.card:hover{border-color:var(--border-hover);background:var(--bg-card-hover)}.card-clickable{cursor:pointer}.card-clickable:hover{box-shadow:var(--shadow-md);transform:translateY(-1px)}.glass-card{background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:var(--radius-lg);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);padding:24px}.btn{display:inline-flex;align-items:center;gap:8px;padding:8px 18px;border-radius:var(--radius-md);font-family:var(--font-sans);font-size:.875rem;font-weight:500;cursor:pointer;transition:all var(--transition-fast);border:1px solid transparent;line-height:1.4}.btn-primary{background:var(--text-primary);color:var(--text-inverse);border-color:var(--text-primary)}.btn-primary:hover{background:var(--bg-card);box-shadow:var(--shadow-glow)}.btn-secondary{background:transparent;color:var(--text-primary);border-color:var(--border)}.btn-secondary:hover{background:var(--glass-hover);border-color:var(--border-hover)}.btn-danger{background:transparent;color:var(--status-failed);border-color:#ef44444d}.btn-danger:hover{background:#ef44441a;border-color:var(--status-failed)}.btn-ghost{background:transparent;color:var(--text-secondary);border:none;padding:6px 12px}.btn-ghost:hover{color:var(--text-primary);background:var(--glass-hover)}.btn-sm{padding:5px 12px;font-size:.8rem}.btn:disabled{opacity:.5;cursor:not-allowed}.status-badge{display:inline-flex;align-items:center;gap:6px;padding:3px 10px;border-radius:100px;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em}.status-badge:before{content:"";width:7px;height:7px;border-radius:50%;display:inline-block}.status-pending{color:var(--status-pending);background:#f59e0b1a}.status-pending:before{background:var(--status-pending)}.status-building{color:var(--status-building);background:#8b5cf61a}.status-building:before{background:var(--status-building);animation:pulse 1.5s infinite}.status-deploying{color:var(--status-deploying);background:#3b82f61a}.status-deploying:before{background:var(--status-deploying);animation:pulse 1.5s infinite}.status-ready{color:var(--status-ready);background:#10b9811a}.status-ready:before{background:var(--status-ready)}.status-failed{color:var(--status-failed);background:#ef44441a}.status-failed:before{background:var(--status-failed)}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}.form-group{margin-bottom:20px}.form-group label{display:block;font-size:.85rem;font-weight:500;color:var(--text-secondary);margin-bottom:6px}.form-input{width:100%;padding:10px 14px;background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text-primary);font-family:var(--font-sans);font-size:.9rem;transition:all var(--transition-fast);outline:none}.form-input:focus{border-color:var(--border-focus);box-shadow:0 0 0 3px var(--accent-subtle)}.form-input::placeholder{color:var(--text-muted)}.auth-page{min-height:calc(100vh - 120px);display:grid;place-items:center;padding:24px;background-image:none}.auth-shell{width:100%;max-width:920px;display:grid;grid-template-columns:1fr 420px;gap:24px;align-items:center}.auth-brand h1{font-size:2.2rem;line-height:1.1;letter-spacing:-.04em;margin-bottom:10px}.auth-brand p{color:var(--text-secondary);font-size:.98rem;max-width:380px}.auth-preview-grid{margin-top:18px;display:grid;gap:10px}.auth-preview-card{border:1px solid var(--glass-border);background:#ffffff05;border-radius:var(--radius-md);padding:12px 14px}.auth-preview-title{display:flex;align-items:center;gap:7px;font-size:.85rem;font-weight:600;margin-bottom:6px}.auth-preview-card ul{list-style:none;display:grid;gap:4px;color:var(--text-secondary);font-size:.82rem}.auth-preview-card li:before{content:"•";margin-right:8px;color:var(--accent)}.auth-card{padding:28px;background:linear-gradient(180deg,#ffffff05,#ffffff03);border-color:var(--glass-border);box-shadow:var(--shadow-lg)}.auth-title{font-size:1.35rem;font-weight:650;letter-spacing:-.02em;margin-bottom:18px}.auth-form{display:flex;flex-direction:column;gap:4px}.auth-input-wrap{display:flex;align-items:center;gap:10px;border:1px solid var(--border);border-radius:var(--radius-md);background:var(--bg-input);padding:0 12px;transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}.auth-input-wrap:focus-within{border-color:var(--border-focus);box-shadow:0 0 0 3px var(--accent-subtle)}.auth-input-wrap svg{color:var(--text-muted);flex-shrink:0}.auth-input{border:none;box-shadow:none;padding-left:0;padding-right:0;background:transparent}.auth-input:focus{box-shadow:none}.auth-submit{margin-top:8px;width:100%;justify-content:center}.auth-alert{margin-bottom:16px;border:1px solid rgba(239,68,68,.35);background:#ef44441a;color:#fca5a5;border-radius:var(--radius-md);padding:10px 12px;font-size:.85rem}.auth-success{margin-bottom:16px;border:1px solid rgba(16,185,129,.35);background:#10b9811a;color:#6ee7b7;border-radius:var(--radius-md);padding:10px 12px;font-size:.85rem}.auth-divider{margin:18px 0 14px;display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:12px}.auth-divider span{display:block;height:1px;background:var(--border)}.auth-divider p{color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em;font-size:.72rem}.auth-oauth-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}.auth-oauth-btn{justify-content:center}.auth-footnote{margin-top:18px;text-align:center;color:var(--text-secondary);font-size:.86rem}.auth-muted-note{margin-top:10px;color:var(--text-muted);font-size:.78rem;display:flex;align-items:center;gap:6px}.auth-inline-link{border:none;background:transparent;color:var(--accent);cursor:pointer;font-size:.84rem;padding:0}.auth-inline-link:hover{color:var(--accent-hover)}.auth-two-col{display:grid;grid-template-columns:1fr 1fr;gap:12px}.login-v7-page{min-height:calc(100vh - 90px);padding:26px 20px 34px}.login-v7-shell{max-width:1200px;margin:0 auto;display:grid;grid-template-columns:1fr;gap:24px}.login-v7-hero{text-align:center;padding-top:10px}.login-v7-hero h1{font-size:clamp(2rem,4vw,3.5rem);line-height:1.1;letter-spacing:-.04em;margin-bottom:12px}.login-v7-hero p{max-width:720px;margin:0 auto;color:var(--text-secondary);font-size:1.05rem}.login-v7-actions{margin-top:18px;display:inline-flex;gap:10px;flex-wrap:wrap;justify-content:center}.login-v7-card{max-width:620px;width:100%;margin:0 auto;background:var(--bg-secondary);border-color:var(--border-hover);box-shadow:var(--shadow-lg)}.login-v7-card-logo{font-size:1.15rem;font-weight:700;letter-spacing:-.02em;color:var(--text-primary)}.login-v7-card h2{margin-top:8px;margin-bottom:18px;font-size:2rem;letter-spacing:-.03em}.login-v7-oauth-row{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:14px}.login-v7-oauth-row .btn{justify-content:center}.login-v7-divider{position:relative;margin:10px 0 14px;text-align:center}.login-v7-divider:before{content:"";position:absolute;left:0;right:0;top:50%;border-top:1px solid var(--border)}.login-v7-divider span{position:relative;padding:0 10px;background:var(--bg-secondary);color:var(--text-muted);font-size:.82rem}.login-v7-bottom-links{display:flex;justify-content:space-between;gap:10px;margin-top:10px;color:var(--text-muted);font-size:.86rem}.login-v7-image-wrap{margin:8px auto 0;max-width:760px;width:100%;padding:16px;border:1px solid var(--border);border-radius:var(--radius-xl);background:linear-gradient(180deg,var(--bg-secondary),var(--bg-card));box-shadow:var(--shadow-md)}.login-v7-image{width:100%;height:auto;border-radius:var(--radius-lg);display:block;opacity:.94}.log-viewer{background:var(--log-bg);border:1px solid var(--border);border-radius:var(--radius-lg);padding:16px 20px;font-family:var(--font-mono);font-size:.8rem;line-height:1.8;color:var(--log-text);max-height:500px;overflow-y:auto;overflow-x:hidden}.log-viewer::-webkit-scrollbar{width:6px}.log-viewer::-webkit-scrollbar-track{background:transparent}.log-viewer::-webkit-scrollbar-thumb{background:#333;border-radius:3px}.log-line{display:flex;gap:12px;padding:1px 0}.log-line .log-time{color:var(--text-muted);flex-shrink:0;font-size:.75rem}.log-line .log-source{color:var(--accent);flex-shrink:0;min-width:48px;font-size:.75rem}.log-line .log-text{word-break:break-all}.page-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:32px;flex-wrap:wrap;gap:16px}.page-header h1{font-size:1.75rem;font-weight:700;letter-spacing:-.04em;color:var(--text-primary)}.page-header h1 span{color:var(--text-secondary);font-weight:400}.project-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:16px}.project-card{display:flex;flex-direction:column;gap:14px}.project-card .project-name{font-size:1.05rem;font-weight:600;color:var(--text-primary);letter-spacing:-.02em}.project-card .project-meta{display:flex;align-items:center;gap:12px;font-size:.8rem;color:var(--text-muted)}.project-card .project-meta svg{width:14px;height:14px}.project-card .project-url{font-family:var(--font-mono);font-size:.78rem;color:var(--text-secondary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.project-card .project-footer{display:flex;align-items:center;justify-content:space-between;padding-top:14px;border-top:1px solid var(--border)}.deployment-list{display:flex;flex-direction:column;gap:2px}.deployment-item{display:flex;align-items:center;gap:16px;padding:14px 18px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-md);transition:all var(--transition-fast);cursor:pointer}.deployment-item:hover{border-color:var(--border-hover);background:var(--bg-card-hover)}.deployment-item .deploy-info{flex:1;min-width:0}.deployment-item .deploy-info .deploy-title{font-size:.9rem;font-weight:500;color:var(--text-primary);margin-bottom:2px}.deployment-item .deploy-info .deploy-meta{font-size:.78rem;color:var(--text-muted);display:flex;align-items:center;gap:8px}.status-timeline{display:flex;gap:0;margin:24px 0}.timeline-step{flex:1;display:flex;flex-direction:column;align-items:center;position:relative}.timeline-step:before{content:"";position:absolute;top:16px;left:50%;right:-50%;height:2px;background:var(--border);z-index:0}.timeline-step:last-child:before{display:none}.timeline-step.active:before,.timeline-step.completed:before{background:var(--accent)}.timeline-dot{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;background:var(--bg-card);border:2px solid var(--border);z-index:1;transition:all var(--transition-base)}.timeline-step.completed .timeline-dot{background:var(--status-ready);border-color:var(--status-ready);color:#fff}.timeline-step.active .timeline-dot{background:var(--accent);border-color:var(--accent);color:#fff;box-shadow:0 0 12px #3b82f666;animation:pulse 2s infinite}.timeline-step.failed .timeline-dot{background:var(--status-failed);border-color:var(--status-failed);color:#fff}.timeline-label{margin-top:8px;font-size:.75rem;font-weight:500;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em}.timeline-step.active .timeline-label,.timeline-step.completed .timeline-label{color:var(--text-primary)}.env-table{width:100%;border-collapse:separate;border-spacing:0}.env-table th{text-align:left;padding:10px 14px;font-size:.78rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;border-bottom:1px solid var(--border)}.env-table td{padding:10px 14px;font-size:.85rem;border-bottom:1px solid var(--border)}.env-table td:first-child{font-family:var(--font-mono);font-weight:500;color:var(--accent)}.env-table td:nth-child(2){font-family:var(--font-mono);color:var(--text-secondary)}.empty-state{text-align:center;padding:60px 24px;color:var(--text-muted)}.empty-state svg{margin-bottom:16px;opacity:.3}.empty-state h3{font-size:1.1rem;font-weight:600;margin-bottom:8px;color:var(--text-secondary)}.empty-state p{font-size:.9rem;margin-bottom:20px}.loading-spinner{display:flex;align-items:center;justify-content:center;padding:60px}.spinner{width:32px;height:32px;border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.section{margin-bottom:32px}.section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.section-header h2{font-size:1.1rem;font-weight:600;letter-spacing:-.02em}.detail-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:16px}.detail-item{display:flex;flex-direction:column;gap:4px}.detail-item .detail-label{font-size:.78rem;font-weight:500;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em}.detail-item .detail-value{font-size:.9rem;color:var(--text-primary);font-weight:500}.detail-item .detail-value.mono{font-family:var(--font-mono);font-size:.85rem}.breadcrumbs{display:flex;align-items:center;gap:8px;font-size:.85rem;margin-bottom:24px;color:var(--text-muted)}.breadcrumbs a{color:var(--text-secondary)}.breadcrumbs span{color:var(--text-muted)}@media (max-width: 768px){.app-header{height:56px}.app-header-inner{padding:0 12px;gap:10px}.header-nav{margin-left:8px;gap:4px}.header-nav a{padding:6px 9px;font-size:.82rem}.theme-toggle{min-width:auto;padding:6px 10px}.theme-toggle span,.header-account-link span,.btn.btn-ghost.btn-sm span{display:none}.header-account-link{padding:6px 8px}.main-content{padding:20px 16px}.dashboard-overview-grid{grid-template-columns:repeat(2,minmax(120px,1fr))}.dashboard-empty-layout,.project-grid{grid-template-columns:1fr}.page-header{flex-direction:column;align-items:flex-start}.detail-grid{grid-template-columns:1fr 1fr}.status-timeline{flex-direction:column;gap:8px}.timeline-step:before{display:none}.auth-shell{grid-template-columns:1fr;max-width:480px}.auth-brand h1{font-size:1.8rem}.auth-brand p{font-size:.9rem}.auth-two-col{grid-template-columns:1fr;gap:0}.login-v7-oauth-row{grid-template-columns:1fr}.login-v7-bottom-links{flex-direction:column}}.landing-page{font-family:var(--font-sans);background-color:var(--bg-primary);color:var(--text-primary);min-height:100vh;display:flex;flex-direction:column;position:relative;overflow-x:hidden}.landing-header{display:flex;justify-content:space-between;align-items:center;padding:24px 48px;max-width:1200px;margin:0 auto;width:100%;position:relative;z-index:10}.landing-logo{display:flex;align-items:center;gap:8px;font-weight:800;font-size:1.25rem;color:var(--text-primary)}.landing-nav{display:flex;gap:32px}.landing-nav a{color:var(--text-secondary);text-decoration:none;font-size:.95rem;font-weight:500}.landing-nav a:hover{color:var(--text-primary)}.btn-landing-signup{display:inline-block;padding:8px 16px;border:1px solid var(--text-primary);border-radius:6px;font-weight:500;font-size:.95rem;color:var(--text-primary);text-decoration:none;background:var(--bg-card);transition:all .2s}.btn-landing-signup:hover{background:var(--bg-card-hover)}.landing-main{flex:1;display:flex;flex-direction:column;align-items:center;padding-top:80px;position:relative;z-index:10}.landing-hero{text-align:center;max-width:800px;padding:0 20px}.landing-hero h1{font-size:3.5rem;font-weight:800;letter-spacing:-.04em;margin-bottom:16px;color:var(--text-primary)}.landing-hero p{font-size:1.15rem;color:var(--text-secondary);margin-bottom:40px}.landing-cta{display:flex;justify-content:center;gap:16px;margin-bottom:64px}.btn-landing-primary{background:var(--text-primary);color:var(--bg-primary);padding:12px 24px;border-radius:6px;font-weight:600;font-size:1rem;text-decoration:none;border:1px solid var(--text-primary);transition:all .2s}.btn-landing-primary:hover{background:var(--text-secondary);color:var(--bg-primary)}.btn-landing-secondary{background:var(--bg-card);color:var(--text-primary);padding:12px 24px;border-radius:6px;font-weight:600;font-size:1rem;text-decoration:none;border:1px solid var(--border);transition:all .2s}.btn-landing-secondary:hover{border-color:var(--text-primary)}.landing-preview{margin:0 auto 100px;max-width:800px;padding:0 20px;width:100%}.landing-preview-window{background:var(--bg-card);border:1px solid var(--border);border-radius:12px;box-shadow:0 20px 40px #0000000d;overflow:hidden;padding:20px}.landing-preview-window img{width:100%;height:auto;display:block}.landing-globe{position:absolute;bottom:-300px;left:0;right:0;display:flex;justify-content:center;pointer-events:none}.globe-overlay{position:absolute;top:80px;left:50%;transform:translate(-50%);z-index:20}.globe-overlay h2{color:var(--bg-primary);font-size:1.5rem;font-weight:600}.globe-placeholder{width:1200px;height:600px;border-radius:50%;background:radial-gradient(circle at center,#2c3140 0%,#1a1d27 60%,var(--bg-primary) 100%);box-shadow:0 -20px 60px #0003;position:relative}.globe-placeholder:after{content:"";position:absolute;top:0;left:0;right:0;bottom:0;border-radius:50%;background-image:linear-gradient(rgba(255,255,255,.05) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.05) 1px,transparent 1px);background-size:60px 60px;opacity:.5;border:1px solid rgba(255,255,255,.1)}.login-v8-page{font-family:var(--font-sans);background-color:var(--bg-primary);min-height:100vh;display:flex;flex-direction:column;align-items:center;padding-top:10vh;position:relative;overflow:hidden}.login-v8-card{background:var(--bg-card);border:1px solid var(--border);border-radius:12px;padding:40px;width:100%;max-width:440px;box-shadow:0 10px 30px #00000008;position:relative;z-index:10}.login-v8-brand{display:flex;align-items:center;justify-content:center;gap:8px;margin-bottom:24px}.login-v8-brand svg{color:var(--text-primary)}.login-v8-brand .logo-text{font-weight:800;font-size:1.4rem;color:var(--text-primary)}.login-v8-card h2{text-align:center;font-size:1.75rem;font-weight:700;color:var(--text-primary);margin-bottom:32px;letter-spacing:-.02em}.login-v8-oauth{display:flex;gap:12px;margin-bottom:24px}.btn-oauth{flex:1;display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:10px;border-radius:6px;font-size:.85rem;font-weight:500;cursor:pointer;transition:all .2s;background:var(--bg-card)}.git-button{background:var(--text-primary);color:var(--bg-primary);border:1px solid var(--text-primary);white-space:nowrap}.git-button:hover{background:var(--text-secondary)}.git-button svg{flex-shrink:0}.google-button{border:1px solid var(--border);color:var(--text-secondary);padding:10px;flex:0 0 auto}.google-button:hover{background:var(--bg-card-hover)}.login-v8-divider{position:relative;text-align:center;margin:24px 0}.login-v8-divider:before{content:"";position:absolute;top:50%;left:0;right:0;height:1px;background:#eaeaea}.login-v8-divider span{position:relative;background:var(--bg-card);padding:0 12px;color:var(--text-muted);font-size:.85rem}.login-v8-form{display:flex;flex-direction:column;gap:16px}.login-v8-field{display:flex;flex-direction:column}.field-label{font-size:.9rem;font-weight:600;color:var(--text-primary);margin-bottom:8px}.login-v8-input{width:100%;padding:10px 12px;border:1px solid var(--border);border-radius:6px;font-size:.95rem;color:var(--text-primary);background:var(--bg-card);transition:border-color .2s}.login-v8-input:focus{outline:none;border-color:var(--text-muted)}.login-v8-input::placeholder{color:var(--text-muted)}.btn-v8-primary{width:100%;background:var(--text-primary);color:var(--bg-primary);padding:12px;border:none;border-radius:6px;font-weight:600;font-size:.95rem;cursor:pointer;transition:background .2s;margin-top:8px}.btn-v8-primary:hover:not(:disabled){background:var(--text-secondary)}.btn-v8-primary:disabled{opacity:.6;cursor:not-allowed}.login-v8-footer{display:flex;justify-content:space-between;margin-top:24px;font-size:.85rem}.login-v8-footer a{color:var(--text-secondary);text-decoration:none}.login-v8-footer a:hover{text-decoration:underline;color:var(--text-primary)}.login-v8-footer .footer-right a{color:var(--text-primary)}.login-v8-globe{position:absolute;bottom:-40vh;left:0;right:0;display:flex;justify-content:center;pointer-events:none;z-index:1}.v8-resend{display:block;margin:16px auto 0}
