*,:after,:before{--tw-border-spacing-x:0;--tw-border-spacing-y:0;--tw-translate-x:0;--tw-translate-y:0;--tw-rotate:0;--tw-skew-x:0;--tw-skew-y:0;--tw-scale-x:1;--tw-scale-y:1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness:proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-color:rgb(59 130 246/0.5);--tw-ring-offset-shadow:0 0 #0000;--tw-ring-shadow:0 0 #0000;--tw-shadow:0 0 #0000;--tw-shadow-colored:0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }::backdrop{--tw-border-spacing-x:0;--tw-border-spacing-y:0;--tw-translate-x:0;--tw-translate-y:0;--tw-rotate:0;--tw-skew-x:0;--tw-skew-y:0;--tw-scale-x:1;--tw-scale-y:1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness:proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-color:rgb(59 130 246/0.5);--tw-ring-offset-shadow:0 0 #0000;--tw-ring-shadow:0 0 #0000;--tw-shadow:0 0 #0000;--tw-shadow-colored:0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }/*
! tailwindcss v3.4.19 | MIT License | https://tailwindcss.com
*/*,:after,:before{border:0 solid #e5e7eb}:after,:before{--tw-content:""}:host,html{line-height:1.5;-webkit-text-size-adjust:100%;-moz-tab-size:4;-o-tab-size:4;tab-size:4;font-family:ui-sans-serif,system-ui,sans-serif,Apple Color Emoji,Segoe UI Emoji,Segoe UI Symbol,Noto Color Emoji;font-feature-settings:normal;font-variation-settings:normal;-webkit-tap-highlight-color:transparent}body{line-height:inherit}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,pre,samp{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-feature-settings:normal;font-variation-settings:normal;font-size:1em}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}button,input,optgroup,select,textarea{font-family:inherit;font-feature-settings:inherit;font-variation-settings:inherit;font-size:100%;font-weight:inherit;line-height:inherit;letter-spacing:inherit;color:inherit;margin:0;padding:0}button,select{text-transform:none}button,input:where([type=button]),input:where([type=reset]),input:where([type=submit]){-webkit-appearance:button;background-color:transparent;background-image:none}:-moz-focusring{outline:auto}:-moz-ui-invalid{box-shadow:none}progress{vertical-align:baseline}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}summary{display:list-item}blockquote,dd,dl,figure,h1,h2,h3,h4,h5,h6,hr,p,pre{margin:0}fieldset{margin:0}fieldset,legend{padding:0}menu,ol,ul{list-style:none;margin:0;padding:0}dialog{padding:0}textarea{resize:vertical}input::-moz-placeholder,textarea::-moz-placeholder{opacity:1;color:#9ca3af}input::placeholder,textarea::placeholder{opacity:1;color:#9ca3af}[role=button],button{cursor:pointer}:disabled{cursor:default}audio,canvas,embed,iframe,img,object,svg,video{display:block;vertical-align:middle}img,video{max-width:100%;height:auto}[hidden]:where(:not([hidden=until-found])){display:none}.visible{visibility:visible}.fixed{position:fixed}.absolute{position:absolute}.relative{position:relative}.block{display:block}.inline{display:inline}.flex{display:flex}.contents{display:contents}.hidden{display:none}.grow{flex-grow:1}.resize{resize:both}.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)}:root{--color-bg:#ffffff;--color-ink:#2a2318;--color-muted:#7a7060;--color-faint:#b8b0a0;--color-line:#e0dbd0}*,:after,:before{box-sizing:border-box}html{background-color:var(--color-bg)}body{margin:0;padding:0;background:transparent;color:var(--color-ink);font-family:var(--font-hand)}a{color:inherit;text-decoration:none}a:hover{text-decoration:underline}.content a,.mdx a,.prose a{color:var(--color-muted);text-decoration:underline;text-underline-offset:.2em}.content a:hover,.mdx a:hover,.prose a:hover,footer a:hover{color:var(--color-ink)}#root-container{min-height:100vh;display:flex;flex-direction:column;position:relative;z-index:1}main{flex:1;padding:0 5em}nav{display:flex;align-items:center;justify-content:space-between;padding:0 4em;height:5em;text-transform:uppercase}.overview{padding-top:2em;padding-bottom:4em;font-family:var(--font-main)}.overview p.empty{text-align:center;margin-top:4em}.overview h1{font-size:3.5em;font-family:var(--font-hand);margin-bottom:.75em;color:var(--color-ink);text-transform:uppercase}.overview ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:3em}.overview .content-card{padding:2.5em 2.5em 1em;margin-bottom:1em}.overview .content-card canvas{margin:.5em;padding:.5em}.overview .content-card a{display:block}.content-card-link{display:flex!important;gap:1.25em;align-items:flex-start}.content-thumbnail{flex-shrink:0;-o-object-fit:cover;object-fit:cover;border:2px solid var(--color-line)}.content-card-text{flex:1;min-width:0}.content-card .date{font-size:1.5em;color:var(--color-muted);margin-bottom:.5em}.content-card .title{display:block;text-transform:uppercase;font-weight:700;font-size:2em;margin-bottom:.5em}.content-card .description,.content-card .title{font-family:var(--font-body);color:var(--color-ink)}.content-card .description{font-size:1.3em;max-width:100%}.hero{padding-top:3em;padding-bottom:2em;gap:2em}.hero,.hero .featured{display:flex;flex-direction:column;align-items:center}.hero .featured{gap:.625em;margin-top:.5em}.hero .featured a{font-size:1.7em;color:var(--color-ink);display:flex;align-items:center;gap:.5em}.hero .subhead{font-size:2em;font-weight:700;color:var(--color-ink);text-align:center}.hero-nav{display:flex;gap:3em;margin-top:.5em}.hero-nav-item{display:flex;flex-direction:column;align-items:center;gap:.4em;color:var(--color-ink);font-size:1.1em;text-transform:uppercase;letter-spacing:.08em;text-decoration:none}.hero-nav-item:hover{text-decoration:none;animation:wiggle .4s ease-in-out}@keyframes wiggle{0%{transform:rotate(0deg)}20%{transform:rotate(-8deg)}40%{transform:rotate(8deg)}60%{transform:rotate(-5deg)}80%{transform:rotate(4deg)}to{transform:rotate(0deg)}}#nav-logo{height:49px;width:auto;-o-object-fit:contain;object-fit:contain;-o-object-position:left center;object-position:left center;mix-blend-mode:multiply;display:block}.nav-links{display:flex;gap:2.5em}.nav-links a{font-size:1.5em;color:var(--color-ink)}.nav-user{font-size:1.5em;color:var(--color-muted)}.nav-signout{font-size:1.5em;font-family:inherit;color:var(--color-ink);background:none;border:none;cursor:pointer;padding:0;text-transform:uppercase}.nav-signout:hover{text-decoration:underline}footer{display:flex;align-items:center;justify-content:space-between;padding:1.5em 5em 3em}footer .social-links{display:flex;gap:3em}footer .social-links a{font-size:1em;color:var(--color-faint);display:flex;align-items:center;gap:.375em}footer .social-links a:hover{color:var(--color-ink)}article{padding-top:3em;padding-bottom:6em;max-width:55rem;margin:0 auto}article header{margin-bottom:1.5em}article header .date{font-size:2em;color:var(--color-faint);margin-bottom:.75em}article header h1{font-size:3em;line-height:1.2;color:var(--color-ink);margin:0;text-transform:uppercase;padding:0;font-family:var(--font-body);font-weight:700}article .video{margin-top:3em;position:relative;padding-bottom:56.25%;height:0}article .video iframe{position:absolute;top:0;left:0;width:100%;height:100%;border:0}.talk-links{display:flex;gap:1em;margin-top:3em}.talk-cta{display:inline-block;padding:.5em 1.25em;border:2px solid var(--color-ink);color:var(--color-ink);text-decoration:none;font-family:var(--font-hand);font-size:1.1em;letter-spacing:.05em}.talk-cta:hover{background:var(--color-ink);color:var(--color-bg)}article .content{font-family:var(--font-body);font-style:normal;color:var(--color-ink);line-height:1.7}.blog-post{display:flex;flex-direction:column;gap:1em}.blog-post header{margin:0;padding-bottom:0}.blog-post header .date{font-size:1.5em;color:var(--color-faint);margin-bottom:.75em}.blog-post header .hero-image{position:relative;width:100%;margin-top:1em;margin-bottom:1em;border:1px solid black}.blog-post header h1{font-size:3em;line-height:1.2;color:var(--color-ink);margin:0;text-transform:uppercase;padding:0}.blog-post .prose,.mdx{font-size:1em;font-family:var(--font-body);color:var(--color-ink)}.blog-post .prose img,.mdx img{max-width:100%;margin:2em auto;display:block;border:1px solid black}.blog-post .prose .image-right,.mdx .image-right{float:right;max-width:45%;margin-left:2em;margin-bottom:1em}.blog-post .prose .image-left{float:left;max-width:45%;margin-right:2em;margin-bottom:1em}.blog-post .prose p,.description p,.mdx p{line-height:1.7;margin-bottom:1em;text-align:justify}.description p{font-size:.8em}.prose ul{padding-left:1.5em;margin:0 3em 1em 2em;text-align:justify}.prose ul li{list-style:outside;margin-bottom:.35em}.blog-post .prose h2{font-size:2em;margin-top:.75em;margin-bottom:.25em}.blog-post .prose h2,.blog-post .prose h3{font-weight:700;font-family:var(--font-body);line-height:1.2}.blog-post .prose h3{font-size:1.5em;padding-top:0;padding-bottom:.5em}.blog-post .signoff{width:30%;float:right;margin-right:3em}.mdx{max-width:55rem;margin:0 auto}.mdx .social-links{display:flex;flex-direction:column;gap:.75em;margin:1em 0 3em 2em}.mdx .social-links a{display:flex;align-items:center;gap:.5em;font-size:1.2 em;text-decoration:none}.mdx h1{font-size:2.8em;margin-bottom:.1em}.mdx h1,.mdx h2{font-family:var(--font-body);text-transform:uppercase;font-weight:700}.mdx h2{font-size:1.9em;margin-top:.75em;padding-bottom:.5em;line-height:1.2}.mdx p{font-size:1em;font-family:var(--font-body);color:var(--color-ink);margin-bottom:1em}.mdx ul li{margin-bottom:.5em;margin-left:2em;list-style:outside}@media (max-width:800px){.content-thumbnail{width:200px}.content-card .date{font-size:.8em}}@media (max-width:600px){main{padding:0 1.25em}nav{padding:.75em 1.25em;height:auto;flex-wrap:wrap;gap:.5em}#nav-logo{height:32px}.nav-links{gap:1.25em}.nav-links a{font-size:1.25em}.nav-signout,.nav-user{font-size:1em}.hero-nav{gap:2em}footer{padding:1.25em 1.25em 2em;flex-direction:column;align-items:center;gap:1.25em}footer .social-links{flex-wrap:wrap;justify-content:center;gap:1.5em}.overview h1{font-size:2.25em}.overview ul{gap:1.5em}.hero .subhead{font-size:1.5em}article{max-width:100%;padding-top:2em;padding-bottom:4em}article header{margin-bottom:1.5em}.mdx h1,article header h1{font-size:2em}.mdx h2{font-size:1.4em}.mdx p,.mdx ul li{font-size:1em}.content-card-link{flex-direction:column}.content-thumbnail{width:100%;height:auto;aspect-ratio:16/9}.blog-post header h1{font-size:3em}}.signin-page{max-width:28em;margin:4em auto;padding:0 1.5em;display:flex;flex-direction:column;align-items:center;gap:.5em}.signin-page h1{font-family:var(--font-hand);font-size:2.5em;color:var(--color-ink);margin:0 0 .25em}.signin-page .signin-note{font-family:var(--font-body);color:var(--color-muted);font-size:1em;margin:0 0 1.5em}.signin-error{width:100%;padding:.75em 1.25em;background:#fef2f2;border:2px solid #dc2626;color:#991b1b;font-family:var(--font-body);font-size:.95em;line-height:1.5}.signin-providers{display:flex;flex-direction:column;gap:1em;width:100%}.signin-providers form{width:100%}.provider-btn{width:100%;padding:.75em 1.5em;background:transparent;border:none;font-family:var(--font-hand);font-size:1.1em;color:var(--color-ink);cursor:pointer;text-align:center;letter-spacing:.03em}.provider-btn:hover{color:var(--color-muted)}.auth-error-page{max-width:28em;margin:4em auto;padding:0 1.5em;text-align:center}.auth-error-page h1{font-family:var(--font-hand);font-size:2.5em;color:var(--color-ink);margin:0 0 .5em}.auth-error-page p{font-family:var(--font-body);color:var(--color-muted);line-height:1.6}.auth-error-page a{color:var(--color-ink);text-decoration:underline;text-underline-offset:.2em}.comments-section{margin-top:3em;padding-top:2em;border-top:1px solid var(--color-rule,#e0ddd5)}.comments-heading{font-family:var(--font-hand);font-size:1.8em;color:var(--color-ink);margin:0 0 1em}.comments-empty{font-family:var(--font-body);color:var(--color-muted);font-style:italic}.comments-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:1.5em}.comment{padding-bottom:1.5em;border-bottom:1px solid var(--color-rule,#e0ddd5)}.comment:last-child{border-bottom:none}.comment-meta{display:flex;gap:1em;align-items:baseline;margin-bottom:.4em}.comment-author{font-family:var(--font-hand);font-size:1.05em;color:var(--color-ink)}.comment-date{font-size:.82em;color:var(--color-muted)}.comment-body,.comment-date{font-family:var(--font-body)}.comment-body{line-height:1.65;color:var(--color-ink);margin:0}.comment-form{margin-top:2.5em;padding-top:2em;border-top:1px solid var(--color-rule,#e0ddd5)}.comment-form-heading{font-family:var(--font-hand);font-size:1.5em;color:var(--color-ink);margin:0 0 1em}.comment-form-error{background:#fef2f2;border:2px solid #dc2626;color:#991b1b;padding:.6em 1em;border-radius:4px;font-family:var(--font-body);font-size:.9em;margin-bottom:1em}.comment-form-field{display:flex;flex-direction:column;gap:.3em;margin-bottom:1em}.comment-form-field label{font-family:var(--font-body);font-size:.9em;color:var(--color-muted)}.comment-form-field input,.comment-form-field textarea{font-family:var(--font-body);font-size:1em;color:var(--color-ink);background:transparent;border:1px solid var(--color-rule,#e0ddd5);border-radius:4px;padding:.5em .75em;outline:none;transition:border-color .15s}.comment-form-field input:focus,.comment-form-field textarea:focus{border-color:var(--color-ink)}.comment-form-field textarea{resize:vertical}.comment-form-submit{font-family:var(--font-hand);font-size:1.1em;color:var(--color-ink);background:transparent;border:2px solid var(--color-ink);border-radius:4px;padding:.5em 1.5em;cursor:pointer;transition:background .15s,color .15s}.comment-form-submit:hover:not(:disabled){background:var(--color-ink);color:var(--color-bg)}.comment-form-submit:disabled{opacity:.5;cursor:not-allowed}.comment-form-success{margin-top:2.5em;padding:1em 1.25em;background:#f0fdf4;border:2px solid #16a34a;border-radius:4px;font-family:var(--font-body);color:#15803d}.comment-form-byline{font-size:.9em;margin:-.5em 0 1em}.comment-form-byline,.comment-signin-prompt{font-family:var(--font-body);color:var(--color-muted)}.comment-signin-prompt{margin-top:2.5em;padding-top:2em;border-top:1px solid var(--color-rule,#e0ddd5)}.comment-signin-prompt a{color:var(--color-ink);text-underline-offset:.2em}.admin-page{max-width:52em;margin:2em auto;padding:0 1.5em}.admin-heading{font-family:var(--font-hand);font-size:2em;color:var(--color-ink);margin:0 0 1em}.admin-tabs{display:flex;gap:0;border-bottom:2px solid var(--color-rule,#e0ddd5);margin-bottom:1.5em}.admin-tab{font-family:var(--font-body);font-size:.9em;color:var(--color-muted);text-decoration:none;padding:.5em 1.25em;border-bottom:2px solid transparent;margin-bottom:-2px;display:flex;align-items:center;gap:.4em;transition:color .15s}.admin-tab--active,.admin-tab:hover{color:var(--color-ink)}.admin-tab--active{border-bottom-color:var(--color-ink)}.admin-tab-count{font-size:.8em;background:var(--color-rule,#e0ddd5);border-radius:999px;padding:.1em .5em;line-height:1.4}.admin-tab--active .admin-tab-count{background:var(--color-ink);color:var(--color-bg)}.admin-empty{font-family:var(--font-body);color:var(--color-muted);font-style:italic}.admin-comment-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:1em}.admin-comment-card{border:1px solid var(--color-rule,#e0ddd5);border-radius:6px;padding:1em 1.25em}.admin-comment-meta{display:flex;flex-wrap:wrap;align-items:baseline;gap:.6em;margin-bottom:.5em}.admin-comment-author{font-family:var(--font-hand);font-size:1.05em;color:var(--color-ink)}.admin-comment-link{text-decoration:underline;text-underline-offset:.2em}.admin-comment-date,.admin-comment-link{font-family:var(--font-body);font-size:.82em;color:var(--color-muted)}.admin-comment-date{margin-left:auto}.admin-comment-body{font-family:var(--font-body);line-height:1.6;color:var(--color-ink);margin:0 0 .75em}.admin-comment-actions{display:flex;gap:.5em}.admin-btn{font-family:var(--font-body);font-size:.85em;padding:.3em .9em;border-radius:4px;border:1px solid;cursor:pointer;background:transparent;transition:background .15s,color .15s}.admin-btn--approve{border-color:#16a34a;color:#16a34a}.admin-btn--approve:hover{background:#16a34a;color:white}.admin-btn--reject{border-color:#dc2626;color:#dc2626}.admin-btn--reject:hover{background:#dc2626;color:white}.comment-reject-form{margin-left:auto}.comment-reject-btn{background:none;border:none;color:#dc2626;font-size:3em;line-height:1;cursor:pointer;padding:0 .25em;opacity:1;transition:opacity .15s}.comment-reject-btn:hover{opacity:1}body:has(.hw-app){overflow:hidden}body:has(.hw-app) #root-container{height:100dvh;overflow:hidden}body:has(.hw-app) main{padding:0;overflow:hidden;display:flex;flex-direction:column}.hw-app{flex:1;display:flex;flex-direction:column;background:#1a1a1a;color:#f0f0f0;font-family:-apple-system,BlinkMacSystemFont,sans-serif;overflow:hidden;touch-action:none;-moz-user-select:none;user-select:none;-webkit-user-select:none}.hw-app *{box-sizing:border-box;margin:0;padding:0}.hw-app .tab-bar{display:flex;background:#222;border-bottom:1px solid #3a3a3a;flex-shrink:0}.hw-app .tab-btn{flex:1;padding:10px 16px;background:none;border:none;border-bottom:3px solid transparent;color:#888;font-size:15px;font-weight:500;cursor:pointer;transition:color .15s,border-color .15s}.hw-app .tab-btn--active{color:#f0f0f0;border-bottom-color:#4a90d9}.hw-app .top-bar{display:flex;align-items:center;gap:12px;padding:10px 16px;background:#2a2a2a;border-bottom:1px solid #3a3a3a;flex-shrink:0}.hw-app .set-selector{flex:1;background:#3a3a3a;border:none;color:#f0f0f0;padding:8px 12px;border-radius:8px;font-size:15px}.hw-app .btn-new-set{background:#4a90d9;color:white}.hw-app .btn-new-set,.hw-app .btn-open-grid{border:none;padding:8px 14px;border-radius:8px;font-size:15px;cursor:pointer}.hw-app .btn-open-grid{background:#3a3a3a;color:#fff}.hw-app .btn-export{background:#5a7a4a;border:none;color:white;padding:8px 14px;border-radius:8px;font-size:15px;cursor:pointer}.hw-app .btn-export:disabled{opacity:.4;cursor:default}.hw-app .progress-bar{padding:8px 16px;background:#222;flex-shrink:0}.hw-app .progress-label{font-size:13px;color:#999;margin-bottom:4px}.hw-app .progress-track{height:6px;background:#3a3a3a;border-radius:3px;overflow:hidden}.hw-app .progress-fill{height:100%;background:#4a90d9;border-radius:3px;transition:width .3s ease}.hw-app #main{flex:1;display:flex;flex-direction:row;overflow:hidden}.hw-app .capture-section{flex:1;min-width:0;display:flex;flex-direction:column;overflow:hidden}.hw-app .capture-area-row{flex:1;display:flex;flex-direction:row;overflow:hidden;min-height:0}.hw-app .canvas-zone{width:26vw;min-width:156px;max-width:416px;flex-shrink:0;display:flex;flex-direction:column;overflow:hidden;padding:12px 8px 0 12px}.hw-app .dead-zone{flex:1;pointer-events:none}.hw-app .char-label{text-align:center;padding:10px 16px 4px;flex-shrink:0}.hw-app .char-display{font-size:40px;font-weight:300;color:#fff;letter-spacing:2px}.hw-app .char-type{font-size:12px;color:#888;margin-top:2px}.hw-app .canvas-wrapper{width:100%}.hw-app .canvas-wrapper,.hw-app .capture-canvas{-moz-user-select:none;user-select:none;-webkit-user-select:none}.hw-app .capture-canvas{background:white;border-radius:12px;touch-action:none;cursor:crosshair;display:block}.hw-app .action-bar{display:flex;gap:6px;padding:6px 0 4px;flex-shrink:0}.hw-app .action-btn{flex:1;padding:9px;border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer}.hw-app .action-btn:disabled{opacity:.5;cursor:not-allowed}.hw-app .btn-clear{background:#3a3a3a;color:#ccc}.hw-app .btn-preview{background:#5a5a5a;color:#fff}.hw-app .btn-accept{background:#34c759;color:#fff}.hw-app .btn-discard{background:#ff3b30;color:#fff}.hw-app .captures-area{flex:1;overflow-y:auto;min-height:0;padding:8px 8px 8px 0}.hw-app .captures-label{font-size:12px;color:#888;margin-bottom:10px;display:flex;align-items:center;gap:5px}.hw-app .captures-tiles{display:flex;flex-wrap:wrap;gap:10px}.hw-app .capture-tile{position:relative;width:80px;height:100px;background:#2a2a2a;border:1px solid #3a3a3a;border-radius:10px;cursor:pointer;overflow:hidden;transition:border-color .12s,background .12s}.hw-app .capture-tile:hover{border-color:#4a90d9;background:#252e3e}.hw-app .capture-tile-ref{position:absolute;top:5px;left:5px;width:20px;height:20px;background:rgba(0,0,0,.55);border:1px solid rgba(52,199,89,.4);border-radius:50%;color:#34c759;font-size:11px;display:flex;align-items:center;justify-content:center;cursor:pointer;padding:0;line-height:1;opacity:.3;transition:opacity .15s}.hw-app .capture-tile-ref--active{opacity:1;background:rgba(52,199,89,.15);border-color:#34c759}.hw-app .capture-tile-del{position:absolute;top:5px;right:5px;width:20px;height:20px;background:rgba(0,0,0,.55);border:1px solid rgba(255,59,48,.5);border-radius:50%;color:#ff3b30;font-size:9px;display:flex;align-items:center;justify-content:center;cursor:pointer;padding:0;line-height:1}.hw-app .capture-tile-del:disabled{opacity:.4;cursor:not-allowed}.hw-app .quality-dot{width:8px;height:8px;border-radius:50%;display:inline-block;flex-shrink:0}.hw-app .q-none{background:#ff3b30}.hw-app .q-one{background:#ff9f0a}.hw-app .q-good{background:#34c759}.hw-app .char-grid-overlay{position:fixed;inset:0;background:#1a1a1a;z-index:100;display:flex;flex-direction:column}.hw-app .char-grid-header{display:flex;align-items:center;padding:14px 16px;background:#2a2a2a;border-bottom:1px solid #3a3a3a;gap:12px}.hw-app .char-grid-header h2{flex:1;font-size:18px}.hw-app .btn-close-grid{background:none;border:none;color:#fff;font-size:24px;cursor:pointer}.hw-app .char-grid{flex:1;overflow-y:auto;padding:12px;display:flex;flex-wrap:wrap;gap:6px;align-content:flex-start}.hw-app .grid-section-label{width:100%;font-size:11px;color:#888;padding:4px 0 2px}.hw-app .grid-cell{width:52px;height:52px;display:flex;flex-direction:column;align-items:center;justify-content:center;border-radius:8px;background:#2a2a2a;cursor:pointer;border:2px solid transparent;gap:2px}.hw-app .grid-cell.active{border-color:#4a90d9}.hw-app .grid-cell .glyph-char{font-size:18px}.hw-app .grid-cell .glyph-dot{width:6px;height:6px;border-radius:50%}.hw-app .status-toast{position:fixed;bottom:20px;left:50%;transform:translateX(-50%);background:rgba(0,0,0,.8);color:#fff;padding:8px 16px;border-radius:20px;font-size:14px;pointer-events:none;z-index:200}.hw-app .error-msg{color:#ff3b30;font-size:13px;padding:4px 16px;text-align:center}.hw-app .empty-state{flex:1;display:flex;align-items:center;justify-content:center;color:#666;font-size:15px}.hw-app .glyph-roster{width:20%;min-width:90px;flex-shrink:0;display:flex;flex-direction:column;background:#161616;border-left:1px solid #242424;overflow:hidden}.hw-app .roster-header{padding:7px 10px 6px;font-size:9px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:#444;border-bottom:1px solid #222;flex-shrink:0}.hw-app .roster-scroll{flex:1;overflow-y:auto;overflow-x:hidden;scrollbar-width:thin;scrollbar-color:#2e2e2e transparent}.hw-app .roster-section-label{padding:8px 10px 3px;font-size:8px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:#333}.hw-app .roster-row{display:flex;align-items:center;gap:5px;padding:5px 6px 5px 8px;cursor:pointer;border-left:2px solid transparent;transition:background .12s;min-height:46px;overflow:hidden}.hw-app .roster-row:hover{background:#1c1c1c}.hw-app .roster-row--active{background:#192030;border-left-color:#4a90d9}.hw-app .roster-char{font-size:14px;width:20px;text-align:center;flex-shrink:0;color:#c0c0c0;line-height:1;font-weight:500}.hw-app .roster-thumbs{display:flex;align-items:center;gap:3px;overflow:hidden;flex:1;min-width:0}.hw-app .roster-thumb{flex-shrink:0;border-radius:3px;background:#212121;display:block}.hw-app .roster-empty-dash{color:#2c2c2c;font-size:12px}.hw-app .diagram-area{flex:1;display:flex;flex-direction:row;overflow:hidden;min-height:0}.hw-app .diagram-roster{width:220px;flex-shrink:0;background:#222;border-right:1px solid #3a3a3a;display:flex;flex-direction:column;overflow:hidden}.hw-app .btn-new-diagram{margin:10px;padding:9px 12px;background:#4a90d9;border:none;border-radius:8px;color:white;font-size:14px;cursor:pointer;flex-shrink:0}.hw-app .diagram-roster-empty{padding:16px;font-size:13px;color:#666;text-align:center}.hw-app .diagram-list{list-style:none;overflow-y:auto;flex:1;padding:4px 0}.hw-app .diagram-list-item{display:flex;align-items:flex-start;gap:6px;padding:8px 10px;cursor:pointer;border-radius:6px;margin:2px 6px;transition:background .12s}.hw-app .diagram-list-item:hover{background:#2a2a2a}.hw-app .diagram-list-item--selected{background:#253040}.hw-app .diagram-list-info{flex:1;display:flex;flex-direction:column;gap:2px;min-width:0}.hw-app .diagram-list-name{font-size:14px}.hw-app .diagram-list-date{font-size:11px;color:#666;flex-shrink:0}.hw-app .btn-delete-diagram{background:none;border:none;color:#ff3b30;font-size:18px;cursor:pointer;padding:0 2px;line-height:1;flex-shrink:0;opacity:.5}.hw-app .btn-delete-diagram:hover{opacity:1}.hw-app .diagram-workspace{flex:1;display:flex;flex-direction:column;overflow:hidden;min-width:0}.hw-app .diagram-toolbar{display:flex;align-items:center;gap:8px;padding:8px 12px;background:#2a2a2a;border-bottom:1px solid #3a3a3a;flex-shrink:0}.hw-app .diagram-name{flex:1;font-size:15px;font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.hw-app .tool-btn{padding:7px 14px;border:none;border-radius:7px;background:#3a3a3a;color:#e0e0e0;font-size:14px;cursor:pointer;flex-shrink:0}.hw-app .tool-btn:disabled{opacity:.35;cursor:not-allowed}.hw-app .tool-btn--save{background:#34c759;color:#fff}.hw-app .tool-btn--export{background:#5a7a4a;color:#fff}.hw-app .tool-btn--cancel{background:#555;color:#ccc}.hw-app .diagram-canvas-area{flex:1;display:flex;align-items:center;justify-content:center;overflow:hidden;background:#181818;padding:16px}.hw-app .diagram-canvas-wrapper{display:flex;align-items:center;justify-content:center;width:100%;height:100%}.hw-app .diagram-canvas{background:white;border-radius:8px;touch-action:none;cursor:crosshair;display:block;max-width:100%;max-height:100%}.hw-app .adjust-tab{flex:1;flex-direction:column}.hw-app .adjust-main,.hw-app .adjust-tab{display:flex;overflow:hidden;min-height:0}.hw-app .adjust-main{flex:1;flex-direction:row}.hw-app .adjust-char-list{width:100px;flex-shrink:0;display:flex;flex-direction:column;background:#161616;border-right:1px solid #242424;overflow:hidden}.hw-app .adjust-char-row{display:flex;align-items:center;justify-content:space-between;padding:7px 8px 7px 10px;cursor:pointer;border-left:2px solid transparent;transition:background .12s}.hw-app .adjust-char-row:hover{background:#1c1c1c}.hw-app .adjust-char-row--active{background:#192030;border-left-color:#4a90d9}.hw-app .adjust-capture-count{font-size:11px;color:#555}.hw-app .adjust-panel{flex:1;display:flex;flex-direction:column;overflow:hidden;min-width:0}.hw-app .adjust-thumbnails{display:flex;flex-direction:row;gap:8px;padding:12px 16px;background:#1e1e1e;border-bottom:1px solid #2a2a2a;flex-shrink:0;overflow-x:auto}.hw-app .adjust-thumbnail{display:flex;flex-direction:column;align-items:center;gap:4px;cursor:pointer;border-radius:8px;border:2px solid transparent;padding:4px;background:#2a2a2a;flex-shrink:0;transition:border-color .12s}.hw-app .adjust-thumbnail canvas{background:white;border-radius:4px}.hw-app .adjust-thumbnail--active{border-color:#4a90d9}.hw-app .adjust-thumb-label{font-size:10px;color:#666}.hw-app .adjust-controls{display:flex;flex-direction:column;gap:12px;padding:16px;background:#202020;border-bottom:1px solid #2a2a2a;flex-shrink:0}.hw-app .adjust-slider-row{display:flex;align-items:center;gap:10px}.hw-app .adjust-slider-label{font-size:13px;color:#999;width:56px;flex-shrink:0}.hw-app .adjust-slider{flex:1;accent-color:#4a90d9}.hw-app .adjust-slider-value{font-size:13px;color:#ccc;width:38px;text-align:right;flex-shrink:0;font-variant-numeric:tabular-nums}.hw-app .adjust-reset-btn{align-self:flex-start;padding:6px 14px;background:#3a3a3a;border:none;border-radius:7px;color:#ccc;font-size:13px;cursor:pointer}.hw-app .adjust-hint{padding:20px 16px;font-size:13px;color:#555}.hw-app .adjust-preview-area{flex:1;display:flex;flex-direction:column;overflow:hidden;min-height:0;padding:12px 16px;gap:10px}.hw-app .adjust-phrase-input{background:#2a2a2a;border:none;border-radius:8px;color:#f0f0f0;padding:8px 12px;font-size:14px;flex-shrink:0;-moz-user-select:text;user-select:text;-webkit-user-select:text}.hw-app .adjust-preview-canvas-wrap{flex:1;overflow:hidden;background:white;border-radius:10px;min-height:0}.hw-app .adjust-preview-canvas{width:100%;height:100%;display:block}.hw-app .dialog-overlay{position:fixed;inset:0;background:rgba(0,0,0,.7);display:flex;align-items:center;justify-content:center;z-index:1000}.hw-app .dialog{background:#2a2a2a;border-radius:14px;padding:24px;width:320px;display:flex;flex-direction:column;gap:14px}.hw-app .dialog-title{font-size:18px;font-weight:600}.hw-app .dialog-label{display:flex;flex-direction:column;gap:6px;font-size:13px;color:#aaa}.hw-app .dialog-input{background:#3a3a3a;border:none;border-radius:8px;color:#f0f0f0;padding:9px 12px;font-size:15px}.hw-app .aspect-ratio-options{display:flex;gap:8px;flex-wrap:wrap}.hw-app .aspect-btn{padding:7px 14px;border:1px solid #4a4a4a;border-radius:7px;background:#333;color:#ccc;font-size:14px;cursor:pointer}.hw-app .aspect-btn--active{background:#4a90d9;border-color:#4a90d9;color:white}.hw-app .dialog-actions{display:flex;gap:10px;justify-content:flex-end;margin-top:4px}.hw-app .btn-dialog-cancel{background:#444;color:#ccc}.hw-app .btn-dialog-cancel,.hw-app .btn-dialog-confirm{padding:9px 18px;border:none;border-radius:8px;font-size:15px;cursor:pointer}.hw-app .btn-dialog-confirm{background:#4a90d9;color:white}@font-face{font-family:Noto Sans;font-style:normal;font-weight:100 900;font-stretch:100%;font-display:swap;src:url(/_next/static/media/82ef96de0e8f4d8c-s.woff2) format("woff2");unicode-range:u+0460-052f,u+1c80-1c8a,u+20b4,u+2de0-2dff,u+a640-a69f,u+fe2e-fe2f}@font-face{font-family:Noto Sans;font-style:normal;font-weight:100 900;font-stretch:100%;font-display:swap;src:url(/_next/static/media/a6ecd16fa044d500-s.woff2) format("woff2");unicode-range:u+0301,u+0400-045f,u+0490-0491,u+04b0-04b1,u+2116}@font-face{font-family:Noto Sans;font-style:normal;font-weight:100 900;font-stretch:100%;font-display:swap;src:url(/_next/static/media/bd82c78e5b7b3fe9-s.woff2) format("woff2");unicode-range:u+0900-097f,u+1cd0-1cf9,u+200c-200d,u+20a8,u+20b9,u+20f0,u+25cc,u+a830-a839,u+a8e0-a8ff,u+11b00-11b09}@font-face{font-family:Noto Sans;font-style:normal;font-weight:100 900;font-stretch:100%;font-display:swap;src:url(/_next/static/media/c32c8052c071fc42-s.woff2) format("woff2");unicode-range:u+1f??}@font-face{font-family:Noto Sans;font-style:normal;font-weight:100 900;font-stretch:100%;font-display:swap;src:url(/_next/static/media/6f22fce21a7c433c-s.woff2) format("woff2");unicode-range:u+0370-0377,u+037a-037f,u+0384-038a,u+038c,u+038e-03a1,u+03a3-03ff}@font-face{font-family:Noto Sans;font-style:normal;font-weight:100 900;font-stretch:100%;font-display:swap;src:url(/_next/static/media/1d8a05b60287ae6c-s.woff2) format("woff2");unicode-range:u+0102-0103,u+0110-0111,u+0128-0129,u+0168-0169,u+01a0-01a1,u+01af-01b0,u+0300-0301,u+0303-0304,u+0308-0309,u+0323,u+0329,u+1ea0-1ef9,u+20ab}@font-face{font-family:Noto Sans;font-style:normal;font-weight:100 900;font-stretch:100%;font-display:swap;src:url(/_next/static/media/77c207b095007c34-s.woff2) format("woff2");unicode-range:u+0100-02ba,u+02bd-02c5,u+02c7-02cc,u+02ce-02d7,u+02dd-02ff,u+0304,u+0308,u+0329,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:Noto Sans;font-style:normal;font-weight:100 900;font-stretch:100%;font-display:swap;src:url(/_next/static/media/1755441e3a2fa970-s.p.woff2) format("woff2");unicode-range:u+00??,u+0131,u+0152-0153,u+02bb-02bc,u+02c6,u+02da,u+02dc,u+0304,u+0308,u+0329,u+2000-206f,u+20ac,u+2122,u+2191,u+2193,u+2212,u+2215,u+feff,u+fffd}@font-face{font-family:Noto Sans Fallback;src:local("Arial");ascent-override:100.54%;descent-override:27.56%;line-gap-override:0.00%;size-adjust:106.33%}.__className_c85df0{font-family:Noto Sans,Noto Sans Fallback;font-style:normal}.__variable_c85df0{--font-body:"Noto Sans","Noto Sans Fallback"}@font-face{font-family:Shadows Into Light;font-style:normal;font-weight:400;font-display:swap;src:url(/_next/static/media/3c0a36d4615ad53c-s.woff2) format("woff2");unicode-range:u+0100-02ba,u+02bd-02c5,u+02c7-02cc,u+02ce-02d7,u+02dd-02ff,u+0304,u+0308,u+0329,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:Shadows Into Light;font-style:normal;font-weight:400;font-display:swap;src:url(/_next/static/media/cedc0d4e6b719cc0-s.p.woff2) format("woff2");unicode-range:u+00??,u+0131,u+0152-0153,u+02bb-02bc,u+02c6,u+02da,u+02dc,u+0304,u+0308,u+0329,u+2000-206f,u+20ac,u+2122,u+2191,u+2193,u+2212,u+2215,u+feff,u+fffd}@font-face{font-family:Shadows Into Light Fallback;src:local("Arial");ascent-override:138.94%;descent-override:51.05%;line-gap-override:0.00%;size-adjust:84.56%}.__className_2e9024{font-family:Shadows Into Light,Shadows Into Light Fallback;font-weight:400;font-style:normal}.__variable_2e9024{--font-hand:"Shadows Into Light","Shadows Into Light Fallback"}