:root{--bg:oklch(17% 0 0);--surface:oklch(21% 0 0);--surface-2:oklch(27% 0 0);--border:oklch(31% 0 0);--border-strong:oklch(42% 0 0);--text:oklch(98% 0 0);--text-dim:oklch(74% 0 0);--text-faint:oklch(58% 0 0);--accent:oklch(72% 0.19 150);--ok:oklch(72% 0.19 150);--warn:oklch(82% 0.14 85);--fail:oklch(64% 0.20 25);--mono:ui-monospace,"SF Mono","JetBrains Mono",Menlo,monospace;--sans:ui-sans-serif,system-ui,-apple-system,"Segoe UI",sans-serif;--radius:10px;--space:clamp(1rem,0.6rem + 1.6vw,2rem)}*{box-sizing:border-box}body,html{margin:0;padding:0}body{background:var(--bg);color:var(--text);font-family:var(--sans);font-size:15px;line-height:1.5;-webkit-font-smoothing:antialiased;background-image:radial-gradient(1100px 520px at 50% -25%,oklch(34% .09 150/.22),transparent);min-height:100vh}a{color:inherit;text-decoration:none}.app-header{display:flex;align-items:center;gap:.85rem;padding:.9rem var(--space);border-bottom:1px solid var(--border);background:oklch(17% .013 255/.7);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);position:-webkit-sticky;position:sticky;top:0;z-index:10}.brand-dot{width:9px;height:9px;border-radius:50%;background:var(--ok);box-shadow:0 0 0 3px oklch(74% .16 150/.18)}.brand{font-weight:700;letter-spacing:.14em;font-size:.82rem}.brand-sub{color:var(--text-faint);font-size:.74rem;letter-spacing:.08em;text-transform:uppercase;border-left:1px solid var(--border);padding-left:.85rem}.app-main{padding:var(--space);max-width:1280px;margin:0 auto}.page-title{font-size:1.05rem;font-weight:650;margin:0 0 .25rem}.page-sub{color:var(--text-dim);font-size:.85rem;margin:0 0 1.4rem}.kpi-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));grid-gap:.8rem;gap:.8rem;margin-bottom:1.6rem}.kpi{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:.9rem 1rem;position:relative;overflow:hidden}.kpi:before{content:"";position:absolute;inset:0 0 auto 0;height:2px;background:var(--accent);opacity:.7}.kpi.is-ok:before{background:var(--ok)}.kpi.is-warn:before{background:var(--warn)}.kpi.is-fail:before{background:var(--fail)}.kpi-value{font-size:1.9rem;font-weight:700;font-feature-settings:"tnum";font-variant-numeric:tabular-nums;line-height:1.1}.kpi-label{color:var(--text-dim);font-size:.76rem;text-transform:uppercase;letter-spacing:.06em;margin-top:.25rem}.panel{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}table{width:100%;border-collapse:collapse}thead th{text-align:left;font-size:.72rem;text-transform:uppercase;letter-spacing:.07em;color:var(--text-faint);font-weight:600;padding:.7rem 1rem;background:var(--surface-2)}tbody td,thead th{border-bottom:1px solid var(--border)}tbody td{padding:.75rem 1rem;vertical-align:middle}tbody tr:last-child td{border-bottom:none}tbody tr{transition:background .12s ease}tbody tr.clickable:hover{background:var(--surface-2);cursor:pointer}.cell-name{font-weight:600}.cell-org,.mono{font-family:var(--mono);font-size:.82rem;color:var(--text-dim)}.cell-stack{display:flex;flex-direction:column;gap:.1rem}.pill{display:inline-flex;align-items:center;gap:.4rem;padding:.2rem .6rem;border-radius:999px;font-size:.74rem;font-weight:600;border:1px solid transparent;white-space:nowrap}.pill:before{content:"";width:7px;height:7px;border-radius:50%;background:currentColor}.pill.success{color:var(--ok);background:oklch(74% .16 150/.12);border-color:oklch(74% .16 150/.25)}.pill.partial{color:var(--warn);background:oklch(82% .14 85/.12);border-color:oklch(82% .14 85/.25)}.pill.failed{color:var(--fail);background:oklch(68% .19 25/.13);border-color:oklch(68% .19 25/.28)}.pill.none{color:var(--text-faint);background:oklch(40% .01 255/.2);border-color:var(--border)}.badge{font-size:.72rem;padding:.12rem .5rem;border-radius:6px;border:1px solid var(--border-strong);color:var(--text-dim)}.badge.on{color:var(--ok);border-color:oklch(74% .16 150/.4)}.badge.off{color:var(--text-faint)}.num-ok{color:var(--ok)}.num-fail,.num-ok{font-feature-settings:"tnum";font-variant-numeric:tabular-nums}.num-fail{color:var(--fail)}.link-accent{color:var(--accent);border-bottom:1px solid oklch(72% .19 150/.35)}.link-accent:hover{border-bottom-color:var(--accent)}.muted{color:var(--text-faint)}.back-link{color:var(--text-dim);font-size:.82rem;display:inline-block;margin-bottom:1rem}.back-link:hover{color:var(--text)}.detail-head{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:1.2rem 1.3rem;margin-bottom:1.4rem}.detail-head h1{margin:0 0 .3rem;font-size:1.35rem}.detail-meta{display:flex;flex-wrap:wrap;gap:.5rem 1.4rem;color:var(--text-dim);font-size:.85rem;margin-top:.7rem}.detail-meta span strong{color:var(--text);font-weight:600}.section-title{font-size:.8rem;text-transform:uppercase;letter-spacing:.07em;color:var(--text-faint);margin:0 0 .7rem}.fail-list{font-family:var(--mono);font-size:.76rem;color:var(--fail);margin:.3rem 0 0;padding-left:1rem}.empty{color:var(--text-faint);padding:2rem;text-align:center}.auth-wrap{min-height:calc(100vh - 120px);display:grid;place-items:center;padding:2rem 1rem}.auth-card{width:100%;max-width:380px;background:var(--surface);border:1px solid var(--border);border-radius:14px;padding:1.8rem 1.6rem;display:flex;flex-direction:column;gap:.85rem;box-shadow:0 20px 60px oklch(0 0 0/.4)}.auth-brand{display:flex;align-items:center;gap:.6rem;margin-bottom:.2rem}.auth-title{font-size:1.4rem;margin:.4rem 0 0}.auth-sub{color:var(--text-dim);font-size:.85rem;margin:0 0 .4rem}.auth-error{background:oklch(64% .2 25/.13);border:1px solid oklch(64% .2 25/.3);color:var(--fail);border-radius:8px;padding:.6rem .8rem;font-size:.84rem}.auth-field{display:flex;flex-direction:column;gap:.35rem}.auth-field span{font-size:.78rem;color:var(--text-dim);letter-spacing:.02em}.auth-field input{background:var(--bg);border:1px solid var(--border-strong);color:var(--text);border-radius:8px;padding:.65rem .8rem;font-size:.95rem;font-family:var(--sans);transition:border-color .12s ease,box-shadow .12s ease}.auth-field input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px oklch(72% .19 150/.18)}.auth-btn{margin-top:.4rem;background:var(--accent);color:oklch(18% .04 150);border:none;border-radius:999px;padding:.75rem 1rem;font-weight:700;font-size:.95rem;cursor:pointer;transition:filter .12s ease,transform 80ms ease}.auth-btn:hover{filter:brightness(1.08)}.auth-btn:active{transform:translateY(1px)}.header-nav{display:flex;gap:.3rem;align-items:center}.nav-link{color:var(--text-dim);font-size:.82rem;padding:.3rem .6rem;border-radius:7px;transition:color .12s ease,background .12s ease}.nav-link.active,.nav-link:hover{color:var(--text);background:var(--surface-2)}.nav-link .nav-ico{margin-right:.3rem}.tabs{display:flex;gap:.4rem;border-bottom:1px solid var(--border);margin:0 0 1.5rem}.tab{padding:.6rem .9rem;font-size:.86rem;color:var(--text-dim);border-bottom:2px solid transparent;margin-bottom:-1px;transition:color .12s ease,border-color .12s ease}.tab.active,.tab:hover{color:var(--text)}.tab.active{border-bottom-color:var(--accent)}.form-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:1.3rem 1.4rem;max-width:640px}.form-card+.form-card{margin-top:1.2rem}.form-card h2{font-size:.95rem;margin:0 0 .3rem;font-weight:650}.form-card .card-sub{color:var(--text-dim);font-size:.82rem;margin:0 0 1.1rem}.field{display:flex;flex-direction:column;gap:.35rem;margin-bottom:.95rem}.field>label{font-size:.78rem;color:var(--text-dim);letter-spacing:.02em}.field input[type=email],.field input[type=number],.field input[type=password],.field input[type=text],.field select,.field textarea{background:var(--bg);border:1px solid var(--border-strong);color:var(--text);border-radius:8px;padding:.6rem .75rem;font-size:.9rem;font-family:var(--sans);width:100%;transition:border-color .12s ease,box-shadow .12s ease}.field textarea.mono-editor{font-family:var(--mono);font-size:.82rem;line-height:1.5;min-height:200px;resize:vertical;white-space:pre}.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px oklch(72% .19 150/.18)}.field-hint{font-size:.74rem;color:var(--text-faint)}.field-row{display:flex;gap:.9rem}.field-row>.field{flex:1 1}.toggle-field{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:.8rem 0;border-top:1px solid var(--border)}.toggle-field .toggle-label{font-size:.88rem}.toggle-field .toggle-desc{font-size:.76rem;color:var(--text-faint);margin-top:.15rem}.switch{position:relative;width:42px;height:24px;flex-shrink:0}.switch input{opacity:0;width:0;height:0}.switch .track{position:absolute;inset:0;cursor:pointer;border-radius:999px;background:var(--surface-2);border:1px solid var(--border-strong);transition:background .16s ease,border-color .16s ease}.switch .track:before{content:"";position:absolute;height:16px;width:16px;left:3px;top:3px;border-radius:50%;background:var(--text-dim);transition:transform .16s ease,background .16s ease}.switch input:checked+.track{background:oklch(72% .19 150/.3);border-color:var(--accent)}.switch input:checked+.track:before{transform:translateX(18px);background:var(--accent)}.btn-row{display:flex;gap:.6rem;align-items:center;margin-top:.4rem;flex-wrap:wrap}.btn{border-radius:999px;padding:.55rem 1.1rem;font-size:.85rem;font-weight:600;cursor:pointer;font-family:var(--sans);border:1px solid transparent;transition:filter .12s ease,background .12s ease,border-color .12s ease,transform 80ms ease}.btn:active{transform:translateY(1px)}.btn:disabled{opacity:.55;cursor:default}.btn-primary{background:var(--accent);color:oklch(18% .04 150);border:none}.btn-primary:hover:not(:disabled){filter:brightness(1.08)}.btn-ghost{border-color:var(--border-strong);color:var(--text-dim)}.btn-ghost:hover:not(:disabled){color:var(--text);border-color:var(--text-dim)}.btn-danger{background:transparent;border-color:oklch(64% .2 25/.4);color:var(--fail)}.btn-danger:hover:not(:disabled){background:oklch(64% .2 25/.12)}.btn-sm{padding:.32rem .7rem;font-size:.78rem}.feedback{font-size:.82rem;padding:.5rem .75rem;border-radius:8px;margin-top:.2rem}.feedback.ok{color:var(--ok);background:oklch(74% .16 150/.12);border:1px solid oklch(74% .16 150/.25)}.feedback.err{color:var(--fail);background:oklch(64% .2 25/.13);border:1px solid oklch(64% .2 25/.3)}.feedback.info,.note{color:var(--text-dim);background:var(--surface-2);border:1px solid var(--border)}.note{border-left:2px solid var(--accent);border-radius:8px;padding:.8rem 1rem;font-size:.82rem;margin-bottom:1rem}.note strong{color:var(--text)}.var-chips{display:flex;flex-wrap:wrap;gap:.4rem;margin-top:.4rem}.var-chip{font-size:.74rem;color:var(--accent);background:oklch(72% .19 150/.1);border:1px solid oklch(72% .19 150/.25);border-radius:6px;padding:.12rem .45rem}.code-input,.var-chip{font-family:var(--mono)}.code-input{font-size:1.4rem!important;letter-spacing:.5rem;text-align:center}.tpl-status{display:inline-flex;align-items:center;gap:.4rem;font-size:.78rem}.tpl-status:before{content:"";width:7px;height:7px;border-radius:50%}.tpl-status.on{color:var(--ok)}.tpl-status.on:before{background:var(--ok)}.tpl-status.off{color:var(--text-faint)}.tpl-status.off:before{background:var(--text-faint)}.header-spacer{flex:1 1}.session-email{color:var(--text-dim);font-size:.8rem}.logout-btn{background:transparent;border:1px solid var(--border-strong);color:var(--text-dim);border-radius:999px;padding:.3rem .8rem;font-size:.78rem;cursor:pointer;font-family:var(--sans);transition:color .12s ease,border-color .12s ease}.logout-btn:hover{color:var(--text);border-color:var(--text-dim)}.app-shell{display:grid;grid-template-columns:232px 1fr;min-height:100vh}.sidebar{position:-webkit-sticky;position:sticky;top:0;height:100vh;background:oklch(13% 0 0);border-right:1px solid var(--border);padding:1.1rem .8rem;display:flex;flex-direction:column;gap:1.3rem}.sidebar-brand{display:flex;align-items:center;gap:.6rem;padding:.3rem .55rem}.sidebar-nav{display:flex;flex-direction:column;gap:.22rem}.side-link{display:flex;align-items:center;gap:.7rem;padding:.6rem .7rem;border-radius:8px;color:var(--text-dim);font-weight:600;font-size:.9rem;transition:background .12s ease,color .12s ease}.side-link.active,.side-link:hover{color:var(--text);background:var(--surface-2)}.side-ico{display:inline-flex;color:var(--text-faint);transition:color .12s ease}.side-link:hover .side-ico{color:var(--text-dim)}.side-link.active .side-ico{color:var(--accent)}.sidebar-foot{margin-top:auto;padding:.5rem .55rem;color:var(--text-faint);font-size:.68rem;text-transform:uppercase;letter-spacing:.09em}.content{display:flex;flex-direction:column;min-width:0}.topbar{display:flex;align-items:center;gap:.8rem;height:56px;padding:0 var(--space);border-bottom:1px solid var(--border);background:oklch(15% 0 0/.65);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);position:-webkit-sticky;position:sticky;top:0;z-index:20}.profile{position:relative}.profile-trigger{list-style:none;cursor:pointer;display:inline-flex}.profile-trigger::-webkit-details-marker{display:none}.avatar{width:34px;height:34px;border-radius:50%;display:grid;place-items:center;font-size:.76rem;font-weight:800;letter-spacing:.02em;color:oklch(16% .05 150);background:var(--accent);border:2px solid transparent;transition:border-color .12s ease}.profile-trigger:hover .avatar,.profile[open] .avatar{border-color:oklch(100% 0 0/.3)}.profile-menu{position:absolute;right:0;top:calc(100% + 10px);width:230px;background:var(--surface-2);border:1px solid var(--border-strong);border-radius:12px;padding:.9rem;box-shadow:0 18px 50px oklch(0 0 0/.55);display:flex;flex-direction:column;gap:.45rem;z-index:30}.profile-email{font-weight:600;font-size:.85rem;word-break:break-all}.profile-role{color:var(--accent);font-size:.7rem;text-transform:uppercase;letter-spacing:.07em}.profile-logout{margin-top:.35rem;width:100%;background:transparent;border:1px solid var(--border-strong);color:var(--text-dim);border-radius:8px;padding:.5rem;font-size:.82rem;cursor:pointer;font-family:var(--sans);transition:color .12s ease,border-color .12s ease}.profile-logout:hover{color:var(--text);border-color:var(--text-dim)}@media (max-width:760px){.app-shell{grid-template-columns:60px 1fr}.sidebar{padding:1.1rem .5rem}.side-link{justify-content:center;padding:.6rem}.brand,.side-link span:not(.side-ico),.sidebar-foot{display:none}}.run-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(210px,1fr));grid-gap:.7rem;gap:.7rem;margin-bottom:1.4rem}.run-card{background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:.85rem .95rem;display:flex;flex-direction:column;gap:.35rem;transition:border-color .12s ease,background .12s ease}.run-card:hover{background:var(--surface-2);border-color:var(--border-strong)}.run-card.active{border-color:var(--accent);background:var(--surface-2)}.run-time{font-family:var(--mono);font-size:.84rem;font-weight:600}.run-counts{display:flex;flex-wrap:wrap;gap:.5rem;font-size:.8rem;font-feature-settings:"tnum";font-variant-numeric:tabular-nums}.run-sub{color:var(--text-faint);font-size:.76rem}.num-warn{color:var(--warn);font-feature-settings:"tnum";font-variant-numeric:tabular-nums}.filterbar{display:flex;align-items:center;gap:.5rem;margin-bottom:.9rem;flex-wrap:wrap}.filterbar-label{color:var(--text-faint);font-size:.78rem}.filter-link{padding:.32rem .8rem;border-radius:999px;font-size:.8rem;font-weight:600;color:var(--text-dim);border:1px solid var(--border-strong);transition:color .12s ease,border-color .12s ease,background .12s ease}.filter-link:hover{color:var(--text)}.filter-link.active{color:oklch(16% .05 150);background:var(--accent);border-color:var(--accent)}.filter-clear{margin-left:.3rem;color:var(--text-faint);font-size:.78rem}.filter-clear:hover{color:var(--fail)}.bento{display:grid;grid-template-columns:repeat(3,1fr);grid-gap:.9rem;gap:.9rem}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:1.1rem 1.2rem;min-width:0}.span-2{grid-column:span 2}.span-3{grid-column:span 3}@media (max-width:860px){.bento{grid-template-columns:1fr}.span-2,.span-3{grid-column:span 1}}.card-title{font-size:.73rem;text-transform:uppercase;letter-spacing:.08em;color:var(--text-faint);margin-bottom:.9rem}.card-foot{display:inline-block;margin-top:.85rem;font-size:.78rem}.gauge-row{display:flex;align-items:baseline;gap:1rem;margin-bottom:.85rem;flex-wrap:wrap}.gauge-pct{font-size:2.4rem;font-weight:800;line-height:1;font-feature-settings:"tnum";font-variant-numeric:tabular-nums;color:var(--accent)}.gauge-meta{color:var(--text-dim);font-size:.85rem}.gauge-meta strong{color:var(--text)}.progress{height:10px;border-radius:999px;background:var(--surface-2);overflow:hidden;margin-top:.6rem}.progress-fill{height:100%;background:var(--accent);border-radius:999px}.progress-fill.warn{background:var(--warn)}.bars{display:flex;flex-direction:column;gap:.65rem}.bar-row{display:grid;grid-template-columns:62px 1fr 28px;align-items:center;grid-gap:.6rem;gap:.6rem}.bar-label{font-size:.8rem;color:var(--text-dim)}.bar-track{height:8px;background:var(--surface-2);border-radius:999px;overflow:hidden}.bar-fill{display:block;height:100%;background:var(--accent);border-radius:999px}.bar-val{font-size:.8rem;text-align:right;color:var(--text-dim)}.activity{list-style:none;margin:0;padding:0}.activity-item{display:grid;grid-template-columns:auto 1fr auto auto;align-items:center;grid-gap:.85rem;gap:.85rem;padding:.55rem 0;border-bottom:1px solid var(--border)}.activity-item:last-child{border-bottom:none}.activity-name{font-weight:600;font-size:.88rem}.activity-mods{font-size:.8rem}.activity-time{font-size:.78rem}.toolbar{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin-bottom:1rem;flex-wrap:wrap}.seg{background:var(--surface);border:1px solid var(--border-strong);border-radius:999px;padding:3px}.seg,.seg form,.seg-btn{display:inline-flex}.seg-btn{align-items:center;gap:.4rem;border:none;background:transparent;color:var(--text-dim);font-family:var(--sans);font-weight:600;font-size:.84rem;padding:.4rem .95rem;border-radius:999px;cursor:pointer;transition:color .12s ease,background .12s ease}.seg-btn:hover{color:var(--text)}.seg-btn.active{background:var(--accent);color:oklch(16% .05 150)}.seg-count{font-feature-settings:"tnum";font-variant-numeric:tabular-nums;opacity:.7;font-size:.78rem}.seg-btn.active .seg-count{opacity:.85}.search{flex:1 1;max-width:320px}.search input{width:100%;background:var(--surface);border:1px solid var(--border-strong);color:var(--text);border-radius:999px;padding:.5rem .95rem;font-size:.86rem;font-family:var(--sans)}.search input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px oklch(72% .19 150/.16)}.auth-link{text-align:center;font-size:.82rem;color:var(--text-dim);margin-top:.2rem;transition:color .12s ease}.auth-link:hover{color:var(--accent)}.auth-success{background:oklch(72% .19 150/.12);border:1px solid oklch(72% .19 150/.3);color:var(--ok);border-radius:8px;padding:.6rem .8rem;font-size:.84rem}.search{display:flex;gap:.5rem;align-items:center;max-width:420px}.search input{flex:1 1;min-width:0}.search-btn{border:1px solid var(--border-strong);background:var(--surface-2);color:var(--text-dim);border-radius:999px;padding:.5rem .9rem;font-size:.82rem;font-weight:600;cursor:pointer;font-family:var(--sans);white-space:nowrap;transition:color .12s ease,border-color .12s ease}.search-btn:hover{color:var(--text);border-color:var(--text-dim)}.detail-ids{display:flex;flex-wrap:wrap;gap:.35rem 1.4rem;margin-top:.15rem}.id-line{font-family:var(--mono);font-size:.84rem;color:var(--text);display:inline-flex;align-items:baseline;gap:.4rem}.id-line .lbl{font-family:var(--sans);color:var(--text-faint);text-transform:uppercase;font-size:.66rem;letter-spacing:.07em}.files-panel{padding:1.1rem 1.2rem}.files-head{display:flex;justify-content:space-between;align-items:flex-start;gap:1rem;flex-wrap:wrap}.files-head strong{font-size:.95rem}.files-sub{color:var(--text-dim);font-size:.82rem;margin:.25rem 0 0;max-width:46ch;line-height:1.4}.btn-accent{background:var(--accent);color:oklch(18% .04 150);border:none;border-radius:999px;padding:.55rem 1.1rem;font-size:.85rem;font-weight:600;cursor:pointer;white-space:nowrap;transition:filter var(--duration-fast,.15s) ease}.btn-accent:hover:not(:disabled){filter:brightness(1.08)}.btn-accent:disabled{opacity:.55;cursor:progress}.files-err,.files-ok{margin-top:.9rem;padding:.55rem .8rem;border-radius:var(--radius);font-size:.83rem;border:1px solid}.files-ok{color:var(--accent);background:oklch(72% .19 150/.08);border-color:oklch(72% .19 150/.3)}.files-err{color:oklch(70% .17 25);background:oklch(70% .17 25/.08);border-color:oklch(70% .17 25/.3)}.files-panel table{margin-top:1rem}.files-actions{display:flex;gap:.9rem;align-items:center;white-space:nowrap}.link-danger{background:none;cursor:pointer;padding:0;color:oklch(70% .17 25);font-size:.82rem;border:none;border-bottom:1px solid oklch(70% .17 25/.35)}.link-danger:hover:not(:disabled){border-bottom-color:oklch(70% .17 25)}.link-danger:disabled{opacity:.5;cursor:default}.files-head-actions{display:flex;gap:.5rem;align-items:center;flex-wrap:wrap}.btn-ghost{background:transparent;color:var(--text);border:1px solid var(--border-strong);border-radius:999px;padding:.5rem 1rem;font-size:.85rem;font-weight:500;cursor:pointer;white-space:nowrap;transition:border-color var(--duration-fast,.15s) ease,background var(--duration-fast,.15s) ease}.btn-ghost:hover:not(:disabled){border-color:var(--accent);background:oklch(72% .19 150/.06)}.btn-ghost:disabled{opacity:.5;cursor:default}.tag{font-size:.7rem;text-transform:uppercase;letter-spacing:.05em;padding:.15rem .5rem;border-radius:999px;white-space:nowrap;color:var(--text-dim);background:oklch(40% .01 255/.25);border:1px solid var(--border)}.tag-up{color:var(--accent);background:oklch(72% .19 150/.1);border-color:oklch(72% .19 150/.3)}.client-status{display:flex;flex-wrap:wrap;gap:.5rem .8rem;align-items:center;margin-top:.8rem;font-size:.82rem}.portal-wrap{min-height:100vh;display:flex;flex-direction:column}.portal-top{display:flex;justify-content:space-between;align-items:center;padding:1.1rem 1.6rem;border-bottom:1px solid var(--border)}.portal-logout{background:transparent;color:var(--text-dim);border:1px solid var(--border-strong);border-radius:999px;padding:.45rem 1rem;font-size:.82rem;cursor:pointer;transition:border-color var(--duration-fast,.15s) ease,color var(--duration-fast,.15s) ease}.portal-logout:hover{border-color:var(--accent);color:var(--text)}.portal-main{width:100%;max-width:720px;margin:0 auto;padding:2.4rem 1.6rem}.portal-title{font-size:1.7rem;margin:0 0 .2rem}.portal-sub{color:var(--accent);font-size:.95rem;margin:0 0 1.8rem;font-weight:500}.portal-empty{color:var(--text-dim);background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:2rem;text-align:center}.portal-files{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.6rem}.portal-file{display:flex;justify-content:space-between;align-items:center;gap:1rem;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:.9rem 1.1rem;transition:border-color var(--duration-fast,.15s) ease}.portal-file:hover{border-color:var(--border-strong)}.portal-file-info{display:flex;flex-direction:column;gap:.2rem;min-width:0}.portal-file-name{font-weight:500;word-break:break-word}.portal-file-meta{color:var(--text-dim);font-size:.8rem;font-family:var(--mono)}.portal-dl{flex-shrink:0;background:var(--accent);color:oklch(18% .04 150);border-radius:999px;padding:.5rem 1.1rem;font-size:.85rem;font-weight:600;text-decoration:none;white-space:nowrap;transition:filter var(--duration-fast,.15s) ease}.portal-dl:hover{filter:brightness(1.08)}.portal-foot{color:var(--text-faint);font-size:.8rem;margin-top:2rem;text-align:center}