:root,:root[data-theme=dark]{--bg: #08080c;--bg-grad: radial-gradient(1100px 560px at 82% -12%, rgba(124,92,255,.14), transparent 58%), radial-gradient(820px 460px at -8% 4%, rgba(34,211,238,.06), transparent 55%);--panel: #101016;--panel-2: #16161f;--panel-3: #1d1d28;--border: #23232f;--border-soft: #1a1a24;--text: #f3f4f8;--muted: #868a99;--faint: #565b6b;--accent: #8b5cf6;--accent-2: #a78bfa;--accent-grad: linear-gradient(135deg, #a78bfa 0%, #7c3aed 100%);--accent-soft: rgba(139,92,246,.13);--cyan: #22d3ee;--ok: #34d399;--warn: #fbbf24;--err: #f87171;--nav-active-bg: rgba(139,92,246,.16);--nav-active-fg: #ffffff;--sidebar-bg: linear-gradient(180deg, #0c0c12, #08080c);--topbar-bg: rgba(8,8,12,.72);--input-bg: #0c0c12;--input-bg-focus: #0e0e15;--code-bg: #050507;--code-text: #aab2c5;--w-value: linear-gradient(180deg, #fff, #cdbdff);--radius: 16px;--radius-sm: 11px;--radius-xs: 8px;--shadow: 0 1px 2px rgba(0,0,0,.5), 0 12px 30px rgba(0,0,0,.32);--shadow-sm: 0 1px 2px rgba(0,0,0,.4);--ring: 0 0 0 3px rgba(139,92,246,.28);--inset: inset 0 1px 0 rgba(255,255,255,.03)}:root[data-theme=light]{--bg: #f4f5fb;--bg-grad: radial-gradient(1100px 560px at 82% -12%, rgba(124,92,255,.1), transparent 58%), radial-gradient(820px 460px at -8% 4%, rgba(34,211,238,.05), transparent 55%);--panel: #ffffff;--panel-2: #f3f4f9;--panel-3: #e7e9f1;--border: #d6dae6;--border-soft: #e6e9f1;--text: #161823;--muted: #5c6270;--faint: #9197a5;--accent: #7c3aed;--accent-2: #7c3aed;--accent-grad: linear-gradient(135deg, #8b5cf6 0%, #6d28d9 100%);--accent-soft: rgba(124,58,237,.1);--cyan: #0891b2;--ok: #059669;--warn: #d97706;--err: #dc2626;--nav-active-bg: rgba(124,58,237,.12);--nav-active-fg: #5b21b6;--sidebar-bg: linear-gradient(180deg, #ffffff, #f6f7fc);--topbar-bg: rgba(255,255,255,.78);--input-bg: #ffffff;--input-bg-focus: #ffffff;--code-bg: #0f1117;--code-text: #aab2c5;--w-value: linear-gradient(180deg, #312170, #6d28d9);--shadow: 0 1px 2px rgba(30,30,60,.05), 0 14px 34px rgba(30,30,60,.1);--shadow-sm: 0 1px 2px rgba(30,30,60,.06);--ring: 0 0 0 3px rgba(124,58,237,.16);--inset: inset 0 1px 0 rgba(255,255,255,.6)}:root,:root[data-theme=dark]{color-scheme:dark}:root[data-theme=light]{color-scheme:light}html{transition:background-color .2s ease;background-color:var(--bg)}body,.card,.widget,.tile,.sidebar,.topbar,input,select,.release{transition:background-color .2s ease,border-color .2s ease,color .2s ease}*{box-sizing:border-box}html,body{margin:0;padding:0;height:100%}body{background-color:var(--bg);background-image:var(--bg-grad);background-attachment:fixed;color:var(--text);font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-size:14px;line-height:1.5;-webkit-font-smoothing:antialiased}a{color:var(--accent-2);text-decoration:none}h1{font-size:23px;font-weight:750;letter-spacing:-.025em;margin:0 0 2px;color:var(--text)}h2{display:flex;align-items:center;gap:8px;font-size:11.5px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.09em;margin:0 0 16px}h2 app-icon{color:var(--accent-2)}code,.mono{font-family:ui-monospace,SF Mono,SFMono-Regular,Menlo,monospace}.muted{color:var(--muted)}.faint{color:var(--faint)}.accent{color:var(--accent-2)}.mt{margin-top:16px}.row{display:flex;align-items:center;gap:12px}.spacer{flex:1}label{display:block;font-size:11px;font-weight:600;letter-spacing:.05em;text-transform:uppercase;color:var(--muted);margin-bottom:8px}input,select,textarea{width:100%;padding:11px 13px;background:var(--input-bg);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);font-size:14px;font-family:inherit;margin-bottom:15px;box-shadow:var(--inset);transition:border-color .15s,box-shadow .15s,background .15s}input::placeholder{color:var(--faint)}input:hover,select:hover{border-color:var(--accent)}input:focus,select:focus,textarea:focus{outline:none;border-color:var(--accent);background:var(--input-bg-focus);box-shadow:var(--ring)}select{appearance:none;cursor:pointer;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%23868a99' stroke-width='2.4' stroke-linecap='round' stroke-linejoin='round'><polyline points='6 9 12 15 18 9'/></svg>");background-repeat:no-repeat;background-position:right 12px center;padding-right:34px}button{display:inline-flex;align-items:center;gap:8px;justify-content:center;border:none;border-radius:var(--radius-sm);padding:10px 17px;font-size:13.5px;font-weight:650;cursor:pointer;font-family:inherit;background:var(--accent-grad);color:#fff;box-shadow:0 6px 16px #7c3aed59,var(--inset);transition:transform .08s,filter .15s,opacity .15s,box-shadow .15s}button:hover{filter:brightness(1.08);box-shadow:0 8px 22px #7c3aed73,var(--inset)}button:active{transform:translateY(1px)}button.secondary{background:var(--panel-2);color:var(--text);border:1px solid var(--border);box-shadow:var(--inset)}button.secondary:hover{background:var(--panel-3);border-color:#30303e;filter:none;box-shadow:var(--inset)}button.ghost{background:transparent;color:var(--muted);box-shadow:none;padding:8px}button.ghost:hover{background:var(--panel-2);color:var(--text);filter:none}button:disabled{opacity:.45;cursor:not-allowed;filter:none;transform:none;box-shadow:none}.card{position:relative;background:linear-gradient(180deg,rgba(255,255,255,.022),transparent 120px),var(--panel);border:1px solid var(--border);border-radius:var(--radius);padding:22px;margin-bottom:16px;box-shadow:var(--shadow),var(--inset)}.card.pad-lg{padding:26px}.card-actions{display:flex;align-items:center;gap:10px}.profile-card{display:flex;align-items:center;gap:16px}.avatar-lg{width:60px;height:60px;border-radius:50%;flex:0 0 60px;display:grid;place-items:center;font-size:19px;font-weight:750;color:#fff;background:var(--accent-grad);box-shadow:0 8px 24px #7c3aed80;letter-spacing:.02em}.status-pill{display:inline-flex;align-items:center;gap:6px;font-size:11.5px;font-weight:650;padding:3px 10px;border-radius:999px;background:var(--accent-soft);color:var(--accent-2)}.status-pill.on{background:#34d39921;color:var(--ok)}.status-pill i{width:7px;height:7px;border-radius:50%;background:currentColor}.badge,.chip{display:inline-flex;align-items:center;gap:6px;padding:3px 10px;border-radius:999px;font-size:11.5px;font-weight:650;line-height:1.6}.badge:before,.chip.dotted:before{content:"";width:7px;height:7px;border-radius:50%;background:currentColor}.badge.running,.chip.running{background:var(--accent-soft);color:var(--accent-2)}.badge.success,.chip.success{background:#34d39924;color:var(--ok)}.badge.failed,.chip.failed{background:#f8717124;color:var(--err)}.badge.idle,.chip.idle{background:#868a9924;color:var(--muted)}.chip{font-size:11px}.chip.running.dotted:before,.badge.running:before{animation:pulse 1.4s ease-in-out infinite}.kv{display:grid;grid-template-columns:150px 1fr;gap:0;margin-top:6px;font-size:13px}.kv .k,.kv .v{padding:11px 0;border-bottom:1px solid var(--border-soft)}.kv .k{color:var(--muted)}.kv .v{word-break:break-all;text-align:right}.kv>div:nth-last-child(-n+2){border-bottom:none}.shell{display:flex;min-height:100vh}.sidebar{width:246px;flex:0 0 246px;position:sticky;top:0;height:100vh;background:var(--sidebar-bg);border-right:1px solid var(--border-soft);padding:18px 14px;display:flex;flex-direction:column;z-index:40}.sidebar .brand{display:flex;align-items:center;gap:11px;font-size:16px;font-weight:780;letter-spacing:-.02em;padding:6px 10px 24px}.logo{display:grid;place-items:center;width:32px;height:32px;border-radius:10px;background:var(--accent-grad);color:#fff;box-shadow:0 5px 16px #7c3aed80}.sidebar nav{display:flex;flex-direction:column;gap:3px}.sidebar nav a{display:flex;align-items:center;gap:12px;color:var(--muted);padding:11px 12px;border-radius:11px;font-size:14px;font-weight:550;position:relative;transition:background .15s,color .15s}.sidebar nav a:hover{background:var(--panel-2);color:var(--text)}.sidebar nav a.active{background:var(--nav-active-bg);color:var(--nav-active-fg);font-weight:650}.sidebar nav a.active app-icon{color:var(--accent)}.sidebar nav a.active:before{content:"";position:absolute;left:-14px;top:10px;bottom:10px;width:3px;border-radius:0 3px 3px 0;background:var(--accent)}.side-foot{margin-top:auto;font-size:11px;color:var(--faint);padding:12px 10px 4px;border-top:1px solid var(--border-soft)}.main{flex:1;min-width:0;display:flex;flex-direction:column}.topbar{display:flex;align-items:center;gap:12px;padding:13px 26px;border-bottom:1px solid var(--border-soft);background:var(--topbar-bg);backdrop-filter:blur(12px);position:sticky;top:0;z-index:30}.topbar .hamburger{display:none}.user-pill{display:flex;align-items:center;gap:8px;padding:5px 12px 5px 6px;background:var(--panel-2);border:1px solid var(--border);border-radius:999px;font-size:13px;font-weight:550}.user-pill .avatar{width:25px;height:25px;border-radius:50%;display:grid;place-items:center;background:var(--accent-grad);color:#fff}.content{padding:28px;max-width:1180px;width:100%}.widgets{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:14px;margin-bottom:16px}.widget{position:relative;overflow:hidden;background:linear-gradient(180deg,rgba(255,255,255,.025),transparent 90px),var(--panel);border:1px solid var(--border);border-radius:var(--radius);padding:18px 18px 16px;box-shadow:var(--shadow-sm);transition:border-color .15s,transform .12s,box-shadow .15s}.widget:hover{border-color:var(--accent);transform:translateY(-2px);box-shadow:var(--shadow)}.widget .w-icon{position:absolute;top:15px;right:15px;width:34px;height:34px;border-radius:10px;display:grid;place-items:center;color:var(--accent-2);background:var(--accent-soft)}.w-label{font-size:10.5px;text-transform:uppercase;letter-spacing:.07em;color:var(--muted);font-weight:600}.w-value{font-size:27px;font-weight:780;letter-spacing:-.03em;margin:9px 0 3px;background:var(--w-value);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;color:transparent}.w-sub{font-size:12px;color:var(--muted)}.tiles{display:grid;grid-template-columns:repeat(auto-fill,minmax(290px,1fr));gap:14px}.tile{position:relative;overflow:hidden;display:flex;align-items:center;gap:13px;padding:16px;color:var(--text);background:var(--panel-2);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);transition:border-color .15s,transform .12s,box-shadow .15s}.tile:hover{border-color:var(--accent);transform:translateY(-3px);box-shadow:var(--shadow),0 0 0 1px #8b5cf640}.tile.big{flex-direction:column;align-items:stretch}.tile:before{content:"";position:absolute;left:0;top:0;bottom:0;width:0;border-radius:3px 0 0 3px;transition:width .15s}.tile.s-ok:before{width:3px;background:var(--ok)}.tile.s-err:before{width:3px;background:var(--err)}.tile.s-run:before{width:3px;background:var(--accent)}.tile.s-run{border-color:#8b5cf666;box-shadow:var(--shadow-sm),0 0 0 1px #8b5cf640}.tile.s-ok{background:linear-gradient(90deg,rgba(52,211,153,.05),transparent 60%),var(--panel-2)}.tile .t-main{flex:1;min-width:0}.tile .t-name{font-weight:650}.stat-ic{position:relative;width:30px;height:30px;border-radius:9px;flex:0 0 30px;display:grid;place-items:center}.stat-ic app-icon{display:inline-flex}.stat-ic.ok{color:var(--ok);background:#34d39926;box-shadow:0 0 0 1px #34d39940;animation:pop .42s cubic-bezier(.2,1.5,.4,1) backwards}.stat-ic.err{color:var(--err);background:#f8717126;box-shadow:0 0 0 1px #f8717140;animation:shake .55s ease both}.stat-ic.run{color:var(--accent-2);background:var(--accent-soft);box-shadow:0 0 0 1px #8b5cf64d}.stat-ic.idle{color:var(--faint);background:#868a9921}.stat-ic.run app-icon{animation:spin .9s linear infinite}.stat-ic.run:after{content:"";position:absolute;inset:-2px;border-radius:11px;border:2px solid var(--accent);animation:statring 1.5s ease-out infinite}@keyframes pop{0%{transform:scale(.4);opacity:0}to{transform:scale(1);opacity:1}}@keyframes shake{0%,to{transform:translate(0)}18%{transform:translate(-2.5px)}38%{transform:translate(2.5px)}58%{transform:translate(-2px)}78%{transform:translate(2px)}}@keyframes statring{0%{transform:scale(.85);opacity:.65}to{transform:scale(1.55);opacity:0}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.3}}.flash{animation:flashpop .6s cubic-bezier(.2,1.4,.4,1)}@keyframes flashpop{0%{transform:scale(1)}40%{transform:scale(1.09)}to{transform:scale(1)}}.skel{position:relative;overflow:hidden;background:var(--panel-2);border-radius:10px}.skel:after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,transparent,rgba(255,255,255,.07),transparent);transform:translate(-100%);animation:shimmerload 1.3s ease-in-out infinite}.skel-tile{height:84px}.skel-row{height:44px;margin-bottom:8px}@keyframes shimmerload{to{transform:translate(100%)}}@media (prefers-reduced-motion: reduce){.skel:after,.flash,.chip.running.dotted:before{animation:none}}.dash-2col{display:grid;grid-template-columns:1fr 340px;gap:16px;align-items:start}.donut-wrap{display:flex;flex-direction:column;align-items:center;gap:16px}.donut{position:relative;width:170px;height:170px}.donut svg{transform:rotate(-90deg);width:100%;height:100%}.donut .track{fill:none;stroke:var(--panel-3);stroke-width:12}.donut .val{fill:none;stroke:url(#donutGrad);stroke-width:12;stroke-linecap:round;transition:stroke-dasharray .6s ease}.donut-center{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center}.donut-num{font-size:30px;font-weight:780;letter-spacing:-.03em}.donut-legend{display:flex;gap:22px;font-size:13px}.donut-legend b{font-weight:700}.table-wrap{overflow-x:auto}.tbl{width:100%;border-collapse:collapse;font-size:13px}.tbl th{text-align:left;color:var(--muted);font-weight:600;font-size:10.5px;text-transform:uppercase;letter-spacing:.06em;padding:10px 12px;border-bottom:1px solid var(--border);position:sticky;top:0;background:var(--panel)}.tbl td{padding:12px;border-bottom:1px solid var(--border-soft);vertical-align:middle}.tbl tbody tr{transition:background .12s}.tbl tbody tr:last-child td{border-bottom:none}.tbl tbody tr:hover{background:var(--panel-2)}.pipe-grid{display:grid;grid-template-columns:270px 1fr;gap:16px;align-items:start}.psteps{display:flex;flex-direction:column;gap:4px;position:sticky;top:86px;align-self:start}.monitor-body.full .psteps{top:4px}.pstep{display:flex;align-items:center;gap:11px;padding:11px 12px;border-radius:10px;font-size:13.5px;border:1px solid transparent;transition:background .15s,border-color .15s}.pstep.running{background:var(--accent-soft);border-color:#8b5cf64d}.pstep.ok .pstep-label{color:var(--text)}.pstep.pending{opacity:.55}.pstep.skipped{opacity:.4}.pstep-ic{width:22px;height:22px;display:grid;place-items:center;flex:0 0 22px}.pstep.ok .pstep-ic{color:var(--ok)}.pstep.failed .pstep-ic{color:var(--err)}.pstep-label{flex:1;min-width:0;font-weight:550}.pstep-state{font-size:10.5px;text-transform:uppercase;letter-spacing:.05em;color:var(--faint);font-weight:600}.pstep.running .pstep-state{color:var(--accent-2)}.pstep.failed .pstep-state{color:var(--err)}.pstep.ok .pstep-state{color:var(--ok)}.pdot{width:9px;height:9px;border-radius:50%;background:var(--faint)}.pdash{color:var(--faint);font-weight:700}.spin{width:15px;height:15px;border-radius:50%;border:2px solid rgba(139,92,246,.25);border-top-color:var(--accent-2);animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.terminal{background:var(--code-bg);border:1px solid var(--border);border-radius:var(--radius-sm);padding:14px 16px;font-family:ui-monospace,Menlo,monospace;font-size:12.5px;line-height:1.65;max-height:340px;min-height:200px;overflow-y:auto;color:var(--code-text);box-shadow:inset 0 0 60px #0000008c}.terminal .tline{white-space:pre-wrap;word-break:break-word}.terminal .tline.marker{color:#e6e9f2}.terminal .tline.marker:first-letter{color:var(--accent-2)}@media (max-width: 760px){.pipe-grid{grid-template-columns:1fr}.psteps{position:static}}app-card{display:block}.monitor-card{scroll-margin-top:88px}app-card.deploy-kick>.card{animation:kickglow 1.1s ease}@keyframes kickglow{0%{box-shadow:0 0 #8b5cf68c,var(--shadow),var(--inset);border-color:var(--accent)}60%{box-shadow:0 0 0 8px #8b5cf600,var(--shadow),var(--inset);border-color:var(--accent)}to{box-shadow:var(--shadow),var(--inset)}}@media (prefers-reduced-motion: reduce){app-card.deploy-kick>.card{animation:none}}.dropzone{border:1.5px dashed var(--border);border-radius:var(--radius-sm);padding:32px;text-align:center;cursor:pointer;background:var(--panel-2);transition:border-color .15s,background .15s;display:flex;flex-direction:column;align-items:center;gap:10px;color:var(--muted)}.dropzone:hover,.dropzone.drag{border-color:var(--accent);background:var(--accent-soft);color:var(--text)}.dropzone code{background:#ffffff12;padding:1px 6px;border-radius:5px}.progress{height:8px;background:var(--panel-3);border-radius:999px;overflow:hidden;border:1px solid var(--border)}.progress .bar{height:100%;background:var(--accent-grad);transition:width .25s}.release{display:flex;align-items:center;gap:12px;padding:14px;margin-bottom:10px;background:var(--panel-2);border:1px solid var(--border-soft);border-radius:var(--radius-sm);transition:border-color .15s}.release:hover{border-color:#2c2c3a}.release.active{border-color:var(--ok);box-shadow:inset 3px 0 0 var(--ok)}.release .rel-main{flex:1;min-width:0}.auth-wrap{min-height:100vh;display:grid;place-items:center;padding:20px;background:radial-gradient(700px 420px at 50% -10%,rgba(124,92,255,.16),transparent 60%)}.auth-card{width:100%;max-width:408px}@media (max-width: 980px){.dash-2col{grid-template-columns:1fr}}@media (max-width: 880px){.sidebar{position:fixed;left:0;top:0;transform:translate(-100%);transition:transform .22s ease;box-shadow:var(--shadow)}.shell.nav-open .sidebar{transform:translate(0)}.shell.nav-open .scrim{display:block}.scrim{display:none;position:fixed;inset:0;background:#0000008c;z-index:35;backdrop-filter:blur(2px)}.topbar .hamburger{display:inline-flex}.content{padding:18px}.profile-card{flex-wrap:wrap}.kv{grid-template-columns:1fr}.kv .v{text-align:left}.kv .k{padding-bottom:2px;border-bottom:none}.kv .v{padding-top:2px}}@media (max-width: 560px){.content{padding:14px}.widgets{grid-template-columns:1fr 1fr;gap:11px}.widget{padding:14px}.w-value{font-size:22px}.tiles{grid-template-columns:1fr}.release{flex-wrap:wrap}.release button{width:100%}h1{font-size:20px}}:root{--gold: #e8c66b;--gold-2: #c9a13a}.brand-name{font-weight:800;letter-spacing:-.02em;white-space:nowrap;font-size:16.5px;background:linear-gradient(95deg,var(--text) 0%,var(--accent-2) 120%);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;color:transparent}:root[data-theme=light] .brand-name{background:linear-gradient(95deg,#1a1430,#6d28d9 120%);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}.brand-sub{font-weight:600}.logo{position:relative;overflow:hidden}.logo:after{content:"";position:absolute;inset:0;border-radius:inherit;box-shadow:inset 0 0 0 1px #e8c66b73;pointer-events:none}.logo:before{content:"";position:absolute;top:-60%;left:-30%;width:40%;height:220%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.5),transparent);transform:rotate(18deg);animation:shimmer 5.5s ease-in-out infinite}@keyframes shimmer{0%,72%{transform:translate(-180%) rotate(18deg)}88%,to{transform:translate(420%) rotate(18deg)}}.avatar-lg{box-shadow:0 8px 24px #7c3aed80,inset 0 0 0 1.5px #e8c66b80}@keyframes rise{0%{opacity:0;transform:translateY(11px)}to{opacity:1;transform:none}}.card-anim{animation:rise .42s cubic-bezier(.2,.7,.3,1) backwards}.stagger>*{animation:rise .46s cubic-bezier(.2,.7,.3,1) backwards}.stagger>*:nth-child(1){animation-delay:.03s}.stagger>*:nth-child(2){animation-delay:.08s}.stagger>*:nth-child(3){animation-delay:.13s}.stagger>*:nth-child(4){animation-delay:.18s}.stagger>*:nth-child(5){animation-delay:.23s}.stagger>*:nth-child(6){animation-delay:.28s}.page-head{animation:rise .4s cubic-bezier(.2,.7,.3,1) backwards}button:not(.secondary):not(.ghost){position:relative;overflow:hidden}button:not(.secondary):not(.ghost):after{content:"";position:absolute;inset:0;background:linear-gradient(110deg,transparent 30%,rgba(255,255,255,.22) 50%,transparent 70%);transform:translate(-120%);transition:transform .5s ease}button:not(.secondary):not(.ghost):hover:after{transform:translate(120%)}@media (prefers-reduced-motion: reduce){.card-anim,.stagger>*,.page-head,.logo:before,.stat-ic,.stat-ic app-icon,.stat-ic:after,.spin{animation:none!important}*,*:before,*:after{transition:none!important}}
