body{margin:0}#root{min-height:100dvh}*,:before,:after{box-sizing:border-box;margin:0;padding:0}body{color:#111827;background:#f5f7fa;min-height:100dvh;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}.app{flex-direction:column;max-width:480px;min-height:100dvh;margin:0 auto;display:flex;position:relative}.app-content{scroll-behavior:smooth;flex:1;padding-bottom:80px;overflow-y:auto}.page{padding:20px}.page-title{color:#111827;margin-bottom:4px;font-size:22px;font-weight:800}.page-subtitle{color:#6b7280;word-break:keep-all;margin-bottom:12px;font-size:13px;line-height:1.7}.bottom-nav{z-index:100;background:#fff;border-top:1px solid #e5e7eb;width:100%;max-width:480px;display:flex;position:fixed;bottom:0;left:50%;transform:translate(-50%)}.nav-btn{padding:12px 0 max(14px, env(safe-area-inset-bottom));cursor:pointer;color:#9ca3af;background:0 0;border:none;flex-direction:column;flex:1;align-items:center;gap:2px;font-size:11px;display:flex;position:relative}.nav-btn span:first-child{font-size:22px}.nav-btn.active{color:#22c55e}.nav-btn.active:after{content:"";bottom:max(6px, calc(env(safe-area-inset-bottom) - 8px));background:#22c55e;border-radius:50%;width:4px;height:4px;position:absolute;left:50%;transform:translate(-50%)}.today-header{justify-content:space-between;align-items:flex-start;margin-bottom:12px;display:flex}.header-badges{align-items:center;gap:8px;display:flex}.badge{border-radius:20px;padding:5px 10px;font-size:13px;font-weight:700}.badge-streak{color:#d97706;background:#fef3c7}.badge-marble{color:#7c3aed;background:#ede9fe}.progress-bar-bg{background:#e5e7eb;border-radius:4px;height:8px;margin-bottom:4px;overflow:hidden}.progress-bar-fill{background:linear-gradient(90deg,#22c55e,#16a34a);border-radius:4px;height:8px;transition:width .3s}.progress-text{color:#6b7280;margin-bottom:16px;font-size:12px}.cards-container{flex-direction:column;gap:0;display:flex}.subject-section{margin-bottom:20px}.subject-header{color:#374151;border-bottom:1px solid #e5e7eb;margin-bottom:12px;padding:10px 0;font-size:15px;font-weight:700}.card-wrapper{margin-bottom:16px}.flip-container{width:100%;min-height:200px;transform-style:preserve-3d;transform:rotateY(var(--flip));cursor:pointer;transition:transform .28s;display:grid}.card-face{backface-visibility:hidden;border:1px solid #0000000d;border-radius:16px;flex-direction:column;grid-area:1/1;justify-content:center;align-items:center;min-height:220px;padding:20px;display:flex;box-shadow:0 4px 16px #00000014,0 1px 4px #0000000a}.card-front{background:#fff}.card-back{background:#f8fafc;justify-content:flex-start;transform:rotateY(180deg)}.subject-badge{color:#fff;border-radius:10px;padding:4px 8px;font-size:12px;font-weight:700;position:absolute;top:12px;left:16px}.card-front-text{text-align:center;color:#111827;font-size:22px;font-weight:700}.flip-hint{color:#9ca3af;font-size:12px;position:absolute;bottom:12px}.card-back-text{color:#374151;text-align:center;word-break:keep-all;font-size:15px;line-height:1.7}.complete-btn{color:#fff;cursor:pointer;border:none;border-radius:24px;margin:10px auto 0;padding:10px 32px;font-size:15px;font-weight:700;transition:transform .1s,box-shadow .1s;display:block}.complete-btn:active{transform:scale(.97)}.done-tag{color:#059669;text-align:center;background:#d1fae5;border-radius:24px;margin:10px auto 0;padding:8px 20px;font-weight:700;display:block}.done-screen{justify-content:center;align-items:center;min-height:calc(100dvh - 72px);padding:24px;display:flex}.done-content{text-align:center}.done-emoji{margin-bottom:16px;font-size:64px;animation:.4s pop;display:block}.done-content h2{margin-bottom:8px;font-size:28px;font-weight:800}.done-streak{color:#22c55e;margin-bottom:16px;font-size:20px;font-weight:600}@keyframes pop{0%{transform:scale(.5)}80%{transform:scale(1.1)}to{transform:scale(1)}}.marble-chip{color:#7c3aed;background:#ede9fe;border-radius:20px;padding:10px 20px;font-weight:700;display:inline-block}.extra-learn-btn{color:#fff;cursor:pointer;background:linear-gradient(135deg,#22c55e,#16a34a);border:none;border-radius:14px;width:100%;max-width:240px;margin:20px auto 0;padding:14px 20px;font-size:16px;font-weight:700;display:block;box-shadow:0 4px 12px #22c55e4d}.modal-overlay{z-index:200;background:#00000080;justify-content:center;align-items:center;padding:24px;display:flex;position:fixed;inset:0}.modal-card{text-align:center;background:#fff;border-radius:20px;flex-direction:column;gap:12px;width:100%;max-width:400px;padding:28px;display:flex}.modal-box{background:var(--bg-primary,#fff);border-radius:16px;width:100%;max-width:380px;padding:24px;box-shadow:0 20px 60px #0000004d}.modal-emoji{font-size:48px}.modal-card h3{color:#111827;font-size:20px;font-weight:800}.modal-card p{color:#6b7280;font-size:14px}.modal-marbles{font-size:16px;font-weight:600;color:#7c3aed!important}.btn{cursor:pointer;border:none;border-radius:12px;width:100%;padding:14px;font-size:15px;font-weight:700}.btn-green{color:#fff;background:#22c55e}.btn-ghost{color:#9ca3af;background:0 0;font-weight:400}.btn-danger{color:#ef4444;background:#fef2f2;border:1px solid #fecaca}.stats-row{gap:10px;margin-bottom:16px;display:flex}.stat-card{border-radius:12px;flex-direction:column;flex:1;align-items:center;gap:4px;padding:12px;display:flex}.stat-card span{font-size:20px}.stat-card strong{color:#111827;font-size:22px;font-weight:800}.stat-card small{color:#6b7280;text-align:center;font-size:11px}.section-card{background:#fff;border-radius:14px;margin-bottom:16px;padding:16px;box-shadow:0 1px 4px #0000000d}.section-title{color:#374151;margin-bottom:12px;font-size:15px;font-weight:700}.weekly-header{color:#374151;justify-content:space-between;align-items:center;margin-bottom:10px;font-size:15px;font-weight:600;display:flex}.goal-met-badge{color:#059669;font-size:13px;font-weight:700}.weekly-progress-bg{background:#e5e7eb;border-radius:4px;height:8px;margin-bottom:12px;overflow:hidden}.weekly-progress-fill{background:#22c55e;border-radius:4px;height:8px;transition:width .3s}.day-dots{gap:8px;display:flex}.day-dot{background:#e5e7eb;border-radius:50%;width:24px;height:24px}.day-dot-filled{background:#22c55e}.heatmap-labels{gap:3px;margin-bottom:4px;display:flex}.heatmap-labels span{color:#9ca3af;text-align:center;width:14px;font-size:10px}.heatmap-cell{background:#e5e7eb;border-radius:3px;width:14px;height:14px}.heatmap-done{background:#22c55e}.heatmap-today{outline-offset:-1px;outline:2px solid #059669}.heatmap-future{background:#f3f4f6}.heatmap-legend{color:#9ca3af;justify-content:flex-end;align-items:center;gap:6px;margin-top:8px;font-size:11px;display:flex}.legend-dot{border-radius:2px;width:10px;height:10px;display:inline-block}.subject-stat-row{border-bottom:1px solid #f3f4f6;align-items:center;gap:12px;padding:12px 0;display:flex}.subject-stat-row:last-child{border-bottom:none}.subject-stat-row>span:first-child{font-size:22px}.subject-stat-name{color:#374151;flex:1;font-size:15px;font-weight:600}.subject-stat-count{color:#22c55e;font-size:16px;font-weight:700}.settings-section{margin-bottom:28px}.settings-section-title{color:#6b7280;text-transform:uppercase;letter-spacing:.5px;margin-bottom:10px;font-size:12px;font-weight:700}.settings-row{color:#374151;background:#fff;border:1px solid #0000000a;border-radius:12px;justify-content:space-between;align-items:center;margin-bottom:4px;padding:14px 16px;font-size:15px;display:flex;box-shadow:0 1px 4px #0000000d}.settings-value{color:#9ca3af;font-size:14px}.settings-notice{color:#059669;background:#f0fff4;border-radius:10px;margin-top:4px;padding:10px 12px;font-size:13px}.toggle{flex-shrink:0;width:44px;height:24px;display:inline-block;position:relative}.toggle input{opacity:0;width:0;height:0}.toggle-slider{cursor:pointer;background:#e5e7eb;border-radius:24px;transition:all .2s;position:absolute;inset:0}.toggle-slider:before{content:"";background:#fff;border-radius:50%;width:18px;height:18px;transition:all .2s;position:absolute;top:3px;left:3px}.toggle input:checked+.toggle-slider{background:#22c55e}.toggle input:checked+.toggle-slider:before{transform:translate(20px)}.card-type-badge{color:#6b7280;text-transform:uppercase;background:#f3f4f6;border-radius:6px;padding:3px 7px;font-size:10px;font-weight:600;position:absolute;top:12px;right:16px}.card-pronunciation{color:#9ca3af;margin-top:4px;font-size:13px;font-style:italic}.tts-btn{cursor:pointer;color:#6b7280;background:0 0;border:1px solid #e5e7eb;border-radius:20px;margin-top:8px;padding:4px 10px;font-size:14px;transition:background .15s}.tts-btn:hover{background:#f3f4f6}.tts-small{margin-top:4px;padding:2px 7px;font-size:12px}.card-example{text-align:left;background:#fff9;border-radius:8px;width:100%;margin-top:10px;padding:8px}.example-label{color:#9ca3af;text-transform:uppercase;margin-bottom:3px;font-size:10px;font-weight:700;display:block}.card-example p{color:#4b5563;font-size:13px;line-height:1.4}.card-synonyms{text-align:left;width:100%;margin-top:10px}.synonyms-label{color:#9ca3af;text-transform:uppercase;margin-bottom:6px;font-size:10px;font-weight:700;display:block}.synonyms-list{flex-wrap:wrap;gap:6px;display:flex}.synonym-chip{color:#7c3aed;background:#ede9fe;border-radius:20px;padding:4px 10px;font-size:12px;font-weight:600}.quiz-header{border-radius:12px 12px 0 0;justify-content:space-between;align-items:center;padding:10px 16px;display:flex}.subject-badge-inline{color:#fff;font-size:12px;font-weight:700}.quiz-mode-label{color:#fffc;font-size:11px}.quiz-controller{background:#fff;border-radius:12px;overflow:hidden;box-shadow:0 2px 8px #0000001a}.quiz-progress{background:#f9fafb;border-bottom:1px solid #e5e7eb;align-items:center;gap:8px;padding:10px 16px;display:flex}.quiz-step{color:#9ca3af;background:#e5e7eb;border-radius:50%;justify-content:center;align-items:center;width:24px;height:24px;font-size:12px;font-weight:700;display:flex}.quiz-step.active{color:#fff;background:#22c55e}.quiz-step.done{color:#059669;background:#d1fae5}.quiz-card{border-radius:20px;flex-direction:column;gap:12px;padding:24px;display:flex}.quiz-label{color:#6b7280;text-transform:uppercase;letter-spacing:.5px;font-size:11px;font-weight:700}.quiz-question{color:#111827;word-break:keep-all;overflow-wrap:break-word;text-align:center;font-size:20px;font-weight:700;line-height:1.4}.quiz-subtext{color:#9ca3af;font-size:13px}.quiz-hint{color:#6b7280;word-break:break-word;background:#f9fafb;border-radius:10px;padding:10px 12px;font-size:13px;line-height:1.5}.quiz-pronunciation{color:#9ca3af;font-size:14px;font-style:italic}.quiz-input-row{gap:8px;display:flex}.quiz-input{border:1.5px solid #e5e7eb;border-radius:12px;outline:none;flex:1;padding:13px 14px;font-size:15px}.quiz-input:focus{border-color:#22c55e}.quiz-submit-btn{color:#fff;cursor:pointer;background:#22c55e;border:none;border-radius:12px;padding:13px 20px;font-size:15px;font-weight:700}.quiz-submit-btn:disabled{color:#9ca3af;cursor:not-allowed;background:#e5e7eb}.quiz-options{flex-direction:column;gap:10px;display:flex}.quiz-option{text-align:left;color:#374151;cursor:pointer;word-break:keep-all;background:#fff;border:2px solid #e5e7eb;border-radius:12px;width:100%;min-height:52px;padding:14px 16px;font-size:15px;line-height:1.4;transition:all .15s}.quiz-option:hover:not(:disabled){background:#f0fff4;border-color:#22c55e}.quiz-option.active{color:#1d4ed8;background:#eff6ff;border-color:#3b82f6;font-weight:600}.quiz-option.correct{color:#059669;background:#f0fff4;border-color:#22c55e;font-weight:600}.quiz-option.incorrect{color:#dc2626;background:#fff1f2;border-color:#ef4444}.quiz-option:disabled{cursor:default}.quiz-feedback{border-radius:10px;flex-direction:column;gap:10px;padding:12px 14px;font-size:14px;font-weight:600;display:flex}.quiz-feedback.correct{color:#059669;background:#f0fff4}.quiz-feedback.incorrect{color:#dc2626;background:#fff1f2}.quiz-retry-btn,.quiz-skip-btn{cursor:pointer;text-align:center;background:0 0;border:1.5px solid;border-radius:10px;flex:1;min-height:48px;padding:11px 12px;font-size:14px;font-weight:600}.quiz-feedback>div{gap:8px;display:flex}.pronunciation-actions{flex-wrap:wrap;gap:10px;display:flex}.mic-btn{color:#fff;cursor:pointer;background:#3b82f6;border:none;border-radius:12px;flex:1;min-width:140px;padding:15px 12px;font-size:15px;font-weight:700;transition:background .2s,box-shadow .2s;box-shadow:0 4px 12px #3b82f659}.mic-btn.listening{background:#ef4444;animation:1s infinite pulse}.mic-btn:disabled{cursor:not-allowed;background:#93c5fd}@keyframes pulse{0%,to{opacity:1}50%{opacity:.7}}.quiz-tries{color:#9ca3af;font-size:12px}.quiz-alt-btn{color:#9ca3af;cursor:pointer;background:0 0;border:none;width:100%;margin-top:8px;padding:4px 8px;font-size:13px;text-decoration:underline;transition:color .15s}.quiz-alt-btn:disabled{opacity:.4;cursor:not-allowed}.quiz-transcript{color:#374151;background:#f9fafb;border-radius:10px;padding:10px 12px;font-size:13px;line-height:1.5}.quiz-error{color:#ef4444;background:#fff1f2;border-radius:10px;padding:10px 12px;font-size:13px}.history-filter-row{flex-wrap:wrap;gap:6px;margin-bottom:12px;display:flex}.history-filter-btn{color:#6b7280;cursor:pointer;white-space:nowrap;background:#f3f4f6;border:none;border-radius:20px;padding:6px 12px;font-size:12px;font-weight:600}.history-filter-btn.active{color:#fff;background:#22c55e}.history-list{flex-direction:column;gap:8px;display:flex}.history-item{cursor:pointer;border:1px solid #e5e7eb;border-radius:10px;overflow:hidden}.history-item.expanded{border-color:#22c55e}.history-item-header{justify-content:space-between;align-items:center;padding:10px 12px;display:flex}.history-item-meta{flex:1;align-items:center;gap:8px;min-width:0;display:flex}.history-subject-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px}.history-front{color:#111827;text-overflow:ellipsis;white-space:nowrap;font-size:14px;font-weight:600;overflow:hidden}.history-item-right{flex-shrink:0;align-items:center;gap:8px;display:flex}.history-date{color:#9ca3af;font-size:11px}.history-expand-icon{color:#9ca3af;font-size:10px}.history-item-body{background:#f9fafb;border-top:1px solid #e5e7eb;flex-direction:column;gap:6px;padding:10px 12px;display:flex}.history-back{color:#374151;font-size:13px;line-height:1.5}.history-example{color:#6b7280;font-size:12px;font-style:italic}.history-synonyms{flex-direction:column;gap:4px;display:flex}.history-times{color:#9ca3af;font-size:11px}.load-more-btn{color:#6b7280;cursor:pointer;background:0 0;border:1px solid #e5e7eb;border-radius:10px;width:100%;margin-top:10px;padding:10px;font-size:13px;display:block}.load-more-btn:hover{background:#f3f4f6}.dashboard-section{background:#fff;border-radius:14px;margin-bottom:12px;padding:14px 16px;box-shadow:0 1px 4px #0000000d}.dashboard-section-header{justify-content:space-between;align-items:center;margin-bottom:8px;display:flex}.dashboard-section-label{color:#6b7280;text-transform:uppercase;letter-spacing:.4px;font-size:13px;font-weight:700}.dashboard-today-count{color:#3b82f6;font-size:15px;font-weight:700}.dashboard-today-count.complete{color:#22c55e}.dashboard-progress-bar-bg{background:#e5e7eb;border-radius:4px;height:8px;overflow:hidden}.dashboard-progress-bar-fill{background:#3b82f6;border-radius:4px;height:8px;transition:width .3s}.dashboard-progress-bar-fill.complete{background:#22c55e}.dashboard-streak-row{justify-content:space-between;align-items:center;display:flex}.dashboard-streak-main{color:#d97706;font-size:16px;font-weight:700}.dashboard-streak-max{color:#9ca3af;font-size:12px;font-weight:600}.subject-progress-item{margin-bottom:12px}.subject-progress-item:last-child{margin-bottom:0}.subject-progress-header{color:#374151;justify-content:space-between;align-items:center;margin-bottom:5px;font-size:13px;font-weight:600;display:flex}.subject-progress-count{color:#9ca3af;font-size:11px;font-weight:500}.opacity-60{opacity:.6}.browser-page{padding:16px 16px 80px}.browser-header{margin-bottom:12px}.browser-title{color:#111827;margin:0 0 10px;font-size:18px;font-weight:700}.browser-search{box-sizing:border-box;border:1px solid #d1d5db;border-radius:8px;outline:none;width:100%;padding:9px 12px;font-size:14px}.browser-search:focus{border-color:#22c55e;box-shadow:0 0 0 2px #22c55e26}.browser-filters{flex-wrap:wrap;gap:6px;margin-bottom:10px;display:flex}.browser-count{color:#9ca3af;margin-bottom:8px;font-size:12px}.browser-empty{text-align:center;color:#9ca3af;padding:40px 0;font-size:14px}.browser-list{flex-direction:column;gap:8px;display:flex}.browser-card{background:#fff;border:1px solid #e5e7eb;border-radius:10px;align-items:flex-start;gap:10px;padding:10px 12px;display:flex}.browser-subject-badge{color:#fff;white-space:nowrap;border-radius:6px;flex-shrink:0;margin-top:2px;padding:3px 7px;font-size:10px}.browser-card-body{flex:1;min-width:0}.browser-front{color:#111827;margin:0 0 2px;font-size:14px;font-weight:600}.browser-reading{color:#6b7280;margin:0 0 2px;font-size:11px}.browser-back{color:#4b5563;margin:0;font-size:13px}.jlpt-level-badge{color:#fff;vertical-align:middle;letter-spacing:.5px;background:#f59e0b;border-radius:4px;margin-left:6px;padding:1px 5px;font-size:10px;font-weight:700;display:inline-block}.quiz-repractice-btn{color:#22c55e;cursor:pointer;background:0 0;border:2px solid #22c55e;border-radius:12px;flex:1;padding:13px 18px;font-size:15px;font-weight:600;transition:background .15s,color .15s}.quiz-repractice-btn:hover{color:#fff;background:#22c55e}.quiz-next-btn{color:#fff;cursor:pointer;background:#22c55e;border:none;border-radius:12px;flex:2;padding:15px 18px;font-size:15px;font-weight:700}.landing-page{color:#111827;background:#fff;min-height:100vh;font-family:inherit}.landing-hero{color:#fff;text-align:center;background:linear-gradient(135deg,#22c55e 0%,#16a34a 100%);padding:60px 20px 48px}.landing-hero-inner{max-width:600px;margin:0 auto}.landing-title{letter-spacing:-.5px;margin:0 0 12px;font-size:2.4rem;font-weight:800}.landing-subtitle{opacity:.92;margin:0 0 28px;font-size:1.1rem;line-height:1.6}.landing-cta{color:#16a34a;cursor:pointer;background:#fff;border:none;border-radius:50px;padding:14px 32px;font-size:1.05rem;font-weight:700;transition:transform .15s,box-shadow .15s;display:inline-block;box-shadow:0 4px 16px #00000026}.landing-cta:hover{transform:translateY(-2px);box-shadow:0 6px 20px #0003}.landing-main{max-width:720px;margin:0 auto;padding:0 20px 40px}.landing-section{border-top:1px solid #f3f4f6;margin-top:12px;padding:36px 0 0}.landing-section:first-child{border-top:none}.landing-section h2{color:#111827;margin:0 0 12px;font-size:1.4rem;font-weight:700}.landing-section h3{color:#374151;margin:16px 0 8px;font-size:1.05rem;font-weight:600}.landing-section p{color:#4b5563;margin:0 0 12px;font-size:.97rem;line-height:1.75}.landing-subjects{grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:14px;margin-top:4px;display:grid}.landing-subject-card{background:#f9fafb;border:1px solid #e5e7eb;border-radius:12px;padding:16px}.landing-subject-card .subject-emoji{margin-bottom:6px;font-size:1.6rem;display:block}.landing-subject-card h3{color:#111827;margin:0 0 6px;font-size:1rem;font-weight:700}.landing-subject-card p{color:#6b7280;margin:0;font-size:.85rem;line-height:1.6}.landing-features,.landing-recommend{margin:0;padding:0;list-style:none}.landing-features li,.landing-recommend li{color:#4b5563;padding:4px 0 4px 22px;font-size:.95rem;line-height:1.7;position:relative}.landing-features li:before{content:"✓";color:#22c55e;font-weight:700;position:absolute;left:0}.landing-recommend li:before{content:"→";color:#22c55e;font-weight:700;position:absolute;left:0}.landing-cta-section{text-align:center}.landing-footer{text-align:center;color:#6b7280;background:#f9fafb;border-top:1px solid #e5e7eb;padding:24px 20px;font-size:13px}.landing-ai-cards{grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:14px;margin-top:16px;display:grid}.landing-ai-card{background:#f0fdf4;border:1px solid #bbf7d0;border-radius:12px;padding:16px}.landing-ai-card-subject{color:#6b7280;margin-bottom:6px;font-size:.75rem;font-weight:600;display:inline-block}.landing-ai-card-front{color:#111827;margin:0 0 6px;font-size:1rem;font-weight:700}.landing-ai-card-back{color:#374151;margin:0 0 6px;font-size:.88rem;line-height:1.6}.landing-ai-card-example{color:#6b7280;margin:0;font-size:.82rem;font-style:italic;line-height:1.5}
