@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-backdrop-blur:initial;--tw-backdrop-brightness:initial;--tw-backdrop-contrast:initial;--tw-backdrop-grayscale:initial;--tw-backdrop-hue-rotate:initial;--tw-backdrop-invert:initial;--tw-backdrop-opacity:initial;--tw-backdrop-saturate:initial;--tw-backdrop-sepia:initial}}}@layer theme{:root,:host{--font-sans:ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji";--font-mono:ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;--spacing:.25rem;--radius-sm:.25rem;--radius-md:.375rem;--radius-lg:.5rem;--shadow-sm:0 1px 3px 0 #0000001a, 0 1px 2px -1px #0000001a;--default-transition-duration:.15s;--default-transition-timing-function:cubic-bezier(.4, 0, .2, 1);--default-font-family:var(--font-sans);--default-mono-font-family:var(--font-mono)}}@layer base{*,:after,:before,::backdrop{box-sizing:border-box;border:0 solid;margin:0;padding:0}::file-selector-button{box-sizing:border-box;border:0 solid;margin:0;padding:0}html,:host{-webkit-text-size-adjust:100%;tab-size:4;line-height:1.5;font-family:var(--default-font-family,ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji");font-feature-settings:var(--default-font-feature-settings,normal);font-variation-settings:var(--default-font-variation-settings,normal);-webkit-tap-highlight-color:transparent}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;-webkit-text-decoration:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:var(--default-mono-font-family,ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace);font-feature-settings:var(--default-mono-font-feature-settings,normal);font-variation-settings:var(--default-mono-font-variation-settings,normal);font-size:1em}small{font-size:80%}sub,sup{vertical-align:baseline;font-size:75%;line-height:0;position:relative}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}:-moz-focusring{outline:auto}progress{vertical-align:baseline}summary{display:list-item}ol,ul,menu{list-style:none}img,svg,video,canvas,audio,iframe,embed,object{vertical-align:middle;display:block}img,video{max-width:100%;height:auto}button,input,select,optgroup,textarea{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}::file-selector-button{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}:where(select:is([multiple],[size])) optgroup{font-weight:bolder}:where(select:is([multiple],[size])) optgroup option{padding-inline-start:20px}::file-selector-button{margin-inline-end:4px}::placeholder{opacity:1}@supports (not ((-webkit-appearance:-apple-pay-button))) or (contain-intrinsic-size:1px){::placeholder{color:currentColor}@supports (color:color-mix(in lab,red,red)){::placeholder{color:color-mix(in oklab,currentcolor 50%,transparent)}}}textarea{resize:vertical}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-date-and-time-value{min-height:1lh;text-align:inherit}::-webkit-datetime-edit{display:inline-flex}::-webkit-datetime-edit-fields-wrapper{padding:0}::-webkit-datetime-edit{padding-block:0}::-webkit-datetime-edit-year-field{padding-block:0}::-webkit-datetime-edit-month-field{padding-block:0}::-webkit-datetime-edit-day-field{padding-block:0}::-webkit-datetime-edit-hour-field{padding-block:0}::-webkit-datetime-edit-minute-field{padding-block:0}::-webkit-datetime-edit-second-field{padding-block:0}::-webkit-datetime-edit-millisecond-field{padding-block:0}::-webkit-datetime-edit-meridiem-field{padding-block:0}::-webkit-calendar-picker-indicator{line-height:1}:-moz-ui-invalid{box-shadow:none}button,input:where([type=button],[type=reset],[type=submit]){appearance:button}::file-selector-button{appearance:button}::-webkit-inner-spin-button{height:auto}::-webkit-outer-spin-button{height:auto}[hidden]:where(:not([hidden=until-found])){display:none!important}}@layer components;@layer utilities{.static{position:static}.start{inset-inline-start:var(--spacing)}.mb-3{margin-bottom:calc(var(--spacing) * 3)}.mb-4{margin-bottom:calc(var(--spacing) * 4)}.block{display:block}.contents{display:contents}.flex{display:flex}.hidden{display:none}.table{display:table}.flex-shrink{flex-shrink:1}.border-collapse{border-collapse:collapse}.transform{transform:var(--tw-rotate-x,) var(--tw-rotate-y,) var(--tw-rotate-z,) var(--tw-skew-x,) var(--tw-skew-y,)}.flex-wrap{flex-wrap:wrap}.truncate{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.border{border-style:var(--tw-border-style);border-width:1px}.backdrop-filter{-webkit-backdrop-filter:var(--tw-backdrop-blur,) var(--tw-backdrop-brightness,) var(--tw-backdrop-contrast,) var(--tw-backdrop-grayscale,) var(--tw-backdrop-hue-rotate,) var(--tw-backdrop-invert,) var(--tw-backdrop-opacity,) var(--tw-backdrop-saturate,) var(--tw-backdrop-sepia,);backdrop-filter:var(--tw-backdrop-blur,) var(--tw-backdrop-brightness,) var(--tw-backdrop-contrast,) var(--tw-backdrop-grayscale,) var(--tw-backdrop-hue-rotate,) var(--tw-backdrop-invert,) var(--tw-backdrop-opacity,) var(--tw-backdrop-saturate,) var(--tw-backdrop-sepia,)}.transition{transition-property:color,background-color,border-color,outline-color,text-decoration-color,fill,stroke,--tw-gradient-from,--tw-gradient-via,--tw-gradient-to,opacity,box-shadow,transform,translate,scale,rotate,filter,-webkit-backdrop-filter,backdrop-filter,display,content-visibility,overlay,pointer-events;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}}:root{--bg-base:#030712;--bg-surface:#111827;--bg-inset:#1f2937;--border:#1f2937;--border-subtle:#374151;--text-primary:#f9fafb;--text-secondary:#9ca3af;--text-muted:#6b7280;--text-label:#9ca3af;--accent:#4ade80;--accent-hover:#86efac;--accent-cta:#22c55e;--accent-cta-h:#4ade80;--input-ph:#4b5563;--result-good-bg:#052e16;--result-good-bd:#15803d;--result-ok-bg:#1c1400;--result-ok-bd:#a16207;--result-bad-bg:#1a0000;--result-bad-bd:#991b1b;--radius-sm:.5rem;--radius-md:.75rem;--radius-lg:1rem;--radius-xl:1.5rem;--shadow-sm:0 2px 8px #0000001a;--shadow-soft:0 10px 30px #0003;--shadow-lift:0 14px 34px #00000047;--focus-ring:0 0 0 3px var(--accent)}@supports (color:color-mix(in lab,red,red)){:root{--focus-ring:0 0 0 3px color-mix(in srgb, var(--accent) 35%, transparent)}}:root{--space-xs:.25rem;--space-sm:.5rem;--space-md:1rem;--space-lg:1.5rem;--space-xl:2rem;--space-2xl:3rem;--transition-fast:.15s;--transition-base:.2s;--transition-slow:.3s;--ease-smooth:cubic-bezier(.4, 0, .2, 1);--nav-control-height:2.15rem;--max-width-container:64rem;--max-width-narrow:42rem;--max-width-wide:80rem}@media(prefers-color-scheme:light){:root:not([data-theme=dark]){--bg-base:#f9fafb;--bg-surface:#fff;--bg-inset:#f3f4f6;--border:#e5e7eb;--border-subtle:#d1d5db;--text-primary:#111827;--text-secondary:#374151;--text-muted:#6b7280;--text-label:#4b5563;--accent:#16a34a;--accent-hover:#15803d;--accent-cta:#16a34a;--accent-cta-h:#15803d;--input-ph:#9ca3af;--result-good-bg:#f0fdf4;--result-good-bd:#86efac;--result-ok-bg:#fefce8;--result-ok-bd:#fde047;--result-bad-bg:#fff1f2;--result-bad-bd:#fca5a5}}[data-theme=light]{--bg-base:#f9fafb;--bg-surface:#fff;--bg-inset:#f3f4f6;--border:#e5e7eb;--border-subtle:#d1d5db;--text-primary:#111827;--text-secondary:#374151;--text-muted:#6b7280;--text-label:#4b5563;--accent:#16a34a;--accent-hover:#15803d;--accent-cta:#16a34a;--accent-cta-h:#15803d;--input-ph:#9ca3af;--result-good-bg:#f0fdf4;--result-good-bd:#86efac;--result-ok-bg:#fefce8;--result-ok-bd:#fde047;--result-bad-bg:#fff1f2;--result-bad-bd:#fca5a5}[data-theme=dark]{--bg-base:#030712;--bg-surface:#111827;--bg-inset:#1f2937;--border:#1f2937;--border-subtle:#374151;--text-primary:#f9fafb;--text-secondary:#9ca3af;--text-muted:#6b7280;--text-label:#9ca3af;--accent:#4ade80;--accent-hover:#86efac;--accent-cta:#22c55e;--accent-cta-h:#4ade80;--input-ph:#4b5563;--result-good-bg:#052e16;--result-good-bd:#15803d;--result-ok-bg:#1c1400;--result-ok-bd:#a16207;--result-bad-bg:#1a0000;--result-bad-bd:#991b1b}*,:before,:after{box-sizing:border-box}html{scroll-behavior:smooth;overflow-x:clip}body{background-color:var(--bg-base);color:var(--text-primary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizelegibility;transition:background-color var(--transition-base),color var(--transition-base);margin:0;font-family:Inter,ui-sans-serif,system-ui,-apple-system,Segoe UI,Roboto,Helvetica Neue,Arial,Noto Sans,Apple Color Emoji,Segoe UI Emoji,Segoe UI Symbol;line-height:1.6;overflow-x:clip}.page-wrapper{background-color:var(--bg-base);width:100%;min-height:100vh;color:var(--text-primary);transition:background-color var(--transition-base),color var(--transition-base);flex-direction:column;display:flex;overflow-x:clip}.page-content{min-width:0;max-width:var(--max-width-container);width:100%;padding:var(--space-lg) var(--space-md);flex:1 1 0;margin-left:auto;margin-right:auto}.page-narrow{max-width:var(--max-width-narrow);margin-left:auto;margin-right:auto}.page-narrow>*+*{margin-top:var(--space-lg)}.flex{display:flex}.inline-flex{display:inline-flex}.grid{display:grid}.hidden{display:none}.block{display:block}.flex-col{flex-direction:column}.flex-row{flex-direction:row}.items-center{align-items:center}.items-start{align-items:flex-start}.items-end{align-items:flex-end}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.justify-end{justify-content:flex-end}.flex-1{flex:1 1 0}.flex-wrap{flex-wrap:wrap}.gap-1{gap:var(--space-xs)}.gap-2{gap:var(--space-sm)}.gap-3{gap:.75rem}.gap-4{gap:var(--space-md)}.gap-6{gap:var(--space-lg)}.gap-8{gap:var(--space-xl)}.m-0{margin:0}.mt-1{margin-top:var(--space-xs)}.mt-2{margin-top:var(--space-sm)}.mt-4{margin-top:var(--space-md)}.mt-6{margin-top:var(--space-lg)}.mb-1{margin-bottom:var(--space-xs)}.mb-2{margin-bottom:var(--space-sm)}.mb-3{margin-bottom:.75rem}.mb-4{margin-bottom:var(--space-md)}.mb-6{margin-bottom:var(--space-lg)}.p-2{padding:var(--space-sm)}.p-4{padding:var(--space-md)}.p-6{padding:var(--space-lg)}.text-center{text-align:center}.text-left{text-align:left}.text-right{text-align:right}.font-bold{font-weight:700}.font-semibold{font-weight:600}.font-medium{font-weight:500}.uppercase{text-transform:uppercase}.w-full{width:100%}.h-full{height:100%}.min-h-screen{min-height:100vh}.relative{position:relative}.absolute{position:absolute}.fixed{position:fixed}.sticky{position:sticky}.overflow-hidden{overflow:hidden}.overflow-auto{overflow:auto}.rounded{border-radius:var(--radius-sm)}.rounded-md{border-radius:var(--radius-md)}.rounded-lg{border-radius:var(--radius-lg)}.rounded-full{border-radius:9999px}.cursor-pointer{cursor:pointer}.cursor-not-allowed{cursor:not-allowed}.transition{transition:all var(--transition-base) var(--ease-smooth)}.transition-fast{transition:all var(--transition-fast) var(--ease-smooth)}.opacity-0{opacity:0}.opacity-50{opacity:.5}.opacity-100{opacity:1}.pointer-events-none{pointer-events:none}.pointer-events-auto{pointer-events:auto}.page-wide{max-width:var(--max-width-wide);margin-left:auto;margin-right:auto}.navbar{border-bottom:1px solid var(--border);z-index:50;-webkit-backdrop-filter:saturate(130%)blur(10px);backdrop-filter:saturate(130%)blur(10px);background-color:var(--bg-surface);position:sticky;top:0}@supports (color:color-mix(in lab,red,red)){.navbar{background-color:color-mix(in srgb,var(--bg-surface) 88%,transparent)}}.navbar{transition:background-color var(--transition-base),border-color var(--transition-base);overflow:visible}.navbar-inner{max-width:var(--max-width-container);padding:.55rem var(--space-md);justify-content:space-between;align-items:center;margin-left:auto;margin-right:auto;display:flex}.navbar-brand{letter-spacing:.1em;color:var(--accent);align-items:center;gap:.5rem;font-size:1.12rem;font-weight:700;line-height:1.4rem;transition:color .15s;display:flex}.navbar-brand:hover{color:var(--accent-hover)}.navbar-brand img{width:1.5rem;height:1.5rem}.navbar-desktop{visibility:hidden;flex:none;width:0;height:0;display:none;overflow:hidden}@media(min-width:640px){.navbar-desktop{visibility:visible;flex:1 1 0;width:auto;height:auto;display:flex;overflow:visible}}.navbar-links{align-items:center;gap:1.5rem;font-size:.875rem;font-weight:500;line-height:1.25rem;display:flex}.navbar-link{height:var(--nav-control-height);box-sizing:border-box;color:var(--text-secondary);align-items:center;padding:0 .35rem;line-height:1.25rem;transition:color .15s;display:inline-flex;position:relative}.navbar-link:hover{color:var(--accent)}.navbar-link:after{content:"";background:var(--accent);transform-origin:0;width:100%;height:2px;transition:transform .18s;position:absolute;bottom:-.2rem;left:0;transform:scaleX(0)}.navbar-link:hover:after{transform:scaleX(1)}.navbar-right{flex:auto;justify-content:flex-end;align-items:center;gap:.6rem;display:flex}.navbar-divider{background:var(--border-subtle);width:1px;height:1.5rem;margin:0 .35rem}.navbar-btn-ghost,.navbar-btn-accent{height:var(--nav-control-height);box-sizing:border-box;cursor:pointer;border:none;border-radius:.5rem;padding:0 .72rem;font-size:.875rem;font-weight:500;line-height:1.25rem;transition:background .15s,color .15s}.navbar-btn-ghost{color:var(--text-secondary);background:0 0}.navbar-btn-ghost:hover{background:var(--bg-inset)}.navbar-btn-accent{background:var(--accent);color:#000;font-weight:600}.navbar-btn-accent:hover{background:var(--accent-hover)}.user-menu-wrapper{position:relative}.navbar-user-btn{height:var(--nav-control-height);box-sizing:border-box;color:var(--text-secondary);cursor:pointer;background:0 0;border:none;border-radius:0;align-items:center;gap:.4rem;padding:0 .35rem;font-size:.875rem;font-weight:500;line-height:1.25rem;transition:color .15s;display:flex;position:relative}.navbar-user-btn:hover{color:var(--accent)}.navbar-user-btn:after{content:"";background:var(--accent);transform-origin:0;width:100%;height:2px;transition:transform .18s;position:absolute;bottom:-.2rem;left:0;transform:scaleX(0)}.navbar-user-btn:hover:after{transform:scaleX(1)}.user-dropdown{background:var(--bg-surface);border:1px solid var(--border);z-index:100;border-radius:.5rem;min-width:10rem;position:absolute;top:calc(100% + .5rem);right:0;overflow:hidden;box-shadow:0 8px 16px #0000004d}.user-dropdown-item{text-align:left;width:100%;color:var(--text-secondary);cursor:pointer;background:0 0;border:none;align-items:center;gap:.5rem;padding:.65rem 1rem;font-size:.875rem;font-weight:500;text-decoration:none;transition:background .15s,color .15s;display:flex}.user-dropdown-item:hover{background:var(--bg-inset);color:var(--accent)}.theme-icon-btn{height:var(--nav-control-height);box-sizing:border-box;min-width:3rem;color:var(--text-secondary);cursor:pointer;background:0 0;border:none;border-radius:0;justify-content:center;align-items:center;padding:0 .35rem;font-size:1.1rem;line-height:1;transition:color .15s;display:inline-flex;position:relative}.theme-icon-btn:hover{color:var(--accent)}.theme-icon-btn:after{content:"";background:var(--accent);transform-origin:0;width:100%;height:2px;transition:transform .18s;position:absolute;bottom:-.2rem;left:0;transform:scaleX(0)}.theme-icon-btn:hover:after{transform:scaleX(1)}.navbar-mobile-controls{align-items:center;gap:.5rem;display:flex}@media(min-width:640px){.navbar-mobile-controls{display:none}}.hamburger{height:var(--nav-control-height);box-sizing:border-box;border:1px solid var(--border-subtle);min-width:3rem;color:var(--text-muted);cursor:pointer;background:0 0;border-radius:.5rem;justify-content:center;align-items:center;padding:0 .7rem;font-size:1.125rem;line-height:1;transition:color .15s,border-color .15s,background .15s;display:inline-flex}.hamburger:hover{color:var(--accent);border-color:var(--accent);background:var(--bg-inset)}.mobile-menu{background-color:var(--bg-surface);border-top:1px solid var(--border);border-bottom:1px solid var(--border);z-index:49;border-radius:0 0 .9rem .9rem;flex-direction:column;display:flex;position:absolute;top:100%;left:0;right:0;overflow:hidden;box-shadow:0 8px 16px #0000004d}.mobile-link{color:var(--text-secondary);border-bottom:1px solid var(--border);align-items:center;gap:.625rem;padding:.75rem 1rem;font-size:.875rem;font-weight:500;line-height:1.25rem;transition:color .15s,background-color .15s;display:flex}.mobile-link:hover{color:var(--accent);background-color:var(--bg-inset)}.mobile-link-btn{text-align:left;cursor:pointer;background:0 0;border:none;width:100%}.mobile-divider{background-color:var(--border);height:1px;margin:.25rem 0}.footer{background-color:var(--bg-surface);border-top:1px solid var(--border);padding:.7rem var(--space-md);text-align:center;color:var(--text-muted);transition:background-color var(--transition-base),border-color var(--transition-base);font-size:.8125rem;line-height:1.2rem}.card{background-color:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--space-lg);box-shadow:var(--shadow-soft);transition:background-color var(--transition-base),border-color var(--transition-base),box-shadow var(--transition-base)}.card:hover{box-shadow:var(--shadow-lift)}.card-sm{background-color:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);min-width:0;box-shadow:var(--shadow-soft);transition:background-color var(--transition-base),border-color var(--transition-base),box-shadow var(--transition-base);padding:1.25rem}.card-sm:hover{box-shadow:var(--shadow-lift)}.card-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.1em;margin-bottom:1rem;font-size:.75rem;line-height:1rem}.divider{border-color:var(--border);margin-top:1.5rem;margin-bottom:1.5rem}.page-title{color:var(--accent);letter-spacing:-.02em;font-size:1.875rem;font-weight:800;line-height:2.25rem}.section-title{color:var(--accent);letter-spacing:-.015em;margin-bottom:.75rem;font-size:1.5rem;font-weight:700;line-height:2rem}.sub-title{color:var(--text-primary);margin-bottom:.25rem;font-weight:600}.body-text{color:var(--text-secondary);font-size:.875rem;line-height:1.625}.label-text{color:var(--text-label);font-size:.75rem;line-height:1rem}.tooltip-icon{color:var(--text-muted);cursor:help;vertical-align:middle;align-items:center;margin-left:.15rem;display:inline-flex;position:relative}.tooltip-icon:before{content:attr(data-tooltip);background:var(--bg-inset);border:1px solid var(--border-subtle);color:var(--text-secondary);border-radius:var(--radius-sm);white-space:normal;pointer-events:none;opacity:0;z-index:50;width:max-content;max-width:180px;box-shadow:var(--shadow-sm);padding:.4rem .6rem;font-size:.7rem;line-height:1.4;transition:opacity .15s;position:absolute;bottom:calc(100% + 8px);left:50%;transform:translate(-50%)}.tooltip-icon:after{content:"";border:5px solid #0000;border-top-color:var(--border-subtle);pointer-events:none;opacity:0;z-index:50;transition:opacity .15s;position:absolute;bottom:calc(100% + 2px);left:50%;transform:translate(-50%)}.tooltip-icon:hover:before,.tooltip-icon:hover:after{opacity:1}.accent-text{color:var(--accent);font-weight:600}.muted{color:var(--text-muted);font-size:.75rem;line-height:1rem}.link{color:var(--accent)}.link:hover{text-decoration:underline}.btn-primary{width:100%;padding:.75rem var(--space-md);border-radius:var(--radius-md);color:#fff;cursor:pointer;transition:background-color var(--transition-fast),transform var(--transition-fast);background-color:#16a34a;border:none;justify-content:center;align-items:center;gap:.375rem;font-weight:700;display:flex}.btn-primary:hover{background-color:#15803d;transform:translateY(-1px)}.btn-primary:active{transform:translateY(0)}.btn-danger{padding:var(--space-sm) var(--space-md);border-radius:var(--radius-md);color:#fff;cursor:pointer;transition:background-color var(--transition-fast),transform var(--transition-fast);background-color:#b91c1c;border:1px solid #0000;flex:1 1 0;justify-content:center;align-items:center;gap:.4rem;font-weight:700;display:inline-flex}.btn-danger:hover{background-color:#991b1b;transform:translateY(-1px)}.btn-danger:active{transform:translateY(0)}.btn-success{padding:var(--space-sm) var(--space-md);border-radius:var(--radius-md);color:#fff;cursor:pointer;transition:background-color var(--transition-fast),transform var(--transition-fast);background-color:#16a34a;border:1px solid #0000;flex:1 1 0;justify-content:center;align-items:center;gap:.4rem;font-weight:700;display:inline-flex}.btn-success:hover{background-color:#15803d;transform:translateY(-1px)}.btn-success:active{transform:translateY(0)}.btn-ghost{padding:var(--space-sm) var(--space-md);border-radius:var(--radius-md);border:1px solid var(--border-subtle);color:var(--text-secondary);cursor:pointer;transition:border-color var(--transition-fast),color var(--transition-fast),background-color var(--transition-fast);background:0 0;flex:1 1 0;justify-content:center;align-items:center;gap:.4rem;font-weight:500;display:inline-flex}.btn-ghost:disabled{opacity:.3;cursor:not-allowed}.btn-ghost:hover:not(:disabled){border-color:var(--accent);color:var(--accent);background-color:var(--accent)}@supports (color:color-mix(in lab,red,red)){.btn-ghost:hover:not(:disabled){background-color:color-mix(in srgb,var(--accent) 5%,transparent)}}.btn-outline{width:100%;padding:var(--space-sm) var(--space-md);border-radius:var(--radius-md);border:1px solid var(--border-subtle);color:var(--text-secondary);cursor:pointer;transition:border-color var(--transition-fast),color var(--transition-fast),background-color var(--transition-fast);background:0 0;font-size:.875rem;font-weight:500;line-height:1.25rem}.btn-outline:hover{border-color:var(--accent);color:var(--accent);background-color:var(--accent)}@supports (color:color-mix(in lab,red,red)){.btn-outline:hover{background-color:color-mix(in srgb,var(--accent) 5%,transparent)}}.btn-regen{border-radius:var(--radius-md);border:1px solid var(--border-subtle);width:100%;color:var(--text-secondary);cursor:pointer;background:0 0;justify-content:center;align-items:center;gap:.375rem;margin-top:.75rem;padding:.5rem 1rem;font-size:.875rem;font-weight:500;line-height:1.25rem;transition:border-color .15s,color .15s,background .15s;display:flex}.btn-regen:hover{border-color:var(--accent);color:var(--accent)}.btn-regen.btn-regen-success,.btn-regen.btn-regen-success:hover{border-color:var(--accent)}@supports (color:color-mix(in lab,red,red)){.btn-regen.btn-regen-success,.btn-regen.btn-regen-success:hover{border-color:color-mix(in srgb,var(--accent) 55%,var(--border-subtle))}}.btn-regen.btn-regen-success,.btn-regen.btn-regen-success:hover{color:var(--accent);background:var(--accent)}@supports (color:color-mix(in lab,red,red)){.btn-regen.btn-regen-success,.btn-regen.btn-regen-success:hover{background:color-mix(in srgb,var(--accent) 14%,transparent)}}.btn-cta{border-radius:var(--radius-md);background-color:var(--accent-cta);color:#fff;cursor:pointer;border:none;padding:.75rem 2rem;font-size:1.125rem;font-weight:700;line-height:1.75rem;transition:background-color .15s;display:inline-block}.btn-cta:hover{background-color:var(--accent-cta-h)}.input{width:100%;padding:var(--space-sm) .75rem;border-radius:var(--radius-md);border:1px solid var(--border-subtle);background-color:var(--bg-inset);color:var(--text-primary);transition:background-color var(--transition-base),border-color var(--transition-base),color var(--transition-base),box-shadow var(--transition-fast);font-size:.875rem;line-height:1.25rem}.input:hover{border-color:var(--accent)}@supports (color:color-mix(in lab,red,red)){.input:hover{border-color:color-mix(in srgb,var(--accent) 45%,var(--border-subtle))}}.input:focus{border-color:var(--accent);box-shadow:var(--focus-ring);outline:none}.select{padding:var(--space-sm) .75rem;border-radius:var(--radius-md);border:1px solid var(--border-subtle);background-color:var(--bg-inset);color:var(--text-primary);transition:background-color var(--transition-base),border-color var(--transition-base),color var(--transition-base),box-shadow var(--transition-fast);font-size:.875rem;line-height:1.25rem}.select:hover{border-color:var(--accent)}@supports (color:color-mix(in lab,red,red)){.select:hover{border-color:color-mix(in srgb,var(--accent) 45%,var(--border-subtle))}}.select:focus{border-color:var(--accent);box-shadow:var(--focus-ring);outline:none}select.input,select.select,select.lesson-select{appearance:none;background-image:linear-gradient(45deg,transparent 50%,var(--text-muted) 50%),linear-gradient(135deg,var(--text-muted) 50%,transparent 50%);background-position:calc(100% - 1rem) calc(50% - 2px),calc(100% - .7rem) calc(50% - 2px);background-repeat:no-repeat;background-size:.35rem .35rem,.35rem .35rem;background-clip:padding-box;padding-right:2rem}.textarea{width:100%;padding:var(--space-sm) .75rem;border-radius:var(--radius-md);border:1px solid var(--border-subtle);background-color:var(--bg-inset);color:var(--text-primary);resize:none;transition:background-color var(--transition-base),border-color var(--transition-base),color var(--transition-base),box-shadow var(--transition-fast);font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-size:.875rem;line-height:1.25rem}.textarea:hover{border-color:var(--accent)}@supports (color:color-mix(in lab,red,red)){.textarea:hover{border-color:color-mix(in srgb,var(--accent) 45%,var(--border-subtle))}}.textarea:focus{border-color:var(--accent);box-shadow:var(--focus-ring);outline:none}.textarea::placeholder{color:var(--text-secondary);opacity:.7}.result-box{border-radius:var(--radius-lg);box-shadow:var(--shadow-soft);text-align:center;border-style:solid;border-width:1px;padding:1.25rem}.result-good{background-color:var(--result-good-bg);border-color:var(--result-good-bd)}.result-ok{background-color:var(--result-ok-bg);border-color:var(--result-ok-bd)}.result-bad{background-color:var(--result-bad-bg);border-color:var(--result-bad-bd)}.diff-card{background-color:var(--bg-surface);border:1px solid var(--border);border-radius:.75rem;padding:1.25rem}.diff-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:.5rem;margin-bottom:.875rem;display:flex}.diff-header .card-label{margin-bottom:0}.diff-legend{flex-wrap:wrap;gap:.5rem;display:flex}.diff-tokens{flex-wrap:wrap;gap:.35rem;font-family:monospace;font-size:1rem;line-height:1.8;display:flex}.diff-token{border-radius:.3rem;padding:.1rem .4rem;font-size:.875rem;font-weight:600;display:inline-block}.diff-correct{color:#22c55e;background:#22c55e26}.diff-sub{color:#ca8a04;background:#eab30826}.diff-missing{color:#ef4444;background:#ef444426;text-decoration:line-through}.diff-extra{color:#a855f7;background:#a855f726}.diff-expected{opacity:.8;font-size:.7rem;font-weight:400}.hero{text-align:center;padding-top:4rem;padding-bottom:4rem}.hero-title{color:var(--accent);letter-spacing:-.035em;margin-bottom:1rem;font-size:3rem;font-weight:800;line-height:1}.hero-sub{color:var(--text-secondary);max-width:44rem;margin-bottom:2rem;margin-left:auto;margin-right:auto;font-size:1.125rem;line-height:1.75rem}.about-grid{gap:1.5rem;margin-top:2rem;margin-bottom:2rem;display:grid}@media(min-width:640px){.about-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}.feature-grid{gap:1.5rem;margin-top:2rem;margin-bottom:2rem;display:grid}@media(min-width:640px){.feature-grid{grid-template-columns:repeat(3,minmax(0,1fr))}}.feature-icon{color:var(--accent);justify-content:center;align-items:center;margin-bottom:.75rem;font-size:1.875rem;line-height:2.25rem;display:inline-flex}.feature-icon svg{width:1.875rem;height:1.875rem}.feature-title{color:var(--text-primary);margin-bottom:.25rem;font-size:1.125rem;font-weight:700;line-height:1.75rem}.feature-body{color:var(--text-secondary);font-size:.875rem;line-height:1.25rem}.learn-page,.learn-col-left,.learn-col-right{flex-direction:column;gap:1rem;min-width:0;display:flex}@media(max-width:767px){.learn-col-right .learn-answer-textarea{min-height:11rem}}@media(min-width:768px){.learn-page{grid-template-columns:5fr 7fr;gap:1rem;display:grid}.learn-result-box{grid-column:1/-1}.learn-col-left{min-width:0}.learn-col-right{flex-direction:column;gap:1rem;min-width:0;display:flex}.learn-col-right>.learn-answer-card{flex-direction:column;flex:1;display:flex}.learn-col-right .learn-answer-textarea{field-sizing:fixed;flex:1 1 0;min-height:6rem}}.learn-heading{margin-bottom:1rem}.learn-page .card-label{color:var(--text-label)}.learn-answer-card>.card-label{margin-bottom:0}.page-title-sub{color:var(--text-secondary);margin-top:.25rem;font-size:.875rem;line-height:1.5}.lesson-row{flex-wrap:wrap;align-items:center;gap:.6rem;display:flex}.lesson-current-label{color:var(--accent);white-space:nowrap;margin:0;font-size:.875rem;font-weight:500;line-height:1.25rem}.lesson-select{border-radius:var(--radius-md);border:1px solid var(--border-subtle);background-color:var(--bg-inset);width:100%;min-width:0;color:var(--text-primary);flex:1;padding:.5rem 2rem .5rem .75rem;font-size:.875rem;line-height:1.25rem;transition:background-color .2s,border-color .2s,color .2s}.lesson-select:hover{border-color:var(--accent)}@supports (color:color-mix(in lab,red,red)){.lesson-select:hover{border-color:color-mix(in srgb,var(--accent) 45%,var(--border-subtle))}}.lesson-select:focus{box-shadow:var(--focus-ring);outline:none}.lesson-char-row{grid-template-columns:max-content minmax(0,1fr);align-items:center;gap:.45rem .65rem;margin-bottom:.65rem;display:grid}.lesson-char-preview{color:var(--text-secondary);white-space:nowrap;margin:0;font-size:.8125rem;font-weight:600;line-height:2.15rem}.lesson-char-select{width:100%;min-width:0;max-width:none;margin-left:0}.btn-play-letter-full{white-space:nowrap;width:100%;margin-top:0;padding:.5rem 1rem}.lesson-char-play-row{gap:.5rem;margin-top:.75rem;display:flex}.lesson-char-play-row .btn-regen{flex:1;margin-top:0}@media(max-width:640px){.lesson-char-row{grid-template-columns:max-content minmax(0,1fr);align-items:center;column-gap:.45rem}.lesson-char-select{max-width:none}.lesson-char-preview{font-size:.78rem}}@media(max-width:420px){.settings-grid-2{grid-template-columns:1fr}.player-buttons{flex-wrap:wrap}.player-buttons>*{flex:100%}}.settings-grid{grid-template-columns:repeat(3,1fr);gap:.75rem;display:grid}.settings-grid-2{grid-template-columns:repeat(2,1fr)}.settings-adv{margin-top:.5rem}.settings-adv-toggle{color:var(--text-muted);cursor:pointer;-webkit-user-select:none;user-select:none;align-items:center;gap:.3rem;padding:.15rem 0;font-size:.75rem;list-style:none;display:flex}.settings-adv-toggle:before{content:"›";transition:transform .2s;display:inline-block}.settings-adv[open] .settings-adv-toggle:before{transform:rotate(90deg)}.settings-adv-grid{grid-template-columns:repeat(2,1fr);margin-top:.5rem}.settings-field{flex-direction:column;justify-content:space-between;gap:.25rem;display:flex}.answer-card{background-color:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);min-width:0;box-shadow:var(--shadow-soft);transition:background-color var(--transition-base),border-color var(--transition-base),box-shadow var(--transition-base);flex-direction:column;gap:.75rem;padding:1.25rem;display:flex}.answer-card:hover{box-shadow:var(--shadow-lift)}.player-wrapper{flex-direction:column;gap:.5rem;display:flex}.player-header{justify-content:space-between;align-items:baseline;gap:.5rem;display:flex}.player-label{margin-bottom:0}.player-top{flex-direction:column;align-items:stretch;gap:.75rem;display:flex}.player-progress-row{align-items:center;gap:.5rem;display:flex}.player-progress{background:var(--border);border-radius:2px;flex:1;height:4px;overflow:hidden}.player-progress-fill{background:var(--accent);border-radius:2px;height:100%}.player-timer{font-variant-numeric:tabular-nums;color:var(--accent);white-space:nowrap;text-align:right;min-width:9ch;font-size:.7rem}.player-timer-delay{color:var(--text-muted)}.player-buttons{align-items:stretch;gap:.75rem;display:flex}.player-buttons .hidden{display:none}.player-duration{color:var(--text-muted);text-align:right;align-self:flex-end;margin:0;font-size:.75rem}@media(max-width:900px){.player-top{gap:.45rem}}.btn-next-lesson,.btn-prev-lesson{border-radius:var(--radius-md);cursor:pointer;align-items:center;gap:.4rem;margin-top:.75rem;padding:.5rem 1.25rem;font-size:.875rem;font-weight:700;transition:background-color .15s,border-color .15s,color .15s;display:inline-flex}.btn-next-lesson{background-color:var(--accent-cta);color:#fff;border:none}.btn-next-lesson:hover{background-color:var(--accent-cta-h)}.btn-prev-lesson{border:1px solid var(--border-subtle);color:var(--text-secondary);background-color:#0000}.btn-prev-lesson:hover{border-color:var(--accent);color:var(--accent)}.auth-page{padding-top:1.5rem;padding-bottom:1.5rem}.auth-card{max-width:38rem;margin-left:auto;margin-right:auto;padding:1.75rem}.auth-title{margin-bottom:.35rem;font-size:2rem;line-height:2.25rem}.auth-subtitle{margin-bottom:1.25rem}.auth-form{flex-direction:column;gap:1rem;display:flex}.auth-footer-text{text-align:center;margin:0}.error-text{margin:0}@media(max-width:639px){.auth-card{padding:1.25rem}.auth-title{font-size:1.75rem;line-height:2rem}}.placeholder-page{flex-direction:column;justify-content:center;align-items:center;min-height:calc(100vh - 6rem);padding:3rem 1rem;display:flex}.placeholder-header{text-align:center;flex-direction:column;align-items:center;gap:1rem;margin-bottom:1.5rem;display:flex}.placeholder-header .page-title{margin:0}.placeholder-icon{color:var(--accent);font-size:3rem}.placeholder-message{color:var(--text-secondary);text-align:center;max-width:400px;margin:0}.page-wrapper:before{content:"";pointer-events:none;z-index:-1;background:radial-gradient(700px 300px at 10% -10%,var(--accent),transparent 60%),radial-gradient(600px 260px at 90% -10%,var(--accent),transparent 65%);position:fixed;inset:0}@supports (color:color-mix(in lab,red,red)){.page-wrapper:before{background:radial-gradient(700px 300px at 10% -10%,color-mix(in srgb,var(--accent) 14%,transparent),transparent 60%),radial-gradient(600px 260px at 90% -10%,color-mix(in srgb,var(--accent) 10%,transparent),transparent 65%)}}.nav-label-icon{align-items:center;gap:.3rem;display:inline-flex}.nav-icon{pointer-events:none;flex-shrink:0;width:1rem;height:1rem}.mobile-link svg,.navbar-link svg,.navbar-user-btn svg,.theme-icon-btn svg,.btn-regen svg,.btn-primary svg,.btn-success svg,.btn-danger svg,.btn-ghost svg,.hamburger svg{pointer-events:none}button:focus-visible,a:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible{box-shadow:var(--focus-ring);outline:none}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes slideInRight{0%{opacity:0;transform:translate(-20px)}to{opacity:1;transform:translate(0)}}@keyframes pulse{50%{opacity:.5}}@keyframes spin{to{transform:rotate(360deg)}}@keyframes shimmer{0%{background-position:-1000px 0}to{background-position:1000px 0}}.animate-fadeIn{animation:fadeIn .3s var(--ease-smooth)}.animate-fadeInUp{animation:fadeInUp .4s var(--ease-smooth)}.animate-slideInRight{animation:slideInRight .3s var(--ease-smooth)}.animate-pulse{animation:2s cubic-bezier(.4,0,.6,1) infinite pulse}.animate-spin{animation:1s linear infinite spin}.skeleton{background:linear-gradient(90deg,var(--bg-inset) 0%,var(--bg-inset) 50%,var(--bg-inset) 100%)}@supports (color:color-mix(in lab,red,red)){.skeleton{background:linear-gradient(90deg,var(--bg-inset) 0%,color-mix(in srgb,var(--bg-inset) 80%,var(--border)) 50%,var(--bg-inset) 100%)}}.skeleton{border-radius:var(--radius-md);background-size:1000px 100%;animation:2s linear infinite shimmer}.skeleton-text{height:1rem;margin-bottom:var(--space-sm)}.skeleton-title{width:60%;height:1.5rem;margin-bottom:var(--space-md)}.skeleton-avatar{border-radius:50%;width:3rem;height:3rem}@media(max-width:639px){.hide-mobile{display:none!important}}@media(min-width:640px){.show-mobile{display:none!important}}@media(min-width:768px){.hide-tablet{display:none!important}}@media(max-width:767px){.show-tablet{display:none!important}}@media(min-width:1024px){.hide-desktop{display:none!important}}@media(max-width:639px){.text-responsive{font-size:.875rem}}@container (min-width:640px){.container-sm\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}}@media print{.no-print,.navbar,.footer,button,.btn-primary,.btn-ghost,.btn-outline{display:none!important}.page-wrapper{background:#fff!important}.card,.card-sm{box-shadow:none!important;border:1px solid #ccc!important}}.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}.skip-to-content{background:var(--accent);color:#000;padding:var(--space-sm) var(--space-md);border-radius:var(--radius-md);z-index:100;transition:top var(--transition-fast);font-weight:600;position:absolute;top:-100px;left:0}.skip-to-content:focus{top:var(--space-sm)}@media(prefers-reduced-motion:reduce){*,:before,:after{scroll-behavior:auto!important;transition-duration:.01ms!important;animation-duration:.01ms!important;animation-iteration-count:1!important}.animate-fadeIn,.animate-fadeInUp,.animate-slideInRight,.animate-pulse,.animate-spin{animation:none!important}}@media(prefers-contrast:more){.card,.card-sm,.answer-card{border-width:2px}.btn-primary,.btn-success,.btn-danger{border:2px solid}}@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-backdrop-blur{syntax:"*";inherits:false}@property --tw-backdrop-brightness{syntax:"*";inherits:false}@property --tw-backdrop-contrast{syntax:"*";inherits:false}@property --tw-backdrop-grayscale{syntax:"*";inherits:false}@property --tw-backdrop-hue-rotate{syntax:"*";inherits:false}@property --tw-backdrop-invert{syntax:"*";inherits:false}@property --tw-backdrop-opacity{syntax:"*";inherits:false}@property --tw-backdrop-saturate{syntax:"*";inherits:false}@property --tw-backdrop-sepia{syntax:"*";inherits:false}
