@import"https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&family=JetBrains+Mono:wght@400;500&display=swap";:root{color-scheme:dark;--c-amber-200: 253 230 138;--c-amber-400: 251 191 36;--c-amber-500: 245 158 11;--c-amber-700: 180 83 9;--c-amber-900: 120 53 15;--c-black: 0 0 0;--c-blue-100: 219 234 254;--c-blue-300: 147 197 253;--c-blue-400: 96 165 250;--c-blue-500: 59 130 246;--c-blue-900: 30 58 138;--c-cyan-400: 34 211 238;--c-cyan-50: 236 254 255;--c-cyan-600: 8 145 178;--c-cyan-700: 14 116 144;--c-emerald-100: 209 250 229;--c-emerald-200: 167 243 208;--c-emerald-400: 52 211 153;--c-gray-900: 17 24 39;--c-green-200: 187 247 208;--c-green-300: 134 239 172;--c-green-500: 34 197 94;--c-green-800: 22 101 52;--c-green-900: 20 83 45;--c-mint-50: 223 253 243;--c-placeholder: 135 133 147;--c-purple-300: 216 180 254;--c-purple-400: 192 132 252;--c-purple-50: 243 232 255;--c-purple-500: 168 85 247;--c-purple-700: 126 34 206;--c-red-200: 254 202 202;--c-red-300: 252 165 165;--c-red-400: 248 113 113;--c-red-500: 239 68 68;--c-red-700: 185 28 28;--c-red-900: 127 29 29;--c-rose-400: 251 113 133;--c-rose-50: 255 241 242;--c-sky-100: 224 242 254;--c-sky-200: 186 230 253;--c-sky-300: 125 211 252;--c-sky-400: 56 189 248;--c-sky-500: 14 165 233;--c-sky-900: 12 74 110;--c-slate-200: 226 232 240;--c-slate-300: 203 213 225;--c-slate-400: 148 163 184;--c-slate-700: 51 65 85;--c-slate-800: 33 33 40;--c-slate-900: 22 22 27;--c-slate-950: 13 13 16;--c-violet-400: 167 139 250;--c-violet-600: 124 58 237;--c-white: 255 255 255;--c-yellow-400: 250 204 21;--c-slate-50: 248 250 252;--c-slate-100: 241 245 249;--c-slate-500: 100 116 139;--c-slate-600: 71 85 105;--c-rose-100: 255 228 230;--c-rose-200: 254 205 211;--c-rose-300: 253 164 175;--c-rose-500: 244 63 94;--c-pink-300: 249 168 212;--c-green-600: 22 163 74;--c-amber-600: 217 119 6;--c-red-600: 220 38 38;--c-ink-text: 15 23 42;--c-ink-900: 10 10 12;--c-ink-850: 20 20 24;--c-ink-panel: 19 19 23;--c-ink-panel-strong: 22 22 27;--c-ink-accent-text: 2 17 27;--c-ink-031525: 15 15 18;--c-ink-04111f: 14 14 17;--c-ink-050814: 10 10 12;--c-ink-060913: 11 11 13;--c-ink-070b14: 12 12 15;--c-ink-080d18: 15 15 18;--c-ink-090e19: 16 16 19;--c-ink-0a0f1b: 17 17 20;--c-ink-0a0f1c: 17 17 21;--c-ink-0b111d: 18 18 22;--c-ink-0c121f: 19 19 23;--c-ink-0c1220: 19 19 23;--c-ink-0d0c16: 17 17 20;--c-ink-0d1524: 21 21 25;--c-ink-140a20: 20 10 32;--c-ink-280e12: 40 14 18;--c-surface-0: 9 9 11;--c-surface-1: 15 15 18;--c-surface-2: 22 22 27;--c-surface-3: 31 31 38;--bg: rgb(var(--c-surface-0));--bg-soft: rgb(var(--c-surface-1));--panel: rgb(var(--c-surface-2) / .78);--panel-strong: rgb(var(--c-surface-2));--text: rgb(var(--c-slate-50));--text-secondary: rgb(var(--c-slate-300));--text-strong: rgb(var(--c-slate-200));--muted: rgb(var(--c-slate-400));--text-muted: rgb(var(--c-slate-400) / .85);--text-on-accent: rgb(var(--c-ink-accent-text));--border: rgb(var(--c-white) / .08);--border-strong: rgb(var(--c-white) / .16);--border-subtle: rgb(var(--c-white) / .06);--accent: rgb(var(--c-sky-400));--accent-soft: rgb(var(--c-sky-400) / .18);--link: rgb(var(--c-sky-400));--success: rgb(var(--c-emerald-400));--success-soft: rgb(var(--c-emerald-400) / .12);--success-text: rgb(var(--c-green-200));--warning: rgb(var(--c-amber-500));--warning-text: rgb(var(--c-amber-200));--danger: rgb(var(--c-red-400));--danger-soft: rgb(var(--c-red-400) / .28);--danger-text: rgb(var(--c-red-200));--shadow: 0 1px 2px rgb(var(--c-black) / .4), 0 10px 28px rgb(var(--c-black) / .5);--scrim: rgb(var(--c-black) / .66);--gradient-app-bg: radial-gradient(120% 80% at 50% -20%, rgb(var(--c-sky-400) / .08), transparent 60%), linear-gradient(180deg, rgb(var(--c-surface-0)) 0%, rgb(var(--c-surface-0)) 100%);--font-sans: "Inter", ui-sans-serif, system-ui, -apple-system, "Segoe UI", sans-serif;--font-mono: "JetBrains Mono", ui-monospace, "SFMono-Regular", Menlo, monospace;--tracking-tight: -.011em;--tracking-tighter: -.02em;--rail-width: 56px;--topbar-height: 52px}[data-theme=light]{color-scheme:light;--c-ink-900: 255 245 247;--c-ink-850: 255 255 255;--c-ink-panel: 255 255 255;--c-ink-panel-strong: 255 255 255;--c-ink-070b14: 255 255 255;--c-ink-080d18: 255 255 255;--c-ink-090e19: 255 255 255;--c-ink-0a0f1b: 255 255 255;--c-ink-0a0f1c: 255 255 255;--c-ink-0b111d: 255 255 255;--c-ink-0c121f: 255 255 255;--c-ink-0c1220: 255 255 255;--c-ink-0d0c16: 255 255 255;--c-ink-0d1524: 255 255 255;--c-ink-031525: 255 255 255;--c-ink-04111f: 255 255 255;--c-ink-050814: 255 245 247;--c-ink-060913: 255 245 247;--c-ink-140a20: 255 255 255;--c-ink-280e12: 255 255 255;--c-slate-950: 255 255 255;--c-slate-900: 255 255 255;--c-slate-800: 255 255 255;--c-gray-900: 255 255 255;--c-surface-0: 255 255 255;--c-surface-1: 255 255 255;--c-surface-2: 255 255 255;--c-surface-3: 248 250 252;--c-sky-400: 244 63 94;--c-sky-500: 225 29 72;--c-sky-300: 225 29 72;--c-sky-200: 190 18 60;--c-sky-100: 255 228 230;--c-cyan-600: 225 29 72;--c-cyan-700: 190 18 60;--c-cyan-400: 251 113 133;--c-blue-900: 219 234 254;--c-sky-900: 224 242 254;--c-red-900: 254 226 226;--c-amber-900: 254 243 199;--c-green-900: 220 252 231;--c-blue-100: 225 29 72;--c-mint-50: 22 101 52;--c-green-300: 22 101 52;--c-emerald-200: 22 101 52;--c-emerald-100: 22 101 52;--c-red-300: 185 28 28;--bg: rgb(var(--c-slate-50));--bg-soft: rgb(var(--c-slate-100));--panel: rgb(var(--c-white));--panel-strong: rgb(var(--c-white));--text: rgb(var(--c-ink-text));--text-secondary: rgb(var(--c-slate-700));--text-strong: rgb(var(--c-ink-text));--muted: rgb(var(--c-slate-600));--text-muted: rgb(var(--c-slate-500));--text-on-accent: rgb(var(--c-white));--border: rgb(var(--c-slate-300) / .75);--border-strong: rgb(var(--c-slate-400) / .7);--border-subtle: rgb(var(--c-slate-300) / .45);--accent: rgb(var(--c-rose-500));--accent-soft: rgb(var(--c-rose-500) / .14);--link: rgb(var(--c-violet-600));--success: rgb(var(--c-green-600));--success-soft: rgb(var(--c-green-600) / .14);--success-text: rgb(var(--c-green-800));--warning: rgb(var(--c-amber-600));--warning-text: rgb(var(--c-amber-700));--danger: rgb(var(--c-red-600));--danger-soft: rgb(var(--c-red-600) / .12);--danger-text: rgb(var(--c-red-700));--shadow: 0 1px 2px rgb(var(--c-slate-900) / .06), 0 10px 28px rgb(var(--c-slate-900) / .08);--scrim: rgb(var(--c-slate-900) / .32);--gradient-app-bg: radial-gradient(120% 80% at 50% -20%, rgb(var(--c-slate-200) / .6), transparent 60%), linear-gradient(180deg, rgb(var(--c-slate-50)) 0%, rgb(var(--c-slate-100)) 100%)}*{box-sizing:border-box}html,body{margin:0;min-height:100%}body{background:var(--gradient-app-bg);background-attachment:fixed;color:var(--text);font-family:var(--font-sans);font-feature-settings:"cv11","ss01";-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility}a{color:inherit;text-decoration:none}.app-shell{display:grid;grid-template-columns:var(--rail-width) minmax(0,1fr);height:100vh;height:100dvh}.app-rail{position:relative;z-index:20;display:flex;flex-direction:column;align-items:center;gap:1rem;padding:.75rem 0;border-right:1px solid var(--border);background:rgb(var(--c-surface-1) / .7);backdrop-filter:blur(16px)}.rail-brand{display:grid;place-items:center;padding:.25rem}.rail-brand__mark{display:grid;place-items:center;width:2rem;height:2rem;border-radius:.75rem;background:linear-gradient(135deg,rgb(var(--c-cyan-400) / .9),rgb(var(--c-cyan-700) / .9));color:rgb(var(--c-ink-04111f));font-weight:700;font-size:.95rem;box-shadow:0 8px 20px rgb(var(--c-cyan-400) / .25)}.rail-brand__mark--muted{background:rgb(var(--c-slate-400) / .14);color:var(--muted);box-shadow:none;font-size:.75rem}.rail-nav{display:grid;gap:.35rem;width:100%;padding:0 .35rem}.rail-link{display:grid;place-items:center;width:100%;aspect-ratio:1 / 1;border-radius:.75rem;border:1px solid transparent;color:var(--muted);transition:color .18s ease,border-color .18s ease,background .18s ease}.rail-link:hover,.rail-link.is-active{color:var(--accent);border-color:var(--border-strong);background:var(--accent-soft)}.rail-foot{margin-top:auto;padding-bottom:.35rem}.user{position:relative}.user__trigger{display:grid;place-items:center;width:2rem;height:2rem;border:1px solid transparent;border-radius:.75rem;background:rgb(var(--c-slate-400) / .14);color:var(--muted);cursor:pointer;list-style:none;transition:color .18s ease,border-color .18s ease,background .18s ease}.user__trigger::-webkit-details-marker{display:none}.user__trigger:hover,.user[open] .user__trigger{color:rgb(var(--c-blue-100));border-color:var(--border-strong);background:rgb(var(--c-sky-500) / .1)}.user__avatar{font-size:.75rem;font-weight:700}.user__menu{position:absolute;left:calc(100% + .75rem);bottom:0;display:grid;gap:.5rem;min-width:12rem;padding:.55rem;border:1px solid var(--border);border-radius:1rem;background:rgb(var(--c-slate-900) / .94);box-shadow:var(--shadow)}.user__identity{display:flex;align-items:center;gap:.45rem;min-width:0}.user__name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:.8rem;font-weight:600}.user__badge{padding:.12rem .4rem;border-radius:999px;background:var(--success-soft);color:rgb(var(--c-emerald-200));font-size:.68rem;font-weight:700;text-transform:uppercase}.user form{margin:0}.user__logout{width:100%;padding:.4rem .65rem;border:0;border-radius:999px;background:rgb(var(--c-slate-400) / .12);color:var(--muted);font:inherit;font-size:.75rem;font-weight:700;cursor:pointer}.user__logout:hover{color:var(--text);background:var(--border-subtle)}.app-viewport{display:flex;flex-direction:column;min-width:0;min-height:0}.app-topbar{position:relative;z-index:30;display:flex;align-items:center;justify-content:space-between;gap:1rem;min-height:var(--topbar-height);padding:0 1rem;border-bottom:1px solid var(--border);background:rgb(var(--c-surface-0) / .7);backdrop-filter:blur(16px) saturate(140%)}.topbar-title{position:relative;display:flex;align-items:center;gap:.5rem;min-width:0}.topbar-title h1{margin:0;font-size:.95rem;font-weight:600;letter-spacing:var(--tracking-tight);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.topbar-crumb{display:inline-flex;align-items:center;gap:.4rem;color:var(--muted);font-size:.85rem}.topbar-crumb a:hover{color:var(--text)}.topbar-eyebrow{color:var(--muted);font-size:.75rem;letter-spacing:.1em;text-transform:uppercase;margin-left:.25rem}.topbar-actions{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap;justify-content:flex-end}.environment-nav{position:relative;display:inline-flex;align-items:center;gap:.45rem;min-width:0}.environment-nav__divider{color:rgb(var(--c-slate-400) / .45);font-size:1.2rem}.environment-nav__trigger{display:inline-flex;align-items:center;gap:.35rem;min-width:0;padding:.15rem .1rem;border:0;background:transparent;color:var(--text);font:inherit;font-size:.95rem;font-weight:600;cursor:pointer}.environment-nav__trigger span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.environment-nav__trigger svg{flex:0 0 auto;color:var(--muted);transition:color .15s ease,transform .15s ease}.environment-nav__trigger:hover svg,.environment-nav__trigger[aria-expanded=true] svg{color:var(--accent)}.environment-nav__trigger[aria-expanded=true] svg{transform:rotate(180deg)}.environment-menu{position:absolute;top:calc(100% + 1.1rem);left:-.8rem;z-index:40;width:min(20rem,calc(100vw - 2rem));padding:.8rem .55rem .55rem;border:1px solid rgb(var(--c-slate-400) / .18);border-radius:.75rem;background:rgb(var(--c-ink-0a0f1c) / .98);box-shadow:0 18px 48px var(--scrim),0 0 0 1px rgb(var(--c-sky-300) / .04);backdrop-filter:blur(12px);animation:add-menu-in .14s ease-out}.environment-menu__title{margin:0 0 .45rem;padding:0 .6rem;color:var(--muted);font-size:.82rem;font-weight:700}.environment-menu__list{display:grid;gap:.1rem;padding-bottom:.55rem;border-bottom:1px solid rgb(var(--c-slate-400) / .14)}.environment-menu__item,.environment-menu__new{display:flex;align-items:center;gap:.75rem;width:100%;min-height:2.6rem;padding:0 .6rem;border:0;border-radius:.55rem;background:transparent;color:var(--text);font:inherit;font-size:.92rem;font-weight:600;text-align:left;cursor:pointer;transition:background .14s ease,color .14s ease}.environment-menu__item:hover,.environment-menu__new:hover{background:rgb(var(--c-sky-500) / .12)}.environment-menu__check,.environment-menu__new span:first-child{display:grid;place-items:center;width:1.4rem;color:var(--accent);font-size:1.05rem;line-height:1}.environment-menu__new{margin-top:.55rem;color:rgb(var(--c-slate-200) / .7)}.environment-menu__new:hover{color:var(--text)}.environment-modal-overlay{background:rgb(var(--c-black) / .68);backdrop-filter:blur(9px);-webkit-backdrop-filter:blur(9px)}.environment-modal{display:grid;gap:1.05rem;width:min(42rem,100%);padding:1.45rem;border:1px solid rgb(var(--c-slate-400) / .14);border-radius:1.15rem;background:rgb(var(--c-ink-0a0f1c) / .98);box-shadow:0 26px 70px rgb(var(--c-slate-950) / .72),0 0 0 1px rgb(var(--c-sky-300) / .05);animation:modal-dialog-in .18s cubic-bezier(.16,1,.3,1)}.environment-modal__header{display:flex;align-items:center;justify-content:space-between;gap:1rem}.environment-modal__header h2{margin:0;font-size:1.35rem;font-weight:800;letter-spacing:-.02em}.environment-modal__close{border:0;background:transparent}.environment-modal__intro{max-width:35rem;margin:-.25rem 0 0;color:rgb(var(--c-slate-300) / .72);font-size:1rem;line-height:1.45}.environment-modal__name-input{width:100%;min-height:3.05rem;padding:0 .95rem;border:1px solid rgb(var(--c-sky-400) / .55);border-radius:.55rem;background:rgb(var(--c-slate-950) / .72);color:var(--text);font:inherit;font-size:1rem;outline:none;box-shadow:0 0 0 1px rgb(var(--c-sky-400) / .12)}.environment-modal__name-input::placeholder{color:rgb(var(--c-slate-300) / .55)}.environment-modal__name-input:focus{border-color:rgb(var(--c-sky-400) / .9);box-shadow:0 0 0 3px var(--accent-soft)}.environment-modal__options{display:grid;gap:.7rem;margin:0;padding:0;border:0}.environment-modal__option{display:grid;grid-template-columns:auto minmax(0,1fr);gap:.85rem;padding:1rem;border:1px solid rgb(var(--c-slate-400) / .14);border-radius:.6rem;background:rgb(var(--c-white) / .025);cursor:pointer;transition:background .15s ease,border-color .15s ease}.environment-modal__option--selected{border-color:rgb(var(--c-sky-400) / .42);background:rgb(var(--c-sky-500) / .14)}.environment-modal__radio{display:grid;place-items:center;width:1.35rem;height:1.35rem;margin-top:.1rem;border:1.5px solid rgb(var(--c-slate-400) / .45);border-radius:999px}.environment-modal__option--selected .environment-modal__radio{border-color:var(--accent);background:var(--accent);box-shadow:inset 0 0 0 .35rem rgb(var(--c-ink-0a0f1c) / .98)}.environment-modal__option-content{display:grid;gap:.75rem;min-width:0}.environment-modal__option-content strong{color:var(--text);font-size:1rem;font-weight:800}.environment-modal__option-copy{color:rgb(var(--c-slate-300) / .68);font-size:.94rem;line-height:1.45}.environment-modal__select-wrap{position:relative;display:block;max-width:100%}.environment-modal__select-wrap svg{position:absolute;top:50%;right:.9rem;color:var(--muted);pointer-events:none;transform:translateY(-50%)}.environment-modal__select{width:100%;min-height:3rem;padding:0 2.6rem 0 .9rem;border:1px solid var(--border);border-radius:.55rem;appearance:none;background:rgb(var(--c-slate-950) / .86);color:var(--text);font:inherit;font-size:1rem;outline:none}.environment-modal__select:focus{border-color:rgb(var(--c-sky-400) / .72);box-shadow:0 0 0 3px rgb(var(--c-sky-400) / .14)}.environment-modal__select:disabled{cursor:not-allowed;opacity:.55}.environment-modal__submit{min-height:3.2rem;border:0;border-radius:.55rem;background:linear-gradient(135deg,rgb(var(--c-cyan-600)),var(--accent));color:var(--text-on-accent);font:inherit;font-size:1rem;font-weight:800;cursor:pointer;transition:background .15s ease,transform .15s ease,opacity .15s ease}.environment-modal__submit:hover:enabled{background:linear-gradient(135deg,rgb(var(--c-cyan-700)),rgb(var(--c-cyan-400)));transform:translateY(-1px)}.environment-modal__submit:disabled{cursor:not-allowed;opacity:.48}.app-content{flex:1;min-height:0;padding:1.25rem;overflow:auto}.app-content--bleed{padding:0;overflow:hidden}.app-content__subtitle{margin:0 0 1rem;max-width:60ch;color:var(--muted);line-height:1.55}.auth-page{display:grid;place-items:center;min-height:100vh;min-height:100dvh;padding:1.5rem}.auth-card{width:min(100%,26rem);padding:1.4rem;border:1px solid var(--border);border-radius:1.15rem;background:var(--panel);box-shadow:var(--shadow)}.auth-card__brand{display:inline-flex;align-items:center;gap:.55rem;margin-bottom:1.5rem;font-weight:700}.auth-card__eyebrow{margin:0 0 .25rem;color:var(--accent);font-size:.75rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase}.auth-card h1{margin:0;font-size:1.6rem}.auth-card__subtitle{margin:.45rem 0 1.25rem;color:var(--muted)}.auth-card__mock-note,.auth-form__error{margin:0 0 1rem;padding:.75rem .85rem;border-radius:.75rem;font-size:.88rem;line-height:1.45}.auth-card__mock-note{border:1px solid rgb(var(--c-emerald-400) / .25);background:rgb(var(--c-emerald-400) / .1);color:rgb(var(--c-emerald-100))}.auth-form{display:grid;gap:.9rem}.auth-form label{display:grid;gap:.35rem;color:var(--muted);font-size:.82rem;font-weight:700}.auth-form input{width:100%;padding:.72rem .8rem;border:1px solid var(--border);border-radius:.7rem;background:rgb(var(--c-slate-950) / .45);color:var(--text);font:inherit}.auth-form input:focus{outline:none;border-color:var(--border-strong);box-shadow:0 0 0 3px rgb(var(--c-sky-400) / .12)}.auth-form button{padding:.72rem .9rem;border:1px solid rgb(var(--c-sky-300) / .45);border-radius:.7rem;background:linear-gradient(135deg,rgb(var(--c-sky-400) / .94),rgb(var(--c-cyan-700) / .95));color:rgb(var(--c-ink-031525));font:inherit;font-weight:800;cursor:pointer}.auth-form__error{border:1px solid var(--danger-soft);background:rgb(var(--c-red-400) / .12);color:var(--danger-text)}.projects-page{display:grid;gap:1.25rem}.projects-page__summary{display:flex;align-items:center;gap:.85rem;padding:.1rem .15rem}.projects-page__summary p{margin:0;font-size:.8125rem;font-weight:500;letter-spacing:var(--tracking-tight);color:var(--muted)}.new-project__button{display:inline-flex;align-items:center;gap:.4rem;padding:.38rem .8rem;border-radius:.55rem;border:1px solid transparent;background:var(--accent);color:var(--text-on-accent);font:inherit;font-size:.82rem;font-weight:600;letter-spacing:var(--tracking-tight);cursor:pointer;transition:transform .15s ease,box-shadow .15s ease,opacity .15s ease}.new-project__button:hover,.new-project__button[aria-expanded=true]{transform:translateY(-1px);box-shadow:0 6px 18px var(--accent-soft)}.new-project__plus{font-size:1rem;line-height:1}.modal-overlay{position:fixed;inset:0;z-index:50;display:grid;place-items:center;padding:1.5rem;background:var(--scrim);backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);animation:modal-overlay-in .16s ease-out}@keyframes modal-overlay-in{0%{opacity:0}to{opacity:1}}.modal-dialog{width:min(28rem,100%);border-radius:1rem;border:1px solid var(--border);background:rgb(var(--c-ink-0a0f1c) / .96);box-shadow:0 24px 60px rgb(var(--c-slate-950) / .6),0 0 0 1px rgb(var(--c-slate-400) / .06);animation:modal-dialog-in .18s cubic-bezier(.16,1,.3,1)}@keyframes modal-dialog-in{0%{opacity:0;transform:translateY(8px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}.modal-dialog__header{display:flex;align-items:center;justify-content:space-between;gap:.75rem;padding:1rem 1rem .75rem;border-bottom:1px solid var(--border)}.modal-dialog__header h2{margin:0;font-size:1rem;font-weight:600}.modal-dialog__close{display:grid;place-items:center;width:1.9rem;height:1.9rem;border-radius:.55rem;border:1px solid var(--border);background:rgb(var(--c-slate-900) / .85);color:var(--muted);cursor:pointer;transition:background .15s ease,color .15s ease,border-color .15s ease}.modal-dialog__close:hover:enabled{background:rgb(var(--c-slate-800) / .95);color:var(--text);border-color:rgb(var(--c-slate-400) / .45)}.modal-dialog__close:disabled{cursor:not-allowed;opacity:.6}.modal-dialog__form{display:grid;gap:.6rem;padding:1rem}.modal-dialog__form label{color:var(--muted);font-size:.82rem}.modal-dialog__form input{min-height:2.5rem;padding:0 .75rem;border-radius:.6rem;border:1px solid var(--border);background:rgb(var(--c-slate-950) / .85);color:var(--text);font:inherit;font-size:.9rem;outline:none}.modal-dialog__form input:focus{border-color:rgb(var(--c-sky-400) / .6);box-shadow:0 0 0 3px rgb(var(--c-sky-400) / .15)}.modal-dialog__field{display:grid;gap:.4rem;color:var(--muted);font-size:.82rem}.modal-dialog__field input{min-height:2.5rem;padding:0 .75rem;border-radius:.6rem;border:1px solid var(--border);background:rgb(var(--c-slate-950) / .85);color:var(--text);font:inherit;font-size:.9rem;outline:none}.modal-dialog__field input:focus{border-color:rgb(var(--c-sky-400) / .6);box-shadow:0 0 0 3px rgb(var(--c-sky-400) / .15)}.modal-dialog__actions{display:flex;justify-content:flex-end;gap:.5rem;margin-top:.25rem}.modal-dialog__submit,.modal-dialog__confirm,.modal-dialog__cancel{min-height:2.4rem;padding:0 .95rem;border-radius:.6rem;font:inherit;font-size:.85rem;font-weight:600;cursor:pointer}.modal-dialog__submit,.modal-dialog__confirm{border:0;background:linear-gradient(135deg,rgb(var(--c-cyan-600)),var(--accent));color:var(--text-on-accent);transition:transform .15s ease,box-shadow .15s ease}.modal-dialog__submit:hover:enabled,.modal-dialog__confirm:hover:enabled{transform:translateY(-1px);box-shadow:0 10px 20px rgb(var(--c-sky-400) / .2)}.modal-dialog__submit:disabled,.modal-dialog__confirm:disabled{cursor:not-allowed;opacity:.6}.modal-dialog__cancel{border:1px solid var(--border);background:transparent;color:var(--muted)}.modal-dialog__cancel:hover:enabled{color:var(--text);border-color:rgb(var(--c-slate-400) / .45)}.modal-dialog__cancel:disabled{cursor:not-allowed;opacity:.6}.modal-dialog__error{margin:0;padding:.55rem .75rem;border-radius:.55rem;background:rgb(var(--c-red-900) / .22);border:1px solid var(--danger-soft);color:var(--danger-text);font-size:.83rem}.modal-dialog__body{padding:.95rem 1rem .25rem;display:grid;gap:.65rem;font-size:.88rem;color:var(--text);line-height:1.5}.modal-dialog>.modal-dialog__actions{padding:.25rem 1rem 1rem;margin-top:0}.modal-dialog__body p{margin:0}.modal-dialog__body strong{color:var(--danger-text)}.modal-dialog__warning{padding:.55rem .75rem;border-radius:.55rem;border:1px solid rgb(var(--c-amber-500) / .38);background:rgb(var(--c-amber-900) / .22);color:var(--warning-text);font-size:.83rem}.modal-dialog__danger{min-height:2.4rem;padding:0 .95rem;border-radius:.6rem;border:0;background:linear-gradient(135deg,rgb(var(--c-red-700)),rgb(var(--c-red-500)));color:rgb(var(--c-rose-50));font:inherit;font-size:.85rem;font-weight:600;cursor:pointer;transition:transform .15s ease,box-shadow .15s ease}.modal-dialog__danger:hover:enabled{transform:translateY(-1px);box-shadow:0 10px 22px rgb(var(--c-red-500) / .28)}.modal-dialog__danger:disabled{cursor:not-allowed;opacity:.65}.danger-zone{display:grid;gap:.6rem;margin-top:.4rem;padding-top:.75rem;border-top:1px solid var(--border)}.danger-zone__actions{display:flex;gap:.6rem}.danger-zone__actions .danger-zone__button{flex:1}.danger-zone__button{padding:.55rem .85rem;border-radius:.55rem;border:1px solid rgb(var(--c-red-400) / .35);background:rgb(var(--c-red-900) / .14);color:rgb(var(--c-red-300));font:inherit;font-size:.85rem;font-weight:600;cursor:pointer;transition:background .15s ease,color .15s ease,border-color .15s ease}.danger-zone__button:hover:enabled{background:rgb(var(--c-red-900) / .3);color:var(--danger-text);border-color:rgb(var(--c-red-400) / .55)}.danger-zone__button:disabled{cursor:not-allowed;opacity:.55}.detach-form{display:grid;gap:.55rem;padding-top:.5rem;margin-top:.1rem;border-top:1px solid var(--border)}.detach-form__submit{padding:.5rem .8rem;border-radius:.55rem;border:1px solid rgb(var(--c-yellow-400) / .3);background:rgb(var(--c-amber-900) / .18);color:var(--warning-text);font:inherit;font-size:.82rem;font-weight:600;cursor:pointer;transition:background .15s ease,border-color .15s ease}.detach-form__submit:hover:enabled{background:rgb(var(--c-amber-900) / .32);border-color:rgb(var(--c-yellow-400) / .5)}.detach-form__submit:disabled{cursor:not-allowed;opacity:.55}.projects-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(17.5rem,20rem));justify-content:start;align-items:start;gap:.85rem}.project-card,.empty-state,.details-panel{border:1px solid var(--border);border-radius:1rem;background:var(--panel);box-shadow:var(--shadow);backdrop-filter:blur(18px)}.project-card{position:relative;display:grid;grid-template-rows:auto minmax(0,1fr) auto;gap:.75rem;width:100%;min-height:13rem;padding:.95rem 1rem .85rem;transition:transform .18s ease,border-color .18s ease,box-shadow .18s ease;animation:rise-in .32s ease both}.project-card:hover{transform:translateY(-2px);border-color:var(--border-strong);box-shadow:0 1px 2px rgb(var(--c-black) / .3),0 16px 40px rgb(var(--c-black) / .45)}.project-card--deleting{opacity:.62}.project-card__delete-error{flex-basis:100%;color:var(--danger-text)}.project-card__header,.project-card__footer,.details-panel__header{display:flex;justify-content:space-between;gap:1rem;align-items:center}.details-panel__header-actions{display:inline-flex;align-items:center;gap:.5rem}.details-panel__eyebrow{display:inline-flex;align-items:center;gap:.5rem;margin:0}.details-panel__eyebrow .status-pill{letter-spacing:0;text-transform:none}.details-panel__close{display:grid;place-items:center;width:1.8rem;height:1.8rem;padding:0;border-radius:.5rem;border:1px solid var(--border);background:rgb(var(--c-slate-900) / .74);color:var(--muted);cursor:pointer;transition:color .16s ease,border-color .16s ease,background .16s ease}.details-panel__close:hover{color:var(--text);border-color:var(--border-strong);background:rgb(var(--c-sky-500) / .12)}.project-card__header h2,.details-panel__header h3{margin:0;font-size:.9375rem;font-weight:600;letter-spacing:var(--tracking-tight);color:var(--text-strong)}.details-tabs{display:flex;gap:1.2rem;margin:-.2rem -1rem 0;padding:0 1rem;border-bottom:1px solid var(--border)}.details-tabs__item{position:relative;padding:.15rem 0 .75rem;border:0;background:transparent;color:var(--muted);font:inherit;font-size:.82rem;font-weight:600;cursor:pointer;transition:color .16s ease}.details-tabs__item:hover,.details-tabs__item--active{color:var(--text)}.details-tabs__item--active:after{content:"";position:absolute;right:0;bottom:-1px;left:0;height:1px;border-radius:999px;background:var(--text)}.details-tab-panel--empty{min-height:12rem}.variables-panel{display:grid;gap:.8rem}.variables-panel__header{display:flex;align-items:center;justify-content:space-between;gap:.75rem}.variables-panel__header strong{font-size:.95rem;color:var(--text)}.variables-panel__new-button{min-height:2.2rem;padding:0 .85rem;border-radius:.6rem;border:1px solid rgb(var(--c-sky-400) / .3);background:rgb(var(--c-sky-500) / .14);color:rgb(var(--c-sky-200));font:inherit;font-size:.82rem;font-weight:700;cursor:pointer;transition:background .15s ease,border-color .15s ease,color .15s ease,transform .15s ease}.variables-panel__new-button:hover:enabled{transform:translateY(-1px);border-color:rgb(var(--c-sky-400) / .5);background:rgb(var(--c-sky-500) / .24);color:rgb(var(--c-sky-100))}.variables-panel__new-button:disabled{cursor:not-allowed;opacity:.6}.variable-form{display:grid;gap:.65rem;padding-bottom:.8rem;border-bottom:1px solid var(--border)}.variable-form__row{display:grid;grid-template-columns:minmax(9rem,.85fr) minmax(12rem,1.2fr) auto auto;gap:.55rem;align-items:center}.variable-form__field{position:relative;display:grid;color:var(--muted);font-size:.78rem}.variable-form__label{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.variable-form input{width:100%;min-height:2.45rem;padding:0 .75rem;border-radius:.65rem;border:1px solid var(--border);background:rgb(var(--c-slate-900) / .88);color:var(--text);font:inherit;font-size:.88rem}.variable-form input:focus{outline:2px solid rgb(var(--c-sky-400) / .32);outline-offset:2px;border-color:rgb(var(--c-sky-400) / .45)}.variable-form__secret{display:inline-flex;align-items:center;gap:.5rem;min-height:2.45rem;width:fit-content;padding:0 .8rem;border:1px solid var(--border);border-radius:.65rem;background:rgb(var(--c-slate-900) / .72);color:var(--text);font-size:.82rem;font-weight:600;cursor:pointer;transition:background .15s ease,border-color .15s ease}.variable-form__secret:hover{border-color:rgb(var(--c-slate-400) / .45)}.variable-form__secret:has(input:checked){border-color:rgb(var(--c-sky-400) / .4);background:rgb(var(--c-sky-400) / .08)}.variable-form__secret input[type=checkbox]{appearance:none;-webkit-appearance:none;flex:none;box-sizing:border-box;width:1.05rem;height:1.05rem;min-height:0;margin:0;padding:0;border:1px solid var(--border-strong);border-radius:.35rem;background:rgb(var(--c-slate-900) / .9);cursor:pointer;transition:background .15s ease,border-color .15s ease}.variable-form__secret input[type=checkbox]:checked{border-color:var(--accent);background-color:var(--accent);background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='none' stroke='%2302111b' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M3.5 8.4l3 3 6-6.6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:center;background-size:.72rem}.variable-form__secret input[type=checkbox]:focus-visible{outline:2px solid rgb(var(--c-sky-400) / .32);outline-offset:2px}.variable-form__secret input[type=checkbox]:disabled{cursor:not-allowed;opacity:.55}.variable-form__actions{display:flex;align-items:center;gap:.5rem}.variable-form__submit,.variable-form__cancel,.variable-row button{min-height:2.35rem;padding:0 .9rem;border-radius:.6rem;border:1px solid var(--border);background:rgb(var(--c-slate-900) / .9);color:var(--text);font:inherit;font-size:.82rem;font-weight:600;cursor:pointer;transition:background .15s ease,border-color .15s ease}.variable-form__submit{background:linear-gradient(135deg,rgb(var(--c-cyan-600)),var(--accent));color:var(--text-on-accent);border:0}.variable-form__cancel{background:rgb(var(--c-slate-900) / .72);color:var(--muted)}.variable-form__submit:hover:enabled,.variable-row button:hover:enabled{border-color:rgb(var(--c-slate-400) / .45);background:rgb(var(--c-slate-800) / .95)}.variable-form__submit:hover:enabled{background:linear-gradient(135deg,rgb(var(--c-cyan-700)),rgb(var(--c-cyan-400)))}.variable-form__cancel:hover:enabled{border-color:rgb(var(--c-slate-400) / .45);color:var(--text)}.variable-form__submit:disabled,.variable-form__cancel:disabled,.variable-row button:disabled{cursor:not-allowed;opacity:.6}@media(max-width:980px){.variable-form__row{grid-template-columns:1fr}.variable-form__actions{justify-content:stretch}.variable-form__actions>button{flex:1}}.variables-list{display:grid;gap:.55rem}.variable-row{display:grid;grid-template-columns:minmax(0,1fr) repeat(3,auto);gap:.5rem;align-items:center;padding:.65rem;border-radius:.75rem;border:1px solid var(--border);background:rgb(var(--c-slate-900) / .66)}.variable-row__main{min-width:0;display:grid;gap:.35rem}.variable-row__heading{display:flex;align-items:center;gap:.4rem;min-width:0}.variable-row code{font-family:JetBrains Mono,SFMono-Regular,ui-monospace,monospace;font-size:.78rem}.variable-row__heading code,.variable-row__value{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.variable-row__value{color:var(--muted)}.variable-badge{padding:.16rem .38rem;border-radius:999px;border:1px solid rgb(var(--c-slate-400) / .22);color:var(--muted);font-size:.68rem;line-height:1}.project-card__preview{position:relative;overflow:hidden;min-height:0;padding:1rem;border-radius:.65rem;border:1px solid var(--border-subtle);background:radial-gradient(var(--border) 1px,transparent 1px) 0 0 / 18px 18px,var(--bg);display:grid;place-items:center}.project-card__icons{display:flex;flex-wrap:wrap;justify-content:center;align-items:center;gap:.6rem}.resource-icon{display:inline-grid;place-items:center;border-radius:.65rem;border:1px solid rgb(var(--c-slate-400) / .18);background:rgb(var(--c-slate-900) / .82);color:var(--text);box-shadow:0 6px 16px rgb(var(--c-slate-950) / .35);transition:transform .18s ease,border-color .18s ease,background .18s ease}.resource-icon--md{width:2.5rem;height:2.5rem}.resource-icon--sm{width:1.6rem;height:1.6rem;border-radius:.45rem;box-shadow:none}.project-card:hover .resource-icon{border-color:rgb(var(--c-slate-400) / .32)}.resource-icon--md svg{width:1.25rem;height:1.25rem}.resource-icon--sm svg{width:.95rem;height:.95rem}.resource-icon--postgres{color:rgb(var(--c-sky-300));background:rgb(var(--c-sky-900) / .45);border-color:rgb(var(--c-sky-300) / .32)}.resource-icon--redis{color:rgb(var(--c-red-300));background:rgb(var(--c-red-900) / .42);border-color:rgb(var(--c-red-300) / .32)}.resource-icon--github{color:var(--text-strong);background:rgb(var(--c-gray-900) / .9);border-color:rgb(var(--c-slate-400) / .28)}.resource-icon--docker{color:rgb(var(--c-blue-400));background:rgb(var(--c-blue-900) / .4);border-color:rgb(var(--c-blue-400) / .3)}.resource-icon--bare{background:transparent;border:0;box-shadow:none;border-radius:0;width:auto;height:auto}.resource-icon--creating,.resource-icon--deleting{opacity:.7;animation:resource-icon-pulse 1.6s ease-in-out infinite}.resource-icon--unhealthy{border-color:rgb(var(--c-red-400) / .55);box-shadow:0 0 0 1px rgb(var(--c-red-400) / .18),0 6px 16px rgb(var(--c-slate-950) / .35)}.resource-icon--overflow{color:var(--muted);font-size:.78rem;font-weight:600;letter-spacing:.02em}@keyframes resource-icon-pulse{0%,to{opacity:.55}50%{opacity:.9}}@media(prefers-reduced-motion:reduce){.project-loading,.project-loading__node,.project-loading__edge,.project-loading__icon,.project-loading__badge,.project-loading__title,.project-loading__subtitle,.project-loading__status,.resource-icon--creating,.resource-icon--deleting,.project-card__status--deleting .project-card__status-dot{animation:none}}.project-card__empty{margin:0;color:var(--muted);font-size:.8125rem}.project-card__footer{justify-content:flex-start;align-items:center;gap:.4rem;color:var(--muted);font-size:.72rem;letter-spacing:var(--tracking-tight);flex-wrap:wrap}.project-card__footer-sep{color:var(--border-strong)}.project-card__status{display:inline-flex;align-items:center;gap:.4rem;padding:.2rem .5rem .2rem .45rem;border-radius:999px;border:1px solid var(--border);background:var(--bg-soft);font-size:.7rem;font-weight:600;white-space:nowrap}.project-card__status-dot{width:.5rem;height:.5rem;border-radius:999px;background:currentColor}.project-card__status--online{color:var(--success)}.project-card__status--degraded{color:rgb(var(--c-amber-400))}.project-card__status--empty{color:rgb(var(--c-slate-400) / .7)}.project-card__status--deleting{color:var(--warning)}.project-card__status--failed{color:var(--danger)}.project-card__status--deleting .project-card__status-dot{animation:project-delete-pulse 1.2s ease-in-out infinite;box-shadow:0 0 0 2px rgb(var(--c-slate-900) / .7),0 0 rgb(var(--c-amber-500) / .42)}@keyframes project-delete-pulse{0%,to{opacity:.65;transform:scale(.92);box-shadow:0 0 0 2px rgb(var(--c-slate-900) / .7),0 0 rgb(var(--c-amber-500) / .38)}50%{opacity:1;transform:scale(1.08);box-shadow:0 0 0 2px rgb(var(--c-slate-900) / .7),0 0 0 5px rgb(var(--c-amber-500) / 0)}}.empty-state{padding:1.75rem}.not-found-layout{display:grid;place-items:center;height:100%;min-height:0;padding:2rem}.empty-state--centered{width:min(32rem,100%);text-align:center}.empty-state__eyebrow{margin:0 0 .45rem!important;color:var(--accent)!important;font-size:.78rem;font-weight:700;letter-spacing:.16em;text-transform:uppercase}.empty-state__link{display:inline-flex;margin-top:1rem;border:0;background:transparent;color:rgb(var(--c-sky-200));font:inherit;font-weight:600;cursor:pointer}.empty-state__link:hover{color:var(--text)}.empty-state h2,.details-panel__empty h3{margin:0}.empty-state p,.details-panel__empty p{margin:.5rem 0 0;color:var(--muted);line-height:1.6}.project-loading{position:relative;display:grid;grid-template-rows:auto minmax(0,1fr) auto;gap:1rem;height:100%;min-height:0;padding:.75rem;background:radial-gradient(circle at 30% 20%,rgb(var(--c-sky-400) / .05),transparent 50%),radial-gradient(circle,rgb(var(--c-slate-400) / .14) 1px,transparent 1px),linear-gradient(180deg,rgb(var(--c-ink-080d18) / .92),rgb(var(--c-ink-070b14) / .95));background-size:auto,22px 22px,cover;animation:project-page-in .22s ease-out both}.project-loading__summary{display:flex;gap:.45rem}.project-loading__summary span{width:5.5rem;height:1.8rem;border-radius:999px;background:rgb(var(--c-slate-400) / .12)}.project-loading__canvas{position:relative;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6.5rem;min-height:0}.project-loading__node{position:relative;z-index:1;display:grid;gap:.7rem;width:20rem;min-height:8.4rem;padding:1rem;border:1px solid var(--accent-soft);border-radius:1rem;background:rgb(var(--c-ink-090e19) / .82);box-shadow:0 18px 46px rgb(var(--c-slate-950) / .28);animation:project-node-float 1.8s ease-in-out infinite}.project-loading__node--bottom{animation-delay:.12s}.project-loading__node-header{display:flex;align-items:center;gap:.65rem}.project-loading__icon,.project-loading__badge,.project-loading__title,.project-loading__subtitle,.project-loading__status{display:block;overflow:hidden;background:linear-gradient(90deg,transparent,rgb(var(--c-slate-200) / .16),transparent),rgb(var(--c-slate-400) / .1);background-size:220% 100%;animation:project-skeleton-shimmer 1.35s ease-in-out infinite}.project-loading__icon{width:2rem;height:2rem;border:1px solid rgb(var(--c-sky-400) / .22);border-radius:.6rem}.project-loading__badge{width:6.25rem;height:1.45rem;border-radius:999px}.project-loading__title{width:9rem;height:1.1rem;border-radius:.35rem}.project-loading__subtitle{width:14rem;height:.8rem;border-radius:.35rem}.project-loading__status{width:5rem;height:.8rem;border-radius:999px}.project-loading__edge{position:absolute;width:1px;height:8.5rem;border-left:2px dashed rgb(var(--c-blue-300) / .32);animation:project-edge-flow 1.1s linear infinite}.project-loading p{margin:0;color:var(--muted);font-size:.86rem;text-align:center}@keyframes project-skeleton-shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}@keyframes project-node-float{0%,to{opacity:.78;transform:translateY(0)}50%{opacity:1;transform:translateY(-3px)}}@keyframes project-edge-flow{0%{opacity:.32}50%{opacity:.68}to{opacity:.32}}@keyframes project-page-in{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}.user__link{display:block;width:100%;padding:.4rem .65rem;border-radius:999px;color:var(--muted);font-size:.75rem;font-weight:700;text-align:center;text-decoration:none}.user__link:hover{color:var(--text);background:var(--border-subtle)}.github-page{max-width:46rem}.github-connection{display:flex;flex-direction:column;gap:1rem;padding:1.25rem;border:1px solid var(--border);border-radius:1rem;background:var(--panel);box-shadow:var(--shadow);backdrop-filter:blur(18px)}.github-connection__head{display:flex;align-items:flex-start;gap:.75rem}.github-connection__logo{display:inline-flex;align-items:center;justify-content:center;width:2.25rem;height:2.25rem;flex:none;border-radius:.6rem;border:1px solid var(--border);background:var(--bg-soft);color:var(--text)}.github-connection__title{margin:0;font-size:1rem;font-weight:600;letter-spacing:-.01em;color:var(--text)}.github-connection__lead{margin:.15rem 0 0;font-size:.85rem;line-height:1.45;color:var(--text-secondary)}.github-connection__pill{margin-left:auto;align-self:center;flex:none;padding:.18rem .55rem;border-radius:999px;font-size:.72rem;font-weight:600;border:1px solid var(--border)}.github-connection__pill--on{color:var(--success-text);background:var(--success-soft);border-color:var(--success-soft)}.github-connection__pill--off{color:var(--text-muted);background:var(--bg-soft)}.github-connection__notice{padding:.85rem 1rem;border:1px solid var(--border);border-radius:.7rem;background:var(--bg-soft);font-size:.85rem;line-height:1.5;color:var(--text-secondary)}.github-connection__notice code{font-family:var(--font-mono);font-size:.8em;padding:.05rem .3rem;border-radius:.3rem;background:var(--panel-strong);color:var(--text)}.github-connection__list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.4rem}.github-connection__item{display:flex;align-items:center;justify-content:space-between;padding:.55rem .8rem;border:1px solid var(--border);border-radius:.6rem;background:var(--bg-soft)}.github-connection__account{font-weight:600;font-size:.88rem;color:var(--text)}.github-connection__item-meta{font-size:.72rem;color:var(--text-muted)}.github-connection__empty{margin:0;font-size:.85rem;color:var(--text-muted)}.github-connection__error{margin:0;font-size:.82rem;color:var(--danger-text)}.github-connection__actions{display:flex;flex-wrap:wrap;gap:.5rem}.github-connection__button{display:inline-flex;align-items:center;gap:.4rem;padding:.4rem .85rem;border-radius:.55rem;border:1px solid var(--border-strong);background:var(--bg-soft);color:var(--text);font:inherit;font-size:.85rem;font-weight:600;cursor:pointer;text-decoration:none;transition:transform .15s ease,box-shadow .15s ease,border-color .15s ease}.github-connection__button:hover{transform:translateY(-1px);border-color:var(--text-muted)}.github-connection__button:disabled{opacity:.6;cursor:default;transform:none}.github-connection__button--primary{border-color:transparent;background:var(--accent);color:var(--text-on-accent)}.github-connection__button--primary:hover{border-color:transparent;box-shadow:0 6px 18px var(--accent-soft)}.repo-picker{display:flex;flex-direction:column;gap:.5rem}.repo-picker__filter{width:100%}.repo-picker__list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.25rem;max-height:13rem;overflow-y:auto}.repo-picker__row{display:flex;align-items:center;justify-content:space-between;gap:.6rem;width:100%;padding:.45rem .65rem;border:1px solid var(--border);border-radius:.5rem;background:var(--bg-soft);color:var(--text);font:inherit;text-align:left;cursor:pointer;transition:border-color .15s ease,background .15s ease}.repo-picker__row:hover{border-color:var(--border-strong)}.repo-picker__row--selected{border-color:var(--accent);background:var(--accent-soft)}.repo-picker__name{font-size:.85rem;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.repo-picker__meta{display:inline-flex;align-items:center;gap:.4rem;flex:none}.repo-picker__badge{padding:.05rem .4rem;border-radius:999px;font-size:.68rem;font-weight:600;border:1px solid var(--border)}.repo-picker__badge--private{color:var(--warning-text);background:rgb(var(--c-amber-500) / .12)}.repo-picker__badge--public{color:var(--text-muted);background:var(--panel-strong)}.repo-picker__branch{font-family:var(--font-mono);font-size:.7rem;color:var(--text-muted)}.repo-picker__row--skeleton{min-height:2.0625rem;pointer-events:none;cursor:default}.repo-picker__skeleton{display:block;border-radius:.35rem;background:linear-gradient(90deg,transparent,rgb(var(--c-slate-200) / .16),transparent),rgb(var(--c-slate-400) / .1);background-size:220% 100%;animation:repo-picker-skeleton-shimmer 1.35s ease-in-out infinite}.repo-picker__skeleton--name{width:56%;height:.85rem}li:nth-child(2)>.repo-picker__row--skeleton .repo-picker__skeleton--name{width:38%}li:nth-child(3)>.repo-picker__row--skeleton .repo-picker__skeleton--name{width:64%}.repo-picker__skeleton--badge{width:3.4rem;height:.95rem;border-radius:999px}.repo-picker__skeleton--branch{width:2.4rem;height:.7rem}@keyframes repo-picker-skeleton-shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}@media(prefers-reduced-motion:reduce){.repo-picker__skeleton{animation:none}}.git-create-options{display:flex;flex-direction:column;gap:.6rem}.git-create-options__subdir{display:flex;flex-direction:column;gap:.3rem;font-size:.78rem;font-weight:600;color:var(--text-secondary)}.git-create-options__deploy-now{display:flex;align-items:flex-start;gap:.5rem;font-size:.82rem;color:var(--text);cursor:pointer}.git-create-options__deploy-now input{margin-top:.15rem;accent-color:var(--accent)}.git-create-options__deploy-now small{display:block;margin-top:.1rem;font-size:.72rem;font-weight:400;color:var(--text-muted)}.repo-picker__manual-toggle{align-self:flex-start;padding:0;border:0;background:none;color:var(--link);font:inherit;font-size:.78rem;font-weight:600;cursor:pointer}.repo-picker__manual-toggle:hover{text-decoration:underline}.repo-picker__manual-toggle:disabled{opacity:.6;cursor:default}.topology-layout{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:0;height:100%;min-height:0}.details-panel{width:clamp(520px,58vw,820px);min-width:min(480px,100vw)}.topology-stage{position:relative;display:flex;flex-direction:column;min-height:0;background:radial-gradient(circle at 30% 20%,rgb(var(--c-sky-400) / .05),transparent 50%)}.topology-canvas{position:relative;flex:1;min-height:0;border:0;border-radius:0;background:radial-gradient(circle,rgb(var(--c-slate-400) / .14) 1px,transparent 1px),linear-gradient(180deg,rgb(var(--c-ink-080d18) / .92),rgb(var(--c-ink-070b14) / .95));background-size:22px 22px,cover}.topology-flow{width:100%;height:100%}.topology-metrics{position:absolute;top:.75rem;left:.75rem;z-index:5;display:flex;gap:.4rem;flex-wrap:wrap;pointer-events:none}.topology-actions{position:absolute;top:.75rem;right:.75rem;z-index:6;display:flex;flex-direction:column;align-items:flex-end;gap:.5rem}.topology-flashes{position:absolute;top:3.25rem;left:50%;transform:translate(-50%);z-index:7;display:grid;gap:.45rem;max-width:min(34rem,calc(100% - 2rem));pointer-events:none}.topology-flashes .flash{pointer-events:auto;box-shadow:0 12px 28px rgb(var(--c-slate-950) / .45)}.topology-deploy-bar{position:absolute;top:.75rem;left:50%;z-index:8;display:flex;align-items:center;gap:.45rem;min-height:2.65rem;padding:.35rem;border:1px solid rgb(var(--c-purple-700) / .5);border-radius:.5rem;background:rgb(var(--c-ink-140a20) / .94);box-shadow:0 14px 38px rgb(var(--c-slate-950) / .45),0 0 0 1px rgb(var(--c-purple-400) / .08);transform:translate(-50%)}.topology-deploy-bar__summary{padding:0 .75rem;color:rgb(var(--c-purple-300));font-size:.83rem;font-weight:700;white-space:nowrap}.topology-deploy-bar button{min-height:2rem;border-radius:.4rem;font:inherit;font-size:.8rem;font-weight:700;cursor:pointer}.topology-deploy-bar__details,.topology-deploy-bar__more{border:1px solid rgb(var(--c-slate-400) / .24);background:rgb(var(--c-slate-900) / .72);color:var(--text)}.topology-deploy-bar__details{padding:0 .85rem}.topology-deploy-bar__deploy{display:inline-flex;align-items:center;gap:.45rem;padding:0 .95rem;border:0;background:linear-gradient(135deg,rgb(var(--c-violet-600)),rgb(var(--c-purple-400)));color:#fff}.topology-deploy-bar__deploy span{color:rgb(var(--c-white) / .72);font-size:.68rem;font-weight:600}.topology-deploy-bar__more{width:2rem;padding:0}.topology-deploy-bar button:disabled{cursor:wait;opacity:.65}.topology-deploy-bar__error{position:absolute;top:calc(100% + .45rem);left:0;margin:0;padding:.5rem .65rem;border:1px solid rgb(var(--c-red-400) / .35);border-radius:.55rem;background:rgb(var(--c-red-900) / .95);color:var(--danger-text);font-size:.78rem;white-space:nowrap}.topology-deploy-bar--applying{padding-inline:.75rem .35rem}.topology-deploy-bar__spinner{width:1rem;height:1rem;margin-left:.35rem;border:2px solid rgb(var(--c-purple-400) / .25);border-top-color:rgb(var(--c-purple-400));border-radius:999px;animation:topology-deploy-spin .8s linear infinite}.topology-deploy-bar__inspect{padding:0 .85rem;border:0;background:transparent;color:rgb(var(--c-purple-300))}.topology-deploy-bar__inspect:hover{color:rgb(var(--c-purple-50))}@keyframes topology-deploy-spin{to{transform:rotate(360deg)}}.pending-changes-modal__body{display:flex;flex-direction:column;gap:1rem}.pending-changes-modal__app{display:flex;align-items:center;gap:.65rem;margin:0}.pending-changes-modal__app span{color:var(--muted);font-size:.82rem}.pending-changes-table{display:flex;flex-direction:column;gap:.45rem}.pending-changes-table__header,.pending-changes-table__row{display:grid;grid-template-columns:1.4fr .8fr 1.2fr;gap:.75rem;align-items:start}.pending-changes-table__header{color:var(--muted);font-size:.72rem;font-weight:700;letter-spacing:.04em;text-transform:uppercase}.pending-changes-table__row{padding:.75rem;border:1px solid var(--border);border-radius:.55rem;background:rgb(var(--c-slate-900) / .55)}.pending-changes-table__change{display:flex;flex-direction:column;gap:.2rem}.pending-changes-table__kind{color:var(--muted);font-size:.72rem;font-weight:700;text-transform:uppercase}.pending-changes-table__old{color:var(--muted)}.pending-changes-table__new code{display:inline-block;padding:.15rem .4rem;border-radius:.35rem;background:rgb(var(--c-green-500) / .12);color:rgb(var(--c-green-300));font-size:.78rem;word-break:break-all}.pending-changes-modal__footer{display:flex;align-items:center;gap:.65rem;padding:.85rem 1rem;border-top:1px solid var(--border);color:rgb(var(--c-purple-300));font-size:.82rem;font-weight:600}.add-button{display:inline-flex;align-items:center;gap:.4rem;padding:.4rem .85rem;border-radius:.55rem;border:1px solid var(--border);background:rgb(var(--c-slate-900) / .85);color:var(--text);font:inherit;font-size:.82rem;font-weight:600;cursor:pointer;transition:background .15s ease,border-color .15s ease,transform .15s ease}.add-button:hover,.add-button[aria-expanded=true]{background:rgb(var(--c-slate-800) / .95);border-color:rgb(var(--c-slate-400) / .45)}.add-button__plus{color:var(--muted);font-size:.95rem;line-height:1}.add-menu{width:min(22rem,calc(100vw - 2rem));border-radius:.85rem;border:1px solid var(--border);background:rgb(var(--c-ink-0a0f1c) / .96);box-shadow:0 16px 40px var(--scrim),0 0 0 1px rgb(var(--c-slate-400) / .05);backdrop-filter:blur(8px);overflow:hidden;animation:add-menu-in .14s ease-out}.add-menu-overlay{background:rgb(var(--c-slate-950) / .6);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px)}.add-menu--dialog{width:min(34rem,calc(100vw - 2rem));max-height:min(38rem,calc(100vh - 3rem));display:grid;overflow:hidden;animation:modal-dialog-in .18s cubic-bezier(.16,1,.3,1)}.add-menu__modal-header{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:1rem 1rem .85rem;border-bottom:1px solid var(--border)}.add-menu__modal-header .page-eyebrow{margin:0 0 .25rem}.add-menu__modal-header h2{margin:0;font-size:1.05rem;font-weight:700}.add-menu--dialog .add-menu__picker,.add-menu--dialog .add-menu__form{min-height:0;overflow:auto}@keyframes add-menu-in{0%{opacity:0;transform:translateY(-4px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}.add-menu__picker{display:flex;flex-direction:column}.add-menu__category-header{display:flex;align-items:center;gap:.55rem;padding:.75rem;border-bottom:1px solid var(--border)}.add-menu__search{min-height:2.6rem;padding:0 .85rem;border:0;border-bottom:1px solid var(--border);background:transparent;color:var(--text);font:inherit;font-size:.9rem;outline:none}.add-menu__search::placeholder{color:var(--muted)}.add-menu__search:focus{background:rgb(var(--c-sky-400) / .06)}.add-menu__list{list-style:none;margin:0;padding:.25rem;max-height:18rem;overflow-y:auto}.add-menu__item{display:flex;align-items:center;gap:.75rem;width:100%;padding:.55rem .6rem;border:0;border-radius:.55rem;background:transparent;color:var(--text);font:inherit;text-align:left;cursor:pointer;transition:background .12s ease}.add-menu__item:hover:not(:disabled),.add-menu__item:focus-visible:not(:disabled){background:rgb(var(--c-sky-400) / .1);outline:none}.add-menu__item--disabled,.add-menu__item:disabled{cursor:not-allowed;opacity:.55}.add-menu__item-icon{display:grid;place-items:center;width:2rem;height:2rem;border-radius:.45rem;border:1px solid var(--border);background:rgb(var(--c-slate-900) / .85);color:rgb(var(--c-blue-300));flex:0 0 auto}.add-menu__item-text{display:grid;gap:.1rem;flex:1;min-width:0}.add-menu__item-text strong{font-size:.88rem;font-weight:600}.add-menu__item-text span{color:var(--muted);font-size:.78rem}.add-menu__item-chevron{color:var(--muted);flex:0 0 auto}.add-menu__empty{padding:.8rem;color:var(--muted);font-size:.85rem;text-align:center}.add-menu__form{display:grid;gap:.6rem;padding:.75rem}.add-menu__form-header{display:flex;align-items:center;gap:.55rem}.add-menu__form-title{display:flex;align-items:center;gap:.6rem;flex:1;min-width:0}.add-menu__form-title strong{display:block;font-size:.9rem;font-weight:600}.add-menu__form-title p{margin:0;color:var(--muted);font-size:.78rem}.add-menu__back{display:grid;place-items:center;width:1.8rem;height:1.8rem;border-radius:.45rem;border:1px solid var(--border);background:rgb(var(--c-slate-900) / .85);color:var(--muted);cursor:pointer;flex:0 0 auto}.add-menu__back:hover:enabled{color:var(--text);border-color:rgb(var(--c-slate-400) / .45)}.add-menu__back:disabled{opacity:.5;cursor:not-allowed}.add-menu__form input,.add-menu__field select{min-height:2.4rem;padding:0 .7rem;border-radius:.55rem;border:1px solid var(--border);background:rgb(var(--c-slate-950) / .85);color:var(--text);font:inherit;font-size:.88rem;outline:none}.add-menu__form input:focus,.add-menu__field select:focus{border-color:rgb(var(--c-sky-400) / .6);box-shadow:0 0 0 3px rgb(var(--c-sky-400) / .15)}.add-menu__field{display:grid;gap:.35rem}.add-menu__field label{color:var(--muted);font-size:.78rem;font-weight:600}.add-menu__field p{margin:0;color:var(--muted);font-size:.78rem}.add-menu__submit{min-height:2.4rem;padding:0 .85rem;border-radius:.55rem;border:0;background:linear-gradient(135deg,rgb(var(--c-cyan-600)),var(--accent));color:var(--text-on-accent);font:inherit;font-size:.85rem;font-weight:700;cursor:pointer;transition:transform .15s ease,box-shadow .15s ease}.add-menu__submit:hover:enabled{transform:translateY(-1px);box-shadow:0 10px 20px rgb(var(--c-sky-400) / .2)}.add-menu__submit:disabled{cursor:not-allowed;opacity:.6}.add-menu__error{margin:0;padding:.5rem .65rem;border-radius:.5rem;background:rgb(var(--c-red-900) / .22);border:1px solid var(--danger-soft);color:var(--danger-text);font-size:.82rem}.add-menu__hint{display:flex;align-items:center;gap:.4rem;margin:0;padding:.55rem .7rem;border-radius:.55rem;background:rgb(var(--c-blue-900) / .25);border:1px solid rgb(var(--c-blue-500) / .35);color:rgb(var(--c-blue-300));font-size:.82rem}.add-menu__examples{display:grid;gap:.35rem;padding:.65rem .75rem;border-radius:.55rem;background:rgb(var(--c-slate-900) / .6);border:1px solid var(--border);color:var(--muted);font-size:.8rem}.add-menu__examples strong{color:var(--text);font-size:.85rem;font-weight:600}.add-menu__examples ul{list-style:disc;margin:0;padding-left:1.1rem}.add-menu__examples li{font-family:JetBrains Mono,SFMono-Regular,ui-monospace,monospace;font-size:.78rem;color:var(--muted)}.add-menu__github-preview{display:grid;gap:.5rem;min-height:3.4rem}.add-menu__github-card{display:grid;justify-items:center;gap:.35rem;padding:1rem .9rem 1.1rem;border-radius:.7rem;background:rgb(var(--c-slate-900) / .75);border:1px solid var(--border);text-align:center}.add-menu__github-card-icon{display:grid;place-items:center;width:2.2rem;height:2.2rem;color:var(--text)}.add-menu__github-card strong{font-size:.9rem;font-weight:600;color:var(--text);font-family:JetBrains Mono,SFMono-Regular,ui-monospace,monospace}.add-menu__github-card p{margin:0;color:var(--muted);font-size:.8rem}.add-menu__submit--github{background:linear-gradient(135deg,rgb(var(--c-violet-600)),rgb(var(--c-purple-500)));color:rgb(var(--c-white))}.add-menu__submit--github:hover:enabled{box-shadow:0 10px 20px rgb(var(--c-purple-500) / .25)}.visually-hidden{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.resource-logs-panel,.resource-logs-section{display:grid;gap:.7rem}.resource-logs-section__header{display:grid;gap:.55rem}.resource-logs-button{padding:.5rem .85rem;border-radius:.55rem;border:1px solid var(--border);background:rgb(var(--c-slate-900) / .85);color:var(--text);font:inherit;font-size:.85rem;font-weight:600;cursor:pointer;transition:background .15s ease,border-color .15s ease}.resource-logs-button:hover:enabled{background:rgb(var(--c-slate-800) / .95);border-color:rgb(var(--c-slate-400) / .45)}.resource-logs-button:disabled{cursor:not-allowed;opacity:.6}.resource-logs{margin:0;max-height:32rem;overflow:auto;padding:.7rem .85rem;border-radius:.6rem;border:1px solid var(--border);background:rgb(var(--c-slate-950) / .92);color:var(--text-strong);font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-size:.78rem;line-height:1.5;white-space:pre-wrap;word-break:break-word}.logs-page{display:grid;grid-template-rows:auto auto 1fr;gap:.75rem;min-height:100%;padding:1rem;background:linear-gradient(rgb(var(--c-slate-900) / .7) 1px,transparent 1px),linear-gradient(90deg,rgb(var(--c-slate-900) / .7) 1px,transparent 1px),var(--bg);background-size:4rem 4rem}.logs-toolbar{display:grid;grid-template-columns:minmax(18rem,1fr) auto auto;gap:.55rem;align-items:center;padding:.7rem;border:1px solid var(--border);border-radius:.9rem;background:rgb(var(--c-slate-950) / .76);box-shadow:var(--shadow)}.logs-search input,.logs-select,.logs-toolbar__button{width:100%;min-height:2.25rem;border:1px solid var(--border);border-radius:.65rem;background:rgb(var(--c-slate-900) / .92);color:var(--text);font:inherit;font-size:.85rem}.logs-search{position:relative;display:block}.logs-search input{padding:0 .85rem 0 2.3rem}.logs-search input:focus{outline:none;border-color:var(--border-strong);box-shadow:0 0 0 3px var(--accent-soft)}.logs-search input::placeholder{color:var(--muted)}.logs-search__icon{position:absolute;top:50%;left:.8rem;width:1rem;height:1rem;transform:translateY(-50%);fill:none;stroke:var(--muted);stroke-width:2;stroke-linecap:round;pointer-events:none}.logs-suggest{position:absolute;z-index:30;top:calc(100% + .35rem);left:0;right:0;margin:0;padding:.3rem;list-style:none;border:1px solid var(--border-strong);border-radius:.7rem;background:var(--panel-strong);box-shadow:var(--shadow);max-height:18rem;overflow:auto}.logs-suggest__label{padding:.35rem .6rem .25rem;color:var(--muted);font-size:.68rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase}.logs-suggest__item{display:flex;align-items:baseline;justify-content:space-between;gap:.75rem;padding:.42rem .6rem;border-radius:.5rem;cursor:pointer}.logs-suggest__item.is-active{background:var(--accent-soft)}.logs-suggest__name{color:var(--text);font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-size:.82rem}.logs-suggest__hint{color:var(--muted);font-size:.72rem;text-align:right;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.logs-live{display:inline-flex;align-items:center;gap:.45rem;min-height:2.25rem;min-width:5.6rem;justify-content:center;padding:0 .9rem;border:1px solid var(--border);border-radius:.65rem;background:rgb(var(--c-slate-900) / .92);color:var(--muted);font:inherit;font-size:.82rem;font-weight:700;cursor:pointer;transition:border-color .15s ease,background .15s ease,color .15s ease}.logs-live__dot{width:.5rem;height:.5rem;border-radius:999px;background:var(--muted)}.logs-live.is-live{border-color:rgb(var(--c-emerald-400) / .45);color:var(--success)}.logs-live.is-live .logs-live__dot{background:var(--success);box-shadow:0 0 rgb(var(--c-emerald-400) / .55);animation:logs-live-pulse 1.8s ease-out infinite}@keyframes logs-live-pulse{0%{box-shadow:0 0 rgb(var(--c-emerald-400) / .55)}70%{box-shadow:0 0 0 .4rem rgb(var(--c-emerald-400) / 0)}to{box-shadow:0 0 rgb(var(--c-emerald-400) / 0)}}@media(prefers-reduced-motion:reduce){.logs-live.is-live .logs-live__dot{animation:none}}.logs-select{padding:0 2rem 0 .75rem;appearance:none;-webkit-appearance:none;cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%2394a3b8' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .75rem center;background-size:1rem}.logs-range{position:relative}.logs-select--range{min-width:9.5rem}.logs-range__panel{position:absolute;z-index:40;top:calc(100% + .35rem);right:0;left:auto;width:18rem;max-width:min(18rem,calc(100vw - 2rem));display:grid;gap:.55rem;padding:.75rem;border:1px solid var(--border-strong);border-radius:.7rem;background:var(--panel-strong);box-shadow:var(--shadow)}.logs-range__field{display:grid;gap:.25rem}.logs-range__field label{color:var(--muted);font-size:.72rem;font-weight:600}.logs-range__input-wrap{position:relative;display:block}.logs-range__input-wrap svg{position:absolute;top:50%;right:.65rem;color:var(--text);pointer-events:none;transform:translateY(-50%)}.logs-range__input{position:relative;width:100%;min-height:2.25rem;padding:0 2.1rem 0 .65rem;border:1px solid var(--border);border-radius:.65rem;background:rgb(var(--c-slate-900) / .92);color:var(--text);color-scheme:dark;font:inherit;font-size:.85rem}.logs-range__input::-webkit-calendar-picker-indicator{position:absolute;top:0;right:.45rem;width:1.5rem;height:100%;margin:0;cursor:pointer;opacity:0}.logs-range__input:focus{outline:none;border-color:var(--border-strong);box-shadow:0 0 0 3px var(--accent-soft)}.logs-range__hint{margin:0;color:var(--muted);font-size:.72rem}.logs-range__error{margin:0;padding:.45rem .55rem;font-size:.78rem}.logs-range__apply{min-height:2.1rem;padding:0 .75rem;border:1px solid var(--border);border-radius:.65rem;background:rgb(var(--c-sky-500) / .16);color:var(--text);font:inherit;font-size:.82rem;font-weight:700;cursor:pointer;transition:border-color .15s ease,background .15s ease}.logs-range__apply:hover{border-color:rgb(var(--c-sky-300) / .55);background:rgb(var(--c-sky-500) / .24)}.logs-live:disabled{cursor:not-allowed;opacity:.55}.logs-toolbar__button{min-width:5.6rem;padding:0 .9rem;font-weight:700;cursor:pointer;transition:border-color .15s ease,background .15s ease}.logs-toolbar__button:hover:enabled{border-color:rgb(var(--c-sky-300) / .55);background:rgb(var(--c-sky-500) / .16)}.logs-toolbar__button:disabled{cursor:not-allowed;opacity:.6}.resource-console-panel{display:grid;grid-template-rows:auto 1fr;gap:.6rem;min-height:0}.resource-console__bar{display:flex;align-items:center;justify-content:space-between;gap:.6rem}.resource-console__status{display:inline-flex;align-items:center;gap:.45rem;color:var(--muted);font-size:.78rem;font-weight:600}.resource-console__dot{width:.5rem;height:.5rem;border-radius:999px;background:var(--muted)}.resource-console__status--connected{color:var(--success)}.resource-console__status--connected .resource-console__dot{background:var(--success)}.resource-console__status--error,.resource-console__status--closed{color:var(--danger-text)}.resource-console__status--error .resource-console__dot,.resource-console__status--closed .resource-console__dot{background:rgb(var(--c-red-400) / .9)}.resource-console__reconnect{padding:.4rem .75rem;border-radius:.55rem;border:1px solid var(--border);background:rgb(var(--c-slate-900) / .85);color:var(--text);font:inherit;font-size:.8rem;font-weight:600;cursor:pointer;transition:background .15s ease,border-color .15s ease}.resource-console__reconnect:hover{background:rgb(var(--c-slate-800) / .95);border-color:rgb(var(--c-slate-400) / .45)}.resource-console__terminal{min-height:22rem;height:60vh;max-height:38rem;padding:.5rem;border-radius:.6rem;border:1px solid var(--border);background:rgb(var(--c-slate-950) / .92);overflow:hidden}.resource-console__terminal .xterm,.resource-console__terminal .xterm-viewport{height:100%}.logs-results{min-height:0;border:1px solid var(--border);border-radius:1rem;background:rgb(var(--c-slate-950) / .7);overflow:hidden}.logs-list{display:grid;align-content:start;max-height:calc(100vh - 12rem);overflow:auto}.logs-row{display:grid;grid-template-columns:5.4rem minmax(8rem,12rem) 4.5rem minmax(0,1fr);gap:.75rem;align-items:baseline;padding:.42rem .75rem;border-bottom:1px solid rgb(var(--c-slate-800) / .72);color:var(--text-secondary);font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-size:.78rem}.logs-row time,.logs-row__resource,.logs-row__stream{color:var(--muted)}.logs-row__resource,.logs-row__stream{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.logs-row code{color:var(--text-strong);white-space:pre-wrap;word-break:break-word}.logs-empty{display:grid;place-items:center;align-content:center;gap:.45rem;min-height:calc(100vh - 12rem);padding:2rem;text-align:center;color:var(--muted)}.logs-empty h2{margin:0;color:var(--text);font-size:.95rem}.logs-empty p{margin:0;font-size:.8rem}.logs-empty__icon{display:grid;place-items:center;width:3.4rem;height:3.4rem;border:1px solid var(--border);border-radius:.8rem;background:rgb(var(--c-slate-900) / .7)}.logs-empty__icon span{width:1.7rem;height:1.2rem;border:1px solid rgb(var(--c-slate-400) / .45);border-radius:.2rem;box-shadow:0 -.45rem 0 -.2rem rgb(var(--c-slate-400) / .25),0 .45rem 0 -.2rem rgb(var(--c-slate-400) / .25)}@media(max-width:820px){.logs-toolbar{grid-template-columns:1fr}.logs-range__panel{right:0;left:0;width:auto;max-width:none}.logs-row{grid-template-columns:4.6rem 1fr}.logs-row__stream{display:none}.logs-row code{grid-column:1 / -1}}.app-metrics-panel,.app-metrics-section,.app-metrics-grid{display:grid;gap:.65rem}.app-metrics-section__header{display:flex;align-items:flex-start;justify-content:space-between;gap:.75rem}.metrics-section-title{margin:0 0 .15rem;color:var(--text);font-size:.9rem;font-weight:800}.app-metrics-section__header .detail-note{margin:0}.app-metrics-section>.detail-note,.database-metrics-section>.detail-note{margin:0}.app-scale-form{display:grid;gap:.75rem;margin-top:.35rem}.app-scale-grid{display:grid;gap:.5rem}.app-scale-row{display:flex;align-items:center;justify-content:space-between;gap:.75rem;padding:.5rem .7rem;border:1px solid var(--border);border-radius:.7rem;background:rgb(var(--c-slate-900) / .55)}.app-scale-row__label{display:grid;gap:.1rem;min-width:0}.app-scale-row__label strong{color:var(--text);font-size:.85rem;font-weight:700}.app-scale-row__label .detail-note{margin:0;font-size:.72rem}.app-scale-stepper{display:flex;align-items:center;gap:.35rem}.app-scale-stepper__button{width:1.85rem;height:1.85rem;display:inline-flex;align-items:center;justify-content:center;border:1px solid var(--border);border-radius:.55rem;background:rgb(var(--c-slate-400) / .08);color:var(--text);font-size:1rem;line-height:1;cursor:pointer}.app-scale-stepper__button:hover:not(:disabled){background:rgb(var(--c-slate-400) / .18)}.app-scale-stepper__button:disabled{opacity:.4;cursor:not-allowed}.app-scale-stepper__input{width:3.2rem;padding:.35rem .4rem;text-align:center;border:1px solid var(--border);border-radius:.55rem;background:rgb(var(--c-slate-900) / .65);color:var(--text);font-size:.85rem;-moz-appearance:textfield}.app-scale-stepper__input::-webkit-outer-spin-button,.app-scale-stepper__input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.app-scale-actions{display:flex;justify-content:flex-end}.app-metrics-grid{grid-template-columns:repeat(auto-fit,minmax(14rem,1fr))}.app-metrics-card{display:grid;gap:.75rem;padding:.75rem;border:1px solid var(--border);border-radius:.8rem;background:rgb(var(--c-slate-900) / .55)}.app-metrics-card__header{display:flex;align-items:flex-start;justify-content:space-between;gap:.75rem}.app-metrics-card__header div{display:grid;gap:.15rem;min-width:0}.app-metrics-card__header span,.app-metrics-card__header code,.app-metrics-list dt,.app-metrics-list dd span{color:var(--muted);font-size:.78rem}.app-metrics-card__header span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.app-metrics-card__header code{flex:0 0 auto}.app-metrics-list{display:grid;gap:.55rem;margin:0}.app-metrics-list div{display:grid;gap:.15rem}.app-metrics-list dt,.app-metrics-list dd{margin:0}.app-metrics-list dd{display:grid;gap:.1rem;color:var(--text);font-weight:700}.database-metrics-section{display:grid;gap:.6rem;padding-top:.6rem;border-top:1px solid var(--border)}.database-metrics-status{padding:.2rem .55rem;border:1px solid var(--border);border-radius:999px;color:var(--muted);font-size:.72rem;font-weight:700;text-transform:uppercase}.database-metrics-status--fresh{border-color:rgb(var(--c-green-500) / .45);color:var(--success-text)}.database-metrics-status--stale{border-color:rgb(var(--c-amber-500) / .45);color:var(--warning-text)}.database-metrics-status--unavailable{border-color:rgb(var(--c-red-400) / .45);color:var(--danger-text)}.deployments-section,.deployments-layout,.deployments-history,.deployments-list,.deployment-log-card{display:grid;gap:.75rem}.deployments-section__header,.deployment-log-card__header,.release-phase__header{display:flex;align-items:flex-start;justify-content:space-between;gap:.75rem}.release-phase{display:grid;gap:.5rem;margin-top:.75rem;padding-top:.75rem;border-top:1px solid var(--border-subtle, var(--border-subtle))}.release-phase__header code{display:block;margin-top:.25rem;font-size:.8rem;word-break:break-all}.deployments-list{gap:.5rem}.deployment-subtabs{display:flex;align-items:center;gap:.35rem;margin:-.1rem -.25rem 0;padding-bottom:.2rem;overflow-x:auto}.deployment-subtabs__detail{display:inline-flex;align-items:stretch;min-width:0}.deployment-subtabs__item,.deployment-subtabs__close{border:1px solid var(--border);background:rgb(var(--c-slate-900) / .62);color:var(--muted);font:inherit;font-size:.78rem;font-weight:700;cursor:pointer;transition:color .16s ease,border-color .16s ease,background .16s ease}.deployment-subtabs__item{max-width:14rem;padding:.4rem .7rem;border-radius:999px;overflow:hidden;text-overflow:ellipsis;text-transform:capitalize;white-space:nowrap}.deployment-subtabs__detail .deployment-subtabs__item{border-top-right-radius:0;border-bottom-right-radius:0}.deployment-subtabs__close{display:grid;place-items:center;width:2rem;border-left:0;border-radius:0 999px 999px 0}.deployment-subtabs__item:hover,.deployment-subtabs__close:hover,.deployment-subtabs__item--active{border-color:rgb(var(--c-sky-400) / .45);background:rgb(var(--c-sky-500) / .12);color:var(--text)}.deployments-history__header{display:flex;align-items:center;justify-content:space-between;gap:.75rem;color:var(--text);font-size:.82rem}.deployments-history__header span{color:var(--muted);font-size:.75rem}.deployment-row{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:.45rem .65rem;width:100%;padding:.7rem;border:1px solid var(--border);border-radius:.75rem;background:rgb(var(--c-slate-900) / .65);color:var(--text);font:inherit;text-align:left;cursor:pointer;transition:border-color .16s ease,background .16s ease,transform .16s ease}.deployment-row .status-pill{grid-column:2;grid-row:1;align-self:start;padding:.18rem .48rem;border-radius:999px;font-size:.68rem;font-weight:700;letter-spacing:.04em;text-transform:uppercase}.deployment-row:hover,.deployment-row--selected{border-color:rgb(var(--c-sky-400) / .45);background:rgb(var(--c-sky-500) / .1)}.deployment-row:hover{transform:translateY(-1px)}.deployment-row--current{padding:.9rem;border-color:rgb(var(--c-emerald-400) / .28);background:linear-gradient(135deg,rgb(var(--c-green-500) / .13),rgb(var(--c-slate-900) / .72)),rgb(var(--c-slate-900) / .7)}.deployment-row__main{display:grid;gap:.18rem;min-width:0}.deployment-row__main strong{text-transform:capitalize}.deployment-row__eyebrow{color:rgb(var(--c-green-300));font-size:.7rem;font-weight:800;letter-spacing:.08em;text-transform:uppercase}.deployment-row__main span,.deployment-row__meta,.deployment-log-card p,.deployment-log-card__meta{color:var(--muted);font-size:.78rem}.deployment-row__meta{grid-column:1 / -1}.deployment-log-card{padding:.75rem;border:1px solid var(--border);border-radius:.8rem;background:rgb(var(--c-slate-900) / .55)}.deployment-log-card .status-pill{align-self:flex-start;text-transform:uppercase}.deployment-log-card__header p{margin:.2rem 0 0;word-break:break-word}.deployment-log-card__meta{display:grid;gap:.2rem;text-align:right;white-space:nowrap}.deployment-detail-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.55rem;margin:0}.deployment-detail-grid div{padding:.65rem;border:1px solid var(--border);border-radius:.7rem;background:rgb(var(--c-slate-900) / .5)}.deployment-detail-grid dt{margin:0 0 .2rem;color:var(--muted);font-size:.68rem;font-weight:800;letter-spacing:.08em;text-transform:uppercase}.deployment-detail-grid dd{margin:0;color:var(--text);font-size:.82rem;font-weight:700;overflow-wrap:anywhere}.topology-metrics span,.status-pill,.detail-card,.attached-list__item{padding:.35rem .7rem;border-radius:999px;border:1px solid var(--border);background:rgb(var(--c-slate-900) / .85);font-size:.78rem;color:var(--muted)}.topology-controls{background:rgb(var(--c-slate-900) / .82)!important;border:1px solid var(--border)!important;border-radius:.55rem!important;box-shadow:none!important;overflow:hidden}.topology-controls .react-flow__controls-button{background:transparent;border:0;border-bottom:1px solid var(--border);color:rgb(var(--c-blue-100));fill:currentColor;width:28px;height:28px;transition:background .16s ease,color .16s ease}.topology-controls .react-flow__controls-button:last-child{border-bottom:0}.topology-controls .react-flow__controls-button:hover{background:rgb(var(--c-sky-500) / .12);color:var(--text)}.topology-controls .react-flow__controls-button:disabled{opacity:.5}.topology-controls .react-flow__controls-button svg{fill:currentColor;max-width:12px;max-height:12px}.details-panel{display:grid;align-content:start;gap:1rem;padding:1rem;border-radius:0;border-right:0;border-top:0;border-bottom:0;border-left:1px solid var(--border);background:rgb(var(--c-ink-090e19) / .72);box-shadow:none;overflow:auto;animation:panel-in .28s cubic-bezier(.22,1,.36,1) both}.page-eyebrow,.detail-note{color:var(--muted);font-size:.8rem;letter-spacing:.1em;text-transform:uppercase}.detail-note{letter-spacing:0;text-transform:none;font-size:.9rem;line-height:1.55}.status-pill{padding:.3rem .65rem;font-size:.78rem}.status-pill--ready{border-color:rgb(var(--c-emerald-400) / .32);color:var(--success-text)}.status-pill--creating,.status-pill--pending,.status-pill--running{border-color:rgb(var(--c-amber-500) / .32);color:var(--warning-text)}.status-pill--succeeded{border-color:rgb(var(--c-emerald-400) / .32);color:var(--success-text)}.status-pill--failed,.status-pill--unhealthy{border-color:rgb(var(--c-red-400) / .45);background:rgb(var(--c-red-900) / .28);color:rgb(var(--c-red-300))}.status-pill--deleting{border-color:rgb(var(--c-red-400) / .32);color:var(--danger-text)}.details-stack,.attached-list{display:grid;gap:.6rem}.settings-sections{display:grid;gap:1.1rem}.settings-section{display:grid;gap:.75rem;padding:.85rem .9rem .95rem;border:1px solid var(--border);border-radius:.9rem;background:rgb(var(--c-ink-0c1220) / .5)}.settings-section__header{display:flex;align-items:flex-start;gap:.65rem}.settings-section__icon{display:inline-flex;align-items:center;justify-content:center;flex-shrink:0;width:1.95rem;height:1.95rem;border:1px solid var(--border);border-radius:.6rem;background:rgb(var(--c-slate-900) / .85);color:rgb(var(--c-sky-200))}.settings-section__icon svg{width:16px;height:16px}.settings-section__heading{display:grid;gap:.15rem;padding-top:.1rem}.settings-section__title{margin:0;font-size:.92rem;font-weight:700;letter-spacing:-.01em;color:var(--text)}.settings-section__subtitle{margin:0;font-size:.82rem;line-height:1.5;color:var(--muted)}.settings-section__body{display:grid;gap:.6rem}.settings-section--danger{border-color:var(--danger-soft);background:rgb(var(--c-ink-280e12) / .4)}.settings-section--danger .settings-section__icon{border-color:rgb(var(--c-red-400) / .4);background:rgb(var(--c-red-900) / .2);color:rgb(var(--c-red-300))}.settings-section--danger .danger-zone{margin-top:0;padding-top:0;border-top:0}.detail-card{display:grid;gap:.25rem;padding:.6rem .8rem;border-radius:.65rem;background:rgb(var(--c-slate-900) / .74)}.detail-card span,.detail-card label{color:var(--muted);font-size:.78rem}.detail-card strong{font-size:.95rem}.domain-status-row{display:flex;align-items:center;gap:.4rem;flex-wrap:wrap}.detail-card .domain-status-badge{display:inline-flex;align-items:center;width:fit-content;padding:.12rem .48rem;border:1px solid rgb(var(--c-slate-400) / .24);border-radius:999px;background:rgb(var(--c-slate-900) / .72);color:var(--text-secondary);font-size:.72rem;font-weight:700}.detail-card .domain-status-badge--ready,.detail-card .domain-status-badge--active{border-color:rgb(var(--c-emerald-400) / .42);background:rgb(var(--c-green-900) / .28);color:var(--success-text)}.detail-card .domain-status-badge--pending{border-color:rgb(var(--c-amber-500) / .44);background:rgb(var(--c-amber-900) / .26);color:var(--warning-text)}.detail-card .domain-status-badge--failed{border-color:rgb(var(--c-red-400) / .5);background:rgb(var(--c-red-900) / .28);color:var(--danger-text)}.detail-card .domain-status-badge--inactive,.detail-card .domain-status-badge--unknown{border-color:rgb(var(--c-slate-400) / .26);background:rgb(var(--c-slate-700) / .28);color:var(--text-secondary)}.detail-card input,.detail-card select{width:100%;min-height:2.4rem;padding:0 .7rem;border:1px solid var(--border);border-radius:.6rem;background:rgb(var(--c-slate-900) / .88);color:var(--text);font:inherit}.healthcheck-card{gap:.45rem}.healthcheck-form{display:grid;gap:.55rem}.docker-image-card{gap:.45rem}.docker-image-form{display:grid;gap:.55rem}.detail-card__button{min-height:2.35rem;border:1px solid var(--border);border-radius:.6rem;background:rgb(var(--c-slate-900) / .9);color:var(--text);font:inherit;font-size:.82rem;font-weight:600;cursor:pointer}.detail-card__button:disabled{cursor:wait;opacity:.65}.resource-group-actions{display:flex;align-items:center;gap:.45rem;flex-wrap:wrap}.domain-action-button{min-height:2rem;padding:0 .7rem;border-color:rgb(var(--c-slate-400) / .24);background:rgb(var(--c-slate-900) / .72);color:var(--text-secondary);font-size:.78rem;transition:background .15s ease,border-color .15s ease,color .15s ease,transform .15s ease}.domain-action-button:hover:enabled{transform:translateY(-1px);border-color:rgb(var(--c-sky-400) / .45);background:rgb(var(--c-sky-500) / .14);color:rgb(var(--c-sky-100))}.domain-action-button--primary{border-color:rgb(var(--c-sky-400) / .38);background:rgb(var(--c-sky-500) / .16);color:rgb(var(--c-sky-200))}.domain-action-button--danger{border-color:rgb(var(--c-red-400) / .35);background:rgb(var(--c-red-900) / .14);color:rgb(var(--c-red-300))}.domain-action-button--danger:hover:enabled{border-color:rgb(var(--c-red-400) / .55);background:rgb(var(--c-red-900) / .3);color:var(--danger-text)}.detail-note--error{color:var(--danger-text)}.attach-form{display:grid;gap:.55rem}.attach-form label{color:var(--muted);font-size:.85rem}.attach-form input,.attach-form select,.attach-form button{width:100%;min-height:2.6rem;border-radius:.65rem;font:inherit}.attach-form input,.attach-form select{padding:0 .75rem;border:1px solid var(--border);background:rgb(var(--c-slate-900) / .88);color:var(--text)}.attach-form button{border:0;background:linear-gradient(135deg,rgb(var(--c-cyan-600)),var(--accent));color:var(--text-on-accent);font-weight:700;cursor:pointer;transition:transform .18s ease,box-shadow .18s ease}.attach-form button:hover:enabled{transform:translateY(-1px);box-shadow:0 12px 24px rgb(var(--c-sky-400) / .22)}.attach-form button:disabled{cursor:not-allowed;opacity:.6}.flash{margin:0;padding:.7rem .85rem;border-radius:.75rem;font-size:.88rem;animation:flash-enter .18s ease-out}@keyframes flash-enter{0%{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}@media(prefers-reduced-motion:reduce){.flash,.details-panel{animation:none}}.flash--success{background:rgb(var(--c-green-800) / .22);border:1px solid rgb(var(--c-emerald-400) / .26);color:var(--success-text)}.flash--error{background:rgb(var(--c-red-900) / .2);border:1px solid var(--danger-soft);color:var(--danger-text)}.resource-group-node{width:100%;height:100%;border-radius:12px;border:1px solid rgb(var(--c-placeholder) / .28);background:rgb(var(--c-placeholder) / .05);box-shadow:0 14px 36px rgb(var(--c-slate-950) / .12);cursor:default;transition:background .16s ease,border-color .16s ease,box-shadow .16s ease}.react-flow__node-group{background:transparent!important;border:0!important;box-shadow:none!important}.resource-group-node.is-selected{border-color:rgb(var(--c-slate-200) / .42);background:rgb(var(--c-slate-200) / .16);box-shadow:inset 0 0 0 1px rgb(var(--c-slate-900) / .54),0 18px 50px rgb(var(--c-slate-950) / .22)}.resource-group-node__header{display:flex;align-items:center;gap:.7rem;min-height:3.5rem;padding:.85rem 1rem .65rem;border-bottom:0;cursor:grab}.react-flow__node.dragging .resource-group-node__header{cursor:grabbing}.react-flow__edge-path{stroke-linecap:round;stroke-linejoin:round}.resource-group-node__header>div{min-width:0}.resource-group-node[data-collapsed=true] .resource-group-node__header{border-bottom:0}.resource-group-node__icon{display:flex;align-items:center;justify-content:center;width:1.9rem;height:1.9rem;line-height:1;border-radius:.65rem;background:rgb(var(--c-slate-400) / .15);color:var(--text-strong);font-size:.78rem;font-weight:700}.resource-group-node__header strong,.resource-group-node__header span:not(.resource-group-node__icon){display:block}.resource-group-node__header strong{color:var(--text);font-size:.92rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.resource-group-node__header span{color:var(--muted);font-size:.72rem}.resource-group-node--blue{--group-accent: rgb(var(--c-blue-500) / .34)}.resource-group-node--emerald{--group-accent: rgb(var(--c-emerald-400) / .34)}.resource-group-node--violet{--group-accent: rgb(var(--c-violet-400) / .34)}.resource-group-node--amber{--group-accent: rgb(var(--c-amber-500) / .34)}.resource-group-node--rose{--group-accent: rgb(var(--c-rose-400) / .34)}.resource-group-node--slate{--group-accent: rgb(var(--c-slate-400) / .34)}.resource-group-node--blue .resource-group-node__icon,.resource-group-node--emerald .resource-group-node__icon,.resource-group-node--violet .resource-group-node__icon,.resource-group-node--amber .resource-group-node__icon,.resource-group-node--rose .resource-group-node__icon,.resource-group-node--slate .resource-group-node__icon{border:1px solid var(--group-accent)}.resource-group-node__menu{display:inline-flex;flex-direction:column;align-items:center;justify-content:center;gap:.18rem;width:1.8rem;height:1.8rem;margin-left:auto;border:0;border-radius:.55rem;background:transparent;color:var(--muted);cursor:pointer}.resource-group-node__menu:hover{background:rgb(var(--c-slate-400) / .12);color:var(--text)}.resource-group-node__menu span{width:.22rem;height:.22rem;border-radius:999px;background:currentColor}.canvas-context-menu{position:fixed;z-index:120;display:grid;gap:.15rem;min-width:14rem;padding:.45rem;border:1px solid rgb(var(--c-slate-400) / .18);border-radius:.8rem;background:rgb(var(--c-ink-0c121f) / .98);box-shadow:0 18px 50px rgb(var(--c-slate-950) / .48)}.canvas-context-menu button,.canvas-context-menu summary{display:flex;align-items:center;justify-content:space-between;gap:.75rem;min-height:2.2rem;padding:0 .75rem;border:0;border-radius:.55rem;background:transparent;color:var(--text);font:inherit;font-size:.82rem;font-weight:600;text-align:left;cursor:pointer;list-style:none}.canvas-context-menu summary::-webkit-details-marker{display:none}.canvas-context-menu button:hover:not(:disabled),.canvas-context-menu summary:hover{background:rgb(var(--c-slate-400) / .12)}.canvas-context-menu button:disabled{cursor:not-allowed;opacity:.45}.canvas-context-menu__label{display:inline-flex;align-items:center;gap:.7rem;min-width:0}.canvas-context-menu__group-icon,.canvas-context-menu__plus{display:inline-grid;place-items:center;color:rgb(var(--c-purple-400))}.canvas-context-menu__flyout{position:relative;display:grid}.canvas-context-menu__flyout-trigger{width:100%}.canvas-context-menu__flyout:hover>.canvas-context-menu__flyout-trigger,.canvas-context-menu__flyout:focus-within>.canvas-context-menu__flyout-trigger{background:rgb(var(--c-purple-500) / .14);color:rgb(var(--c-purple-300))}.canvas-context-menu__flyout-panel{position:absolute;top:-.45rem;left:calc(100% + .45rem);display:grid;gap:.15rem;min-width:13.5rem;padding:.45rem;border:1px solid rgb(var(--c-slate-400) / .18);border-radius:.8rem;background:rgb(var(--c-ink-0d0c16) / .98);box-shadow:0 18px 50px rgb(var(--c-slate-950) / .48);opacity:0;pointer-events:none;visibility:hidden}.canvas-context-menu__flyout:hover>.canvas-context-menu__flyout-panel,.canvas-context-menu__flyout:focus-within>.canvas-context-menu__flyout-panel{opacity:1;pointer-events:auto;visibility:visible}.canvas-context-menu__submenu{display:grid}.canvas-context-menu__submenu-panel{display:grid;gap:.1rem;padding:.15rem 0 .2rem 1rem}.canvas-context-menu__submenu-panel button{min-height:1.9rem;color:var(--muted);text-transform:capitalize}.canvas-context-menu__danger{color:var(--danger-text)!important}.resource-node{display:grid;gap:.5rem;width:13.5rem;padding:.9rem 1rem;border-radius:.85rem;border:1px solid var(--border);background:rgb(var(--c-ink-0b111d) / .96);box-shadow:0 14px 36px rgb(var(--c-slate-950) / .38);cursor:grab;transition:border-color .16s ease,box-shadow .16s ease,background .16s ease}.react-flow__node.dragging .resource-node,.react-flow__node.dragging .resource-group-node{cursor:grabbing}.resource-node:hover{border-color:rgb(var(--c-slate-400) / .3);background:rgb(var(--c-ink-0d1524) / .98);box-shadow:0 20px 46px rgb(var(--c-slate-950) / .46)}.resource-node>strong{margin-top:.1rem}.resource-node>small{margin-top:.15rem}.resource-node__volume{display:flex;align-items:center;gap:.4rem;width:100%;min-width:0;margin-top:.5rem;padding:.5rem 0 0;border:none;border-top:1px solid var(--border, rgb(var(--c-slate-400) / .18));background:transparent;color:var(--text-muted, var(--text-muted));font-family:inherit;font-size:.72rem;text-align:left;cursor:pointer;transition:color .12s ease}.resource-node__volume:hover{color:var(--text, rgb(var(--c-slate-200) / .95))}.resource-node__volume.is-selected{color:rgb(var(--c-sky-300) / .95)}.resource-node__volume svg{flex:none;opacity:.8}.resource-node__volume span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.resource-node.is-selected{border-color:rgb(var(--c-sky-400) / .55);box-shadow:0 18px 56px rgb(var(--c-sky-500) / .2)}.resource-node strong{font-size:.9rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.resource-node p,.resource-node small{margin:0;color:var(--muted);font-size:.72rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.resource-node__heading{display:inline-flex;align-items:center;gap:.4rem;width:fit-content}.resource-node__badge{padding:.2rem .45rem;border-radius:999px;background:rgb(var(--c-sky-400) / .14);color:rgb(var(--c-sky-200));font-size:.6rem;letter-spacing:.1em;text-transform:uppercase}.resource-node__status{display:inline-flex;align-items:center;gap:.45rem;color:rgb(var(--c-mint-50));font-size:.75rem}.status-dot{width:.45rem;height:.45rem;border-radius:999px;background:var(--muted);box-shadow:0 0 0 4px rgb(var(--c-slate-400) / .08)}.status-dot--ready{background:var(--success);box-shadow:0 0 0 4px var(--success-soft)}.status-dot--creating{background:var(--warning);box-shadow:0 0 0 4px rgb(var(--c-amber-500) / .12)}.status-dot--unhealthy{background:var(--danger);box-shadow:0 0 0 4px rgb(var(--c-red-400) / .18)}.status-dot--deleting{background:var(--danger);box-shadow:0 0 0 4px rgb(var(--c-red-400) / .12)}.resource-node__handle{opacity:0;pointer-events:none}@keyframes rise-in{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@keyframes panel-in{0%{opacity:0;transform:translate(12px)}to{opacity:1;transform:translate(0)}}@media(max-width:960px){.topology-layout{grid-template-columns:minmax(0,1fr);grid-template-rows:minmax(0,1fr) auto}.details-panel{width:auto;min-width:0;border-left:0;border-top:1px solid var(--border);max-height:40vh}}@media(max-width:720px){:root{--rail-width: 48px;--topbar-height: 48px}.app-content{padding:1rem}.projects-page__summary{flex-direction:column;align-items:flex-start}.projects-grid{grid-template-columns:minmax(0,1fr)}.project-card{width:100%}.project-card__footer{row-gap:.35rem}.topbar-eyebrow{display:none}}
