@font-face{font-family:Inter;font-style:normal;font-weight:400 700;font-display:swap;src:url(/fonts/inter-latin.woff2)format("woff2");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:JetBrains Mono;font-style:normal;font-weight:400 500;font-display:swap;src:url(/fonts/jetbrains-mono-latin.woff2)format("woff2");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}:root{--color-cream:#f4efe6;--color-paper:#fbf8f1;--color-ink-raw:#15120d;--color-charcoal:#2a251c;--color-yolk:#f5b840;--color-moss:#3d5a3a;--color-slate:#5f5a4d;--color-bg:var(--color-cream);--color-surface:var(--color-paper);--color-ink:var(--color-ink-raw);--color-secondary:var(--color-slate);--color-muted:#8a8474;--color-border:#15120d1f;--color-border-hover:#15120d40;--color-accent:var(--color-ink-raw);--color-accent-hover:var(--color-charcoal);--color-accent-light:#f5b8402e;--color-accent-text:var(--color-paper);--color-success:#2f8f4c;--color-success-light:#eaf5ec;--color-warning:#c39210;--color-warning-light:#fbf3de;--color-danger:#c43b3b;--color-danger-light:#fbe9e9;--color-info:#365fa5;--color-info-light:#ebf0f8;--color-sidebar:var(--color-ink-raw);--color-sidebar-hover:var(--color-charcoal);--color-sidebar-text:#fbf8f1a6;--color-sidebar-active:var(--color-paper);--color-sidebar-accent:var(--color-yolk);--font-display:"Inter", -apple-system, BlinkMacSystemFont, sans-serif;--font-body:"Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;--font-mono:"JetBrains Mono", "SF Mono", SFMono-Regular, ui-monospace, monospace;--text-xs:12px;--text-sm:13px;--text-base:14px;--text-md:16px;--text-lg:20px;--text-xl:24px;--text-2xl:32px;--text-3xl:40px;--radius-sm:4px;--radius-md:8px;--radius-lg:12px;--radius-xl:16px;--radius-full:999px;--shadow-sm:0 1px 3px #0000000d;--shadow-md:0 4px 12px #00000014;--shadow-lg:0 12px 32px #0000001f;--shadow-card-hover:0 6px 20px #15120d14;--header-height:56px;--sidebar-width:260px;--content-max:1200px;--content-narrow:720px}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-size:16px}body{font-family:var(--font-body);font-size:var(--text-base);color:var(--color-ink);background:var(--color-bg);line-height:1.6}h1,h2,h3,h4{font-family:var(--font-display);letter-spacing:-.015em;font-weight:500;line-height:1.25}a{color:inherit;text-decoration:none}a:hover{opacity:.8}.prose a{border-bottom:1.5px solid var(--color-yolk);transition:background-color .15s}.prose a:hover{background-color:var(--color-accent-light);opacity:1}code,pre,.mono{font-family:var(--font-mono)}.app-layout{flex-direction:column;min-height:100vh;display:flex}.app-header{z-index:100;height:var(--header-height);background:var(--color-surface);border-bottom:1px solid var(--color-border);justify-content:space-between;align-items:center;padding:0 24px;display:flex;position:sticky;top:0}.header-left{align-items:center;gap:8px;display:flex}.header-logo{font-family:var(--font-display);color:var(--color-ink);align-items:center;gap:10px;font-size:18px;font-weight:700;text-decoration:none;display:flex}.header-logo:hover{text-decoration:none}.header-nav{gap:4px;margin-left:20px;display:flex}.header-nav-link{font-size:var(--text-sm);color:var(--color-secondary);border-radius:var(--radius-md);align-items:center;gap:8px;padding:6px 12px;font-weight:500;text-decoration:none;transition:color .15s,background .15s;display:inline-flex}.header-nav-link:hover{color:var(--color-ink);background:var(--color-bg);text-decoration:none}.header-nav-link.router-link-active{color:var(--color-ink);background:var(--color-bg)}.header-right{align-items:center;gap:12px;display:flex}.header-user{color:var(--color-ink);border-radius:var(--radius-md);align-items:center;gap:8px;padding:4px 8px;text-decoration:none;transition:background .15s;display:flex}.header-user:hover{background:var(--color-bg);text-decoration:none}.header-avatar{object-fit:cover;background:var(--color-accent-light);border-radius:50%;width:28px;height:28px}.header-handle{font-size:var(--text-sm);color:var(--color-secondary);font-weight:500}.project-layout{min-height:calc(100vh - var(--header-height));display:flex}.sidebar{width:var(--sidebar-width);background:var(--color-sidebar);min-height:100%;color:var(--color-sidebar-text);flex-shrink:0;padding:20px 0}.sidebar-header{border-bottom:1px solid #ffffff14;padding:0 20px 16px}.sidebar-project-name{font-family:var(--font-display);font-size:var(--text-md);color:var(--color-sidebar-active);font-weight:600;line-height:1.3}.sidebar-badges{gap:6px;margin-top:8px;display:flex}.sidebar-description{font-size:var(--text-xs);color:var(--color-sidebar-text);opacity:.7;margin-top:6px;line-height:1.4}.sidebar-nav{padding:12px 0}.sidebar-link{font-size:var(--text-sm);color:var(--color-sidebar-text);align-items:center;gap:10px;padding:9px 20px;font-weight:500;text-decoration:none;transition:background .15s,color .15s;display:flex}.sidebar-link:hover{background:var(--color-sidebar-hover);color:var(--color-sidebar-active);text-decoration:none}.sidebar-link.active{color:var(--color-sidebar-active);background:var(--color-sidebar-hover);border-left:3px solid var(--color-sidebar-accent);padding-left:17px}.sidebar-section-title{text-transform:uppercase;letter-spacing:.06em;color:var(--color-sidebar-text);opacity:.5;padding:16px 20px 8px;font-size:11px;font-weight:600}.sidebar-tables{border-top:1px solid #ffffff14}.sidebar-table-link{font-size:var(--text-xs);font-family:var(--font-mono);color:var(--color-sidebar-text);padding:6px 20px 6px 32px;text-decoration:none;transition:background .15s,color .15s;display:block}.sidebar-table-link:hover{background:var(--color-sidebar-hover);color:var(--color-sidebar-active);text-decoration:none}.sidebar-table-link.active{color:var(--color-sidebar-accent)}.project-main{flex:1;min-width:0;padding:28px 32px;overflow-y:auto}.page-container{max-width:var(--content-max);margin:0 auto;padding:28px 32px}.page-header{justify-content:space-between;align-items:center;gap:16px;margin-bottom:24px;display:flex}.page-title{font-family:var(--font-display);font-size:var(--text-xl);font-weight:700}.section-title{font-family:var(--font-display);font-size:var(--text-lg);margin-top:32px;margin-bottom:16px;font-weight:600}.btn{border-radius:var(--radius-md);font-family:var(--font-body);font-size:var(--text-sm);cursor:pointer;white-space:nowrap;border:1px solid #0000;justify-content:center;align-items:center;gap:8px;padding:10px 20px;font-weight:600;line-height:1;text-decoration:none;transition:all .15s;display:inline-flex}.btn:hover{text-decoration:none}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--color-accent);color:var(--color-accent-text);border-color:var(--color-accent)}.btn-primary:hover:not(:disabled){background:var(--color-accent-hover);border-color:var(--color-accent-hover);transform:translateY(-1px);box-shadow:0 4px 14px #15120d2e}.btn-secondary{background:var(--color-surface);color:var(--color-ink);border-color:var(--color-border)}.btn-secondary:hover:not(:disabled){border-color:var(--color-border-hover);background:var(--color-bg)}.btn-ghost{color:var(--color-secondary);background:0 0;border-color:#0000}.btn-ghost:hover:not(:disabled){color:var(--color-ink);background:var(--color-bg)}.btn-danger{background:var(--color-danger);color:#fff;border-color:var(--color-danger)}.btn-danger:hover:not(:disabled){background:#b34545}.btn-outline{color:var(--color-ink);border-color:var(--color-border);background:0 0}.btn-outline:hover:not(:disabled){border-color:var(--color-accent);color:var(--color-accent)}.btn-sm{font-size:var(--text-xs);padding:6px 12px}.btn-xs{padding:4px 8px;font-size:11px}.btn-lg{font-size:var(--text-md);border-radius:var(--radius-lg);padding:14px 28px}.btn-block{width:100%}.form-group{margin-bottom:16px}.form-label{font-size:var(--text-sm);color:var(--color-ink);margin-bottom:6px;font-weight:600;display:block}.input,select.input,textarea.input{border:1px solid var(--color-border);border-radius:var(--radius-md);width:100%;font-family:var(--font-body);font-size:var(--text-base);color:var(--color-ink);background:var(--color-surface);outline:none;padding:10px 14px;transition:border-color .15s,box-shadow .15s}.input:focus{border-color:var(--color-accent);box-shadow:0 0 0 3px var(--color-accent-light)}.input::placeholder{color:var(--color-muted)}textarea.input{resize:vertical;min-height:80px}.form-hint{font-size:var(--text-xs);color:var(--color-secondary);margin-top:4px}.form-hint-success{color:var(--color-success)}.form-hint-danger{color:var(--color-danger)}.radio-group{flex-direction:column;gap:10px;display:flex}.radio-label{font-size:var(--text-sm);cursor:pointer;border:1px solid var(--color-border);border-radius:var(--radius-md);gap:10px;padding:10px 14px;transition:border-color .15s,background .15s;display:flex}.radio-label:hover{border-color:var(--color-border-hover);background:var(--color-bg)}.radio-label input[type=radio]{accent-color:var(--color-accent);margin-top:3px}.card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);margin-bottom:16px;padding:20px}.card-title{font-family:var(--font-display);font-size:var(--text-md);margin-bottom:12px;font-weight:600}.card-header-row{justify-content:space-between;align-items:center;margin-bottom:12px;display:flex}.project-grid{grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:16px;display:grid}.project-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);color:inherit;cursor:pointer;padding:20px;text-decoration:none;transition:transform .15s,box-shadow .15s,border-color .15s;display:block}.project-card:hover{box-shadow:var(--shadow-card-hover);border-color:var(--color-border-hover);text-decoration:none;transform:translateY(-2px)}.project-card-header{justify-content:space-between;align-items:flex-start;gap:8px;margin-bottom:8px;display:flex}.project-name{font-family:var(--font-display);font-size:var(--text-md);color:var(--color-ink);font-weight:600}.project-badges{flex-shrink:0;gap:6px;display:flex}.project-description{font-size:var(--text-sm);color:var(--color-secondary);-webkit-line-clamp:2;-webkit-box-orient:vertical;margin-bottom:10px;line-height:1.5;display:-webkit-box;overflow:hidden}.project-tagline{font-size:var(--text-sm);color:var(--color-secondary);margin-bottom:6px;font-style:italic}.project-meta{font-size:var(--text-xs);color:var(--color-muted);flex-wrap:wrap;gap:12px;display:flex}.meta-item{align-items:center;gap:4px;display:inline-flex}.project-date{font-size:var(--text-xs);color:var(--color-muted);margin-top:8px}.badge{border-radius:var(--radius-full);letter-spacing:.02em;align-items:center;padding:3px 10px;font-size:11px;font-weight:600;display:inline-flex}.badge-personal{background:var(--color-border);color:var(--color-secondary)}.badge-unlisted{background:var(--color-warning-light);color:var(--color-warning)}.badge-public{background:var(--color-success-light);color:var(--color-success)}.badge-app{background:var(--color-accent-light);color:var(--color-charcoal)}.badge-active{background:var(--color-success-light);color:var(--color-success)}.badge-paused{background:var(--color-warning-light);color:var(--color-warning)}.badge-archived{background:var(--color-bg);color:var(--color-muted)}.badge-role{background:var(--color-info-light);color:var(--color-info)}.badge-success{background:var(--color-success-light);color:var(--color-success)}.badge-warning{background:var(--color-warning-light);color:var(--color-warning)}.badge-danger{background:var(--color-danger-light);color:var(--color-danger)}.badge-info{background:var(--color-info-light);color:var(--color-info)}.badge-live{background:var(--color-success-light);color:var(--color-success)}.badge-superseded{background:var(--color-bg);color:var(--color-muted)}.badge-draft{color:#7a4f00;background:#f5bf4b2e}.badge-failed{background:var(--color-danger-light);color:var(--color-danger)}.badge-pending,.badge-building{background:var(--color-warning-light);color:var(--color-warning)}.alert{border-radius:var(--radius-md);font-size:var(--text-sm);margin-bottom:16px;padding:12px 16px;line-height:1.5}.alert-danger{background:var(--color-danger-light);color:var(--color-danger)}.alert-success{background:var(--color-success-light);color:var(--color-success)}.alert-warning{background:var(--color-warning-light);color:var(--color-warning)}.alert-info{background:var(--color-info-light);color:var(--color-info)}.data-table-wrapper{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);overflow:hidden}.data-table-toolbar{border-bottom:1px solid var(--color-border);justify-content:space-between;align-items:center;gap:12px;padding:12px 16px;display:flex}.toolbar-left{flex:1;align-items:center;gap:8px;max-width:400px;display:flex}.toolbar-right{align-items:center;gap:8px;display:flex}.toolbar-search{border:1px solid var(--color-border);border-radius:var(--radius-md);font-size:var(--text-sm);background:var(--color-bg);outline:none;flex:1;padding:7px 12px;transition:border-color .15s}.toolbar-search:focus{border-color:var(--color-accent)}.data-table{border-collapse:collapse;width:100%}.data-table th{text-align:left;text-transform:uppercase;letter-spacing:.04em;color:var(--color-secondary);border-bottom:1px solid var(--color-border);white-space:nowrap;background:var(--color-bg);padding:10px 16px;font-size:11px;font-weight:600}.sortable-th{cursor:pointer;-webkit-user-select:none;user-select:none}.sortable-th:hover{color:var(--color-ink)}.sort-indicator{margin-left:4px;font-size:10px}.data-table td{border-bottom:1px solid var(--color-border);font-size:var(--text-sm);text-overflow:ellipsis;white-space:nowrap;max-width:300px;padding:10px 16px;overflow:hidden}.data-row{cursor:pointer;transition:background .1s}.data-row:hover{background:var(--color-accent-light)}.actions-th{text-align:right;width:120px}.actions-cell{text-align:right;white-space:nowrap}.actions-cell .btn+.btn{margin-left:6px}.cell-content{text-overflow:ellipsis;vertical-align:middle;max-width:250px;display:inline-block;overflow:hidden}.data-table-footer{border-top:1px solid var(--color-border);font-size:var(--text-sm);color:var(--color-secondary);justify-content:space-between;align-items:center;padding:12px 16px;display:flex}.pagination{align-items:center;gap:8px;display:flex}.page-indicator{font-size:var(--text-sm);color:var(--color-secondary);text-align:center;min-width:60px}.logs-table-wrapper{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);overflow:hidden}.method-badge{font-family:var(--font-mono);border-radius:var(--radius-sm);background:var(--color-bg);color:var(--color-secondary);padding:2px 8px;font-size:11px;font-weight:600}.status-badge{border-radius:var(--radius-full);font-size:11px;font-weight:600;font-family:var(--font-mono);align-items:center;padding:2px 10px;display:inline-flex}.status-success{background:var(--color-success-light);color:var(--color-success)}.status-warning{background:var(--color-warning-light);color:var(--color-warning)}.status-danger{background:var(--color-danger-light);color:var(--color-danger)}.log-detail-row td{background:var(--color-bg);padding:0}.log-detail{border-left:3px solid var(--color-accent);padding:16px 20px}.log-section{margin-bottom:12px}.log-section:last-child{margin-bottom:0}.log-section h4{text-transform:uppercase;letter-spacing:.04em;color:var(--color-secondary);margin-bottom:6px;font-size:11px;font-weight:600}.log-output{background:var(--color-sidebar);color:var(--color-sidebar-text);border-radius:var(--radius-md);font-family:var(--font-mono);font-size:var(--text-xs);white-space:pre-wrap;max-height:300px;padding:12px 16px;overflow:auto}.log-error{background:var(--color-danger-light);color:var(--color-danger);border-radius:var(--radius-md);font-family:var(--font-mono);font-size:var(--text-xs);white-space:pre-wrap;max-height:300px;padding:12px 16px;overflow:auto}.deploys-list{flex-direction:column;gap:12px;display:flex}.deploy-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);cursor:pointer;padding:16px 20px;transition:box-shadow .15s,border-color .15s}.deploy-card:hover{box-shadow:var(--shadow-sm);border-color:var(--color-accent)}.deploy-card-header{justify-content:space-between;align-items:center;display:flex}.deploy-info{align-items:center;gap:12px;display:flex}.deploy-version{font-weight:700;font-family:var(--font-mono);font-size:15px}.deploy-date{color:var(--color-secondary);font-size:var(--text-sm)}.deploy-detail{border-top:1px solid var(--color-border);margin-top:16px;padding-top:16px}.deploy-section{margin-bottom:16px}.deploy-section:last-child{margin-bottom:0}.deploy-section h4{text-transform:uppercase;letter-spacing:.04em;color:var(--color-secondary);margin-bottom:8px;font-size:11px;font-weight:600}.file-list,.function-list{list-style:none}.file-list li,.function-list li{font-size:var(--text-sm);font-family:var(--font-mono);color:var(--color-secondary);padding:4px 0}.env-table-wrapper{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);overflow:hidden}.env-key{font-weight:600}.env-secret{color:var(--color-muted);letter-spacing:.1em;align-items:center;gap:8px;display:flex}.env-value{font-family:var(--font-mono);font-size:var(--text-sm);align-items:center;gap:8px;display:flex}.modal-overlay{z-index:1000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#1c191766;justify-content:center;align-items:center;padding:24px;display:flex;position:fixed;inset:0}.modal{background:var(--color-surface);border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);flex-direction:column;width:100%;max-height:calc(100vh - 48px);display:flex;overflow:hidden}.modal-sm{max-width:400px}.modal-md{max-width:540px}.modal-lg{max-width:720px}.modal-header{border-bottom:1px solid var(--color-border);justify-content:space-between;align-items:center;padding:16px 24px;display:flex}.modal-title{font-family:var(--font-display);font-size:var(--text-lg);font-weight:600}.modal-close{color:var(--color-muted);cursor:pointer;background:0 0;border:none;padding:0 4px;font-size:24px;line-height:1;transition:color .15s}.modal-close:hover{color:var(--color-ink)}.modal-body{padding:24px;overflow-y:auto}.modal-footer{border-top:1px solid var(--color-border);justify-content:flex-end;align-items:center;gap:8px;padding:16px 24px;display:flex}.login-page{background:var(--color-cream);justify-content:center;align-items:center;min-height:100vh;padding:24px;display:flex}.login-wide{background:var(--color-surface);border:1px solid var(--color-border);border-radius:20px;width:100%;max-width:820px;min-height:520px;display:flex;overflow:hidden;box-shadow:0 2px 12px #0000000f,0 8px 40px #0000000a}.login-panel-left{background:var(--color-ink-raw);width:320px;color:var(--color-paper);flex-direction:column;flex-shrink:0;justify-content:space-between;padding:48px 36px 32px;display:flex;position:relative;overflow:hidden}.login-panel-left:after{content:"";pointer-events:none;background:#ffffff0f;border-radius:50%;width:200px;height:200px;position:absolute;bottom:-60px;right:-60px}.login-panel-left:before{content:"";pointer-events:none;background:#ffffff0d;border-radius:50%;width:140px;height:140px;position:absolute;top:-40px;left:-40px}.panel-left-content{z-index:1;position:relative}.brand-mark{color:var(--color-paper);margin-bottom:24px}.login-panel-left h1{font-family:var(--font-display);color:inherit;margin-bottom:8px;font-size:28px;font-weight:500;line-height:1.2}.panel-sub{opacity:.85;margin-bottom:4px;font-size:15px;line-height:1.5}.panel-sub strong{opacity:1;font-weight:600}.panel-domain{font-size:13px;font-family:var(--font-mono);opacity:.55;margin-top:2px}.step-context{background:#ffffff1f;border:1px solid #ffffff26;border-radius:24px;align-items:center;gap:10px;margin-top:24px;padding:8px 16px 8px 10px;display:inline-flex}.context-avatar{background:#ffffff26;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;display:flex}.context-email{font-size:13px;font-family:var(--font-mono);opacity:.85;text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.panel-left-footer{z-index:1;opacity:.55;max-width:360px;font-size:12px;line-height:1.5;position:relative}.panel-left-footer a{color:inherit;text-underline-offset:2px;text-decoration:underline}.panel-left-footer a:hover{opacity:.85}.panel-left-footer-desc{opacity:.8}.login-panel-right{flex:1;justify-content:center;align-items:center;padding:48px 44px;display:flex}.panel-right-content{width:100%;max-width:340px}.form-heading{font-family:var(--font-display);color:var(--color-ink);margin-bottom:6px;font-size:22px;font-weight:600}.form-sub{color:var(--color-secondary);margin-bottom:28px;font-size:14px;line-height:1.5}.form-sub strong{color:var(--color-ink);font-weight:500}.btn-auth-option{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);width:100%;color:var(--color-ink);cursor:pointer;align-items:center;gap:12px;margin-bottom:0;padding:12px 16px;font-family:inherit;font-size:14px;font-weight:500;transition:background .15s,border-color .15s,box-shadow .15s;display:flex}.btn-auth-option:hover{background:var(--color-cream);border-color:var(--color-border-hover);box-shadow:0 1px 3px #0000000f}.btn-auth-option:disabled{opacity:.6;cursor:not-allowed}.btn-auth-option svg{flex-shrink:0}.btn-auth-option span{text-align:left;flex:1}.login-hint{font-size:var(--text-sm);color:var(--color-secondary);margin-bottom:20px;line-height:1.5}.login-footer-text{color:var(--color-muted);margin-top:24px;font-size:13px;line-height:1.5}.login-legal{color:var(--color-muted);margin-top:16px;font-size:12px;line-height:1.6}.login-legal a{color:var(--color-secondary);text-decoration:none}.login-legal a:hover{color:var(--color-ink);text-decoration:underline}.back-btn{margin-top:8px}.back-btn svg{vertical-align:middle;margin-right:4px}.code-input{text-align:center;font-size:var(--text-xl);font-family:var(--font-mono);letter-spacing:.2em;padding:12px}.divider{color:var(--color-muted);font-size:var(--text-xs);align-items:center;gap:12px;margin:20px 0;display:flex}.divider:before,.divider:after{content:"";background:var(--color-border);flex:1;height:1px}.handle-input-wrap{align-items:center;display:flex}.handle-prefix{font-size:var(--text-md);color:var(--color-secondary);padding-right:4px;font-weight:600}.handle-input{font-family:var(--font-mono)}.passkey-hero-btn{justify-content:center;align-items:center;gap:10px;display:flex}.passkey-hero-btn svg{flex-shrink:0}.passkey-prompt-icon{background:var(--color-accent-light);border:1px solid #f5b84059;border-radius:50%;justify-content:center;align-items:center;width:72px;height:72px;margin:0 auto 20px;display:flex}@media (width<=680px){.login-wide{flex-direction:column;max-width:420px;min-height:auto}.login-panel-left{width:100%;min-height:auto;padding:32px 28px 24px}.login-panel-left h1{font-size:22px}.panel-left-footer{display:none}.login-panel-right{padding:32px 28px 36px}}.collab-list{flex-direction:column;gap:8px;display:flex}.collab-row{border-bottom:1px solid var(--color-border);justify-content:space-between;align-items:center;padding:10px 0;display:flex}.collab-row:last-child{border-bottom:none}.collab-info{align-items:center;gap:10px;display:flex}.collab-avatar{object-fit:cover;border-radius:50%;width:32px;height:32px}.collab-actions{align-items:center;gap:8px;display:flex}.profile-form{max-width:480px}.input-static{font-size:var(--text-sm);color:var(--color-secondary);font-family:var(--font-mono);padding:8px 0}.search-bar{gap:8px;display:flex}.search-bar .input{min-width:280px}.plan-current{font-size:var(--text-lg);align-items:center;gap:12px;font-weight:600;display:flex}.plans-grid{grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:16px;margin-top:16px;display:grid}.plan-card{border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:24px;transition:border-color .15s}.plan-card:hover{border-color:var(--color-border-hover)}.plan-card.plan-active{border-color:var(--color-accent);background:var(--color-accent-light)}.plan-card h3{font-family:var(--font-display);font-size:var(--text-lg);margin-bottom:8px;font-weight:700}.plan-price{font-family:var(--font-display);font-size:var(--text-2xl);margin-bottom:12px;font-weight:800}.plan-price span{font-size:var(--text-sm);color:var(--color-secondary);font-weight:400}.plan-features{margin-bottom:16px;list-style:none}.plan-features li{font-size:var(--text-sm);color:var(--color-secondary);padding:4px 0}.plan-features li:before{content:"✓";color:var(--color-success);margin-right:8px;font-weight:600}.loading-state,.empty-state,.error-state{text-align:center;color:var(--color-muted);flex-direction:column;justify-content:center;align-items:center;padding:64px 24px;display:flex}.loading-state p,.empty-state p,.error-state p{color:var(--color-secondary);max-width:360px;margin-top:8px;line-height:1.5}.empty-state h3,.error-state h3{font-family:var(--font-display);font-size:var(--text-lg);color:var(--color-ink);margin-top:16px;font-weight:600}.empty-state .btn{margin-top:16px}.spinner{border:3px solid var(--color-border);border-top-color:var(--color-accent);border-radius:50%;width:24px;height:24px;animation:.6s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.text-muted{color:var(--color-muted)}.text-secondary{color:var(--color-secondary)}.text-accent{color:var(--color-accent)}.text-success{color:var(--color-success)}.text-danger{color:var(--color-danger)}.mt-1{margin-top:4px}.mt-2{margin-top:8px}.mt-3{margin-top:16px}.mt-4{margin-top:24px}.mt-6{margin-top:32px}.mb-2{margin-bottom:8px}.mb-3{margin-bottom:16px}.profile-header{border-bottom:1px solid var(--color-border);align-items:flex-start;gap:24px;margin-bottom:24px;padding-bottom:32px;display:flex}.profile-avatar-lg{object-fit:cover;border-radius:50%;flex-shrink:0;width:96px;height:96px}.profile-avatar-fallback{background:var(--color-accent-light);color:var(--color-accent);font-family:var(--font-display);font-size:var(--text-2xl);justify-content:center;align-items:center;font-weight:700;display:flex}.profile-info{flex:1}.profile-display-name{font-family:var(--font-display);font-size:var(--text-2xl);margin-bottom:2px;font-weight:700}.profile-handle{font-size:var(--text-md);color:var(--color-secondary);margin-bottom:8px}.profile-bio{font-size:var(--text-base);color:var(--color-secondary);max-width:480px;margin-bottom:12px;line-height:1.6}.profile-stats{font-size:var(--text-sm);color:var(--color-secondary);gap:20px;display:flex}.profile-stats strong{color:var(--color-ink)}.profile-actions{flex-shrink:0}.detail-hero{align-items:flex-start;gap:32px;display:flex}.detail-hero-main{flex:1;min-width:0}.detail-sidebar{flex-shrink:0;width:280px}.detail-screenshot{aspect-ratio:16/10;border-radius:var(--radius-lg);border:1px solid var(--color-border);width:100%;margin-bottom:20px;overflow:hidden}.detail-screenshot img{object-fit:cover;width:100%;height:100%}.detail-screenshot-placeholder{background:var(--color-accent-light);color:var(--color-accent);font-family:var(--font-display);justify-content:center;align-items:center;font-size:64px;font-weight:700;display:flex}.detail-title{font-family:var(--font-display);font-size:var(--text-2xl);margin-bottom:4px;font-weight:700}.detail-tagline{font-size:var(--text-md);color:var(--color-secondary);margin-bottom:8px;font-style:italic}.detail-description{font-size:var(--text-base);color:var(--color-secondary);margin-bottom:16px;line-height:1.6}.detail-meta{font-size:var(--text-sm);color:var(--color-muted);flex-wrap:wrap;align-items:center;gap:12px;margin-bottom:20px;display:flex}.detail-creator{color:var(--color-ink);align-items:center;gap:6px;font-weight:500;text-decoration:none;display:flex}.detail-creator:hover{text-decoration:underline}.detail-creator-avatar{object-fit:cover;border-radius:50%;width:24px;height:24px}.detail-actions{flex-wrap:wrap;gap:8px;display:flex}.detail-owner-card{color:inherit;align-items:center;gap:12px;text-decoration:none;display:flex}.detail-owner-card:hover{text-decoration:none}.detail-owner-avatar{object-fit:cover;border-radius:50%;width:40px;height:40px}.detail-owner-card span{font-size:var(--text-xs);display:block}.recent-strip{gap:12px;display:flex;overflow-x:auto}.recent-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);color:inherit;min-width:180px;font-size:var(--text-sm);flex-direction:column;gap:4px;padding:12px 16px;text-decoration:none;transition:border-color .15s;display:flex}.recent-card:hover{border-color:var(--color-accent);text-decoration:none}.feed-list{flex-direction:column;gap:20px;display:flex}.feed-item{color:inherit;text-decoration:none}.feed-item:hover{text-decoration:none}.feed-item-creator{align-items:center;gap:8px;margin-bottom:4px;display:flex}.feed-avatar{object-fit:cover;border-radius:50%;width:24px;height:24px}@media (width<=768px){.project-layout{flex-direction:column}.sidebar{width:100%;min-height:auto}.sidebar-nav{padding:0;display:flex;overflow-x:auto}.sidebar-link{white-space:nowrap;padding:12px 16px}.sidebar-link.active{border-left:none;border-bottom:3px solid var(--color-sidebar-accent);padding-left:16px}.sidebar-tables{display:none}.project-main,.page-container{padding:20px}.page-header{flex-direction:column;align-items:flex-start}.project-grid{grid-template-columns:1fr}.data-table-toolbar{flex-direction:column}.toolbar-left{max-width:none}.search-bar{flex-direction:column}.search-bar .input{min-width:auto}.plans-grid{grid-template-columns:1fr}.header-nav{display:none}.app-header{gap:8px;padding:0 16px}.header-settings-link svg{margin-right:0}.header-settings-link-label{display:none}.btn{min-height:40px}.btn-sm{min-height:34px}}@media (width<=480px){.page-container,.project-main{padding:16px}.app-header{padding:0 12px}.data-table{display:block;overflow-x:auto}.modal{width:calc(100% - 32px);margin:16px}}
