*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--primary:#4f46e5;--danger:#ef4444;--text-muted:#6b7280;--bg:#f9fafb;--surface:#fff;--border:#e5e7eb}body{color:#111827;background:#f9fafb;font-family:Open Sans,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}a{color:#4f46e5;text-decoration:none}img{max-width:100%}@font-face{font-family:Open Sans;src:url(/open-sans-latin-CWNzRldh.woff2)format("woff2");font-weight:100 900;font-style:normal;font-display:swap}.app-layout{flex-direction:column;min-height:100vh;display:flex}.main-content{flex:1;width:100%;max-width:960px;margin:0 auto;padding:24px 16px}@media (width>=768px){.main-content{padding:32px 24px}}.topbar{z-index:100;background:#fff;border-bottom:1px solid #e5e7eb;justify-content:space-between;align-items:center;height:56px;padding:0 16px;display:flex;position:sticky;top:0;overflow:hidden;box-shadow:0 1px 3px #0000001a,0 1px 2px #0000000f}.topbar__logo{color:#4f46e5;align-items:center;gap:8px;min-width:0;font-size:18px;font-weight:700;text-decoration:none;display:flex}.topbar__icon{object-fit:contain;flex-shrink:0;width:28px;height:28px}.topbar__version{color:#6b7280;align-self:flex-end;margin-bottom:2px;font-size:11px;font-weight:400}.topbar__nav{align-items:center;gap:16px;display:flex}.topbar__nav-link{color:#6b7280;font-size:14px;font-weight:500;transition:all .2s}.topbar__nav-link:hover{color:#4f46e5}.topbar__streak{color:#fff;background:linear-gradient(135deg,#f59e0b,#f97316);border-radius:999px;align-items:center;gap:4px;padding:5px 12px 5px 8px;font-weight:700;text-decoration:none;transition:all .2s;display:inline-flex}.topbar__streak:hover{transform:scale(1.07)}.topbar__streak.is-zero{color:#6b7280;box-shadow:none;background:#f9fafb;animation:none}.topbar__streak-fire{font-size:20px;line-height:1}.topbar__streak-count{font-size:18px;font-weight:800;line-height:1}.topbar__streak-label{opacity:.85;align-self:flex-end;margin-bottom:1px;font-size:11px;font-weight:500}@keyframes streak-glow{0%,to{box-shadow:0 2px 8px #f9731659}50%{box-shadow:0 4px 20px #f97316a6}}.topbar__streak:not(.is-zero):not(:hover){animation:2.5s ease-in-out infinite streak-glow}.btn{cursor:pointer;border:none;border-radius:8px;justify-content:center;align-items:center;gap:8px;padding:8px 16px;font-size:14px;font-weight:500;transition:all .2s;display:inline-flex}.btn--primary{color:#fff;background:#4f46e5}.btn--primary:hover{background:#4338ca}.btn--outline{color:#111827;background:0 0;border:1px solid #e5e7eb}.btn--outline:hover{background:#f9fafb}.btn--danger{color:#fff;background:#ef4444}.btn--danger:hover{filter:brightness(.9)}.btn--sm{padding:4px 10px;font-size:13px}.btn--lg{padding:12px 24px;font-size:16px}.btn--ghost{color:#6b7280;background:0 0;border:none}.btn--ghost:hover{color:#111827;background:#f9fafb}.btn--danger-ghost{color:#ef4444;opacity:.75;background:0 0;border:none}.btn--danger-ghost:hover{opacity:1;background:#ef44441a}.btn--icon{border-radius:50%;width:36px;height:36px;padding:0;font-size:18px}.form-group{margin-bottom:16px}.form-group label{color:#111827;margin-bottom:6px;font-size:14px;font-weight:500;display:block}.form-group input,.form-group textarea,.form-group select{color:#111827;background:#fff;border:1px solid #e5e7eb;border-radius:8px;width:100%;padding:8px 12px;font-family:Open Sans,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-size:14px;transition:border-color .2s}.form-group input:focus,.form-group textarea:focus,.form-group select:focus{border-color:#4f46e5;outline:none}.form-group textarea{resize:vertical;min-height:80px}.deck-grid{grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:16px;margin-top:24px;display:grid}.lang-filter{border-bottom:1px solid #e5e7eb;flex-wrap:wrap;gap:6px;margin-top:16px;padding-bottom:12px;display:flex}.lang-filter__tab{appearance:none;color:#6b7280;cursor:pointer;background:0 0;border:1px solid #e5e7eb;border-radius:999px;padding:6px 16px;font-size:14px;font-weight:500;transition:all .2s}.lang-filter__tab:hover{color:#111827;border-color:#6b7280}.lang-filter__tab.is-active{color:#4f46e5;background:#4f46e51f;border-color:#4f46e5;font-weight:600}.deck-card{cursor:pointer;background:#fff;border:1px solid #e5e7eb;border-radius:8px;padding:20px;transition:all .2s;box-shadow:0 1px 3px #0000001a,0 1px 2px #0000000f}.deck-card:hover{border-color:#4f46e5;transform:translateY(-2px)}.deck-card__name{margin-bottom:4px;font-size:16px;font-weight:600}.deck-card__meta{color:#6b7280;font-size:13px}.deck-card__due{color:#4f46e5;margin-top:12px;font-size:13px;font-weight:500}.card-table{border-collapse:collapse;width:100%;margin-top:16px;font-size:14px}.card-table th,.card-table td{text-align:left;border-bottom:1px solid #e5e7eb;padding:10px 12px}.card-table th{color:#6b7280;background:#f9fafb;font-weight:600}.card-table tr:hover td{background:#f9fafb}.card-table__meta{color:#6b7280;white-space:nowrap;font-size:13px}.card-table__date{opacity:.8;margin-left:6px;font-size:12px}.card-table__actions{text-align:right;white-space:nowrap;justify-content:flex-end;align-items:center;gap:6px;display:flex}.card-table__actions .btn{flex-shrink:0;width:34px;height:34px;padding:0;font-size:15px}@media (width<=600px){.card-table{border-collapse:separate;border-spacing:0 8px;margin-top:8px}.card-table thead{display:none}.card-table tr{background:#fff;border:1px solid #e5e7eb;border-radius:8px;grid-template-rows:auto auto;grid-template-columns:1fr auto;display:grid}.card-table tr:hover td{background:0 0}.card-table tr td{border-bottom:none;padding:12px 14px 4px}.card-table tr td:first-child{grid-area:1/1;padding-bottom:4px;font-size:15px;font-weight:600}.card-table tr td:nth-child(2){color:#6b7280;text-align:right;grid-area:1/2;padding-bottom:4px;font-size:15px}.card-table tr td:nth-child(3){grid-area:2/1;align-self:end;padding-top:2px;padding-bottom:12px;font-size:12px}.card-table tr td:nth-child(4){text-align:right;grid-area:2/2;align-self:end;padding-top:2px;padding-bottom:10px}.card-table tr td:nth-child(4) .btn{width:38px;height:38px;padding:0;font-size:16px}}.study-card{text-align:center;background:#fff;border:1px solid #e5e7eb;border-radius:8px;flex-direction:column;justify-content:center;align-items:center;max-width:600px;min-height:200px;margin:32px auto;padding:48px 32px;display:flex;position:relative;box-shadow:0 1px 3px #0000001a,0 1px 2px #0000000f}.study-card__box{color:#6b7280;background:#f9fafb;border-radius:12px;padding:4px 8px;font-size:12px;position:absolute;top:12px;right:16px}.study-card__front{font-size:28px;font-weight:600}.study-card__back{color:#4f46e5;margin-top:16px;font-size:22px}.study-card__notes{color:#6b7280;max-width:480px;margin-top:16px;font-size:14px;font-style:italic}.study-actions{flex-wrap:wrap;justify-content:center;gap:12px;margin-top:24px;display:flex}.study-actions kbd{opacity:.7;border:1px solid;border-radius:3px;margin-left:6px;padding:1px 6px;font-size:11px;display:inline-block}@media (width<=600px){.study-actions kbd{display:none}}.study-progress{text-align:center;color:#6b7280;margin-bottom:8px;font-size:13px}.study-header{justify-content:space-between;align-items:center;margin-bottom:4px;display:flex}.dir-toggle{background:#f9fafb;border:1px solid #e5e7eb;border-radius:8px;gap:2px;padding:2px;display:flex}.dir-toggle__btn{appearance:none;cursor:pointer;color:#6b7280;background:0 0;border:none;border-radius:5px;min-width:40px;min-height:36px;padding:4px 10px;font-size:16px;line-height:1;transition:all .15s}.dir-toggle__btn:hover{color:#111827;background:#fff}.dir-toggle__btn.is-active{color:#4f46e5;background:#fff;box-shadow:0 1px 3px #0000001a}.study-actions--type{flex-direction:column;align-items:center;gap:12px}.type-input-wrap{gap:8px;width:100%;max-width:500px;display:flex}.type-input{color:#111827;background:#fff;border:2px solid #e5e7eb;border-radius:8px;outline:none;flex:1;min-width:0;padding:10px 14px;font-family:inherit;font-size:16px;transition:border-color .2s}.type-input:focus{border-color:#4f46e5}.type-input:disabled{background:#f9fafb}.type-feedback{text-align:center;font-size:15px}.type-feedback--correct{color:#16a34a;font-size:20px;font-weight:700}.type-feedback--wrong{color:#ef4444}.dialog{color:#111827;background:#fff;border:none;border-radius:8px;width:calc(100% - 32px);max-width:480px;height:fit-content;max-height:calc(100svh - 32px);margin:auto;padding:28px;position:fixed;inset:0;overflow-y:auto;box-shadow:0 1px 3px #0000001a,0 1px 2px #0000000f}.dialog--lg{max-width:720px}@media (width<=600px){.dialog{width:calc(100% - 16px);max-height:calc(100svh - 16px);padding:20px 16px}.dialog--lg{max-width:none}}.dialog::backdrop{-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#0006}.dialog h2{margin:0 0 16px;font-size:20px;font-weight:700}.dialog__actions{justify-content:flex-end;gap:8px;margin-top:16px;display:flex}.dialog__actions--spread{justify-content:space-between;align-items:center}@media (width<=440px){.dialog__actions--spread{flex-direction:column;align-items:stretch}.dialog__actions--spread>div{justify-content:flex-end;gap:8px;display:flex}}.dialog__danger-zone{border-top:1px solid #e5e7eb;justify-content:flex-start;margin-top:20px;padding-top:16px;display:flex}.ocr-trigger{flex-wrap:wrap;align-items:center;gap:10px;margin-bottom:14px;display:flex}.ocr-progress-bar{background:#e5e7eb;border-radius:3px;height:6px;overflow:hidden}.ocr-progress-bar div{background:#4f46e5;border-radius:3px;height:100%;transition:width .3s}.import-option{color:#6b7280;cursor:pointer;-webkit-user-select:none;user-select:none;align-items:center;gap:7px;font-size:13px;display:inline-flex}.import-option input[type=checkbox]{accent-color:#4f46e5;cursor:pointer;flex-shrink:0;width:16px;height:16px}.import-table{border-collapse:collapse;width:100%;font-size:14px}.import-table th,.import-table td{text-align:left;border-bottom:1px solid #e5e7eb;padding:8px 10px}.import-table th{color:#6b7280;background:#f9fafb;font-size:12px;font-weight:600;position:sticky;top:0}@media (width<=600px){.import-table thead{display:none}.import-table tbody tr{border-bottom:1px solid #e5e7eb;grid-template-rows:auto auto;grid-template-columns:1fr auto;gap:2px 8px;padding:10px 4px;display:grid}.import-table td{border:none;padding:0}.import-table td:first-child{grid-area:1/1;font-size:15px;font-weight:600}.import-table td:nth-child(2){color:#6b7280;grid-area:2/1;font-size:13px}.import-table td:nth-child(3){color:#6b7280;text-align:right;text-overflow:ellipsis;white-space:nowrap;grid-area:1/2/3;align-self:center;max-width:70px;font-size:11px;overflow:hidden}}.import-table .import-row--error{background:#ef44440f}.import-table .import-row--error td{color:#ef4444}.import-table .import-row__warn{font-style:normal}.page-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;margin-bottom:24px;display:flex}.page-header h1{font-size:24px;font-weight:700}.back-link{color:#6b7280;margin-bottom:8px;font-size:13px;display:inline-block}.stats-hero{grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:16px;margin-bottom:40px;display:grid}.stats-hero__item{text-align:center;background:#fff;border:1px solid #e5e7eb;border-radius:8px;flex-direction:column;gap:8px;padding:20px;display:flex;box-shadow:0 1px 3px #0000001a,0 1px 2px #0000000f}.stats-hero__num{color:#4f46e5;font-size:36px;font-weight:700;line-height:1}.stats-hero__label{color:#6b7280;font-size:13px}.stats-section{margin-bottom:40px}.stats-section h2{color:#111827;margin-bottom:16px;font-size:16px;font-weight:600}.stats-barchart{background:#fff;border:1px solid #e5e7eb;border-radius:8px;align-items:flex-end;gap:8px;height:120px;padding:16px;display:flex}.barchart__col{flex-direction:column;flex:1;justify-content:flex-end;align-items:center;gap:4px;height:100%;display:flex}.barchart__val{color:#6b7280;min-height:16px;font-size:11px}.barchart__bar{background:#4f46e5;border-radius:3px 3px 0 0;width:100%;min-height:2px;transition:height .2s}.barchart__label{color:#6b7280;white-space:nowrap;font-size:10px}.stats-boxes{background:#fff;border:1px solid #e5e7eb;border-radius:8px;flex-direction:column;gap:12px;padding:16px;display:flex}.box-bar{align-items:center;gap:12px;display:flex}.box-bar__label{color:#6b7280;flex-shrink:0;width:50px;font-size:13px}.box-bar__track{background:#f9fafb;border-radius:4px;flex:1;height:20px;overflow:hidden}.box-bar__fill{border-radius:4px;min-width:2px;height:100%;transition:width .2s}.box-bar__count{color:#6b7280;text-align:right;flex-shrink:0;width:32px;font-size:13px}.stats-deck-list{flex-direction:column;gap:12px;display:flex}.stats-deck-card{background:#fff;border:1px solid #e5e7eb;border-radius:8px;padding:16px;box-shadow:0 1px 3px #0000001a,0 1px 2px #0000000f}.stats-deck-card__header{justify-content:space-between;align-items:center;margin-bottom:10px;display:flex}.stats-deck-card__name{color:#111827;font-weight:600}.stats-deck-card__name:hover{color:#4f46e5}.stats-deck-card__due{color:#6b7280;font-size:13px}.stats-deck-card__due--active{color:#ef4444;font-weight:500}.stats-deck-card__bars{background:#f9fafb;border-radius:6px;height:12px;margin-bottom:8px;display:flex;overflow:hidden}.stats-deck-card__info{color:#6b7280;font-size:12px}.mini-bar{min-width:4px;height:100%}