*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--bg:#f8f9fa;--surface:#fff;--text:#1a1a2e;--text-secondary:#6b7280;--border:#e5e7eb;--blue:#3b82f6;--blue-light:#dbeafe;--green:#10b981;--green-light:#d1fae5;--orange:#f59e0b;--orange-light:#fef3c7;--red:#ef4444;--red-light:#fee2e2;--purple:#8b5cf6;--purple-light:#ede9fe;--radius:10px;--shadow-sm:0 1px 2px #0000000d;--shadow:0 1px 3px #0000001a, 0 1px 2px #0000000f;color:var(--text);background:var(--bg);-webkit-font-smoothing:antialiased;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,system-ui,sans-serif;font-size:15px;line-height:1.5}@media (prefers-color-scheme:dark){:root{--bg:#0f1117;--surface:#1a1b23;--text:#e5e7eb;--text-secondary:#9ca3af;--border:#2d2f3a;--blue-light:#1e2a4a;--green-light:#0d2818;--orange-light:#2a2008;--red-light:#2a0e0e;--purple-light:#1e1538;--shadow-sm:0 1px 2px #0003;--shadow:0 1px 3px #0000004d, 0 1px 2px #0003}}body{margin:0}#root{min-height:100dvh}.app-header{z-index:100;background:var(--surface);border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;gap:12px;padding:10px 16px;display:flex;position:sticky;top:0}.header-left{align-items:center;gap:10px;display:flex}.app-title{color:var(--text);font-size:17px;font-weight:700;line-height:1.2}.app-subtitle{color:var(--text-secondary);font-size:12px;line-height:1.2}.icon-btn{color:var(--text);cursor:pointer;-webkit-tap-highlight-color:transparent;background:0 0;border:none;border-radius:8px;justify-content:center;align-items:center;padding:8px;display:flex}.icon-btn:hover{background:var(--border)}.tab-bar{background:var(--surface);border-bottom:1px solid var(--border);gap:0;padding:0 16px;display:flex}.tab{color:var(--text-secondary);cursor:pointer;text-align:center;-webkit-tap-highlight-color:transparent;background:0 0;border:none;border-bottom:2px solid #0000;flex:1;padding:10px 16px;font-size:14px;font-weight:600;transition:color .15s,border-color .15s}.tab:hover{color:var(--text)}.tab-active{color:var(--blue);border-bottom-color:var(--blue)}.overview-bar{background:var(--surface);border-bottom:1px solid var(--border);padding:12px 16px}.overview-stats{gap:20px;margin-bottom:8px;display:flex}.stat-group{align-items:baseline;gap:6px;display:flex}.stat-label{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;font-size:12px;font-weight:600}.stat-value{font-size:15px;font-weight:700}.must-color{color:var(--blue)}.nice-color{color:var(--purple)}.hours-row{justify-content:space-between;align-items:baseline;margin:6px 0 4px;display:flex}.hours-remaining{color:var(--orange);font-size:16px;font-weight:700}.hours-detail{color:var(--text-secondary);font-size:12px}.pace-message{color:var(--text-secondary);background:var(--bg);text-align:center;border-radius:6px;margin-bottom:6px;padding:4px 10px;font-size:12px;font-weight:600}.progress-bar{background:var(--border);border-radius:99px;width:100%;position:relative;overflow:hidden}.progress-fill{border-radius:99px;height:100%;transition:width .3s}.progress-label{color:#fff;text-shadow:0 1px 3px #00000080;pointer-events:none;justify-content:center;align-items:center;font-size:13px;font-weight:700;display:flex;position:absolute;inset:0}.toolbar{z-index:90;background:var(--bg);border-bottom:1px solid var(--border);flex-direction:column;gap:8px;padding:10px 16px;display:flex;position:sticky;top:53px}.filter-pills{-webkit-overflow-scrolling:touch;gap:6px;display:flex;overflow-x:auto}.pill{border:1px solid var(--border);background:var(--surface);color:var(--text-secondary);cursor:pointer;white-space:nowrap;-webkit-tap-highlight-color:transparent;border-radius:99px;padding:5px 14px;font-size:13px;font-weight:500}.pill:hover{border-color:var(--blue);color:var(--blue)}.pill-active{background:var(--blue);color:#fff;border-color:var(--blue)}.search-input{border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);width:100%;color:var(--text);outline:none;padding:8px 12px;font-size:14px}.search-input:focus{border-color:var(--blue);box-shadow:0 0 0 2px var(--blue-light)}.main-content{width:100%;max-width:800px;margin:0 auto;padding:16px}.week-section{margin-bottom:24px}.week-header{cursor:pointer;-webkit-tap-highlight-color:transparent;justify-content:space-between;align-items:center;padding:8px 0;display:flex}.week-title{color:var(--text);margin:0;font-size:18px;font-weight:700}.week-subtitle{color:var(--text-secondary);margin:2px 0 0;font-size:13px}.week-header-right{align-items:center;gap:8px;display:flex}.week-pct{color:var(--blue);font-size:15px;font-weight:700}.chevron{color:var(--text-secondary);font-size:12px}.week-days{flex-direction:column;gap:10px;margin-top:12px;display:flex}.day-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);overflow:hidden}.day-card.active-day{border-color:var(--blue);box-shadow:0 0 0 2px var(--blue-light)}.day-card.day-complete{border-color:var(--green)}.rest-day{opacity:.7}.day-header{cursor:pointer;-webkit-tap-highlight-color:transparent;justify-content:space-between;align-items:center;gap:8px;padding:12px 14px;display:flex}.day-header-left{align-items:center;gap:10px;min-width:0;display:flex}.day-header-right{flex-shrink:0;align-items:center;gap:8px;display:flex}.day-badge{border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;font-size:12px;font-weight:700;display:flex}.day-badge.pending{background:var(--blue-light);color:var(--blue)}.day-badge.done{background:var(--green-light);color:var(--green);font-size:16px}.day-badge.rest{background:var(--orange-light);color:var(--orange);font-size:10px}.day-title{color:var(--text);font-size:14px;font-weight:600;line-height:1.2}.day-subtitle{color:var(--text-secondary);font-size:12px}.day-count{color:var(--text-secondary);font-size:13px;font-weight:600}.day-hours-badge{color:var(--orange);background:var(--orange-light);border-radius:99px;padding:2px 8px;font-size:11px;font-weight:600}.day-body{padding:0 14px 14px}.task-section{margin-top:12px}.task-section-header{text-transform:uppercase;letter-spacing:.5px;justify-content:space-between;align-items:center;padding:6px 0;font-size:12px;font-weight:700;display:flex}.must-header{color:var(--blue)}.nice-header{color:var(--purple)}.task-section-count{font-size:11px;font-weight:600}.task-item{cursor:pointer;-webkit-tap-highlight-color:transparent;-webkit-user-select:none;user-select:none;overflow-anchor:none;border-radius:8px;align-items:flex-start;gap:10px;padding:10px 8px;transition:background .15s;display:flex}.task-item:hover{background:var(--bg)}.task-check{border:2px solid var(--border);border-radius:6px;flex-shrink:0;justify-content:center;align-items:center;width:22px;height:22px;margin-top:1px;transition:all .15s;display:flex}.task-must .task-check{border-color:var(--blue)}.task-nice .task-check{border-color:var(--purple)}.task-quiz .task-check{border-color:var(--orange)}.task-quiz .task-hours{background:var(--orange-light);color:var(--orange)}.task-done .task-check{background:var(--green);border-color:var(--green)}.task-done .task-check:after{content:"✓";color:#fff;font-size:14px;font-weight:700}.task-text{color:var(--text);font-size:14px;line-height:1.5}.task-done .task-text{opacity:.5;text-decoration:line-through}.task-text a{color:var(--blue);background:var(--blue-light);border-radius:4px;padding:2px 6px;font-size:12px;font-weight:600;text-decoration:none}.task-text a:hover{text-decoration:underline}.task-hours{color:var(--text-secondary);background:var(--bg);white-space:nowrap;border-radius:99px;flex-shrink:0;align-self:center;padding:2px 8px;font-size:11px;font-weight:600}.task-done .task-hours{opacity:.4}.task-wrapper{border-radius:8px;position:relative}.task-detail-btn{color:var(--blue);background:var(--blue-light);cursor:pointer;white-space:nowrap;-webkit-tap-highlight-color:transparent;border:none;border-radius:99px;flex-shrink:0;align-self:center;padding:2px 10px;font-size:11px;font-weight:600}.task-detail-btn:hover{opacity:.8}.task-detail{background:var(--bg);border-left:3px solid var(--blue);border-radius:8px;margin:0 8px 8px 40px;padding:10px 14px}.task-detail p{color:var(--text-secondary);margin:0;font-size:13px;line-height:1.6}.task-detail p+p{margin-top:6px}.task-done .task-detail{opacity:.5}.proof-section{background:var(--green-light);border-radius:8px;margin-top:14px;padding:10px 12px}.proof-label{text-transform:uppercase;letter-spacing:.5px;color:var(--green);margin-bottom:4px;font-size:11px;font-weight:700}.proof-text{color:var(--text-secondary);font-size:13px;font-style:italic;line-height:1.5}.course-ref{margin-top:32px;margin-bottom:24px}.course-ref-title{margin-bottom:12px;font-size:18px;font-weight:700}.course-table{flex-direction:column;gap:4px;display:flex}.course-row{background:var(--surface);border:1px solid var(--border);color:var(--text);border-radius:8px;align-items:center;gap:10px;padding:10px 12px;text-decoration:none;transition:border-color .15s;display:flex}.course-row:hover{border-color:var(--blue)}.course-num{color:var(--text-secondary);flex-shrink:0;width:28px;font-size:12px;font-weight:700}.course-name{flex:1;min-width:0;font-size:14px}.course-hours{color:var(--text-secondary);flex-shrink:0;font-size:12px}.completion-banner{text-align:center;margin-bottom:40px;padding:24px 16px}.completion-text{color:var(--text-secondary);font-size:15px;font-style:italic;font-weight:600}.sidebar-overlay{z-index:200;background:#0006;position:fixed;inset:0}.sidebar{background:var(--surface);z-index:201;-webkit-overflow-scrolling:touch;width:280px;max-width:85vw;transition:transform .25s;position:fixed;top:0;bottom:0;left:0;overflow-y:auto;transform:translate(-100%)}.sidebar-open{transform:translate(0)}.sidebar-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:16px;display:flex}.sidebar-header h3{font-size:16px;font-weight:700}.sidebar-close{color:var(--text-secondary);cursor:pointer;background:0 0;border:none;padding:4px 8px;font-size:24px}.nav-week{padding:12px 16px}.nav-week-title{text-transform:uppercase;letter-spacing:.5px;color:var(--text-secondary);margin-bottom:6px;font-size:11px;font-weight:700}.nav-day{cursor:pointer;text-align:left;width:100%;color:var(--text);-webkit-tap-highlight-color:transparent;background:0 0;border:none;border-radius:8px;align-items:center;gap:8px;padding:8px 10px;font-size:14px;display:flex}.nav-day:hover{background:var(--bg)}.nav-active{background:var(--blue-light)!important}.nav-done .nav-day-num{color:var(--green)}.nav-day-num{text-align:center;flex-shrink:0;width:20px;font-size:13px;font-weight:700}.nav-day-label{text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0;overflow:hidden}.nav-day-pct{color:var(--text-secondary);flex-shrink:0;font-size:12px;font-weight:600}.modal-overlay{z-index:300;background:#00000080;justify-content:center;align-items:center;padding:16px;display:flex;position:fixed;inset:0}.modal{background:var(--surface);border-radius:16px;width:100%;max-width:440px;max-height:85vh;overflow-y:auto;box-shadow:0 20px 60px #0000004d}.modal-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:16px 20px;display:flex}.modal-header h2{margin:0;font-size:18px}.modal-close{color:var(--text-secondary);cursor:pointer;background:0 0;border:none;padding:4px 8px;font-size:24px}.modal-body{padding:20px}.settings-section{margin-bottom:24px}.settings-section h3{margin-bottom:4px;font-size:15px;font-weight:700}.settings-section p{color:var(--text-secondary);margin-bottom:10px;font-size:13px}.btn{cursor:pointer;-webkit-tap-highlight-color:transparent;border:none;border-radius:8px;padding:10px 18px;font-size:14px;font-weight:600}.btn-primary{background:var(--blue);color:#fff}.btn-primary:hover{opacity:.9}.btn-secondary{background:var(--bg);color:var(--text);border:1px solid var(--border)}.btn-secondary:hover{border-color:var(--blue)}.btn-secondary:disabled{opacity:.5;cursor:default}.btn-danger{background:var(--red);color:#fff}.btn-danger:hover{opacity:.9}.import-row{margin-bottom:10px}.import-textarea{border:1px solid var(--border);resize:vertical;background:var(--bg);width:100%;color:var(--text);border-radius:8px;margin-bottom:8px;padding:10px;font-family:monospace;font-size:13px}.danger-section{border-top:1px solid var(--border);padding-top:16px}.settings-message{background:var(--green-light);color:var(--green);text-align:center;border-radius:8px;padding:10px 14px;font-size:13px;font-weight:600}@media (width>=768px){.toolbar{flex-direction:row;justify-content:space-between;align-items:center}.search-input{width:250px}.main-content{padding:24px 32px}}.sparkle-container{pointer-events:none;z-index:10;position:absolute;top:11px;left:19px}.sparkle-particle{background:var(--color);width:12px;height:12px;animation:.7s ease-out forwards sparkle-burst;animation-delay:var(--delay);opacity:0;border-radius:50%;position:absolute}@keyframes sparkle-burst{0%{opacity:1;transform:translate(0)scale(.6)}40%{opacity:1}to{transform:translate(var(--tx), var(--ty)) scale(0);opacity:0}}.confetti-overlay{pointer-events:none;z-index:999;position:fixed;inset:0;overflow:hidden}.confetti-piece{top:-20px;left:var(--x);width:var(--w);height:var(--h);background:var(--color);opacity:0;animation:confetti-fall var(--duration) ease-in forwards;animation-delay:var(--delay);border-radius:2px;position:absolute}@keyframes confetti-fall{0%{opacity:1;transform:translateY(0)rotate(0)rotateX(0)}75%{opacity:1}to{transform:translateY(105vh) rotateZ(var(--spin)) rotateX(720deg);opacity:0}}.confetti-banner{text-align:center;opacity:0;animation:.6s cubic-bezier(.34,1.56,.64,1) forwards banner-pop;position:absolute;top:30vh;left:0;right:0}.confetti-banner-text{color:var(--green);background:var(--surface);border-radius:16px;padding:12px 32px;font-size:28px;font-weight:800;display:inline-block;box-shadow:0 8px 32px #00000026}@keyframes banner-pop{0%{opacity:0;transform:scale(.3)}to{opacity:1;transform:scale(1)}}.checklist-view{width:100%}.checklist-overview{background:var(--surface);border-bottom:1px solid var(--border);padding:12px 16px}.checklist-stats-row{justify-content:space-between;align-items:baseline;margin-bottom:8px;display:flex}.checklist-stats-label{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;font-size:12px;font-weight:600}.checklist-stats-value{color:var(--blue);font-size:15px;font-weight:700}.cl-section{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);margin-bottom:12px;overflow:hidden}.cl-section-done{border-color:var(--green)}.cl-section-header{cursor:pointer;-webkit-tap-highlight-color:transparent;justify-content:space-between;align-items:center;gap:8px;padding:14px;display:flex}.cl-section-header-left{min-width:0}.cl-section-title{color:var(--text);margin:0;font-size:15px;font-weight:700;line-height:1.3}.cl-section-subtitle{color:var(--text-secondary);margin:2px 0 0;font-size:12px}.cl-section-header-right{flex-shrink:0;align-items:center;gap:8px;display:flex}.cl-section-count{color:var(--text-secondary);font-size:13px;font-weight:600}.cl-count-done{color:var(--green)}.cl-section-pct{color:var(--blue);text-align:right;min-width:32px;font-size:13px;font-weight:700}.cl-pct-done{color:var(--green)}.cl-section-items{padding:0 14px 10px}.cl-item{cursor:pointer;-webkit-tap-highlight-color:transparent;-webkit-user-select:none;user-select:none;border-radius:8px;align-items:flex-start;gap:10px;padding:8px;transition:background .15s;display:flex}.cl-item:hover{background:var(--bg)}.cl-item-check-wrapper{flex-shrink:0;position:relative}.cl-item-check{border:2px solid var(--blue);border-radius:6px;justify-content:center;align-items:center;width:22px;height:22px;margin-top:1px;transition:all .15s;display:flex}.cl-item-done .cl-item-check{background:var(--green);border-color:var(--green)}.cl-item-done .cl-item-check:after{content:"✓";color:#fff;font-size:14px;font-weight:700}.cl-item-text{color:var(--text);font-size:14px;line-height:1.5}.cl-item-done .cl-item-text{opacity:.5;text-decoration:line-through}@media (prefers-reduced-motion:reduce){.sparkle-particle,.confetti-piece,.confetti-banner{animation:none;display:none}}.vocab-drill{flex-direction:column;gap:16px;width:100%;max-width:800px;margin:0 auto;padding:16px 16px 70vh;display:flex}.vocab-overview{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);padding:14px 16px}.vocab-stats-row{flex-wrap:wrap;gap:16px;margin-bottom:10px;display:flex}.vocab-stat{flex-direction:column;gap:2px;display:flex}.vocab-stat-value{color:var(--green);font-size:22px;font-weight:700;line-height:1}.vocab-stat-value.vocab-stat-progress{color:var(--orange)}.vocab-stat-value.vocab-stat-untouched{color:var(--text-secondary)}.vocab-stat-label{text-transform:uppercase;letter-spacing:.5px;color:var(--text-secondary);font-size:11px;font-weight:600}.vocab-progress-bar-wrap{align-items:center;gap:10px;display:flex}.vocab-progress-bar{background:var(--border);border-radius:99px;flex:1;height:8px;overflow:hidden}.vocab-progress-fill{background:var(--green);border-radius:99px;height:100%;transition:width .3s}.vocab-progress-pct{color:var(--green);text-align:right;min-width:40px;font-size:13px;font-weight:700}.vocab-controls{flex-wrap:wrap;align-items:flex-end;gap:10px;display:flex}.vocab-filter-panel{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);padding:14px 16px}.vocab-filter-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:10px;margin-bottom:10px;display:flex}.vocab-filter-title{text-transform:uppercase;letter-spacing:.5px;color:var(--text-secondary);font-size:12px;font-weight:700}.vocab-filter-header-actions{align-items:center;gap:4px;display:flex}.vocab-link-btn{color:var(--blue);cursor:pointer;-webkit-tap-highlight-color:transparent;background:0 0;border:none;border-radius:4px;padding:2px 6px;font-size:13px;font-weight:600}.vocab-link-btn:hover{background:var(--blue-light)}.vocab-link-sep{color:var(--text-secondary);font-size:13px}.vocab-filter-groups{flex-direction:column;gap:12px;display:flex}.vocab-filter-group{border-top:1px solid var(--border);padding-top:10px}.vocab-filter-group:first-child{border-top:none;padding-top:0}.vocab-filter-group-header{align-items:center;gap:8px;margin-bottom:6px;display:flex}.vocab-filter-group-name{color:var(--text);font-size:14px;font-weight:700}.vocab-filter-group-count{color:var(--text-secondary);background:var(--bg);border-radius:99px;padding:2px 8px;font-size:11px;font-weight:600}.vocab-filter-group-cats{flex-wrap:wrap;gap:6px 10px;display:flex}.vocab-cat-check{background:var(--bg);border:1px solid var(--border);color:var(--text);cursor:pointer;-webkit-tap-highlight-color:transparent;-webkit-user-select:none;user-select:none;border-radius:99px;align-items:center;gap:6px;padding:4px 10px;font-size:13px;font-weight:500;display:inline-flex}.vocab-cat-check:hover:not(.vocab-cat-disabled){border-color:var(--blue)}.vocab-cat-check input[type=checkbox]{cursor:pointer;accent-color:var(--blue);margin:0}.vocab-cat-check:has(input:checked){background:var(--blue-light);border-color:var(--blue);color:var(--blue)}.vocab-cat-disabled{opacity:.5;cursor:not-allowed}.vocab-cat-disabled input{cursor:not-allowed}.vocab-cat-count{color:var(--text-secondary);font-size:12px;font-weight:500}.vocab-cat-check:has(input:checked) .vocab-cat-count{color:var(--blue)}.vocab-btn-primary,.vocab-btn-secondary,.vocab-btn-danger{border-radius:var(--radius);cursor:pointer;-webkit-tap-highlight-color:transparent;border:1px solid #0000;padding:9px 16px;font-size:14px;font-weight:600;transition:opacity .15s,transform .1s}.vocab-btn-primary{background:var(--blue);color:#fff}.vocab-btn-primary:hover:not(:disabled){opacity:.9}.vocab-btn-primary:active:not(:disabled){transform:scale(.98)}.vocab-btn-primary:disabled{opacity:.5;cursor:not-allowed}.vocab-btn-secondary{background:var(--surface);color:var(--text);border-color:var(--border)}.vocab-btn-secondary:hover{border-color:var(--blue);color:var(--blue)}.vocab-btn-danger{color:var(--red);border-color:var(--red);background:0 0}.vocab-btn-danger:hover{background:var(--red-light)}.vocab-start-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);text-align:center;box-shadow:var(--shadow-sm);padding:32px 20px}.vocab-start-card h2{margin-bottom:10px;font-size:20px;font-weight:700}.vocab-start-card p{color:var(--text-secondary);margin-bottom:20px;font-size:14px}.vocab-start-btn{padding:12px 28px;font-size:16px}.vocab-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);padding:20px}.vocab-card-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:8px;margin-bottom:16px;display:flex}.vocab-mode-badge{text-transform:uppercase;letter-spacing:.5px;color:var(--blue);background:var(--blue-light);border-radius:99px;padding:4px 10px;font-size:11px;font-weight:700}.vocab-category-badge{color:var(--text-secondary);background:var(--bg);border-radius:99px;padding:4px 10px;font-size:11px;font-weight:600}.vocab-prompt-label{text-transform:uppercase;letter-spacing:.5px;color:var(--text-secondary);margin-bottom:6px;font-size:12px;font-weight:600}.vocab-prompt-body{color:var(--text);margin-bottom:16px;font-size:22px;font-weight:700}.vocab-prompt-code{background:var(--bg);color:var(--text);border:1px solid var(--border);white-space:pre-wrap;border-radius:8px;margin-bottom:16px;padding:14px;font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;font-size:14px;overflow-x:auto}.vocab-code-prompt{color:var(--text);margin-bottom:10px;font-size:16px;font-weight:600;line-height:1.4}.vocab-hint-box{background:var(--orange-light);border-left:3px solid var(--orange);border-radius:6px;margin-bottom:14px;padding:10px 14px;font-size:13px}.vocab-hint-box strong{color:var(--orange);margin-bottom:6px;display:block}.vocab-hint-box ul{margin:0;padding-left:18px}.vocab-hint-box li{margin:2px 0}.vocab-hint-panel{background:var(--blue-light);border-left:3px solid var(--blue);border-radius:6px;margin-bottom:14px;padding:10px 14px;font-size:13px}.vocab-hint-panel-header{color:var(--blue);margin-bottom:6px;font-weight:600}.vocab-hint-list{margin:0;padding-left:22px}.vocab-hint-list li{white-space:pre-wrap;margin:4px 0;line-height:1.4}.vocab-hint-btn,.vocab-skip-btn{border-radius:var(--radius);cursor:pointer;border:1px solid var(--border);background:var(--surface);color:var(--text);-webkit-tap-highlight-color:transparent;padding:9px 16px;font-size:14px;font-weight:600}.vocab-hint-btn:hover:not(:disabled){border-color:var(--blue);color:var(--blue)}.vocab-skip-btn:hover:not(:disabled){border-color:var(--text-secondary);color:var(--text-secondary)}.vocab-hint-btn:disabled,.vocab-skip-btn:disabled{opacity:.5;cursor:not-allowed}.vocab-input-section{margin-bottom:12px}.vocab-answer-input{border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);width:100%;color:var(--text);resize:vertical;min-height:80px;padding:12px;font-family:inherit;font-size:15px;line-height:1.5}.vocab-answer-input:focus{border-color:var(--blue);box-shadow:0 0 0 2px var(--blue-light);outline:none}.vocab-interim{color:var(--text-secondary);margin-top:6px;font-size:13px;font-style:italic}.vocab-actions{flex-wrap:wrap;align-items:center;gap:10px;display:flex}.vocab-mic-btn{border-radius:var(--radius);cursor:pointer;border:1px solid var(--border);background:var(--surface);color:var(--text);-webkit-tap-highlight-color:transparent;padding:9px 16px;font-size:14px;font-weight:600}.vocab-mic-btn:hover{border-color:var(--blue);color:var(--blue)}.vocab-mic-btn.vocab-mic-listening{background:var(--red);color:#fff;border-color:var(--red);animation:1.2s infinite vocab-pulse}@keyframes vocab-pulse{0%,to{box-shadow:0 0 #ef444480}50%{box-shadow:0 0 0 6px #ef444400}}.vocab-error{color:var(--red);background:var(--red-light);border-radius:6px;margin-top:8px;padding:8px 12px;font-size:13px}.vocab-result{border-top:2px solid var(--border);margin-top:16px;padding-top:16px}.vocab-verdict-correct{border-top-color:var(--green)}.vocab-verdict-partial{border-top-color:var(--orange)}.vocab-verdict-wrong{border-top-color:var(--red)}.vocab-result-header{justify-content:space-between;align-items:center;margin-bottom:14px;display:flex}.vocab-verdict-label{letter-spacing:1px;font-size:18px;font-weight:800}.vocab-verdict-correct .vocab-verdict-label{color:var(--green)}.vocab-verdict-partial .vocab-verdict-label{color:var(--orange)}.vocab-verdict-wrong .vocab-verdict-label{color:var(--red)}.vocab-score{color:var(--text);font-size:24px;font-weight:800}.vocab-result-body{flex-direction:column;gap:12px;font-size:14px;display:flex}.vocab-answer-echo{background:var(--bg);border-radius:8px;padding:10px 14px}.vocab-answer-echo strong{text-transform:uppercase;letter-spacing:.5px;color:var(--text-secondary);margin-bottom:4px;font-size:12px;display:block}.vocab-answer-echo p{margin:0;line-height:1.5}.vocab-points-hit,.vocab-points-missed{border-radius:8px;padding:10px 14px}.vocab-points-hit{background:var(--green-light);border-left:3px solid var(--green)}.vocab-points-hit strong{color:var(--green)}.vocab-points-missed{background:var(--red-light);border-left:3px solid var(--red)}.vocab-points-missed strong{color:var(--red)}.vocab-points-hit strong,.vocab-points-missed strong{margin-bottom:6px;display:block}.vocab-points-hit ul,.vocab-points-missed ul{margin:0;padding-left:18px}.vocab-points-hit li,.vocab-points-missed li{margin:3px 0}.vocab-followup{background:var(--blue-light);border-left:3px solid var(--blue);border-radius:8px;padding:10px 14px;line-height:1.5}.vocab-followup strong{color:var(--blue)}.vocab-full-answer{background:var(--bg);border-radius:8px;padding:10px 14px;font-size:13px}.vocab-full-answer summary{cursor:pointer;color:var(--text-secondary);font-weight:600}.vocab-full-answer summary:hover{color:var(--blue)}.vocab-full-answer p{margin:8px 0 6px}.vocab-full-answer ul{margin:4px 0;padding-left:20px}.vocab-full-answer li{margin:2px 0}.vocab-interview-phrase{color:var(--text-secondary);border-left:2px solid var(--border);padding-left:10px;font-style:italic;margin-top:10px!important}.vocab-next-btn{width:100%;margin-top:14px;padding:12px;font-size:15px}.vocab-term-list{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);padding:16px}.vocab-term-category{margin-bottom:16px}.vocab-term-category:last-child{margin-bottom:0}.vocab-term-category h3{color:var(--blue);text-transform:uppercase;letter-spacing:.5px;margin-bottom:8px;font-size:14px;font-weight:700}.vocab-term-category ul{flex-direction:column;gap:4px;margin:0;padding:0;list-style:none;display:flex}.vocab-term-row{background:var(--bg);border-radius:6px;justify-content:space-between;align-items:center;gap:10px;padding:6px 10px;font-size:13px;display:flex}.vocab-term-row.vocab-term-graduated{background:var(--green-light)}.vocab-term-name{color:var(--text);font-weight:600}.vocab-term-passes{color:var(--text-secondary);white-space:nowrap;font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;font-size:11px}
