:root{color:#17211b;font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;background:#f6f7f1;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}*{box-sizing:border-box}body{background:linear-gradient(#ffffffb3,#fff0 240px),#f6f7f1;min-width:320px;min-height:100vh;margin:0}button,input,textarea{font:inherit}button{cursor:pointer;border:0}button:disabled{cursor:not-allowed;opacity:.48}.app-shell{background:#fbfcf7;width:min(100%,760px);min-height:100vh;margin:0 auto;box-shadow:0 0 0 1px #17211b14}.screen{min-height:100vh;padding:18px}.topbar,.practice-header{justify-content:space-between;align-items:center;gap:12px;margin-bottom:18px;display:flex}.topbar h1,.practice-header strong{color:#17211b;margin:0}.topbar h1{font-size:1.65rem;line-height:1.05}.eyebrow,.muted,.practice-header span{color:#617068}.eyebrow{text-transform:uppercase;margin:0 0 5px;font-size:.78rem;font-weight:750}.icon-button{color:#24342b;background:#e8ece2;border-radius:8px;flex:none;place-items:center;width:44px;height:44px;display:inline-grid}.icon-button.primary{color:#fff;background:#226f54}.icon-button.danger{color:#8c2f39;background:#f4dddd}.wide-action,.nav-grid button,.control-row button{color:#fff;background:#226f54;border-radius:8px;justify-content:center;align-items:center;gap:8px;min-height:48px;font-weight:800;display:inline-flex}.wide-action{width:100%;margin:4px 0 20px}.wide-action.warning{color:#382a00;background:#f3c84b}.wide-action.warning.active{color:#fff;background:#a55233}.practice-list h2{margin:20px 0 10px;font-size:1rem}.empty-state{color:#617068;text-align:center;border:1px dashed #b9c2b9;border-radius:8px;place-items:center;min-height:180px;display:grid}.practice-card{background:#fff;border:1px solid #dce2d8;border-radius:8px;grid-template-columns:1fr auto;align-items:stretch;gap:10px;margin-bottom:10px;padding:12px;display:grid}.practice-main{min-width:0;color:inherit;text-align:left;background:0 0;padding:0}.practice-main strong,.practice-main span{overflow-wrap:anywhere;display:block}.practice-main>span{color:#617068;margin-top:4px}.meta-row,.progress-summary{color:#617068;flex-wrap:wrap;gap:8px;margin:10px 0 8px;font-size:.84rem;display:flex}.progress-track{background:#e4e9df;border-radius:999px;width:100%;height:8px;overflow:hidden}.progress-track div{background:#36a979;height:100%}.home-footer{color:#617068;text-align:center;margin-top:28px;padding:18px 0 4px;font-size:.9rem;font-weight:700}.home-footer a{color:#226f54;font-weight:800;text-decoration:none}.home-footer a:hover{text-decoration:underline}.form-stack{gap:16px;display:grid}label span{color:#35443b;margin-bottom:8px;font-weight:800;display:block}input,textarea{color:#17211b;background:#fff;border:1px solid #ccd6cc;border-radius:8px;outline:none;width:100%}input:focus,textarea:focus{border-color:#226f54;box-shadow:0 0 0 3px #226f5429}input{min-height:50px;padding:0 14px}.file-picker input{opacity:0;width:1px;height:1px;position:absolute}.file-picker div{overflow-wrap:anywhere;background:#fff;border:1px solid #ccd6cc;border-radius:8px;align-items:center;gap:10px;min-height:56px;padding:0 14px;display:flex}.file-picker small{color:#617068;margin-inline-start:6px;font-size:.76rem;font-weight:800}.error-message{color:#8c2f39;background:#f8e4e4;border-radius:8px;margin:0;padding:12px;font-weight:700}.practice-screen{padding-bottom:138px}.practice-header{z-index:4;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#fbfcf7f5;border-bottom:1px solid #17211b14;margin:-18px -18px 12px;padding:12px 18px;position:sticky;top:0}.practice-header div{text-align:center;min-width:0}.practice-header span{margin-top:3px;font-size:.82rem;display:block}.player-section{gap:12px;display:grid}.video-frame{aspect-ratio:16/9;background:#101513;border-radius:8px;width:100%;overflow:hidden}.video-frame iframe,.video-frame>div{width:100%;height:100%}.video-scrubber{color:#617068;grid-template-columns:46px 1fr 46px;align-items:center;gap:8px;font-size:.78rem;font-weight:800;display:grid}.video-scrubber span:last-child{text-align:right}.video-scrubber input{accent-color:#226f54;cursor:pointer;min-height:28px;padding:0}.video-scrubber input:disabled{cursor:not-allowed}.control-row{grid-template-columns:1fr 1.25fr 1fr;gap:8px;display:grid}.control-row.has-original{grid-template-columns:1fr 1.15fr 1fr 1fr}.control-row button{color:#23342b;background:#e5ebe2;min-width:0;padding:0 8px}.control-row .replay-button{color:#fff;background:#226f54}.control-row button.active-speed,.control-row button.active-original{color:#fff;background:#2f6fbd;box-shadow:inset 0 0 0 2px #ffffff6b}.subtitle-band{color:#15221a;background:#eef6eb;border-inline-start:4px solid #36a979;border-radius:8px;margin:14px 0;padding:16px;font-size:1.18rem;line-height:1.7}.original-subtitle-band{color:#17211b;background:#eef4ff;border-inline-start:4px solid #2f6fbd;border-radius:8px;margin:0 0 14px;padding:14px 16px;font-size:1rem;font-weight:750;line-height:1.55}.answer-box textarea{resize:vertical;min-height:190px;padding:14px;line-height:1.45;display:block}.practice-actions{z-index:5;padding:10px 18px calc(10px + env(safe-area-inset-bottom));-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#fbfcf7f5;border-top:1px solid #17211b1a;gap:8px;margin:14px -18px -18px;display:grid;position:sticky;bottom:0}.practice-actions .wide-action{margin:0}.nav-grid{grid-template-columns:1fr 1fr;gap:10px;margin:0;display:grid}.nav-grid button{background:#24342b}.drawer-backdrop{z-index:10;background:#0f16126b;justify-content:flex-end;display:flex;position:fixed;inset:0}.segment-drawer{background:#fbfcf7;width:min(92vw,430px);height:100%;padding:16px;box-shadow:-18px 0 44px #17211b3d}.segment-drawer header{justify-content:space-between;align-items:center;margin-bottom:12px;display:flex}.segment-drawer h2{margin:0}.segment-list{gap:8px;max-height:calc(100vh - 82px);padding-bottom:20px;display:grid;overflow:auto}.segment-row{color:#17211b;text-align:start;background:#fff;border:1px solid #dce2d8;border-radius:8px;grid-template-columns:34px 1fr 42px;align-items:center;gap:8px;min-height:58px;padding:8px;display:grid}.segment-row.active{background:#ecf6ef;border-color:#226f54}.segment-row.completed{background:#f0f8e8;border-color:#86b98f}.segment-row.completed span{color:#fff;background:#3f8f54}.segment-row.completed.active{background:#dff2d6;border-color:#226f54;box-shadow:inset 0 0 0 1px #226f54}.segment-row span{background:#e8ece2;border-radius:999px;place-items:center;width:30px;height:30px;font-size:.83rem;font-weight:800;display:grid}.segment-row div{min-width:0}.segment-row small{color:#617068;margin-bottom:3px;font-size:.76rem;font-weight:800;display:block}.segment-row b{-webkit-line-clamp:2;-webkit-box-orient:vertical;line-height:1.45;display:-webkit-box;overflow:hidden}.segment-row em{color:#226f54;justify-content:flex-end;gap:4px;font-style:normal;display:flex}@media (width>=680px){.screen{padding:24px}.practice-screen{padding-bottom:154px}.practice-header{margin:-24px -24px 16px;padding:14px 24px}.practice-actions{margin-bottom:-24px;margin-left:-24px;margin-right:-24px;padding-left:24px;padding-right:24px}.topbar h1{font-size:2rem}}
