*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--green: #2e7d32;--green-light: #4caf50;--green-bg: #e8f5e9;--red: #c62828;--orange: #e65100;--yellow: #f9a825;--blue: #1565c0;--text: #212121;--text-secondary: #616161;--border: #e0e0e0;--card-bg: #ffffff;--bg: #f5f5f5;--radius: 12px;--shadow: 0 2px 8px rgba(0,0,0,.12)}html,body{height:100%;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:var(--bg);color:var(--text);font-size:16px;line-height:1.5}#root{min-height:100%;display:flex;flex-direction:column}button{cursor:pointer;border:none;background:none;font-family:inherit;font-size:inherit}.pin-screen{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;padding:24px;gap:24px}.pin-screen h1{font-size:1.8rem;color:var(--green);text-align:center}.pin-screen p{color:var(--text-secondary);text-align:center}.pin-display{display:flex;gap:12px;margin:8px 0}.pin-dot{width:16px;height:16px;border-radius:50%;background:var(--border);transition:background .15s}.pin-dot.filled{background:var(--green)}.pin-keypad{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;width:100%;max-width:280px}.pin-key{aspect-ratio:1;border-radius:50%;background:#fff;box-shadow:var(--shadow);font-size:1.4rem;font-weight:500;color:var(--text);transition:background .1s}.pin-key:active{background:var(--green-bg)}.pin-key.delete{font-size:1.1rem;color:var(--text-secondary)}.pin-error{color:var(--red);font-size:.9rem}.home-screen{display:flex;flex-direction:column;min-height:100vh}.home-header{background:var(--green);color:#fff;padding:20px 16px 16px}.home-header h1{font-size:1.3rem;font-weight:600}.home-header p{font-size:.85rem;opacity:.85;margin-top:2px}.topic-list{flex:1;padding:16px 16px 100px;display:flex;flex-direction:column;gap:10px}.topic-card{background:#fff;border-radius:var(--radius);box-shadow:var(--shadow);padding:14px 16px;display:flex;align-items:center;gap:12px}.topic-info{flex:1;min-width:0}.topic-title{font-weight:600;font-size:.95rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.topic-progress{font-size:.8rem;color:var(--text-secondary);margin-top:2px}.topic-actions{display:flex;align-items:center;gap:10px;flex-shrink:0}.train-btn{background:var(--green);color:#fff;padding:6px 14px;border-radius:20px;font-size:.85rem;font-weight:500}.train-btn:disabled{background:var(--border);color:var(--text-secondary);cursor:default}.toggle{position:relative;width:44px;height:24px}.toggle input{opacity:0;width:0;height:0}.toggle-slider{position:absolute;top:0;right:0;bottom:0;left:0;background:#ccc;border-radius:24px;transition:background .2s;cursor:pointer}.toggle-slider:before{content:"";position:absolute;width:18px;height:18px;border-radius:50%;background:#fff;top:3px;left:3px;transition:transform .2s;box-shadow:0 1px 3px #0003}.toggle input:checked+.toggle-slider{background:var(--green)}.toggle input:checked+.toggle-slider:before{transform:translate(20px)}.fab{position:fixed;bottom:24px;left:50%;transform:translate(-50%);background:var(--green);color:#fff;padding:14px 28px;border-radius:28px;font-size:1rem;font-weight:600;box-shadow:0 4px 16px #2e7d3266;white-space:nowrap;z-index:10}.fab:disabled{background:#9e9e9e;box-shadow:none;cursor:default}.study-screen{display:flex;flex-direction:column;min-height:100vh;background:var(--bg)}.study-header{background:var(--green);color:#fff;padding:14px 16px;display:flex;align-items:center;gap:12px}.back-btn{color:#fff;font-size:1.4rem;line-height:1;padding:4px}.study-header h2{flex:1;font-size:1rem;font-weight:600}.study-header .card-count{font-size:.85rem;opacity:.85}.progress-bar-wrap{height:4px;background:#ffffff4d}.progress-bar-fill{height:100%;background:#fff;transition:width .3s}.study-content{flex:1;padding:16px 16px 24px;display:flex;flex-direction:column;gap:16px}.phase-label{font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--text-secondary);text-align:center}.card{background:#fff;border-radius:var(--radius);box-shadow:var(--shadow);padding:24px 20px;min-height:160px;display:flex;flex-direction:column;gap:16px}.card-question{font-size:1.05rem;font-weight:500;line-height:1.5;color:var(--text)}.card-answer{font-size:.95rem;color:var(--text-secondary);line-height:1.6;white-space:pre-wrap;border-top:1px solid var(--border);padding-top:12px}.flip-card-wrapper{perspective:1000px}.flip-card{background:#fff;border-radius:var(--radius);box-shadow:var(--shadow);padding:24px 20px;min-height:160px;display:flex;flex-direction:column;justify-content:center;align-items:center;cursor:pointer;text-align:center;gap:12px;transition:background .15s;position:relative}.flip-card:active{background:var(--green-bg)}.flip-card .flip-hint{font-size:.75rem;color:var(--text-secondary);position:absolute;bottom:12px;left:0;right:0;text-align:center}.flip-card-front{font-size:1.05rem;font-weight:500;color:var(--text)}.flip-card-back{font-size:.95rem;color:var(--text-secondary);white-space:pre-wrap;text-align:left;width:100%}.flip-card-back .flip-card-question{font-size:.85rem;color:var(--text-secondary);margin-bottom:8px}.flip-card-back .flip-card-answer{font-size:1rem;color:var(--text);font-weight:500}.mc-options{display:flex;flex-direction:column;gap:10px}.mc-option{background:#fff;border:2px solid var(--border);border-radius:var(--radius);padding:14px 16px;font-size:.95rem;text-align:left;transition:border-color .15s,background .15s}.mc-option:active{background:var(--green-bg)}.mc-option.correct{border-color:var(--green);background:var(--green-bg);color:var(--green)}.mc-option.wrong{border-color:var(--red);background:#ffebee;color:var(--red)}.rating-section{display:flex;flex-direction:column;gap:8px}.rating-label{font-size:.8rem;color:var(--text-secondary);text-align:center}.rating-buttons{display:flex;gap:8px}.rating-btn{flex:1;aspect-ratio:1;border-radius:var(--radius);font-size:1.1rem;font-weight:700;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;transition:opacity .1s}.rating-btn:active{opacity:.8}.rating-btn span.sublabel{font-size:.55rem;font-weight:500;text-transform:uppercase;letter-spacing:.04em}.rating-1{background:#ffcdd2;color:var(--red)}.rating-2{background:#ffe0b2;color:var(--orange)}.rating-3{background:#fff9c4;color:#827717}.rating-4{background:#dcedc8;color:#558b2f}.rating-5{background:var(--green-bg);color:var(--green)}.done-screen{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;padding:32px 24px;gap:20px;text-align:center}.done-icon{font-size:4rem}.done-screen h2{font-size:1.6rem;color:var(--green)}.done-screen p{color:var(--text-secondary);font-size:.95rem}.done-btn{background:var(--green);color:#fff;padding:14px 32px;border-radius:28px;font-size:1rem;font-weight:600;box-shadow:var(--shadow)}.mastered-badge{display:inline-flex;align-items:center;gap:4px;background:var(--green-bg);color:var(--green);font-size:.75rem;font-weight:600;padding:2px 8px;border-radius:12px}@media (min-width: 640px){.home-screen,.study-screen,.pin-screen,.done-screen{max-width:720px;margin:0 auto;width:100%}#root{align-items:center;background:#e0e0e0}.home-screen,.study-screen{background:var(--bg);min-height:100vh;box-shadow:0 0 24px #00000026}.home-header{padding:24px 24px 20px}.topic-list{padding:20px 24px 120px;display:grid;grid-template-columns:1fr 1fr;gap:12px}.topic-card{padding:16px 18px}.study-content{padding:20px 24px;max-width:560px;align-self:center;width:100%}.card{padding:28px 24px;min-height:200px}.flip-card{min-height:200px;padding:28px 24px}.rating-btn{font-size:1.3rem;padding:12px 4px;aspect-ratio:unset}.pin-screen,.done-screen{min-height:100vh}}
