@import"https://fonts.googleapis.com/css2?family=Fredoka:wght@400;500;600;700&family=Luckiest+Guy&family=Noto+Sans+Mono:wght@400;600;700&display=swap";/*! tailwindcss v4.3.2 | MIT License | https://tailwindcss.com */@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;--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%;-moz-tab-size:4;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]){-webkit-appearance:button;-moz-appearance:button;appearance:button}::file-selector-button{-webkit-appearance:button;-moz-appearance: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{.hidden{display:none}}:root{--color-text:#172033;--color-text-muted:#526074;--color-label:#344158;--color-page:#f5f7fb;--color-surface:#fff;--color-surface-subtle:#f8fafc;--color-back-surface:#f1f5f9;--color-border:#d9e0ec;--color-border-strong:#bcc8d8;--color-primary:#24533f;--color-primary-hover:#173829;--color-primary-soft:#dcefe5;--color-primary-subtle:#eaf4ef;--color-primary-focus:#c8ded3;--color-danger:#9d2f2f;--color-danger-hover:#7f1d1d;--color-danger-soft:#fff6f6;--color-danger-subtle:#ffe0e0;--color-danger-border:#d7a6a6;--color-danger-border-soft:#f2c0c0;--color-rating-worst:#dc2626;--color-rating-worst-text:#7f1d1d;--color-rating-worst-soft:#fee2e2;--color-rating-worst-border:#fca5a5;--color-rating-middle:#ca8a04;--color-rating-middle-text:#713f12;--color-rating-middle-soft:#fef3c7;--color-rating-middle-border:#facc15;--color-rating-best:#16a34a;--color-rating-best-text:#14532d;--color-rating-best-soft:#dcfce7;--color-rating-best-border:#86efac;--color-gray-text:#64748b;--color-gray-strong:#334155;--color-gray-border:#cbd5e1;--color-overlay:#0f172a73;--color-hud-border:#bcc8d8b8;--color-hud-surface:#ffffffeb;--radius-card:8px;--radius-control:6px;--radius-badge:4px;--shadow-panel:0 18px 48px #17203314;--shadow-card:0 22px 48px #17203329, 0 4px 12px #17203314;--shadow-dialog:0 24px 72px #1720333d;--shadow-hud:0 12px 34px #1720332e;--shadow-button:0 6px 14px #ca8a0438;--shadow-menu-item:0 8px 18px #1720330f;--font-body:"Fredoka", ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-display:"Luckiest Guy", var(--font-body);--font-mono:"Noto Sans Mono", ui-monospace, SFMono-Regular, Consolas, "Liberation Mono", monospace}*{box-sizing:border-box}body{min-width:320px;min-height:100vh;font-family:var(--font-body);color:var(--color-text);background:var(--color-page);margin:0}button,input,textarea,select{font:inherit}input,textarea,select{font-size:1rem;font-weight:400}button{border-radius:var(--radius-control);min-height:44px;color:var(--color-surface);background:var(--color-primary);font-family:var(--font-body);letter-spacing:0;cursor:pointer;border:0;font-weight:400}button:hover,button:focus-visible{background:var(--color-primary-hover)}button:disabled{cursor:not-allowed;opacity:.7}.secondary-button{border:1px solid var(--color-border-strong);color:var(--color-primary);background:var(--color-surface)}.secondary-button:hover,.secondary-button:focus-visible{border-color:var(--color-primary);color:var(--color-primary-hover);background:var(--color-primary-subtle)}.danger-button{color:var(--color-surface);background:var(--color-danger)}.danger-button:hover,.danger-button:focus-visible{background:var(--color-danger-hover)}.icon-button{min-height:44px;color:var(--color-text-muted);background:0 0;place-items:center;display:grid}.icon-button:hover,.icon-button:focus-visible{color:var(--color-text);background:var(--color-surface-subtle)}input{border:1px solid var(--color-border-strong);border-radius:var(--radius-control);width:100%;min-height:44px;color:var(--color-text);background:var(--color-surface);margin-top:8px;padding:10px 12px}textarea{resize:vertical;border:1px solid var(--color-border-strong);border-radius:var(--radius-control);width:100%;min-height:96px;color:var(--color-text);background:var(--color-surface);margin-top:8px;padding:10px 12px}input:focus,textarea:focus{outline:3px solid var(--color-primary-focus);border-color:var(--color-primary)}.fen-input{font-family:var(--font-mono);font-size:1rem}.json-textarea{min-height:220px;font-family:var(--font-mono);font-size:1rem;line-height:1.5}.app-shell{min-height:100vh;padding:16px 16px calc(112px + env(safe-area-inset-bottom));place-items:center;display:grid}.browse-mode-active{padding-top:84px;padding-bottom:calc(176px + env(safe-area-inset-bottom))}.dialog-backdrop{z-index:50;background:var(--color-overlay);justify-content:center;align-items:flex-end;padding:48px 12px 12px;display:flex;position:fixed;top:0;right:0;bottom:0;left:0}.dialog-panel{width:100%;max-height:calc(100dvh - 24px);color:var(--color-text);background:var(--color-surface);box-shadow:var(--shadow-dialog);border-radius:8px 8px 0 0;outline:none;padding:16px;overflow:auto}.dialog-header{grid-template-columns:1fr auto;align-items:start;gap:12px;display:grid}.dialog-header h2{margin:0}.dialog-description{color:var(--color-text-muted);margin:8px 0 0;font-size:.875rem;line-height:1.4}.dialog-close-button{border-radius:var(--radius-control);width:44px}.dialog-body{margin-top:20px}.dialog-copy{color:var(--color-label);margin:0;line-height:1.5}.dialog-actions{gap:8px;margin-top:20px;display:grid}.dialog-single-action{justify-self:center;width:min(100%,160px)}.flashcard-screen{gap:12px;width:min(100%,420px);display:grid}.landing-screen{text-align:center;place-items:center;width:min(100%,420px);display:grid}.landing-hero{justify-items:center;gap:18px;display:grid}.eyebrow{color:var(--color-primary);font-family:var(--font-display);letter-spacing:.02em;text-transform:uppercase;margin:0 0 12px;font-size:.875rem;font-weight:400}.eyebrow-back{color:var(--color-gray-text)}h1,h2,h3,h4,h5,h6{font-family:var(--font-display);font-weight:400}h1{margin:0 0 24px;font-size:2rem;line-height:1.1}h2{margin:0;font-size:1.5rem;line-height:1.1}.landing-hero h1{margin:0;font-size:2.75rem;line-height:.98}.landing-copy{color:var(--color-text-muted);margin:0;font-size:1rem;line-height:1.5}.landing-actions{width:min(100%,240px)}.landing-actions button{grid-template-columns:auto auto;justify-content:center;align-items:center;gap:8px;width:100%;display:inline-grid}.auth-card{border:1px solid var(--color-border);border-radius:var(--radius-card);background:var(--color-surface);width:100%;box-shadow:var(--shadow-panel);gap:16px;padding:18px;display:grid}.auth-card-dialog{box-shadow:none;border:0;border-radius:0;padding:0}.auth-kicker{color:var(--color-primary);font-family:var(--font-display);letter-spacing:.02em;text-transform:uppercase;margin:0 0 8px;font-size:.8125rem;font-weight:400}.session-view{gap:18px;display:grid}.auth-card label{color:var(--color-label);font-size:.9375rem;font-weight:700}.form-error{color:var(--color-danger);margin:0;font-size:.9375rem;font-weight:700}.session-copy{color:var(--color-text-muted);margin:-8px 0 4px;line-height:1.5}.flashcard-view{border:1px solid var(--color-border);border-radius:var(--radius-card);background:var(--color-surface);box-shadow:var(--shadow-card);gap:16px;padding:18px;display:grid}.flashcard-side-label{justify-self:end;margin:0}.flashcard-side-label-back{justify-self:start}.flashcard-title-row{min-height:1.65rem}.flashcard-view-back{background:var(--color-back-surface)}.flashcard-card-header{grid-template-columns:1fr auto;align-items:start;min-height:44px;display:grid}.browse-mode-topbar{top:calc(12px + env(safe-area-inset-top));z-index:39;grid-template-columns:1fr auto;align-items:center;gap:10px;max-width:420px;margin:0 auto;display:grid;position:fixed;left:12px;right:12px}.browse-mode-indicator{border:1px solid var(--color-primary-focus);border-radius:var(--radius-card);min-height:40px;color:var(--color-primary);background:var(--color-hud-surface);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);grid-template-columns:auto 1fr;align-items:center;gap:8px;padding:0 12px;font-size:.8125rem;line-height:1;display:inline-grid;box-shadow:0 18px 40px #1720333d,0 6px 16px #17203324}.browse-mode-close{border:1px solid var(--color-hud-border);border-radius:var(--radius-card);width:40px;min-height:40px;color:var(--color-text-muted);background:var(--color-hud-surface);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);box-shadow:0 18px 40px #1720333d,0 6px 16px #17203324}.browse-mode-close:hover,.browse-mode-close:focus-visible{color:var(--color-text);background:var(--color-surface)}.rate-button{border:1px solid var(--color-rating-middle-border);width:44px;min-height:44px;color:var(--color-rating-middle-text);background:var(--color-rating-middle-soft);box-shadow:var(--shadow-button);border-radius:999px;place-items:center;display:grid}.rate-button:hover,.rate-button:focus-visible{color:var(--color-surface);background:var(--color-rating-middle)}.flashcard-text{color:var(--color-label);white-space:pre-wrap;margin:0;font-size:1rem;line-height:1.55}.card-stats{border-top:1px dashed var(--color-gray-text);border-bottom:1px dashed var(--color-gray-text);gap:0;margin:0;display:grid}.card-stats div{border-bottom:1px dashed var(--color-gray-border);color:var(--color-gray-strong);grid-template-columns:1fr auto;align-items:center;gap:12px;padding:8px 0;display:grid}.card-stats div:last-child{border-bottom:0}.card-stats dt{color:currentColor;letter-spacing:0;font-size:.8125rem;font-weight:700;line-height:1.2}.card-stats dd{color:var(--color-text);margin:0;font-size:1rem;font-weight:400;line-height:1}.card-stat-value{border:1px solid var(--color-gray-border);border-radius:var(--radius-badge);min-width:2.35rem;min-height:1.65rem;color:var(--color-gray-strong);background:var(--color-surface-subtle);font-family:var(--font-body);letter-spacing:0;place-items:center;padding:0 10px;font-weight:400;display:inline-grid}.card-stat-text-value{color:var(--color-text);text-align:right;font-size:.9375rem;line-height:1.35}.card-stat-badge-worst{border-color:var(--color-rating-worst-border);color:var(--color-rating-worst-text);background:var(--color-rating-worst-soft)}.card-stat-badge-middle{border-color:var(--color-rating-middle-border);color:var(--color-rating-middle-text);background:var(--color-rating-middle-soft)}.card-stat-badge-best{border-color:var(--color-rating-best-border);color:var(--color-rating-best-text);background:var(--color-rating-best-soft)}.flashcard-swap-button{grid-template-columns:auto auto;justify-content:center;align-items:center;gap:8px;display:inline-grid}.card-form{gap:14px;display:grid}.card-form label{color:var(--color-label);font-size:.9375rem;font-weight:700}.card-form-edit input,.card-form-edit textarea{font-weight:400}.rate-options{grid-template-columns:1fr;gap:8px;display:grid}.rate-options button{border-radius:var(--radius-card);place-items:center;gap:3px;min-height:58px;display:grid}.rate-options span{font-family:inherit;font-weight:inherit;letter-spacing:inherit;line-height:1}.rate-options small{opacity:.82;font-size:.75rem;font-weight:700;line-height:1}.rate-options .rate-option-worst{border:1px solid var(--color-rating-worst-border);color:var(--color-rating-worst-text);background:var(--color-rating-worst-soft)}.rate-options .rate-option-worst:hover,.rate-options .rate-option-worst:focus-visible{background:var(--color-rating-worst)}.rate-options .rate-option-middle{border:1px solid var(--color-rating-middle-border);color:var(--color-rating-middle-text);background:var(--color-rating-middle-soft)}.rate-options .rate-option-middle:hover,.rate-options .rate-option-middle:focus-visible{background:var(--color-rating-middle)}.rate-options .rate-option-best{border:1px solid var(--color-rating-best-border);color:var(--color-rating-best-text);background:var(--color-rating-best-soft)}.rate-options .rate-option-best:hover,.rate-options .rate-option-best:focus-visible{background:var(--color-rating-best)}.rate-options .rate-option-worst:hover,.rate-options .rate-option-worst:focus-visible,.rate-options .rate-option-middle:hover,.rate-options .rate-option-middle:focus-visible,.rate-options .rate-option-best:hover,.rate-options .rate-option-best:focus-visible{color:var(--color-surface)}@media(min-width:420px){.rate-options{grid-template-columns:repeat(3,1fr)}}.stats-list{margin:0}.stats-list div{border-bottom:1px solid var(--color-border);grid-template-columns:1fr auto;align-items:center;gap:16px;padding:14px 0;display:grid}.stats-list div:last-child{border-bottom:0}.stats-list dt{color:var(--color-text-muted);font-weight:700}.stats-list dd{color:var(--color-text);font-family:var(--font-display);letter-spacing:.02em;margin:0;font-size:1.5rem;font-weight:400}.stats-list-best dd{color:var(--color-rating-best)}.stats-list-wide dd{font-family:var(--font-body);letter-spacing:0;text-align:right;font-size:1rem;font-weight:700}.chess-diagram{--light-square:#eeeed2;--dark-square:#769657;--highlight-square:#f6ca55c2;aspect-ratio:1;border-radius:var(--radius-control);background:var(--light-square);-webkit-user-select:none;user-select:none;border:1px solid #9daf99;grid-template-rows:repeat(8,1fr);grid-template-columns:repeat(8,1fr);width:min(100%,356px);display:grid;overflow:hidden}.chess-diagram-back{--light-square:#e5e7eb;--dark-square:#9ca3af;--highlight-square:#94a3b89e;border-color:#94a3b8}.chess-square{place-items:center;min-width:0;min-height:0;display:grid;position:relative}.chess-square-light{background:var(--light-square)}.chess-square-dark{background:var(--dark-square)}.chess-square-highlighted:before{z-index:0;content:"";background:var(--highlight-square);position:absolute;top:0;right:0;bottom:0;left:0}.chess-piece{z-index:2;object-fit:contain;pointer-events:none;width:96%;height:96%;position:relative}.chess-coordinate{z-index:1;color:var(--dark-square);font-size:.625rem;font-weight:400;line-height:1;position:absolute}.chess-square-dark .chess-coordinate{color:var(--light-square)}.chess-rank{top:4px;left:4px}.chess-file{bottom:4px;right:4px}.chess-diagram-error{border:1px solid var(--color-danger-border);border-radius:var(--radius-control);color:var(--color-danger);background:var(--color-danger-soft);padding:12px;font-weight:700}.quick-hud{right:12px;bottom:calc(12px + env(safe-area-inset-bottom));z-index:40;border:1px solid var(--color-hud-border);border-radius:var(--radius-card);background:var(--color-hud-surface);max-width:420px;box-shadow:var(--shadow-hud);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);grid-auto-columns:1fr;grid-auto-flow:column;gap:6px;margin:0 auto;padding:8px;display:grid;position:fixed;left:12px}.browse-hud{right:12px;bottom:calc(88px + env(safe-area-inset-bottom));z-index:39;grid-auto-columns:1fr;grid-auto-flow:column;gap:6px;max-width:420px;margin:0 auto;display:grid;position:fixed;left:12px}.quick-hud-button{border-radius:var(--radius-control);min-width:0;min-height:52px;color:var(--color-primary);background:0 0;place-items:center;gap:3px;padding:6px 4px;font-size:.75rem;line-height:1;display:grid}.browse-hud-button{border:1px solid var(--color-hud-border);background:var(--color-hud-surface);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);box-shadow:0 18px 40px #1720333d,0 6px 16px #17203324}.quick-hud-button:hover,.quick-hud-button:focus-visible{color:var(--color-surface);background:var(--color-primary)}.action-menu{gap:10px;display:grid}.action-menu-item{border:1px solid var(--color-primary-focus);border-radius:var(--radius-card);min-height:52px;color:var(--color-primary);background:var(--color-surface);text-align:left;box-shadow:var(--shadow-menu-item);grid-template-columns:38px 1fr;align-items:center;gap:10px;padding:10px;display:grid}.action-menu-item svg{border-radius:var(--radius-control);background:var(--color-primary-soft);width:38px;height:38px;padding:9px}.action-menu-item:hover,.action-menu-item:focus-visible{border-color:var(--color-primary);background:var(--color-primary-subtle);color:var(--color-primary-hover)}.action-menu-item-danger{border-color:var(--color-danger-border-soft);color:var(--color-danger);background:var(--color-surface)}.action-menu-item-danger svg{background:var(--color-danger-subtle)}.action-menu-item-danger:hover,.action-menu-item-danger:focus-visible{border-color:var(--color-danger-border);background:var(--color-danger-soft)}@media(min-width:640px){.app-shell{padding:24px 24px calc(116px + env(safe-area-inset-bottom))}.browse-mode-active{padding-top:92px;padding-bottom:calc(180px + env(safe-area-inset-bottom))}.dialog-backdrop{align-items:center;padding:24px}.dialog-panel{border-radius:var(--radius-card);max-width:448px;max-height:min(640px,100dvh - 48px);padding:20px}.dialog-actions{grid-template-columns:repeat(2,1fr)}.dialog-single-action{grid-column:1/-1}.landing-screen{width:min(100%,420px)}.landing-hero h1{font-size:3.5rem}.auth-card{padding:32px}.fen-input,.json-textarea{font-size:.875rem}}@media(min-width:768px){.browse-mode-topbar,.browse-hud,.quick-hud{width:min(420px,100vw - 48px);left:0;right:0}}
