:root{color-scheme:light;font-family:Segoe UI,PingFang SC,Microsoft YaHei,sans-serif;background:#f3f5f8;color:#18212f}*{box-sizing:border-box}html,body,#root{margin:0;min-height:100%}body{min-height:100vh;background:linear-gradient(180deg,#f7f8fb,#eef2f8)}button,input,textarea,select{font:inherit}button:disabled,label:has(input:disabled){cursor:not-allowed}.page-shell{min-height:100vh;padding:12px 14px 20px}.page-content{width:min(1120px,100%);margin:0 auto;display:grid;gap:12px}.panel{background:#fffffff0;border:1px solid rgba(203,214,226,.9);border-radius:20px;box-shadow:0 14px 36px #12223612;padding:14px}.tool-header,.manage-header{padding-block:10px}.tool-header-row{display:flex;align-items:center;justify-content:space-between;gap:12px}.eyebrow{margin:0 0 8px;font-size:12px;letter-spacing:.08em;text-transform:uppercase;color:#718198}h1{margin:0;font-size:clamp(24px,3vw,30px);line-height:1.02}.friend-layout,.manage-layout,.manage-main-column{display:grid;gap:16px}.friend-layout{grid-template-columns:minmax(420px,520px) minmax(0,1fr);align-items:start}.manage-layout{grid-template-columns:minmax(0,1fr) minmax(320px,380px);align-items:start}.manage-header-row,.section-head,.download-item,.manage-item{display:flex;justify-content:space-between;gap:12px;align-items:flex-start}.section-title{font-size:16px;font-weight:800;line-height:1.1}.subtle-text,.helper-text,.status-text,.empty-text{color:#617084;line-height:1.7}.subtle-text{font-size:13px}.video-shell{overflow:hidden;border-radius:14px}.video-shell video,.video-placeholder{display:block;width:100%;aspect-ratio:16 / 9}.video-shell video{background:#000}.video-placeholder{display:grid;place-items:center;padding:24px;text-align:center;color:#ffffffe0;background:linear-gradient(135deg,#1a2636,#324e72);line-height:1.8}.selector-row,.button-grid,.download-list,.manage-list,.meta-grid,.manage-list-tools{margin-top:10px}.selector-input,.text-input{width:100%;min-height:42px;padding:8px 12px;border-radius:12px;border:1px solid #cad6e2;background:#fff;color:#18212f}.meta-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.compact-grid{margin-top:14px}.meta-card{padding:10px 12px;border-radius:14px;background:#f8fbfe;border:1px solid #dde7ef}.meta-label{display:block;font-size:12px;color:#748397}.meta-value{display:block;margin-top:6px;line-height:1.6;word-break:break-word}.meta-subvalue{display:block;margin-top:4px;font-size:12px;color:#5f7a9a}.hint-card{margin-top:10px;padding:10px 12px;border-radius:14px;background:#f4f8fd;border:1px solid #dbe7f3;color:#58687b;line-height:1.7}.friend-side-tools{margin-top:10px;padding:10px 12px;border-radius:16px;background:linear-gradient(180deg,#f8fbff,#f2f7fc);border:1px solid #d8e4ee}.side-tools-row{display:grid;grid-template-columns:160px minmax(0,1fr) 86px;gap:10px;align-items:center}.practice-panel{background:linear-gradient(180deg,#fffffffa,#f7fafefa)}.recorded-pill{display:inline-flex;align-items:center;padding:6px 10px;margin-top:10px;border-radius:999px;background:#eef8f1;border:1px solid #cfe6d7;color:#245839;font-size:12px;font-weight:700}.inline-pill{margin-top:0;align-self:center}.line-card{margin-top:4px;min-height:74px;display:flex;align-items:center;justify-content:center;padding:12px 16px;border-radius:18px;background:#f5f9fd;border:1px solid #dbe9f3;text-align:center;font-size:clamp(20px,2.6vw,25px);line-height:1.55;font-weight:700}.button-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.practice-toolbar{margin-top:6px;display:flex;flex-wrap:wrap;gap:8px;align-items:center}.practice-toolbar .action-button{min-width:118px}.toolbar-record-button{min-width:176px}.triple-grid{grid-template-columns:repeat(3,minmax(0,1fr))}.action-button{min-height:42px;display:inline-flex;align-items:center;justify-content:center;border-radius:14px;border:none;padding:0 14px;cursor:pointer;font-weight:700;transition:transform .15s ease,opacity .15s ease}.action-button:hover:not(:disabled){transform:translateY(-1px)}.action-button:disabled{opacity:.55}.dark-button,.primary-button{background:#162235;color:#fff}.secondary-button{background:#fff;border:1px solid #cbd7e3;color:#18212f}.danger-button{background:#b42318;color:#fff}.small-button{min-height:38px;min-width:82px;font-size:13px}.cloud-status{min-height:38px;display:flex;align-items:center;padding:0 14px;border-radius:14px;border:1px solid #d7e0ea;background:#f8fbff;color:#5e6d80;font-size:14px}.cloud-status-pending{border-color:#d7e0ea;color:#5e6d80}.cloud-status-success{border-color:#cfe6d7;background:#eef8f1;color:#245839}.cloud-status-error{border-color:#f1c7c3;background:#fff3f2;color:#9f2d24}.upload-queue-panel{margin-top:6px;padding-top:6px;border-top:1px solid #e0e7ef}.queue-toolbar{display:flex;align-items:center;gap:8px}.upload-queue-list{display:grid;gap:6px;margin-top:8px}.upload-queue-item{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:8px 12px;border-radius:12px;background:#f8fbff;border:1px solid #dde7ef}.upload-queue-name{font-size:14px;font-weight:700;color:#1f2b3a}.upload-queue-actions{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.upload-queue-empty{margin-top:8px}.upload-badge{display:inline-flex;align-items:center;justify-content:center;min-width:82px;min-height:28px;padding:0 10px;border-radius:999px;font-size:12px;font-weight:700}.upload-badge-pending{background:#eef4fb;color:#40607f}.upload-badge-success{background:#eef8f1;color:#245839}.upload-badge-error{background:#fff3f2;color:#9f2d24}.jump-button{min-height:42px}.download-list,.manage-list,.manage-list-tools{display:grid;gap:10px}.download-item,.manage-item{padding:12px 14px;border-radius:14px;background:#fbfdff;border:1px solid #dde7ef}.download-name{font-size:15px;font-weight:700}.back-link{align-self:center;color:#1c4a8c;text-decoration:none;font-weight:700}.uploader-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.field-stack{display:grid;gap:6px}.warning-card{background:#fff6df;border-color:#f0d797;color:#7b5a09}.success-card{background:#eef8f1;border-color:#cfe6d7;color:#245839}.manage-item-copy{display:grid;gap:4px;line-height:1.6;color:#5f6d7f}.manage-item-links{display:flex;flex-wrap:wrap;gap:10px;margin-top:4px;font-size:13px}.manage-item-links a{color:#1c4a8c;text-decoration:none;font-weight:700}.manage-item-actions{display:grid;gap:8px;min-width:108px}.guide-modal-backdrop{position:fixed;inset:0;background:#131d2a7a;display:grid;place-items:center;padding:20px;z-index:20}.guide-modal{width:min(860px,100%);max-height:min(88vh,920px);overflow:auto;background:#fff;border-radius:22px;border:1px solid #d8e1eb;box-shadow:0 30px 80px #0a18282e;padding:18px}.guide-modal-head{display:flex;justify-content:space-between;gap:12px;align-items:flex-start}.guide-modal-body,.guide-editor-list{display:grid;gap:14px;margin-top:14px}.guide-block,.guide-editor-item{padding:14px;border-radius:16px;background:#f8fbff;border:1px solid #dde7ef}.guide-text-content{white-space:pre-wrap;line-height:1.8;color:#243142}.guide-image,.guide-video{display:block;width:100%;border-radius:14px;background:#000}.guide-caption{margin-top:10px;color:#617084;line-height:1.7}.guide-editor-toolbar{display:flex;flex-wrap:wrap;gap:10px;margin-top:12px}.guide-editor-item-head{display:flex;justify-content:space-between;gap:10px;align-items:center;margin-bottom:12px}.guide-textarea{min-height:160px;resize:vertical}@media(max-width:920px){.friend-layout,.manage-layout{grid-template-columns:1fr}}@media(max-width:720px){.page-shell{padding:14px 12px 28px}.meta-grid,.button-grid,.triple-grid,.uploader-grid,.side-tools-row,.practice-toolbar{grid-template-columns:1fr}.manage-item-actions{min-width:0}.manage-header-row,.section-head,.download-item,.manage-item,.tool-header-row,.guide-modal-head,.guide-editor-item-head{flex-direction:column;align-items:stretch}}
