:root{--page-bg: #f4f8fd;--page-bg-strong: #eaf2fb;--card: #ffffff;--card-soft: #f8fbff;--line: #dce8f5;--line-strong: #b7cde5;--blue: #6f9dce;--blue-strong: #4f84bd;--text: #26394d;--muted: #6b7d90;--faint: #91a2b3;--shadow: 0 22px 55px rgba(77, 118, 164, .16);--foreign-subtitle-font: Inter, "Noto Sans JP", "Hiragino Sans", "Yu Gothic", Meiryo, "Segoe UI", Arial, "PingFang SC", "Microsoft YaHei", sans-serif;font-family:Inter,PingFang SC,Microsoft YaHei,system-ui,sans-serif;color:var(--text);background:var(--page-bg)}*{box-sizing:border-box}html,body,#app{width:100%;height:100%;overflow:hidden}body{margin:0;background:radial-gradient(circle at 14% 0%,rgba(111,157,206,.24),transparent 28%),linear-gradient(180deg,#f8fbff 0%,var(--page-bg) 50%,#ffffff 100%)}button,input,select,textarea{font:inherit}.app-shell{position:relative;height:var(--app-height, 100dvh);min-height:0;display:grid;grid-template-rows:52px minmax(0,1fr) 96px;align-content:start;overflow:hidden}.learning-top-nav{grid-row:1;min-width:0;min-height:0;padding:8px 16px;border-bottom:1px solid var(--line);background:#ffffffeb;display:flex;align-items:center;justify-content:center;gap:10px;box-shadow:0 10px 24px #4d76a414;z-index:12}.learning-top-nav button{min-width:78px;min-height:34px;padding:6px 18px;border:1px solid var(--line);border-radius:999px;background:var(--card-soft);color:var(--text);font-weight:900;cursor:pointer}.learning-top-nav button:hover,.learning-top-nav button:focus-visible{border-color:var(--blue);color:var(--blue-strong);background:#eef6ff}.workspace{grid-row:2;min-width:0;min-height:0;height:100%;position:relative;display:grid;grid-template-columns:minmax(500px,.98fr) minmax(460px,1.02fr);gap:14px;padding:10px 16px;overflow:hidden;align-items:stretch}.hero-area,.study-panel{min-width:0;min-height:0}.hero-area{display:flex;flex-direction:column;height:100%;gap:0}.title-row{min-height:40px;display:flex;align-items:center;gap:12px;font-size:12px}.title-row>div{min-width:0}.title-catalog-button{-webkit-appearance:none;-moz-appearance:none;appearance:none;border:0;outline:0;box-shadow:none;cursor:pointer}.title-catalog-button:hover{cursor:pointer}.title-catalog-button:focus-visible{box-shadow:0 0 0 3px #6f9dce47}.auth-page,.catalog-page{min-height:100dvh;background:var(--page-bg);color:var(--text)}.auth-page{display:grid;place-items:center;padding:24px}.auth-panel{width:min(960px,100%);min-height:480px;display:grid;grid-template-columns:1fr 420px;gap:32px;align-items:center;padding:42px;border:1px solid var(--line);border-radius:8px;background:#ffffffeb;box-shadow:var(--shadow)}.auth-copy{display:grid;gap:14px}.auth-copy h1{font-size:34px}.auth-copy p,.catalog-header p,.course-head p{color:var(--muted)}.auth-form{padding:24px;border:1px solid var(--line);border-radius:8px;background:var(--card-soft)}.wide-primary{width:100%}.catalog-page{height:100dvh;overflow:auto;padding:22px}.catalog-header{max-width:1180px;margin:0 auto 18px;display:flex;align-items:center;justify-content:space-between;gap:16px}.catalog-header h1{margin-top:10px;font-size:28px}.catalog-actions,.inline-actions{display:flex;align-items:center;gap:8px;flex-wrap:wrap;justify-content:flex-end}.catalog-content{max-width:1180px;margin:0 auto;display:grid;gap:14px}.course-section{display:grid;grid-template-columns:180px minmax(0,1fr);gap:18px;padding:16px;border:1px solid var(--line);border-radius:8px;background:#ffffffeb;box-shadow:0 14px 34px #4d76a41a}.course-cover{min-height:128px;border-radius:8px;background:linear-gradient(135deg,#dcecfb,#eef7e8);background-size:cover;background-position:center;display:grid;place-items:center;color:var(--blue-strong);font-size:42px;font-weight:900}.course-main{min-width:0;display:grid;gap:12px}.course-head{display:flex;justify-content:space-between;gap:14px}.course-head h2{font-size:20px}.video-list{display:grid;gap:8px}.video-row{width:100%;min-height:46px;padding:10px 12px;border:1px solid var(--line);border-radius:8px;background:var(--card-soft);display:grid;grid-template-columns:minmax(0,1fr) auto auto;align-items:center;gap:10px;color:var(--text);text-align:left}.video-open-button{min-width:0;border:0;padding:0;background:transparent;display:grid;grid-template-columns:20px minmax(0,1fr);align-items:center;gap:10px;color:inherit;cursor:pointer;text-align:left}.video-open-button span{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.video-row:hover{border-color:var(--blue);background:#fff}.video-actions{display:flex;align-items:center;gap:4px}.add-video-button{justify-self:start}.episode-pill{padding:6px 14px;border-radius:999px;background:#dcecfb;color:var(--blue-strong);font-weight:800;font-size:18px;line-height:1}h1,h2,p{margin:0}h1{font-size:18px;line-height:1.2}.title-row p{color:var(--muted);margin-top:4px;font-size:13px}.file-button{position:relative;display:inline-flex;align-items:center;gap:7px;min-height:34px;max-width:220px;padding:7px 13px;border-radius:999px;border:1px solid var(--line);background:#ffffffe6;color:var(--muted);font-size:14px;font-weight:800;cursor:pointer;overflow:hidden;box-shadow:0 12px 30px #4d76a41f}.file-button span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.file-button input{position:absolute;top:0;right:0;bottom:0;left:0;opacity:0;cursor:pointer}.file-button svg{width:18px;height:18px;flex:0 0 auto}.player-card{flex:1;height:100%;min-height:0;padding:12px;border-radius:26px;background:#ffffffe6;border:1px solid var(--line);box-shadow:var(--shadow);display:grid;grid-template-rows:minmax(0,3.4fr) minmax(150px,1.15fr);align-content:start;gap:8px}.player-card--video-hidden{grid-template-rows:auto}.player-card--video-hidden .current-card{height:100%;min-height:180px;align-content:center}.media-frame{position:relative;width:100%;height:100%;min-height:0;overflow:hidden;border-radius:20px;background:#0e1724}.media-frame--audio{display:grid;place-items:center;background:linear-gradient(135deg,#dbeafe,#eff6ff)}video,audio{width:100%;height:100%;display:block;object-fit:contain}audio{width:min(82%,720px);height:54px}.empty-media{position:absolute;top:0;right:0;bottom:0;left:0;color:#dbeafe;display:grid;place-content:center;gap:8px;text-align:center}.empty-media svg{width:52px;height:52px;margin:0 auto}.play-overlay{position:absolute;top:0;right:0;bottom:0;left:0;margin:auto;width:82px;height:82px;display:grid;place-items:center;border-radius:999px;border:4px solid #ffffff;background:#ffffff1f;color:#fff;cursor:pointer;transition:opacity .16s ease,background .16s ease,transform .16s ease}.play-overlay svg{width:42px;height:42px}.play-overlay--hidden{opacity:0}.play-overlay--hidden:hover,.play-overlay--hidden:focus-visible{opacity:.82}.subtitle-mask{position:absolute;left:0;right:0;z-index:3;min-height:18px;background:#050505;cursor:ns-resize;touch-action:none;box-shadow:0 -1px #ffffff24,0 1px #ffffff24}.subtitle-mask:before,.subtitle-mask:after{content:"";position:absolute;left:0;right:0;height:8px}.subtitle-mask:before{top:-4px}.subtitle-mask:after{bottom:-4px}.subtitle-mask-handle{position:absolute;top:50%;left:50%;width:54px;height:5px;border-radius:999px;background:#ffffff52;transform:translate(-50%,-50%)}.current-card{height:100%;min-height:0;padding:8px 18px;border-radius:20px;border:1px solid var(--line);background:var(--card-soft);display:grid;grid-template-rows:minmax(0,1fr) auto;gap:4px}.current-text{text-align:center;min-height:0;overflow:auto;scrollbar-width:none;display:grid;align-content:center}.current-text::-webkit-scrollbar{display:none}.source-line{font-family:var(--foreign-subtitle-font);color:var(--text);font-size:clamp(15px,1.25vw,19px);line-height:1.42;font-weight:800}.target-line{margin-top:5px;color:var(--muted);font-size:clamp(13px,1vw,16px);line-height:1.42;font-weight:700}.muted-line{color:var(--faint)}.current-meta,.subtitle-card footer,.keyword-card footer,.keyword-card header{display:flex;align-items:center;gap:12px;flex-wrap:wrap;color:var(--faint);font-weight:700}.current-meta{justify-content:center;min-height:26px;overflow:hidden;font-size:12px}.current-meta span:first-child{background:#e4f0fb;color:var(--blue-strong);border-radius:999px;padding:4px 10px}.current-meta--empty{visibility:hidden;pointer-events:none}.study-panel{border-radius:28px;background:#ffffffdb;border:1px solid var(--line);box-shadow:var(--shadow);overflow:hidden;display:flex;flex-direction:column;height:100%}.panel-header{padding:14px 18px;border-bottom:1px solid var(--line);display:flex;align-items:center;justify-content:space-between;gap:16px}.panel-header h2{font-size:18px}.panel-tabs{display:flex;gap:14px;flex-wrap:nowrap;overflow-x:auto;max-width:100%}.panel-tabs button{border:0;background:transparent;color:var(--muted);font-weight:900;display:inline-flex;align-items:center;gap:5px;cursor:pointer;padding:7px 2px;border-bottom:3px solid transparent;white-space:nowrap;flex:0 0 auto;font-size:14px}.panel-tabs svg{width:16px;height:16px}.panel-tabs button.active{color:var(--text);border-color:var(--blue)}.subtitle-list,.keyword-list{flex:1;min-height:0;overflow:auto;padding:12px 16px 28px;display:flex;flex-direction:column;gap:10px}.subtitle-list--virtual{gap:0}.subtitle-list--virtual .subtitle-card{margin-bottom:10px}.subtitle-virtual-spacer{flex:0 0 auto}.subtitle-card,.keyword-card{border:1px solid var(--line);border-radius:18px;padding:11px 14px;background:#ffffffc7;box-shadow:0 12px 28px #4d76a414;cursor:pointer;content-visibility:auto;contain-intrinsic-size:120px}.subtitle-card.active,.keyword-card.active{background:#eaf4ff;border-color:#9fc4e8;box-shadow:0 14px 30px #4d76a442}.subtitle-card footer,.keyword-card footer{margin-top:8px;font-size:12px}.keyword-card header{justify-content:space-between}.keyword-timeline-row{display:flex;align-items:center;gap:12px;flex-wrap:wrap;min-height:24px;padding:3px 0;border-radius:8px;color:var(--faint);font-weight:700;cursor:pointer;font-size:12px}.keyword-timeline-row:hover,.keyword-timeline-row.active{background:#eef6ff;color:var(--blue-strong)}.keyword-timeline-row strong{color:var(--faint);font-size:inherit;line-height:inherit;min-width:86px}.keyword-timeline-row .el-button{padding:0;min-height:24px;width:24px;color:var(--muted);font-size:14px}.keyword-timeline-list{display:grid;gap:4px;margin-top:8px}.keyword-timeline-row .favorite-inline{width:24px;height:24px}.keyword-timeline-row .favorite-inline svg{width:17px;height:17px}.keyword-explanation{margin-top:14px;color:var(--text);font-size:14px;line-height:1.55;font-weight:600}.keyword-explanation p,.keyword-tooltip-text p,.keyword-detail-explanation p{margin:0 0 10px}.keyword-explanation p:last-child,.keyword-tooltip-text p:last-child,.keyword-detail-explanation p:last-child{margin-bottom:0}.keyword-explanation strong,.keyword-tooltip-text strong,.keyword-detail-explanation strong{font-weight:900}.keyword-explanation ul,.keyword-explanation ol,.keyword-detail-explanation ul,.keyword-detail-explanation ol{margin:8px 0 12px;padding-left:1.35em}.keyword-explanation li,.keyword-detail-explanation li{margin:4px 0}.keyword-explanation hr,.keyword-detail-explanation hr{border:0;border-top:1px solid var(--line-strong);margin:14px 0}.keyword-cue-times{display:flex;flex-wrap:wrap;gap:6px;margin-top:10px}.keyword-cue-times span{padding:3px 8px;border-radius:999px;background:#eef5fc;color:var(--faint);font-size:12px;font-weight:800}.keyword-chip{display:inline-flex;align-items:center;padding:0 7px;border-radius:999px;border:0;font-weight:800;font-style:normal;cursor:pointer;line-height:1.16;vertical-align:.03em;box-shadow:inset 0 0 0 1px transparent}.keyword-chip--teal{color:#477d76;background:#e5f5f2;box-shadow:inset 0 0 0 1px #add7d0}.keyword-chip--amber{color:#926335;background:#fff1df;box-shadow:inset 0 0 0 1px #efcda8}.keyword-chip--blue{color:#356d9d;background:#e4f1ff;box-shadow:inset 0 0 0 1px #b9d6ef}.keyword-chip--violet{color:#695f9f;background:#eeecff;box-shadow:inset 0 0 0 1px #cbc7f5}.keyword-chip--rose{color:#9c5a6a;background:#ffedf1;box-shadow:inset 0 0 0 1px #efbfcb}.keyword-chip--green{color:#497a4e;background:#eaf8ec;box-shadow:inset 0 0 0 1px #b9d9bd}.cloze-blank{display:inline-grid;align-items:center;justify-content:center;width:var(--blank-ch, 7ch);min-width:var(--blank-ch, 7ch);height:1.12em;vertical-align:-.08em;border-radius:999px;border:1px dashed #9fcfc8;background:repeating-linear-gradient(135deg,rgba(127,204,194,.28) 0 8px,transparent 8px 14px),#e5f5f2cc;cursor:help;color:transparent;font-weight:800;line-height:1.1;box-sizing:border-box}.cloze-blank:focus,.cloze-blank:hover,.cloze-blank:active,.cloze-blank.revealed{width:auto;min-width:var(--blank-ch, 7ch);padding:0 8px;color:inherit;background:#ffffffe6}.cloze-blank:after{content:attr(data-answer)}.favorite-toggle,.favorite-inline{border:0;background:transparent;color:var(--faint);cursor:pointer;font-weight:900;display:inline-flex;align-items:center;justify-content:center;padding:0;line-height:1}.favorite-toggle{width:30px;height:30px;border-radius:999px}.favorite-inline{width:24px;height:24px;border-radius:999px}.favorite-toggle svg,.favorite-inline svg{display:block;width:17px;height:17px;fill:transparent;stroke-width:2.4}.favorite-toggle svg{width:19px;height:19px}.favorite-toggle.active,.favorite-inline.active{color:#d59a2f;background:#fff3c4}.favorite-toggle.active svg,.favorite-inline.active svg{fill:currentColor}.current-edit-button{width:24px;height:24px;min-height:24px;padding:0;border:0;background:transparent;font-size:16px;color:var(--muted)}.current-edit-button:hover,.current-edit-button:focus{background:transparent;color:var(--blue-strong)}.favorite-card{border-color:#e2b35f;background:#fffaf0}.cloze-blank--amber{border-color:#e6c098;background:repeating-linear-gradient(135deg,rgba(239,205,168,.38) 0 8px,transparent 8px 14px),#fff1dfd9}.cloze-blank--blue{border-color:#a7c9e8;background:repeating-linear-gradient(135deg,rgba(185,214,239,.42) 0 8px,transparent 8px 14px),#e4f1ffdb}.cloze-blank--violet{border-color:#bbb5ed;background:repeating-linear-gradient(135deg,rgba(203,199,245,.42) 0 8px,transparent 8px 14px),#eeecffdb}.cloze-blank--rose{border-color:#e4b3c0;background:repeating-linear-gradient(135deg,rgba(239,191,203,.36) 0 8px,transparent 8px 14px),#ffedf1d9}.cloze-blank--green{border-color:#accfb1;background:repeating-linear-gradient(135deg,rgba(185,217,189,.42) 0 8px,transparent 8px 14px),#eaf8ecdb}.cloze-blank--teal.revealed,.cloze-blank--teal:hover,.cloze-blank--teal:focus,.cloze-blank--teal:active{color:#477d76;background:#e5f5f2;border-color:#add7d0}.cloze-blank--amber.revealed,.cloze-blank--amber:hover,.cloze-blank--amber:focus,.cloze-blank--amber:active{color:#926335;background:#fff1df;border-color:#efcda8}.cloze-blank--blue.revealed,.cloze-blank--blue:hover,.cloze-blank--blue:focus,.cloze-blank--blue:active{color:#356d9d;background:#e4f1ff;border-color:#b9d6ef}.cloze-blank--violet.revealed,.cloze-blank--violet:hover,.cloze-blank--violet:focus,.cloze-blank--violet:active{color:#695f9f;background:#eeecff;border-color:#cbc7f5}.cloze-blank--rose.revealed,.cloze-blank--rose:hover,.cloze-blank--rose:focus,.cloze-blank--rose:active{color:#9c5a6a;background:#ffedf1;border-color:#efbfcb}.cloze-blank--green.revealed,.cloze-blank--green:hover,.cloze-blank--green:focus,.cloze-blank--green:active{color:#497a4e;background:#eaf8ec;border-color:#b9d9bd}.keyword-tooltip{position:absolute;z-index:80;width:min(240px,calc(100vw - 24px));max-height:min(160px,calc(100vh - 32px));padding:10px 12px;border-radius:14px;background:#fffffff5;border:1px solid var(--line-strong);box-shadow:0 14px 30px #26394d2e;pointer-events:none;overflow-y:auto;overscroll-behavior:contain;--tooltip-accent: #5f927f}.keyword-tooltip:before{content:"";display:block;height:3px;background:var(--tooltip-accent);margin:-10px -12px 8px}.keyword-tooltip header{display:flex;align-items:center;justify-content:space-between;gap:10px;color:var(--tooltip-accent);font-size:13px}.keyword-tooltip--teal{--tooltip-accent: #477d76}.keyword-tooltip--amber{--tooltip-accent: #926335}.keyword-tooltip--blue{--tooltip-accent: #356d9d}.keyword-tooltip--violet{--tooltip-accent: #695f9f}.keyword-tooltip--rose{--tooltip-accent: #9c5a6a}.keyword-tooltip--green{--tooltip-accent: #497a4e}.keyword-tooltip p{margin-top:8px;color:var(--text);line-height:1.38;white-space:pre-wrap;overflow-wrap:anywhere;font-size:13px;display:-webkit-box;-webkit-line-clamp:4;-webkit-box-orient:vertical;overflow:hidden}.keyword-detail-dialog.el-overlay{background:#0f172075;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px)}.keyword-detail-dialog .el-dialog{position:fixed;top:50%;left:50%;margin:0!important;transform:translate(-50%,-50%);border-radius:30px;background:#ffffffd1;overflow:hidden;box-shadow:0 30px 90px #0f172052;-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px)}.keyword-detail-dialog .el-dialog__header{display:none}.keyword-detail-dialog .el-dialog__body{padding:0}.keyword-detail-close{position:absolute;top:26px;right:26px;z-index:2;width:54px;height:54px;border:0;border-radius:999px;background:#ffffffdb;color:var(--muted);font-size:36px;line-height:1;cursor:pointer}.keyword-detail-card{--detail-accent: #477d76;max-height:min(78vh,720px);overflow:auto;padding:38px 34px 34px;border-top:5px solid var(--detail-accent);background:linear-gradient(135deg,#ffffffb8,#f8fbffe6),var(--card)}.keyword-detail-handle{display:block;width:74px;height:6px;margin:-22px auto 22px;border-radius:999px;background:#91a2b380}.keyword-detail-card--teal{--detail-accent: #477d76}.keyword-detail-card--amber{--detail-accent: #926335}.keyword-detail-card--blue{--detail-accent: #356d9d}.keyword-detail-card--violet{--detail-accent: #695f9f}.keyword-detail-card--rose{--detail-accent: #9c5a6a}.keyword-detail-card--green{--detail-accent: #497a4e}.detail-eyebrow{color:var(--faint);font-size:14px;font-weight:900}.keyword-detail-title-row{display:flex;align-items:center;gap:12px;margin:12px 0 26px}.keyword-detail-card h3{margin:12px 0 14px;color:var(--text);font-size:clamp(34px,4vw,54px);line-height:1}.keyword-detail-title-row h3{margin:0;min-width:0}.keyword-detail-edit{width:38px;height:38px;border:0;border-radius:999px;background:#e4f0fbd1;color:var(--blue-strong);display:inline-flex;align-items:center;justify-content:center;cursor:pointer;flex:0 0 auto}.keyword-detail-edit svg{width:18px;height:18px}.keyword-detail-definition{border-top:4px solid var(--detail-accent);border-radius:22px;padding:22px 24px 26px;background:#ffffffc7;box-shadow:inset 0 0 0 1px var(--line)}.keyword-detail-definition strong{display:inline-block;margin-bottom:14px;color:var(--detail-accent);font-size:24px}.keyword-detail-explanation{overflow-wrap:anywhere;color:var(--text);font-size:18px;line-height:1.65}.control-bar{grid-row:3;position:relative;z-index:10;min-width:0;min-height:0;border-top:1px solid var(--line);background:#ffffffed;box-shadow:0 -18px 45px #4d76a41f;padding:4px 16px 8px;display:grid;grid-template-rows:12px 18px 52px;gap:2px;overflow:visible}.timeline{width:100%;height:12px;accent-color:var(--blue);-webkit-appearance:none;-moz-appearance:none;appearance:none;background:transparent}.timeline::-webkit-slider-runnable-track{height:4px;border-radius:999px;background:linear-gradient(90deg,var(--blue-strong) 0%,var(--blue-strong) var(--progress, 0%),#ffffff var(--progress, 0%),#ffffff 100%);border:1px solid var(--line)}.timeline::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:11px;height:11px;border-radius:50%;background:var(--blue);border:2px solid #fff;margin-top:-4px;box-shadow:0 2px 8px #4f84bd59}.timeline::-moz-range-track{height:4px;border-radius:999px;background:#fff;border:1px solid var(--line)}.timeline::-moz-range-progress{height:4px;border-radius:999px;background:var(--blue-strong)}.control-topline{display:flex;align-items:center;justify-content:space-between;gap:14px;font-size:12px}.time-readout{white-space:nowrap;color:var(--muted);font-weight:800}.time-readout strong{color:var(--text);font-size:16px}.repeat-readout{display:flex;gap:10px;align-items:center;color:var(--blue-strong);font-weight:900}.muted-repeat{color:var(--faint)}.control-actions{min-width:0;display:flex;align-items:center;justify-content:center;gap:10px;flex-wrap:nowrap;overflow-x:auto;overflow-y:visible;padding-bottom:0;scrollbar-width:thin}.tool-button,.primary-control{border:0;background:transparent;color:var(--muted);cursor:pointer;font-weight:800;flex:0 0 auto}.tool-button{min-width:52px;min-height:42px;display:inline-flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;border-radius:12px}.tool-button:hover,.tool-button.active{color:var(--blue-strong);background:#edf5fd}.cloze-blank,.cloze-blank:after{cursor:pointer}.tool-button:not(.active):focus:not(:focus-visible),.mobile-catalog-list button:focus:not(:focus-visible),.segment-cue-list button:focus:not(:focus-visible){outline:0;background:transparent}.tool-button:active:not(.active){background:transparent}.tool-button svg{width:18px;height:18px}.tool-button span{font-size:11px}.tool-value{font-size:13px!important;color:var(--text)}.compact{min-width:56px}.primary-control{width:50px;height:50px;border-radius:999px;background:linear-gradient(135deg,var(--blue),var(--blue-strong));color:#fff;box-shadow:0 12px 24px #4f84bd47;display:inline-grid;place-items:center}.primary-control svg{width:24px;height:24px}.primary-control span{display:none}.control-divider{width:1px;height:34px;background:var(--line-strong);flex:0 0 auto}.mobile-more-button{display:none}.mobile-catalog{display:inline-flex}.mobile-catalog-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:60;display:flex;align-items:center;justify-content:center;background:#0f172a52;padding:20px}.mobile-catalog-sheet{width:min(620px,100%);max-height:min(76vh,680px);padding:18px 16px;border-radius:24px;background:#fffffff0;border:1px solid rgba(220,232,245,.92);box-shadow:0 24px 70px #26394d3d;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);display:grid;grid-template-rows:auto minmax(0,1fr);gap:14px}.mobile-catalog-sheet header{display:flex;align-items:center;justify-content:space-between;gap:12px}.mobile-catalog-sheet header div{display:grid;gap:4px}.mobile-catalog-sheet header strong{font-size:20px}.mobile-catalog-sheet header span{color:var(--muted);font-size:13px;font-weight:800}.mobile-catalog-sheet header button{width:42px;height:42px;border:0;border-radius:999px;background:#f3f6fa;color:var(--text);font-size:28px;line-height:1;cursor:pointer}.mobile-catalog-list{min-height:0;overflow:auto;display:grid;gap:10px;padding-right:2px}.mobile-catalog-list button{min-height:74px;width:100%;border:1px solid var(--line);border-radius:18px;background:#f8fbffeb;display:grid;grid-template-columns:52px minmax(0,1fr) auto;align-items:center;gap:12px;padding:12px;color:var(--text);text-align:left;cursor:pointer}.mobile-catalog-list button.active{border-color:var(--blue);background:#f0f7ff}.mobile-catalog-list button>span{width:46px;height:46px;border-radius:14px;background:#dcecfb;color:var(--blue-strong);display:grid;place-items:center;font-weight:900}.mobile-catalog-list strong{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:15px}.mobile-catalog-list em{font-style:normal;color:var(--muted);font-size:12px;font-weight:800}.mobile-more-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px}.mobile-more-grid .tool-button{min-width:0;min-height:48px;width:100%}.import-dialog-panel{display:grid;gap:12px}.import-file-button{width:100%;max-width:none;min-height:48px;border-radius:16px;justify-content:flex-start;padding:10px 14px;box-shadow:none}.batch-file-button{width:100%;max-width:none;min-height:40px;border-radius:8px;box-shadow:none}.batch-import-note{color:var(--muted);font-size:13px;font-weight:700}.subtitle-line--hidden{visibility:hidden;pointer-events:none}.import-order-row{min-height:48px;padding:10px 14px;border:1px solid var(--line);border-radius:16px;background:#f8fbffc7;display:flex;align-items:center;justify-content:space-between;gap:12px;color:var(--muted);font-weight:900}.font-size-panel{display:grid;gap:18px}.font-size-preview{min-height:118px;border:1px solid var(--line);border-radius:22px;background:#f8fbffc7;display:grid;place-items:center;align-content:center;gap:8px;color:var(--text);text-align:center}.font-size-preview span{font-size:22px;font-weight:900}.font-size-preview strong{font-size:18px;font-weight:900}.font-size-preview p{color:var(--muted);font-weight:800}.font-size-tabs,.font-size-presets{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.font-size-tabs button,.font-size-presets button{border:1px solid var(--line-strong);border-radius:999px;min-height:44px;background:#ffffffe0;color:var(--muted);font-weight:900;cursor:pointer}.font-size-tabs button.active,.font-size-presets button.active{color:#fff;border-color:transparent;background:var(--blue);box-shadow:0 12px 24px #4f84bd38}.font-size-range{width:100%;accent-color:var(--blue)}.font-size-scale{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));color:var(--faint);font-size:12px;font-weight:800}.font-size-scale span:nth-child(2),.font-size-scale span:nth-child(3),.font-size-scale span:nth-child(4){text-align:center}.font-size-scale span:last-child{text-align:right}.font-size-presets{grid-template-columns:repeat(4,minmax(0,1fr))}.dialog-section-head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin:8px 0 10px}.keyword-draft-list{display:grid;gap:12px}.keyword-draft{border:1px solid var(--line-strong);border-radius:16px;padding:14px;background:#f8fbffbd;display:grid;gap:12px}.keyword-draft-head{display:flex;align-items:center;justify-content:space-between;gap:10px;color:var(--muted);font-size:13px;font-weight:900}.keyword-draft-actions{display:flex;align-items:center;justify-content:flex-end;gap:4px;flex-wrap:wrap}.keyword-draft-grid{display:grid;grid-template-columns:minmax(150px,.7fr) minmax(150px,.7fr) minmax(260px,1.6fr);gap:12px;align-items:start}.keyword-field{display:grid;gap:6px}.keyword-field>span{color:var(--faint);font-size:12px;font-weight:900}.keyword-field--wide{min-width:0}.export-summary{display:grid;gap:8px;color:var(--muted);font-weight:700}.glass-dialog .el-dialog{border-radius:24px;overflow:hidden;background:#ffffffe6;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px)}.segment-dialog,.loop-dialog{display:grid;gap:18px}.range-pill{padding:14px 18px;border:1px solid var(--line);border-radius:999px;background:#f8fbffe6;color:var(--muted);font-weight:900}.range-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}.wide-primary{min-height:48px;border-radius:14px;font-weight:900}.segment-cue-list{max-height:300px;overflow:auto;display:grid;gap:10px}.segment-cue-list button{border:1px solid var(--line);border-radius:14px;background:#ffffffd1;color:var(--text);display:grid;grid-template-columns:58px 1fr auto;gap:12px;align-items:center;padding:12px 14px;text-align:left;cursor:pointer}.segment-cue-list button.selected{border-color:#9fc4e8;background:#eaf4ff}.segment-cue-list button.boundary-start,.segment-cue-list button.boundary-end{border-color:var(--blue-strong)}.segment-cue-list span{color:var(--blue-strong);font-family:ui-monospace,SFMono-Regular,Consolas,monospace;font-weight:800}.segment-cue-list em{min-width:42px;padding:4px 8px;border-radius:999px;background:#dcecfb;color:var(--blue-strong);font-size:12px;font-style:normal;font-weight:900;text-align:center}.loop-mode-row,.loop-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.loop-mode-row button,.loop-grid button{border:1px solid var(--line);border-radius:14px;min-height:46px;background:#ffffffdb;color:var(--muted);font-weight:900;cursor:pointer}.loop-mode-row button.active,.loop-grid button.active{background:var(--blue);color:#fff;border-color:transparent}.loop-dialog p{color:var(--muted);font-weight:700}.loop-range{width:100%;accent-color:var(--blue)}.loop-grid{grid-template-columns:repeat(3,minmax(0,1fr))}@media(max-width:1180px){.workspace{grid-template-columns:1fr;overflow:auto}.study-panel{min-height:520px}}@media(max-width:760px){.auth-panel{grid-template-columns:1fr;padding:22px}.auth-copy h1,.catalog-header h1{font-size:26px}.catalog-header,.course-head{align-items:flex-start;flex-direction:column}.catalog-actions,.inline-actions{justify-content:flex-start}.course-section{grid-template-columns:1fr}.course-cover{min-height:150px}.app-shell{height:var(--app-height, 100dvh);grid-template-rows:minmax(0,1fr) 164px}.learning-top-nav{display:none}.workspace{grid-row:1;height:100%;padding:0 0 8px;grid-template-rows:auto minmax(0,1fr);align-content:start;align-items:stretch;overflow:hidden}.hero-area{min-height:0;gap:0}.title-row{display:none}.player-card{height:auto;padding:0;border:0;border-radius:0;box-shadow:none;background:transparent;gap:0;grid-template-rows:auto}.player-card--video-hidden{height:190px}.media-frame{aspect-ratio:16 / 9;width:100%;min-height:0;border-radius:0}.media-frame video{object-fit:contain;object-position:center center}.current-card{display:none}.current-text{align-content:center;overflow:auto}.file-button{min-height:28px;max-width:min(46vw,190px);padding:5px 10px;gap:5px;font-size:12px;box-shadow:0 8px 20px #4d76a41a}.file-button svg{width:15px;height:15px}.import-file-button{max-width:none;min-height:46px;padding:10px 12px;font-size:13px;box-shadow:none}.study-panel{min-height:0;height:100%;border-radius:0;border-left:0;border-right:0;box-shadow:none}.subtitle-list,.keyword-list{flex:1 1 auto;padding:12px 10px 20px;min-height:0;overflow:auto;overscroll-behavior:contain;scroll-padding-top:10px}.panel-header{padding:8px 10px;gap:8px}.panel-header h2{width:46px;flex:0 0 46px;font-size:16px;line-height:1.05}.panel-tabs{gap:8px}.panel-tabs button{gap:3px;padding:5px 1px;font-size:12px;border-bottom-width:2px}.panel-tabs svg{width:14px;height:14px}.control-bar{grid-row:2;padding:4px 6px 10px;grid-template-rows:12px 20px 98px}.control-topline{font-size:11px}.time-readout strong{font-size:15px}.control-actions{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));grid-template-rows:34px 56px;justify-content:normal;align-items:center;gap:0 4px;overflow:visible}.control-actions>*{justify-self:center}.mobile-secondary,.control-actions>.control-divider{display:none}.mobile-primary,.mobile-catalog,.mobile-more-button{display:inline-flex}.mobile-speed{grid-column:1;grid-row:1}.mobile-segment{grid-column:2;grid-row:1}.mobile-loop{grid-column:3;grid-row:1}.mobile-prev{grid-column:2;grid-row:2}.primary-control.transport-control{grid-column:3;grid-row:2}.mobile-next{grid-column:4;grid-row:2}.mobile-auto{grid-column:4;grid-row:1}.mobile-catalog{grid-column:5;grid-row:1}.mobile-more-button{grid-column:5;grid-row:2}.tool-button{min-width:0;width:100%;min-height:34px;gap:2px;padding:0;border-radius:10px}.tool-button svg{width:16px;height:16px}.tool-button span{font-size:9px;line-height:1.12}.primary-control{width:52px;height:52px}.transport-control.tool-button{min-height:52px}.font-size-dialog .el-dialog,.keyword-detail-dialog .el-dialog,.el-dialog{width:calc(100vw - 24px)!important;max-width:calc(100vw - 24px);margin:8vh auto 0!important;border-radius:22px}.font-size-dialog .el-dialog__body,.el-dialog__body{max-height:min(70vh,620px);overflow:auto;padding:14px 16px}.font-size-presets{grid-template-columns:repeat(2,minmax(0,1fr))}.cue-editor-dialog .el-dialog__body{padding:12px 14px}.cue-editor-dialog .el-form-item{margin-bottom:12px}.cue-editor-dialog .el-row{display:grid;grid-template-columns:1fr 1fr;gap:8px}.cue-editor-dialog .el-col{max-width:none;flex:none;width:100%}.cue-editor-dialog .el-input-number{width:100%}.dialog-section-head{align-items:flex-start;flex-direction:column;gap:8px}.keyword-draft{padding:10px;border-radius:14px;gap:10px}.keyword-field>span{font-size:11px}.keyword-field .el-textarea__inner{max-height:180px}.subtitle-card,.keyword-card{padding:9px 10px;border-radius:14px}.subtitle-content{gap:3px}.source-line{line-height:1.34}.target-line{line-height:1.32;margin-top:3px}.subtitle-card footer,.keyword-card footer{gap:8px;margin-top:6px;font-size:11px}.favorite-inline{width:20px;height:20px}.favorite-inline svg{width:15px;height:15px}.keyword-draft{padding:12px}.keyword-draft-grid{grid-template-columns:1fr;gap:10px}.keyword-tooltip{width:min(300px,calc(100vw - 20px));max-height:min(280px,calc(100vh - 28px));padding:12px 14px;border-radius:14px;font-size:12px}.keyword-tooltip:before{margin:-12px -14px 10px}.keyword-detail-close{top:12px;right:12px;width:40px;height:40px;font-size:28px}.keyword-detail-card{max-height:78vh;padding:26px 22px 30px}.keyword-detail-card h3{font-size:34px}.keyword-detail-title-row{gap:8px;margin-bottom:20px}.keyword-detail-edit{width:34px;height:34px}.keyword-detail-card p{font-size:15px;line-height:1.55}}
