:root{color:#172033;background:#edf1f7;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,PingFang SC,Microsoft YaHei,sans-serif;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{box-sizing:border-box}html,body,#root{width:100%;min-width:100%;height:100%;min-height:100%;margin:0}body{overflow:hidden}button,input{font:inherit}button{cursor:pointer}.device-page{min-height:100vh;display:grid;place-items:center;padding:40px 20px;background:linear-gradient(135deg,rgba(39,90,174,.12),transparent 32%),linear-gradient(315deg,rgba(16,146,122,.12),transparent 30%),#edf1f7}.device-shell{width:min(460px,100%);display:flex;flex-direction:column;align-items:center}.device-header{text-align:center;margin-bottom:28px}.brand-mark{width:58px;height:58px;display:grid;place-items:center;margin:0 auto 18px;border-radius:16px;background:#14213d;color:#fff;font-size:17px;font-weight:800;letter-spacing:0;box-shadow:0 14px 28px #14213d38}.device-header h1{margin:0;color:#162033;font-size:30px;line-height:1.2;font-weight:760;letter-spacing:0}.device-header p{margin:10px 0 0;color:#617089;font-size:15px}.text-button{margin-top:12px;border:0;background:transparent;color:#1f66d1;font-size:14px;padding:6px 8px}.text-button:hover{color:#174fa5}.qr-panel{width:min(360px,100%);aspect-ratio:1;display:grid;place-items:center;padding:28px;border:1px solid rgba(112,129,154,.22);border-radius:22px;background:#fff;box-shadow:0 24px 60px #23304829,0 2px 8px #2330480f}.qr-image{width:100%;height:100%;object-fit:contain;display:block}.qr-stage{width:100%;height:100%;min-height:250px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;text-align:center}.qr-stage .qr-image{width:min(240px,100%);height:min(240px,100%);flex:0 0 auto}.qr-stage strong{color:#172033;font-size:18px;font-weight:760}.qr-stage span{color:#66758e;font-size:13px;line-height:1.5}.qr-placeholder{width:100%;height:100%;min-height:250px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:18px;color:#66758e;text-align:center}.loader{width:48px;height:48px;border:4px solid #dde5f0;border-top-color:#246bdb;border-radius:50%;animation:spin .8s linear infinite}.success-mark{width:62px;height:62px;display:grid;place-items:center;border-radius:50%;background:#24a56d;color:#fff;font-size:32px;font-weight:800;box-shadow:0 12px 26px #24a56d38}@keyframes spin{to{transform:rotate(360deg)}}.error-text,.form-error{color:#cf2e2e}.error-text{max-width:220px;margin:0;font-size:14px;line-height:1.6}.primary-button,.secondary-button{min-height:42px;border-radius:10px;padding:0 18px;border:1px solid transparent;font-size:14px;font-weight:650}.primary-button{background:#1f66d1;color:#fff;box-shadow:0 10px 22px #1f66d133}.primary-button:hover{background:#1958b6}.secondary-button{background:#fff;color:#46546a;border-color:#d6dfeb}.secondary-button:hover{background:#f6f8fb}.device-footer{display:inline-flex;align-items:center;gap:10px;margin-top:26px;padding:11px 16px;border:1px solid rgba(112,129,154,.2);border-radius:999px;background:#ffffffa3;color:#4f5f78;font-size:14px;box-shadow:0 8px 22px #23304814}.status-dot{width:8px;height:8px;flex:0 0 auto;border-radius:50%;background:#24a56d;box-shadow:0 0 0 4px #24a56d24}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;display:grid;place-items:center;padding:20px;background:#141c2b8a;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.config-modal{width:min(430px,100%);padding:26px;border-radius:18px;background:#fff;box-shadow:0 28px 80px #0f172a4d}.modal-header{margin-bottom:22px}.modal-header h2{margin:0;color:#172033;font-size:22px;line-height:1.3}.modal-header p{margin:8px 0 0;color:#64748b;font-size:14px;line-height:1.6}.form-field{display:block;margin-bottom:16px}.form-field span{display:block;margin-bottom:7px;color:#344256;font-size:14px;font-weight:650}.form-field input{width:100%;height:44px;padding:0 12px;border:1px solid #ccd6e4;border-radius:10px;color:#172033;background:#fff;outline:none}.form-field input:focus{border-color:#1f66d1;box-shadow:0 0 0 3px #1f66d124}.form-error{margin:0 0 14px;font-size:14px}.modal-actions{display:flex;justify-content:flex-end;gap:12px;margin-top:22px}.home-page{width:100vw;height:100vh;padding:20px 24px;display:grid;grid-template-columns:minmax(360px,.9fr) minmax(520px,1.35fr);grid-template-rows:auto minmax(0,1fr);grid-template-areas:"header header" "left result";gap:16px;overflow:hidden;background:linear-gradient(135deg,rgba(39,90,174,.12),transparent 32%),linear-gradient(315deg,rgba(16,146,122,.12),transparent 30%),#edf1f7}.home-header{grid-area:header;display:flex;justify-content:space-between;align-items:center;gap:16px;min-height:66px;padding:10px 16px;border-radius:12px;background:#ffffffc7;border:1px solid rgba(112,129,154,.18);box-shadow:0 12px 28px #23304814}.home-brand{display:flex;align-items:center;gap:12px}.home-brand .brand-mark{width:44px;height:44px;margin:0;border-radius:12px;font-size:14px}.home-brand-text{display:flex;flex-direction:column;line-height:1.3}.home-brand-text strong{color:#162033;font-size:16px;font-weight:700}.home-brand-text span{color:#66758e;font-size:13px}.home-user{display:flex;align-items:center;gap:10px;color:#46546a;font-size:14px;min-width:0}.home-user span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.user-avatar{width:36px;height:36px;border-radius:50%;background:linear-gradient(135deg,#1f66d1,#24a56d);box-shadow:0 6px 14px #1f66d138}.home-hero{padding:28px 32px;border-radius:20px;background:#14213d;color:#fff;box-shadow:0 18px 40px #14213d38}.home-hero h1{margin:0;font-size:28px;font-weight:700;letter-spacing:0}.home-hero p{margin:8px 0 0;color:#ffffffc7;font-size:15px}.home-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:18px}.home-card{padding:22px;border-radius:16px;background:#fff;border:1px solid rgba(112,129,154,.18);box-shadow:0 12px 24px #23304814;display:flex;flex-direction:column;gap:10px;transition:transform .18s ease,box-shadow .18s ease}.home-card:hover{transform:translateY(-2px);box-shadow:0 18px 32px #2330481f}.home-card-icon{width:44px;height:44px;border-radius:12px;background:#1f66d11a;color:#1f66d1;display:grid;place-items:center;font-size:20px}.home-card h3{margin:4px 0 0;color:#172033;font-size:16px;font-weight:700}.home-card p{margin:0;color:#66758e;font-size:13px;line-height:1.6}.home-footer{display:inline-flex;align-self:flex-start;align-items:center;gap:10px;padding:10px 16px;border-radius:999px;background:#ffffffb8;border:1px solid rgba(112,129,154,.2);color:#4f5f78;font-size:13px}.workflow-panel,.video-panel,.result-panel{min-width:0;min-height:0;padding:16px;border-radius:12px;background:#fff;border:1px solid rgba(112,129,154,.18);box-shadow:0 14px 32px #23304817;overflow:hidden}.workflow-panel{grid-area:left;display:flex;flex-direction:column;gap:12px;align-self:start;max-height:35vh}.workflow-main{display:flex;align-items:flex-start;gap:12px}.workflow-indicator{width:46px;height:46px;flex:0 0 auto;display:grid;place-items:center;border-radius:50%;color:#fff;font-size:22px;font-weight:800}.workflow-indicator-waiting,.workflow-indicator-analyzing{background:#1f66d1}.workflow-indicator-done{background:#24a56d}.workflow-indicator-error{background:#cf2e2e}.loader-small{width:24px;height:24px;border-width:3px;border-color:#ffffff59;border-top-color:#fff}.workflow-kicker{margin:0 0 4px;color:#1f66d1;font-size:12px;font-weight:760}.workflow-main h1{margin:0;color:#162033;font-size:22px;line-height:1.2;letter-spacing:0}.workflow-main p:last-child{margin:6px 0 0;color:#66758e;font-size:13px;line-height:1.45;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.workflow-meta{display:grid;grid-template-columns:1fr;gap:8px}.workflow-meta div{min-height:0;padding:9px 11px;border-radius:10px;background:#f6f8fb;border:1px solid #e1e8f2}.workflow-meta span,.result-header span{display:block;color:#66758e;font-size:12px}.workflow-meta strong{display:block;margin-top:4px;color:#172033;font-size:13px;overflow-wrap:anywhere}.workflow-action{align-self:flex-start}.video-panel{grid-area:left;align-self:end;display:flex;flex-direction:column;gap:10px;max-height:calc(65vh - 86px)}.video-panel-header{display:flex;justify-content:space-between;align-items:flex-start;gap:10px;min-height:0}.video-panel-header h2{margin:0;color:#172033;font-size:16px}.video-panel-header span{display:block;margin-top:4px;color:#66758e;font-size:12px;line-height:1.35;display:-webkit-box;-webkit-line-clamp:1;-webkit-box-orient:vertical;overflow:hidden}.video-open-link{flex:0 0 auto;padding:7px 10px;border-radius:8px;background:#edf5ff;color:#1f66d1;font-size:12px;font-weight:760;text-decoration:none}.video-player-wrap{width:100%;aspect-ratio:16 / 9;max-height:100%;overflow:hidden;border-radius:10px;background:#101827;border:1px solid #dce5f1}.video-player{display:block;width:100%;height:100%;background:#101827;object-fit:contain}.video-empty{padding:14px;border-radius:10px;background:#f6f8fb;color:#66758e;font-size:14px}.result-panel{grid-area:result;display:flex;flex-direction:column;gap:10px;height:100%}.result-header{display:flex;align-items:center;justify-content:space-between;gap:16px}.result-header h2{margin:0;color:#172033;font-size:18px}.coach-result{flex:1;min-height:0;display:grid;grid-template-rows:auto auto minmax(0,1fr);gap:10px;overflow:hidden}.result-intro{padding:12px 14px;border-radius:10px;background:#14213d;color:#fff;font-size:17px;font-weight:720;line-height:1.35}.result-columns{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;min-height:0}.result-section{min-height:0;display:flex;flex-direction:column;gap:8px}.result-section h3{margin:0;color:#172033;font-size:14px}.point-list,.issue-list{display:flex;flex-direction:column;gap:8px;min-height:0;overflow:hidden}.point-card,.issue-card{border:1px solid #e1e8f2;border-radius:12px;background:#f8fafc}.point-card{padding:10px 12px}.point-card strong,.issue-card h4,.training-plan-title strong,.exercise-item strong{color:#172033}.point-card p{margin:5px 0 0;color:#5f6d82;font-size:12px;line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.point-card span{display:inline-flex;margin-top:6px;padding:4px 7px;border-radius:7px;background:#eaf3ff;color:#1f66d1;font-size:11px;max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.point-card-progress{background:#f3fbf7;border-color:#cfeede}.issue-card{padding:12px;display:flex;flex-direction:column;gap:8px}.issue-header{display:flex;justify-content:space-between;gap:12px}.issue-time{display:inline-flex;margin-bottom:5px;padding:3px 7px;border-radius:7px;background:#fff4e6;color:#a15c00;font-size:11px;font-weight:700}.issue-card h4{margin:0;font-size:15px}.issue-card p{margin:0;color:#4f5f78;font-size:12px;line-height:1.45;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.issue-detail-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px;margin:0}.issue-detail-grid div{padding:8px;border-radius:8px;background:#fff;border:1px solid #e5ebf3}.issue-detail-grid dt{margin-bottom:4px;color:#1f66d1;font-size:11px;font-weight:760}.issue-detail-grid dd{margin:0;color:#56657b;font-size:11px;line-height:1.35;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}.training-plan{padding:10px;border-radius:10px;background:#fff;border:1px solid #dfe7f1}.training-plan-title{display:flex;align-items:baseline;gap:8px;margin-bottom:8px}.training-plan-title span{color:#66758e;font-size:12px}.exercise-list{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px}.exercise-item{display:grid;grid-template-columns:22px 1fr;gap:7px;padding:8px;border-radius:8px;background:#f6f8fb;min-width:0}.exercise-item>span{width:22px;height:22px;display:grid;place-items:center;border-radius:50%;background:#1f66d1;color:#fff;font-size:11px;font-weight:760}.exercise-item p,.exercise-item small{display:block;margin:3px 0 0;color:#607089;font-size:11px;line-height:1.3;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.empty-result{margin:0;padding:12px;border-radius:10px;background:#f6f8fb;color:#66758e;font-size:12px}.result-json{flex:1;min-height:0;margin:0;padding:14px;overflow:hidden;border-radius:10px;background:#101827;color:#edf5ff;font-size:12px;line-height:1.45;white-space:pre-wrap;overflow-wrap:anywhere}@media (max-width: 1100px){.home-page{grid-template-columns:minmax(310px,.88fr) minmax(420px,1.12fr);padding:14px;gap:12px}.issue-detail-grid,.exercise-list{grid-template-columns:1fr}.issue-detail-grid dd{-webkit-line-clamp:2}}@media (max-width: 820px){.home-page{grid-template-columns:1fr;grid-template-rows:auto minmax(180px,.45fr) minmax(0,.55fr);grid-template-areas:"header" "left" "result";height:100dvh}.workflow-panel{max-height:none;align-self:start}.video-panel{align-self:end;max-height:42vh}.result-panel{min-height:0}.workflow-meta{grid-template-columns:repeat(3,minmax(0,1fr))}.result-columns,.issue-detail-grid{grid-template-columns:1fr}.exercise-list{grid-template-columns:repeat(3,minmax(0,1fr))}}@media (max-width: 520px){.device-page{padding:28px 16px}.device-header h1{font-size:26px}.qr-panel{padding:22px;border-radius:18px}.device-footer{width:100%;justify-content:center;border-radius:14px}.modal-actions{flex-direction:column-reverse}.primary-button,.secondary-button{width:100%}.home-page{padding:10px;gap:10px;grid-template-rows:auto minmax(150px,.4fr) minmax(0,.6fr)}.home-header{min-height:56px;padding:8px 10px;flex-wrap:nowrap}.home-hero{padding:22px 20px}.home-hero h1{font-size:24px}.workflow-panel,.video-panel,.result-panel{padding:10px;border-radius:10px}.workflow-main{align-items:flex-start;gap:8px}.workflow-indicator{width:38px;height:38px;font-size:18px}.workflow-main h1{font-size:18px}.workflow-meta{grid-template-columns:1fr}.result-header{align-items:flex-start;flex-direction:column}.video-panel-header{flex-direction:row}.video-open-link{width:auto;text-align:center}.result-columns,.issue-detail-grid{grid-template-columns:1fr}.result-intro{padding:9px 10px;font-size:14px}.exercise-list{grid-template-columns:1fr}.training-plan-title{flex-direction:column;gap:4px}}.miniprogram-page{width:100%;min-width:100%;height:100vh;height:100dvh;min-height:100vh;min-height:100dvh;display:grid;place-items:center;background:#fff}.miniprogram-content{display:flex;flex-direction:column;align-items:center;gap:24px}.miniprogram-content .qr-box{width:200px;height:200px;background:#e5e7eb}.miniprogram-content .qr-image{width:100%;height:100%;object-fit:cover}.miniprogram-text{display:flex;flex-direction:column;align-items:center;color:#2c3245;font-size:24px;font-weight:700;line-height:1.4}.landing-page{width:100%;min-width:100%;height:100vh;height:100dvh;min-height:100vh;min-height:100dvh;position:relative;background:#0b1120;overflow:hidden;color:#fff;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif}.landing-bg{position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(circle at 60% 30%,#1e3a8a66,#0b1120 70%);z-index:1}.landing-brand-logo{position:absolute;top:clamp(28px,3.2vw,56px);right:clamp(28px,3.2vw,56px);z-index:3;height:clamp(64px,7.5vw,120px);width:auto;object-fit:contain;pointer-events:none;-webkit-user-select:none;user-select:none}.landing-content{position:relative;z-index:2;width:100%;height:100%;max-width:100%;margin:0 auto;padding:clamp(38px,4vw,80px);display:flex;flex-direction:column;overflow:hidden}.landing-top-area{flex:none;margin-bottom:clamp(12px,1.2vw,20px)}.landing-title{margin:0;font-size:clamp(58px,6.2vw,110px);font-style:italic;font-weight:900;letter-spacing:clamp(0px,.12vw,2px);line-height:1;text-transform:uppercase}.landing-title .text-white{color:#f8fafc}.landing-title .text-outline-glow{color:transparent;-webkit-text-stroke:clamp(1px,.12vw,2px) #d0f0ff;text-shadow:0 0 20px rgba(100,200,255,.6),0 0 40px rgba(100,200,255,.4)}.landing-cards-area{display:flex;gap:clamp(16px,1.5vw,24px);margin-top:clamp(44px,5.2vw,100px);margin-bottom:auto;min-height:0}.l-card{flex:1;max-width:clamp(260px,21vw,340px);background:#0f172a66;border:1px solid rgba(255,255,255,.08);border-radius:clamp(10px,.8vw,12px);padding:clamp(20px,1.7vw,30px);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px)}.l-card-header{display:flex;align-items:center;gap:clamp(9px,.8vw,12px);margin-bottom:clamp(10px,.9vw,16px)}.l-icon{width:clamp(20px,1.4vw,24px);height:clamp(20px,1.4vw,24px);display:flex;align-items:center;justify-content:center}.blue-icon{color:#60a5fa}.light-blue-icon{color:#38bdf8}.l-card h3{margin:0;font-size:clamp(16px,1.2vw,20px);font-weight:700;color:#f8fafc}.l-card p{margin:0;font-size:clamp(12px,.86vw,14px);line-height:1.65;color:#94a3b8}.l-card p .highlight-text{color:#60a5fa}.landing-bottom-area{display:flex;justify-content:space-between;align-items:flex-end;gap:clamp(24px,3vw,56px);width:100%;flex:none}.landing-slogan{font-size:clamp(26px,2.5vw,44px);font-style:italic;font-weight:900;margin-bottom:clamp(10px,1.2vw,20px);line-height:1.15}.landing-slogan .text-white{color:#f8fafc}.landing-slogan .highlight-glow-text{color:#60a5fa;text-shadow:0 0 20px rgba(96,165,250,.5)}.landing-qr-card{background:#1e293bb3;border:1px solid rgba(255,255,255,.1);border-radius:clamp(12px,1vw,16px);padding:clamp(22px,1.9vw,32px);display:flex;align-items:center;gap:clamp(24px,2.4vw,40px);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);flex:none}.landing-qr-text{display:flex;flex-direction:column;gap:clamp(6px,.7vw,10px)}.landing-qr-brand-logo{height:clamp(28px,2.6vw,40px);width:auto;object-fit:contain;align-self:flex-start;margin-bottom:clamp(4px,.4vw,8px);pointer-events:none;-webkit-user-select:none;user-select:none}.landing-qr-text h3{margin:0;font-size:clamp(17px,1.35vw,22px);font-weight:700;color:#f8fafc;white-space:nowrap}.landing-qr-text p{margin:0;font-size:clamp(11px,.8vw,13px);color:#60a5fa;letter-spacing:1.5px}.landing-qr-box{width:clamp(112px,9vw,150px);height:clamp(112px,9vw,150px);background:#fff;padding:8px;border-radius:8px}.landing-qr-box img{width:100%;height:100%;object-fit:contain}@media (max-width: 1024px){.landing-content{padding:32px}.landing-title{font-size:54px}.landing-cards-area{flex-wrap:wrap;margin-top:32px}.landing-bottom-area{gap:24px}.landing-slogan{margin-bottom:0}}.home-page-new{width:100%;min-width:100%;height:100vh;height:100dvh;min-height:100vh;min-height:100dvh;background:#f8fafc;display:flex;flex-direction:column;overflow:hidden}.status-screen{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;color:#162033}.status-screen h2{font-size:28px;font-weight:700;margin:20px 0 10px}.status-screen p{font-size:16px;color:#66758e;margin:0}.status-icon{display:flex;align-items:center;justify-content:center}.waiting-icon{color:#3b82f6}.analyzing-icon{display:flex;gap:8px;height:48px;align-items:center}.analyzing-icon .dot{width:12px;height:12px;background-color:#3b82f6;border-radius:50%;animation:bounce 1.4s infinite ease-in-out both}.analyzing-icon .dot:nth-child(1){animation-delay:-.32s}.analyzing-icon .dot:nth-child(2){animation-delay:-.16s}@keyframes bounce{0%,80%,to{transform:scale(0)}40%{transform:scale(1)}}.error-icon{width:56px;height:56px;border-radius:50%;background:#cf2e2e;color:#fff;font-size:32px;font-weight:700}.done-screen{flex:1;display:flex;flex-direction:column;padding:clamp(10px,1.1vh,16px) clamp(20px,2.2vw,40px) clamp(12px,1.3vh,20px);height:100%;min-height:0;overflow:hidden}.done-header{display:flex;justify-content:space-between;align-items:center;gap:clamp(10px,1.2vw,20px);padding-bottom:clamp(6px,.7vh,10px);border-bottom:1px solid #edf2f7;margin-bottom:clamp(8px,.9vh,12px);flex:0 0 auto}.header-left{display:flex;align-items:baseline;gap:16px}.header-left h2{margin:0;font-size:clamp(20px,1.5vw,26px);font-weight:800;color:#1e293b}.exercise-name{font-size:clamp(15px,1.1vw,20px);font-weight:600;color:#2b7fff}.header-right{display:flex;align-items:center}.header-right.compact{gap:12px}.header-tip{max-width:min(420px,36vw);font-size:clamp(12px,.85vw,14px);color:#2b7fff;background:#eff6ff;padding:6px 14px;border-radius:999px;line-height:1.3;border:1px solid #dbeafe}.exit-countdown-card{min-width:clamp(168px,12vw,210px);padding:10px 16px;border-radius:14px;background:linear-gradient(135deg,#0f172a,#1d4ed8);color:#fff;box-shadow:0 14px 34px #1d4ed847;display:flex;align-items:center;justify-content:space-between;gap:16px}.exit-countdown-card span{font-size:13px;color:#ffffffc7}.exit-countdown-card strong{font-size:clamp(22px,1.8vw,28px);line-height:1;font-variant-numeric:tabular-nums;letter-spacing:0}.done-content{flex:1;display:grid;grid-template-columns:minmax(300px,min(40%,500px)) minmax(0,1fr);gap:clamp(16px,1.5vw,26px);min-height:0;overflow:hidden}.done-left-column{display:grid;grid-template-rows:minmax(0,1.25fr) minmax(0,1fr) minmax(0,.82fr);gap:clamp(10px,1vw,16px);min-height:0;min-width:0;height:100%;overflow:hidden}.done-left-column--no-vbt{grid-template-rows:minmax(0,1.2fr) minmax(0,1fr)}.done-right-column{display:flex;flex-direction:column;min-height:0;min-width:0;height:100%;overflow:hidden}.done-video-wrapper{min-height:0;height:100%;background:#0f172a;border-radius:clamp(12px,1vw,16px);display:flex;align-items:center;justify-content:center;overflow:hidden;position:relative;box-shadow:0 8px 24px #0f172a1f}.done-video-player{width:100%;height:100%;object-fit:contain}.done-video-placeholder{color:#94a3b8;font-size:clamp(16px,1.4vw,22px);font-weight:600}.video-controls-overlay{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;display:flex;align-items:flex-end;justify-content:space-between;padding:14px 16px}.video-control-btn{display:inline-flex;align-items:center;justify-content:center;width:34px;height:34px;border-radius:8px;color:#e2e8f0;background:#0f172a8c;border:1px solid rgba(255,255,255,.12)}.vbt-speed-card{min-height:0;height:100%;background:#fff;border:1px solid #e2e8f0;border-radius:clamp(12px,1vw,16px);padding:clamp(10px,.9vh,14px) clamp(12px,1vw,16px);display:grid;grid-template-rows:auto minmax(0,1fr);gap:8px;box-shadow:0 4px 16px #0f172a0a;overflow:hidden}.vbt-speed-header{display:flex;align-items:center;gap:8px;font-size:clamp(14px,1vw,17px);font-weight:700;color:#1e293b;flex:0 0 auto}.vbt-speed-icon{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:8px;background:#eff6ff;color:#2b7fff}.vbt-speed-body{min-height:0;height:100%;display:flex;gap:8px;align-items:stretch;overflow:hidden}.vbt-chart{flex:1;min-width:0;min-height:0;height:100%;display:flex;gap:4px;overflow:hidden}.vbt-chart-y-axis{flex:0 0 auto;display:flex;flex-direction:column;justify-content:space-between;align-items:flex-end;padding-bottom:20px;color:#94a3b8;font-size:11px;line-height:1}.vbt-axis-unit{margin-top:4px;font-size:10px}.vbt-chart-bars{flex:1;min-height:0;display:flex;align-items:flex-end;justify-content:space-between;gap:clamp(1px,.25vw,3px);padding:0 clamp(6px,.8vw,10px) 20px;border-bottom:1px solid #e2e8f0;position:relative}.vbt-bar-col{flex:1 1 0;min-width:0;display:flex;flex-direction:column;align-items:center;justify-content:flex-end;height:100%;gap:4px}.vbt-bar-stack{flex:1;min-height:0;width:clamp(10px,1.1vw,14px);display:flex;flex-direction:column;justify-content:flex-end;align-items:center}.vbt-bar-group{width:100%;min-height:18px;display:flex;flex-direction:column;justify-content:flex-end;align-items:center}.vbt-bar-value{flex:0 0 auto;margin-bottom:2px;font-size:clamp(8px,.65vw,10px);font-weight:700;color:#2b7fff;line-height:1;white-space:nowrap;text-align:center}.vbt-bar-fill{flex:1 1 auto;width:100%;min-height:4px;border-radius:4px 4px 2px 2px;background:linear-gradient(180deg,#60a5fa,#2b7fff)}.vbt-bar-label{font-size:clamp(8px,.65vw,10px);color:#64748b;white-space:nowrap;line-height:1;transform:scale(.95);transform-origin:center top}.vbt-chart-bars--dense{gap:0;padding-inline:clamp(4px,.6vw,8px)}.vbt-chart-bars--dense .vbt-bar-stack{width:clamp(8px,.9vw,12px)}.vbt-chart-bars--dense .vbt-bar-value{font-size:clamp(7px,.58vw,9px)}.vbt-chart-bars--dense .vbt-bar-label{font-size:clamp(7px,.52vw,8px);transform:scale(.92);letter-spacing:-.02em}.vbt-stats-panel{flex:0 0 clamp(62px,5.5vw,76px);display:flex;flex-direction:column;gap:6px;min-height:0;height:100%}.vbt-stat-item{flex:1 1 0;min-height:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;padding:5px 6px;border-radius:8px;background:#f8fafc;border:1px solid #e2e8f0;text-align:center}.vbt-stat-item span{font-size:clamp(11px,.95vw,13px);font-weight:700;color:#475569;line-height:1.2}.vbt-stat-item strong{font-size:clamp(12px,1vw,15px);color:#2b7fff;font-weight:800;line-height:1.15}.vbt-stat-item:first-child strong{font-size:clamp(10px,.85vw,12px);line-height:1.2}.render-pending-badge{position:absolute;top:18px;left:18px;z-index:3;display:inline-flex;align-items:center;gap:9px;max-width:calc(100% - 36px);padding:10px 14px;border-radius:999px;color:#fff;background:#0f172ac2;border:1px solid rgba(255,255,255,.16);box-shadow:0 10px 24px #0f172a47;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);font-size:14px;font-weight:800}.render-pending-spinner{width:16px;height:16px;flex:0 0 auto;border-radius:50%;border:2px solid rgba(255,255,255,.34);border-top-color:#fff;animation:render-pending-spin .82s linear infinite}@keyframes render-pending-spin{to{transform:rotate(360deg)}}.vbt-effort-panel{position:absolute;right:18px;bottom:18px;z-index:2;width:min(320px,calc(100% - 240px));padding:12px 14px;border-radius:14px;color:#fff;background:#0f172ad1;border:1px solid rgba(255,255,255,.16);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);box-shadow:0 12px 28px #0f172a3d}.vbt-effort-title{font-size:13px;font-weight:800;color:#ffffffc7;margin-bottom:8px}.vbt-effort-metrics{display:flex;flex-wrap:wrap;gap:8px}.vbt-effort-metrics span{display:inline-flex;align-items:center;gap:5px;min-height:28px;padding:5px 9px;border-radius:999px;background:#ffffff21;font-size:13px;font-weight:800}.vbt-effort-metrics strong{font-size:15px}.vbt-effort-panel p{margin:9px 0 0;font-size:12px;line-height:1.45;color:#ffffffc2;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.render-ready-toast{position:fixed;top:24px;left:50%;transform:translate(-50%);z-index:50;display:flex;align-items:center;gap:14px;min-width:360px;max-width:min(520px,calc(100vw - 32px));padding:16px 20px;border-radius:18px;color:#fff;background:linear-gradient(135deg,#16a34a,#0f766e);box-shadow:0 18px 44px #0f766e57;animation:toast-slide-in .28s ease-out}.render-ready-icon{width:42px;height:42px;flex:0 0 auto;border-radius:50%;display:grid;place-items:center;background:#fff3;font-size:24px;font-weight:900}.render-ready-toast strong,.render-ready-toast span{display:block}.render-ready-toast strong{font-size:18px}.render-ready-toast span{margin-top:4px;color:#ffffffd1;font-size:13px}@keyframes toast-slide-in{0%{opacity:0;transform:translate(-50%,-18px)}to{opacity:1;transform:translate(-50%)}}.done-eval-banner{display:flex;align-items:stretch;gap:clamp(12px,1.2vw,20px);padding:clamp(14px,1.1vw,20px) clamp(16px,1.3vw,22px);border-radius:clamp(12px,1vw,16px);background:linear-gradient(135deg,#2b7fff,#1d4ed8);color:#fff;flex:0 0 auto}.eval-banner-left{flex:1;min-width:0}.eval-banner-left .done-card-title{margin-bottom:8px;color:#fff}.eval-banner-left .eval-content{margin:0}.eval-banner-stats{flex:0 0 auto;display:flex;gap:10px}.eval-stat-box{min-width:clamp(88px,8vw,110px);padding:10px 14px;border-radius:12px;background:#fff;display:flex;flex-direction:column;gap:6px}.eval-stat-box span{font-size:12px;color:#64748b}.eval-stat-box strong{font-size:clamp(16px,1.2vw,20px);color:#2b7fff;font-weight:800}.eval-stat-box strong.stat-good{color:#16a34a}.done-card-title{display:flex;align-items:center;gap:10px;font-size:clamp(17px,1.2vw,22px);font-weight:700;margin-bottom:clamp(8px,.8vw,14px);flex:0 0 auto}.done-card-title .icon{font-size:clamp(20px,1.5vw,26px)}.done-card-title.dark{color:#1e293b;margin-bottom:0}.eval-content{font-size:clamp(14px,1vw,18px);line-height:1.42}.done-highlights-card{background:#fff;border:1px solid #e2e8f0;border-radius:clamp(12px,1vw,16px);padding:clamp(10px,.9vh,12px) clamp(14px,1.1vw,18px);min-height:0;height:100%;display:grid;grid-template-rows:auto minmax(0,1fr);overflow:hidden;box-shadow:0 4px 16px #0f172a0a;align-content:start}.done-highlights-card .done-card-title{color:#3b82f6;margin-bottom:8px}.highlights-content{display:flex;flex-direction:column;gap:6px;min-height:0;overflow:hidden;justify-content:flex-start}.hl-section{flex:0 0 auto;display:flex;flex-direction:column;gap:6px;overflow:hidden}.hl-section strong{display:block;font-size:clamp(15px,1vw,20px);color:#1e293b;margin-bottom:2px}.point-list{display:flex;flex-direction:column;gap:7px;min-height:0;overflow:hidden}.highlight-item{flex:0 0 auto;display:flex;align-items:flex-start;justify-content:space-between;gap:10px;padding:clamp(6px,.6vh,8px) clamp(10px,.85vw,12px);border-radius:8px;background:#f8fafc;border:1px solid #e2e8f0}.highlight-item-text{flex:1;min-width:0}.highlight-item-text strong{display:block;margin-bottom:2px;font-size:clamp(13px,.95vw,16px);color:#1e293b;line-height:1.25}.highlight-item-text p{margin:0;font-size:clamp(12px,.85vw,14px);color:#475569;line-height:1.35}.highlight-thumb{flex:0 0 auto;font-size:18px;opacity:.85}.point-item{padding:clamp(9px,.8vw,12px) clamp(11px,.9vw,16px);border-radius:10px;background:#fff;border:1px solid #e2e8f0}.point-title{display:block;margin-bottom:4px;font-size:clamp(14px,1vw,18px);font-weight:700;color:#1e293b}.point-item p{margin:0;font-size:clamp(13px,.9vw,16px);color:#475569;line-height:1.42}.point-reference{margin-top:6px!important;color:#64748b!important;font-size:clamp(13px,.9vw,16px)!important}.done-issues-wrapper{flex:1;display:grid;grid-template-rows:auto auto minmax(0,1fr) auto;gap:clamp(12px,1vw,20px);min-height:0;height:100%;overflow:hidden}.issues-grid{display:grid;gap:clamp(12px,1.2vw,18px);min-height:0;overflow:hidden;flex:1}.issues-grid--1{grid-template-columns:minmax(0,1fr);grid-template-rows:minmax(0,1fr)}.issues-grid--2{grid-template-columns:repeat(2,minmax(0,1fr));grid-template-rows:minmax(0,1fr)}.issues-grid--3{grid-template-columns:repeat(3,minmax(0,1fr));grid-template-rows:minmax(0,1fr)}.issues-grid--4{grid-template-columns:repeat(2,minmax(0,1fr));grid-template-rows:repeat(2,minmax(0,1fr))}.done-issue-card{border:1px solid #e2e8f0;border-radius:clamp(12px,1vw,16px);padding:clamp(14px,1.2vw,20px);background:#fff;display:flex;flex-direction:column;gap:clamp(8px,.8vw,12px);border-top-width:5px;min-height:0;overflow:hidden}.issue-content-scroll{flex:1;display:flex;flex-direction:column;gap:clamp(8px,.8vw,12px);min-height:0;overflow-x:hidden;overflow-y:auto;scrollbar-width:thin;scrollbar-color:#cbd5e1 transparent;padding-right:2px}.issue-content-scroll::-webkit-scrollbar{width:4px}.issue-content-scroll::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:4px}.issues-grid--4 .done-issue-card{padding:clamp(10px,1vh,14px) clamp(10px,1vw,14px);gap:6px}.issues-grid--4 .issue-title{font-size:clamp(14px,1.05vw,17px);line-height:1.25}.issues-grid--4 .issue-content-scroll{gap:5px}.issues-grid--4 .issue-desc{font-size:clamp(10px,.78vw,12px);line-height:1.35}.issues-grid--4 .issue-desc strong{font-size:clamp(11px,.82vw,13px);margin-bottom:2px}.issue-header{display:flex;align-items:center;justify-content:space-between;gap:16px;flex:none}.issue-title{font-size:clamp(18px,1.35vw,26px);font-weight:700;color:#1e293b;line-height:1.3}.issue-time{flex:none;padding:5px 10px;border-radius:999px;background:#ffedd5;color:#c2410c;font-size:clamp(13px,.95vw,18px);font-weight:700}.issue-desc{font-size:clamp(12px,.9vw,15px);color:#475569;line-height:1.45}.issue-desc strong{display:block;margin-bottom:4px;color:#1e293b;font-size:clamp(13px,.95vw,16px)}.issue-desc p{margin:0}.done-cta-card{flex:0 0 auto;display:flex;align-items:center;gap:14px;padding:clamp(14px,1.1vw,18px) clamp(16px,1.3vw,22px);border-radius:clamp(12px,1vw,16px);background:#f1f5f9;border:1px solid #e2e8f0}.cta-icon{flex:0 0 auto;width:40px;height:40px;display:grid;place-items:center;border-radius:50%;background:#2b7fff;color:#fff}.cta-text{display:flex;flex-direction:column;gap:4px}.cta-text strong{font-size:clamp(14px,1vw,17px);color:#1e293b}.cta-text span{font-size:clamp(12px,.85vw,14px);color:#64748b}.done-empty-panel{flex:1;display:grid;place-items:center;border-radius:16px;background:#fff;border:1px solid #e2e8f0;color:#64748b;font-size:16px}.training-plan{margin-top:4px;padding:clamp(12px,1vw,18px);border-radius:10px;background:#eff6ff;border:1px solid #bfdbfe}.training-plan-title{display:flex;flex-wrap:wrap;align-items:center;gap:8px;margin-bottom:10px;color:#1e293b}.training-plan-title strong{font-size:clamp(16px,1.15vw,22px)}.training-plan-title span{color:#2563eb;font-size:clamp(13px,.95vw,18px)}.training-exercises{display:flex;flex-direction:column;gap:10px}.training-exercise{padding:clamp(10px,.85vw,14px);border-radius:10px;background:#fff;border:1px solid #dbeafe}.exercise-title{display:flex;align-items:center;gap:9px;margin-bottom:6px;color:#1e293b}.exercise-title span{display:inline-flex;align-items:center;justify-content:center;width:clamp(24px,1.7vw,32px);height:clamp(24px,1.7vw,32px);border-radius:50%;background:#3b82f6;color:#fff;font-size:clamp(13px,.95vw,18px);font-weight:700}.exercise-title strong{font-size:clamp(15px,1.05vw,20px)}.training-exercise p{margin:4px 0 0;color:#475569;font-size:clamp(13px,.95vw,17px);line-height:1.42}.training-exercise p strong{color:#1e293b}@media (max-width: 1280px){.issues-grid--3{grid-template-columns:repeat(2,minmax(0,1fr));grid-template-rows:repeat(2,minmax(0,1fr))}.issues-grid--3 .done-issue-card:last-child{grid-column:1 / -1}}@media (max-width: 1024px){.done-content{grid-template-columns:1fr;grid-template-rows:minmax(0,.42fr) minmax(0,.58fr);overflow:hidden}.done-left-column{grid-template-rows:minmax(0,1.2fr) minmax(0,.95fr) minmax(0,.8fr);height:100%}.issues-grid--1,.issues-grid--2,.issues-grid--3,.issues-grid--4{grid-template-columns:minmax(0,1fr);grid-template-rows:repeat(var(--issue-count, 3),minmax(0,1fr))}.issues-grid--3 .done-issue-card:last-child{grid-column:auto}.eval-banner-stats{flex-wrap:wrap}}@media (max-width: 720px){.done-header{flex-direction:column;align-items:flex-start}.header-right.compact{width:100%;flex-wrap:wrap}.header-tip{max-width:100%;white-space:normal}.done-eval-banner{flex-direction:column}.eval-banner-stats{width:100%}.eval-stat-box{flex:1}.vbt-speed-body{flex-direction:column}.vbt-stats-panel{flex-direction:row;flex:none}.vbt-stat-item{flex:1}}
