*{margin:0;padding:0;box-sizing:border-box}:root{--bg: #0f0f13;--surface: #1a1a24;--surface-2: #24243a;--border: #2a2a40;--text: #e8e8f0;--text-dim: #8888a0;--accent: #6366f1;--accent-hover: #818cf8;--green: #22c55e;--red: #ef4444;--orange: #f59e0b;--blue: #3b82f6;--radius: 8px}html{background:var(--bg);color:var(--text);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,system-ui,sans-serif;font-size:16px;line-height:1.5}main{max-width:640px;margin:0 auto;padding:24px 16px;min-height:100vh}.home{display:flex;flex-direction:column;align-items:center;gap:32px;padding-top:48px}.home h1{font-size:2rem;font-weight:700;letter-spacing:-.02em}.auth-subtitle{color:var(--text-dim);font-size:.95rem;margin-top:-16px}.user-info{display:flex;align-items:center;gap:12px;margin-top:-16px}.user-name{color:var(--text-dim);font-size:.9rem}.auth-form{width:100%;max-width:360px}.auth-form form{display:flex;flex-direction:column;gap:8px}.auth-error{color:var(--red);font-size:.85rem}.auth-switch{text-align:center;color:var(--text-dim);font-size:.85rem;margin-top:12px}.auth-link{background:none;border:none;color:var(--accent);cursor:pointer;font-size:.85rem;text-decoration:underline}.auth-link:hover{color:var(--accent-hover)}.auth-oauth{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;padding:12px;font-size:.95rem;font-weight:500}.auth-divider{display:flex;align-items:center;gap:12px;color:var(--text-dim);font-size:.8rem;margin:4px 0}.auth-divider:before,.auth-divider:after{content:"";flex:1;height:1px;background:var(--border)}.auth-tabs{display:flex;gap:4px;margin-bottom:8px}.auth-tab{flex:1;padding:8px;background:none;border:1px solid var(--border);border-radius:var(--radius);color:var(--text-dim);font-size:.85rem;cursor:pointer;transition:all .15s}.auth-tab.active{background:var(--surface-2);border-color:var(--accent);color:var(--text)}.auth-magic-sent{text-align:center;padding:16px;color:var(--text-dim);font-size:.9rem}.auth-magic-sent p{margin-bottom:8px}.stats-bar{display:flex;gap:24px}.stat{display:flex;flex-direction:column;align-items:center;gap:2px}.stat-number{font-size:1.5rem;font-weight:700}.stat-label{font-size:.75rem;color:var(--text-dim);text-transform:uppercase;letter-spacing:.05em}.stat-due .stat-number{color:var(--orange)}.menu{display:flex;flex-direction:column;gap:8px;width:100%;max-width:400px}.menu-btn{display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:12px;padding:14px 16px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);color:var(--text);font-size:1rem;cursor:pointer;text-align:left;text-decoration:none;transition:border-color .15s,background .15s}.menu-btn:hover:not(:disabled):not(.disabled){border-color:var(--accent);background:var(--surface-2)}.menu-btn:disabled,.menu-btn.disabled{opacity:.4;cursor:not-allowed;pointer-events:none}.menu-desc{color:var(--text-dim);font-size:.85rem}.menu-key{display:inline-flex;align-items:center;justify-content:center;min-width:24px;height:24px;padding:0 6px;background:var(--surface-2);border:1px solid var(--border);border-radius:4px;font-size:.75rem;font-weight:600;font-family:monospace;color:var(--text-dim)}.view-header{display:flex;align-items:center;gap:12px;margin-bottom:20px}.view-header h2{font-size:1.25rem;font-weight:600}.back-btn{display:inline-flex;align-items:center;gap:6px;padding:6px 10px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);color:var(--text-dim);font-size:.85rem;cursor:pointer}.back-btn:hover{border-color:var(--accent);color:var(--text)}.word-count,.progress{margin-left:auto;color:var(--text-dim);font-size:.85rem}.review-meta{margin-left:auto;display:flex;align-items:center;gap:12px}.input{padding:10px 12px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);color:var(--text);font-size:.95rem;outline:none;transition:border-color .15s}.input:focus{border-color:var(--accent)}.input::placeholder{color:var(--text-dim)}.input-with-btn{display:flex;gap:4px}.input-with-btn .input{flex:1;min-width:0}.btn.btn-lookup{padding:6px 8px;font-weight:700;flex-shrink:0}.lookup-error{color:var(--danger);font-size:.85em;margin:0}.dictionary-controls{margin-bottom:12px}.search-input{width:100%}.btn{padding:10px 16px;border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);color:var(--text);font-size:.95rem;cursor:pointer;transition:all .15s}.btn:hover:not(:disabled){border-color:var(--accent);background:var(--surface-2)}.btn:disabled{opacity:.4;cursor:not-allowed}.btn-primary{background:var(--accent);border-color:var(--accent);color:#fff;font-weight:600}.btn-primary:hover:not(:disabled){background:var(--accent-hover);border-color:var(--accent-hover)}.btn-small{padding:4px 10px;font-size:.8rem}.btn-danger{color:var(--red)}.btn-danger:hover{border-color:var(--red)}.btn-add{font-size:1.1rem;font-weight:700;line-height:1;color:var(--green)}.btn-add:hover:not(:disabled){border-color:var(--green);background:var(--surface-2)}.tag-filter{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:12px}.tag-pill{padding:4px 12px;border-radius:999px;background:var(--surface);border:1px solid var(--border);color:var(--text-dim);font-size:.8rem;cursor:pointer}.tag-pill.active{background:var(--accent);border-color:var(--accent);color:#fff}.tag-pill.small{padding:2px 8px;font-size:.7rem}.word-list{display:flex;flex-direction:column;gap:4px}.word-row{display:grid;grid-template-columns:minmax(0,.8fr) minmax(0,1.2fr) auto auto;align-items:center;gap:8px;padding:10px 12px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);font-size:.9rem}.word-dutch{font-weight:600}.word-english{color:var(--text-dim);display:flex;align-items:center;flex-wrap:wrap;gap:4px}.word-actions{display:flex;gap:4px}.srs-badge{padding:2px 8px;border-radius:4px;font-size:.7rem;font-weight:600;text-transform:uppercase}.srs-badge.new{background:var(--blue);color:#fff}.srs-badge.learning{background:var(--orange);color:#000}.srs-badge.known{background:var(--green);color:#000}.word-row-add{padding:0;background:transparent;border:1px dashed var(--border)}.word-row-add:has(.edit-row){background:var(--surface);border-style:solid;padding:10px 12px}.add-row-btn{grid-column:1 / -1;padding:10px 12px;background:transparent;border:none;border-radius:var(--radius);color:var(--text-dim);font-size:.9rem;cursor:pointer;text-align:left;transition:color .15s,background .15s}.add-row-btn:hover{color:var(--accent);background:var(--surface-2)}.edit-row{display:grid;grid-template-columns:minmax(0,.8fr) minmax(0,1.2fr) auto auto;grid-template-areas:"dutch english save cancel" "tags  tags    tags tags";gap:6px;grid-column:1 / -1}.edit-row .input-dutch,.edit-row .input-with-btn{grid-area:dutch}.edit-row .input-english{grid-area:english}.edit-row .input-tags{grid-area:tags}.edit-row .btn-save{grid-area:save}.edit-row .btn-cancel{grid-area:cancel}.edit-row .lookup-error{grid-column:1 / -1}.edit-row .input{font-size:.85rem;padding:6px 8px}.empty{text-align:center;color:var(--text-dim);padding:32px}.pack-list{display:flex;flex-direction:column;gap:8px}.pack-row{display:grid;grid-template-columns:1fr auto auto;align-items:center;gap:12px;padding:12px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius)}.pack-row.subscribed{border-color:var(--green)}.pack-info{display:flex;flex-direction:column;gap:2px;min-width:0}.pack-name{font-weight:600;display:flex;align-items:center;gap:8px}.pack-desc{font-size:.85rem;color:var(--text-dim)}.pack-count{font-size:.85rem;color:var(--text-dim);white-space:nowrap}.mistake-row{display:grid;grid-template-columns:auto minmax(0,.8fr) minmax(0,1.2fr);align-items:center;gap:12px;padding:10px 12px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);font-size:.9rem}.mistake-direction{font-size:.65rem;font-weight:600;text-transform:uppercase;color:var(--text-dim);border:1px solid var(--border);padding:2px 6px;border-radius:4px}.mistake-word{font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.mistake-answers{display:flex;flex-direction:column;gap:2px;min-width:0}.mistake-line{display:flex;align-items:baseline;gap:8px;min-width:0}.mistake-icon{font-size:.85rem;font-weight:700;flex-shrink:0;width:14px;text-align:center}.mistake-line.correct .mistake-icon{color:var(--green)}.mistake-line.wrong .mistake-icon{color:var(--red)}.mistake-translation{color:var(--text-dim);font-size:.85rem}.scroll-sentinel{height:1px}.loading-more{text-align:center;color:var(--text-dim);padding:12px;font-size:.85rem}.list-end{text-align:center;color:var(--text-dim);padding:12px;font-size:.8rem}.progress-bar{height:4px;background:var(--surface);border-radius:2px;margin-bottom:24px;overflow:hidden}.progress-fill{height:100%;background:var(--accent);border-radius:2px;transition:width .3s ease}.card{perspective:800px;cursor:pointer;margin:0 auto 24px;width:100%;max-width:440px;height:260px}.card-inner{position:relative;width:100%;height:100%;transition:transform .5s;transform-style:preserve-3d}.card-inner.no-transition{transition:none}.card.flipped .card-inner{transform:rotateY(180deg)}.card-front,.card-back{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;padding:24px;background:var(--surface);border:1px solid var(--border);border-radius:12px;backface-visibility:hidden}.card-back{transform:rotateY(180deg);border-color:var(--accent)}.card-label{font-size:.75rem;text-transform:uppercase;letter-spacing:.1em;color:var(--text-dim)}.card-word{font-size:2rem;font-weight:700;text-align:center}.card-hint{font-size:.8rem;color:var(--text-dim)}.card-notes{font-size:.85rem;color:var(--text-dim);font-style:italic;text-align:center}.rating-buttons{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;max-width:440px;margin:0 auto}.rate-btn{display:flex;flex-direction:column;align-items:center;gap:4px;padding:12px 8px;font-size:.85rem;font-weight:600}.rate-btn.again{border-color:var(--red);color:var(--red)}.rate-btn.hard{border-color:var(--orange);color:var(--orange)}.rate-btn.good{border-color:var(--green);color:var(--green)}.rate-btn.easy{border-color:var(--blue);color:var(--blue)}.rate-btn.again:hover{background:#ef44441a}.rate-btn.hard:hover{background:#f59e0b1a}.rate-btn.good:hover{background:#22c55e1a}.rate-btn.easy:hover{background:#3b82f61a}.quiz-prompt{display:flex;flex-direction:column;align-items:center;gap:8px;padding:32px 24px;background:var(--surface);border:1px solid var(--border);border-radius:12px;margin-bottom:20px}.quiz-choices{display:flex;flex-direction:column;gap:8px;max-width:440px;margin:0 auto}.quiz-choice{display:flex;align-items:center;gap:12px;text-align:left;font-size:1rem;padding:14px 16px}.quiz-choice.correct{border-color:var(--green);background:#22c55e1a;color:var(--green)}.quiz-choice.wrong{border-color:var(--red);background:#ef44441a;color:var(--red)}.quiz-next{text-align:center;margin-top:20px;display:flex;flex-direction:column;align-items:center;gap:12px}.result-correct{color:var(--green);font-weight:600;font-size:1.1rem}.result-wrong{color:var(--red);font-weight:600;font-size:1.1rem}.done-card{display:flex;flex-direction:column;align-items:center;gap:12px;padding:48px 24px;background:var(--surface);border:1px solid var(--border);border-radius:12px;text-align:center}.done-emoji{font-size:3rem;color:var(--green)}@media(max-width:480px){.word-row{grid-template-columns:1fr 1fr}.srs-badge,.word-actions{grid-column:1 / -1}.edit-row{grid-template-columns:1fr 1fr}.edit-row .input-tags{grid-column:1 / -1}.rating-buttons{grid-template-columns:repeat(2,1fr)}.card{height:220px}.card-word{font-size:1.5rem}}.error-boundary{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.75rem;padding:3rem 1.5rem;text-align:center}.error-boundary-title{font-size:1.25rem;font-weight:600;color:var(--text)}.error-boundary-message{color:var(--text-dim);font-size:.95rem}.sync-warning{color:var(--text-dim);font-size:.8rem;opacity:.7}.landing-hero{display:flex;flex-direction:column;align-items:center;gap:16px;text-align:center;padding:64px 0 48px}.landing-hero h1{font-size:2.25rem;font-weight:700;letter-spacing:-.02em;line-height:1.15}.landing-lede{color:var(--text-dim);max-width:520px;font-size:1.05rem}.landing-cta{padding:12px 28px;font-size:1rem;text-decoration:none;display:inline-block;margin-top:8px}.landing-sub{color:var(--text-dim);font-size:.85rem}.landing-features{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin:32px 0}.landing-feature{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:16px}.landing-feature-title{font-weight:600;margin-bottom:6px}.landing-feature p{color:var(--text-dim);font-size:.9rem;line-height:1.7}.landing-feature kbd{display:inline-flex;align-items:center;justify-content:center;min-width:22px;height:22px;padding:0 6px;background:var(--surface-2);border:1px solid var(--border);border-radius:4px;font-size:.75rem;font-weight:600;font-family:monospace;color:var(--text);vertical-align:baseline}.landing-how{margin:48px 0 32px}.landing-how h2{font-size:1.25rem;font-weight:600;margin-bottom:12px}.landing-how ol{padding-left:20px;color:var(--text-dim);display:flex;flex-direction:column;gap:6px}.landing-how li::marker{color:var(--text-dim)}.landing-cta-block{display:flex;justify-content:center;padding:32px 0}@media(max-width:480px){.landing-features{grid-template-columns:1fr}.landing-hero h1{font-size:1.75rem}}.error-page{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:80vh;gap:.75rem;text-align:center}.error-page h1{font-size:4rem;font-weight:700;color:var(--text);margin:0}.error-page p{color:var(--text-dim);font-size:1.1rem;margin:0 0 1rem}
