@font-face{font-family:Inter;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/2c55a0e60120577a-s.0bjc5tiuqdqro.woff2)format("woff2");unicode-range:U+460-52F,U+1C80-1C8A,U+20B4,U+2DE0-2DFF,U+A640-A69F,U+FE2E-FE2F}@font-face{font-family:Inter;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/9c72aa0f40e4eef8-s.0m6w47a4e5dy9.woff2)format("woff2");unicode-range:U+301,U+400-45F,U+490-491,U+4B0-4B1,U+2116}@font-face{font-family:Inter;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/ad66f9afd8947f86-s.11u06r12fd6v_.woff2)format("woff2");unicode-range:U+1F??}@font-face{font-family:Inter;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/5476f68d60460930-s.0wxq9webf.ew4.woff2)format("woff2");unicode-range:U+370-377,U+37A-37F,U+384-38A,U+38C,U+38E-3A1,U+3A3-3FF}@font-face{font-family:Inter;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/2bbe8d2671613f1f-s.067x_6k0k23tk.woff2)format("woff2");unicode-range:U+102-103,U+110-111,U+128-129,U+168-169,U+1A0-1A1,U+1AF-1B0,U+300-301,U+303-304,U+308-309,U+323,U+329,U+1EA0-1EF9,U+20AB}@font-face{font-family:Inter;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/1bffadaabf893a1e-s.16ipb6fqu393i.woff2)format("woff2");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Inter;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/83afe278b6a6bb3c-s.p.0q-301v4kxxnr.woff2)format("woff2");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Inter Fallback;src:local(Arial);ascent-override:90.44%;descent-override:22.52%;line-gap-override:0.0%;size-adjust:107.12%}.inter_5972bc34-module__OU16Qa__className{font-family:Inter,Inter Fallback;font-style:normal}
@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-rotate-x:initial;--tw-rotate-y:initial;--tw-rotate-z:initial;--tw-skew-x:initial;--tw-skew-y:initial;--tw-border-style:solid;--tw-ordinal:initial;--tw-slashed-zero:initial;--tw-numeric-figure:initial;--tw-numeric-spacing:initial;--tw-numeric-fraction: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;--tw-blur:initial;--tw-brightness:initial;--tw-contrast:initial;--tw-grayscale:initial;--tw-hue-rotate:initial;--tw-invert:initial;--tw-opacity:initial;--tw-saturate:initial;--tw-sepia:initial;--tw-drop-shadow:initial;--tw-drop-shadow-color:initial;--tw-drop-shadow-alpha:100%;--tw-drop-shadow-size:initial;--tw-duration:initial}}}@font-face{font-family:Ivar Soft;src:url(/fonts/IvarSoft-Regular.otf)format("opentype");font-weight:400;font-style:normal;font-display:swap}@font-face{font-family:Ivar Text;src:url(/fonts/IvarText-Regular.woff)format("woff");font-weight:400;font-style:normal;font-display:swap}@font-face{font-family:Ivar Text;src:url(/fonts/IvarText-SemiBold.woff)format("woff");font-weight:600;font-style:normal;font-display:swap}@font-face{font-family:Ivar Text;src:url(/fonts/IvarText-Italic.otf)format("opentype");font-weight:400;font-style:italic;font-display:swap}@font-face{font-family:Maison Neue;src:url(/fonts/MaisonNeue-Bold.woff)format("woff");font-weight:700;font-style:normal;font-display:swap}.\@container{container-type:inline-size}.pointer-events-none{pointer-events:none}.collapse{visibility:collapse}.invisible{visibility:hidden}.visible{visibility:visible}.sr-only{clip:rect(0,0,0,0);white-space:nowrap;border-width:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}.absolute{position:absolute}.fixed{position:fixed}.relative{position:relative}.static{position:static}.sticky{position:sticky}.col-span-full{grid-column:1/-1}.container{width:100%}.mx-auto{margin-inline:auto}.block{display:block}.contents{display:contents}.flex{display:flex}.grid{display:grid}.hidden{display:none}.inline{display:inline}.inline-block{display:inline-block}.inline-flex{display:inline-flex}.table{display:table}.h-full{height:100%}.min-h-screen{min-height:100vh}.w-full{width:100%}.min-w-full{min-width:100%}.flex-1{flex:1}.flex-shrink,.shrink{flex-shrink:1}.grow{flex-grow:1}.transform{transform:var(--tw-rotate-x,)var(--tw-rotate-y,)var(--tw-rotate-z,)var(--tw-skew-x,)var(--tw-skew-y,)}.cursor-not-allowed{cursor:not-allowed}.resize{resize:both}.grid-cols-1{grid-template-columns:repeat(1,minmax(0,1fr))}.grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.flex-col{flex-direction:column}.flex-row{flex-direction:row}.flex-wrap{flex-wrap:wrap}.items-center{align-items:center}.justify-between{justify-content:space-between}.justify-center{justify-content:center}.justify-end{justify-content:flex-end}.justify-start{justify-content:flex-start}.truncate{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.overflow-hidden{overflow:hidden}.overflow-x-auto{overflow-x:auto}.rounded-full{border-radius:3.40282e38px}.border{border-style:var(--tw-border-style);border-width:1px}.border-b-2{border-bottom-style:var(--tw-border-style);border-bottom-width:2px}.text-center{text-align:center}.text-left{text-align:left}.text-right{text-align:right}.whitespace-nowrap{white-space:nowrap}.capitalize{text-transform:capitalize}.lowercase{text-transform:lowercase}.uppercase{text-transform:uppercase}.italic{font-style:italic}.tabular-nums{--tw-numeric-spacing:tabular-nums;font-variant-numeric:var(--tw-ordinal,)var(--tw-slashed-zero,)var(--tw-numeric-figure,)var(--tw-numeric-spacing,)var(--tw-numeric-fraction,)}.underline{text-decoration-line:underline}.opacity-50{opacity:.5}.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}.grayscale{--tw-grayscale:grayscale(100%);filter:var(--tw-blur,)var(--tw-brightness,)var(--tw-contrast,)var(--tw-grayscale,)var(--tw-hue-rotate,)var(--tw-invert,)var(--tw-saturate,)var(--tw-sepia,)var(--tw-drop-shadow,)}.invert{--tw-invert:invert(100%);filter:var(--tw-blur,)var(--tw-brightness,)var(--tw-contrast,)var(--tw-grayscale,)var(--tw-hue-rotate,)var(--tw-invert,)var(--tw-saturate,)var(--tw-sepia,)var(--tw-drop-shadow,)}.filter{filter:var(--tw-blur,)var(--tw-brightness,)var(--tw-contrast,)var(--tw-grayscale,)var(--tw-hue-rotate,)var(--tw-invert,)var(--tw-saturate,)var(--tw-sepia,)var(--tw-drop-shadow,)}.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,visibility,content-visibility,overlay,pointer-events;transition-timing-function:var(--tw-ease,ease);transition-duration:var(--tw-duration,0s)}.transition-all{transition-property:all;transition-timing-function:var(--tw-ease,ease);transition-duration:var(--tw-duration,0s)}.transition-colors{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,ease);transition-duration:var(--tw-duration,0s)}.transition-shadow{transition-property:box-shadow;transition-timing-function:var(--tw-ease,ease);transition-duration:var(--tw-duration,0s)}.duration-200{--tw-duration:.2s;transition-duration:.2s}.select-all{-webkit-user-select:all;user-select:all}.focus\:ring-2:focus{--tw-ring-shadow:var(--tw-ring-inset,)0 0 0 calc(2px + 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)}.focus\:outline-none:focus{--tw-outline-style:none;outline-style:none}:root{--color-warm1:#f8f8f5;--color-warm2:#f6f1e4;--color-warm3:#f7d9b6;--color-warm4:#d49646;--color-warm5:#8c2f00;--color-off-black:#080605;--color-true-black:#000;--color-border:#e0ddd5;--color-line:#08060526;--color-focus:#f7d9b6cc;--color-sage:#6e8268;--color-sage-soft:#c9d0bf;--color-sage-deep:#4f6049;--color-text-secondary:#080605;--color-error:#dc2626;--color-error-hover:#b91c1c;--color-warning:#d97706;--color-success:#059669;--color-info:#0288d1;--color-selection:#2563eb;--color-selection-light:#2563eb1a;--color-selection-medium:#2563eb33;--color-selection-fill:#3b82f64d;--spacing-1:.25rem;--spacing-2:.5rem;--spacing-3:.75rem;--spacing-4:1rem;--spacing-6:1.5rem;--spacing-8:2rem;--spacing-10:2.5rem;--spacing-12:3rem;--text-xs:.875rem;--text-sm:.875rem;--text-base:1rem;--text-lg:1.125rem;--text-xl:1.5rem;--text-2xl:1.625rem;--text-3xl:2rem;--font-display:"Ivar Soft",Georgia,"Times New Roman",serif;--font-body:"Ivar Text",Georgia,"Times New Roman",serif;--font-ui:"Maison Neue",Helvetica,Arial,sans-serif;--track-caps:.05em;--track-caps-lg:.16em;--shadow-sm:0 2px 4px #0000000d;--shadow-md:0 4px 12px #00000026;--shadow-lg:0 8px 24px #0000001f;--shadow-xl:0 12px 32px #0000002e,0 4px 8px #0000001a;--radius-sm:.25rem;--radius-md:.5rem;--radius-lg:1rem;--foreground-rgb:8,6,5;--background-rgb:248,248,245;--button-bg:var(--color-warm2)}*{font-family:var(--font-body);font-weight:400}button:focus-visible,a:focus-visible,[role=button]:focus-visible,select:focus-visible{outline:2px solid var(--color-warm4);outline-offset:2px}html,body{height:100%;color:var(--color-off-black);background-color:#fff;margin:0;padding:0;overflow:hidden}body.files-page,html.files-page{overflow:auto!important}body{color:rgb(var(--foreground-rgb));background:#fff}.form-input{color:var(--color-off-black);border:1px solid var(--color-border);background-color:#fff;border-radius:.25rem;padding:.5rem .75rem;font-family:Georgia,serif;font-size:1rem;transition:all .2s ease-in-out}.form-input:focus{border-color:var(--color-warm4);box-shadow:0 0 0 2px var(--color-focus);outline:none}.form-input-error{border-color:var(--color-error);background-color:#dc26260d}.form-label{color:var(--color-off-black);margin-bottom:.5rem;font-family:Georgia,serif;font-size:1rem;font-weight:400;display:block}.form-helper-text{color:var(--color-off-black);margin-top:.25rem;font-family:Georgia,serif;font-size:.875rem;font-style:italic}.sidebar-helper-note{color:var(--color-off-black);margin:4px 0 0;font-family:Georgia,serif;font-size:.875rem;font-style:italic;font-weight:400;line-height:1.4}.weaving-canvas{border:1px solid var(--color-border);background-color:#fff;border-radius:.5rem}.canvas-grid-line{stroke:var(--color-true-black);opacity:.15}.canvas-grid-line-major{stroke:var(--color-true-black);opacity:.4}.canvas-cell-hover{fill:var(--color-warm3);opacity:.6}.canvas-cell-selected{stroke:var(--color-warm4);stroke-width:2px}.canvas-cell-active{stroke:var(--color-warm5);stroke-width:2px}.color-swatch{border:.5px solid var(--color-off-black);cursor:pointer;border-radius:2px;flex-shrink:0;width:22px;min-width:22px;height:22px;min-height:22px;transition:border-color .15s ease-in-out,outline-color .15s ease-in-out,transform .15s ease-in-out;display:inline-block}.color-swatch:hover{border-color:var(--color-sage);transform:scale(1.05)}.color-swatch.selected{outline:2px solid var(--color-sage);outline-offset:1px;border-color:var(--color-off-black)}.color-swatch.empty{border:2px solid var(--color-true-black);background-color:#0000}.color-swatch{position:relative}.color-swatch[aria-label]:before{content:attr(aria-label);text-transform:none;white-space:nowrap;opacity:0;visibility:hidden;z-index:1000;pointer-events:none;border-radius:4px;padding:6px 10px;font-family:Georgia,serif;font-size:16px;font-weight:400;transition:opacity .2s,visibility .2s;position:absolute;bottom:-40px;left:50%;transform:translate(-50%);background-color:var(--color-off-black)!important;color:#fff!important}.color-swatch[aria-label]:after{content:"";opacity:0;visibility:hidden;z-index:1000;pointer-events:none;border:4px solid #0000;transition:opacity .2s,visibility .2s;position:absolute;bottom:-8px;left:50%;transform:translate(-50%);border-bottom-color:var(--color-off-black)!important}.color-swatch[aria-label]:hover:before,.color-swatch[aria-label]:hover:after{opacity:1;visibility:visible}.yarn-color-swatch{border:1px solid var(--color-border);cursor:pointer;border-radius:50%;width:2rem;height:2rem;transition:all .2s ease-in-out;display:inline-block}.yarn-color-swatch:hover{border-color:var(--color-warm4);box-shadow:0 0 0 4px var(--color-focus);transform:scale(1.05)}.yarn-color-swatch{position:relative}.yarn-color-swatch[aria-label]:before{content:attr(aria-label);text-transform:none;white-space:nowrap;opacity:0;visibility:hidden;pointer-events:none;border-radius:4px;padding:6px 10px;font-family:Georgia,serif;font-size:16px;font-weight:400;transition:opacity .2s,visibility .2s;position:absolute;bottom:calc(100% + 12px);left:50%;transform:translate(-50%);background-color:var(--color-off-black)!important;color:#fff!important;z-index:10000!important;background-image:none!important}.yarn-color-swatch[aria-label]:after{content:"";opacity:0;visibility:hidden;pointer-events:none;border:4px solid #0000;transition:opacity .2s,visibility .2s;position:absolute;bottom:-8px;left:50%;transform:translate(-50%);border-bottom-color:var(--color-off-black)!important;z-index:10000!important}.yarn-color-swatch[aria-label]:hover:before,.yarn-color-swatch[aria-label]:hover:after{opacity:1;visibility:visible}button.yarn-color-swatch[aria-label]:before,.yarn-color-swatch[aria-label]:before{background-color:var(--color-off-black)!important;background-image:none!important;background:var(--color-off-black)!important;color:#fff!important;z-index:10000!important}button.yarn-color-swatch[aria-label]:after,.yarn-color-swatch[aria-label]:after{border-bottom-color:var(--color-off-black)!important;z-index:10000!important}.global-btn{letter-spacing:.05em;background-color:var(--color-warm2);cursor:pointer;color:var(--color-off-black);border:none;border-radius:.5rem;margin-right:.75rem;padding:.625rem 1.25rem;font-size:1rem;transition:all .2s ease-in-out;text-transform:uppercase!important;font-family:Helvetica,Arial,sans-serif!important;font-weight:700!important}.global-btn:last-child{margin-right:0}.global-btn:hover{background-color:var(--color-warm3);transform:translateY(-1px)}.global-btn:focus{outline:2px solid var(--color-focus);outline-offset:2px}.global-btn:disabled{opacity:.5;cursor:not-allowed;transform:none}.global-btn-primary{border:none;box-shadow:0 2px 4px #0000001a;background-color:var(--color-off-black)!important;color:var(--color-warm1)!important}.global-btn-primary:hover{transform:translateY(-1px);box-shadow:0 4px 8px #0003;background-color:var(--color-off-black)!important;color:var(--color-warm1)!important}.global-btn-destructive{background-color:var(--color-error);color:#fff;border:none}.global-btn-ghost{background-color:#0000;border:none}.global-btn-ghost:hover{background-color:var(--color-warm3)}.dropdown-menu{border:1px solid var(--color-border);z-index:9999;background:#fff;border-radius:.5rem;min-width:160px;padding:.5rem;position:fixed;box-shadow:0 4px 12px #00000026}.dropdown-menu-item{cursor:pointer;text-align:left;width:100%;font-size:1rem;font-family:var(--font-body);color:var(--color-off-black);background:0 0;border:none;border-radius:.25rem;align-items:center;gap:.5rem;padding:.5rem .75rem;transition:background-color .2s ease-in-out;display:flex}.dropdown-menu-item:hover{background-color:var(--color-warm3)}.file-menu-btn{cursor:pointer;color:var(--color-off-black);font-family:var(--font-display);background:0 0;border:none;border-radius:.5rem;align-items:center;gap:.5rem;padding:.5rem 1rem;font-size:20px;font-weight:400;line-height:1;transition:background-color .2s ease-in-out;display:flex}.file-menu-btn:hover{background-color:var(--color-warm3)}.file-menu-btn:focus{outline:none}.file-menu-btn:focus-visible{outline:2px solid var(--color-warm4);outline-offset:2px}.draft-mode-selector{display:inline-block}.mode-selector-container{align-items:center;gap:.5rem;display:flex}.mode-label{color:var(--color-off-black);text-transform:uppercase;letter-spacing:.05em;font-family:Helvetica,Arial,sans-serif;font-size:1rem;font-weight:700}.mode-select-button{border:1px solid var(--color-border);color:var(--color-off-black);cursor:pointer;background:#fff;border-radius:.25rem;align-items:center;gap:.5rem;min-width:120px;padding:.5rem .75rem;font-family:Georgia,serif;font-size:1rem;transition:background-color .2s ease-in-out;display:flex}.mode-select-button:hover{background-color:var(--color-warm3)}.mode-select-button:focus{outline:none}.mode-select-button:focus-visible{outline:2px solid var(--color-warm4);outline-offset:2px}.dropdown-arrow{font-size:1rem;transition:transform .2s ease-in-out}.mode-select-button[aria-expanded=true] .dropdown-arrow{transform:rotate(180deg)}.btn-destructive{letter-spacing:.05em;color:var(--color-error)!important;text-transform:uppercase!important;background-color:#dc262626!important;font-family:Helvetica,Arial,sans-serif!important;font-weight:700!important}.btn-destructive:hover{background-color:#dc262640!important}.sidebar-menu-btn .fa,.sidebar-menu-btn .fas,.sidebar-menu-btn .far,.sidebar-menu-btn .fal,.sidebar-menu-btn .fab,aside .sidebar-menu-btn .fa,aside .sidebar-menu-btn .fas,aside .sidebar-menu-btn .far,aside .sidebar-menu-btn .fal,aside .sidebar-menu-btn .fab{vertical-align:middle!important;width:1em!important;height:1em!important;font-size:28px!important;display:inline-block!important}.fa,.fas,.far,.fal,.fab{vertical-align:middle;width:1em;min-width:1em;height:1em;min-height:1em;font-size:16px;display:inline-block}.sidebar-menu-btn .fa,.sidebar-menu-btn .fas,.sidebar-menu-btn .far,.sidebar-menu-btn .fal,.sidebar-menu-btn .fab,aside[aria-label=Sidebar\ menu] .fa,aside[aria-label=Sidebar\ menu] .fas,aside[aria-label=Sidebar\ menu] .far,aside[aria-label=Sidebar\ menu] .fal,aside[aria-label=Sidebar\ menu] .fab{min-width:28px!important;min-height:28px!important;font-size:28px!important}.sidebar-icon-button{position:relative}.sidebar-icon-button:before{content:attr(aria-label);background-color:var(--color-off-black);color:#fff;text-transform:none;white-space:nowrap;opacity:0;visibility:hidden;z-index:1000;pointer-events:none;border-radius:4px;padding:6px 10px;font-family:Georgia,serif;font-size:16px;font-weight:400;transition:opacity .2s,visibility .2s;position:absolute;top:50%;left:calc(100% + 12px);transform:translateY(-50%)}.sidebar-icon-button:after{content:"";border:4px solid #0000;border-right-color:var(--color-off-black);opacity:0;visibility:hidden;z-index:1000;pointer-events:none;transition:opacity .2s,visibility .2s;position:absolute;top:50%;left:calc(100% + 4px);transform:translateY(-50%)}.sidebar-icon-button:hover:before,.sidebar-icon-button:hover:after{opacity:1;visibility:visible}.toolbarButton{position:relative}.toolbarButton:before{content:attr(aria-label);background-color:var(--color-off-black);color:#fff;text-transform:none;white-space:nowrap;opacity:0;visibility:hidden;z-index:1000;pointer-events:none;border-radius:4px;padding:6px 10px;font-family:Georgia,serif;font-size:16px;font-weight:400;transition:opacity .2s,visibility .2s;position:absolute;bottom:-40px;left:50%;transform:translate(-50%)}.toolbarButton:after{content:"";border:4px solid #0000;border-bottom-color:var(--color-off-black);opacity:0;visibility:hidden;z-index:1000;pointer-events:none;transition:opacity .2s,visibility .2s;position:absolute;bottom:-8px;left:50%;transform:translate(-50%)}.toolbarButton:hover:before,.toolbarButton:hover:after{opacity:1;visibility:visible}.fa-stack{vertical-align:middle;width:2em;height:2em;line-height:2em}.color-charts-section{flex-direction:column;gap:.75rem;padding:1rem;display:flex}.color-charts-section h4{color:var(--color-off-black);margin:0 0 .5rem;font-family:Georgia,serif;font-size:1.1rem;font-weight:400}.color-charts-section .global-btn{text-align:left;width:100%;margin-bottom:8px}.color-charts-section .global-btn:disabled{opacity:.5;cursor:not-allowed;background-color:var(--color-warm1);color:var(--color-text-secondary)}input[type=file]::file-selector-button{background-color:var(--button-bg);cursor:pointer;border:none;border-radius:4px;margin-right:12px;padding:8px 16px;transition:background-color .2s;text-transform:uppercase!important;font-family:Helvetica,Arial,sans-serif!important;font-weight:700!important}input[type=file]::file-selector-button:hover{background-color:var(--color-warm3)}.app-panel{background-color:var(--color-warm2);color:var(--color-off-black);border-radius:1rem;padding:1.5rem;box-shadow:0 4px 12px #00000014}.app-sidebar{background-color:var(--color-warm2);border-right:1px solid var(--color-border);flex-direction:column;gap:1rem;padding:1.5rem;display:flex}.sidebar-menu-item{color:var(--color-off-black);text-transform:uppercase;letter-spacing:.05em;border-radius:.5rem;align-items:center;gap:.75rem;padding:.75rem 1rem;font-family:Helvetica,Arial,sans-serif;font-weight:700;text-decoration:none;transition:background-color .2s ease-in-out;display:flex}.sidebar-menu-item:hover{background-color:var(--color-warm3)}.sidebar-menu-item.active{background-color:var(--color-warm3);border:1px solid var(--color-warm4)}.sidebar-menu-btn.selected{border:1.5px solid var(--color-true-black);box-sizing:border-box;z-index:1}.sidebar-submenu .sidebar-menu-btn{text-align:left!important;width:200px!important;margin-bottom:0!important;margin-right:0!important}.app-toolbar{align-items:center;gap:0;padding:0;display:flex;background-color:var(--color-warm1)!important;border:none!important;border-bottom:.5px solid var(--color-off-black)!important;box-shadow:none!important}.toolbar-btn{cursor:pointer;width:32px;height:32px;color:var(--color-off-black);font-family:var(--font-display);background:0 0;border:0;border-radius:3px;justify-content:center;align-items:center;margin:0 1px;font-size:18px;transition:background-color .15s;display:inline-flex}.toolbar-btn:hover{background-color:var(--color-warm2)}.toolbar-btn:focus{outline:none}.toolbar-btn:focus-visible{outline:2px solid var(--color-warm4);outline-offset:2px}.toolbar-btn.selected,.toolbar-btn.active{background-color:var(--color-warm3)}.toolbar-btn:active{background-color:var(--color-warm2)}.toolbar-btn:disabled{opacity:.4;cursor:not-allowed}.toolbar-btn:disabled:hover{background-color:#0000}.toolbar-btn svg{width:16px;height:16px}.top-toolbar-btn.selected{border:1.5px solid var(--color-true-black);box-sizing:border-box;z-index:1}.toolbar-btn{position:relative}.toolbar-btn:before{content:attr(aria-label);background-color:var(--color-off-black);color:#fff;text-transform:none;white-space:nowrap;opacity:0;visibility:hidden;z-index:1000;pointer-events:none;border-radius:4px;padding:6px 10px;font-family:Georgia,serif;font-size:16px;font-weight:400;transition:opacity .2s,visibility .2s;position:absolute;bottom:-40px;left:50%;transform:translate(-50%)}.toolbar-btn:after{content:"";border:4px solid #0000;border-bottom-color:var(--color-off-black);opacity:0;visibility:hidden;z-index:1000;pointer-events:none;transition:opacity .2s,visibility .2s;position:absolute;bottom:-8px;left:50%;transform:translate(-50%)}.toolbar-btn:hover:before,.toolbar-btn:hover:after{opacity:1;visibility:visible}.toolbar-btn:disabled:hover:before,.toolbar-btn:disabled:hover:after{opacity:0;visibility:hidden}.sr-only{clip:rect(0,0,0,0);white-space:nowrap;border:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}.app-modal{z-index:1000;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.app-modal-overlay{background-color:#0006;position:absolute;inset:0}.app-modal-content{background:var(--color-warm1);border:.5px solid var(--color-off-black);min-width:320px;max-width:420px;font-family:var(--font-body);color:var(--color-off-black);border-radius:0;flex-direction:column;gap:1.5rem;max-height:90vh;margin:0 auto;padding:2rem 2.5rem;display:flex;position:relative;overflow:hidden auto;box-shadow:0 18px 48px #00000052}.app-modal-small{min-width:280px;max-width:320px;padding:1.5rem 2rem}.app-modal-medium{min-width:320px;max-width:420px;padding:2rem 2.5rem}.app-modal-large{min-width:400px;max-width:95vw;padding:2.5rem 3rem}.app-modal-header{border-bottom:.5px solid var(--color-off-black);background:0 0;justify-content:space-between;align-items:center;margin:-2rem -2.5rem 0;padding:1.5rem 2.5rem 1rem;display:flex}.app-modal-title{font-family:var(--font-display);font-weight:400;font-size:var(--text-2xl);color:var(--color-off-black);letter-spacing:-.01em;margin:0}.app-modal-close-fixed{cursor:pointer;color:var(--color-off-black);opacity:.7;z-index:10;background:0 0;border:0;border-radius:0;justify-content:center;align-items:center;width:28px;height:28px;padding:0;font-size:.875rem;transition:opacity .15s;display:flex;position:absolute;top:1rem;right:1rem}.app-modal-close-fixed:hover{color:var(--color-off-black);opacity:1;background-color:#0000;transform:none}.app-modal-modern .app-modal-content{background:var(--color-warm1);border:1px solid var(--color-true-black);box-shadow:0 12px 32px #0000002e,0 4px 8px #0000001a}.app-modal-modern .app-modal-header{background:var(--color-warm1);background-image:repeating-linear-gradient(0deg,transparent,transparent 24px,#0806051a 24px,#0806051a 26px),repeating-linear-gradient(0deg,transparent,transparent 24px,#0806051a 24px,#0806051a 26px),repeating-linear-gradient(90deg,transparent,transparent 24px,#0806051a 24px,#0806051a 26px),repeating-linear-gradient(90deg,transparent,transparent 24px,#0806051a 24px,#0806051a 26px),var(--color-warm1);background-blend-mode:multiply;opacity:1;background-position:0 0,24px 24px,24px 0,0 24px,0 0;background-size:48px 48px,48px 48px,48px 48px,48px 48px,100%;position:relative}.app-modal-modern .app-modal-header:after{content:"";background-image:repeating-linear-gradient(90deg,#08060533,#08060533 3px,#0000 3px 6px);background-size:12px 3px;height:3px;position:absolute;bottom:0;left:0;right:0}.app-modal-modern .app-modal-title{letter-spacing:.01em;font-weight:500}.app-modal-modern .app-modal-close-fixed{transition:all .2s}.app-modal-modern .app-modal-close-fixed:hover{background-color:#08060514;transform:scale(1.05)}.warp-chart-modal{flex-direction:column;gap:1.5rem;min-width:800px;max-width:100%;min-height:400px;display:flex}.total-ends-display{background-color:var(--color-warm1);text-align:center;color:var(--color-off-black);border-radius:.5rem;padding:.75rem 1rem;font-size:1.1rem}.total-ends-display .preview-info{color:var(--color-off-black);margin-top:.5rem;font-family:Georgia,serif;font-size:.875rem;font-style:italic}.validation-errors{background-color:var(--color-warm1);border:1px solid var(--color-error);color:var(--color-error);border-radius:.5rem;padding:.75rem}.validation-warnings{background-color:#d977060d;border:1px solid #d977064d;border-radius:.5rem;padding:.75rem}.yarn-assignments-section{flex-direction:column;gap:1rem;display:flex}.palette-info{background-color:var(--color-warm1);border:1px solid var(--color-off-black);border-radius:.5rem;margin-bottom:1rem;padding:.75rem}.palette-info p{color:var(--color-off-black);margin:0;font-family:Georgia,serif;font-size:.875rem;font-style:italic}.yarn-assignment-row{background-color:var(--color-warm1);border-radius:.5rem;align-items:center;gap:1rem;padding:.75rem;display:flex}.yarn-letter{min-width:80px}.color-input{border:2px solid var(--color-border);cursor:pointer;border-radius:.25rem;width:40px;height:40px}.color-select{border:1px solid var(--color-border);min-width:120px;color:var(--color-off-black);background-color:#fff;border-radius:.25rem;padding:.5rem}.ends-input{border:1px solid var(--color-border);text-align:center;width:80px;color:var(--color-off-black);border-radius:.25rem;padding:.5rem}.sequence-section{flex-direction:column;gap:0;display:flex}.sequence-grid{background-color:#fff;border:1px solid #000;border-radius:.5rem;overflow-x:auto}.sequence-header{display:none}.yarn-label{background-color:var(--color-warm1);border-right:1px solid #000;align-items:center;gap:.25rem;padding:.25rem .5rem;font-size:1rem;font-weight:500;display:flex}.sequence-input.constrained{background-color:var(--color-warm1);color:var(--color-text-secondary)}.sequence-actions{align-items:center;gap:1rem;display:flex}.sequence-actions .remove-button{background-color:var(--color-error);color:#fff;cursor:pointer;border:none;border-radius:.25rem;align-items:center;gap:.5rem;width:auto;height:auto;padding:.5rem 1rem;font-size:1rem;transition:background-color .2s;display:flex}.sequence-actions .remove-button:hover{background-color:var(--color-error);filter:brightness(.85)}.row-actions{border-right:1px solid var(--color-border);justify-content:center;align-items:center;padding:.5rem;display:flex}.repetitions-section{flex-direction:column;gap:1rem;display:flex}.repetition-row{background-color:var(--color-warm1);border-radius:.5rem;align-items:center;gap:1rem;padding:.75rem;display:flex}.repetition-inputs{flex:1;align-items:center;gap:.5rem;display:flex}.repetition-input{border:1px solid var(--color-border);text-align:center;width:60px;color:var(--color-off-black);border-radius:.25rem;padding:.25rem}.preview-section,.warp-preview{flex-direction:column;gap:1rem;display:flex}.preview-info{color:var(--color-off-black);gap:2rem;font-family:Georgia,serif;font-size:.875rem;font-style:italic;display:flex}.color-bar-preview{background-color:var(--color-warm1);border-radius:.25rem;flex-wrap:wrap;gap:1px;max-height:200px;padding:.5rem;display:flex;overflow-y:auto}.preview-cell{border:1px solid var(--color-border);cursor:pointer;width:12px;height:12px;transition:transform .1s}.preview-cell:hover{z-index:1;transform:scale(1.2)}.preview-error{text-align:center;color:var(--color-text-secondary);font-style:italic}.remove-button{width:32px;height:32px;color:var(--color-text-secondary);cursor:pointer;background-color:#0000;border:none;border-radius:.25rem;justify-content:center;align-items:center;transition:background-color .2s;display:flex}.app-modal-small .app-modal-header{border-bottom:.5px solid var(--color-off-black);background:0 0;margin:-1.5rem -2rem 0;padding:1.25rem 2rem .875rem}.app-modal-large .app-modal-header{border-bottom:.5px solid var(--color-off-black);background:0 0;margin:-2.5rem -3rem 0;padding:1.5rem 3rem 1rem}.app-modal-title{font-size:var(--text-2xl);font-weight:400;font-family:var(--font-display);color:var(--color-off-black);letter-spacing:-.01em;margin:0}.app-modal-body{flex-direction:column;flex:1;gap:1.25rem;padding-top:.25rem;display:flex;overflow-x:auto}.project-info-modal.app-modal-content{background:var(--color-warm2);max-width:540px;overflow:hidden}.yarn-calculator-modal.app-modal-content{background:var(--color-warm2);max-width:600px;overflow:hidden}.yarn-calculator-modal .app-modal-body,.project-info-modal .app-modal-body{min-height:0;padding-right:1rem;overflow:hidden auto}.project-info-modal .form-input{box-sizing:border-box;background:#fff;border:1px solid #08060559;width:100%}.project-info-modal .form-input:focus{border-color:var(--color-off-black);box-shadow:0 0 0 2px var(--color-focus)}.project-info-modal .project-info-tab{color:var(--color-off-black);cursor:pointer;background:0 0;border:none;border-bottom:2px solid #0000;margin-bottom:-1px;padding:.5rem .25rem;font-family:Georgia,serif;font-size:1rem;font-weight:400;transition:border-color .15s}.project-info-modal .project-info-tab:hover:not(.selected){border-bottom-color:var(--color-warm3)}.project-info-modal .project-info-tab.selected{border-bottom-color:var(--color-warm4)}.app-modal-overlay{z-index:-1;position:absolute;inset:0}.modal-input{border:1px solid var(--color-off-black);width:100%;max-width:320px;color:var(--color-off-black);box-sizing:border-box;background:#fff;border-radius:.375rem;margin-top:.5rem;padding:.625rem .75rem;font-family:Georgia,serif;font-size:1rem;transition:border-color .2s}.modal-input:focus{border-color:var(--color-off-black);outline:none;box-shadow:0 0 0 3px #08060526}.modal-button,.modal-button-secondary{background:var(--color-warm2);color:var(--color-off-black);border:1.5px solid var(--color-off-black);text-transform:uppercase;letter-spacing:.05em;cursor:pointer;border-radius:.375rem;padding:.625rem 1.25rem;font-family:Helvetica,Arial,sans-serif;font-size:1rem;font-weight:700;transition:all .15s}.modal-button:hover,.modal-button-secondary:hover{background:var(--color-warm3);color:var(--color-off-black)}.modal-button-primary{border:1.5px solid var(--color-off-black);text-transform:uppercase;letter-spacing:.05em;cursor:pointer;border-radius:.375rem;padding:.625rem 1.25rem;font-family:Helvetica,Arial,sans-serif;font-size:1rem;font-weight:700;transition:all .15s;background:var(--color-off-black)!important;color:var(--color-warm1)!important}.modal-button-primary:hover{transform:translateY(-1px);background:var(--color-warm2)!important;color:var(--color-off-black)!important}.modal-button-ghost{color:var(--color-off-black);border:1.5px solid var(--color-off-black);text-transform:uppercase;letter-spacing:.05em;cursor:pointer;background:0 0;border-radius:.375rem;padding:.625rem 1.25rem;font-family:Helvetica,Arial,sans-serif;font-size:1rem;font-weight:700;transition:all .15s}.modal-button-ghost:hover{background:var(--color-warm3);color:var(--color-off-black)}.modal-button-destructive{border:1.5px solid var(--color-error);text-transform:uppercase;letter-spacing:.05em;cursor:pointer;border-radius:.375rem;padding:.625rem 1.25rem;font-family:Helvetica,Arial,sans-serif;font-size:1rem;font-weight:700;transition:all .15s;background:var(--color-error)!important;color:#fff!important}.modal-button-destructive:hover{background:var(--color-error-hover)!important}.modal-button:disabled,.modal-button-secondary:disabled{background-color:var(--color-warm1);color:var(--color-border);cursor:not-allowed}.modal-button-primary:disabled{background-color:var(--color-border);color:var(--color-warm1);cursor:not-allowed}.modal-button.selected,.modal-button-secondary.selected{background:var(--color-off-black)!important;color:var(--color-warm1)!important;border:1.5px solid var(--color-off-black)!important;outline:none!important}.modal-button.selected:hover,.modal-button-secondary.selected:hover{background:var(--color-off-black)!important;color:var(--color-warm1)!important}.app-modal-content button.modal-button,.app-modal-content button.modal-button-secondary,.app-modal-body button.modal-button,.app-modal-body button.modal-button-secondary{background:var(--color-warm2)!important}.app-modal-content button.modal-button:hover,.app-modal-content button.modal-button-secondary:hover,.app-modal-body button.modal-button:hover,.app-modal-body button.modal-button-secondary:hover{background:var(--color-warm3)!important;color:var(--color-off-black)!important}.app-modal-content button.modal-button-primary,.app-modal-body button.modal-button-primary{background:var(--color-off-black)!important;color:var(--color-warm1)!important}.app-modal-content button.modal-button-primary:hover,.app-modal-body button.modal-button-primary:hover{transform:translateY(-1px);background:var(--color-warm2)!important;color:var(--color-off-black)!important}.app-modal label{text-transform:uppercase;letter-spacing:.03em;color:var(--color-off-black);margin-bottom:.375rem;font-family:Helvetica,Arial,sans-serif;font-size:1rem;font-weight:700;display:block}.app-modal .modal-actions{justify-content:flex-end;gap:1rem;margin-top:1.5rem;display:flex}.draggable-item{cursor:grab;transition:all .2s;position:relative}.draggable-item:active{cursor:grabbing}.draggable-item-over{opacity:.7;transform:scale(1.02)}.drag-drop-zone-before{border-top:3px solid var(--color-warm4);background-color:#d496461a}.drag-drop-zone-after{border-bottom:3px solid var(--color-warm4);background-color:#d496461a}.drag-drop-zone-inside{border:2px dashed var(--color-warm4);background-color:#d496461a;border-radius:8px}.drop-zone{min-height:200px;transition:all .2s}.drop-zone-active{border:2px dashed var(--color-warm4);background-color:#d496460d;border-radius:8px}.upload-drop-zone{border:2px dashed var(--color-border);text-align:center;background-color:var(--color-warm1);border-radius:8px;padding:2rem;transition:all .2s}.upload-drop-zone-active{border-color:var(--color-warm4);background-color:#d496460d}.upload-icon{color:var(--color-text-secondary);margin-bottom:1rem;font-size:3rem}.upload-text{color:var(--color-off-black);margin-bottom:.5rem;font-size:1.1rem}.upload-hint{color:var(--color-off-black);font-family:Georgia,serif;font-size:.875rem;font-style:italic}.upload-browse-button{color:var(--color-warm5);cursor:pointer;font-size:inherit;background:0 0;border:none;text-decoration:underline}.upload-browse-button:hover{color:var(--color-warm4)}.upload-browse-button:disabled{color:var(--color-text-secondary);cursor:not-allowed}.upload-status-list{border-top:1px solid var(--color-border);margin-top:1.5rem;padding-top:1rem}.upload-status-list h4{color:var(--color-off-black);margin-bottom:1rem;font-family:Helvetica,Arial,sans-serif;font-weight:700}.upload-status-item{background-color:var(--color-warm1);border-radius:6px;align-items:center;margin-bottom:.5rem;padding:.75rem;display:flex}.upload-status-pending{border-left:3px solid var(--color-warning)}.upload-status-uploading{border-left:3px solid var(--color-warm4)}.upload-status-success{border-left:3px solid var(--color-success)}.upload-status-error{border-left:3px solid var(--color-error)}.upload-file-icon{color:var(--color-text-secondary);margin-right:.75rem}.upload-file-info{flex:1}.upload-file-name{color:var(--color-off-black);margin-bottom:.25rem;font-weight:500}.upload-progress{align-items:center;gap:.5rem;display:flex}.upload-progress-bar{background-color:var(--color-border);border-radius:2px;flex:1;height:4px;overflow:hidden}.upload-progress-fill{background-color:var(--color-warm4);height:100%;transition:width .3s}.upload-progress-text{color:var(--color-off-black);min-width:3rem;font-family:Georgia,serif;font-size:.875rem;font-style:italic}.upload-error{color:var(--color-error);font-size:1rem}.upload-success{color:var(--color-success);font-size:1rem}.photo-upload-container{flex-direction:column;gap:1rem;display:flex}.photo-upload-button-container{align-items:center;gap:.75rem;display:flex}.photo-upload-button{background:var(--color-warm2);color:var(--color-off-black);cursor:pointer;border:none;border-radius:.25rem;align-items:center;gap:.5rem;padding:.5rem 1rem;font-family:Georgia,serif;font-size:1rem;font-weight:400;transition:background-color .2s ease-in-out;display:flex}.photo-upload-button:disabled{opacity:.5;cursor:not-allowed}.photo-upload-input{display:none}.photo-upload-error{color:var(--color-error);background-color:#dc26261a;border-radius:.25rem;margin-bottom:1rem;padding:.5rem .75rem;font-family:Georgia,serif;font-size:1rem}.photo-grid{grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:1rem;display:grid}.photo-item{border:1px solid var(--color-border);background:var(--color-warm1);border-radius:.5rem;padding:.75rem}.photo-preview{margin-bottom:.5rem}.photo-image{object-fit:cover;border-radius:.25rem;width:100%;height:120px}.photo-info{color:var(--color-off-black);margin-bottom:.5rem;font-family:Georgia,serif;font-size:.875rem;font-style:italic}.photo-name{color:var(--color-off-black);margin-bottom:.25rem;font-family:Georgia,serif;font-weight:400}.photo-name-input{border:1px solid var(--color-border);width:100%;color:var(--color-off-black);background:#fff;border-radius:.25rem;margin-bottom:.5rem;padding:.25rem .5rem;font-family:Georgia,serif;font-size:1rem}.photo-name-input:focus{border-color:var(--color-warm4);box-shadow:0 0 0 2px var(--color-focus);outline:none}.photo-actions{gap:.5rem;display:flex}.photo-remove-button{background:var(--color-warm2);color:var(--color-off-black);cursor:pointer;border:none;border-radius:.25rem;align-items:center;gap:.25rem;padding:.25rem .5rem;font-family:Georgia,serif;font-size:1rem;font-weight:400;transition:background-color .2s ease-in-out;display:flex}.photo-remove-button:hover{background:var(--color-warm3)}.photo-empty-state{text-align:center;color:var(--color-off-black);border:1px dashed var(--color-border);border-radius:.5rem;padding:3rem 1rem}.account-page-container{background:#fff;min-height:100vh}.account-content{max-width:36rem;margin:0 auto;padding:4rem 1.5rem 3rem}.account-title{color:var(--color-off-black);margin:1.5rem 0;font-family:Georgia,serif;font-size:1.25rem;font-weight:400}.account-card-primary{background:var(--color-warm1);border:1px solid var(--color-border);border-radius:1rem;padding:2rem}.account-inner-divider{background:var(--color-border);height:1px;margin:1.5rem 0}.account-section-header{justify-content:space-between;align-items:center;margin-bottom:1rem;display:flex}.account-section-title{color:var(--color-off-black);margin:0 0 .5rem;font-family:Georgia,serif;font-size:1.125rem;font-weight:400}.account-field-group{flex-direction:column;gap:.75rem;display:flex}.account-field{flex-direction:column;gap:.25rem;display:flex}.account-label{text-transform:uppercase;color:var(--color-off-black);letter-spacing:.05em;font-family:Helvetica,Arial,sans-serif;font-size:1rem;font-weight:700}.account-value{color:var(--color-off-black);background:#fff;border-radius:.5rem;margin:0;padding:.5rem .75rem;font-family:Georgia,serif;font-size:1rem}.account-input{border:1px solid var(--color-border);color:var(--color-off-black);background:#fff;border-radius:.5rem;width:100%;padding:.5rem .75rem;font-family:Georgia,serif;font-size:1rem;transition:border-color .2s}.account-input:focus{border-color:var(--color-focus);box-shadow:0 0 0 2px var(--color-focus);outline:none}.account-body-text{color:var(--color-off-black);margin:0;font-family:Georgia,serif;font-size:1rem}.account-note{color:var(--color-off-black);margin:.5rem 0 0;font-family:Georgia,serif;font-size:.875rem;font-style:italic}.account-note-success{color:var(--color-success)}.account-note-warning{color:var(--color-warning)}.account-note-error{color:var(--color-error)}.account-status-row{justify-content:space-between;align-items:center;gap:1rem;display:flex}.account-checkbox-label{color:var(--color-off-black);cursor:pointer;align-items:center;gap:.5rem;font-family:Georgia,serif;font-size:1rem;display:flex}.account-actions{gap:.5rem;margin-top:1rem;display:flex}.account-secondary{flex-direction:column;gap:.25rem;margin-top:2rem;padding:0 .5rem;display:flex}.account-secondary-row{justify-content:space-between;align-items:center;gap:1rem;padding:.75rem 0;display:flex}.account-secondary-title{color:var(--color-off-black);margin:0;font-family:Georgia,serif;font-size:1rem;font-weight:400}.account-secondary-danger{color:var(--color-error)}.account-linked-status{align-items:center;gap:.5rem;display:flex}.account-linked-badge{background:var(--color-off-black);width:1.5rem;height:1.5rem;color:var(--color-warm1);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:.7rem;display:inline-flex}.account-saved-feedback{color:var(--color-off-black);font-family:Georgia,serif;font-size:.875rem;font-style:italic;animation:2s ease-in-out forwards account-fade-in-out}@keyframes account-fade-in-out{0%{opacity:0}15%{opacity:1}70%{opacity:1}to{opacity:0}}.repeat-group-manager{background-color:var(--color-warm1);border-radius:.5rem;margin:1rem 0;padding:1rem}.repeat-group-header h3{color:var(--color-off-black);margin:0}.add-button{background-color:var(--color-off-black);color:var(--color-warm1);cursor:pointer;text-transform:uppercase;letter-spacing:.05em;border:none;border-radius:.5rem;align-items:center;gap:.5rem;padding:.625rem 1.25rem;font-family:Helvetica,Arial,sans-serif;font-size:1rem;font-weight:700;transition:all .2s ease-in-out;display:flex;box-shadow:0 2px 4px #0000001a}.add-button:hover{transform:translateY(-1px);box-shadow:0 4px 8px #0003}.add-repeat-form{border:1px solid var(--color-border);background-color:#fff;border-radius:.375rem;margin-bottom:1rem;padding:1rem}.add-repeat-form h4{color:var(--color-off-black);margin:0 0 1rem}.add-child-form{border:1px solid var(--color-border);background-color:var(--color-warm1);border-radius:.375rem;margin:1rem 0;padding:1rem}.add-child-form h5{color:var(--color-off-black);margin:0 0 1rem;font-size:1rem}.add-repeat-form-content{flex-direction:column;gap:1rem;display:flex}.form-row{flex-direction:column;gap:.5rem;display:flex}.form-row label{color:var(--color-off-black);font-size:1rem;font-weight:500}.form-row input,.form-row select{border:1px solid var(--color-border);border-radius:.375rem;padding:.5rem;font-size:1rem}.form-row input:focus,.form-row select:focus:not(.mode-select){border-color:var(--color-warm4);box-shadow:0 0 0 2px var(--color-focus);outline:none}.form-actions{gap:.5rem;margin-top:1rem;display:flex}.cancel-button{color:var(--color-off-black);border:1.5px solid var(--color-off-black);cursor:pointer;text-transform:uppercase;letter-spacing:.05em;background:0 0;border-radius:.375rem;padding:.625rem 1.25rem;font-family:Helvetica,Arial,sans-serif;font-size:1rem;font-weight:700;transition:all .2s ease-in-out}.cancel-button:hover{background:var(--color-off-black);color:var(--color-warm1)}.validation-errors{background-color:#dc26260d;border:1px solid #dc262633;border-radius:.375rem;margin-bottom:1rem;padding:.75rem}.error-message{color:var(--color-error);margin-bottom:.25rem;font-size:1rem}.error-message:last-child{margin-bottom:0}.validation-warnings{background-color:#d977060d;border:1px solid #d977064d;border-radius:.375rem;margin-bottom:1rem;padding:.75rem}.warning-message{color:var(--color-warning);margin-bottom:.25rem;font-size:1rem}.warning-message:last-child{margin-bottom:0}.repeat-groups-list{flex-direction:column;gap:.5rem;display:flex}.repeat-group-item{background-color:#fff;border-radius:.375rem;padding:1rem;box-shadow:0 1px 3px #0000001a}.repeat-group-header{justify-content:space-between;align-items:center;margin-bottom:.5rem;display:flex}.repeat-group-info{flex-direction:column;gap:.25rem;display:flex}.repeat-group-label{color:var(--color-off-black);font-family:Helvetica,Arial,sans-serif;font-size:1rem;font-weight:700}.repeat-group-range{color:var(--color-off-black);font-family:Georgia,serif;font-size:.875rem;font-style:italic}.repeat-group-actions{gap:.25rem;display:flex}.add-child-button,.edit-button,.remove-button{cursor:pointer;background:0 0;border:none;border-radius:.25rem;justify-content:center;align-items:center;width:1.5rem;height:1.5rem;padding:.25rem;font-size:1rem;display:flex}.add-child-button{color:var(--color-success)}.add-child-button:hover{background-color:var(--color-warm2)}.edit-button{color:var(--color-warm5)}.edit-button:hover{background-color:var(--color-warm1)}.remove-button{color:var(--color-error)}.remove-button:hover{background-color:#dc26260d}.repeat-group-edit-form{background-color:var(--color-warm1);border:1px solid var(--color-border);border-radius:.375rem;margin-top:1rem;padding:1rem}.edit-form-row{flex-direction:column;gap:.5rem;margin-bottom:1rem;display:flex}.edit-form-row:last-child{margin-bottom:0}.edit-form-row label{color:var(--color-off-black);font-size:1rem;font-weight:500}.edit-form-row input{border:1px solid var(--color-border);border-radius:.375rem;padding:.5rem;font-size:1rem}.edit-form-row input:focus{border-color:var(--color-warm4);box-shadow:0 0 0 2px var(--color-focus);outline:none}.no-repeats-message{text-align:center;color:var(--color-text-secondary);background-color:#fff;border:1px dashed #d1d5db;border-radius:.375rem;padding:2rem;font-style:italic}.visual-repeat-manager{background-color:var(--color-warm1);border-radius:.5rem;margin:1rem 0;padding:1rem}.visual-repeat-header{justify-content:space-between;align-items:center;margin-bottom:1rem;display:flex}.visual-repeat-header h4{color:var(--color-off-black);margin:0}.quick-add-button{background-color:var(--color-off-black);color:var(--color-warm1);cursor:pointer;text-transform:uppercase;letter-spacing:.05em;border:none;border-radius:.5rem;align-items:center;gap:.5rem;padding:.625rem 1.25rem;font-family:Helvetica,Arial,sans-serif;font-size:1rem;font-weight:700;transition:all .2s ease-in-out;display:flex;box-shadow:0 2px 4px #0000001a}.quick-add-button:hover{background-color:var(--color-true-black)}.quick-add-form{border:1px solid var(--color-border);background-color:#fff;border-radius:.375rem;margin-bottom:1rem;padding:1rem}.quick-add-row{flex-wrap:wrap;align-items:center;gap:.5rem;display:flex}.quick-add-row label{color:var(--color-off-black);font-size:1rem;font-weight:500}.quick-add-row input{border:1px solid var(--color-border);text-align:center;border-radius:.25rem;padding:.25rem .5rem;font-size:1rem}.quick-add-row input:focus{border-color:var(--color-warm4);box-shadow:0 0 0 2px var(--color-focus);outline:none}.quick-add-row span{color:var(--color-off-black);font-family:Georgia,serif;font-size:.875rem;font-style:italic}.visual-repeat-manager .repeat-groups-list{flex-direction:column;gap:.5rem;display:flex}.visual-repeat-manager .repeat-group-item{cursor:pointer;background-color:#fff;border-radius:.375rem;justify-content:space-between;align-items:center;padding:.75rem;transition:all .2s;display:flex;box-shadow:0 1px 3px #0000001a}.visual-repeat-manager .repeat-group-item:hover{box-shadow:0 2px 6px #00000026}.visual-repeat-manager .repeat-group-info{flex-direction:column;gap:.25rem;display:flex}.visual-repeat-manager .repeat-group-label{color:var(--color-off-black);font-family:Helvetica,Arial,sans-serif;font-size:1rem;font-weight:700}.visual-repeat-manager .repeat-group-range{color:var(--color-off-black);font-family:Georgia,serif;font-size:.875rem;font-style:italic}.visual-repeat-manager .repeat-group-controls{align-items:center;gap:.5rem;display:flex}.repeat-count-input{border:1px solid var(--color-border);text-align:center;border-radius:.25rem;width:60px;padding:.25rem .5rem;font-size:1rem}.repeat-count-input:focus{border-color:var(--color-warm4);box-shadow:0 0 0 2px var(--color-focus);outline:none}.visual-repeat-manager .remove-button{cursor:pointer;color:var(--color-text-secondary);background:0 0;border:none;border-radius:.25rem;justify-content:center;align-items:center;width:1.5rem;height:1.5rem;padding:.25rem;font-size:1rem;display:flex}.visual-repeat-manager .remove-button:hover{background-color:var(--color-warm3)}.sequence-grid{background-color:#fff;border:1px solid #000;border-radius:.5rem;overflow:hidden}.sequence-grid-dynamic{width:auto!important;min-width:auto!important;max-width:none!important}.bracket-overlay{pointer-events:none;z-index:10;position:absolute;top:0;left:0;overflow:visible}.bracket-top,.bracket-left,.bracket-right{stroke:#000;stroke-width:2px;fill:none}.visual-repeat-manager .validation-errors{background-color:#dc26260d;border:1px solid #dc262633;border-radius:.375rem;margin-bottom:1rem;padding:.75rem}.visual-repeat-manager .validation-errors h5{color:#dc2626;margin:0 0 .5rem;font-family:Helvetica,Arial,sans-serif;font-size:1rem;font-weight:700}.visual-repeat-manager .error-message{color:var(--color-error);margin-bottom:.25rem;font-size:1rem}.visual-repeat-manager .error-message:last-child{margin-bottom:0}.sequence-header{background-color:var(--color-warm3);color:var(--color-off-black);z-index:10;border-bottom:1px solid #000;align-items:center;font-family:Helvetica,Arial,sans-serif;font-weight:700;display:grid;position:relative}.header-cell{text-align:center;border-right:1px solid #000;justify-content:center;align-items:center;padding:.125rem;font-size:1rem;display:flex}.header-cell:last-child{border-right:none}.sequence-row{border-bottom:1px solid #000;align-items:center;display:grid}.sequence-row:last-child{border-bottom:none}.yarn-label{color:var(--color-off-black);background-color:var(--color-warm1);border-right:2px solid #000;align-items:center;gap:.5rem;height:100%;padding:.25rem .5rem;font-weight:500;display:flex;position:relative}.yarn-label:after{content:"";z-index:1;background-color:#000;width:2px;position:absolute;top:0;bottom:0;right:-2px}.color-select-cell{background-color:var(--color-warm1);border-right:2px solid #000;align-items:center;gap:.5rem;height:100%;padding:.5rem;display:flex;position:relative}.color-select-cell:after{content:"";z-index:1;background-color:#000;width:2px;position:absolute;top:0;bottom:0;right:-2px}.color-select-cell .color-select{border:1px solid var(--color-border);background-color:#fff;border-radius:.25rem;flex:1;min-width:100px;padding:.25rem;font-size:1rem}.color-select-cell .remove-button{color:var(--color-text-secondary);cursor:pointer;background:0 0;border:none;border-radius:.25rem;justify-content:center;align-items:center;min-width:24px;height:24px;padding:.25rem;display:flex}.color-select-cell .remove-button:hover{background-color:var(--color-warm3);color:#dc2626}.yarn-color-cell{background-color:var(--color-warm1);border-bottom:1px solid #000;border-right:1px solid #000;justify-content:space-between;align-items:center;height:100%;padding:.5rem;display:flex;position:relative}.yarn-color-content{flex:1;align-items:center;gap:.5rem;display:flex}.yarn-color-cell .color-select{border:1px solid var(--color-border);background-color:#fff;border-radius:.25rem;min-width:100px;padding:.25rem;font-size:1rem}.yarn-color-cell .remove-button{color:var(--color-text-secondary);cursor:pointer;background:0 0;border:none;border-radius:.25rem;justify-content:center;align-items:center;min-width:24px;height:24px;margin-left:.5rem;padding:.25rem;display:flex}.yarn-color-cell .remove-button:hover{background-color:var(--color-warm3);color:#dc2626}.yarn-color-cell:last-child{border-bottom:none}.yarn-color-cell:first-child{border-bottom:1px solid #000}.count-input{border-right:1px solid #000;justify-content:center;align-items:center;min-height:40px;padding:.5rem;display:flex;position:relative}.count-input input{margin:0 auto;display:block}.count-input:last-child{border-right:none}.sequence-input{text-align:center;border:1px solid #000;border-radius:.25rem;width:40px;padding:.125rem;font-size:1rem}.sequence-input:focus{border-color:var(--color-warm4);box-shadow:0 0 0 2px var(--color-focus);outline:none}.sequence-input.constrained{border-color:var(--color-text-secondary);background-color:var(--color-warm3)}.count-input.constrained{background-color:var(--color-warm3)}.sequence-actions{gap:.5rem;margin-top:1rem;display:flex}.thread-size-modal{flex-direction:column;gap:1rem;display:flex}okhread-size-modal .thread-section{border:1px solid var(--color-border);background-color:var(--color-warm1);border-radius:8px;padding:1rem}.thread-size-modal .section-heading{color:var(--color-off-black);border-bottom:1px solid #e5e7eb;margin:0 0 1rem;padding-bottom:.5rem;font-family:Georgia,serif;font-size:16px;font-weight:400}.thread-size-modal .form-group{flex-direction:column;gap:.25rem;margin-bottom:1rem;display:flex}.thread-size-modal .form-group:last-child{margin-bottom:0}.thread-size-modal .form-group label{color:var(--color-off-black);font-size:16px;font-weight:400}.thread-size-modal .modal-input{border:1px solid var(--color-border);border-radius:4px;padding:.5rem;font-family:Georgia,serif;font-size:16px}.thread-size-modal .modal-input:focus{border-color:var(--color-warm4);box-shadow:0 0 0 2px var(--color-focus);outline:none}.thread-size-modal .modal-actions{justify-content:flex-end;gap:.5rem;margin-top:1rem;display:flex}.gradation-modal{flex-direction:column;gap:1.5rem;min-width:800px;max-width:100%;min-height:400px;display:flex}.gradation-color-selection{flex-direction:column;gap:1rem;display:flex}.gradation-color-selection h3{color:var(--color-off-black);margin:0 0 .5rem;font-family:Georgia,serif;font-size:16px;font-weight:400}.color-picker-row{background-color:var(--color-warm1);border-radius:.5rem;align-items:center;gap:1rem;padding:.75rem;display:flex}.color-picker{align-items:center;gap:.5rem;display:flex}.color-picker select{border:1px solid var(--color-off-black);background-color:#fff;border-radius:.375rem;padding:.375rem .5rem;font-size:1rem}.thread-count-section{flex-direction:column;gap:.5rem;display:flex}.thread-count-section label{text-transform:uppercase;letter-spacing:.03em;color:var(--color-off-black);font-family:Helvetica,Arial,sans-serif;font-size:.875rem;font-weight:700}.thread-count-section input{border:1px solid var(--color-off-black);border-radius:.375rem;width:120px;padding:.625rem .75rem;font-size:1rem}.thread-count-section input:focus{border-color:var(--color-off-black);outline:none;box-shadow:0 0 0 3px #08060526}.gradation-smoothness-control{flex-direction:column;gap:.5rem;display:flex}.gradation-smoothness-control label{text-transform:uppercase;letter-spacing:.03em;color:var(--color-off-black);font-family:Helvetica,Arial,sans-serif;font-size:.875rem;font-weight:700}.slider-container{flex-direction:column;gap:.25rem;width:80%;max-width:100%;display:flex}.smoothness-slider{background:var(--color-border);-webkit-appearance:none;box-sizing:border-box;border-radius:3px;outline:none;width:100%;max-width:100%;height:6px}.smoothness-slider::-webkit-slider-thumb{appearance:none;background:var(--color-warm4);cursor:pointer;border-radius:50%;width:18px;height:18px}.smoothness-slider::-moz-range-thumb{background:var(--color-warm4);cursor:pointer;border:none;border-radius:50%;width:18px;height:18px}.slider-labels{color:var(--color-text-secondary);justify-content:space-between;width:100%;margin-top:.25rem;font-family:Georgia,serif;font-size:.875rem;font-style:italic;display:flex}.smoothness-value{text-align:center;color:var(--color-off-black);font-size:16px;font-weight:500}.gradation-preview{flex-direction:column;gap:.5rem;display:flex}.gradation-preview label{text-transform:uppercase;letter-spacing:.03em;color:var(--color-off-black);font-family:Helvetica,Arial,sans-serif;font-size:.875rem;font-weight:700}.preview-container{flex-direction:column;gap:.5rem;width:80%;display:flex}.preview-bar{border:1px solid var(--color-border);box-sizing:border-box;border-radius:.25rem;width:100%;display:flex;overflow:hidden}.preview-thread{border-right:1px solid #f3f4f6}.preview-thread:last-child{border-right:none}.preview-info{color:var(--color-off-black);justify-content:space-between;font-family:Georgia,serif;font-size:.875rem;font-style:italic;display:flex}.modal-actions{flex-direction:row;justify-content:flex-end;align-items:center;gap:1rem;margin-top:1rem;display:flex}.apply-button{background:var(--color-off-black);color:var(--color-warm1);text-transform:uppercase;letter-spacing:.05em;cursor:pointer;border:none;border-radius:.5rem;width:auto;min-width:120px;padding:.625rem 1.25rem;font-family:Helvetica,Arial,sans-serif;font-size:1rem;font-weight:700;transition:all .2s ease-in-out;box-shadow:0 2px 4px #0000001a}.apply-button:disabled{opacity:.5;cursor:not-allowed}.apply-button:hover{transform:translateY(-1px);box-shadow:0 4px 8px #0003}.cancel-button{color:var(--color-off-black);border:1.5px solid var(--color-off-black);text-transform:uppercase;letter-spacing:.05em;cursor:pointer;background:0 0;border-radius:.375rem;width:auto;min-width:120px;padding:.625rem 1.25rem;font-family:Helvetica,Arial,sans-serif;font-size:1rem;font-weight:700;transition:all .2s ease-in-out}.add-color{background:var(--color-warm2);color:var(--color-off-black);border:1.5px solid var(--color-off-black);text-transform:uppercase;letter-spacing:.05em;cursor:pointer;border-radius:.375rem;align-self:flex-start;padding:.625rem 1.25rem;font-family:Helvetica,Arial,sans-serif;font-size:1rem;font-weight:700;transition:all .2s ease-in-out}.add-color:hover,.cancel-button:hover{background:var(--color-off-black);color:var(--color-warm1)}.remove-color{background-color:var(--color-error);color:#fff;cursor:pointer;border:none;border-radius:50%;justify-content:center;align-items:center;width:20px;height:20px;font-family:Helvetica,Arial,sans-serif;font-size:16px;font-weight:700;transition:background-color .15s;display:flex}.remove-color:hover{background-color:var(--color-error-hover)}.sidebar-gradation-form{flex-direction:column;gap:0;display:flex;overflow:hidden}.sidebar-gradation-section{border-bottom:1px solid var(--color-border);flex-direction:column;gap:.75rem;padding:.75rem 0;display:flex}.sidebar-gradation-section:last-of-type{border-bottom:none;padding-bottom:0}.sidebar-gradation-form .color-picker-row{flex-direction:column;align-items:stretch;gap:.375rem;padding:.5rem .625rem}.sidebar-gradation-form .color-picker-row>span{font-size:.875rem;font-style:italic}.sidebar-gradation-form .color-picker{gap:.375rem;width:100%}.sidebar-gradation-form .color-swatch{flex-shrink:0;width:22px;height:22px}.sidebar-gradation-form .gradation-color-selection{gap:.375rem}.sidebar-gradation-form .gradation-color-selection h3{margin:0;font-size:1rem}.sidebar-gradation-form .slider-container,.sidebar-gradation-form .preview-container{box-sizing:border-box;width:100%;max-width:100%}.sidebar-gradation-form .thread-count-section input{box-sizing:border-box;width:100%}.sidebar-gradation-form .add-color{padding:.375rem .75rem;font-size:.875rem}.sidebar-gradation-form .remove-color{width:18px;height:18px;font-size:14px}.sidebar-gradation-form .preview-bar{box-sizing:border-box;width:100%}.sidebar-gradation-form .preview-thread{flex:1;min-width:0;width:auto!important}.sidebar-gradation-form .preview-info{flex-direction:column;gap:.125rem}.sidebar-gradation-form .smoothness-value{text-align:left}.sidebar-gradation-form .stripe-width-controls{flex-direction:column;gap:.5rem}.sidebar-gradation-form .width-control input{box-sizing:border-box;width:100%}.sidebar-gradation-form .preview-stripe{flex:1;min-width:0;width:auto!important}.sidebar-gradation-form .preview-statistics{flex-direction:column;gap:.125rem}.sidebar-gradation-form .regenerate-button{width:100%}.palette-color-select{flex:1;min-width:0}.palette-color-select-trigger{border:1px solid var(--color-off-black);cursor:pointer;width:100%;color:var(--color-off-black);text-align:left;background:#fff;border-radius:.25rem;align-items:center;gap:.375rem;min-width:0;padding:.3rem .5rem;font-family:Georgia,serif;font-size:.875rem;font-weight:400;display:flex}.palette-color-select-trigger:hover{border-color:var(--color-off-black);background:var(--color-warm1)}.palette-color-select-trigger:focus-visible{box-shadow:0 0 0 2px var(--color-focus);outline:none}.palette-color-select-swatch{border:1px solid var(--color-border);border-radius:50%;flex-shrink:0;width:14px;height:14px;display:inline-block}.palette-color-select-name{text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0;overflow:hidden}.palette-color-select-chevron{color:var(--color-off-black);flex-shrink:0;font-size:.75rem;line-height:1}.palette-color-select-dropdown{border:1px solid var(--color-off-black);max-height:200px;box-shadow:var(--shadow-md);background:#fff;border-radius:.25rem;overflow-y:auto}.palette-color-select-option{cursor:pointer;width:100%;color:var(--color-off-black);text-align:left;background:0 0;border:none;align-items:center;gap:.375rem;padding:.3rem .5rem;font-family:Georgia,serif;font-size:.875rem;font-weight:400;display:flex}.palette-color-select-option:hover{background:var(--color-warm2)}.palette-color-select-option.selected{background:var(--color-warm1)}.palette-color-select-option:focus-visible{box-shadow:inset 0 0 0 2px var(--color-warm4);outline:none}.random-stripe-modal{flex-direction:column;gap:1.5rem;min-width:800px;max-width:100%;min-height:400px;display:flex}.random-stripe-color-selection{flex-direction:column;gap:1rem;display:flex}.random-stripe-color-selection h3{color:var(--color-off-black);margin:0 0 .5rem;font-family:Georgia,serif;font-size:16px;font-weight:400}.color-picker-grid{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;display:grid}.color-picker-item{background-color:var(--color-warm1);border-radius:.5rem;flex-direction:column;gap:.5rem;padding:.75rem;display:flex}.stripe-configuration-section{background-color:var(--color-warm1);border-radius:.5rem;flex-direction:column;gap:1rem;padding:1rem;display:flex}.stripe-configuration-section h3{color:var(--color-off-black);margin:0 0 .5rem;font-family:Georgia,serif;font-size:16px;font-weight:400}.stripe-count-control,.width-control{flex-direction:column;gap:.5rem;display:flex}.stripe-count-control label,.width-control label{text-transform:uppercase;letter-spacing:.03em;color:var(--color-off-black);font-family:Helvetica,Arial,sans-serif;font-size:.875rem;font-weight:700}.stripe-count-control input,.width-control input{border:1px solid var(--color-off-black);border-radius:.375rem;width:120px;padding:.625rem .75rem;font-size:1rem}.stripe-width-controls{align-items:flex-end;gap:1rem;display:flex}.randomness-control{flex-direction:column;gap:.5rem;display:flex}.randomness-control label{color:var(--color-off-black);font-family:Georgia,serif;font-size:16px;font-weight:400}.randomness-control input[type=range]{width:100%;margin:.5rem 0}.randomness-labels{color:var(--color-off-black);justify-content:space-between;font-family:Georgia,serif;font-size:14px;font-style:italic;display:flex}.mirror-toggle{border:1px solid var(--color-off-black);background-color:#fff;border-radius:.375rem;align-items:center;gap:.5rem;padding:.5rem;display:flex}.mirror-toggle label{text-transform:uppercase;letter-spacing:.03em;color:var(--color-off-black);cursor:pointer;align-items:center;gap:.5rem;font-family:Helvetica,Arial,sans-serif;font-size:.875rem;font-weight:700;display:flex}.mirror-info{color:var(--color-off-black);margin-left:1rem;font-size:.875rem}.seed-control{align-items:center;gap:1rem;display:flex}.seed-control label{text-transform:uppercase;letter-spacing:.03em;color:var(--color-off-black);font-family:Helvetica,Arial,sans-serif;font-size:.875rem;font-weight:700}.seed-control input{border:1px solid var(--color-off-black);border-radius:.375rem;width:150px;padding:.625rem .75rem;font-size:1rem}.new-seed-button,.regenerate-button{background:var(--color-warm2);color:var(--color-off-black);border:1.5px solid var(--color-off-black);text-transform:uppercase;letter-spacing:.05em;cursor:pointer;border-radius:.375rem;padding:.625rem 1.25rem;font-family:Helvetica,Arial,sans-serif;font-size:1rem;font-weight:700;transition:all .2s ease-in-out}.new-seed-button:hover,.regenerate-button:hover{background:var(--color-off-black);color:var(--color-warm1)}.stripe-preview{background-color:var(--color-warm1);border-radius:.5rem;flex-direction:column;gap:1rem;padding:1rem;display:flex}.stripe-preview label{text-transform:uppercase;letter-spacing:.03em;color:var(--color-off-black);margin:0;font-family:Helvetica,Arial,sans-serif;font-size:.875rem;font-weight:700}.preview-container{flex-direction:column;gap:.5rem;display:flex}.preview-bar{border:1px solid var(--color-border);border-radius:.25rem;min-height:20px;display:flex;overflow:hidden}.preview-thread{border-right:1px solid #f3f4f6;transition:border-color .2s;display:inline-block}.preview-thread.stripe-boundary{border-right:1px solid var(--color-off-black)}.preview-thread.mirror-line{border-left:2px dashed var(--color-off-black)}.mirror-line-indicator{color:var(--color-off-black);text-transform:uppercase;align-items:center;gap:.5rem;font-family:Helvetica,Arial,sans-serif;font-size:.875rem;font-weight:700;display:flex}.mirror-line-dashed{background:repeating-linear-gradient(to right,var(--color-off-black)0,var(--color-off-black)4px,transparent 4px,transparent 8px);width:20px;height:2px}.preview-statistics{color:var(--color-off-black);flex-wrap:wrap;gap:1rem;font-family:Georgia,serif;font-size:14px;font-style:italic;display:flex}.mirror-notice{color:var(--color-off-black);font-family:Georgia,serif;font-size:.875rem}.validation-errors{border:1px solid var(--color-error);background-color:#dc26260d;border-radius:.5rem;flex-direction:column;gap:.5rem;padding:1rem;display:flex}.error-message{color:var(--color-error);font-family:Georgia,serif;font-size:16px}.sidebar-icon-button{cursor:pointer;box-sizing:border-box;width:3rem;height:3rem;color:var(--color-off-black);background-color:#0000;border:none;border-radius:.5rem;outline:none;justify-content:center;align-items:center;margin:.75rem 0;padding:.75rem;transition:all .2s ease-in-out;display:flex;text-transform:uppercase!important;font-family:Helvetica,Arial,sans-serif!important;font-weight:700!important}.sidebar-submenu-button{background-color:var(--color-warm1);border:.5px solid var(--color-off-black);cursor:pointer;box-sizing:border-box;width:100%;max-width:100%;height:40px;min-height:40px;color:var(--color-off-black);white-space:nowrap;text-overflow:ellipsis;border-radius:3px;outline:none;justify-content:flex-start;align-items:center;gap:10px;margin:.25rem 0;padding:0 12px;transition:background-color .2s ease-in-out;display:flex;overflow:hidden;font-family:var(--font-ui)!important;text-transform:uppercase!important;letter-spacing:var(--track-caps)!important;text-align:left!important;font-size:11px!important;font-weight:700!important}.sidebar-menu-container{flex-direction:column;gap:4px;width:100%;display:flex}.sidebar-icon-button:hover,.sidebar-submenu-button:hover{background-color:var(--color-warm2)}.sidebar-icon-button.selected{background-color:var(--color-warm2);box-shadow:inset 3px 0 0 var(--color-sage);z-index:1;border:0;border-radius:0}.sidebar-submenu-button.selected{background-color:var(--color-warm3);border:.5px solid var(--color-off-black);z-index:1}.sidebar-submenu-button.selected:hover{background-color:var(--color-warm3)}.sidebar-icon-button:focus{outline:none}.sidebar-icon-button:focus-visible{outline:1.5px solid var(--color-sage);outline-offset:-1px}.sidebar-icon-button:focus:not(:focus-visible){outline:none}@keyframes modal-backdrop-in{0%{opacity:0}to{opacity:1}}@keyframes modal-content-in{0%{opacity:0;transform:scale(.95)translateY(8px)}to{opacity:1;transform:scale(1)translateY(0)}}.app-modal{animation:.15s ease-out modal-backdrop-in;z-index:1000!important;justify-content:center!important;align-items:center!important;width:100vw!important;height:100vh!important;padding:20px!important;display:flex!important;position:fixed!important;inset:0!important}.app-modal-overlay{background-color:#0009!important;width:100%!important;height:100%!important;position:absolute!important;inset:0!important}.app-modal-content{animation:.2s ease-out modal-content-in;background:var(--color-warm1)!important;border:.5px solid var(--color-off-black)!important;z-index:1001!important;border-radius:0!important;flex-direction:column!important;max-height:90vh!important;display:flex!important;position:relative!important;overflow:hidden!important;box-shadow:0 18px 48px #00000052!important}.app-modal-small{width:100%!important;max-width:400px!important}.app-modal-medium{width:100%!important;max-width:600px!important}.app-modal-large{width:100%!important;max-width:800px!important}@keyframes onboarding-fade-up{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.onboarding-stagger{opacity:0;animation:.35s cubic-bezier(.16,1,.3,1) forwards onboarding-fade-up}.onboarding-stagger-1{animation-delay:80ms}.onboarding-stagger-2{animation-delay:.18s}.onboarding-stagger-3{animation-delay:.3s}.onboarding-mode-button{background:var(--color-warm2);border:2px solid var(--color-off-black);cursor:pointer;text-transform:uppercase;letter-spacing:.05em;color:var(--color-off-black);border-radius:2px;flex:1;padding:1.5rem 1.25rem;font-family:Helvetica,Arial,sans-serif;font-size:1rem;font-weight:700;transition:transform .2s cubic-bezier(.16,1,.3,1),background-color .2s,box-shadow .2s}.onboarding-mode-button:hover{background:#fff;transform:translateY(-2px);box-shadow:0 4px 12px #0806051a}.onboarding-mode-button:active{box-shadow:none;transition-duration:60ms;transform:translateY(0)}.onboarding-mode-button:focus{outline:none}.onboarding-mode-button:focus-visible{box-shadow:inset 0 0 0 2px var(--color-warm4);outline:none!important}.onboarding-action-row{text-align:left;cursor:pointer;background:0 0;border:none;border-radius:2px;align-items:baseline;gap:1rem;width:100%;padding:.75rem;transition:background-color .15s,padding-left .2s cubic-bezier(.16,1,.3,1);display:flex}.onboarding-action-row:hover{background-color:var(--color-warm2);padding-left:1rem}.onboarding-action-row:focus{outline:none}.onboarding-action-row:focus-visible{box-shadow:inset 0 0 0 2px var(--color-warm4);outline:none!important}.onboarding-action-row:after{content:"→";color:var(--color-off-black);opacity:0;margin-left:auto;font-family:Helvetica,Arial,sans-serif;font-size:1rem;transition:opacity .15s,transform .2s cubic-bezier(.16,1,.3,1);transform:translate(-4px)}.onboarding-action-row:hover:after{opacity:1;transform:translate(0)}.onboarding-action-label{text-transform:uppercase;letter-spacing:.04em;color:var(--color-off-black);flex-shrink:0;font-family:Helvetica,Arial,sans-serif;font-size:1rem;font-weight:700}.onboarding-action-hint{color:var(--color-off-black);font-family:Georgia,serif;font-size:.875rem;font-style:italic;font-weight:400}.hover-bg-warm3:hover{background-color:var(--color-warm3)}.hover-bg-warm1:hover{background-color:var(--color-warm1)}.hover-bg-subtle:hover{background-color:#0000000a}.hover-bg-error-light:hover{background-color:#fee2e2}.hover-darken:hover{filter:brightness(.9)}.hover-color-offblack:hover{color:var(--color-off-black)}.prominent-feedback-btn{background:var(--color-off-black);color:var(--color-warm1);height:30px;font-family:var(--font-ui);font-weight:700;font-size:var(--text-xs);text-transform:uppercase;letter-spacing:var(--track-caps);cursor:pointer;border:none;border-radius:3px;align-items:center;gap:8px;padding:0 14px;transition:background-color .15s;display:inline-flex}.prominent-feedback-btn:hover{background:#1a1816}.prominent-feedback-btn svg{width:14px;height:14px}.action-icon-button{cursor:pointer;color:var(--color-off-black);background:0 0;border:none;border-radius:4px;padding:4px;transition:background-color .15s}.action-icon-button:hover{background-color:var(--color-warm2)}.action-icon-button:focus-visible{outline:2px solid var(--color-warm4);outline-offset:2px}.filename-display{cursor:text;font-family:var(--font-display);font-size:var(--text-base);color:var(--color-off-black);background:0 0;border:.5px solid #0000;border-radius:3px;padding:4px 8px;transition:background-color .15s,border-color .15s}.filename-display:hover{background-color:var(--color-warm2);border-color:var(--color-line)}.global-btn-destructive{color:var(--color-error)!important}.global-btn-destructive:hover{background-color:#dc262614}.lesson-card:hover{box-shadow:var(--shadow-lg)}@keyframes thread-insertion-highlight{0%{opacity:1}to{opacity:0}}.lesson-browser-card.lesson-card:hover{background-color:var(--color-warm1)!important}.sidebar-close-btn{cursor:pointer;color:var(--color-off-black);background:0 0;border:none;border-radius:4px;justify-content:center;align-items:center;padding:8px;display:flex}.sidebar-close-btn:hover{background-color:var(--color-warm3)}.admin-page-container{background-color:var(--color-warm1);height:100vh;min-height:100vh;padding-top:56px;display:flex;overflow:hidden}.admin-nav{background-color:var(--color-warm2);border-right:1px solid var(--color-border);flex-direction:column;gap:.25rem;width:200px;min-width:200px;height:calc(100vh - 56px);padding:1.5rem .75rem;display:flex;position:sticky;top:56px;overflow-y:auto}.admin-nav-title{color:var(--color-off-black);margin-bottom:1rem;padding:0 .75rem;font-family:Georgia,serif;font-size:1rem;font-weight:400}.admin-nav-item{color:var(--color-off-black);border-left:3px solid #0000;border-radius:.5rem;align-items:center;gap:.75rem;padding:.5rem .75rem;font-family:Georgia,serif;font-size:1rem;font-weight:400;text-decoration:none;transition:background-color .15s ease-in-out;display:flex}.admin-nav-item:hover{background-color:var(--color-warm1)}.admin-nav-item.active{background-color:var(--color-warm1);border-left-color:var(--color-warm4)}.admin-content{flex:1;max-width:1100px;padding:2rem 2rem 2rem 2.5rem;overflow-y:auto}.admin-page-title{color:var(--color-off-black);margin:0 0 2rem;font-family:Georgia,serif;font-size:2rem;font-weight:400}.admin-section-title{color:var(--color-off-black);margin:0 0 1rem;font-family:Georgia,serif;font-size:1.25rem;font-weight:400}.admin-card{border:1px solid var(--color-border);background:#fff;border-radius:1rem;padding:1.5rem;overflow:hidden;box-shadow:0 4px 12px #00000014}.admin-card+.admin-card{margin-top:1.5rem}.admin-card-title{color:var(--color-off-black);margin:0 0 1rem;font-family:Georgia,serif;font-size:1.25rem;font-weight:400}.admin-message{border-left:3px solid var(--color-warm4);color:var(--color-off-black);background:#fff;border-radius:.5rem;margin-bottom:1rem;padding:1rem 1.5rem;font-family:Georgia,serif;font-size:1rem;font-weight:400}.admin-message-error{border-left-color:var(--color-error)}.admin-stat-grid{grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:1rem;display:grid}.admin-stat-card{border:1px solid var(--color-border);text-align:center;background:#fff;border-radius:1rem;padding:1.25rem;box-shadow:0 4px 12px #00000014}.admin-stat-number{color:var(--color-off-black);margin-bottom:.25rem;font-family:Helvetica,Arial,sans-serif;font-size:1.5rem;font-weight:700}.admin-stat-label{color:var(--color-off-black);font-family:Georgia,serif;font-size:1rem;font-weight:400}.admin-table{border-collapse:collapse;width:100%;color:var(--color-off-black);font-family:Georgia,serif;font-size:1rem}.admin-table th{text-align:left;border-bottom:2px solid var(--color-border);text-transform:uppercase;letter-spacing:.05em;color:var(--color-off-black);padding:.75rem;font-family:Helvetica,Arial,sans-serif;font-size:.875rem;font-weight:700}.admin-table td{border-bottom:1px solid var(--color-border);padding:.75rem;font-weight:400}.admin-table tbody tr:hover{background-color:var(--color-warm1)}.admin-quick-link{background-color:var(--color-warm2);border:1px solid var(--color-border);color:var(--color-off-black);text-transform:uppercase;letter-spacing:.05em;border-radius:.5rem;padding:.5rem 1rem;font-family:Helvetica,Arial,sans-serif;font-size:1rem;font-weight:700;text-decoration:none;transition:background-color .15s ease-in-out;display:inline-block}.admin-quick-link:hover{background-color:var(--color-warm3)}.admin-badge{text-transform:uppercase;letter-spacing:.05em;border-radius:.25rem;padding:.125rem .5rem;font-family:Helvetica,Arial,sans-serif;font-size:.875rem;font-weight:700;display:inline-block}.admin-tag{background-color:var(--color-warm2);color:var(--color-off-black);border-radius:.25rem;padding:.125rem .375rem;font-family:Georgia,serif;font-size:.875rem;font-style:italic;font-weight:400;display:inline-block}.admin-data-grid{color:var(--color-off-black);gap:.5rem;font-family:Georgia,serif;font-size:1rem;font-weight:400;display:grid}.admin-search-row{gap:.75rem;display:flex}.admin-actions{flex-wrap:wrap;align-items:center;gap:.5rem;display:flex}.admin-confirm{color:var(--color-off-black);align-items:center;gap:.5rem;font-family:Georgia,serif;font-size:1rem;font-weight:400;display:flex}.admin-note{color:var(--color-off-black);margin-top:.75rem;font-family:Georgia,serif;font-size:.875rem;font-style:italic;font-weight:400}.admin-page-header{justify-content:space-between;align-items:center;margin-bottom:2rem;display:flex}.admin-page-header .admin-page-title{margin-bottom:0}.admin-card a{color:var(--color-warm5);text-decoration:none}.admin-card a:hover{text-decoration:underline}.admin-empty{text-align:center;color:var(--color-off-black);padding:2rem;font-family:Georgia,serif;font-size:1rem;font-weight:400}.admin-file-grid{grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:1.25rem;max-width:100%;padding:.5rem;display:grid}.admin-file-card{border:1px solid var(--color-border);cursor:pointer;background:#fff;border-radius:1rem;flex-direction:column;width:240px;transition:all .15s;display:flex;overflow:hidden}.admin-file-card:hover{background:var(--color-warm1)}.admin-file-preview{background:var(--color-warm2);aspect-ratio:3/4;justify-content:center;align-items:center;width:100%;display:flex;position:relative;overflow:hidden}.admin-file-image{object-fit:cover;width:100%;height:100%;display:block;position:absolute;inset:0}.admin-file-title{color:var(--color-off-black);text-align:center;word-break:break-word;margin:0;padding:1rem;font-family:Georgia,serif;font-size:1rem;font-weight:400}.admin-file-placeholder{color:var(--color-off-black);justify-content:center;align-items:center;font-size:2.5rem;display:flex}.admin-breadcrumb{color:var(--color-off-black);align-items:center;gap:.5rem;margin-bottom:1.5rem;font-family:Georgia,serif;font-size:1rem;font-weight:400;display:flex}.admin-breadcrumb-link{cursor:pointer;color:var(--color-off-black);background:0 0;border:none;border-radius:.25rem;padding:.25rem .5rem;font-family:Georgia,serif;font-size:1rem;font-weight:400;transition:background-color .15s}.admin-breadcrumb-link:hover{background:var(--color-warm3)}.admin-breadcrumb-current{color:var(--color-off-black);font-family:Georgia,serif;font-weight:400}.admin-breadcrumb-separator{color:var(--color-off-black)}.admin-support-section{margin-bottom:1.5rem}.admin-pattern-selector{position:relative}.admin-card:has(.admin-pattern-selector){overflow:visible}.admin-pattern-dropdown{border:1px solid var(--color-border);z-index:10;background:#fff;border-radius:.5rem;max-height:240px;position:absolute;top:100%;left:0;right:0;overflow-y:auto;box-shadow:0 4px 12px #0000001f}.admin-pattern-dropdown-item{text-align:left;cursor:pointer;width:100%;color:var(--color-off-black);background:0 0;border:none;align-items:center;padding:.625rem .75rem;font-family:Georgia,serif;font-size:1rem;font-weight:400;transition:background-color .15s;display:flex}.admin-pattern-dropdown-item:hover{background-color:var(--color-warm1)}.admin-pattern-selected{background:var(--color-warm1);border:1px solid var(--color-border);border-radius:.5rem;justify-content:space-between;align-items:flex-start;margin-top:.75rem;padding:.75rem 1rem;display:flex}.admin-response-textarea{color:var(--color-off-black);font-family:Georgia,serif;font-size:1rem;font-weight:400;line-height:1.6}.admin-response-actions{flex-wrap:wrap;align-items:center;gap:.5rem;margin-top:.75rem;display:flex}.admin-collapsible-header{cursor:pointer;width:100%;color:var(--color-off-black);background:0 0;border:none;justify-content:space-between;align-items:center;padding:0;display:flex}.admin-tone-card{background:var(--color-warm1);border:1px solid var(--color-border);border-radius:.5rem;margin-bottom:.75rem;padding:.75rem 1rem}.sidebar-back-button{cursor:pointer;color:var(--color-off-black);text-align:left;text-transform:uppercase;background:0 0;border:none;border-radius:6px;margin-bottom:8px;padding:6px 10px;font-family:Helvetica,Arial,sans-serif;font-size:1rem;font-weight:700;transition:background-color .15s}.sidebar-back-button:hover{background-color:var(--color-warm3)}.sidebar-back-button:focus-visible{outline:2px solid var(--color-off-black);outline-offset:2px}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}.drawdown-preview-shimmer{background:linear-gradient(90deg,var(--color-warm1)25%,var(--color-warm2)50%,var(--color-warm1)75%);background-size:200% 100%;border-radius:4px;animation:1.5s ease-in-out infinite shimmer}@keyframes swatch-pop{0%{opacity:0;transform:scale(.6)}70%{transform:scale(1.1)}to{opacity:1;transform:scale(1)}}.color-swatch-enter{animation:.2s ease-out swatch-pop}@keyframes sidebar-section-enter{0%{opacity:0;max-height:0}to{opacity:1;max-height:500px}}.sidebar-section-content{animation:.15s ease-out sidebar-section-enter;overflow:hidden}@media (prefers-reduced-motion:reduce){*,:before,:after{scroll-behavior:auto!important;transition-duration:.01ms!important;animation-duration:.01ms!important;animation-iteration-count:1!important}}.shed-eyebrow{font-family:var(--font-ui);text-transform:uppercase;letter-spacing:var(--track-caps-lg);font-weight:700;font-size:var(--text-xs);color:var(--color-sage-deep);margin:0}.shed-panel-byline{font-family:var(--font-body);font-style:italic;font-size:var(--text-xs);color:var(--color-off-black);margin:0 0 18px;line-height:1.4}.sidebar-panel:has(.sfh) .shed-panel-byline{display:none!important}.sidebar-panel:has(.sfh)>div:first-child{display:none!important}.shed-helper{font-family:var(--font-body);font-style:italic;font-size:var(--text-xs);color:var(--color-off-black);opacity:.85;margin:0 0 12px;line-height:1.5}.shed-callout{background:var(--color-warm3);border-left:3px solid var(--color-warm5);grid-template-columns:22px 1fr;gap:12px;margin-bottom:16px;padding:12px 14px;display:grid}.shed-callout-glyph{width:22px;height:22px;font-family:var(--font-display);color:var(--color-warm5);justify-content:center;align-items:center;font-size:18px;display:inline-flex}.shed-callout p{font-family:var(--font-body);font-style:italic;font-size:var(--text-xs);color:var(--color-off-black);margin:0;line-height:1.45}.shed-radio-row{border:.5px solid var(--color-off-black);background:#fff;display:flex}.shed-radio-row button{border:0;border-right:.5px solid var(--color-line);cursor:pointer;height:40px;font-family:var(--font-ui);text-transform:uppercase;letter-spacing:var(--track-caps);font-weight:700;font-size:var(--text-xs);color:var(--color-off-black);background:0 0;flex:1}.shed-radio-row button:last-child{border-right:0}.shed-radio-row button.selected{background:var(--color-warm3)}.shed-stepper{border:.5px solid var(--color-off-black);background:#fff;grid-template-columns:36px 1fr 36px;align-items:stretch;height:40px;display:grid}.shed-stepper button{font-family:var(--font-display);cursor:pointer;color:var(--color-off-black);background:0 0;border:0;font-size:18px}.shed-stepper button:hover:not(:disabled){background:var(--color-warm2)}.shed-stepper button:disabled{opacity:.4;cursor:not-allowed}.shed-stepper .v{font-family:var(--font-display);border-left:.5px solid var(--color-line);border-right:.5px solid var(--color-line);justify-content:center;align-items:center;font-size:18px;display:flex}.shed-field-label{font-family:var(--font-ui);text-transform:uppercase;letter-spacing:var(--track-caps-lg);font-weight:700;font-size:var(--text-xs);color:var(--color-off-black);margin-bottom:6px;display:block}.shed-modal-foot{border-top:.5px solid var(--color-off-black);justify-content:flex-end;gap:8px;margin-top:14px;padding:14px 0 0;display:flex}.shed-modal-foot button{font-family:var(--font-ui);text-transform:uppercase;letter-spacing:var(--track-caps-lg);font-weight:700;font-size:var(--text-xs);cursor:pointer;border:.5px solid var(--color-off-black);border-radius:3px;height:36px;padding:0 16px}.shed-modal-foot .ghost{color:var(--color-off-black);background:0 0}.shed-modal-foot .ghost:hover{background:var(--color-warm1)}.shed-modal-foot .primary{background:var(--color-off-black);color:var(--color-warm1)}.shed-modal-foot .primary:hover{background:#1a1816}.shed-modal-foot .destructive{color:var(--color-warm5);border-color:var(--color-warm5);background:0 0;margin-right:auto}.shed-modal-foot .destructive:hover{background:#8c2f0014}.sidebar-panel .shed-modal-foot{flex-direction:column;justify-content:flex-start;align-items:stretch;gap:6px}.sidebar-panel .shed-modal-foot button{width:100%;padding:0 12px}.sidebar-panel .shed-modal-foot .destructive{margin-right:0}.sidebar-panel .shed-segmented{display:flex}.sidebar-panel .shed-segmented button{font-size:var(--text-xs);flex:1;height:40px;padding:0 12px}.shed-statusbar{background-color:var(--color-warm2);text-transform:uppercase;height:32px;letter-spacing:var(--track-caps);color:var(--color-off-black);z-index:100;box-sizing:border-box;border-top:.5px solid var(--color-line);align-items:center;gap:24px;padding:0 16px;font-size:12px;font-weight:700;display:flex;position:fixed;bottom:0;left:0;right:0;font-family:var(--font-ui)!important}.shed-statusbar *{font-family:inherit}.shed-statusbar strong{font-weight:700}.shed-statusbar .hint{text-transform:none;letter-spacing:0;opacity:.65;margin-left:auto;font-style:italic;font-weight:400;font-family:var(--font-body)!important}.shed-brand{box-sizing:border-box;flex-shrink:0;justify-content:center;align-items:center;width:104px;height:88px;margin-right:0;padding:0 6px;display:flex}.shed-brand .shed-brand-logo{-webkit-user-select:none;user-select:none;object-fit:contain;width:auto;max-width:100%;height:76px;display:block}.ws-mode{height:30px;font-family:var(--font-body);background:var(--color-warm2);border:.5px solid var(--color-off-black);cursor:pointer;color:var(--color-off-black);border-radius:3px;align-items:center;gap:6px;margin-left:4px;padding:0 10px;font-size:14px;display:inline-flex}.ws-mode:hover{background:var(--color-warm3)}.ws-mode .label-caps{font-family:var(--font-ui);text-transform:uppercase;letter-spacing:var(--track-caps);font-size:10px;font-weight:700}.ws-mode .mode-name{font-size:14px;font-style:italic}.ws-mode .chev{opacity:.7;margin-left:2px;font-size:10px}:root{--scrollbar-size:8px;--scrollbar-track:var(--color-warm2);--scrollbar-thumb:#08060547;--scrollbar-thumb-hover:#0806058c;--scrollbar-thumb-active:var(--color-off-black)}::-webkit-scrollbar{width:var(--scrollbar-size);height:var(--scrollbar-size)}::-webkit-scrollbar-track{background:var(--scrollbar-track);border-left:.5px solid var(--color-line);border-top:.5px solid var(--color-line)}::-webkit-scrollbar-thumb{background:var(--scrollbar-thumb);border:2px solid var(--scrollbar-track);border-radius:0}::-webkit-scrollbar-thumb:hover{background:var(--scrollbar-thumb-hover)}::-webkit-scrollbar-thumb:active{background:var(--scrollbar-thumb-active)}::-webkit-scrollbar-corner{background:var(--scrollbar-track)}::-webkit-scrollbar-button{width:0;height:0;display:none}*{scrollbar-width:thin;scrollbar-color:var(--scrollbar-thumb)var(--scrollbar-track)}.scroll-hairline::-webkit-scrollbar{width:4px;height:4px}.scroll-hairline::-webkit-scrollbar-thumb{background:#0806052e;border:0}.scroll-hairline::-webkit-scrollbar-thumb:hover{background:#08060573}.scroll-hairline::-webkit-scrollbar-track{background:0 0;border:0}.scroll-large::-webkit-scrollbar{width:12px;height:12px}.scroll-large::-webkit-scrollbar-thumb{border:3px solid var(--color-warm2);background:#08060552}.scroll-modal::-webkit-scrollbar-track{background:var(--color-warm1);border-color:var(--color-line)}.scroll-modal::-webkit-scrollbar-thumb{border-color:var(--color-warm1)}.scroll-ghost::-webkit-scrollbar-thumb{background:0 0}.scroll-ghost:hover::-webkit-scrollbar-thumb{background:var(--scrollbar-thumb)}.shed-modal-shell{background:var(--color-warm1);border:.5px solid var(--color-off-black);border-radius:4px;width:100%;max-width:520px;position:relative;box-shadow:0 18px 48px #00000052}.shed-modal-shell.size-lg{max-width:720px}.shed-modal-shell.size-sm{max-width:420px}.shed-modal-head{border-bottom:.5px solid var(--color-off-black);padding:24px 24px 14px;display:block;position:relative}.shed-modal-head h2{font-family:var(--font-display);font-weight:400;font-size:var(--text-2xl);color:var(--color-off-black);margin:4px 0 0;line-height:1.1}.shed-modal-head .close{cursor:pointer;color:var(--color-off-black);background:0 0;border:0;padding:4px;position:absolute;top:18px;right:18px}.shed-modal-body{padding:18px 24px}.shed-modal-actions{background:var(--color-warm2);border-top:.5px solid var(--color-off-black);align-items:center;gap:8px;padding:14px 24px;display:flex}.shed-modal-actions .destructive{margin-right:auto}.shed-btn-primary{font-family:var(--font-ui);text-transform:uppercase;letter-spacing:var(--track-caps);background:var(--color-off-black);color:var(--color-warm1);border:.5px solid var(--color-off-black);cursor:pointer;border-radius:3px;padding:9px 16px;font-size:11px;font-weight:700}.shed-btn-primary:hover{background:#1f1a16}.shed-btn-ghost{font-family:var(--font-ui);text-transform:uppercase;letter-spacing:var(--track-caps);color:var(--color-off-black);border:.5px solid var(--color-off-black);cursor:pointer;background:0 0;border-radius:3px;padding:9px 16px;font-size:11px;font-weight:700}.shed-btn-ghost:hover{background:var(--color-warm2)}.shed-btn-destructive{font-family:var(--font-ui);text-transform:uppercase;letter-spacing:var(--track-caps);color:var(--color-warm5);border:.5px solid var(--color-warm5);cursor:pointer;background:0 0;border-radius:3px;padding:9px 16px;font-size:11px;font-weight:700}.shed-btn-destructive:hover{background:#8c2f000f}.shed-subheader{border-bottom:.5px solid var(--color-line);align-items:center;gap:8px;margin-bottom:12px;padding:12px 4px 14px;display:flex}.shed-back{font-family:var(--font-ui);text-transform:uppercase;letter-spacing:var(--track-caps);cursor:pointer;color:var(--color-off-black);background:0 0;border:0;align-items:center;gap:6px;padding:6px;font-size:11px;font-weight:700;display:inline-flex}.shed-back:hover{background:var(--color-warm2)}.shed-breadcrumb{font-family:var(--font-body);color:var(--color-off-black);opacity:.55;font-size:13px}.shed-breadcrumb .current{opacity:1}.shed-section-head{cursor:pointer;border:0;border-top:.5px solid var(--color-line);text-align:left;background:0 0;align-items:center;gap:8px;width:100%;padding:10px 4px;display:flex}.shed-section-head h3{font-family:var(--font-display);color:var(--color-off-black);flex:1;margin:0;font-size:18px;font-weight:400}.shed-section-head .caret{width:14px;height:14px;transition:transform .15s}.shed-section-head[aria-expanded=true] .caret{transform:rotate(90deg)}.shed-segmented{border:.5px solid var(--color-off-black);border-radius:3px;display:inline-flex;overflow:hidden}.shed-segmented button{font-family:var(--font-ui);text-transform:uppercase;letter-spacing:var(--track-caps);background:var(--color-warm1);border:0;border-right:.5px solid var(--color-off-black);cursor:pointer;color:var(--color-off-black);padding:8px 12px;font-size:11px;font-weight:700}.shed-segmented button:last-child{border-right:0}.shed-segmented button.active{background:var(--color-off-black);color:var(--color-warm1)}.shed-result-summary{background:var(--color-sage-soft);border-radius:3px;grid-template-columns:repeat(3,1fr);gap:8px;padding:14px 12px;display:grid}.shed-result-summary .col{text-align:center}.shed-result-summary .num{font-family:var(--font-display);color:var(--color-sage-deep);font-size:28px;line-height:1}.shed-result-summary .lbl{font-family:var(--font-ui);text-transform:uppercase;letter-spacing:var(--track-caps-lg);color:var(--color-off-black);margin-top:6px;font-size:10px;font-weight:700;display:block}.page-shell{background:var(--color-warm1);flex-direction:column;min-height:100vh;display:flex}.page-topbar{border-bottom:.5px solid var(--color-off-black);background:var(--color-warm1);z-index:10;flex-shrink:0;justify-content:space-between;align-items:center;height:56px;padding:0 24px;display:flex;position:sticky;top:0}.page-topbar-left{align-items:center;gap:16px;display:flex}.page-topbar-logo{color:var(--color-off-black);border-bottom:0;align-items:center;text-decoration:none;display:inline-flex}.page-topbar-logo img{width:auto;height:22px}.page-topbar-logo .wordmark{font-family:var(--font-display);margin-left:8px;font-size:20px;line-height:1}.page-topbar-title{font-family:var(--font-body);color:var(--color-off-black);opacity:.65;border-left:.5px solid var(--color-line);padding-left:14px;font-size:14px;font-style:italic}.page-topbar-right{align-items:center;gap:12px;display:flex}.page-feedback{font-family:var(--font-ui);text-transform:uppercase;letter-spacing:var(--track-caps);background:var(--color-off-black);color:var(--color-warm1);cursor:pointer;border:0;border-radius:3px;align-items:center;gap:6px;padding:8px 12px;font-size:11px;font-weight:700;display:inline-flex}.page-feedback .dot{background:var(--color-sage);border-radius:50%;width:6px;height:6px}.page-avatar{background:var(--color-warm2);border:.5px solid var(--color-off-black);width:32px;height:32px;font-family:var(--font-ui);color:var(--color-off-black);cursor:pointer;border-radius:50%;justify-content:center;align-items:center;font-size:12px;font-weight:700;display:inline-flex}.sfh{margin-bottom:18px}.sfh-back,.sfh-back *{font-family:var(--font-ui);font-weight:700}.sfh-back{text-transform:uppercase;letter-spacing:var(--track-caps);color:var(--color-off-black);cursor:pointer;background:0 0;border:0;align-items:center;gap:6px;padding:0;font-size:1rem;display:inline-flex}.sfh-back--chip{background:0 0;border:0;border-radius:3px;margin-left:-8px;padding:6px 8px}.sfh-back--chip:hover{background:var(--color-warm2)}.sfh-back--underline{border-bottom:.5px solid var(--color-off-black);padding-bottom:4px}.sfh-back--icon{background:var(--color-warm2);border:.5px solid var(--color-off-black);border-radius:50%;justify-content:center;width:28px;height:28px;padding:0}.sfh-back--icon:hover{background:var(--color-warm3)}.sfh-parent{margin-top:14px;margin-bottom:10px}.sfh-eyebrow{font-family:var(--font-ui);text-transform:uppercase;letter-spacing:var(--track-caps-lg);color:var(--color-sage-deep);margin:0;font-size:11px;font-weight:700}.sfh-title{font-family:var(--font-display);color:var(--color-off-black);margin:12px 0 6px;font-size:24px;font-weight:400;line-height:1.1}.sfh-title--inline{margin:0;font-size:22px;display:inline}.sfh-helper{font-family:var(--font-body);color:var(--color-off-black);margin:0;font-size:.875rem;font-style:italic}.sfh--minimal .sfh-parent{display:none}.ws-yarn-list{flex-direction:column;gap:6px;display:flex}.ws-yarn-row{background:var(--color-warm1);border:.5px solid var(--color-line);cursor:pointer;text-align:left;grid-template-columns:1fr auto 12px;align-items:center;gap:10px;width:100%;padding:8px 10px;display:grid}.ws-yarn-row:hover{background:var(--color-warm2);border-color:var(--color-off-black)}.ws-yarn-row-main{flex-direction:column;gap:2px;min-width:0;display:flex}.ws-yarn-row-main .name{font-family:var(--font-display);color:var(--color-off-black);font-size:15px}.ws-yarn-row-main .meta{font-family:var(--font-body);color:var(--color-off-black);opacity:.65;font-size:11px;font-style:italic}.ws-yarn-row-strip{border:.5px solid var(--color-off-black);grid-template-columns:repeat(8,1fr);width:90px;height:18px;display:grid}.ws-yarn-row-strip>div{width:100%;height:100%}.ws-yarn-row .chev{opacity:.5;width:12px;height:12px}.ws-yarn-line{border-bottom:.5px solid var(--color-line);margin-bottom:18px;padding-bottom:14px}.ws-yarn-line-head{justify-content:space-between;align-items:baseline;margin-bottom:6px;display:flex}.ws-yarn-line-name{font-family:var(--font-display);font-size:18px}.ws-yarn-line-count{font-family:var(--font-body);opacity:.7;font-size:12px;font-style:italic}.ws-yarn-grid{grid-template-columns:repeat(8,1fr);gap:4px;display:grid}.ws-yarn-chip{aspect-ratio:1;border:.5px solid var(--color-off-black);cursor:pointer;background:0 0;padding:0}.ws-yarn-chip:hover{outline:2px solid var(--color-sage);outline-offset:1px}div.ws-picker{flex-direction:column;align-items:stretch;gap:12px;display:flex}div.ws-picker>.react-colorful{align-self:center;width:100%;max-width:220px}div.ws-picker-readout{align-items:center;gap:10px;display:flex}div.ws-picker-preview{border:.5px solid var(--color-off-black);border-radius:3px;flex-shrink:0;width:36px;height:36px}div.ws-picker-field{flex:1;align-items:center;gap:8px;min-width:0;display:flex}div.ws-picker-field label{font-family:var(--font-ui);text-transform:uppercase;letter-spacing:var(--track-caps);font-weight:700;font-size:var(--text-xs);color:var(--color-off-black)}div.ws-picker-field input{font-family:var(--font-body);border:0;border-bottom:.5px solid var(--color-off-black);color:var(--color-off-black);background:0 0;outline:none;flex:1;width:100%;min-width:0;padding:4px 0;font-size:1rem}div.ws-picker-field input:focus{border-bottom-color:var(--color-sage)}button.ws-picker-add{font-family:var(--font-ui);text-transform:uppercase;letter-spacing:var(--track-caps);font-weight:700;font-size:var(--text-xs);color:var(--color-off-black);border:.5px solid var(--color-off-black);cursor:pointer;background:0 0;border-radius:3px;width:100%;height:36px;padding:0 12px;display:block}button.ws-picker-add:hover{background:var(--color-warm2)}@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-border-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-ordinal{syntax:"*";inherits:false}@property --tw-slashed-zero{syntax:"*";inherits:false}@property --tw-numeric-figure{syntax:"*";inherits:false}@property --tw-numeric-spacing{syntax:"*";inherits:false}@property --tw-numeric-fraction{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}@property --tw-blur{syntax:"*";inherits:false}@property --tw-brightness{syntax:"*";inherits:false}@property --tw-contrast{syntax:"*";inherits:false}@property --tw-grayscale{syntax:"*";inherits:false}@property --tw-hue-rotate{syntax:"*";inherits:false}@property --tw-invert{syntax:"*";inherits:false}@property --tw-opacity{syntax:"*";inherits:false}@property --tw-saturate{syntax:"*";inherits:false}@property --tw-sepia{syntax:"*";inherits:false}@property --tw-drop-shadow{syntax:"*";inherits:false}@property --tw-drop-shadow-color{syntax:"*";inherits:false}@property --tw-drop-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-drop-shadow-size{syntax:"*";inherits:false}@property --tw-duration{syntax:"*";inherits:false}
