html{font-size:93.75%}:root{--color-bg: #0f172a;--color-surface: #1e293b;--color-border: #475569;--color-text: #e2e8f0;--color-text-muted: #94a3b8;--color-text-dim: #64748b;--color-accent: #704CF4;--color-accent-hover: #6d28d9;--color-warning: #facc15;--color-white: #ffffff;--state-hover: hsl(215 24% 24%);--state-selected: hsl(215 33% 25%);--state-focus-ring: var(--color-accent);--state-focus-offset: 2px;--space-1: .5rem;--space-2: 1rem;--space-3: 1.5rem;--space-4: 2rem;--space-5: 3rem;--t-xs: .8rem;--t-sm: .933rem;--t-base: 1rem;--t-md: 1.133rem;--t-lg: 1.333rem;--t-xl: 1.6rem;--t-2xl: 2rem;--transition-fast: .15s ease;--transition-base: .25s ease;--radius-sm: 4px;--radius-md: 8px;--radius-lg: 12px}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}body{font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;font-size:var(--t-base);line-height:1.5;color:var(--color-text);background-color:var(--color-bg);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}:focus-visible{outline:2px solid var(--color-accent);outline-offset:2px}:focus:not(:focus-visible){outline:none}.t-xs{font-size:var(--t-xs)}.t-sm{font-size:var(--t-sm)}.t-base{font-size:var(--t-base)}.t-md{font-size:var(--t-md)}.t-lg{font-size:var(--t-lg)}.t-xl{font-size:var(--t-xl)}.t-2xl{font-size:var(--t-2xl);font-weight:500;line-height:1.2}.visually-hidden{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}html,body{height:100%;overflow:hidden}.app-header{display:flex;align-items:center;padding-inline:var(--space-2);padding-block:var(--space-2);border-bottom:1px solid #000;background-color:var(--color-surface)}.app-header__title{font-size:var(--t-md);color:var(--color-white)}.stipple-app{height:calc(100vh - 41px);width:100vw;overflow:hidden}.stipple-app__layout{display:grid;grid-template-columns:250px 1fr;height:100%;width:100%}.panel{background-color:var(--color-surface)}.panel--controls{overflow-y:auto;border-right:1px solid #000}.panel--preview{display:flex;align-items:center;justify-content:center;padding:var(--space-2);overflow:hidden}.panel--preview canvas{max-width:100%;max-height:100%;object-fit:contain}.dropzone{position:relative;border:1px dashed var(--color-border);border-radius:var(--radius-sm);padding:var(--space-2);text-align:center;cursor:pointer;transition:border-color var(--transition-fast),background-color var(--transition-fast)}.dropzone:hover,.dropzone:focus-visible,.dropzone--dragover{border-color:var(--color-accent);background-color:var(--state-hover)}.dropzone__input{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.dropzone__text{font-size:var(--t-xs);color:var(--color-text-muted)}.control{height:32px;padding-inline:var(--space-1);background-color:var(--color-bg);border:none;border-radius:var(--radius-sm);font-family:inherit;font-size:var(--t-xs);line-height:32px;color:var(--color-text);cursor:pointer;transition:background-color var(--transition-fast)}.control:hover{background-color:var(--state-hover)}.control:focus-visible{outline:2px solid var(--state-focus-ring);outline-offset:var(--state-focus-offset)}.controls__group{border:none;padding:var(--space-2);border-bottom:1px solid #000}.controls__inline{display:flex;gap:var(--space-1)}.controls__inline>*{flex:1}.controls__label{display:block;font-size:var(--t-xs);color:var(--color-text-muted);margin-block-end:var(--space-1)}.controls__sublabel{display:block;font-size:.7rem;color:var(--color-text-muted);margin-block-end:5px}.controls__hint{font-size:.65rem;color:var(--color-text-dim);margin-block-start:8px;line-height:1.3}.controls__color-field{display:flex;align-items:center;gap:var(--space-1);line-height:normal}.controls__color-label{flex:1;font-size:var(--t-xs);color:var(--color-text-muted);-webkit-user-select:none;user-select:none}.controls__color{-moz-appearance:none;appearance:none;-webkit-appearance:none;width:20px;height:20px;padding:0;border:none;border-radius:var(--radius-sm);background:transparent;cursor:pointer;flex-shrink:0}.controls__color::-webkit-color-swatch-wrapper{padding:0}.controls__color::-webkit-color-swatch{border:1px solid var(--color-border);border-radius:var(--radius-sm)}.controls__color::-moz-color-swatch{border:1px solid var(--color-border);border-radius:var(--radius-sm)}.controls__bg-group{margin-block-start:var(--space-2)}.controls__bg-options{display:flex;gap:4px}.controls__bg-preset{width:32px;height:32px;padding:0;border:2px solid transparent;border-radius:var(--radius-sm);cursor:pointer;flex-shrink:0;transition:border-color var(--transition-fast)}.controls__bg-preset--dark{background-color:#0a1628}.controls__bg-preset--white{background-color:#fff}.controls__bg-preset--transparent{background-color:#0a1628;position:relative;overflow:hidden}.controls__bg-preset--transparent:after{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(to bottom left,transparent calc(50% - .5px),#942e2d calc(50% - .5px),#942e2d calc(50% + .5px),transparent calc(50% + .5px))}.controls__bg-preset:hover{border-color:var(--color-text-muted)}.controls__bg-preset[aria-pressed=true]{border-color:var(--color-accent)}.controls__bg-preset:focus-visible{outline:2px solid var(--state-focus-ring);outline-offset:var(--state-focus-offset)}.controls__range{--range-progress: 0%;-webkit-appearance:none;-moz-appearance:none;appearance:none;width:100%;height:16px;background:linear-gradient(to right,rgba(255,255,255,.1) 0%,rgba(255,255,255,.1) var(--range-progress),var(--color-bg) var(--range-progress),var(--color-bg) 100%);border-radius:var(--radius-sm);cursor:pointer}.controls__range::-webkit-slider-runnable-track{height:16px;background:transparent;border-radius:var(--radius-sm)}.controls__range::-moz-range-track{height:16px;background:var(--color-bg);border-radius:var(--radius-sm);border:none}.controls__range::-moz-range-progress{height:16px;background:#ffffff1a;border-radius:var(--radius-sm) 0 0 var(--radius-sm)}.controls__range::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:1px;height:16px;background:#ffffff80;border:none;border-radius:0;cursor:ew-resize;transition:background-color var(--transition-fast)}.controls__range::-moz-range-thumb{width:1px;height:24px;background:#ffffff80;border:none;border-radius:0;cursor:ew-resize;transition:background-color var(--transition-fast)}.controls__range:hover::-webkit-slider-thumb{background:#fff;width:4px}.controls__range:hover::-moz-range-thumb{background:#fff}.controls__range:focus-visible{outline:2px solid var(--state-focus-ring);outline-offset:var(--state-focus-offset)}.controls__range--flex{flex:1;min-width:0}.controls__row{display:flex;align-items:center;gap:var(--space-1)}.controls__preview{display:flex;justify-content:center;margin-block-start:var(--space-1)}.controls__preview img{max-height:4rem;border-radius:var(--radius-sm);display:block}.controls__actions{display:flex;padding-inline:var(--space-2);flex-direction:column;gap:var(--space-1);margin-block-start:var(--space-2)}.controls__export{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-1)}.controls__status{display:block;font-size:.65rem;padding:var(--space-2);color:var(--color-text-dim);margin-block-start:var(--space-1);line-height:1.3}.controls__status--processing{color:var(--color-warning)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:4px;min-height:36px;padding:var(--space-1) var(--space-2);border:none;border-radius:var(--radius-sm);font-family:inherit;font-size:var(--t-xs);font-weight:500;cursor:pointer;transition:background-color var(--transition-fast)}.btn:disabled{opacity:.5;cursor:not-allowed}.btn--primary{background-color:var(--color-accent);color:var(--color-white)}.btn--primary:hover:not(:disabled){background-color:var(--color-accent-hover)}.btn--secondary{background-color:var(--state-selected);color:var(--color-text)}.btn--secondary:hover:not(:disabled){background-color:var(--state-hover)}.btn--icon{min-height:28px;min-width:28px;padding:4px;background-color:var(--color-surface);color:var(--color-text);flex-shrink:0}.btn--icon:hover:not(:disabled){background-color:var(--state-hover);border-color:var(--color-text-muted);color:var(--color-text)}.btn--toggle{min-width:48px;background-color:var(--color-bg);color:var(--color-text-muted)}.btn--toggle[aria-pressed=true]{background-color:var(--color-accent);color:var(--color-white)}.btn--toggle:hover:not(:disabled){background-color:var(--state-hover)}.btn--toggle[aria-pressed=true]:hover:not(:disabled){background-color:var(--color-accent-hover)}.tabs{display:flex;gap:0;margin-block:var(--space-2);border-bottom:1px solid var(--color-border)}.tabs__btn{flex:1;padding:var(--space-1);background:transparent;border:none;border-bottom:2px solid transparent;margin-bottom:-1px;font-family:inherit;font-size:var(--t-xs);font-weight:500;color:var(--color-text-muted);cursor:pointer;transition:color var(--transition-fast),border-color var(--transition-fast)}.tabs__btn:hover{color:var(--color-text)}.tabs__btn:focus-visible{outline:2px solid var(--state-focus-ring);outline-offset:-2px}.tabs__btn--active{color:var(--color-white);border-bottom-color:var(--color-white)}.tab-content{overflow-y:auto;flex:1}.tab-content--hidden{display:none}.controls__select{width:100%}.controls__number{width:100%;text-align:center;-webkit-appearance:textfield;appearance:textfield;-moz-appearance:textfield}.controls__number::-webkit-inner-spin-button,.controls__number::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.controls__size-row{margin-block-end:var(--space-2)}.controls__size-inputs{display:flex;align-items:center;gap:var(--space-1)}.controls__size-separator{color:var(--color-text-muted);font-size:var(--t-xs);padding-top:1rem}.controls__field--compact{flex:1}.controls__field--compact .controls__sublabel{text-align:center}.controls__radio-group{display:grid;grid-template-columns:repeat(4,1fr);gap:4px}.controls__radio{display:block;cursor:pointer}.controls__radio input{position:absolute;opacity:0;pointer-events:none}.controls__radio-label{display:block;padding:6px 4px;background-color:var(--color-bg);border-radius:var(--radius-sm);font-size:.65rem;text-align:center;color:var(--color-text-muted);transition:background-color var(--transition-fast),color var(--transition-fast)}.controls__radio:hover .controls__radio-label{background-color:var(--state-hover);color:var(--color-text)}.controls__radio input:checked+.controls__radio-label{background-color:var(--state-selected);color:var(--color-white)}.controls__radio input:focus-visible+.controls__radio-label{outline:2px solid var(--state-focus-ring);outline-offset:var(--state-focus-offset)}.preset-images{display:flex;flex-wrap:wrap;gap:4px;padding-block:var(--space-1)}.preset-images__item{flex-shrink:0;width:40px;height:40px;padding:0;border:1px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-bg);cursor:pointer;overflow:hidden;transition:border-color var(--transition-fast),transform var(--transition-fast)}.preset-images__item:hover{border-color:var(--color-text-muted);transform:scale(1.05)}.preset-images__item:focus-visible{outline:2px solid var(--color-accent);outline-offset:2px}.preset-images__item--active{border-color:var(--color-accent);border-width:2px}.preset-images__item img{width:100%;height:100%;object-fit:cover}
