/*! tailwindcss v4.2.0 | MIT License | https://tailwindcss.com */
@layer properties{@supports (((-webkit-hyphens:none)) and (not (margin-trim:inline))) or ((-moz-orient:inline) and (not (color:rgb(from red r g b)))){*,:before,:after,::backdrop{--tw-translate-x:0;--tw-translate-y:0;--tw-translate-z:0;--tw-rotate-x:initial;--tw-rotate-y:initial;--tw-rotate-z:initial;--tw-skew-x:initial;--tw-skew-y:initial;--tw-space-y-reverse:0;--tw-border-style:solid;--tw-leading:initial;--tw-font-weight:initial;--tw-shadow:0 0 #0000;--tw-shadow-color:initial;--tw-shadow-alpha:100%;--tw-inset-shadow:0 0 #0000;--tw-inset-shadow-color:initial;--tw-inset-shadow-alpha:100%;--tw-ring-color:initial;--tw-ring-shadow:0 0 #0000;--tw-inset-ring-color:initial;--tw-inset-ring-shadow:0 0 #0000;--tw-ring-inset:initial;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-offset-shadow:0 0 #0000;--tw-outline-style:solid}}}@layer theme{:root,:host{--font-sans:ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji";--font-mono:"Fira Code", monospace;--color-red-600:oklch(57.7% .245 27.325);--color-blue-600:oklch(54.6% .245 262.881);--spacing:.25rem;--container-sm:24rem;--container-lg:32rem;--container-2xl:42rem;--container-4xl:56rem;--container-7xl:80rem;--text-xs:.75rem;--text-xs--line-height:calc(1 / .75);--text-sm:.875rem;--text-sm--line-height:calc(1.25 / .875);--text-base:1rem;--text-base--line-height:calc(1.5 / 1);--text-lg:1.125rem;--text-lg--line-height:calc(1.75 / 1.125);--font-weight-medium:500;--font-weight-semibold:600;--radius-md:.375rem;--radius-lg:.5rem;--animate-spin:spin 1s linear infinite;--default-transition-duration:.15s;--default-transition-timing-function:cubic-bezier(.4, 0, .2, 1);--default-font-family:var(--font-sans);--default-mono-font-family:var(--font-mono);--color-bg:#1a1614;--color-bg-warm:#211e1a;--color-bg-card:#2a2520;--color-bg-card-hover:#322d27;--color-copper:#c87533;--color-copper-light:#d4915a;--color-copper-dim:#c875331f;--color-cream:#e8ddd0;--color-text:#e8ddd0;--color-text-muted:#9a8e80;--color-text-faint:#6a6058;--color-border:#3a342e;--color-green-vu:#4ade80;--color-yellow-vu:#fbbf24;--color-red-vu:#ef4444;--color-led-display:#1a2a1a;--color-led-text:#3f6}}@layer base{*,:after,:before,::backdrop{box-sizing:border-box;border:0 solid;margin:0;padding:0}::file-selector-button{box-sizing:border-box;border:0 solid;margin:0;padding:0}html,:host{-webkit-text-size-adjust:100%;tab-size:4;line-height:1.5;font-family:var(--default-font-family,ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji");font-feature-settings:var(--default-font-feature-settings,normal);font-variation-settings:var(--default-font-variation-settings,normal);-webkit-tap-highlight-color:transparent}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:var(--default-mono-font-family,ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace);font-feature-settings:var(--default-mono-font-feature-settings,normal);font-variation-settings:var(--default-mono-font-variation-settings,normal);font-size:1em}small{font-size:80%}sub,sup{vertical-align:baseline;font-size:75%;line-height:0;position:relative}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}:-moz-focusring{outline:auto}progress{vertical-align:baseline}summary{display:list-item}ol,ul,menu{list-style:none}img,svg,video,canvas,audio,iframe,embed,object{vertical-align:middle;display:block}img,video{max-width:100%;height:auto}button,input,select,optgroup,textarea{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}::file-selector-button{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}:where(select:is([multiple],[size])) optgroup{font-weight:bolder}:where(select:is([multiple],[size])) optgroup option{padding-inline-start:20px}::file-selector-button{margin-inline-end:4px}::placeholder{opacity:1}@supports (not ((-webkit-appearance:-apple-pay-button))) or (contain-intrinsic-size:1px){::placeholder{color:currentColor}@supports (color:color-mix(in lab, red, red)){::placeholder{color:color-mix(in oklab, currentcolor 50%, transparent)}}}textarea{resize:vertical}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-date-and-time-value{min-height:1lh;text-align:inherit}::-webkit-datetime-edit{display:inline-flex}::-webkit-datetime-edit-fields-wrapper{padding:0}::-webkit-datetime-edit{padding-block:0}::-webkit-datetime-edit-year-field{padding-block:0}::-webkit-datetime-edit-month-field{padding-block:0}::-webkit-datetime-edit-day-field{padding-block:0}::-webkit-datetime-edit-hour-field{padding-block:0}::-webkit-datetime-edit-minute-field{padding-block:0}::-webkit-datetime-edit-second-field{padding-block:0}::-webkit-datetime-edit-millisecond-field{padding-block:0}::-webkit-datetime-edit-meridiem-field{padding-block:0}::-webkit-calendar-picker-indicator{line-height:1}:-moz-ui-invalid{box-shadow:none}button,input:where([type=button],[type=reset],[type=submit]){appearance:button}::file-selector-button{appearance:button}::-webkit-inner-spin-button{height:auto}::-webkit-outer-spin-button{height:auto}[hidden]:where(:not([hidden=until-found])){display:none!important}html,body{background:var(--color-bg);color:var(--color-text);font-family:"Source Sans 3",sans-serif}h1:focus{outline:none}hr{border-color:var(--color-border);margin:1rem 0}body:before{content:"";opacity:.035;pointer-events:none;z-index:100;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");background-size:256px;position:fixed;inset:0}::-webkit-scrollbar{width:5px}::-webkit-scrollbar-track{background:var(--color-bg)}::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:3px}}@layer components{.panel{border:1px solid var(--color-border);background:linear-gradient(#2e2822 0%,#252019 100%);border-radius:.75rem;box-shadow:0 2px 12px #0000004d,inset 0 1px #ffffff08}.label-engraved{text-transform:uppercase;letter-spacing:.15em;color:var(--color-text-faint);text-shadow:0 1px #0009;font-family:Fira Code,monospace;font-size:9px}.screw{background:conic-gradient(from 45deg,#3a342e,#2a2520,#3a342e,#2a2520);border-radius:50%;flex-shrink:0;width:10px;height:10px;position:relative;box-shadow:inset 0 0 2px #00000080,0 1px #ffffff08}.screw:after{content:"";background:#0006;border-radius:1px;width:6px;height:1.5px;position:absolute;top:4px;left:2px;transform:rotate(35deg)}.led{border:1px solid #0000004d;border-radius:50%;flex-shrink:0;width:8px;height:8px}.led-green{background:radial-gradient(circle at 35% 35%,#6fff9a,#22c55e 60%,#166534);box-shadow:0 0 6px #4ade8080}.led-yellow{background:radial-gradient(circle at 35% 35%,#fde68a,#fbbf24 60%,#92400e);box-shadow:0 0 6px #fbbf2480}.led-red{background:radial-gradient(circle at 35% 35%,#fca5a5,#ef4444 60%,#7f1d1d);box-shadow:0 0 6px #ef444480}.led-copper{background:radial-gradient(circle at 35% 35%,#d4915a,#c87533 60%,#7c4820);box-shadow:0 0 6px #c8753380}.led-off{background:radial-gradient(circle at 35% 35%,#2a2520,#1a1614)}.knob{width:48px;height:48px;box-shadow:0 2px 6px #00000080, 0 0 0 3px #1a1614, 0 0 0 4px var(--color-border), inset 0 1px 1px #ffffff0f;background:linear-gradient(145deg,#3a342e,#22201c);border-radius:50%;flex-shrink:0;position:relative}.knob-indicator{background:var(--color-copper);transform-origin:bottom;border-radius:1px;width:2px;height:10px;position:absolute;top:6px;left:50%;transform:translate(-50%);box-shadow:0 0 4px #c8753366}.vu-meter{background:#111;border-radius:3px;height:8px;overflow:hidden;box-shadow:inset 0 1px 3px #0009}.vu-fill{border-radius:3px;height:100%;transition:width .3s}.vu-green{background:linear-gradient(90deg,#22c55e,#4ade80);box-shadow:0 0 4px #4ade8040}.vu-yellow{background:linear-gradient(90deg,#22c55e 60%,#fbbf24 90%);box-shadow:0 0 4px #fbbf2440}.vu-red{background:linear-gradient(90deg,#22c55e 50%,#fbbf24 75%,#ef4444 95%);box-shadow:0 0 4px #ef444440}.led-ladder{align-items:flex-end;gap:2px;display:flex}.led-seg{background:#1a1614;border-radius:1px;width:4px;height:10px;box-shadow:inset 0 1px 2px #0006}.led-seg.lit-green{background:#22c55e;box-shadow:0 0 3px #22c55e66}.led-seg.lit-yellow{background:#fbbf24;box-shadow:0 0 3px #fbbf2466}.led-seg.lit-red{background:#ef4444;box-shadow:0 0 3px #ef444466}.led-display{background:var(--color-led-display);color:var(--color-led-text);text-shadow:0 0 8px #3f66;border:1px solid #0f1a0f;border-radius:4px;padding:2px 8px;font-family:Share Tech Mono,monospace;box-shadow:inset 0 2px 6px #0009,0 1px #ffffff08}.stomp-btn{box-shadow:0 3px 6px #00000080, 0 0 0 1px var(--color-border), inset 0 1px 0 #ffffff0f;cursor:pointer;color:var(--color-text-muted);background:linear-gradient(#3a342e 0%,#2a2520 50%,#1e1b17 100%);border:2px solid #1a1614;border-radius:6px;transition:all .1s}.stomp-btn:hover{background:linear-gradient(#44382e 0%,#342c24 50%,#24201a 100%)}.stomp-btn:active{box-shadow:0 1px 2px #00000080, 0 0 0 1px var(--color-border), inset 0 2px 4px #0000004d;transform:translateY(1px)}.stomp-btn.engaged{box-shadow:0 1px 2px #00000080, 0 0 0 1px var(--color-border), inset 0 2px 4px #0000004d}.btn-copper{background:linear-gradient(180deg, var(--color-copper-light) 0%, var(--color-copper) 50%, #a5612a 100%);color:#fef3e7;cursor:pointer;border:none;border-radius:.5rem;justify-content:center;align-items:center;gap:.5rem;padding:.5rem 1.25rem;font-size:.875rem;font-weight:500;transition:all .15s;display:inline-flex;box-shadow:0 2px 6px #c875334d,inset 0 1px #ffffff26}.btn-copper:hover{box-shadow:0 3px 10px #c8753366,inset 0 1px #ffffff26}.btn-copper:disabled{opacity:.5;pointer-events:none}.btn-ghost{border:1px solid var(--color-border);color:var(--color-text-muted);cursor:pointer;background:0 0;border-radius:.5rem;justify-content:center;align-items:center;gap:.5rem;padding:.5rem 1.25rem;font-size:.875rem;transition:all .15s;display:inline-flex}.btn-ghost:hover{border-color:var(--color-copper);color:var(--color-copper)}.btn-ghost:disabled{opacity:.5;pointer-events:none}.share-group{border:1px solid #4ade8066;align-items:stretch;display:inline-flex}@supports (color:color-mix(in lab, red, red)){.share-group{border:1px solid color-mix(in srgb, var(--color-green-vu) 40%, transparent)}}.share-group{border-radius:.5rem;overflow:hidden}.share-group-main{color:var(--color-green-vu);cursor:pointer;white-space:nowrap;background:0 0;border:none;padding:.25rem .5rem;font-size:.75rem}.share-group-action{background:0 0;border:none;border-left:1px solid #4ade8040}@supports (color:color-mix(in lab, red, red)){.share-group-action{border-left:1px solid color-mix(in srgb, var(--color-green-vu) 25%, transparent)}}.share-group-action{color:var(--color-text-faint);cursor:pointer;align-items:center;padding:.25rem .4rem;display:flex}.share-group-action:hover{color:var(--color-green-vu);background:#4ade8014}@supports (color:color-mix(in lab, red, red)){.share-group-action:hover{background:color-mix(in srgb, var(--color-green-vu) 8%, transparent)}}.share-group-revoke:hover{color:var(--color-red-vu);background:#ef444414}@supports (color:color-mix(in lab, red, red)){.share-group-revoke:hover{background:color-mix(in srgb, var(--color-red-vu) 8%, transparent)}}.share-group-sm .share-group-main{padding:.125rem .35rem;font-size:.625rem}.share-group-sm .share-group-action{padding:.125rem .3rem}.btn{border-radius:var(--radius-md);padding-inline:calc(var(--spacing) * 4);padding-block:calc(var(--spacing) * 2);font-size:var(--text-sm);line-height:var(--tw-leading,var(--text-sm--line-height));--tw-font-weight:var(--font-weight-medium);font-weight:var(--font-weight-medium);transition-property:color,background-color,border-color,outline-color,text-decoration-color,fill,stroke,--tw-gradient-from,--tw-gradient-via,--tw-gradient-to;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration));justify-content:center;align-items:center;display:inline-flex}.btn:focus{--tw-outline-style:none;outline-style:none}.btn:disabled{pointer-events:none;opacity:.5}.btn{cursor:pointer}.btn-primary{background:linear-gradient(180deg, var(--color-copper-light) 0%, var(--color-copper) 50%, #a5612a 100%);color:#fef3e7;box-shadow:0 2px 6px #c875334d,inset 0 1px #ffffff26}.btn-primary:hover{box-shadow:0 3px 10px #c8753366,inset 0 1px #ffffff26}.btn-outline-primary{border:1px solid var(--color-copper);color:var(--color-copper);background:0 0}.btn-outline-primary:hover{background:var(--color-copper);color:#fef3e7}.btn-outline-secondary{border:1px solid var(--color-border);color:var(--color-text-muted);background:0 0}.btn-outline-secondary:hover{border-color:var(--color-copper);color:var(--color-copper)}.btn-success{background:linear-gradient(180deg, var(--color-copper-light) 0%, var(--color-copper) 50%, #a5612a 100%);color:#fef3e7;box-shadow:0 2px 6px #c875334d}.btn-outline-success{border:1px solid var(--color-border);color:var(--color-text-muted);background:0 0}.btn-outline-success:hover{border-color:var(--color-copper);color:var(--color-copper)}.btn-danger{color:#fff;background:linear-gradient(#ef5555 0%,#dc2626 50%,#b91c1c 100%)}.btn-outline-danger{border:1px solid var(--color-border);color:var(--color-text-muted);background:0 0}.btn-outline-danger:hover{color:#ef4444;border-color:#ef4444}.btn-warning{color:#1a1614;background:linear-gradient(#fbbf24 0%,#d97706 100%)}.btn-link{color:var(--color-copper);background:0 0;border:0;padding:0}.btn-link:hover{color:var(--color-copper-light);text-decoration:underline}.btn-close{height:calc(var(--spacing) * 8);width:calc(var(--spacing) * 8);border-radius:var(--radius-md);color:var(--color-text-muted);justify-content:center;align-items:center;display:inline-flex}.btn-close:hover{color:var(--color-text)}.btn-sm{padding-inline:calc(var(--spacing) * 3);padding-block:calc(var(--spacing) * 1.5);font-size:var(--text-xs);line-height:var(--tw-leading,var(--text-xs--line-height))}.btn-lg{padding-inline:calc(var(--spacing) * 6);padding-block:calc(var(--spacing) * 3);font-size:var(--text-base);line-height:var(--tw-leading,var(--text-base--line-height))}.card{border:1px solid var(--color-border);background:linear-gradient(#2e2822 0%,#252019 100%);border-radius:.75rem;box-shadow:0 2px 12px #0000004d,inset 0 1px #ffffff08}.card-header{border-bottom:1px solid var(--color-border);text-transform:uppercase;letter-spacing:.15em;color:var(--color-copper);text-shadow:0 1px #0009;background:0 0;border-radius:.75rem .75rem 0 0;padding:.75rem 1rem;font-family:Fira Code,monospace;font-size:9px}.card-body{padding:1rem}.card-title{color:var(--color-text);font-size:1rem;font-weight:600}.card-text{color:var(--color-text-muted)}.alert{border:1px solid var(--color-border);background:var(--color-bg-card);color:var(--color-text);border-radius:.5rem;padding:1rem;font-size:.875rem}.alert-danger{color:#fca5a5;background:#ef444414;border-color:#ef44444d}.alert-warning{color:#fde68a;background:#fbbf2414;border-color:#fbbf244d}.alert-success{color:#86efac;background:#4ade8014;border-color:#4ade804d}.alert-info{color:var(--color-copper-light);background:#c8753314;border-color:#c875334d}.badge{padding-inline:calc(var(--spacing) * 2.5);padding-block:calc(var(--spacing) * .5);font-size:var(--text-xs);line-height:var(--tw-leading,var(--text-xs--line-height));--tw-font-weight:var(--font-weight-medium);font-weight:var(--font-weight-medium);border-radius:3.40282e38px;align-items:center;display:inline-flex}.badge.bg-primary{background:var(--color-copper-dim);color:var(--color-copper)}.badge.bg-secondary{color:var(--color-text-muted);background:#ffffff0d}.badge.bg-success{color:var(--color-green-vu);background:#4ade801a}.badge.bg-danger{color:var(--color-red-vu);background:#ef44441a}.badge.bg-warning{color:var(--color-yellow-vu);background:#fbbf241a}.form-control{background:var(--color-bg);border:1px solid var(--color-border);width:100%;color:var(--color-text);border-radius:.5rem;outline:none;padding:.5rem .75rem;font-size:.875rem;transition:border-color .15s;display:block}.form-control::placeholder{color:var(--color-text-faint)}.form-control:focus{border-color:var(--color-copper);box-shadow:0 0 0 2px #c8753333}.form-control:disabled{opacity:.5;background:var(--color-bg-warm)}.form-select{background:var(--color-bg);border:1px solid var(--color-border);width:100%;color:var(--color-text);appearance:none;cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg width='10' height='6' viewBox='0 0 10 6' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1L5 5L9 1' stroke='%239a8e80' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");background-position:right 12px center;background-repeat:no-repeat;border-radius:.5rem;outline:none;padding:.5rem 2.5rem .5rem .75rem;font-size:.875rem;display:block}.form-select:focus{border-color:var(--color-copper);box-shadow:0 0 0 2px #c8753333}.form-label{text-transform:uppercase;letter-spacing:.15em;color:var(--color-text-faint);text-shadow:0 1px #0009;margin-bottom:.375rem;font-family:Fira Code,monospace;font-size:9px;display:block}.form-text{color:var(--color-text-faint);margin-top:.25rem;font-size:.75rem}.form-floating{position:relative}.form-floating>.form-control{padding-top:1.5rem;padding-bottom:.5rem}.form-floating>label{color:var(--color-text-faint);pointer-events:none;transform-origin:0 0;padding:.5rem .75rem;font-size:.875rem;transition:all .15s;position:absolute;top:0;left:0}.form-floating>.form-control:focus~label,.form-floating>.form-control:not(:placeholder-shown)~label{color:var(--color-copper);font-size:.75rem;transform:translateY(-.125rem)}.form-check-input{height:calc(var(--spacing) * 4);width:calc(var(--spacing) * 4);border-color:var(--color-border);accent-color:var(--color-copper);border-radius:.25rem}.form-range{appearance:none;cursor:pointer;background:#111;border-radius:2px;outline:none;width:100%;height:4px;box-shadow:inset 0 1px 2px #00000080}.form-range::-webkit-slider-thumb{-webkit-appearance:none;border:2px solid var(--color-copper);cursor:pointer;background:linear-gradient(145deg,#4a4038,#2a2520);border-radius:50%;width:16px;height:16px;box-shadow:0 1px 4px #00000080}.form-range::-moz-range-thumb{border:2px solid var(--color-copper);cursor:pointer;background:linear-gradient(145deg,#4a4038,#2a2520);border-radius:50%;width:16px;height:16px;box-shadow:0 1px 4px #00000080}.input-group{display:flex}.input-group>.form-control{border-top-right-radius:0;border-bottom-right-radius:0}.input-group>.btn{border-left:0;border-top-left-radius:0;border-bottom-left-radius:0}.input-group-text{background:var(--color-bg-card);border:1px solid var(--color-border);color:var(--color-text-muted);align-items:center;padding:0 .75rem;font-size:.875rem;display:flex}.valid.modified:not([type=checkbox]){outline:1px solid var(--color-green-vu)}.invalid{outline:1px solid var(--color-red-vu)}.validation-message{color:var(--color-red-vu);margin-top:.25rem;font-size:.75rem}.table{border-collapse:collapse;text-align:left;width:100%;font-size:var(--text-sm);line-height:var(--tw-leading,var(--text-sm--line-height));color:var(--color-text)}.table tbody tr{border-bottom:1px solid var(--color-border)}.table td{padding-inline:calc(var(--spacing) * 4);padding-block:calc(var(--spacing) * 3)}.list-group{border-color:var(--color-border)}.list-group-flush{border:0;border-radius:0}.list-group-item{border-bottom:1px solid var(--color-border);background:0 0;padding:.75rem 1rem}.list-group-item:last-child{border-bottom:0}.progress{background:#111;border-radius:3px;width:100%;overflow:hidden;box-shadow:inset 0 1px 3px #0009}.progress-bar{background:linear-gradient(90deg,#22c55e 60%,#fbbf24 90%);border-radius:3px;height:100%;transition:width .3s;box-shadow:0 0 4px #fbbf2440}.nav-pills{flex-direction:column;display:flex}:where(.nav-pills>:not(:last-child)){--tw-space-y-reverse:0;margin-block-start:calc(calc(var(--spacing) * 1) * var(--tw-space-y-reverse));margin-block-end:calc(calc(var(--spacing) * 1) * calc(1 - var(--tw-space-y-reverse)))}.nav-pills .nav-link{color:var(--color-text-muted);border-radius:.375rem;padding:.5rem .75rem;font-size:.875rem;display:block}.nav-pills .nav-link:hover{background:var(--color-bg-card);color:var(--color-text)}.nav-pills .nav-link.active{background:var(--color-copper);color:#fef3e7}.spinner-border{height:calc(var(--spacing) * 8);width:calc(var(--spacing) * 8);animation:var(--animate-spin);color:var(--color-copper);border:4px solid;border-right-color:#0000;border-radius:3.40282e38px;display:inline-block}.spinner-border-sm{height:calc(var(--spacing) * 4);width:calc(var(--spacing) * 4);border-width:2px}.blazor-error-boundary{color:#fca5a5;background:url(data:image/svg+xml;base64,PHN2ZyB3aWR0aD0iNTYiIGhlaWdodD0iNDkiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyIgeG1sbnM6eGxpbms9Imh0dHA6Ly93d3cudzMub3JnLzE5OTkveGxpbmsiIG92ZXJmbG93PSJoaWRkZW4iPjxkZWZzPjxjbGlwUGF0aCBpZD0iY2xpcDAiPjxyZWN0IHg9IjIzNSIgeT0iNTEiIHdpZHRoPSI1NiIgaGVpZ2h0PSI0OSIvPjwvY2xpcFBhdGg+PC9kZWZzPjxnIGNsaXAtcGF0aD0idXJsKCNjbGlwMCkiIHRyYW5zZm9ybT0idHJhbnNsYXRlKC0yMzUgLTUxKSI+PHBhdGggZD0iTTI2My41MDYgNTFDMjY0LjcxNyA1MSAyNjUuODEzIDUxLjQ4MzcgMjY2LjYwNiA1Mi4yNjU4TDI2Ny4wNTIgNTIuNzk4NyAyNjcuNTM5IDUzLjYyODMgMjkwLjE4NSA5Mi4xODMxIDI5MC41NDUgOTIuNzk1IDI5MC42NTYgOTIuOTk2QzI5MC44NzcgOTMuNTEzIDI5MSA5NC4wODE1IDI5MSA5NC42NzgyIDI5MSA5Ny4wNjUxIDI4OS4wMzggOTkgMjg2LjYxNyA5OUwyNDAuMzgzIDk5QzIzNy45NjMgOTkgMjM2IDk3LjA2NTEgMjM2IDk0LjY3ODIgMjM2IDk0LjM3OTkgMjM2LjAzMSA5NC4wODg2IDIzNi4wODkgOTMuODA3MkwyMzYuMzM4IDkzLjAxNjIgMjM2Ljg1OCA5Mi4xMzE0IDI1OS40NzMgNTMuNjI5NCAyNTkuOTYxIDUyLjc5ODUgMjYwLjQwNyA1Mi4yNjU4QzI2MS4yIDUxLjQ4MzcgMjYyLjI5NiA1MSAyNjMuNTA2IDUxWk0yNjMuNTg2IDY2LjAxODNDMjYwLjczNyA2Ni4wMTgzIDI1OS4zMTMgNjcuMTI0NSAyNTkuMzEzIDY5LjMzNyAyNTkuMzEzIDY5LjYxMDIgMjU5LjMzMiA2OS44NjA4IDI1OS4zNzEgNzAuMDg4N0wyNjEuNzk1IDg0LjAxNjEgMjY1LjM4IDg0LjAxNjEgMjY3LjgyMSA2OS43NDc1QzI2Ny44NiA2OS43MzA5IDI2Ny44NzkgNjkuNTg3NyAyNjcuODc5IDY5LjMxNzkgMjY3Ljg3OSA2Ny4xMTgyIDI2Ni40NDggNjYuMDE4MyAyNjMuNTg2IDY2LjAxODNaTTI2My41NzYgODYuMDU0N0MyNjEuMDQ5IDg2LjA1NDcgMjU5Ljc4NiA4Ny4zMDA1IDI1OS43ODYgODkuNzkyMSAyNTkuNzg2IDkyLjI4MzcgMjYxLjA0OSA5My41Mjk1IDI2My41NzYgOTMuNTI5NSAyNjYuMTE2IDkzLjUyOTUgMjY3LjM4NyA5Mi4yODM3IDI2Ny4zODcgODkuNzkyMSAyNjcuMzg3IDg3LjMwMDUgMjY2LjExNiA4Ni4wNTQ3IDI2My41NzYgODYuMDU0N1oiIGZpbGw9IiNGRkU1MDAiIGZpbGwtcnVsZT0iZXZlbm9kZCIvPjwvZz48L3N2Zz4=) 1rem/1.8rem no-repeat,#7f1d1d;border-radius:.5rem;padding:1rem 1rem 1rem 3.7rem}.blazor-error-boundary:after{content:"An error has occurred."}.player-controls{border:1px solid var(--color-border);background:linear-gradient(#2e2822 0%,#252019 100%);border-radius:.75rem;padding:1.25rem;box-shadow:0 2px 12px #0000004d,inset 0 1px #ffffff08}.time-display{background:var(--color-led-display);color:var(--color-led-text);text-shadow:0 0 8px #3f66;white-space:nowrap;text-align:right;border:1px solid #0f1a0f;border-radius:4px;min-width:6rem;padding:4px 10px;font-family:Share Tech Mono,monospace;font-size:.875rem;box-shadow:inset 0 2px 6px #0009,0 1px #ffffff08}.stem-channels{grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:1rem;display:grid}.stem-channel{border:1px solid var(--color-border);background:linear-gradient(#2e2822 0%,#252019 100%);border-radius:.75rem;padding:1rem;transition:all .2s;box-shadow:0 2px 12px #0000004d,inset 0 1px #ffffff08}.stem-channel.muted{opacity:.4;border-color:#ef444466}.stem-channel.soloed{border-color:#c8753380;box-shadow:0 0 12px #c8753326,0 2px 12px #0000004d,inset 0 1px #ffffff08}.stem-header{margin-bottom:calc(var(--spacing) * 2);justify-content:space-between;align-items:center;display:flex}.stem-name{color:var(--color-text);font-size:.875rem;font-weight:600}.stem-controls{gap:.25rem;display:flex}.stem-controls .btn{border-radius:4px;justify-content:center;align-items:center;width:2rem;height:2rem;padding:0;font-size:.75rem;font-weight:700;display:flex}.stem-volume{align-items:center;gap:.5rem;display:flex}.stem-volume .form-range{flex:1}.volume-label{background:var(--color-led-display);color:var(--color-led-text);text-shadow:0 0 8px #3f66;text-align:right;border:1px solid #0f1a0f;border-radius:3px;min-width:2.5rem;padding:1px 6px;font-family:Share Tech Mono,monospace;font-size:.6875rem}.inst-badge{text-transform:uppercase;letter-spacing:.08em;background:var(--color-copper-dim);color:var(--color-copper);cursor:pointer;-webkit-user-select:none;user-select:none;border:1px solid #c8753340;border-radius:9999px;align-items:center;gap:.25rem;padding:.2rem .6rem;font-family:Fira Code,monospace;font-size:.6875rem;transition:all .15s;display:inline-flex}.inst-badge:hover{background:#c8753333}.inst-badge.active{background:var(--color-copper);color:#fef3e7;border-color:var(--color-copper)}.inst-badge.inactive{color:var(--color-text-faint);border-color:var(--color-border);cursor:default;background:#ffffff08}.inst-badge.inactive:hover{background:#ffffff08}.filter-bar{border-bottom:1px solid var(--color-border);flex-direction:column;gap:.75rem;margin-bottom:1rem;padding-bottom:1rem;display:flex}.filter-chip{text-transform:uppercase;letter-spacing:.08em;color:var(--color-text-faint);border:1px solid var(--color-border);cursor:pointer;-webkit-user-select:none;user-select:none;background:#ffffff08;border-radius:9999px;align-items:center;padding:.2rem .6rem;font-family:Fira Code,monospace;font-size:.6875rem;transition:all .15s;display:inline-flex}.filter-chip:hover{color:var(--color-text-muted);background:#ffffff0f}.filter-chip.active{background:var(--color-copper);color:#fef3e7;border-color:var(--color-copper)}.sub-tab-bar{border-bottom:1px solid var(--color-border);gap:0;margin-bottom:1.25rem;display:flex}.sub-tab{text-transform:uppercase;letter-spacing:.1em;color:var(--color-text-faint);cursor:pointer;background:0 0;border:none;border-bottom:2px solid #0000;padding:.625rem 1.25rem;font-family:Fira Code,monospace;font-size:.75rem;transition:all .15s}.sub-tab:hover{color:var(--color-text-muted)}.sub-tab.active{color:var(--color-copper);border-bottom-color:var(--color-copper)}.practice-entry{border-bottom:1px solid var(--color-border);border-radius:.5rem;padding:.75rem 1rem;transition:background .15s}.practice-entry:last-child{border-bottom:none}.practice-entry:hover{background:var(--color-bg-card-hover)}.diff-badge{text-transform:uppercase;letter-spacing:.08em;border-radius:9999px;align-items:center;gap:.3rem;padding:.15rem .5rem;font-family:Fira Code,monospace;font-size:.625rem;display:inline-flex}.diff-bad{color:var(--color-red-vu);background:#ef44441a}.diff-meh{color:var(--color-yellow-vu);background:#fbbf241a}.diff-good{color:var(--color-green-vu);background:#4ade801a}.diff-nailed{background:var(--color-copper-dim);color:var(--color-copper)}}@layer utilities{.visible{visibility:visible}.sr-only{clip-path:inset(50%);white-space:nowrap;border-width:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}.absolute{position:absolute}.relative{position:relative}.static{position:static}.inset-0{inset:calc(var(--spacing) * 0)}.start{inset-inline-start:var(--spacing)}.end{inset-inline-end:var(--spacing)}.top-1\/2{top:50%}.right-1\.5{right:calc(var(--spacing) * 1.5)}.container{width:100%}@media (min-width:40rem){.container{max-width:40rem}}@media (min-width:48rem){.container{max-width:48rem}}@media (min-width:64rem){.container{max-width:64rem}}@media (min-width:80rem){.container{max-width:80rem}}@media (min-width:96rem){.container{max-width:96rem}}.mx-auto{margin-inline:auto}.my-3{margin-block:calc(var(--spacing) * 3)}.my-4{margin-block:calc(var(--spacing) * 4)}.mt-1{margin-top:calc(var(--spacing) * 1)}.mt-1\.5{margin-top:calc(var(--spacing) * 1.5)}.mt-2{margin-top:calc(var(--spacing) * 2)}.mt-3{margin-top:calc(var(--spacing) * 3)}.mt-4{margin-top:calc(var(--spacing) * 4)}.mt-5{margin-top:calc(var(--spacing) * 5)}.mr-1{margin-right:calc(var(--spacing) * 1)}.mr-2{margin-right:calc(var(--spacing) * 2)}.mb-0{margin-bottom:calc(var(--spacing) * 0)}.mb-0\.5{margin-bottom:calc(var(--spacing) * .5)}.mb-1{margin-bottom:calc(var(--spacing) * 1)}.mb-2{margin-bottom:calc(var(--spacing) * 2)}.mb-3{margin-bottom:calc(var(--spacing) * 3)}.mb-4{margin-bottom:calc(var(--spacing) * 4)}.mb-5{margin-bottom:calc(var(--spacing) * 5)}.mb-6{margin-bottom:calc(var(--spacing) * 6)}.mb-8{margin-bottom:calc(var(--spacing) * 8)}.ml-2{margin-left:calc(var(--spacing) * 2)}.ml-auto{margin-left:auto}.block{display:block}.flex{display:flex}.grid{display:grid}.hidden{display:none}.inline-block{display:inline-block}.inline-flex{display:inline-flex}.table{display:table}.h-4{height:calc(var(--spacing) * 4)}.h-5{height:calc(var(--spacing) * 5)}.h-8{height:calc(var(--spacing) * 8)}.h-px{height:1px}.min-h-screen{min-height:100vh}.w-4{width:calc(var(--spacing) * 4)}.w-5{width:calc(var(--spacing) * 5)}.w-8{width:calc(var(--spacing) * 8)}.w-\[200px\]{width:200px}.w-full{width:100%}.w-px{width:1px}.max-w-2xl{max-width:var(--container-2xl)}.max-w-4xl{max-width:var(--container-4xl)}.max-w-7xl{max-width:var(--container-7xl)}.max-w-lg{max-width:var(--container-lg)}.max-w-sm{max-width:var(--container-sm)}.min-w-0{min-width:calc(var(--spacing) * 0)}.flex-1{flex:1}.flex-shrink{flex-shrink:1}.flex-shrink-0{flex-shrink:0}.-translate-y-1\/2{--tw-translate-y:calc(calc(1 / 2 * 100%) * -1);translate:var(--tw-translate-x) var(--tw-translate-y)}.transform{transform:var(--tw-rotate-x,) var(--tw-rotate-y,) var(--tw-rotate-z,) var(--tw-skew-x,) var(--tw-skew-y,)}.cursor-pointer{cursor:pointer}.resize{resize:both}.grid-cols-1{grid-template-columns:repeat(1,minmax(0,1fr))}.flex-col{flex-direction:column}.flex-wrap{flex-wrap:wrap}.items-center{align-items:center}.items-end{align-items:flex-end}.items-start{align-items:flex-start}.justify-between{justify-content:space-between}.justify-center{justify-content:center}.justify-end{justify-content:flex-end}.gap-0{gap:calc(var(--spacing) * 0)}.gap-0\.5{gap:calc(var(--spacing) * .5)}.gap-1{gap:calc(var(--spacing) * 1)}.gap-1\.5{gap:calc(var(--spacing) * 1.5)}.gap-2{gap:calc(var(--spacing) * 2)}.gap-3{gap:calc(var(--spacing) * 3)}.gap-4{gap:calc(var(--spacing) * 4)}.gap-6{gap:calc(var(--spacing) * 6)}:where(.space-y-2>:not(:last-child)){--tw-space-y-reverse:0;margin-block-start:calc(calc(var(--spacing) * 2) * var(--tw-space-y-reverse));margin-block-end:calc(calc(var(--spacing) * 2) * calc(1 - var(--tw-space-y-reverse)))}:where(.space-y-3>:not(:last-child)){--tw-space-y-reverse:0;margin-block-start:calc(calc(var(--spacing) * 3) * var(--tw-space-y-reverse));margin-block-end:calc(calc(var(--spacing) * 3) * calc(1 - var(--tw-space-y-reverse)))}:where(.space-y-6>:not(:last-child)){--tw-space-y-reverse:0;margin-block-start:calc(calc(var(--spacing) * 6) * var(--tw-space-y-reverse));margin-block-end:calc(calc(var(--spacing) * 6) * calc(1 - var(--tw-space-y-reverse)))}.truncate{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.overflow-x-auto{overflow-x:auto}.overflow-y-auto{overflow-y:auto}.rounded{border-radius:.25rem}.rounded-lg{border-radius:var(--radius-lg)}.rounded-md{border-radius:var(--radius-md)}.border{border-style:var(--tw-border-style);border-width:1px}.border-t{border-top-style:var(--tw-border-style);border-top-width:1px}.border-b{border-bottom-style:var(--tw-border-style);border-bottom-width:1px}.border-none{--tw-border-style:none;border-style:none}.p-3{padding:calc(var(--spacing) * 3)}.p-4{padding:calc(var(--spacing) * 4)}.p-5{padding:calc(var(--spacing) * 5)}.p-6{padding:calc(var(--spacing) * 6)}.px-1{padding-inline:calc(var(--spacing) * 1)}.px-1\.5{padding-inline:calc(var(--spacing) * 1.5)}.px-2{padding-inline:calc(var(--spacing) * 2)}.px-3{padding-inline:calc(var(--spacing) * 3)}.px-4{padding-inline:calc(var(--spacing) * 4)}.px-5{padding-inline:calc(var(--spacing) * 5)}.py-0{padding-block:calc(var(--spacing) * 0)}.py-0\.5{padding-block:calc(var(--spacing) * .5)}.py-1{padding-block:calc(var(--spacing) * 1)}.py-1\.5{padding-block:calc(var(--spacing) * 1.5)}.py-2{padding-block:calc(var(--spacing) * 2)}.py-2\.5{padding-block:calc(var(--spacing) * 2.5)}.py-3{padding-block:calc(var(--spacing) * 3)}.py-4{padding-block:calc(var(--spacing) * 4)}.py-5{padding-block:calc(var(--spacing) * 5)}.py-6{padding-block:calc(var(--spacing) * 6)}.py-8{padding-block:calc(var(--spacing) * 8)}.py-12{padding-block:calc(var(--spacing) * 12)}.pt-3{padding-top:calc(var(--spacing) * 3)}.pt-8{padding-top:calc(var(--spacing) * 8)}.pb-16{padding-bottom:calc(var(--spacing) * 16)}.pb-20{padding-bottom:calc(var(--spacing) * 20)}.text-center{text-align:center}.text-left{text-align:left}.text-right{text-align:right}.text-lg{font-size:var(--text-lg);line-height:var(--tw-leading,var(--text-lg--line-height))}.text-sm{font-size:var(--text-sm);line-height:var(--tw-leading,var(--text-sm--line-height))}.text-xs{font-size:var(--text-xs);line-height:var(--tw-leading,var(--text-xs--line-height))}.text-\[10px\]{font-size:10px}.leading-none{--tw-leading:1;line-height:1}.font-medium{--tw-font-weight:var(--font-weight-medium);font-weight:var(--font-weight-medium)}.font-semibold{--tw-font-weight:var(--font-weight-semibold);font-weight:var(--font-weight-semibold)}.text-nowrap{text-wrap:nowrap}.whitespace-nowrap{white-space:nowrap}.whitespace-pre-wrap{white-space:pre-wrap}.text-blue-600{color:var(--color-blue-600)}.text-red-600{color:var(--color-red-600)}.opacity-0{opacity:0}.shadow{--tw-shadow:0 1px 3px 0 var(--tw-shadow-color,#0000001a), 0 1px 2px -1px var(--tw-shadow-color,#0000001a);box-shadow:var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow)}.ring{--tw-ring-shadow:var(--tw-ring-inset,) 0 0 0 calc(1px + var(--tw-ring-offset-width)) var(--tw-ring-color,currentcolor);box-shadow:var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow)}.outline{outline-style:var(--tw-outline-style);outline-width:1px}.transition{transition-property:color,background-color,border-color,outline-color,text-decoration-color,fill,stroke,--tw-gradient-from,--tw-gradient-via,--tw-gradient-to,opacity,box-shadow,transform,translate,scale,rotate,filter,-webkit-backdrop-filter,backdrop-filter,display,content-visibility,overlay,pointer-events;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.transition-opacity{transition-property:opacity;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}@media (hover:hover){.group-hover\:opacity-100:is(:where(.group):hover *){opacity:1}.hover\:opacity-80:hover{opacity:.8}}.disabled\:opacity-20:disabled{opacity:.2}@media (min-width:40rem){.sm\:flex{display:flex}.sm\:inline{display:inline}.sm\:flex-row{flex-direction:row}.sm\:items-end{align-items:flex-end}.sm\:pt-16{padding-top:calc(var(--spacing) * 16)}}@media (min-width:48rem){.md\:col-span-4{grid-column:span 4/span 4}.md\:col-span-12{grid-column:span 12/span 12}.md\:block{display:block}.md\:hidden{display:none}.md\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.md\:grid-cols-12{grid-template-columns:repeat(12,minmax(0,1fr))}.md\:pb-6{padding-bottom:calc(var(--spacing) * 6)}}@media (min-width:64rem){.lg\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.lg\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.lg\:gap-8{gap:calc(var(--spacing) * 8)}}@media (min-width:80rem){.xl\:col-span-6{grid-column:span 6/span 6}.xl\:grid-cols-12{grid-template-columns:repeat(12,minmax(0,1fr))}}}@keyframes recording-pulse{0%,to{box-shadow:0 0 6px #ef444480}50%{box-shadow:0 0 14px #ef4444e6}}.recording-pulse{animation:1.2s ease-in-out infinite recording-pulse}@media (max-width:576px){.stem-channels{grid-template-columns:repeat(2,1fr)}.stem-controls .btn{width:2.75rem;height:2.75rem;font-size:.875rem}.form-range::-webkit-slider-thumb{width:1.5rem;height:1.5rem}.player-controls .form-range{height:2rem}}@media (max-width:400px){.stem-channels{grid-template-columns:1fr}}@property --tw-translate-x{syntax:"*";inherits:false;initial-value:0}@property --tw-translate-y{syntax:"*";inherits:false;initial-value:0}@property --tw-translate-z{syntax:"*";inherits:false;initial-value:0}@property --tw-rotate-x{syntax:"*";inherits:false}@property --tw-rotate-y{syntax:"*";inherits:false}@property --tw-rotate-z{syntax:"*";inherits:false}@property --tw-skew-x{syntax:"*";inherits:false}@property --tw-skew-y{syntax:"*";inherits:false}@property --tw-space-y-reverse{syntax:"*";inherits:false;initial-value:0}@property --tw-border-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-leading{syntax:"*";inherits:false}@property --tw-font-weight{syntax:"*";inherits:false}@property --tw-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-shadow-color{syntax:"*";inherits:false}@property --tw-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-inset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-shadow-color{syntax:"*";inherits:false}@property --tw-inset-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-ring-color{syntax:"*";inherits:false}@property --tw-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-ring-color{syntax:"*";inherits:false}@property --tw-inset-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-ring-inset{syntax:"*";inherits:false}@property --tw-ring-offset-width{syntax:"<length>";inherits:false;initial-value:0}@property --tw-ring-offset-color{syntax:"*";inherits:false;initial-value:#fff}@property --tw-ring-offset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-outline-style{syntax:"*";inherits:false;initial-value:solid}@keyframes spin{to{transform:rotate(360deg)}}