*{box-sizing:border-box;margin:0;padding:0}body{color:#e2e8f0;background:#0f172a;min-height:100vh;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}#root{max-width:1200px;margin:0 auto;padding:24px}a{color:#60a5fa;text-decoration:none}a:hover{text-decoration:underline}:focus-visible,button:focus-visible{outline-offset:2px;outline:2px solid #3b82f6}input:focus-visible,select:focus-visible{outline-offset:0;outline:2px solid #3b82f6}tr:focus-visible{outline-offset:-2px;outline:2px solid #3b82f6}:root{--brand-hue:170;--font-display:"IBM Plex Sans", system-ui, sans-serif;--font-body:"IBM Plex Sans", system-ui, sans-serif;--font-mono:"IBM Plex Mono", "Fira Code", monospace;--size-300:clamp(.7rem, .66rem + .2vw, .8rem);--size-400:clamp(.88rem, .83rem + .24vw, 1rem);--size-500:clamp(1rem, .94rem + .3vw, 1.15rem);--size-600:clamp(1.2rem, 1.1rem + .5vw, 1.4rem);--size-700:clamp(1.5rem, 1.3rem + 1vw, 2rem);--neutral-50:oklch(97% .005 var(--brand-hue));--neutral-100:oklch(95% .005 var(--brand-hue));--neutral-200:oklch(89% .008 var(--brand-hue));--neutral-300:oklch(80% .008 var(--brand-hue));--neutral-400:oklch(68% .008 var(--brand-hue));--neutral-500:oklch(55% .008 var(--brand-hue));--neutral-600:oklch(42% .01 var(--brand-hue));--neutral-700:oklch(32% .01 var(--brand-hue));--neutral-800:oklch(22% .01 var(--brand-hue));--neutral-900:oklch(14% .008 var(--brand-hue));--neutral-950:oklch(10% .005 var(--brand-hue));--brand-400:oklch(68% .14 var(--brand-hue));--brand-500:oklch(55% .18 var(--brand-hue));--brand-600:oklch(48% .16 var(--brand-hue));--brand-700:oklch(40% .12 var(--brand-hue));--brand-900:oklch(22% .06 var(--brand-hue));--color-text:var(--neutral-100);--color-text-muted:var(--neutral-400);--color-text-subtle:var(--neutral-500);--color-surface:var(--neutral-950);--color-surface-raised:var(--neutral-900);--color-surface-sunken:oklch(8% .005 var(--brand-hue));--color-border:var(--neutral-800);--color-border-strong:var(--neutral-700);--color-accent:var(--brand-400);--color-accent-hover:var(--brand-500);--color-valid:oklch(65% .18 150);--color-invalid:oklch(62% .22 25);--color-missing:oklch(70% .18 80);--color-info:oklch(65% .14 230);--space-1:.25rem;--space-2:.5rem;--space-3:.75rem;--space-4:1rem;--space-6:1.5rem;--space-8:2rem;--radius-sm:4px;--radius-md:6px;--radius-lg:10px;--radius-xl:14px;--ease-out:cubic-bezier(0, 0, .2, 1);--duration-fast:.12s;--duration-normal:.2s}*,:before,:after{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font-body);font-size:var(--size-400);color:var(--color-text);background:var(--color-surface);-webkit-font-smoothing:antialiased;padding:0 clamp(16px,4vw,48px) 48px;font-weight:400;line-height:1.5}h1,h2,h3,h4{font-family:var(--font-display);letter-spacing:-.01em;text-wrap:balance}header{margin-bottom:var(--space-8);border-bottom:1px solid var(--color-border);padding:var(--space-4) 0;z-index:200;background:oklch(from var(--color-surface) l c h / 85%);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);justify-content:space-between;align-items:center;display:flex;position:sticky;top:0}header h1{font-size:var(--size-600);color:var(--color-text);font-weight:600}header h1 span{color:var(--color-accent);font-weight:700}nav{gap:var(--space-1);display:flex}nav button{color:var(--color-text-muted);border-radius:var(--radius-md);padding:var(--space-2) var(--space-3);cursor:pointer;font-size:var(--size-300);font-family:var(--font-body);letter-spacing:.02em;transition:color var(--duration-fast) var(--ease-out), background var(--duration-fast) var(--ease-out), border-color var(--duration-fast) var(--ease-out);background:0 0;border:1px solid #0000;font-weight:500}nav button:hover{background:var(--color-surface-raised);color:var(--color-text);border-color:var(--color-border)}nav button.active{background:var(--brand-900);color:var(--color-accent);border-color:var(--brand-700)}.grid{gap:var(--space-4);margin-bottom:var(--space-6);grid-template-columns:repeat(auto-fill,minmax(min(340px,100%),1fr));display:grid}.card{background:var(--color-surface-raised);border:1px solid var(--color-border);border-radius:var(--radius-xl);padding:var(--space-6);transition:transform var(--duration-normal) var(--ease-out), box-shadow var(--duration-normal) var(--ease-out), border-color var(--duration-normal) var(--ease-out)}.card:hover{border-color:var(--color-border-strong)}.card h3{font-size:var(--size-500);color:var(--color-text);margin-bottom:var(--space-3);font-weight:600}.card .meta{font-size:var(--size-300);color:var(--color-text-muted);margin-bottom:var(--space-2)}.stats{gap:var(--space-2);margin-bottom:var(--space-3);flex-wrap:wrap;display:flex}.stat{background:var(--color-surface-sunken);border-radius:var(--radius-md);padding:var(--space-2) var(--space-3);text-align:center;flex:1;min-width:70px}.stat .value{font-size:20px;font-weight:700;font-family:var(--font-mono);font-variant-numeric:tabular-nums}.stat .label{color:var(--color-text-subtle);text-transform:uppercase;letter-spacing:.06em;margin-top:2px;font-size:10px;font-weight:500}.stat.valid .value{color:var(--color-valid)}.stat.invalid .value{color:var(--color-invalid)}.stat.missing .value{color:var(--color-missing)}.stat.total .value{color:var(--color-accent)}.progress-bar{background:var(--color-surface-sunken);border-radius:var(--radius-sm);height:6px;margin-top:var(--space-2);overflow:hidden}.progress-fill{border-radius:var(--radius-sm);height:100%;transition:width .4s var(--ease-out)}.progress-fill.complete{background:var(--color-valid)}.progress-fill.partial{background:var(--color-missing)}.progress-fill.empty{background:var(--color-border)}.pct{font-size:var(--size-300);color:var(--color-text-muted);margin-top:var(--space-1);font-family:var(--font-mono)}.badge{letter-spacing:.03em;font-size:11px;font-weight:600;font-family:var(--font-mono);border-radius:999px;padding:2px 10px;display:inline-block}.badge.valid,.badge.complete{color:var(--color-valid);background:oklch(20% .04 150)}.badge.invalid,.badge.failed{color:var(--color-invalid);background:oklch(20% .04 25)}.badge.missing,.badge.running,.badge.incomplete{color:var(--color-missing);background:oklch(22% .04 80)}.badge.pending,.badge.queued{background:var(--color-surface-sunken);color:var(--color-text-muted);border:1px solid var(--color-border)}.badge.extra,.badge.unread{color:var(--color-info);background:oklch(18% .04 230)}.badge.read{background:var(--color-surface-sunken);color:var(--color-text-subtle)}table{border-collapse:collapse;width:100%}th,td{text-align:left;border-bottom:1px solid var(--color-border);padding:10px 12px;font-size:13px}th{color:var(--color-text-subtle);text-transform:uppercase;letter-spacing:.06em;font-size:11px;font-weight:500;font-family:var(--font-body)}tr[role=button]:hover td{background:oklch(16% .008 var(--brand-hue))}tr:hover td{background:oklch(13% .005 var(--brand-hue))}select,input[type=number],input[type=text],input{--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark;font-family:var(--font-body)}select option{background:var(--color-surface-raised);color:var(--color-text)}.loading{text-align:center;color:var(--color-text-muted);font-size:var(--size-400);padding:64px}.spinner{border:2px solid var(--color-border);border-top-color:var(--color-accent);width:20px;height:20px;margin-bottom:var(--space-3);border-radius:50%;animation:.8s linear infinite spin;display:inline-block}@keyframes spin{to{transform:rotate(360deg)}}.section-title{color:var(--color-text-muted);margin-bottom:var(--space-4);text-transform:uppercase;letter-spacing:.08em;font-size:12px;font-weight:600;font-family:var(--font-body)}.empty{text-align:center;color:var(--color-text-muted);font-size:var(--size-400);padding:48px}.empty .empty-icon{width:44px;height:44px;margin:0 auto var(--space-3);border:1px dashed var(--color-border-strong);border-radius:var(--radius-lg);color:var(--color-text-subtle);justify-content:center;align-items:center;font-size:18px;display:flex}.empty .empty-hint{font-size:var(--size-300);color:var(--color-text-subtle);margin-top:var(--space-2)}.detail-back{margin-bottom:var(--space-4);cursor:pointer;color:var(--color-accent);font-size:13px;font-family:var(--font-body);transition:color var(--duration-fast) var(--ease-out);background:0 0;border:none}.detail-back:hover{color:var(--color-accent-hover);text-decoration:underline}.link-btn{cursor:pointer;color:var(--color-valid);font-size:13px;font-family:var(--font-body);transition:color var(--duration-fast) var(--ease-out);background:0 0;border:none;font-weight:500}.link-btn:hover{color:oklch(75% .2 150);text-decoration:underline}.tags{gap:var(--space-1);margin-top:var(--space-2);flex-wrap:wrap;display:flex}.tag{background:var(--color-surface-sunken);color:var(--color-text-muted);border-radius:var(--radius-sm);font-size:12px;font-family:var(--font-mono);cursor:pointer;transition:border-color var(--duration-fast) var(--ease-out), color var(--duration-fast) var(--ease-out);border:1px solid #0000;padding:3px 10px}.tag:hover{border-color:var(--color-border-strong);color:var(--color-text)}.tag.element{color:var(--color-info);background:oklch(18% .04 230);border-color:oklch(25% .06 230)}.tag.phase{color:oklch(70% .14 280);background:oklch(18% .04 280);border-color:oklch(25% .06 280)}.modal-overlay{z-index:400;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:oklch(0% 0 0/.6);justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal{background:var(--color-surface-raised);border:1px solid var(--color-border-strong);border-radius:var(--radius-xl);padding:var(--space-6);width:90%;max-width:420px;animation:modalIn .2s var(--ease-out)}@keyframes modalIn{0%{opacity:0;transform:scale(.95)translateY(8px)}to{opacity:1;transform:scale(1)translateY(0)}}.modal h3{font-size:var(--size-500);color:var(--color-text);margin-bottom:var(--space-3);font-weight:600}.modal p{color:var(--color-text-muted);margin-bottom:var(--space-6);font-size:14px;line-height:1.5}.modal .modal-actions{gap:var(--space-2);justify-content:flex-end;display:flex}.modal .btn{border-radius:var(--radius-md);padding:var(--space-2) var(--space-4);cursor:pointer;font-size:13px;font-family:var(--font-body);transition:background var(--duration-fast) var(--ease-out), transform var(--duration-fast) var(--ease-out);border:none;font-weight:500}.modal .btn:active{transform:translateY(1px)}.modal .btn-secondary{background:var(--color-border);color:var(--color-text-muted)}.modal .btn-secondary:hover{background:var(--color-border-strong)}.modal .btn-danger{color:#fff;background:oklch(45% .2 25)}.modal .btn-danger:hover{background:oklch(40% .2 25)}.modal .btn-primary{background:var(--color-accent-hover);color:#fff}.modal .btn-primary:hover{background:var(--brand-600)}.toast{background:var(--color-surface-raised);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-3) var(--space-6);z-index:500;animation:toastIn .25s var(--ease-out);cursor:pointer;font-size:13px;font-family:var(--font-body);position:fixed;bottom:24px;right:24px}.toast.error{border-color:var(--color-invalid);color:oklch(80% .12 25)}.toast.success{border-color:var(--color-valid);color:oklch(80% .12 150)}@keyframes toastIn{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.did-editor-row{gap:var(--space-2);margin-bottom:var(--space-2);align-items:center;display:flex}.did-editor-row input,.did-editor-row select{flex:1}.reorder-btn{color:var(--color-text-subtle);cursor:pointer;transition:color var(--duration-fast) var(--ease-out);background:0 0;border:none;padding:2px 6px;font-size:16px}.reorder-btn:hover{color:var(--color-text)}.preview-result{gap:var(--space-2);padding:6px 0;font-size:13px;display:flex}.preview-match{color:var(--color-valid)}.preview-missing{color:var(--color-invalid)}.watch-item{padding:var(--space-3) 0;border-bottom:1px solid var(--color-border);justify-content:space-between;align-items:center;display:flex}.watch-item:last-child{border-bottom:none}:focus-visible{outline:2px solid var(--color-accent);outline-offset:2px}@media (prefers-reduced-motion:reduce){*,:before,:after{transition-duration:.01ms!important;animation-duration:.01ms!important;animation-iteration-count:1!important}}@keyframes fadeUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.grid>.card{animation:fadeUp .4s var(--ease-out) both}.grid>.card:first-child{animation-delay:0s}.grid>.card:nth-child(2){animation-delay:60ms}.grid>.card:nth-child(3){animation-delay:.12s}.grid>.card:nth-child(4){animation-delay:.18s}
