:root{--color-bg: #fafafa;--color-surface: #ffffff;--color-border: #e2e2e2;--color-text: #1a1a1a;--color-text-muted: #6b6b6b;--color-primary: #2563eb;--color-primary-hover: #1d4ed8;--color-danger: #dc2626;--color-danger-hover: #b91c1c;--color-success: #16a34a;--color-warning: #d97706;--radius: .5rem;--radius-lg: .75rem;--shadow: 0 1px 3px rgba(0, 0, 0, .08);--shadow-md: 0 4px 12px rgba(0, 0, 0, .1);--max-width: 48rem}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:100%}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;color:var(--color-text);background:var(--color-bg);line-height:1.6;-webkit-font-smoothing:antialiased}a{color:var(--color-primary);text-decoration:none}a:hover{text-decoration:underline}.container{max-width:var(--max-width);margin:0 auto;padding:0 1rem}nav.topnav{background:var(--color-surface);border-bottom:1px solid var(--color-border);padding:.75rem 0;position:sticky;top:0;z-index:100}nav.topnav .nav-inner{max-width:var(--max-width);margin:0 auto;padding:0 1rem;display:flex;align-items:center;justify-content:space-between}nav.topnav .nav-brand{font-weight:700;font-size:1.125rem;color:var(--color-text);text-decoration:none}nav.topnav .nav-links{display:flex;gap:1.5rem;align-items:center}nav.topnav .nav-links a{color:var(--color-text-muted);font-size:.875rem;font-weight:500;transition:color .15s}nav.topnav .nav-links a:hover{color:var(--color-text);text-decoration:none}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.5rem 1rem;border-radius:var(--radius);font-size:.875rem;font-weight:500;border:1px solid transparent;cursor:pointer;transition:all .15s;line-height:1.4}.btn:hover{text-decoration:none}.btn-primary{background:var(--color-primary);color:#fff}.btn-primary:hover{background:var(--color-primary-hover)}.btn-danger{background:var(--color-danger);color:#fff}.btn-danger:hover{background:var(--color-danger-hover)}.btn-outline{background:transparent;border-color:var(--color-border);color:var(--color-text)}.btn-outline:hover{background:var(--color-bg)}.btn-sm{padding:.25rem .625rem;font-size:.8125rem}.btn-lg{padding:.75rem 1.5rem;font-size:1rem}.card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:1.25rem;box-shadow:var(--shadow)}.form-group{margin-bottom:1rem}.form-group label{display:block;font-size:.875rem;font-weight:500;margin-bottom:.375rem}.form-group input,.form-group textarea,.form-group select{width:100%;padding:.5rem .75rem;border:1px solid var(--color-border);border-radius:var(--radius);font-size:max(1rem,16px);font-family:inherit;background:var(--color-surface);color:var(--color-text);transition:border-color .15s}.form-group input:focus,.form-group textarea:focus,.form-group select:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #2563eb1a}.form-group textarea{resize:vertical;min-height:5rem}.page-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.5rem;padding-top:1.5rem}.page-header h1{font-size:1.5rem;font-weight:700}.empty-state{text-align:center;padding:3rem 1rem;color:var(--color-text-muted)}.empty-state p{margin-bottom:1rem}.badge{display:inline-flex;align-items:center;padding:.125rem .5rem;border-radius:9999px;font-size:.75rem;font-weight:600}.badge-due{background:#fef3c7;color:#92400e}.badge-done{background:#dcfce7;color:#166534}.badge-next{background:#e0f2fe;color:#0c4a6e}.error-msg{background:#fef2f2;color:var(--color-danger);padding:.75rem 1rem;border-radius:var(--radius);font-size:.875rem;margin-bottom:1rem}.review-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);min-height:16rem;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2rem;text-align:center;cursor:pointer;-webkit-user-select:none;user-select:none;transition:box-shadow .15s}.review-card:hover{box-shadow:0 6px 20px #0000001f}.review-card .card-text{font-size:1.25rem;line-height:1.5}.review-card .card-hint{font-size:.8125rem;color:var(--color-text-muted);margin-top:1rem}.review-card img{max-width:100%;max-height:12rem;border-radius:var(--radius);margin-top:1rem}.rating-buttons{display:grid;grid-template-columns:repeat(4,1fr);gap:.5rem;margin-top:1.25rem}.rating-btn{padding:.625rem;border-radius:var(--radius);border:1px solid var(--color-border);background:var(--color-surface);cursor:pointer;text-align:center;transition:all .15s}.rating-btn:hover{border-color:var(--color-primary)}.rating-btn .rating-label{font-weight:600;font-size:.875rem}.rating-btn .rating-interval{font-size:.75rem;color:var(--color-text-muted)}.rating-btn.again{border-color:#fca5a5}.rating-btn.again:hover{background:#fef2f2}.rating-btn.hard{border-color:#fdba74}.rating-btn.hard:hover{background:#fffbeb}.rating-btn.good{border-color:#86efac}.rating-btn.good:hover{background:#f0fdf4}.rating-btn.easy{border-color:#93c5fd}.rating-btn.easy:hover{background:#eff6ff}.progress-bar{width:100%;height:.375rem;background:var(--color-border);border-radius:9999px;overflow:hidden;margin-bottom:1rem}.progress-bar .progress-fill{height:100%;background:var(--color-primary);border-radius:9999px;transition:width .3s ease}.audio-btn{display:inline-flex;align-items:center;gap:.375rem;padding:.375rem .75rem;border-radius:var(--radius);border:1px solid var(--color-border);background:var(--color-surface);cursor:pointer;font-size:.8125rem;color:var(--color-text-muted);transition:all .15s}.audio-btn:hover{border-color:var(--color-primary);color:var(--color-primary)}.deck-list{display:flex;flex-direction:column;gap:.75rem}.deck-item{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.25rem;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow);transition:box-shadow .15s}.deck-item:hover{box-shadow:var(--shadow-md)}.deck-item .deck-info{flex:1}.deck-item .deck-name{font-weight:600;font-size:1rem;color:var(--color-text)}.deck-item .deck-stats{font-size:.8125rem;color:var(--color-text-muted);margin-top:.125rem}.deck-item .deck-actions{display:flex;gap:.5rem;align-items:center}.card-list{display:flex;flex-direction:column;gap:.5rem}.card-item{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;padding:.875rem 1rem;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius)}.card-item .card-content{flex:1;min-width:0}.card-item .card-front{font-weight:500;font-size:.9375rem}.card-item .card-back{font-size:.8125rem;color:var(--color-text-muted);margin-top:.125rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.card-item .card-actions{display:flex;gap:.375rem;flex-shrink:0}.nav-progress.svelte-12qhfyh{position:fixed;top:0;left:0;right:0;height:3px;z-index:9999;overflow:hidden}.nav-progress-bar.svelte-12qhfyh{height:100%;background:var(--color-primary);border-radius:0 2px 2px 0;animation:svelte-12qhfyh-progress 12s ease-out forwards;box-shadow:0 0 8px #2563eb66}@keyframes svelte-12qhfyh-progress{0%{width:0}15%{width:18%}35%{width:42%}60%{width:68%}80%{width:82%}to{width:92%}}.nav-btn.svelte-12qhfyh{background:none;border:none;color:var(--color-text-muted);font-size:.875rem;font-weight:500;cursor:pointer;padding:0;font-family:inherit;transition:color .15s}.nav-btn.svelte-12qhfyh:hover{color:var(--color-text)}.session-refresh.svelte-12qhfyh{display:flex;align-items:center;justify-content:center;min-height:100vh}.session-refresh.svelte-12qhfyh svg:where(.svelte-12qhfyh){animation:svelte-12qhfyh-spin 1s linear infinite}@keyframes svelte-12qhfyh-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}
