@charset "UTF-8";.confirm-backdrop[data-v-07a57902]{position:fixed;inset:0;z-index:3000;display:grid;place-items:center;padding:24px;background:#0f172a61}.confirm-card[data-v-07a57902]{width:min(420px,94vw);border:1px solid rgba(220,231,247,.95);border-radius:10px;background:#fff;box-shadow:0 28px 80px #0f172a3d;padding:20px}.confirm-card header span[data-v-07a57902]{color:#64748b;font-size:12px;font-weight:400}.confirm-card h3[data-v-07a57902]{margin-top:5px;color:#0f172a;font-size:20px;font-weight:950}.confirm-card p[data-v-07a57902]{margin-top:14px;color:#334155;font-size:14px;line-height:1.7;font-weight:760}.confirm-card footer[data-v-07a57902]{display:flex;justify-content:flex-end;gap:10px;margin-top:22px}.confirm-card button[data-v-07a57902]{min-width:88px;height:38px;border-radius:8px;cursor:pointer;font-size:14px;font-weight:400}.confirm-cancel[data-v-07a57902]{border:1px solid #dbe5f5;background:#f8fafc;color:#475569}.confirm-submit[data-v-07a57902]{border:0;background:linear-gradient(135deg,#2563eb,#3f82ff);color:#fff;box-shadow:0 12px 26px #2563eb38}.confirm-submit.danger[data-v-07a57902]{background:linear-gradient(135deg,#ef4444,#dc2626);box-shadow:0 12px 26px #dc262638}.launch-showcase[data-v-2593482b]{position:fixed;inset:0;z-index:3000;overflow:hidden;cursor:pointer;background:#070d1c57;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.launch-showcase[data-v-2593482b]:before{position:absolute;inset:0;content:"";background:radial-gradient(circle at 20% 18%,rgba(38,105,255,.22),transparent 30%),radial-gradient(circle at 82% 74%,rgba(26,188,156,.18),transparent 30%);pointer-events:none}.launch-showcase__stage[data-v-2593482b]{position:relative;z-index:1;width:100%;height:100%;perspective:1400px}.launch-fly-card[data-v-2593482b]{position:absolute;left:50%;top:50%;margin:0;overflow:visible;border:0;background:transparent;opacity:0;transform-origin:center;animation:flyThrough-2593482b 6s cubic-bezier(.18,.82,.18,1) infinite;will-change:transform,opacity,filter}.launch-fly-card img[data-v-2593482b]{display:block;width:min(72vw,980px);height:auto;max-height:82vh;object-fit:contain;background:transparent;pointer-events:none;-webkit-user-select:none;user-select:none}.launch-fly-card--1[data-v-2593482b]{--from-x: -118vw;--from-y: -36vh;--from-rotate: -18deg;--hold-x: -5vw;--hold-y: -4vh;--hold-rotate: -3deg;--to-x: 95vw;--to-y: 38vh;--to-rotate: 15deg;animation-delay:0s}.launch-fly-card--2[data-v-2593482b]{--from-x: 112vw;--from-y: -24vh;--from-rotate: 16deg;--hold-x: 7vw;--hold-y: 3vh;--hold-rotate: 3deg;--to-x: -102vw;--to-y: 42vh;--to-rotate: -14deg;animation-delay:1.2s}.launch-fly-card--3[data-v-2593482b]{--from-x: -86vw;--from-y: 82vh;--from-rotate: 13deg;--hold-x: 0vw;--hold-y: -2vh;--hold-rotate: 1deg;--to-x: 92vw;--to-y: -72vh;--to-rotate: -16deg;animation-delay:2.4s}.launch-fly-card--4[data-v-2593482b]{--from-x: 78vw;--from-y: 88vh;--from-rotate: -15deg;--hold-x: -8vw;--hold-y: 4vh;--hold-rotate: -2deg;--to-x: -96vw;--to-y: -66vh;--to-rotate: 17deg;animation-delay:3.6s}.launch-fly-card--5[data-v-2593482b]{--from-x: 0vw;--from-y: -118vh;--from-rotate: 7deg;--hold-x: 4vw;--hold-y: 0vh;--hold-rotate: 0deg;--to-x: -16vw;--to-y: 112vh;--to-rotate: -8deg;animation-delay:4.8s}.launch-showcase-enter-active[data-v-2593482b],.launch-showcase-leave-active[data-v-2593482b]{transition:opacity .24s ease}.launch-showcase-enter-from[data-v-2593482b],.launch-showcase-leave-to[data-v-2593482b]{opacity:0}@keyframes flyThrough-2593482b{0%{opacity:0;filter:blur(8px) saturate(.8);transform:translate3d(calc(-50% + var(--from-x)),calc(-50% + var(--from-y)),-420px) rotate(var(--from-rotate)) scale(.58)}7%{opacity:1;filter:blur(0) saturate(1.08);transform:translate3d(calc(-50% + var(--hold-x)),calc(-50% + var(--hold-y)),120px) rotate(var(--hold-rotate)) scale(1.02)}13%{opacity:1;filter:blur(0) saturate(1.08);transform:translate3d(calc(-50% + var(--hold-x)),calc(-50% + var(--hold-y)),0) rotate(var(--hold-rotate)) scale(1)}20%{opacity:0;filter:blur(7px) saturate(.86);transform:translate3d(calc(-50% + var(--to-x)),calc(-50% + var(--to-y)),-260px) rotate(var(--to-rotate)) scale(.66)}to{opacity:0;transform:translate3d(calc(-50% + var(--to-x)),calc(-50% + var(--to-y)),-260px) rotate(var(--to-rotate)) scale(.66)}}@media(max-width:760px){.launch-fly-card img[data-v-2593482b]{width:min(90vw,560px);max-height:78vh}}@media(prefers-reduced-motion:reduce){.launch-fly-card[data-v-2593482b]{animation-duration:6s!important;animation-iteration-count:infinite!important}.launch-showcase-enter-active[data-v-2593482b],.launch-showcase-leave-active[data-v-2593482b]{transition-duration:.24s!important}}.notification-wrap[data-v-5e48b06c]{position:relative}.notification-badge[data-v-5e48b06c]{position:absolute;top:0;right:0;min-width:15px;height:15px;padding:0 4px;border:1px solid #fff;border-radius:999px;background:var(--ui-red);color:#fff;font-size:9px;font-weight:400;line-height:13px}.notification-panel[data-v-5e48b06c]{position:absolute;top:calc(100% + 12px);right:-42px;z-index:1900;width:368px;padding:12px;border:1px solid rgba(210,220,240,.96);border-radius:14px;background:#fffffffa;box-shadow:0 24px 60px #0f172a2e}.notification-panel[data-v-5e48b06c]:before{position:absolute;top:-6px;right:52px;width:12px;height:12px;border-top:1px solid rgba(210,220,240,.96);border-left:1px solid rgba(210,220,240,.96);background:#fff;content:"";transform:rotate(45deg)}.notification-panel-head[data-v-5e48b06c],.notification-panel-foot[data-v-5e48b06c]{display:flex;align-items:center;justify-content:space-between;gap:10px}.notification-panel-head[data-v-5e48b06c]{padding:2px 2px 10px;border-bottom:1px solid var(--ui-line)}.notification-panel-head strong[data-v-5e48b06c],.notification-panel-head small[data-v-5e48b06c]{display:block}.notification-panel-head strong[data-v-5e48b06c]{color:var(--ui-ink);font-size:15px;font-weight:400}.notification-panel-head small[data-v-5e48b06c],.notification-panel-foot[data-v-5e48b06c]{color:var(--ui-muted);font-size:12px;font-weight:700}.notification-panel-head button[data-v-5e48b06c]{height:28px;padding:0 10px;border:1px solid var(--ui-line);border-radius:8px;background:#f8fbff;color:var(--ui-blue);cursor:pointer;font-size:12px;font-weight:400}.notification-list[data-v-5e48b06c]{max-height:360px;overflow:auto;padding:8px 0}.notification-item[data-v-5e48b06c]{display:flex;width:100%;gap:10px;padding:10px 8px;border:0;border-radius:10px;background:transparent;color:inherit;cursor:pointer;text-align:left}.notification-item[data-v-5e48b06c]:hover{background:#f2f6ff}.notification-item.unread[data-v-5e48b06c]{background:#3267f60f}.notification-item-tag[data-v-5e48b06c]{flex:0 0 auto;padding:3px 7px;border-radius:999px;background:#3267f61f;color:var(--ui-blue);font-size:11px;font-weight:400}.notification-item-main[data-v-5e48b06c]{min-width:0}.notification-item-main strong[data-v-5e48b06c],.notification-item-main small[data-v-5e48b06c],.notification-item-main em[data-v-5e48b06c]{display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.notification-item-main strong[data-v-5e48b06c]{color:var(--ui-ink);font-size:13px;font-weight:400}.notification-item-main small[data-v-5e48b06c]{margin-top:4px;color:var(--ui-text);font-size:12px;font-weight:600}.notification-item-main em[data-v-5e48b06c]{margin-top:5px;color:var(--ui-muted);font-size:11px;font-style:normal;font-weight:700}.notification-empty[data-v-5e48b06c]{padding:28px 10px;color:var(--ui-muted);text-align:center;font-size:13px;font-weight:800}.notification-empty.error[data-v-5e48b06c]{color:#dc2626}.notification-panel-foot[data-v-5e48b06c]{padding:10px 2px 0;border-top:1px solid var(--ui-line)}.app-dialog-mask[data-v-5e48b06c]{position:fixed;inset:0;z-index:3000;display:grid;place-items:center;padding:24px;background:#0f172a5c;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.app-dialog[data-v-5e48b06c]{width:min(760px,calc(100vw - 32px));max-height:calc(100vh - 48px);overflow:hidden;border:1px solid rgba(210,220,240,.96);border-radius:18px;background:#fff;box-shadow:0 32px 86px #0f172a47}.notice-detail-dialog[data-v-5e48b06c]{width:min(680px,calc(100vw - 32px))}.app-dialog-header[data-v-5e48b06c]{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;padding:20px 22px;border-bottom:1px solid var(--ui-line);background:linear-gradient(135deg,#3267f614,#55c6c214)}.app-dialog-header span[data-v-5e48b06c],.app-dialog-header small[data-v-5e48b06c]{display:block;color:var(--ui-muted);font-size:12px;font-weight:800}.app-dialog-header h3[data-v-5e48b06c]{margin:5px 0;color:var(--ui-ink);font-size:21px;font-weight:400}.app-dialog-header>button[data-v-5e48b06c]{width:30px;height:30px;border:0;border-radius:999px;background:#0f172a14;color:var(--ui-ink);cursor:pointer;font-size:22px;line-height:1}.notice-detail-content[data-v-5e48b06c]{max-height:min(520px,calc(100vh - 210px));overflow:auto;padding:22px;color:var(--ui-ink);font-size:14px;line-height:1.8}.app-dialog-footer[data-v-5e48b06c]{display:flex;justify-content:flex-end;gap:10px;padding:14px 22px 20px;border-top:1px solid var(--ui-line)}.profile-dialog-body[data-v-5e48b06c]{display:grid;grid-template-columns:minmax(0,1fr) minmax(280px,.9fr);gap:16px;padding:18px 22px 22px}.profile-card[data-v-5e48b06c]{min-width:0;padding:16px;border:1px solid var(--ui-line);border-radius:14px;background:#fbfcff}.profile-avatar-row[data-v-5e48b06c]{display:flex;align-items:center;gap:12px;margin-bottom:16px}.profile-avatar[data-v-5e48b06c]{width:46px;height:46px;font-size:18px}.profile-avatar-row strong[data-v-5e48b06c],.profile-avatar-row small[data-v-5e48b06c]{display:block}.profile-avatar-row strong[data-v-5e48b06c]{color:var(--ui-ink);font-size:18px;font-weight:400}.profile-avatar-row small[data-v-5e48b06c]{margin-top:4px;color:var(--ui-muted);font-size:12px;font-weight:800}.profile-field-grid[data-v-5e48b06c]{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;margin:0}.profile-field-grid div[data-v-5e48b06c]{min-width:0;padding:10px;border-radius:10px;background:#fff}.profile-field-grid dt[data-v-5e48b06c]{color:var(--ui-muted);font-size:12px;font-weight:800}.profile-field-grid dd[data-v-5e48b06c]{overflow:hidden;margin:5px 0 0;color:var(--ui-ink);text-overflow:ellipsis;white-space:nowrap;font-size:13px;font-weight:400}.profile-loading[data-v-5e48b06c]{padding:34px 0;color:var(--ui-muted);text-align:center;font-size:13px;font-weight:800}.password-card h4[data-v-5e48b06c]{margin:0 0 12px;color:var(--ui-ink);font-size:16px;font-weight:400}.password-card label[data-v-5e48b06c]{display:block;margin-bottom:12px}.password-card label span[data-v-5e48b06c]{display:block;margin-bottom:6px;color:var(--ui-muted);font-size:12px;font-weight:400}.password-card input[data-v-5e48b06c]{width:100%;height:38px;padding:0 11px;border:1px solid var(--ui-line);border-radius:9px;background:#fff;color:var(--ui-ink);font-size:13px;outline:none}.password-card input[data-v-5e48b06c]:focus{border-color:#3267f6b8;box-shadow:0 0 0 3px #3267f61a}.password-actions[data-v-5e48b06c]{display:flex;justify-content:flex-end;gap:10px;margin-top:16px}.profile-message[data-v-5e48b06c]{margin:14px 22px 0;padding:10px 12px;border-radius:9px;font-size:13px;font-weight:800}.profile-message.success[data-v-5e48b06c]{border:1px solid rgba(22,163,74,.18);background:#f0fdf4;color:#166534}.profile-message.error[data-v-5e48b06c]{border:1px solid rgba(220,38,38,.18);background:#fef2f2;color:#991b1b}@media(max-width:860px){.notification-panel[data-v-5e48b06c]{right:-118px;width:min(340px,calc(100vw - 32px))}.profile-dialog-body[data-v-5e48b06c]{grid-template-columns:1fr}}#nprogress{pointer-events:none}#nprogress .bar{background:#29d;position:fixed;z-index:1031;top:0;left:0;width:100%;height:2px}#nprogress .peg{display:block;position:absolute;right:0;width:100px;height:100%;box-shadow:0 0 10px #29d,0 0 5px #29d;opacity:1;-webkit-transform:rotate(3deg) translate(0px,-4px);-ms-transform:rotate(3deg) translate(0px,-4px);transform:rotate(3deg) translateY(-4px)}#nprogress .spinner{display:block;position:fixed;z-index:1031;top:15px;right:15px}#nprogress .spinner-icon{width:18px;height:18px;box-sizing:border-box;border:solid 2px transparent;border-top-color:#29d;border-left-color:#29d;border-radius:50%;-webkit-animation:nprogress-spinner .4s linear infinite;animation:nprogress-spinner .4s linear infinite}.nprogress-custom-parent{overflow:hidden;position:relative}.nprogress-custom-parent #nprogress .spinner,.nprogress-custom-parent #nprogress .bar{position:absolute}@-webkit-keyframes nprogress-spinner{0%{-webkit-transform:rotate(0deg)}to{-webkit-transform:rotate(360deg)}}@keyframes nprogress-spinner{0%{transform:rotate(0)}to{transform:rotate(360deg)}}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Microsoft YaHei,sans-serif;background:linear-gradient(180deg,#f8f9fa,#fff);background-attachment:fixed;color:#0f172a}.sport-login-page{min-height:100vh;display:grid;grid-template-columns:minmax(0,1.1fr) 420px;gap:48px;align-items:center;padding:56px;background:radial-gradient(circle at 18% 18%,rgba(37,99,235,.18),transparent 30%),radial-gradient(circle at 82% 28%,rgba(14,165,233,.2),transparent 28%),linear-gradient(135deg,#eef7ff,#f8fafc 48%,#ecfeff)}.sport-login-hero{max-width:760px}.sport-login-hero span,.login-kicker{display:inline-flex;color:#0369a1;font-size:13px;font-weight:800;letter-spacing:.12em;text-transform:uppercase;margin-bottom:18px}.sport-login-hero h1{color:#0f172a;font-size:clamp(42px,6vw,78px);line-height:1.03;letter-spacing:-.05em;margin-bottom:24px}.sport-login-hero p{color:#475569;font-size:18px;line-height:1.9;max-width:620px}.sport-login-card{background:#ffffffd1;border:1px solid rgba(148,163,184,.28);border-radius:32px;box-shadow:0 30px 90px #0f172a24;-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);padding:34px;display:grid;gap:20px}.sport-login-card h2{color:#0f172a;font-size:28px}.sport-login-card label{display:grid;gap:8px;color:#334155;font-weight:700}.sport-login-card input{width:100%;border:1px solid #cbd5e1;border-radius:16px;padding:14px 16px;color:#0f172a;background:#fff;font-size:15px;outline:none;transition:border-color .18s ease,box-shadow .18s ease}.sport-login-card input:focus{border-color:#0284c7;box-shadow:0 0 0 4px #0ea5e929}.login-error{color:#b91c1c;background:#fef2f2;border:1px solid #fecaca;border-radius:14px;padding:10px 12px;font-size:14px}.sport-login-submit{width:100%;justify-content:center;min-height:48px}.empty-state-card,.load-error-card{border:1px dashed #cbd5e1;border-radius:20px;padding:28px;background:#f8fafc;color:#475569;text-align:center}.load-error-card{border-color:#fecaca;background:#fff7f7;color:#991b1b}@media(max-width:920px){.sport-login-page{grid-template-columns:1fr;padding:28px}}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}.top-menu{background:linear-gradient(135deg,#87ceeb,#b0e0e6);padding:20px;display:flex;align-items:center;gap:15px;box-shadow:0 2px 8px #0000001a;position:fixed;top:0;left:0;right:0;z-index:1000;height:auto;min-height:85px;box-sizing:border-box}.menu-left{display:flex;align-items:center}.menu-icon{display:flex;align-items:center;justify-content:center;margin-right:10px}.menu-icon svg,.icon-book{width:24px;height:24px;color:#0f172a}.menu-tab{background:#ffffff4d;padding:10px 20px;border-radius:8px;font-weight:600;font-size:16px;color:#0f172a;cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1)}.menu-tab:hover{background:#ffffff80}.menu-tab:focus{outline:2px solid rgba(255,255,255,.5);outline-offset:2px}.menu-tab.active{background:#ffffffe6;box-shadow:0 2px 4px #0000001a}.menu-buttons{display:flex;gap:10px;flex:1;justify-content:flex-end}.menu-btn{background:#fff3;border:none;border-radius:8px;padding:10px 15px;cursor:pointer;display:flex;flex-direction:column;align-items:center;gap:5px;transition:all .2s cubic-bezier(.4,0,.2,1);min-width:80px;text-decoration:none;color:inherit}.menu-btn:visited{color:inherit}.menu-btn:hover{background:#fff6;transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}.menu-btn:focus{outline:2px solid rgba(255,255,255,.5);outline-offset:2px}.menu-btn.exit-btn{background:#f003}.menu-btn.exit-btn:hover{background:#ff00004d}.menu-btn.quick-access-btn{background:#ffc1074d;min-width:60px}.menu-btn.quick-access-btn:hover{background:#ffc10780;transform:translateY(-2px)}.btn-icon{display:flex;align-items:center;justify-content:center;width:20px;height:20px}.btn-icon svg{width:100%;height:100%;color:currentColor}.btn-text{font-size:12px;color:#0f172a;text-align:center;line-height:1.2}.btn-text div{margin:2px 0}.main-container{display:flex;height:calc(100vh - 85px);margin-top:85px;overflow:hidden}.sidebar{width:320px;background:linear-gradient(180deg,#f8f9fa,#fff);border-right:1px solid #e8e8e8;display:flex;flex-direction:column;padding:60px 20px 25px 25px;box-shadow:2px 0 10px #00000008;overflow:hidden;z-index:10;position:relative;height:100%}.sidebar-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;flex-shrink:0}.sidebar-header h3{font-size:18px;color:#0f172a;font-weight:600}.btn-new-course{background:#1890ff;color:#fff;border:none;padding:6px 12px;border-radius:4px;cursor:pointer;font-size:14px;transition:all .2s cubic-bezier(.4,0,.2,1);font-weight:500}.btn-new-course:focus{outline:2px solid rgba(24,144,255,.5);outline-offset:2px}.btn-new-course:hover{background:#40a9ff}.course-list{flex:1;overflow-y:auto;overflow-x:hidden;min-height:0}.course-list::-webkit-scrollbar{width:0;display:none}.course-list{scrollbar-width:none;-ms-overflow-style:none}.course-list::-webkit-scrollbar-track{display:none}.course-list::-webkit-scrollbar-thumb{display:none}.course-list::-webkit-scrollbar-thumb:hover{display:none}.course-item{width:95%;padding:14px 16px;border:1px solid #e8e8e8;border-radius:10px;margin-bottom:12px;cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1);background:#fff;box-shadow:0 2px 8px #0000000a;position:relative}.course-item:hover{border-color:#667eea;background:linear-gradient(135deg,#f0f4ff,#faf5ff);transform:translate(5px);box-shadow:0 4px 12px #667eea26;z-index:3;position:relative}.course-item.active{border-color:#667eea;border-right:5px solid #667eea;background:linear-gradient(135deg,#e6f0ff,#f0e6ff);box-shadow:0 4px 15px #667eea40;transform:translate(8px);position:relative;z-index:5;margin-right:-8px;border-left:2px solid #667eea}.btn-delete-course{position:absolute;top:8px;right:8px;width:22px;height:22px;border-radius:50%;border:none;background:#ff4d4de6;color:#fff;cursor:pointer;display:none;align-items:center;justify-content:center;transition:all .2s cubic-bezier(.4,0,.2,1);z-index:10;box-shadow:0 2px 6px #ff4d4d66;padding:0;opacity:0}.btn-delete-course svg{width:14px;height:14px;stroke-width:2.5}.course-item:hover .btn-delete-course{display:flex;opacity:1}.btn-delete-course:hover{background:red;transform:scale(1.15);box-shadow:0 3px 10px #ff4d4d99}.btn-delete-course:active{transform:scale(.9)}.course-name{font-weight:600;color:#0f172a;margin-bottom:4px}.course-time{font-size:12px;color:#999}.course-status{font-size:11px;padding:2px 6px;border-radius:3px;margin-top:4px;display:inline-block}.course-status.pending{background:#fff7e6;color:#d46b08}.course-status.completed{background:#f6ffed;color:#52c41a}.sidebar-search{margin-bottom:15px;flex-shrink:0;display:flex;flex-direction:column;gap:10px}.search-input-group{position:relative;display:flex;align-items:center}.search-input{width:100%;padding:10px 35px 10px 12px;border:1px solid #e0e0e0;border-radius:8px;font-size:14px;transition:all .3s;background:#fff;box-sizing:border-box}.search-input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 2px #667eea1a}.search-icon{position:absolute;right:12px;display:flex;align-items:center;justify-content:center;pointer-events:none;color:#999}.search-icon svg{width:16px;height:16px}.btn-clear-search{background:#f5f5f5;border:1px solid #e0e0e0;color:#666;padding:8px 12px;border-radius:6px;cursor:pointer;font-size:14px;transition:all .3s;width:100%;font-weight:500}.btn-clear-search:hover{background:#e8e8e8;border-color:#d9d9d9;color:#333}.btn-clear-search:active{transform:scale(.98)}.content-area{flex:1;padding:60px 30px 25px;overflow-y:auto;overflow-x:hidden;background:transparent;position:relative;z-index:1;height:100%;min-height:0;scrollbar-width:none;-ms-overflow-style:none;display:flex;flex-direction:column;align-items:center}.content-area>*{width:90%;max-width:1400px}.content-area::-webkit-scrollbar{width:0;display:none}.content-header{margin-bottom:15px;padding-bottom:10px;border-bottom:2px solid #f0f0f0}.content-header h2{font-size:26px;color:#0f172a;font-weight:700;margin-bottom:0;letter-spacing:.5px}.course-info-section{background:#fafafa;padding:18px 25px;border-radius:10px;margin-bottom:15px;display:flex;justify-content:space-between;align-items:flex-end;box-shadow:0 2px 8px #0000000a;border:1px solid #e8e8e8}.info-inputs{display:flex;gap:25px;flex:1;flex-wrap:wrap}.input-group{display:flex;flex-direction:column;gap:8px}.input-group label{font-size:14px;color:#475569;font-weight:500}.input-group input{padding:10px 14px;border:1px solid #d9d9d9;border-radius:6px;font-size:14px;width:200px;transition:all .3s;background:#fff}.input-group input:focus{outline:none;border-color:#1890ff;box-shadow:0 0 0 2px #1890ff33}.time-input-wrapper{position:relative;display:flex;align-items:center;gap:8px}.time-range-group{width:auto}.time-range-wrapper{display:flex;align-items:center;gap:8px}.time-range-wrapper .time-input{flex:1;min-width:120px}.time-separator{color:#666;font-weight:500;font-size:14px;padding:0 4px}.btn-select-time{background:#1890ff;color:#fff;border:none;padding:10px 18px;border-radius:6px;cursor:pointer;font-size:14px;transition:all .3s;white-space:nowrap;font-weight:500;box-shadow:0 2px 4px #1890ff33}.btn-select-time:hover{background:#40a9ff;transform:translateY(-1px);box-shadow:0 4px 8px #1890ff4d}.time-input-wrapper .time-input{padding-right:35px}.time-icon{position:absolute;right:10px;top:50%;transform:translateY(-50%);pointer-events:none;font-size:16px}.info-buttons{display:flex;gap:10px}.btn-primary{background:#1890ff;color:#fff;border:none;padding:11px 24px;border-radius:6px;cursor:pointer;font-size:14px;transition:all .2s cubic-bezier(.4,0,.2,1);font-weight:500;box-shadow:0 2px 6px #1890ff40}.btn-primary:focus{outline:2px solid rgba(24,144,255,.5);outline-offset:2px}.btn-primary:hover{background:#40a9ff;transform:translateY(-2px);box-shadow:0 4px 12px #1890ff59}.btn-secondary{background:#fff;color:#333;border:1px solid #d9d9d9;padding:11px 24px;border-radius:6px;cursor:pointer;font-size:14px;transition:all .2s cubic-bezier(.4,0,.2,1);font-weight:500;box-shadow:0 2px 4px #0000000d}.btn-secondary:focus{outline:2px solid rgba(24,144,255,.5);outline-offset:2px}.btn-secondary:hover{border-color:#1890ff;color:#1890ff;transform:translateY(-1px);box-shadow:0 4px 8px #0000001a}.data-table-section{margin-bottom:15px;overflow-x:auto}.activity-table{width:100%;border-collapse:collapse;background:#fff;border:1px solid #e0e0e0}.activity-table thead{background:#fafafa}.activity-table th{padding:10px 12px;text-align:center;border:1px solid #e0e0e0;font-weight:600;color:#0f172a;font-size:14px}.activity-table td{padding:6px 8px;border:1px solid #e0e0e0;text-align:center}.row-label{background:#fafafa;font-weight:600;color:#0f172a;text-align:left;padding-left:15px;width:150px}.table-input{width:100%;padding:5px 8px;border:1px solid #d9d9d9;border-radius:4px;font-size:13px;text-align:center}.table-input:focus{outline:none;border-color:#1890ff}.readonly-field{color:#999;font-size:14px}.bottom-section{display:flex;flex-direction:column;gap:12px;padding:15px 20px;background:#fafafa;border-radius:8px;margin-top:15px}.bottom-controls{display:flex;justify-content:space-between;align-items:flex-end;gap:20px}.remark-section{padding:12px 15px;background:#fff9e6;border-left:4px solid #ffc107;border-radius:6px}.remark-text{margin:0;font-size:13px;color:#666;line-height:1.6}.heart-rate-inputs{display:flex;gap:20px;flex-wrap:wrap}.heart-rate-inputs .input-group input{width:150px}.action-buttons{display:flex;gap:10px;justify-content:flex-start;align-items:center}@media(max-width:1200px){.info-inputs{flex-wrap:wrap}.course-info-section{flex-direction:column;align-items:flex-start;gap:15px}.info-buttons{width:100%}}@media(max-width:768px){.main-container{flex-direction:column}.sidebar{width:100%;height:200px}.menu-buttons{flex-wrap:wrap}.menu-btn{min-width:60px;padding:8px 10px}}.page-content{display:none}.menu-btn.active{background:#fff9;box-shadow:0 2px 4px #00000026}.home-content{padding:25px 0;display:flex;gap:35px;align-items:stretch;max-height:calc(100vh - 195px);max-width:1400px;margin:0 auto;overflow:hidden}.home-main-section{flex:0 0 58%;min-width:0;display:flex;flex-direction:column;gap:20px;max-height:100%;overflow:hidden}.home-side-section{flex:1;flex-shrink:0;display:flex;flex-direction:column;max-height:100%;overflow:hidden}.home-page-content{margin-left:0!important;padding:60px 40px 30px!important}.course-management-card{background:linear-gradient(135deg,#ff6b9d,#c44569,#a55eea);padding:40px 35px;border-radius:20px;box-shadow:0 15px 50px #c5456959;color:#fff;height:100%;max-height:calc(100vh - 205px);display:flex;flex-direction:column;justify-content:space-between;position:relative;overflow:hidden}.course-management-card:before{content:"";position:absolute;top:-50%;right:-50%;width:200%;height:200%;background:radial-gradient(circle,rgba(255,255,255,.15) 0%,transparent 70%);animation:pulse 6s ease-in-out infinite}.card-header{text-align:center;position:relative;z-index:1;margin-bottom:25px}.card-header h3{font-size:26px;color:#fff;margin-bottom:8px;font-weight:700;display:flex;align-items:center;justify-content:center;gap:10px}.card-header h3:before{content:"";display:inline-block;width:30px;height:30px;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 24 24' stroke-width='1.5' stroke='white'%3E%3Cpath stroke-linecap='round' stroke-linejoin='round' d='M16.862 4.487l1.687-1.688a1.875 1.875 0 112.652 2.652L10.582 16.07a4.5 4.5 0 01-1.897 1.13L6 18l.8-2.685a4.5 4.5 0 011.13-1.897l8.932-8.931zm0 0L19.5 7.125M18 14v4.75A2.25 2.25 0 0115.75 21H5.25A2.25 2.25 0 013 18.75V8.25A2.25 2.25 0 015.25 6H10' /%3E%3C/svg%3E");background-size:contain;background-repeat:no-repeat;background-position:center;margin-right:10px;filter:drop-shadow(0 2px 4px rgba(0,0,0,.2))}.card-header p{color:#ffffffe6;font-size:14px;position:relative;z-index:1;font-weight:400}.management-stats{display:flex;align-items:center;justify-content:center;gap:20px;margin-bottom:30px;padding:25px 20px;border-radius:16px;background:#fff3;-webkit-backdrop-filter:blur(15px);backdrop-filter:blur(15px);border:1px solid rgba(255,255,255,.3);position:relative;z-index:1;box-shadow:0 4px 15px #0000001a}.management-stat-item{display:flex;flex-direction:column;align-items:center;gap:8px;flex:1;transition:all .2s cubic-bezier(.4,0,.2,1);cursor:pointer}.management-stat-item:hover{transform:scale(1.05);opacity:.9}.stat-icon{font-size:28px;opacity:1;filter:drop-shadow(0 2px 4px rgba(0,0,0,.2));margin-bottom:5px;display:flex;align-items:center;justify-content:center}.management-stat-item .stat-number{font-size:32px;font-weight:700;color:#fff;line-height:1;text-shadow:0 2px 10px rgba(0,0,0,.2)}.management-stat-item .stat-text{font-size:13px;color:#fffffff2;font-weight:500;letter-spacing:.5px}.stat-divider{width:2px;height:60px;background:#fff6;border-radius:2px}.recent-courses{margin-bottom:20px;position:relative;z-index:1;flex:1;min-height:0;overflow-y:auto;scrollbar-width:none;-ms-overflow-style:none}.recent-courses::-webkit-scrollbar{width:0;display:none}.section-title-small{font-size:14px;font-weight:600;color:#ffffffe6;margin-bottom:12px;text-align:left;letter-spacing:.5px}.recent-course-list{display:flex;flex-direction:column;gap:10px}.recent-course-item{background:#fff3;-webkit-backdrop-filter:blur(15px);backdrop-filter:blur(15px);padding:14px 16px;border-radius:12px;display:flex;justify-content:space-between;align-items:center;transition:all .2s cubic-bezier(.4,0,.2,1);cursor:pointer;border:1px solid rgba(255,255,255,.2);box-shadow:0 2px 8px #0000001a}.recent-course-item:hover{background:#ffffff4d;transform:translate(8px);box-shadow:0 4px 15px #00000026;border-color:#fff6}.recent-course-info{flex:1;text-align:left}.recent-course-name{font-size:14px;font-weight:600;color:#fff;margin-bottom:4px}.recent-course-time{font-size:12px;color:#fffc}.recent-course-status{padding:4px 10px;border-radius:12px;font-size:11px;font-weight:600}.recent-course-status.pending-small{background:linear-gradient(135deg,#ffc107,#ff9800);color:#fff;font-weight:600;box-shadow:0 2px 8px #ffc10766}.recent-course-status.completed-small{background:linear-gradient(135deg,#4caf50,#2e7d32);color:#fff;font-weight:600;box-shadow:0 2px 8px #4caf5066}.quick-actions{position:relative;z-index:1}.btn-full{width:100%;background:linear-gradient(135deg,#ffb3d9,#ff8cc8);color:#8b2252;font-weight:700;padding:16px 24px;border-radius:12px;transition:all .2s cubic-bezier(.4,0,.2,1);box-shadow:0 6px 20px #ff8cc866;border:none;font-size:16px;letter-spacing:.5px;text-decoration:none;display:flex;align-items:center;justify-content:center;gap:10px;margin-bottom:15px;cursor:pointer}.btn-full:focus{outline:2px solid rgba(139,34,82,.5);outline-offset:2px}.btn-full:hover{background:linear-gradient(135deg,#ffcce6,#ffb3d9);transform:translateY(-3px);box-shadow:0 8px 30px #ff8cc880}.action-buttons-row{display:flex;gap:8px}.btn-action{flex:1;background:#ffffff40;-webkit-backdrop-filter:blur(15px);backdrop-filter:blur(15px);border:1px solid rgba(255,255,255,.35);color:#fff;padding:12px 10px;border-radius:12px;font-size:13px;font-weight:600;cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1);display:flex;flex-direction:column;align-items:center;gap:6px;box-shadow:0 2px 10px #0000001a}.btn-action:focus{outline:2px solid rgba(255,255,255,.5);outline-offset:2px}.btn-action:hover{background:#ffffff59;transform:translateY(-3px);box-shadow:0 6px 20px #0003;border-color:#ffffff80}.btn-action:first-child{background:#64b5f64d;border-color:#64b5f680}.btn-action:first-child:hover{background:#64b5f666}.btn-action span:first-child{font-size:16px}.welcome-section{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:45px 50px;border-radius:16px;margin-bottom:0;flex:1;min-height:0;display:flex;flex-direction:column;justify-content:flex-start;box-shadow:0 10px 40px #667eea4d;position:relative;overflow:hidden}.welcome-section:before{content:"";position:absolute;top:-50%;right:-50%;width:200%;height:200%;background:radial-gradient(circle,rgba(255,255,255,.1) 0%,transparent 70%);animation:pulse 8s ease-in-out infinite}@keyframes pulse{0%,to{transform:scale(1);opacity:.5}50%{transform:scale(1.1);opacity:.8}}.welcome-section h3{font-size:32px;margin-bottom:15px;font-weight:700;line-height:1.3;position:relative;z-index:1}.welcome-section p{font-size:17px;margin-bottom:25px;opacity:.95;position:relative;z-index:1}.feature-list{list-style:none;padding:0;position:relative;z-index:1}.feature-list li{padding:14px 0;font-size:16px;border-bottom:1px solid rgba(255,255,255,.15);transition:all .2s cubic-bezier(.4,0,.2,1);display:flex;align-items:center;gap:12px;cursor:default}.feature-icon{width:20px;height:20px;flex-shrink:0;color:#fff;opacity:.9}.feature-list li:hover{background:#ffffff0d;border-radius:8px;margin:0 -10px;padding-left:20px;padding-right:10px}.feature-list li:last-child{border-bottom:none}.feature-list li:before{display:none}.quick-stats{display:flex;gap:20px;margin-top:auto;padding-top:30px}.stat-card{flex:1;background:#fff;padding:35px 25px;border-radius:16px;text-align:center;box-shadow:0 4px 20px #00000014;transition:all .2s cubic-bezier(.4,0,.2,1);border:1px solid rgba(0,0,0,.05);position:relative;overflow:hidden;cursor:default}.stat-card:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,#667eea,#764ba2);transform:scaleX(0);transition:transform .3s}.stat-card:hover{transform:translateY(-8px);box-shadow:0 8px 30px #667eea33}.stat-card:hover:before{transform:scaleX(1)}.stat-value{font-size:42px;font-weight:700;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:12px;line-height:1}.stat-label{font-size:15px;color:#666;font-weight:500;letter-spacing:.5px}.charts-section{display:flex;gap:20px;margin-top:15px}.chart-container{flex:1;background:#fff;padding:15px;border-radius:8px;box-shadow:0 2px 8px #0000001a}.chart-container h3{font-size:16px;margin-bottom:10px;color:#333}.chart-placeholder{width:100%;height:320px;background:#fff;border:none;border-radius:8px;display:flex;align-items:center;justify-content:center;color:#999;position:relative;padding:15px}.chart-placeholder canvas{max-width:100%;max-height:100%}.charts-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:20px;margin-top:20px}.chart-card{background:linear-gradient(135deg,#fff,#f8f9fa);padding:25px;border-radius:12px;box-shadow:0 4px 20px #00000014,0 2px 8px #0000000a;border:1px solid rgba(0,0,0,.05);transition:transform .2s ease,box-shadow .2s ease;cursor:default}.chart-card:hover{transform:translateY(-2px);box-shadow:0 6px 25px #0000001f,0 3px 10px #0000000f}.chart-card h3{font-size:18px;font-weight:600;color:#2c3e50;padding-bottom:12px;border-bottom:2px solid #e9ecef;margin-bottom:15px;color:#333;text-align:center}.energy-table-section{margin-bottom:20px}.energy-buttons{display:flex;gap:10px;margin-top:15px;justify-content:flex-start}.energy-table{width:100%;border-collapse:collapse;background:#fff;border:1px solid #e0e0e0}.energy-table th,.energy-table td{padding:12px;text-align:center;border:1px solid #e0e0e0}.energy-table thead{background:#fafafa}.energy-chart-section{background:#fff;padding:20px;border-radius:8px;box-shadow:0 2px 8px #0000001a}.energy-chart-section h3{font-size:18px;margin-bottom:20px;color:#333}.evaluation-table-section{margin-top:20px}.evaluation-table{width:100%;border-collapse:collapse;background:#fff;border:2px solid #333}.evaluation-table thead{background:#90ee90}.evaluation-table th,.evaluation-table td{padding:12px;text-align:center;border:1px solid #333;font-size:14px}.evaluation-table tbody tr:nth-child(2n){background:#f9f9f9}.total-score-cell{font-weight:700;font-size:32px;vertical-align:middle;text-align:center;padding:20px 15px;color:#333;width:120px}.analysis-note{text-align:center;margin-top:20px;font-size:16px;font-weight:600;color:#333}.theory-tabs{display:flex;gap:10px;margin-bottom:20px;border-bottom:2px solid #e0e0e0}.theory-tab{padding:10px 20px;background:#fff;border:none;border-bottom:2px solid transparent;cursor:pointer;font-size:14px;color:#666;transition:all .3s;margin-bottom:-2px}.theory-tab:hover{color:#1890ff}.theory-tab.active{color:#1890ff;border-bottom-color:#1890ff;font-weight:600}.theory-content{background:#fff;padding:20px;border-radius:8px}.section-title{color:#52c41a;font-size:18px;margin-bottom:15px;font-weight:600}.section-title-with-button{display:flex;justify-content:space-between;align-items:center;margin-bottom:15px}.section-title-with-button .section-title{margin-bottom:0;flex:1}.evaluation-standard{background:#f0f0f0;padding:10px;border-radius:4px;margin-bottom:20px;font-size:14px;color:#666}.theory-table{width:100%;border-collapse:collapse;background:#fff;border:1px solid #e0e0e0;margin-bottom:30px}.theory-table thead{background:#fafafa}.theory-table th,.theory-table td{padding:15px;border:1px solid #e0e0e0;text-align:center;vertical-align:middle}.theory-table th{text-align:center;font-weight:600;background:#fafafa}.theory-table td:nth-child(2),.theory-table td:nth-child(3){text-align:center;width:100px}.theory-table input[type=number]{width:60px;padding:6px;border:1px solid #d9d9d9;border-radius:4px;text-align:center}.star-rating{display:flex;gap:5px;justify-content:center;align-items:center}.star{font-size:24px;color:#d9d9d9;cursor:pointer;transition:color .2s,transform .2s;-webkit-user-select:none;user-select:none}.star:hover{transform:scale(1.1)}.star.active,.star-rating:hover .star{color:#ffc107}.star-rating .star:hover~.star{color:#d9d9d9}.theory-chart-section{margin-top:30px}.calculated{background:#fffacd!important;color:#d46b08!important;font-weight:600;text-align:center}.table-input.calculated{background:#fffacd!important;color:#d46b08!important;font-weight:600;border-color:#ffc107}input[readonly]{background:#f5f5f5;cursor:not-allowed}.readonly-display{background:#f9f9f9!important;color:#333!important;cursor:default!important;border-color:#e0e0e0!important}.readonly-data{background:#f5f5f5!important;color:#666!important;cursor:not-allowed!important}.course-record-section{margin:15px 0}.record-table-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px;padding-bottom:8px;border-bottom:2px solid #f0f0f0}.record-table-header .section-title{font-size:18px;color:#333;font-weight:600;margin:0}.btn-add-row,.btn-add-column{background:#1890ff;color:#fff;border:none;padding:10px 20px;border-radius:6px;cursor:pointer;font-size:14px;transition:all .3s;font-weight:500;box-shadow:0 2px 6px #1890ff40}.btn-add-row:hover,.btn-add-column:hover{background:#40a9ff;transform:translateY(-2px);box-shadow:0 4px 12px #1890ff59}.vertical-table-wrapper{overflow:visible}.vertical-record-table{width:100%;border-collapse:collapse;background:#fff;border:1px solid #e0e0e0;border-radius:10px;overflow:hidden;box-shadow:0 2px 8px #0000000a}.vertical-record-table thead{background:linear-gradient(135deg,#f8f9fa,#f0f0f0)}.vertical-record-table thead th{padding:12px 20px;text-align:center;font-weight:600;color:#333;border-bottom:2px solid #e0e0e0}.vertical-record-table tbody tr{border-bottom:1px solid #e8e8e8;transition:background .3s}.vertical-record-table tbody tr:hover{background:#fafafa}.vertical-record-table tbody tr:last-child{border-bottom:none}.vertical-record-table td{padding:18px 20px;text-align:center;vertical-align:middle}.vertical-record-table .name-cell{width:50%;text-align:center}.vertical-record-table .time-cell{width:30%;text-align:center}.vertical-record-table .action-cell{width:20%;text-align:center;vertical-align:middle;padding:15px 10px}.vertical-record-table .name-input,.vertical-record-table .time-input-cell{width:100%;padding:8px 12px;border:1px solid #d9d9d9;border-radius:6px;font-size:14px;text-align:center;transition:all .3s}.vertical-record-table .name-input:focus,.vertical-record-table .time-input-cell:focus{outline:none;border-color:#1890ff;box-shadow:0 0 0 2px #1890ff33}.action-buttons-wrapper{display:flex;flex-direction:row;align-items:center;justify-content:center;gap:6px;width:100%}.btn-move{background:#1890ff;color:#fff;border:none;flex:1;min-width:32px;height:28px;border-radius:4px;cursor:pointer;font-size:16px;line-height:1;padding:0;display:flex;align-items:center;justify-content:center;transition:all .3s;font-weight:700}.btn-move:hover:not(:disabled){background:#40a9ff;transform:scale(1.1);box-shadow:0 2px 8px #1890ff66}.btn-move:disabled{opacity:.3;cursor:not-allowed}.delete-link{color:#ff4d4f;font-size:13px;font-weight:500;transition:all .3s;-webkit-user-select:none;user-select:none;cursor:pointer;padding:4px 8px;border-radius:4px;flex:1;text-align:center;min-width:40px}.delete-link:hover{color:#ff7875;background:#ff4d4f1a}.vertical-record-table .total-name{color:#d46b08;font-weight:700;font-size:16px}.vertical-record-table .total-row{background:#fffacd;font-weight:600}.vertical-record-table .total-name{color:#d46b08;font-size:16px}.vertical-record-table .total-time-cell .total-time{background:transparent;color:#d46b08;font-weight:700;font-size:16px;border:none;text-align:center}.btn-delete-row{background:#ff4d4f;color:#fff;border:none;width:32px;height:32px;border-radius:50%;cursor:pointer;font-size:20px;line-height:1;padding:0;display:inline-flex;align-items:center;justify-content:center;transition:all .3s;font-weight:700}.btn-delete-row:hover{background:#ff7875;transform:scale(1.15);box-shadow:0 4px 12px #ff4d4f80}.btn-delete-row:active{transform:scale(1.05)}.course-record-table{width:100%;border-collapse:collapse;background:#fff;border:1px solid #e0e0e0}.course-record-table thead{background:#fafafa}.course-record-table th{padding:12px;text-align:center;border:1px solid #e0e0e0;font-weight:600;color:#333;font-size:14px}.course-record-table .total-header{background:#fffacd;color:#d46b08;font-weight:700;position:relative}.course-record-table .editable-header{position:relative;cursor:text;min-width:100px;padding:12px 30px 12px 12px}.course-record-table .editable-header:focus{outline:2px solid #1890ff;outline-offset:-2px;background:#f0f7ff}.btn-delete-column{position:absolute;right:5px;top:50%;transform:translateY(-50%);background:#ff4d4f;color:#fff;border:none;width:20px;height:20px;border-radius:50%;cursor:pointer;font-size:16px;line-height:1;padding:0;display:flex;align-items:center;justify-content:center;transition:all .3s}.btn-delete-column:hover{background:#ff7875;transform:translateY(-50%) scale(1.1)}.course-record-table td{padding:8px;border:1px solid #e0e0e0;text-align:center}.course-record-table .calculated{background:#fffacd!important;color:#d46b08;font-weight:600}.heart-rate-section{margin-top:20px;padding:20px;background:#fafafa;border-radius:8px;display:flex;justify-content:space-between;align-items:flex-end}.main-timer{display:flex;align-items:center;gap:10px;padding:10px 20px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border-radius:8px;font-size:18px;font-weight:700;box-shadow:0 2px 8px #00000026}.timer-label{font-size:16px}.timer-display{font-size:24px;font-family:Courier New,monospace;letter-spacing:2px}.content-header{display:flex;justify-content:space-between;align-items:center}.module-timers-section{margin-top:30px;padding:20px;background:#f9f9f9;border-radius:8px}.module-timers-section h4{margin-bottom:15px;color:#333;font-size:18px}.module-timers-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:15px}.module-timer-item{background:#fff;padding:15px;border-radius:8px;border:1px solid #e0e0e0;box-shadow:0 2px 4px #0000000d}.module-timer-header{margin-bottom:10px}.module-name{font-weight:600;color:#333;font-size:16px}.module-timer-display{font-size:20px;font-family:Courier New,monospace;color:#667eea;font-weight:700;text-align:center;padding:10px;background:#f5f5f5;border-radius:4px;margin:10px 0}.module-timer-controls{display:flex;gap:10px;justify-content:center}.btn-timer-start,.btn-timer-stop{padding:8px 20px;border:none;border-radius:4px;cursor:pointer;font-size:14px;transition:all .3s}.btn-timer-start{background:#52c41a;color:#fff}.btn-timer-start:hover{background:#73d13d}.btn-timer-stop{background:#ff4d4f;color:#fff}.btn-timer-stop:hover{background:#ff7875}.module-timer-row{background:#f9f9f9}.module-timer-row td{padding:10px 8px;vertical-align:middle}.module-timer-cell{text-align:center}.module-timer-inline{display:flex;align-items:center;justify-content:center;gap:8px}.module-timer-display-inline{font-family:Courier New,monospace;font-size:16px;font-weight:700;color:#667eea;min-width:50px;text-align:center}.btn-timer-toggle{width:32px;height:32px;border:none;border-radius:50%;background:#52c41a;color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .3s;padding:0;font-size:14px}.btn-timer-toggle:hover{background:#73d13d;transform:scale(1.1)}.btn-timer-toggle .timer-icon{display:inline-block;line-height:1}.module-timer-cell[data-module] .btn-timer-toggle.running{background:#ff4d4f}.module-timer-cell[data-module] .btn-timer-toggle.running:hover{background:#ff7875}.active-course-section{margin-bottom:30px;padding:20px;background:#f9f9f9;border-radius:8px}.active-course-list{margin-top:15px}.active-course-card{display:flex;justify-content:space-between;align-items:center;padding:15px;background:#fff;border-radius:8px;border:1px solid #e0e0e0;margin-bottom:10px;box-shadow:0 2px 4px #0000000d}.active-course-info h4{margin-bottom:5px;color:#333}.active-course-info p{margin:3px 0;color:#666;font-size:14px}.course-status{color:#52c41a;font-weight:600}.no-active-course{text-align:center;color:#999;padding:20px}.btn-start-course{margin-left:10px}.voice-control-section{margin-bottom:30px;padding:20px;background:#f9f9f9;border-radius:8px}.voice-switch{display:flex;flex-direction:column;gap:10px}.switch-label{display:flex;align-items:center;gap:10px;font-size:16px;font-weight:600;cursor:pointer}.switch-label input[type=checkbox]{width:20px;height:20px;cursor:pointer}.switch-hint{color:#666;font-size:14px;margin-left:30px}.voice-config-section{margin-bottom:30px}.config-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:15px}.voice-config-table-wrapper{overflow-x:auto}.voice-config-table{width:100%;border-collapse:collapse;background:#fff;border-radius:8px;overflow:hidden}.voice-config-table th{background:#f5f5f5;padding:12px;text-align:left;font-weight:600;border-bottom:2px solid #e0e0e0}.voice-config-table td{padding:12px;border-bottom:1px solid #e0e0e0}.config-input,.config-select{width:100%;padding:8px;border:1px solid #d9d9d9;border-radius:4px;font-size:14px}.config-input:focus,.config-select:focus{outline:none;border-color:#667eea}.no-data{text-align:center;color:#999;padding:20px}.preset-commands-section{margin-bottom:30px}.preset-commands-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:15px;margin-top:15px}.preset-command-card{display:flex;justify-content:space-between;align-items:center;padding:15px;background:#fff;border-radius:8px;border:1px solid #e0e0e0;box-shadow:0 2px 4px #0000000d}.preset-command-info{flex:1}.preset-trigger{font-weight:600;color:#333;margin-bottom:5px}.preset-action{color:#666;font-size:14px}.config-actions{display:flex;gap:10px;justify-content:center;padding:20px 0}.btn-sm{padding:6px 12px;font-size:14px}.btn-danger{background:#ff4d4f;color:#fff;border:none}.btn-danger:hover{background:#ff7875}.running-course-info{padding:15px}.running-course-card{background:#fff;padding:20px;border-radius:8px;border:1px solid #e0e0e0;box-shadow:0 2px 4px #0000000d}.course-info-item{display:flex;margin-bottom:12px;font-size:14px}.course-info-item:last-child{margin-bottom:0}.course-info-item .label{color:#666;min-width:80px;font-weight:500}.course-info-item .value{color:#333;flex:1}.status-running{color:#52c41a;font-weight:600}.no-running-course{text-align:center;padding:40px 20px;color:#999}.no-running-course p{margin-bottom:15px}.voice-recognition-section{margin-top:20px;padding:15px;background:#fff;border-radius:8px;border:1px solid #e0e0e0}.voice-recognition-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:15px;padding-bottom:10px;border-bottom:1px solid #f0f0f0}.voice-recognition-header h4{margin:0;font-size:16px;color:#333}.btn-voice-toggle{padding:6px 12px;border:1px solid #d9d9d9;border-radius:4px;background:#fff;cursor:pointer;font-size:12px;transition:all .3s;z-index:10;position:relative}.btn-voice-toggle:hover{border-color:#667eea;color:#667eea}.voice-status{font-weight:600}.voice-recognition-status{margin-bottom:15px}.voice-indicator{display:flex;align-items:center;gap:10px;margin-bottom:10px;font-size:14px;color:#666}.voice-dot{width:10px;height:10px;border-radius:50%;background:#d9d9d9;display:inline-block}.voice-dot.active{background:#52c41a;box-shadow:0 0 8px #52c41a99}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.7;transform:scale(1.1)}}.voice-last-command{display:flex;align-items:center;gap:8px;font-size:13px;padding:8px;background:#f5f5f5;border-radius:4px}.voice-last-command .label{color:#999}.command-text{color:#333;font-weight:500;flex:1}.voice-actions{display:flex;gap:10px}.config-description{margin-bottom:20px;padding:15px;background:#f0f7ff;border-left:4px solid #667eea;border-radius:4px}.config-description p{margin:5px 0;color:#666;font-size:14px;line-height:1.6}.config-description p:first-child{margin-top:0}.config-description p:last-child{margin-bottom:0}.voice-records-section{margin-top:20px;padding:15px;background:#fff;border-radius:8px;border:1px solid #e0e0e0;max-height:400px;display:flex;flex-direction:column}.voice-records-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:15px;padding-bottom:10px;border-bottom:1px solid #f0f0f0}.voice-records-header h4{margin:0;font-size:16px;color:#333}.btn-clear-records{padding:4px 10px;font-size:12px;background:#f5f5f5;border:1px solid #d9d9d9;border-radius:4px;cursor:pointer;color:#666}.btn-clear-records:hover{background:#e6f7ff;border-color:#91d5ff;color:#1890ff}.voice-records-list{flex:1;overflow-y:auto;max-height:350px}.voice-record-item{padding:10px;margin-bottom:10px;background:#f9f9f9;border-radius:4px;border-left:3px solid #667eea}.voice-record-item:last-child{margin-bottom:0}.record-time{font-size:11px;color:#999;margin-bottom:6px}.record-content{display:flex;flex-direction:column;gap:4px}.record-command,.record-action{display:flex;align-items:flex-start;font-size:13px;line-height:1.5;margin-top:4px}.record-text-full{color:#333;font-size:14px;line-height:1.6;word-break:break-word;padding:8px;background:#f0f7ff;border-radius:4px;border-left:3px solid #667eea}.record-label{color:#666;min-width:60px;font-weight:500}.record-text{color:#333;flex:1;word-break:break-word}.no-records{text-align:center;padding:30px 20px;color:#999;font-size:14px}.voice-execution-section{margin-top:20px;padding:15px;background:#fff;border-radius:8px;border:1px solid #e8e8e8}.voice-execution-list{max-height:300px;overflow-y:auto}.voice-execution-item{padding:10px;margin-bottom:10px;background:#f9f9f9;border-radius:4px;border-left:3px solid #667eea}.voice-execution-item.exec-success{border-left-color:#52c41a;background:#f6ffed}.voice-execution-item.exec-warning{border-left-color:#faad14;background:#fffbe6}.voice-execution-item.exec-error{border-left-color:#ff4d4f;background:#fff1f0}.voice-execution-item.exec-info{border-left-color:#1890ff;background:#e6f7ff}.exec-time{font-size:11px;color:#999;margin-bottom:6px}.exec-content{display:flex;flex-direction:column;gap:4px}.exec-command{color:#333;font-size:13px;font-weight:500}.exec-result{color:#666;font-size:12px}.permission-help{margin-top:10px;padding:10px;background:#fff7e6;border:1px solid #ffd591;border-radius:4px}.help-text{margin:0 0 5px;color:#d46b08;font-weight:600;font-size:13px}.help-steps{margin:0;color:#666;font-size:12px;line-height:1.5}:root{--ui-blue: #3267f6;--ui-blue-2: #6a5cff;--ui-purple: #7b61ff;--ui-cyan: #64d7ee;--ui-green: #25c276;--ui-red: #f05261;--ui-orange: #f7a935;--ui-ink: #111b34;--ui-text: #2b3550;--ui-muted: #7a849b;--ui-line: #e7ecf6;--ui-bg: #f6f9ff;--ui-card: rgba(255, 255, 255, .92);--ui-radius-lg: 22px;--ui-premium-shadow: 0 22px 48px rgba(23, 53, 112, .12);--ui-shadow: 0 18px 45px rgba(28, 56, 120, .1);--ui-soft-shadow: 0 8px 24px rgba(28, 56, 120, .08)}html,body,#app{min-height:100%}body{overflow:hidden;background:radial-gradient(circle at 12% 8%,rgba(98,135,255,.18),transparent 34%),radial-gradient(circle at 88% 6%,rgba(100,215,238,.16),transparent 30%),linear-gradient(180deg,#f7fbff,#f3f7ff);color:var(--ui-ink)}button,input,select{font:inherit}.app-shell{height:100vh;padding:16px 16px 18px;overflow:hidden}.top-menu{position:static;height:44px;min-height:44px;padding:0 2px 12px;background:transparent;box-shadow:none;display:flex;align-items:center;justify-content:space-between;gap:20px}.page-title-block{display:flex;align-items:baseline;gap:10px;min-width:0}.page-no{color:var(--ui-blue);font-size:28px;line-height:1;font-weight:400}.page-title-block h1{color:var(--ui-ink);font-size:22px;line-height:1;font-weight:400;letter-spacing:0}.page-title-divider,.page-subtitle{color:var(--ui-text);font-size:15px;font-weight:600}.top-meta{display:flex;align-items:center;gap:14px;color:#4f5a72;font-size:12px;white-space:nowrap}.top-icon-button{position:relative;width:30px;height:30px;border:0;background:transparent;color:#52617b;cursor:pointer}.top-icon-button svg{width:20px;height:20px}.notification-dot{position:absolute;top:4px;right:6px;width:7px;height:7px;border:1px solid #fff;border-radius:999px;background:var(--ui-red)}.user-menu-wrap{position:relative}.user-chip{display:inline-flex;align-items:center;gap:8px;border:0;background:transparent;color:var(--ui-ink);cursor:pointer;font-weight:700}.user-chip svg{width:14px;height:14px}.avatar{display:grid;place-items:center;width:26px;height:26px;border-radius:50%;background:linear-gradient(135deg,#d9e8ff,#edf4ff);color:var(--ui-blue);font-size:12px;font-weight:800;box-shadow:inset 0 0 0 1px #3267f629}.main-container{height:calc(100vh - 78px);margin-top:0;overflow:hidden;display:flex;border:1.5px solid rgba(50,103,246,.72);border-radius:14px;background:#ffffffb8;box-shadow:var(--ui-shadow)}.app-rail{width:48px;flex:0 0 48px;display:flex;flex-direction:column;align-items:center;padding:0 0 14px;border-right:1px solid var(--ui-line);background:#ffffffc7}.avatar.large{width:38px;height:38px;font-size:15px}.user-menu-panel{position:absolute;top:calc(100% + 12px);right:0;z-index:1800;width:238px;padding:10px;border:1px solid rgba(210,220,240,.96);border-radius:12px;background:#fffffffa;box-shadow:0 24px 60px #0f172a2e}.user-menu-panel:before{position:absolute;top:-6px;right:22px;width:12px;height:12px;border-top:1px solid rgba(210,220,240,.96);border-left:1px solid rgba(210,220,240,.96);background:#fff;content:"";transform:rotate(45deg)}.user-menu-profile{display:flex;align-items:center;gap:10px;padding:8px 8px 12px;border-bottom:1px solid var(--ui-line)}.user-menu-profile strong,.user-menu-profile small{display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.user-menu-profile strong{color:var(--ui-ink);font-size:14px;font-weight:400}.user-menu-profile small{margin-top:4px;color:var(--ui-muted);font-size:12px;font-weight:700}.user-menu-panel button{display:flex;width:100%;min-height:36px;align-items:center;justify-content:flex-start;margin-top:6px;padding:0 10px;border:0;border-radius:8px;background:transparent;color:var(--ui-ink);cursor:pointer;font-size:13px;font-weight:800}.user-menu-panel button:hover{background:#f2f6ff;color:var(--ui-blue)}.user-menu-panel button.danger{color:#dc2626}.user-menu-panel button.danger:hover{background:#fef2f2;color:#b91c1c}.notice-rail{width:128px;flex:0 0 128px;align-items:stretch;padding:0 10px 14px;background:linear-gradient(180deg,#ffffffeb,#f7faffe6)}.notice-rail-brand{width:100%;height:64px;border-radius:16px}.notice-rail-section{display:flex;flex-direction:column;gap:10px;padding-top:16px}.notice-rail-label{padding:0 8px;color:#7a88a3;font-size:12px;font-weight:800}.notice-rail-link{width:100%;height:42px;padding:0 10px;grid-template-columns:8px 18px minmax(0,1fr);gap:10px;justify-items:start;border-radius:12px}.notice-rail-dot{width:6px;height:6px;border-radius:50%;background:#c8d2e8}.notice-rail-link span:last-child{color:#617087;font-size:12px;font-weight:800;white-space:nowrap}.notice-rail-link.active .notice-rail-dot,.notice-rail-link:hover .notice-rail-dot{background:#2f67ff}.rail-brand{display:grid;place-items:center;width:48px;height:54px;border-radius:12px 12px 6px 6px;background:linear-gradient(180deg,#3267f6,#5d8aff);box-shadow:0 10px 26px #3267f652}.brand-orbit{width:23px;height:23px;border:3px solid #fff;border-radius:50%;position:relative}.brand-orbit:before,.brand-orbit:after{content:"";position:absolute;border-radius:50%;background:#fff}.brand-orbit:before{width:6px;height:6px;top:5px;left:5px}.brand-orbit:after{width:20px;height:3px;left:-2px;top:9px;transform:rotate(62deg)}.rail-nav{display:flex;flex-direction:column;align-items:center;gap:10px;width:100%;padding-top:18px}.rail-link{display:grid;place-items:center;width:34px;height:34px;border-radius:10px;color:#66728b;text-decoration:none;transition:all .18s ease}.rail-link svg{width:17px;height:17px}.rail-link:hover,.rail-link.active{background:linear-gradient(135deg,#3267f61f,#7b61ff24);color:var(--ui-blue);box-shadow:inset 0 0 0 1px #3267f61f}.rail-settings{margin-top:auto}.sidebar{width:220px;flex:0 0 220px;height:100%;padding:18px 14px;border-right:1px solid var(--ui-line);background:#ffffff9e;box-shadow:none}.sidebar-header{margin-bottom:14px}.sidebar-header h3{font-size:16px;font-weight:400;color:var(--ui-ink)}.btn-new-course,.btn-primary,.btn-add-row,.btn-start-course{border:0;border-radius:8px;background:linear-gradient(135deg,var(--ui-blue),var(--ui-blue-2));color:#fff;box-shadow:0 10px 20px #3267f633;font-weight:750}.btn-new-course:hover,.btn-primary:hover,.btn-add-row:hover,.btn-start-course:hover{background:linear-gradient(135deg,#225af0,#6555f8);transform:translateY(-1px)}.btn-secondary,.btn-action,.btn-reset{border:1px solid var(--ui-line);border-radius:8px;background:#fff;color:var(--ui-text)}.sidebar-search{margin-bottom:14px}.search-input,input,select,textarea,.table-input,.name-input,.time-input-cell,.readonly-display{border:1px solid #dfe5f0;border-radius:8px;background:#fff;color:var(--ui-ink);outline:none;transition:border-color .18s ease,box-shadow .18s ease}.search-input:focus,input:focus,select:focus,textarea:focus,.table-input:focus,.name-input:focus,.time-input-cell:focus{border-color:#3267f68c;box-shadow:0 0 0 3px #3267f61a}.course-list{padding:2px 2px 12px}.course-item{width:100%;min-height:92px;margin-bottom:12px;padding:14px 14px 12px;border:1px solid #e2e8f4;border-radius:10px;background:#fff;box-shadow:0 8px 18px #1c38780d}.course-item:hover,.course-item.active{border-color:#3267f6b8;background:linear-gradient(135deg,#f4f7fff5,#fffffffa);box-shadow:0 12px 26px #3267f61f;transform:translate(0)}.course-name{color:var(--ui-ink);font-size:14px;font-weight:400}.course-time{margin-top:7px;color:var(--ui-muted);font-size:12px}.course-status,.recent-course-status{display:inline-flex;align-items:center;height:20px;margin-top:7px;padding:0 7px;border-radius:6px;font-size:11px;font-weight:800}.course-status.pending,.pending-small{background:#e9f2ff;color:var(--ui-blue)}.course-status.completed,.completed-small,.status-running{background:#e8f8ef;color:var(--ui-green)}.content-area{flex:1;min-width:0;height:100%;padding:20px 24px;background:linear-gradient(90deg,#f8fbffc7,#ffffffe6),var(--ui-bg);overflow:auto}.full-width-content{padding:20px 24px}.home-page-content{display:block;padding:20px 24px}.dashboard-page,.course-management-page,.voice-control-section,.voice-config-section,.preset-commands-section,.theory-content{max-width:1180px;margin:0 auto}.dashboard-page{width:100%}.content-area>*{max-width:none}.professional-page{width:min(100%,1220px);margin:0 auto;display:flex;flex-direction:column;gap:14px;color:var(--ui-ink)}.professional-page-hero{display:flex;align-items:center;justify-content:space-between;gap:20px;min-height:92px;padding:20px 22px;border:1px solid rgba(210,220,240,.88);border-radius:10px;background:linear-gradient(135deg,#fffffffa,#f7fafff5),linear-gradient(90deg,#3267f61a,#64d7ee14);box-shadow:var(--ui-soft-shadow)}.professional-page-hero:after{content:"";position:absolute;right:18px;bottom:0;width:120px;height:120px;border-radius:50%;background:radial-gradient(circle,#3267f624,#3267f600 72%);pointer-events:none}.professional-page-hero h2{margin:5px 0 6px;color:var(--ui-ink);font-size:24px;line-height:1.15;font-weight:400;letter-spacing:0}.professional-page-hero p{max-width:640px;color:var(--ui-muted);font-size:13px;line-height:1.65}.professional-kicker{display:block;color:var(--ui-blue);font-size:12px;line-height:1;font-weight:400}.professional-metric-strip{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px}.professional-metric-strip article{min-width:0;min-height:78px;padding:14px 16px;border:1px solid var(--ui-line);border-radius:10px;background:#fff;box-shadow:0 8px 18px #1c38780d}.professional-metric-strip span,.professional-metric-strip em{display:block;overflow:hidden;color:var(--ui-muted);font-size:12px;line-height:1.35;font-style:normal;font-weight:800;text-overflow:ellipsis;white-space:nowrap}.professional-metric-strip strong{display:block;overflow:hidden;margin:6px 0 4px;color:var(--ui-ink);font-size:26px;line-height:1;font-weight:950;text-overflow:ellipsis;white-space:nowrap}.professional-metric-strip article:nth-child(1) strong{color:var(--ui-blue)}.professional-metric-strip article:nth-child(2) strong{color:var(--ui-green)}.professional-metric-strip article:nth-child(3) strong{color:var(--ui-purple)}.professional-metric-strip article:nth-child(4) strong{color:var(--ui-orange)}.professional-panel{border:1px solid var(--ui-line);border-radius:10px;background:#fffffff5;box-shadow:var(--ui-soft-shadow)}.professional-chart-grid{margin-top:0}.professional-timer{flex:0 0 auto;min-width:176px;padding:10px 14px;border:1px solid rgba(50,103,246,.18);border-radius:10px;background:#fff;text-align:right;box-shadow:0 8px 18px #1c38780f}.professional-timer .timer-label{display:block;margin-bottom:4px;color:var(--ui-muted);font-size:12px;font-weight:800}.professional-timer .timer-display{color:var(--ui-blue);font-size:28px;line-height:1;font-weight:950}.content-header{margin:0 0 16px;padding:0 0 12px;border-bottom:1px solid var(--ui-line);background:transparent;box-shadow:none}.content-header h2{color:var(--ui-ink);font-size:22px;font-weight:400}.course-info-section,.course-record-section,.bottom-section,.charts-section,.charts-grid,.energy-table-section,.energy-chart-section,.evaluation-table-section,.theory-content,.voice-control-section,.voice-config-section,.preset-commands-section,.course-management-card,.welcome-section,.quick-stats,.home-main-section,.home-side-section{border:1px solid var(--ui-line);border-radius:10px;background:var(--ui-card);box-shadow:var(--ui-soft-shadow)}.course-info-section,.course-record-section,.energy-table-section,.energy-chart-section,.evaluation-table-section,.theory-content,.voice-control-section,.voice-config-section,.preset-commands-section{padding:18px}.record-table-header,.config-header,.section-title-with-button{border-bottom:1px solid var(--ui-line);padding-bottom:12px}.section-title,.record-table-header .section-title,.chart-container h3,.chart-card h3,.energy-chart-section h3,.card-header h3{color:var(--ui-ink);font-size:16px;font-weight:400}table,.activity-table,.energy-table,.evaluation-table,.theory-table,.vertical-record-table,.course-record-table,.voice-config-table{width:100%;border-collapse:collapse;border-radius:10px;overflow:hidden;background:#fff}thead,.activity-table thead,.energy-table thead,.evaluation-table thead,.theory-table thead,.vertical-record-table thead,.course-record-table thead{background:linear-gradient(180deg,#fbfcff,#f4f7fc)}th,td,.activity-table th,.activity-table td,.energy-table th,.energy-table td,.evaluation-table th,.evaluation-table td,.theory-table th,.theory-table td,.vertical-record-table td,.course-record-table td,.voice-config-table td{border-color:var(--ui-line);color:var(--ui-ink)}.table-input.calculated{border-color:#7b61ff57;background:#f4f1ff;color:#344ee4;font-weight:400}.charts-section,.charts-grid{padding:0;border:0;background:transparent;box-shadow:none}.charts-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:14px;margin-top:14px}.charts-section{gap:14px}.chart-container,.chart-card{border:1px solid var(--ui-line);border-radius:10px;background:#fff;box-shadow:var(--ui-soft-shadow)}.chart-card{min-height:374px;padding:18px}.chart-container{padding:18px}.chart-card h3,.chart-container h3,.energy-chart-section h3,.theory-chart-section .section-title{margin:0 0 10px;padding-bottom:10px;border-bottom:1px solid rgba(231,236,246,.95);line-height:1.35;text-align:left}.chart-placeholder{height:286px;padding:8px 10px;overflow:hidden;border-radius:8px;background:linear-gradient(180deg,#fffffff5,#f8fbfff5),repeating-linear-gradient(0deg,rgba(231,236,246,.42) 0,rgba(231,236,246,.42) 1px,transparent 1px,transparent 56px)}.chart-placeholder canvas{width:100%!important;height:100%!important}.energy-chart-section .chart-placeholder{height:320px}.theory-chart-section .chart-placeholder{height:260px}.chart-card:hover,.chart-container:hover,.energy-chart-section:hover,.theory-chart-section:hover{box-shadow:0 12px 30px #1c38781a}.stat-card,.management-stat-item,.recent-course-item,.preset-command-card{border:1px solid var(--ui-line);border-radius:10px;background:#fff;box-shadow:0 8px 18px #1c38780d}.stat-value,.stat-number{color:var(--ui-ink)}.star.active{color:var(--ui-purple)}@media(max-width:1180px){.app-shell{padding:10px}.top-meta{display:none}.sidebar{width:200px;flex-basis:200px}}.dashboard-page{display:flex;flex-direction:column;gap:14px}.dashboard-welcome{display:flex;align-items:center;justify-content:space-between;min-height:66px}.dashboard-welcome h2{margin-bottom:8px;color:var(--ui-ink);font-size:20px;font-weight:400}.dashboard-welcome p{color:var(--ui-muted);font-size:13px}.dashboard-stats{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:14px}.metric-card{display:flex;align-items:center;gap:14px;min-height:88px;padding:18px;border:1px solid var(--ui-line);border-radius:10px;background:#fff;box-shadow:var(--ui-soft-shadow)}.metric-icon,.recent-icon,.doc-icon{display:grid;place-items:center;flex:0 0 auto;width:34px;height:34px;border-radius:9px;background:#eef5ff;color:var(--ui-blue)}.metric-icon svg,.recent-icon svg,.doc-icon svg{width:18px;height:18px}.metric-card p{margin-bottom:6px;color:var(--ui-text);font-size:13px;font-weight:700}.metric-card strong{display:block;color:var(--ui-ink);font-size:25px;font-weight:400}.metric-card small{color:var(--ui-muted);font-size:12px;font-weight:650}.dashboard-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:14px}.dashboard-card{min-height:190px;padding:18px;border:1px solid var(--ui-line);border-radius:10px;background:#fff;box-shadow:var(--ui-soft-shadow)}.dashboard-card h3,.card-title-row h3{color:var(--ui-ink);font-size:16px;font-weight:400}.card-title-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}.card-title-row button{border:0;background:transparent;color:var(--ui-blue);font-size:12px;font-weight:800;cursor:pointer}.recent-list{display:flex;flex-direction:column;gap:10px}.recent-row{display:grid;grid-template-columns:34px minmax(0,1fr) auto;align-items:center;gap:12px;width:100%;padding:10px;border:0;border-radius:9px;background:#fbfcff;text-align:left;cursor:pointer}.recent-row strong,.course-cell strong{display:block;color:var(--ui-ink);font-size:13px;font-weight:400}.recent-row small,.course-cell small,.management-table td small{display:block;margin-top:4px;color:var(--ui-muted);font-size:12px}.recent-row em,.status-pill{display:inline-flex;align-items:center;height:22px;padding:0 9px;border-radius:7px;font-size:12px;font-style:normal;font-weight:800}.recent-row em.blue,.status-pill.running{background:#e8f1ff;color:var(--ui-blue)}.recent-row em.green,.status-pill.done{background:#e8f8ef;color:var(--ui-green)}.quick-action-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px;margin-top:16px}.quick-action-grid button{display:flex;min-height:70px;flex-direction:column;align-items:center;justify-content:center;gap:8px;border:1px solid var(--ui-line);border-radius:9px;background:linear-gradient(180deg,#fbfdff,#f7fbff);color:var(--ui-text);font-size:12px;font-weight:800;cursor:pointer}.quick-action-grid span{display:grid;place-items:center;width:26px;height:26px;border-radius:8px;color:var(--ui-blue);background:#eef5ff}.quick-action-grid svg{width:16px;height:16px}.donut-wrap{display:grid;grid-template-columns:136px 1fr;align-items:center;gap:18px}.donut-ring{width:132px;height:132px;border-radius:50%;background:conic-gradient(var(--ui-blue) 0 76%,#64d7ee 76% 88%,#edf2fb 88% 100%);position:relative}.donut-ring:before{content:"";position:absolute;inset:18px;border-radius:50%;background:#fff}.donut-center{position:absolute;inset:18px;z-index:1;text-align:center}.donut-ring strong,.donut-ring small{display:block;position:absolute;left:50%;transform:translate(-50%);line-height:1.15;white-space:nowrap}.donut-ring strong{top:50%;transform:translate(-50%,-50%);font-size:25px;font-weight:400}.donut-ring small{top:calc(50% + 21px);color:var(--ui-muted);font-size:11px}.donut-wrap ul{display:flex;flex-direction:column;gap:10px;list-style:none}.donut-wrap li{display:grid;grid-template-columns:auto 1fr auto;gap:8px;align-items:center;color:var(--ui-text);font-size:12px}.dot{width:8px;height:8px;border-radius:50%}.dot.green{background:var(--ui-green)}.dot.orange{background:var(--ui-orange)}.dot.red{background:var(--ui-red)}.course-banner{display:flex;align-items:center;justify-content:space-between;min-height:72px;padding:18px 22px;border-radius:10px;background:radial-gradient(circle at 70% 40%,rgba(255,255,255,.18),transparent 28%),linear-gradient(135deg,#3267f6,#7b61ff);color:#fff;box-shadow:0 16px 30px #3267f63d}.course-banner h3{margin-bottom:6px;font-size:18px;font-weight:400}.course-banner p{opacity:.9;font-size:13px}.course-banner button{display:grid;place-items:center;width:36px;height:36px;border:0;border-radius:50%;background:#fff;color:var(--ui-blue);font-size:22px;cursor:pointer}.shell-without-header .main-container{height:calc(100vh - 34px)}.shell-without-header .app-rail{width:64px;flex-basis:64px;background:#fff}.shell-without-header .rail-brand{width:64px;height:58px;border-radius:12px 12px 8px 8px}.shell-without-header .rail-nav{gap:8px;padding-top:14px}.shell-without-header .rail-link{width:48px;height:46px;border-radius:12px;gap:3px;font-size:10px}.shell-without-header .rail-link span{display:block;max-width:44px;overflow:hidden;color:currentColor;line-height:1;text-overflow:ellipsis;white-space:nowrap}.shell-without-header .rail-link svg{width:17px;height:17px}.app-rail.notice-rail,.shell-without-header .app-rail.notice-rail{width:154px;flex:0 0 154px;align-items:stretch;gap:12px;height:100%;padding:14px 12px;border-right:1px solid rgba(210,220,236,.92);background:linear-gradient(180deg,#fff,#f6f9ff);box-shadow:inset -1px 0 #ffffffd1}.notice-rail-brand,.shell-without-header .notice-rail-brand,.shell-without-header .rail-brand{width:100%;height:54px;flex:0 0 54px;border-radius:12px;background:linear-gradient(135deg,#3267f6,#55c6c2)}.notice-rail-section{min-height:0;flex:1;gap:8px;padding-top:0}.notice-rail-label{padding:0 8px 4px;color:#6b7890;font-size:12px;line-height:1.2;font-weight:400}.rail-nav,.shell-without-header .rail-nav{min-height:0;flex:1;align-items:stretch;gap:6px;overflow-y:auto;overflow-x:hidden;padding:0 2px 4px 0;scrollbar-width:none}.rail-nav::-webkit-scrollbar{display:none}.rail-link.notice-rail-link,.shell-without-header .rail-link.notice-rail-link{position:relative;display:grid;grid-template-columns:4px 20px minmax(0,1fr);place-items:center stretch;width:100%;height:40px;min-height:40px;gap:8px;padding:0 10px;border-radius:10px;color:#53627d;background:transparent;box-shadow:none;font-size:13px;font-weight:400}.rail-link.notice-rail-link svg,.shell-without-header .rail-link.notice-rail-link svg{width:18px;height:18px;justify-self:center;color:currentColor}.notice-rail-link span:last-child,.shell-without-header .notice-rail-link span:last-child{display:block;max-width:none;overflow:hidden;color:currentColor;font-size:13px;line-height:1.1;text-overflow:ellipsis;white-space:nowrap}.notice-rail-dot{width:4px;height:18px;border-radius:999px;background:transparent}.rail-link.notice-rail-link:hover{color:#2457d6;background:#eef5ff}.rail-link.notice-rail-link.active,.shell-without-header .rail-link.notice-rail-link.active{color:#1748c8;background:linear-gradient(135deg,#3267f624,#55c6c21f);box-shadow:inset 0 0 0 1px #3267f61f}.notice-rail-link.active .notice-rail-dot,.notice-rail-link:hover .notice-rail-dot{background:#3267f6}.rail-settings.notice-rail-link{flex:0 0 40px;margin-top:0}.app-rail.notice-rail,.shell-without-header .app-rail.notice-rail{width:188px;flex-basis:188px}.notice-rail-brand,.shell-without-header .notice-rail-brand,.shell-without-header .rail-brand{display:flex;align-items:center;justify-content:center;gap:9px}.notice-rail-brand .brand-orbit{width:22px;height:22px;flex:0 0 auto}.notice-rail-brand strong{color:#fff;font-size:16px;line-height:1;font-weight:400}.grouped-rail-nav{gap:10px}.rail-group{display:grid;gap:4px}.rail-group-toggle{display:grid;grid-template-columns:24px minmax(0,1fr) 16px;align-items:center;gap:8px;width:100%;height:38px;padding:0 10px;border:0;border-radius:10px;background:transparent;color:#41506c;cursor:pointer;font-size:13px;font-weight:400;text-align:left}.rail-group-toggle:hover,.rail-group.active .rail-group-toggle{color:#1748c8;background:#eef5ff}.rail-group-icon,.rail-group-chevron{display:grid;place-items:center}.rail-group-icon svg{width:18px;height:18px}.rail-group-chevron{width:15px;height:15px;transition:transform .18s ease}.rail-group-toggle[aria-expanded=true] .rail-group-chevron{transform:rotate(180deg)}.rail-subnav{display:grid;gap:4px;margin-left:11px;padding:2px 0 4px 10px;border-left:1px solid rgba(203,213,225,.86)}.rail-subnav .rail-link.notice-rail-link,.shell-without-header .rail-subnav .rail-link.notice-rail-link{height:36px;min-height:36px;grid-template-columns:4px 18px minmax(0,1fr);gap:7px;padding:0 8px;border-radius:9px;font-size:12px;font-weight:400}.rail-subnav .notice-rail-link span:last-child,.shell-without-header .rail-subnav .notice-rail-link span:last-child{font-size:12px}.home-dashboard-layout,.realtime-monitor-layout{padding:0}.content-area.realtime-monitor-layout{align-items:stretch;padding:12px}.content-area.realtime-monitor-layout.wearable-course-running{padding:8px 10px;overflow:hidden}.content-area.realtime-monitor-layout>*{width:100%;min-height:100%;margin:0}.content-area.realtime-monitor-layout.wearable-course-running>*{height:100%;min-height:0}.realtime-monitor-page{display:flex;flex-direction:column;gap:16px;color:var(--ui-ink)}.monitor-hero{display:flex;align-items:center;justify-content:space-between;gap:20px;min-height:104px;padding:20px 22px;border:1px solid rgba(210,220,240,.88);border-radius:12px;background:linear-gradient(135deg,#fffffffa,#f6fafff5),linear-gradient(90deg,#3267f61a,#55c6c21a);box-shadow:var(--ui-soft-shadow)}.monitor-hero span{color:var(--ui-blue);font-size:12px;line-height:1;font-weight:400}.monitor-hero h1{margin:8px 0 6px;color:var(--ui-ink);font-size:25px;line-height:1.12;font-weight:400}.monitor-hero p{color:var(--ui-muted);font-size:13px;line-height:1.55;font-weight:700}.monitor-hero button{flex:0 0 auto;min-height:40px;padding:0 18px;border:0;border-radius:10px;background:linear-gradient(135deg,#ff6f67,#f03a32);color:#fff;font-size:14px;font-weight:400;box-shadow:0 14px 26px #f03a3233}.monitor-metric-grid{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:12px}.monitor-metric-card{min-height:104px;padding:16px;border:1px solid rgba(215,224,244,.9);border-radius:12px;background:#fffffff0;box-shadow:var(--ui-soft-shadow)}.monitor-metric-card p{color:#52617a;font-size:13px;font-weight:400}.monitor-metric-card strong{display:block;margin:10px 0 8px;color:#101b3d;font-size:25px;line-height:1;font-weight:400}.monitor-metric-card small{font-size:13px}.monitor-metric-card span{color:#748199;font-size:12px;font-weight:750}.monitor-metric-card.blue{border-top-color:#3267f699}.monitor-metric-card.red{border-top-color:#f04a5c99}.monitor-metric-card.green{border-top-color:#25c27699}.monitor-metric-card.purple{border-top-color:#7b61ff99}.monitor-metric-card.cyan{border-top-color:#129ac799}.monitor-board{display:grid;grid-template-columns:280px minmax(0,1.2fr) 280px;gap:14px;align-items:stretch}.monitor-panel{min-width:0;min-height:240px;padding:16px;border:1px solid rgba(215,224,244,.9);border-radius:12px;background:#fffffff0;box-shadow:var(--ui-soft-shadow)}.monitor-panel.chart-card{padding:16px}.monitor-panel .chart-canvas{--chart-panel-height: 214px;--chart-panel-min-height: 214px}.monitor-chart-panel h3,.monitor-panel-title{margin-bottom:14px}.monitor-panel-title{display:flex;align-items:center;justify-content:space-between;gap:12px}.monitor-panel-title h2,.monitor-chart-panel h3{color:var(--ui-ink);font-size:15px;line-height:1.2;font-weight:400}.monitor-panel-title span{color:var(--ui-muted);font-size:12px;font-weight:800}.monitor-stage-panel,.ranking-panel{min-height:100%}.stage-list{display:flex;flex-direction:column;gap:12px}.stage-row{display:grid;grid-template-columns:minmax(72px,.9fr) minmax(0,1fr) 40px;gap:10px;align-items:center}.stage-row strong,.stage-row small{display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.stage-row strong{color:var(--ui-ink);font-size:13px;font-weight:400}.stage-row small,.stage-row em{color:var(--ui-muted);font-size:12px;font-style:normal;font-weight:700}.stage-bar{height:8px;overflow:hidden;border-radius:999px;background:#edf2fb}.stage-bar i{display:block;height:100%;border-radius:inherit;background:linear-gradient(90deg,#3267f6,#55c6c2)}.court-visual{display:grid;grid-template-columns:repeat(8,1fr);gap:8px;padding-top:4px}.court-visual span{aspect-ratio:1;border-radius:8px;background:#e8f1ff}.court-visual span.hot{background:#fff0f1}.court-visual span.calm{background:#e9fbf3}.heart-chart{grid-column:span 1}.intensity-chart,.court-panel,.ranking-panel{min-height:240px}.wide-chart{grid-column:span 2}.ranking-panel ol{display:grid;gap:12px;list-style:none}.ranking-panel li{display:flex;align-items:center;justify-content:space-between;gap:12px;min-height:42px;padding:0 12px;border-radius:10px;background:#f8fbff}.ranking-panel strong{color:var(--ui-ink);font-size:13px;font-weight:400}.ranking-panel span{color:#e94a5e;font-size:13px;font-weight:400}.home-overview-page{min-height:100%;padding:22px 26px 24px;background:linear-gradient(135deg,#ffffffb8,#f6fafff5),#f5f8ff;color:var(--ui-ink)}.home-hero{display:flex;align-items:center;justify-content:space-between;gap:24px;min-height:70px;margin-bottom:18px}.home-hero p,.home-date-card span,.home-date-card small{color:#71809a;font-size:13px;font-weight:700}.home-hero h1{margin-top:7px;color:#101b3d;font-size:25px;line-height:1.1;font-weight:400}.home-date-card{min-width:188px;padding:13px 16px;border:1px solid rgba(209,220,243,.9);border-radius:10px;background:#ffffffd1;box-shadow:0 14px 36px #30509214}.home-date-card strong{display:block;margin:4px 0;color:#1e4fe8;font-size:22px;line-height:1}.overview-stats-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:16px;margin-bottom:16px}.overview-stat-card{display:flex;align-items:center;gap:14px;min-height:98px;padding:18px;border:1px solid rgba(215,224,244,.9);border-radius:10px;background:#ffffffeb;box-shadow:0 18px 38px #2a498c14}.overview-stat-icon,.home-course-icon,.home-action-grid span{display:grid;place-items:center;flex:0 0 auto;width:36px;height:36px;border-radius:10px;background:#edf4ff;color:#246bff}.overview-stat-card.cyan .overview-stat-icon{background:#eafaff;color:#129ac7}.overview-stat-card.green .overview-stat-icon{background:#ebfbf3;color:#1ba768}.overview-stat-card.red .overview-stat-icon{background:#fff0f1;color:#e94a5e}.overview-stat-icon svg,.home-course-icon svg,.home-action-grid svg{width:18px;height:18px}.overview-stat-card p{margin-bottom:7px;color:#52617a;font-size:13px;font-weight:800}.overview-stat-card strong{display:block;color:#0f1a39;font-size:25px;line-height:1;font-weight:400}.overview-stat-card small{display:block;margin-top:7px;color:#75839c;font-size:12px;font-weight:700}.home-trend-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px;margin-top:16px}.home-trend-panel{--trend-color: #2f67ff;--trend-soft: rgba(47, 103, 255, .12);--trend-glow: rgba(47, 103, 255, .18);min-width:0;position:relative;overflow:hidden;padding:18px 18px 16px;border:1px solid rgba(190,204,226,.78);border-radius:14px;background:linear-gradient(180deg,#fffffffc,#f6f9fdfa),linear-gradient(135deg,#2f67ff14,#10b9810d 46%,#f59e0b0f);box-shadow:0 22px 46px #244c941a,inset 0 1px #ffffffeb}.home-trend-panel.recovery{--trend-color: #18a981;--trend-soft: rgba(24, 169, 129, .12);--trend-glow: rgba(24, 169, 129, .18)}.home-trend-panel:before{position:absolute;top:0;left:22px;right:22px;height:3px;border-radius:0 0 999px 999px;background:linear-gradient(90deg,var(--trend-color),#7b61ff);content:"";opacity:.78}.home-trend-title{position:relative;z-index:2;display:flex;align-items:flex-start;gap:12px;margin-bottom:13px}.home-trend-title>div{min-width:0;flex:1}.home-trend-title-icon{flex:0 0 auto;display:grid;place-items:center;width:36px;height:36px;border-radius:12px;background:linear-gradient(135deg,var(--trend-color),color-mix(in srgb,var(--trend-color) 54%,#ffffff));color:#fff;font-size:12px;line-height:1;font-weight:950;box-shadow:0 12px 24px var(--trend-glow)}.home-trend-title h2{color:#101b3d;font-size:15px;line-height:1.2;font-weight:950}.home-trend-title p{margin-top:4px;color:#72809a;font-size:12px;line-height:1.3;font-weight:800}.home-trend-title strong{flex:0 0 auto;color:var(--trend-color);font-size:20px;line-height:1;font-weight:950}.home-trend-chart{position:relative;z-index:1;min-height:249px;overflow:hidden;padding:12px 14px 8px;border:1px solid rgba(213,224,240,.78);border-radius:12px;background:linear-gradient(180deg,#fffffff0,#f4f8fde0),linear-gradient(rgba(47,103,246,.08) 1px,transparent 1px),linear-gradient(90deg,rgba(47,103,246,.06) 1px,transparent 1px);background-size:auto,100% 44px,56px 100%;box-shadow:inset 0 1px #ffffffeb,inset 0 -18px 34px #2f67f60a}.home-trend-chart:after{position:absolute;inset:0;z-index:0;background:linear-gradient(120deg,transparent 0 62%,rgba(255,255,255,.46) 62% 64%,transparent 64%),linear-gradient(180deg,rgba(255,255,255,.38),transparent 34%);content:"";pointer-events:none}.home-trend-svg{position:relative;z-index:1;display:block;width:100%;height:225px}.home-trend-svg .grid-line{stroke:#6f7e9e24;stroke-width:1}.home-trend-svg polygon{fill:color-mix(in srgb,var(--trend-color) 13%,transparent);opacity:.72}.home-trend-svg .course-line,.home-trend-svg .average-line{fill:none;stroke-linecap:round;stroke-linejoin:round}.home-trend-svg .course-line{stroke:var(--trend-color);stroke-width:3.5;filter:drop-shadow(0 8px 10px var(--trend-glow))}.home-trend-svg .average-line{stroke-width:2.1;stroke-dasharray:6 6}.home-trend-svg .average-line.mine{stroke:#f59b22;stroke-dasharray:6 6}.home-trend-svg .average-line.park{stroke:#7a5cff;stroke-dasharray:2 6}.home-trend-y-axis{position:absolute;top:12px;right:14px;left:14px;z-index:2;height:225px;pointer-events:none}.home-trend-y-axis span{position:absolute;left:0;transform:translateY(-50%);color:#8a96ad;font-size:12px;line-height:1;font-weight:850}.home-trend-point-layer{position:absolute;top:12px;right:14px;left:14px;z-index:4;height:225px;pointer-events:none}.home-trend-point{position:absolute;width:14px;height:14px;border:3px solid var(--trend-color);border-radius:999px;background:#fff;box-shadow:0 6px 10px var(--trend-glow);pointer-events:auto;transform:translate(-50%,-50%)}.home-trend-axis,.home-trend-legend{display:flex;align-items:center;justify-content:space-between;gap:10px}.home-trend-axis{position:relative;z-index:1;margin:-24px 20px 0 38px;color:#7b88a1;font-size:11px;font-weight:800}.home-trend-legend{flex-wrap:wrap;margin-top:12px;color:#5f6f8b;font-size:11px;font-weight:800}.home-trend-legend span{display:inline-flex;align-items:center;gap:6px;min-width:0;white-space:nowrap}.home-trend-legend span:before{content:"";width:18px;height:3px;border-radius:999px;background:var(--trend-color)}.home-trend-legend .mine-line:before{background:#f59b22}.home-trend-legend .park-line:before{background:#7a5cff}.home-trend-empty{position:relative;z-index:1;display:grid;min-height:225px;place-items:center;color:#75839c;font-size:12px;font-weight:400}.home-dashboard-grid{display:grid;grid-template-columns:minmax(220px,.92fr) minmax(320px,1.22fr) minmax(240px,1fr);gap:16px;align-items:stretch}.home-panel{min-width:0;min-height:248px;padding:18px;border:1px solid rgba(215,224,244,.9);border-radius:10px;background:#fffffff0;box-shadow:0 18px 38px #2a498c14}.home-panel-title{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:16px}.home-panel-title h2{color:#101b3d;font-size:16px;line-height:1.2;font-weight:400}.home-panel-title button,.home-panel-title span{border:0;background:transparent;color:#2d67f6;font-size:12px;font-weight:400}.home-course-list{display:flex;flex-direction:column;gap:12px}.home-course-row{display:grid;grid-template-columns:38px minmax(0,1fr) auto;align-items:center;gap:12px;width:100%;min-height:64px;padding:10px;border:0;border-radius:10px;background:#f8fbff;text-align:left;cursor:pointer}.home-course-copy{min-width:0}.home-course-copy strong,.home-course-copy small,.home-course-copy em{display:block;overflow:hidden;line-height:1.25;text-overflow:ellipsis;white-space:nowrap}.home-course-copy strong{color:#101b3d;font-size:13px;font-weight:400}.home-course-copy small,.home-course-copy em{margin-top:3px;color:#71809a;font-size:11px;font-style:normal;font-weight:700}.home-course-row b{display:inline-flex;align-items:center;height:22px;padding:0 8px;border-radius:7px;font-size:11px;font-weight:400}.home-course-row b.blue{background:#e8f1ff;color:#246bff}.home-course-row b.green{background:#e9f8ef;color:#1a9c60}.action-panel{position:relative;display:grid;grid-template-rows:auto minmax(0,1fr);row-gap:16px;overflow:hidden;border-color:#c9d7f2f2;background:linear-gradient(180deg,#fffffffa,#f6fafff5)}.action-panel:before{content:"";position:absolute;top:0;right:0;left:0;height:3px;background:linear-gradient(90deg,#2f67ff,#28bca3 52%,#ffbe4d)}.action-panel .home-panel-title{position:relative;z-index:1;margin-bottom:0}.action-panel .empty-state-card{position:relative;z-index:1;height:100%}.home-action-grid{position:relative;z-index:1;display:grid;grid-template-columns:repeat(3,minmax(0,1fr));grid-auto-rows:minmax(0,1fr);gap:14px;height:100%}.home-action-grid button{position:relative;display:flex;min-width:0;min-height:92px;flex-direction:column;align-items:center;justify-content:center;gap:9px;padding:12px 10px;overflow:hidden;border:1px solid rgba(210,222,246,.95);border-radius:12px;background:linear-gradient(180deg,#fff,#f4f8ff);box-shadow:inset 0 1px #fffffff2,0 8px 18px #2a498c0f;color:#42516c;font-size:12px;font-weight:400;text-align:center;cursor:pointer;transition:transform .18s ease,border-color .18s ease,box-shadow .18s ease,background .18s ease}.home-action-grid button:hover{transform:translateY(-2px);border-color:#2f67ff6b;background:linear-gradient(180deg,#fff,#eef5ff);box-shadow:inset 0 1px #fff,0 14px 24px #2f67ff1f}.home-action-grid button:active{transform:translateY(0)}.home-action-grid button:focus-visible{outline:3px solid rgba(47,103,255,.22);outline-offset:2px}.home-action-grid button span{width:40px;height:40px;border:1px solid rgba(47,103,255,.12);border-radius:13px;background:linear-gradient(180deg,#edf4ff,#e5efff);box-shadow:inset 0 1px #ffffffdb}.home-action-grid button strong,.home-action-grid button small{max-width:100%;overflow:hidden}.home-action-grid button strong{display:block;text-overflow:ellipsis;white-space:nowrap;color:#243653;font-size:12px;line-height:1.15;font-weight:400}.home-action-grid button small{display:-webkit-box;min-height:26px;-webkit-box-orient:vertical;-webkit-line-clamp:2;color:#6d7d97;font-size:11px;line-height:1.25;font-weight:800;white-space:normal}.overview-panel .donut-wrap{grid-template-columns:136px minmax(0,1fr);height:calc(100% - 36px)}.home-overview-donut .donut-ring{background:conic-gradient(#3f75ff 0 75%,#46d3b2 75% 87.5%,#ffbe4d 87.5% 100%)}.donut-center{position:absolute;inset:18px;z-index:1}.donut-ring strong,.donut-ring small{position:absolute;left:50%;display:block;white-space:nowrap}.donut-ring strong{top:50%;transform:translate(-50%,-50%)}.donut-ring small{top:calc(50% + 21px);transform:translate(-50%)}.home-current-course{display:flex;align-items:center;justify-content:space-between;min-height:80px;margin-top:16px;padding:18px 22px;overflow:hidden;border-radius:10px;background:linear-gradient(112deg,#2b69fffa,#775ffff2),#2f67ff;color:#fff;box-shadow:0 22px 42px #3267f63d}.home-current-course span{display:block;margin-bottom:6px;font-size:18px;font-weight:400}.home-current-course h2{font-size:13px;line-height:1.45;font-weight:700;opacity:.92}.home-current-course button{display:grid;place-items:center;flex:0 0 auto;width:38px;height:38px;border:0;border-radius:50%;background:#fff;color:#2f67ff;cursor:pointer}.home-current-course svg{width:20px;height:20px}.realtime-monitor-layout,.no-band-monitor-page{background:transparent}.no-band-monitor-page{min-height:100%;padding:0;gap:12px}.monitor-topbar{display:grid;grid-template-columns:minmax(0,1fr) 360px;gap:12px;align-items:stretch}.monitor-heading{display:flex;flex-direction:column;gap:10px}.monitor-heading h2{color:var(--ui-ink);font-size:22px;line-height:1.2;font-weight:400}.monitor-meta-card{display:flex;flex-wrap:wrap;gap:8px 22px;align-items:center;min-height:54px;padding:0 16px;border:1px solid rgba(50,103,246,.08);border-radius:16px;background:#ffffffe0;box-shadow:0 18px 40px #2a4e981a}.monitor-meta-card span{color:#53627d;font-size:14px;font-weight:700}.monitor-meta-card strong{margin-left:6px;color:var(--ui-ink);font-size:15px;font-weight:400}.session-timer-card{display:flex;flex-direction:column;justify-content:center;gap:8px;padding:16px 22px;border-radius:18px;background:linear-gradient(135deg,#1b67f5,#0f44cb);box-shadow:0 26px 48px #1c4bbb47;color:#fff}.timer-card-label{font-size:13px;font-weight:800;opacity:.92}.timer-card-main{display:flex;align-items:center;justify-content:space-between;gap:18px;min-width:0}.timer-card-main strong{min-width:0;font-size:clamp(30px,3.6vw,46px);line-height:.95;font-weight:400}.timer-card-main em{flex:0 0 auto;min-width:72px;max-width:100%;height:36px;display:inline-flex;align-items:center;justify-content:center;border-radius:999px;background:linear-gradient(135deg,#4bd266,#2bb84a);font-size:13px;font-style:normal;font-weight:400}.lesson-stage-shell{display:grid;grid-template-columns:minmax(0,1fr) 156px;gap:12px;align-items:stretch}.lesson-stage-grid{display:grid;grid-template-columns:repeat(6,minmax(0,1fr));gap:10px}.lesson-stage-card{position:relative;min-height:268px;padding:16px 12px 12px;border:1px solid rgba(50,103,246,.08);border-radius:16px;background:#fffffff0;box-shadow:0 12px 22px #1f468a12;display:flex;flex-direction:column;align-items:center;text-align:center}.lesson-stage-card.is-active{border-color:#3267f6b8;box-shadow:0 20px 44px #254f9d24}.stage-badge{position:absolute;top:-10px;right:12px;min-height:28px;padding:0 12px;display:inline-flex;align-items:center;border-radius:999px;background:linear-gradient(135deg,#2f80ff,#1d61ef);color:#fff;font-size:12px;font-weight:400}.lesson-stage-card h3{color:var(--ui-ink);font-size:15px;line-height:1.25;font-weight:400}.stage-order{width:34px;height:34px;margin:10px 0 12px;display:grid;place-items:center;border-radius:50%;background:linear-gradient(135deg,#eef3fb,#dfe7f5);color:#617087;font-size:15px;font-weight:400}.lesson-stage-card.is-active .stage-order{background:linear-gradient(135deg,#2f80ff,#1f68f0);color:#fff}.stage-time-list{width:100%;padding-bottom:10px;margin-bottom:10px;border-bottom:1px solid #e8eef8;display:flex;flex-direction:column;gap:6px}.stage-time-list div{display:flex;align-items:center;justify-content:space-between;gap:12px}.stage-time-list dt{color:#79879e;font-size:12px;font-weight:700}.stage-time-list dd{color:var(--ui-ink);font-size:14px;font-weight:800}.stage-time-list dd.accent{color:#2f80ff}.stage-density-block{margin-top:auto;display:flex;flex-direction:column;gap:4px}.stage-density-block span{color:#79879e;font-size:12px;font-weight:700}.stage-density-block strong{color:var(--ui-ink);font-size:18px;font-weight:400}.stage-density-block strong.positive{color:#1db14b}.stage-action-button{width:100%;min-height:38px;margin-top:10px;border:1px solid #dbe4f2;border-radius:12px;background:linear-gradient(180deg,#fff,#f5f8fd);color:#2f80ff;font-size:14px;font-weight:400;box-shadow:0 8px 16px #213e750f}.stage-action-button.active{background:linear-gradient(135deg,#2f80ff,#1d61ef);border-color:transparent;color:#fff}.stage-action-button.done{color:#2a9d51}.stage-control-panel{display:grid;gap:8px}.control-button{min-height:58px;border:0;border-radius:16px;color:#fff;font-size:15px;font-weight:400;box-shadow:0 12px 22px #1b346b1a}.control-button.blue{background:linear-gradient(180deg,#3790ff,#1d65ef)}.control-button.purple{background:linear-gradient(180deg,#8b64ff,#6b3df1)}.control-button.orange{background:linear-gradient(180deg,#ffb13a,#ff9717)}.control-button.red{min-height:48px;background:linear-gradient(180deg,#ff6f67,#f03a32)}.analysis-bottom-grid{display:grid;grid-template-columns:minmax(0,1.55fr) minmax(0,.95fr) 220px;gap:12px;align-items:start}.bottom-panel{border-radius:16px;border:1px solid rgba(50,103,246,.08);background:#fffffff0;box-shadow:0 18px 34px #1f468a14}.no-band-monitor-page .chart-card h3{margin:0 0 12px;color:var(--ui-ink);font-size:15px;font-weight:400}.density-chart-panel{--chart-panel-height: 188px;--chart-panel-min-height: 188px;padding:12px 14px 10px}.progress-panel{display:flex;flex-direction:column;gap:8px}.progress-chart-panel{--chart-panel-height: 166px;--chart-panel-min-height: 166px;padding:12px 14px 10px}.progress-total{display:flex;justify-content:flex-end;gap:8px;padding:0 6px;color:#66748d;font-size:15px;font-weight:700}.progress-total strong{color:#2f80ff;font-size:18px;font-weight:400}.summary-stack{display:grid;gap:8px}.summary-card{min-height:72px;padding:14px 16px;border:1px solid rgba(50,103,246,.08);border-radius:16px;background:#fffffff0;box-shadow:0 18px 34px #1f468a14;display:flex;flex-direction:column;justify-content:center;gap:6px}.summary-card span{color:#66748d;font-size:12px;font-weight:700}.summary-card strong{color:var(--ui-ink);font-size:22px;line-height:1;font-weight:400}.summary-card.warning strong{color:#ff9415}.wearable-course-page{min-height:100%;padding:0}.wearable-running-shell{display:flex;flex-direction:column;gap:18px}.wearable-topbar{display:grid;grid-template-columns:minmax(0,1.55fr) minmax(280px,.95fr);gap:18px;align-items:stretch}.wearable-overview-card,.wearable-record-card,.summary-chip,.wearable-stop-button,.wearable-chart-grid .chart-container{border:1px solid rgba(50,103,246,.08);background:#fffffff0;box-shadow:0 18px 34px #1f468a14}.wearable-overview-card{padding:22px 24px 18px;border-radius:22px}.wearable-overview-card h2{color:var(--ui-ink);font-size:30px;line-height:1.2;font-weight:400;margin-bottom:18px}.wearable-meta-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:0;overflow:hidden;border-radius:18px;border:1px solid #e9eff9}.wearable-meta-item{min-height:92px;padding:18px 22px;display:flex;flex-direction:column;justify-content:center;gap:8px;background:linear-gradient(180deg,#fff,#f8fbff)}.wearable-meta-item+.wearable-meta-item{border-left:1px solid #e9eff9}.wearable-meta-item span{color:#6f7d96;font-size:14px;font-weight:700}.wearable-meta-item strong{color:var(--ui-ink);font-size:18px;font-weight:400}.wearable-session-card{border-radius:28px;min-width:0;overflow:hidden}.wearable-session-card .timer-card-main{flex-wrap:wrap}.wearable-record-card{padding:14px 14px 10px;border-radius:22px}.wearable-section-title{padding:0 10px 12px}.wearable-section-title h3{color:var(--ui-ink);font-size:18px;font-weight:400}.wearable-record-table{margin-bottom:0}.wearable-record-table .activity-table{border-radius:18px;overflow:hidden;border-color:#e7edf8}.wearable-record-table .activity-table th,.wearable-record-table .activity-table td{min-width:114px;height:72px;padding:8px 10px;font-size:13px;background:#ffffffb8}.wearable-record-table .row-label{min-width:148px;color:#233152;background:linear-gradient(180deg,#fbfdff,#f6f9fe)}.wearable-stage-head{position:relative;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;min-height:54px}.wearable-stage-head strong{color:var(--ui-ink);font-size:16px;font-weight:400}.wearable-record-table .is-active-column{position:relative;background:linear-gradient(180deg,#f8fbff,#f3f7ff);box-shadow:inset 0 0 0 2px #2f67ff8c}.wearable-record-table .positive{color:#14a245;font-weight:800}.wearable-record-table .negative{color:#f03a32;font-weight:800}.wearable-record-table .accent{color:#2f67ff;font-weight:800}.wearable-record-table .summary-value{color:#2b3552;font-weight:400}.wearable-record-table .summary-value.warm{color:#ff7d24}.wearable-inline-button{min-height:44px;margin-top:0;border-radius:14px;font-size:15px}.wearable-summary-strip{display:grid;grid-template-columns:repeat(3,minmax(0,1fr)) 280px;gap:16px;align-items:stretch}.summary-chip{min-height:70px;padding:0 24px;border-radius:20px;display:flex;align-items:center;gap:12px}.summary-chip span{color:#67758f;font-size:15px;font-weight:700}.summary-chip strong{color:var(--ui-ink);font-size:26px;font-weight:400}.summary-chip em{color:#67758f;font-size:14px;font-style:normal;font-weight:700}.wearable-stop-button{border:0;border-radius:22px;background:linear-gradient(135deg,#2f67ff,#1452eb);color:#fff;font-size:18px;font-weight:400}.wearable-chart-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:18px}.wearable-chart-grid .chart-container{padding:18px 18px 12px;border-radius:22px}.wearable-chart-grid .chart-container h3{margin-bottom:14px;color:var(--ui-ink);font-size:17px;font-weight:400}.expert-insight-card{padding:16px 18px;border:1px solid rgba(50,103,246,.08);border-radius:var(--ui-radius-lg);background:linear-gradient(180deg,#fffffff5,#f7fafff5);box-shadow:var(--ui-premium-shadow)}.expert-insight-card strong{display:block;margin-bottom:8px;color:var(--ui-ink);font-size:14px;font-weight:400}.expert-insight-card p{color:var(--ui-text);font-size:13px;line-height:1.7}@media(max-width:1180px){.overview-stats-grid,.home-trend-grid,.home-dashboard-grid,.lesson-stage-grid,.analysis-bottom-grid,.monitor-topbar,.lesson-stage-shell{grid-template-columns:1fr}.overview-panel .donut-wrap{grid-template-columns:136px minmax(0,1fr)}}@media(max-width:640px){.home-action-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}.energy-summary-row{display:grid;grid-template-columns:1.35fr repeat(6,1fr);gap:12px;margin-bottom:14px}.energy-total-card,.energy-mini-card{min-height:76px;padding:14px 16px;border:1px solid var(--ui-line);border-radius:10px;background:#fff;box-shadow:var(--ui-soft-shadow)}.energy-total-card{background:linear-gradient(135deg,#5b6cf5,#7b61ff);color:#fff}.energy-total-card span,.energy-mini-card span{display:block;margin-bottom:9px;font-size:13px;font-weight:800}.energy-total-card strong,.energy-mini-card strong{font-size:26px;font-weight:400}.energy-total-card em,.energy-mini-card em{margin-left:4px;font-size:13px;font-style:normal;font-weight:800}.energy-total-card small{display:block;margin-top:5px;opacity:.85;font-size:12px}.energy-mini-card{background:linear-gradient(135deg,#fbfdff,#f7fbff)}.energy-mini-card strong{color:var(--ui-ink);font-size:18px}.energy-mini-card em{color:var(--ui-text)}.content-area.analysis-page-content,.content-area.analysis-with-course-sidebar{padding:12px 18px 18px}.content-area.analysis-no-course-sidebar{padding:12px 20px 18px}.analysis-with-course-sidebar~*{min-width:0}.content-area.analysis-with-course-sidebar{background:linear-gradient(180deg,#f8fbff,#f4f8ff)}.analysis-with-course-sidebar+*{min-width:0}.main-container:has(.content-area.analysis-with-course-sidebar) .sidebar{display:flex;flex-direction:column;width:244px;flex-basis:244px;margin:0;padding:20px 18px;border-right:1px solid rgba(221,230,244,.96);background:#ffffffbd}.main-container:has(.content-area.analysis-with-course-sidebar) .sidebar-header{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:14px}.main-container:has(.content-area.analysis-with-course-sidebar) .btn-new-course{min-height:34px;padding:0 14px;border-radius:8px;white-space:nowrap}.main-container:has(.content-area.analysis-with-course-sidebar) .sidebar-search{margin-bottom:16px}.main-container:has(.content-area.analysis-with-course-sidebar) .search-input{height:38px;border-color:#dfe7f3;border-radius:8px}.main-container:has(.content-area.analysis-with-course-sidebar) .course-list{padding:0 0 10px}.main-container:has(.content-area.analysis-with-course-sidebar) .course-item{position:relative;min-height:104px;padding:18px 18px 16px 46px;border-radius:12px;background:#ffffffeb}.main-container:has(.content-area.analysis-with-course-sidebar) .course-item:before{position:absolute;top:22px;left:16px;display:grid;place-items:center;width:20px;height:20px;border-radius:50%;background:#26c281;color:#fff;content:"✓";font-size:12px;font-weight:400}.main-container:has(.content-area.analysis-with-course-sidebar) .course-name{font-size:14px;font-weight:400}.main-container:has(.content-area.analysis-with-course-sidebar) .course-status{display:none}.sidebar-manage-course{display:none}.main-container:has(.content-area.analysis-with-course-sidebar) .sidebar-manage-course{display:inline-flex;align-items:center;justify-content:center;gap:8px;width:100%;min-height:42px;margin-top:auto;border:1px solid #dfe7f3;border-radius:10px;background:#ffffffdb;color:var(--ui-blue);cursor:pointer;font-weight:400}.main-container:has(.content-area.analysis-with-course-sidebar) .sidebar-manage-course svg{width:17px;height:17px}.analysis-page{width:100%;max-width:100%;gap:14px}.analysis-page .professional-panel,.analysis-page .chart-card,.analysis-page .chart-container,.analysis-page .energy-table-section,.analysis-page .energy-chart-section,.analysis-page .evaluation-table-section,.analysis-page .expert-insight-card{border:1px solid rgba(221,230,244,.96);border-radius:12px;background:#fffffff5;box-shadow:0 14px 32px #244c9412}.analysis-hero-card{position:relative;min-height:98px;overflow:hidden;border-radius:12px;padding:20px 26px;background:linear-gradient(90deg,#fffffffa,#f6fafff0),linear-gradient(135deg,#2f67ff14,#6fdaf114)}.analysis-hero-card:after{right:24px;top:-10px;bottom:auto;width:190px;height:140px;border-radius:0;background:linear-gradient(135deg,#2f67ff14,#7a61ff2e),radial-gradient(circle at 70% 40%,rgba(108,224,255,.28),transparent 36%);clip-path:polygon(18% 18%,84% 0,100% 78%,28% 100%,0 48%);opacity:.8}.analysis-hero-card h2{margin:4px 0 6px;font-size:26px}.analysis-hero-card p{max-width:620px;font-size:13px}.analysis-hero-icon{display:grid;place-items:center;flex:0 0 auto;width:70px;height:70px;border-radius:18px;background:linear-gradient(135deg,#eef4ff,#dfe9ff);color:#6d86ff;box-shadow:inset 0 0 0 1px #2f67ff1f,0 14px 26px #2f67ff1f}.analysis-hero-icon svg{width:46px;height:46px}.analysis-hero-art{position:absolute;right:26px;bottom:10px;z-index:1;width:150px;height:76px;opacity:.34;pointer-events:none}.analysis-hero-card>div,.analysis-hero-card>.analysis-hero-icon{position:relative;z-index:2}.analysis-metric-strip{gap:14px}.analysis-metric-strip article{min-height:104px;padding:18px 20px;border-color:#dde6f4f5;border-radius:12px;background:#fffffffa;box-shadow:0 14px 32px #244c9412}.analysis-metric-strip strong{margin:8px 0 6px;font-size:30px}.analysis-info-card,.analysis-record-card,.analysis-heart-card,.analysis-evaluation-card{padding:16px 18px}.analysis-info-card .info-inputs{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:18px}.analysis-info-card .input-group label,.analysis-heart-card .input-group label{margin-bottom:6px;color:#30405f;font-size:12px;font-weight:400}.analysis-info-card input,.analysis-heart-card input,.analysis-page .table-input{min-height:32px;border-color:#dbe4f2;border-radius:7px;background:#fff;color:#405070;text-align:center;font-weight:760}.analysis-info-card input{text-align:left}.analysis-page .table-input.calculated{border-color:#f0dd8d;background:#fff7d7;color:#f05b14}.analysis-record-card .record-table-header,.analysis-page .section-title{margin-bottom:12px;border-bottom:0;padding-bottom:0}.analysis-page table{border:1px solid #dfe7f3;border-collapse:separate;border-spacing:0}.analysis-page th,.analysis-page td{border-right:1px solid #dfe7f3;border-bottom:1px solid #dfe7f3;padding:10px 12px;text-align:center}.analysis-page tr:last-child td{border-bottom:0}.analysis-page th:last-child,.analysis-page td:last-child{border-right:0}.analysis-page thead{background:linear-gradient(180deg,#fbfdff,#f3f7ff)}.analysis-page .row-label{background:#fbfdff;color:#112044;font-weight:400;white-space:nowrap}.analysis-heart-card .heart-rate-inputs{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:38px}.analysis-chart-row,.analysis-four-chart-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}.analysis-chart-card{min-height:0;padding:18px}.analysis-chart-card h3{margin:0 0 12px;border-bottom:1px solid #e6edf7;padding-bottom:10px;color:#0f1d3d;font-size:15px;font-weight:400;text-align:left}.analysis-page .chart-placeholder{height:252px;padding:8px;border-radius:8px;background:linear-gradient(180deg,#fffffff5,#f8fbfff0),repeating-linear-gradient(0deg,rgba(217,226,240,.58) 0,rgba(217,226,240,.58) 1px,transparent 1px,transparent 44px)}.density-charts-page{gap:14px}.density-charts-page .density-charts-hero{height:142px;min-height:142px;justify-content:space-between;padding:24px 34px;border-color:#d3def2fa;border-radius:14px;background:linear-gradient(100deg,#fffffffc,#fafdfffa,#e8effff5);box-shadow:0 16px 34px #244c9412}.density-charts-page .density-charts-hero:after{display:none}.density-charts-hero-copy{max-width:620px}.density-charts-hero-copy .professional-kicker{color:#355cff;font-size:13px;font-weight:950}.density-charts-hero-copy h2{margin:8px 0 10px;color:#0d1d3d;font-size:28px;font-weight:950}.density-charts-hero-copy p{max-width:600px;color:#53627d;font-size:14px;font-weight:760}.density-charts-hero-visual{position:absolute;inset:0 0 0 auto;z-index:1;width:450px;pointer-events:none}.density-charts-hero-visual .hero-panel{position:absolute;right:28px;top:20px;width:304px;height:104px;border-radius:24px;background:linear-gradient(135deg,#2f67ff0f,#2f67ff2e),linear-gradient(120deg,transparent 0 24%,rgba(255,255,255,.36) 24% 26%,transparent 26% 52%,rgba(255,255,255,.26) 52% 54%,transparent 54%);box-shadow:inset 0 0 0 1px #2f67ff1a,0 18px 34px #2f67f61f;transform:skew(-15deg)}.density-charts-hero-visual .hero-grid{position:absolute;right:50px;top:30px;width:258px;height:72px;border-bottom:1px solid rgba(47,103,246,.18);border-left:1px solid rgba(47,103,246,.18);background:linear-gradient(rgba(47,103,246,.12) 1px,transparent 1px),linear-gradient(90deg,rgba(47,103,246,.1) 1px,transparent 1px);background-size:52px 24px;transform:skew(-15deg)}.density-charts-hero-visual .hero-ring{position:absolute;right:306px;top:32px;width:76px;height:76px;border:8px solid rgba(255,255,255,.88);border-left-color:#2f67ff3d;border-bottom-color:#7b61ff47;border-radius:50%;box-shadow:0 18px 36px #4f60ff24;transform:rotate(-32deg)}.density-charts-hero-visual .hero-line{position:absolute;right:64px;bottom:32px;width:236px;height:82px;background:linear-gradient(135deg,transparent 0 9%,#6f8fff 9% 12%,transparent 12% 23%,#7b61ff 23% 26%,transparent 26% 39%,#3f76ff 39% 42%,transparent 42% 55%,#7662ff 55% 58%,transparent 58% 73%,#3f76ff 73% 77%,transparent 77%),linear-gradient(180deg,#7063ff4d,#7063ff0a);clip-path:polygon(0 82%,14% 55%,26% 64%,39% 38%,51% 52%,64% 22%,77% 32%,88% 8%,100% 0,100% 100%,0 100%);opacity:.9}.density-charts-hero-visual .hero-dot{position:absolute;display:block;width:15px;height:15px;border-radius:50%;background:radial-gradient(circle at 35% 35%,#fff,#77a1ff 70%);box-shadow:0 9px 22px #2f67f633}.density-charts-hero-visual .dot-one{right:240px;top:52px}.density-charts-hero-visual .dot-two{right:154px;top:32px}.density-charts-hero-visual .dot-three{right:58px;top:60px;opacity:.72}.density-charts-hero-visual .hero-bar{position:absolute;bottom:32px;width:22px;border-radius:9px 9px 3px 3px;background:linear-gradient(180deg,#8196fff2,#2f67ff9e);box-shadow:0 14px 26px #2f67f626}.density-charts-hero-visual .bar-one{right:250px;height:42px}.density-charts-hero-visual .bar-two{right:210px;height:64px}.density-charts-hero-visual .bar-three{right:170px;height:52px}.density-charts-hero-visual .hero-kpi{position:absolute;right:52px;top:24px;display:inline-flex;align-items:center;justify-content:center;height:32px;min-width:76px;padding:0 12px;border:1px solid rgba(47,103,255,.14);border-radius:999px;background:#ffffffdb;color:#245fff;font-size:13px;font-weight:950;box-shadow:0 12px 24px #2f67f61f}.density-charts-hero-visual .hero-platform{position:absolute;right:34px;bottom:24px;width:292px;height:42px;border-radius:50%;background:linear-gradient(90deg,#2f67f600,#2f67f62e,#2f67f600);transform:skew(-18deg)}.density-chart-metric-strip{grid-template-columns:repeat(4,minmax(0,1fr));gap:16px}.density-chart-metric-strip .density-chart-metric-card{position:relative;display:grid;grid-template-columns:44px minmax(0,1fr);grid-template-rows:auto auto auto;column-gap:12px;align-items:center;min-height:116px;padding:19px 16px;border:1px solid rgba(221,230,244,.96);border-radius:14px;background:linear-gradient(180deg,#fffffffc,#f9fcfffa);box-shadow:0 16px 32px #244c9412}.density-chart-metric-strip .density-chart-metric-icon{grid-row:1/4;display:grid;place-items:center;align-self:center;justify-self:center;overflow:visible;width:44px;height:44px;border-radius:14px;color:#3267f6;background:linear-gradient(135deg,#eef4ff,#dfe8ff);box-shadow:0 12px 26px #2f67f61f;line-height:1}.density-chart-metric-strip .density-chart-metric-icon svg{display:block;width:25px;height:25px}.density-chart-metric-card span:not(.density-chart-metric-icon){min-width:0;color:#52617b;font-size:13px;font-weight:400}.density-chart-metric-card strong{display:block;overflow:visible;margin:7px 0 6px;color:#3267f6;font-size:28px;line-height:1.05;font-weight:950;text-overflow:clip;white-space:nowrap}.density-chart-metric-card em{min-width:0;color:#617087;font-size:12px;font-style:normal;font-weight:800}.density-chart-metric-card.is-green .density-chart-metric-icon{color:#21b96d;background:linear-gradient(135deg,#effcf4,#dcf7e8);box-shadow:0 12px 26px #25c27624}.density-chart-metric-card.is-green strong{color:#20b86c}.density-chart-metric-card.is-purple .density-chart-metric-icon{color:#7b61ff;background:linear-gradient(135deg,#f3f0ff,#e7e1ff);box-shadow:0 12px 26px #7b61ff24}.density-chart-metric-card.is-purple strong{color:#7b61ff}.density-chart-metric-card.is-orange .density-chart-metric-icon{color:#ff9a1f;background:linear-gradient(135deg,#fff8ed,#fff0da);box-shadow:0 12px 26px #ff9a1f24}.density-chart-metric-card.is-orange strong{color:#ff8a1d}.density-charts-page .analysis-four-chart-grid{gap:16px;margin-top:0}.density-charts-page .analysis-chart-card{position:relative;min-height:354px;padding:20px 22px 18px;overflow:hidden;border:1px solid rgba(190,204,226,.78);border-radius:14px;background:linear-gradient(180deg,#fffffffc,#f6f9fdfa),linear-gradient(135deg,#2f67ff14,#10b9810d 46%,#f59e0b0f);box-shadow:0 22px 46px #244c941a,inset 0 1px #ffffffeb}.density-charts-page .analysis-chart-card:before{position:absolute;top:0;left:22px;right:22px;height:3px;border-radius:0 0 999px 999px;background:linear-gradient(90deg,#2f67ff,#7b61ff);content:"";opacity:.78}.density-charts-page .analysis-chart-card h3{position:relative;z-index:2;display:flex;align-items:center;gap:12px;margin:0 0 13px;border-bottom:0;padding:0;color:#132746;font-size:14px;font-weight:950}.density-charts-page .chart-title-icon{flex:0 0 auto;display:grid;place-items:center;width:36px;height:36px;border-radius:12px;background:linear-gradient(135deg,#2f67ff,#77a2ff);color:#fff;font-size:12px;line-height:1;font-weight:950;box-shadow:0 12px 24px #2f67f629}.density-charts-page .analysis-chart-card.is-line .chart-title-icon{background:linear-gradient(135deg,#7b61ff,#9b8cff)}.density-charts-page .analysis-chart-card.is-density .chart-title-icon{background:linear-gradient(135deg,#21b96d,#65d59a)}.density-charts-page .analysis-chart-card.is-trend .chart-title-icon{background:linear-gradient(135deg,#ff961f,#ffbd6f)}.density-charts-page .chart-title-copy{display:flex;min-width:0;flex-direction:column;gap:4px}.density-charts-page .chart-title-copy strong,.density-charts-page .chart-title-copy small{display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.density-charts-page .chart-title-copy strong{color:#102046;font-size:15px;font-weight:950}.density-charts-page .chart-title-copy small{color:#6a7690;font-size:12px;font-weight:800}.density-charts-page .chart-placeholder{position:relative;z-index:1;height:260px;overflow:hidden;padding:12px 14px 8px;border:1px solid rgba(213,224,240,.78);border-radius:12px;background:linear-gradient(180deg,#fffffff0,#f4f8fde0),linear-gradient(rgba(47,103,246,.08) 1px,transparent 1px),linear-gradient(90deg,rgba(47,103,246,.06) 1px,transparent 1px);background-size:auto,100% 44px,56px 100%;box-shadow:inset 0 1px #ffffffeb,inset 0 -18px 34px #2f67f60a}.density-charts-page .chart-placeholder:after{position:absolute;inset:0;z-index:0;background:linear-gradient(120deg,transparent 0 62%,rgba(255,255,255,.46) 62% 64%,transparent 64%),linear-gradient(180deg,rgba(255,255,255,.38),transparent 34%);content:"";pointer-events:none}.density-charts-page .chart-placeholder canvas{position:relative;z-index:2}.density-charts-page .density-chart-tip{min-height:92px;padding:18px 244px 18px 80px;border-radius:14px;background:linear-gradient(90deg,#fffffffa,#f9fcfffa 58%,#e8f0fff5)}.density-charts-page .density-chart-tip:before{position:absolute;left:24px;top:23px;width:42px;height:42px;background:linear-gradient(135deg,#2f67ff,#72a2ff);color:#fff}.density-charts-page .density-chart-tip:after{right:36px;bottom:-4px;width:182px;height:86px;border-radius:0;background:linear-gradient(135deg,#2f67f624,#75a4ff38),linear-gradient(90deg,transparent 8%,rgba(47,103,246,.2) 8% 16%,transparent 16% 34%,rgba(47,103,246,.12) 34% 42%,transparent 42%);clip-path:polygon(4% 68%,22% 55%,34% 32%,50% 54%,64% 20%,86% 38%,96% 80%,12% 88%);opacity:.78}.density-charts-page .density-chart-tip strong,.density-charts-page .density-chart-tip p{grid-column:auto}.density-worksheet-page{gap:13px}.density-worksheet-page .worksheet-hero{justify-content:flex-start;min-height:96px;padding:20px 28px;border:0;border-radius:10px;background:linear-gradient(90deg,#2f57effa,#4b70fff0 54%,#78a6ffe0);box-shadow:0 16px 34px #2f67f633;color:#fff}.density-worksheet-page .worksheet-hero:before{position:absolute;right:40px;bottom:-18px;width:390px;height:110px;background:repeating-linear-gradient(90deg,transparent 0 20px,rgba(255,255,255,.18) 20px 31px),linear-gradient(180deg,transparent 0%,rgba(255,255,255,.18) 100%);clip-path:polygon(0 78%,9% 70%,18% 74%,27% 58%,36% 63%,45% 48%,55% 52%,65% 30%,74% 36%,84% 10%,100% 0,100% 100%,0 100%);content:"";opacity:.55}.density-worksheet-page .worksheet-hero:after{right:138px;top:12px;width:330px;height:80px;border-radius:0;background:radial-gradient(circle at 18% 54%,rgba(255,255,255,.28) 0 2px,transparent 3px),radial-gradient(circle at 42% 42%,rgba(255,255,255,.25) 0 2px,transparent 3px),radial-gradient(circle at 66% 68%,rgba(255,255,255,.26) 0 2px,transparent 3px),linear-gradient(145deg,transparent 0 15%,rgba(255,255,255,.22) 16% 17%,transparent 18% 41%,rgba(255,255,255,.18) 42% 43%,transparent 44%);clip-path:none;opacity:.74}.density-worksheet-page .analysis-hero-icon{width:58px;height:58px;border-radius:16px;background:linear-gradient(135deg,#f3f7ff,#dce7ff);color:#4f6fff;box-shadow:inset 0 0 0 4px #ffffffad,0 10px 24px #0e28823d}.density-worksheet-page .analysis-hero-icon svg{width:34px;height:34px}.density-worksheet-page .worksheet-hero h2{margin:0 0 8px;color:#fff;font-size:22px;font-weight:950}.density-worksheet-page .worksheet-hero p{max-width:none;color:#ffffffdb;font-size:13px;font-weight:700}.worksheet-hero-heart{position:absolute;right:152px;top:22px;z-index:2;display:grid;place-items:center;width:38px;height:38px;border-radius:50%;background:#ffffff2e;color:#fff}.worksheet-hero-heart svg{width:20px;height:20px;opacity:.92}.density-metric-strip{grid-template-columns:repeat(5,minmax(0,1fr))}.density-metric-strip .density-metric-card{position:relative;display:grid;grid-template-columns:46px minmax(0,1fr);grid-template-rows:auto auto;column-gap:13px;align-items:center;min-height:76px;padding:16px 18px;border-radius:10px;overflow:hidden}.density-metric-strip .metric-icon{grid-row:1/3;display:grid;place-items:center;width:42px;height:42px;border-radius:50%;color:#fff;box-shadow:0 10px 22px #244c9421}.density-metric-strip .metric-icon svg{width:23px;height:23px}.density-metric-card span:not(.metric-icon){align-self:end;min-width:0;color:#65728c;font-size:12px;font-weight:400}.density-metric-card strong{display:inline;overflow:visible;margin:4px 4px 0 0;color:#1f5fff;font-size:21px;line-height:1.1;font-weight:950;text-overflow:clip}.density-metric-card em{display:inline;align-self:start;color:#6f7890;font-size:12px;font-weight:400}.density-metric-card.is-violet .metric-icon{background:linear-gradient(135deg,#7362ff,#553fff)}.density-metric-card.is-green .metric-icon{background:linear-gradient(135deg,#58c987,#25b86f)}.density-metric-card.is-orange .metric-icon{background:linear-gradient(135deg,#ffac4e,#ff7a1a)}.density-metric-card.is-blue .metric-icon{background:linear-gradient(135deg,#4f8aff,#2762ef)}.density-metric-card.is-cyan .metric-icon{background:linear-gradient(135deg,#45c5d6,#28a7bb)}.density-metric-card.is-green strong{color:#23b96e}.density-metric-card.is-orange strong{color:#ff7a1a}.density-metric-card.is-cyan strong{color:#24a7ba}.density-course-info{display:none}.density-worksheet-page .analysis-record-card{padding:16px}.density-worksheet-page .record-table-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.density-worksheet-page .section-title{color:#0f1d3d;font-size:15px;font-weight:950}.density-worksheet-page .data-table-section{margin-bottom:0;border:1px solid #dfe7f3;border-radius:9px;overflow:auto}.density-worksheet-page table.activity-table{min-width:860px;border:0;table-layout:fixed}.density-worksheet-page .activity-table thead{background:linear-gradient(180deg,#fbfdff,#f4f7fc)}.density-worksheet-page .activity-table th{height:34px;padding:8px 10px;color:#23324f;font-size:12px;font-weight:400}.density-worksheet-page .activity-table th:first-child{width:154px}.density-worksheet-page .activity-table th:last-child{width:112px}.density-worksheet-page .activity-table td{height:41px;padding:6px 9px;color:#253454;font-size:12px;font-weight:750}.density-worksheet-page .row-label{background:#fbfdff;color:#263752;font-size:12px;font-weight:400;text-align:left}.density-worksheet-page .row-icon{display:inline-grid;place-items:center;width:17px;height:17px;margin-right:8px;color:#73819b;font-size:15px;line-height:1;vertical-align:-2px}.density-worksheet-page .table-input,.density-worksheet-page .analysis-heart-card input{min-height:27px;border-radius:6px;color:#22304e;font-size:12px;font-weight:400}.density-worksheet-page .table-input.readonly-data{border-color:transparent;background:transparent;box-shadow:none}.density-worksheet-page .table-input:not(.readonly-data){background:linear-gradient(180deg,#fff,#f9fbff)}.density-worksheet-page .table-input.calculated{border-color:#3067f633;background:linear-gradient(180deg,#f7fbff,#eef5ff);color:#2364ff}.density-worksheet-page .table-input.calculated.is-good{border-color:#25c27638;background:#eefaf3;color:#1da861}.density-worksheet-page .table-input.calculated.is-high,.density-worksheet-page .table-input.calculated.is-low{border-color:#ff973c40;background:#fff7e8;color:#ff6d1d}.density-worksheet-page .table-input.calculated.is-empty{border-color:#3067f629;background:#f3f7ff;color:#2364ff}.density-worksheet-page .analysis-heart-card{padding:0;border:0;background:transparent;box-shadow:none}.density-worksheet-page .bottom-controls{display:block}.density-worksheet-page .analysis-heart-card .heart-rate-inputs{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px}.heart-input-card{position:relative;display:grid;grid-template-columns:38px minmax(0,1fr);grid-template-rows:auto auto;column-gap:14px;min-height:68px;padding:14px 18px 14px 64px;border:1px solid rgba(221,230,244,.96);border-radius:10px;background:#fffffff5;box-shadow:0 14px 32px #244c9412}.heart-input-card .heart-input-icon{position:absolute;left:18px;top:19px;color:#6b55ff;font-size:28px;line-height:1}.heart-input-card.is-orange .heart-input-icon{color:#ff8a1d}.heart-input-card.is-blue .heart-input-icon{color:#2f67ff}.density-worksheet-page .heart-input-card label{grid-column:1/-1;margin-bottom:7px;color:#52617b;font-size:12px;font-weight:400}.density-worksheet-page .heart-input-card input{grid-column:1/-1;width:min(100%,160px);height:28px;min-height:28px;text-align:left}.density-worksheet-page .analysis-chart-row{gap:14px}.density-worksheet-page .analysis-chart-card{min-height:214px;padding:16px 18px 18px;border-radius:10px}.density-worksheet-page .analysis-chart-card h3{position:relative;margin-bottom:8px;border-bottom:0;padding-bottom:0;color:#152546;font-size:15px;font-weight:950}.density-worksheet-page .analysis-chart-card h3:after{display:inline-block;width:22px;height:2px;margin-left:10px;border-radius:999px;background:linear-gradient(90deg,#3267f6,#3267f600);content:"";vertical-align:middle}.density-worksheet-page .chart-placeholder{height:170px;padding:8px 12px;border-radius:0;background:linear-gradient(180deg,#fffffff5,#fffffffa),repeating-linear-gradient(0deg,rgba(217,226,240,.55) 0,rgba(217,226,240,.55) 1px,transparent 1px,transparent 25px)}.density-worksheet-page .analysis-tip-card{min-height:82px;padding:16px 230px 16px 72px;border-radius:10px;background:linear-gradient(90deg,#fffffffa,#f9fcfffa 60%,#e8f0fff5)}.density-worksheet-page .analysis-tip-card:before{position:absolute;left:18px;top:18px;width:38px;height:38px;background:linear-gradient(135deg,#7ba4ff,#4d6cff);color:#fff;content:"i"}.density-worksheet-page .analysis-tip-card:after{right:28px;bottom:0;width:168px;height:76px;border-radius:0;background:linear-gradient(135deg,#2f67f629,#75a4ff38),linear-gradient(90deg,transparent 16%,rgba(47,103,246,.2) 16% 24%,transparent 24% 38%,rgba(47,103,246,.14) 38% 44%,transparent 44%);clip-path:polygon(20% 35%,40% 20%,75% 16%,88% 35%,78% 86%,22% 86%,8% 62%);opacity:.78}.density-worksheet-page .analysis-tip-card strong,.density-worksheet-page .analysis-tip-card p{grid-column:auto}.density-worksheet-page .analysis-tip-card strong{color:#173160;font-size:16px}.density-worksheet-page .analysis-tip-card p{color:#53627d;font-size:12px}.analysis-tip-card{position:relative;display:grid;grid-template-columns:42px minmax(0,1fr);gap:14px;align-items:center;min-height:72px;padding:16px 18px;overflow:hidden}.analysis-tip-card:before{display:grid;place-items:center;width:42px;height:42px;border-radius:50%;background:linear-gradient(135deg,#eef4ff,#dfe8ff);color:var(--ui-blue);content:"i";font-size:16px;font-weight:950}.analysis-tip-card:after{position:absolute;right:26px;bottom:-14px;width:94px;height:94px;border-radius:50%;background:radial-gradient(circle,rgba(47,103,255,.16),transparent 64%);content:""}.analysis-tip-card strong,.analysis-tip-card p{grid-column:2;margin:0}.analysis-tip-card strong{color:#102046;font-size:16px;font-weight:400}.analysis-tip-card p{color:#52617b;font-size:13px;line-height:1.65}.analysis-energy-summary{gap:14px;margin-bottom:0}.analysis-energy-summary .energy-total-card,.analysis-energy-summary .energy-mini-card{min-height:110px;border-radius:12px;padding:18px 20px}.analysis-energy-summary .energy-total-card{background:linear-gradient(135deg,#4c72ff,#7b61ff)}.energy-analysis-page{max-width:100%}.energy-course-state{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:14px 18px;border:1px solid #dfe7f3}.energy-course-state div{display:flex;min-width:0;flex-direction:column;gap:4px}.energy-course-state span{color:#6a7690;font-size:12px;font-weight:800}.energy-course-state strong{overflow:hidden;color:#102046;font-size:15px;font-weight:400;text-overflow:ellipsis;white-space:nowrap}.energy-course-state em{flex:0 0 auto;color:#3267d6;font-size:13px;font-style:normal;font-weight:400}.energy-course-state .is-error{color:#d92d20}.energy-course-state .is-warning{color:#b54708}.energy-analysis-page .energy-chart-section .chart-placeholder{height:285px}.energy-action-row{display:flex;align-items:center;gap:12px;justify-content:flex-end;padding-top:14px}.energy-save-message{color:#3267d6;font-size:13px;font-weight:800}.energy-analysis-page{gap:14px;max-width:100%}.energy-analysis-page .energy-hero{height:142px;min-height:142px;padding:24px 34px;border-color:#d3def2fa;border-radius:14px;background:linear-gradient(105deg,#fffffffc,#fafdfffa 47%,#e7edfff5);box-shadow:0 16px 34px #244c9412}.energy-analysis-page .energy-hero:after{display:none}.energy-hero-copy{max-width:600px}.energy-hero-copy .professional-kicker{color:#355cff;font-size:13px;font-weight:950}.energy-hero-copy h2{margin:8px 0 10px;color:#0d1d3d;font-size:28px;font-weight:950}.energy-hero-copy p{color:#53627d;font-size:14px;font-weight:760}.energy-hero-visual{position:absolute;inset:0 0 0 auto;width:440px;pointer-events:none}.energy-hero-visual .hero-platform{position:absolute;right:42px;bottom:26px;width:264px;height:54px;border-radius:50%;background:linear-gradient(90deg,#4f60ff00,#4f60ff2e,#4f60ff00);transform:skew(-18deg)}.energy-hero-visual .hero-ring{position:absolute;right:32px;top:28px;width:94px;height:94px;border:9px solid rgba(255,255,255,.88);border-left-color:#4f60ff3d;border-radius:50%;box-shadow:0 18px 36px #4f60ff29}.energy-hero-visual .hero-bars{position:absolute;bottom:28px;width:28px;border-radius:9px 9px 3px 3px;background:linear-gradient(180deg,#8196fff5,#4f60ffad);box-shadow:0 16px 30px #4f60ff2e}.energy-hero-visual .bar-one{right:236px;height:60px}.energy-hero-visual .bar-two{right:192px;height:82px}.energy-hero-visual .bar-three{right:148px;height:68px}.energy-hero-visual .bar-four{right:104px;height:92px}.energy-hero-visual .hero-runner{position:absolute;left:58px;bottom:38px;width:34px;height:42px;border-radius:18px 18px 10px 10px;background:linear-gradient(135deg,#3f63ff,#78a0ff);transform:rotate(-8deg)}.energy-hero-visual .hero-runner:before{position:absolute;left:9px;top:-19px;width:15px;height:15px;border-radius:50%;background:#4d65ff;content:""}.energy-hero-visual .hero-runner:after{position:absolute;left:-18px;bottom:-9px;width:70px;height:16px;border-radius:50%;background:#4f60ff1f;content:""}.energy-metric-strip{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:16px}.energy-metric-card{position:relative;display:grid;grid-template-columns:48px minmax(0,1fr);grid-template-rows:auto auto auto;column-gap:16px;min-width:0;min-height:108px;padding:19px 22px;border:1px solid rgba(221,230,244,.96);border-radius:13px;background:#fffffffa;box-shadow:0 16px 32px #244c9412}.energy-metric-icon{grid-row:1/4;display:grid;place-items:center;width:46px;height:46px;border-radius:15px;color:#5b63ff;background:linear-gradient(135deg,#f0f2ff,#e3e8ff);box-shadow:0 12px 24px #4f60ff1f}.energy-metric-icon svg{width:26px;height:26px}.energy-metric-card>span:not(.energy-metric-icon),.energy-metric-card em{display:block;overflow:hidden;color:#52617b;font-size:13px;line-height:1.35;font-style:normal;font-weight:400;text-overflow:ellipsis;white-space:nowrap}.energy-metric-card strong{display:block;overflow:hidden;margin:7px 0 6px;color:#0d1d3d;font-size:27px;line-height:1.05;font-weight:950;text-overflow:ellipsis;white-space:nowrap}.energy-metric-card small{margin-left:4px;color:#0d1d3d;font-size:13px;font-weight:400}.energy-metric-card.is-blue .energy-metric-icon{color:#2f67ff;background:linear-gradient(135deg,#eef4ff,#dfe9ff)}.energy-metric-card.is-orange .energy-metric-icon{color:#ff9b1f;background:linear-gradient(135deg,#fff7ea,#ffe8c6)}.energy-metric-card.is-green .energy-metric-icon{color:#23b973;background:linear-gradient(135deg,#ecfbf3,#d7f5e5)}.energy-metric-card.is-green strong{font-size:22px}.energy-stage-strip{display:grid;grid-template-columns:repeat(6,minmax(0,1fr));gap:14px;padding:14px 16px;border:1px solid rgba(221,230,244,.96);border-radius:14px;background:#fffffffa;box-shadow:0 16px 32px #244c9412}.energy-stage-card{display:grid;grid-template-columns:42px minmax(0,1fr);gap:12px;align-items:center;min-width:0;min-height:82px;padding:12px 14px;border:1px solid #e4ebf6;border-radius:10px;background:#fff}.energy-stage-card .stage-icon{display:grid;place-items:center;width:42px;height:42px;border-radius:12px;color:#22b979;background:#e8f8ef;font-size:22px;font-weight:950}.energy-stage-card div{min-width:0}.energy-stage-card span:not(.stage-icon),.energy-stage-card em,.energy-stage-card small{display:block;overflow:hidden;color:#65718a;font-size:12px;line-height:1.25;font-style:normal;font-weight:820;text-overflow:ellipsis;white-space:nowrap}.energy-stage-card strong{display:inline-block;margin:4px 4px 2px 0;color:#0d1d3d;font-size:21px;line-height:1;font-weight:950}.energy-stage-card em{display:inline-block}.energy-stage-card small{margin-top:3px}.energy-stage-card.is-blue .stage-icon{color:#2f67ff;background:#edf3ff}.energy-stage-card.is-purple .stage-icon,.energy-stage-card.is-violet .stage-icon{color:#765dff;background:#f0edff}.energy-stage-card.is-orange .stage-icon{color:#ff931e;background:#fff3e1}.energy-stage-card.is-cyan .stage-icon{color:#21b9c3;background:#e8fbfd}.energy-stage-empty{grid-column:1/-1;padding:18px;color:#66738d;font-size:13px;font-weight:400;text-align:center}.energy-analysis-page .energy-chart-section{padding:22px 24px 20px;border-radius:14px}.energy-analysis-page .energy-chart-section h3{display:flex;align-items:center;justify-content:space-between;margin:0 0 16px;border-bottom:0;padding:0;color:#0d1d3d;font-size:16px;font-weight:950}.energy-analysis-page .energy-chart-section h3 span{color:#5b63ff;font-size:13px;font-weight:400}.energy-analysis-page .energy-chart-section .chart-placeholder{height:218px;padding:6px 8px 0;border-radius:0;background:linear-gradient(180deg,#fffffffa,#fffffffa),repeating-linear-gradient(0deg,rgba(217,226,240,.52) 0,rgba(217,226,240,.52) 1px,transparent 1px,transparent 40px)}.energy-analysis-page .energy-analysis-tip{min-height:88px;padding:16px 244px 16px 80px;border-radius:14px;background:linear-gradient(90deg,#fffffffa,#f9fcfffa 58%,#e8f0fff5)}.energy-analysis-page .energy-analysis-tip:before{position:absolute;left:24px;top:20px;width:42px;height:42px;background:linear-gradient(135deg,#7864ff,#94a5ff);color:#fff;content:"i"}.energy-analysis-page .energy-analysis-tip:after{right:34px;bottom:-8px;width:162px;height:76px;border-radius:0;background:linear-gradient(135deg,#4f60ff1f,#75a4ff33),linear-gradient(90deg,transparent 20%,rgba(79,96,255,.18) 20% 28%,transparent 28% 48%,rgba(79,96,255,.12) 48% 56%,transparent 56%);clip-path:polygon(22% 18%,64% 4%,88% 24%,82% 92%,18% 92%,4% 38%);opacity:.78}.energy-analysis-page .energy-analysis-tip strong,.energy-analysis-page .energy-analysis-tip p{grid-column:auto}.density-evaluation-page{gap:14px}.density-evaluation-page .evaluation-hero{height:140px;min-height:140px;padding:24px 34px;border-color:#d3def2fa;border-radius:14px;background:linear-gradient(100deg,#fffffffa,#fafdfffa 54%,#ebf2fff5);box-shadow:0 16px 34px #244c9412}.density-evaluation-page .evaluation-hero:after{display:none}.density-evaluation-hero-copy{max-width:650px}.density-evaluation-hero-copy .professional-kicker{color:#2f67ff;font-size:12px;font-weight:950}.density-evaluation-hero-copy h2{margin:8px 0;color:#0d1d3d;font-size:26px;font-weight:950}.density-evaluation-hero-copy p{color:#53627d;font-size:13px;font-weight:750}.density-evaluation-hero-visual{position:absolute;inset:0 0 0 auto;width:370px;pointer-events:none}.density-evaluation-hero-visual .hero-board{position:absolute;right:24px;top:18px;width:260px;height:104px;border-radius:28px;background:linear-gradient(135deg,#2f67ff0f,#2f67ff2e),linear-gradient(120deg,transparent 0 26%,rgba(255,255,255,.34) 26% 28%,transparent 28% 54%,rgba(255,255,255,.28) 54% 56%,transparent 56%);box-shadow:inset 0 0 0 1px #2f67ff1a,0 18px 34px #2f67f61f;transform:skew(-15deg)}.density-evaluation-hero-visual .hero-path{position:absolute;right:34px;top:46px;width:238px;height:48px;border-top:4px solid rgba(47,103,246,.42);border-radius:50%;clip-path:polygon(0 0,100% 0,100% 60%,0 88%)}.density-evaluation-hero-visual .hero-runner{position:absolute;right:88px;top:58px;width:34px;height:42px;border-radius:18px 18px 10px 10px;background:linear-gradient(135deg,#2f67ff,#70a1ff);box-shadow:0 10px 24px #2f67f640}.density-evaluation-hero-visual .hero-runner:before{position:absolute;left:10px;top:-18px;width:16px;height:16px;border-radius:50%;background:#2f67ff;content:""}.density-evaluation-hero-visual .hero-runner:after{position:absolute;left:-12px;bottom:-10px;width:58px;height:16px;border-radius:50%;background:#2f67f61f;content:""}.density-evaluation-hero-visual .hero-bars{position:absolute;left:30px;top:58px;width:74px;height:46px;background:linear-gradient(180deg,#3f76ff,#245fff) 0 26px/12px 20px no-repeat,linear-gradient(180deg,#3f76ff,#245fff) 22px 14px/12px 32px no-repeat,linear-gradient(180deg,#3f76ff,#245fff) 44px 2px/12px 44px no-repeat}.density-evaluation-hero-visual .hero-bars:before{position:absolute;left:0;top:-14px;width:62px;height:38px;border-top:4px solid #79a3ff;border-right:4px solid #2f67ff;content:"";transform:skewY(-28deg)}.density-evaluation-summary{display:grid;grid-template-columns:1.05fr repeat(2,minmax(0,1fr));gap:18px}.density-evaluation-summary article{min-width:0;min-height:148px;border:1px solid rgba(221,230,244,.96);border-radius:14px;background:#fffffffa;box-shadow:0 18px 34px #244c9412}.density-evaluation-summary .density-evaluation-score-card{position:relative;display:block;overflow:hidden;padding:26px 24px 24px 28px;border-color:#2f67f633;background:radial-gradient(circle at 78% 42%,rgba(255,255,255,.22),transparent 34%),linear-gradient(135deg,#1f5fff,#78a5ff);color:#fff}.density-evaluation-summary .density-evaluation-score-card:after{position:absolute;right:40px;top:32px;width:98px;height:98px;border-radius:50%;border:14px solid rgba(255,255,255,.26);border-left-color:#ffffff0f;content:"";transform:rotate(-32deg)}.density-evaluation-score-card>div{position:relative;z-index:1;max-width:150px}.density-evaluation-score-card span,.density-evaluation-score-card em{position:relative;z-index:1;display:block;font-style:normal;font-weight:400}.density-evaluation-score-card span{font-size:14px}.density-evaluation-score-card strong{position:relative;z-index:1;display:block;margin:16px 0 12px;color:#fff;font-size:44px;line-height:.9;font-weight:950}.density-evaluation-score-card small{font-size:20px;font-weight:400}.density-evaluation-score-card b{display:inline-block;margin-left:8px;padding:4px 10px;border-radius:999px;background:#ffffff38;color:#fff;font-size:13px}.density-evaluation-score-card .score-progress-ring{position:absolute;right:24px;top:36px;z-index:1;width:76px;height:76px;border-radius:50%;background:radial-gradient(circle at center,rgba(47,103,246,.58) 0 48%,transparent 49%),conic-gradient(rgba(255,255,255,.86) var(--score-progress),rgba(255,255,255,.25) 0)}.density-evaluation-metric-card{position:relative;padding:24px 22px 20px 78px}.density-evaluation-metric-card .metric-badge{position:absolute;left:24px;top:28px;display:grid;place-items:center;width:34px;height:34px;border-radius:12px;background:linear-gradient(135deg,#eef4ff,#dfe8ff);color:#3267f6;font-size:18px;font-weight:950;box-shadow:0 10px 22px #2f67f621}.density-evaluation-metric-card>span:not(.metric-badge),.density-evaluation-metric-card em{display:block;overflow:hidden;color:#51607b;font-size:13px;line-height:1.35;font-style:normal;font-weight:400;text-overflow:ellipsis;white-space:nowrap}.density-evaluation-metric-card strong{display:block;margin:20px 0 18px;color:#2f67ff;font-size:37px;line-height:.9;font-weight:950}.density-evaluation-metric-card small{font-size:17px;font-weight:400}.density-evaluation-metric-card.is-green .metric-badge{background:linear-gradient(135deg,#e7fbf0,#c9f4dc);color:#18a45f}.density-evaluation-metric-card.is-green strong{color:#18a45f}.density-evaluation-metric-card.is-orange .metric-badge{background:linear-gradient(135deg,#fff6e9,#ffe7c2);color:#ff8a1d}.density-evaluation-metric-card.is-orange strong{color:#ff7a1a}.density-evaluation-workbench{display:grid;grid-template-columns:minmax(0,1fr);gap:16px;align-items:stretch}.density-evaluation-page .evaluation-table-section{width:100%;min-width:0;padding:0;overflow:hidden}.density-evaluation-page .evaluation-table{width:100%;border:0;table-layout:fixed}.density-evaluation-page .evaluation-table thead{background:linear-gradient(180deg,#fbfdff,#f4f7fc)}.density-evaluation-page .evaluation-table th,.density-evaluation-page .evaluation-table td{height:47px;border-color:#e1e8f4;color:#132342;font-size:13px;font-weight:400}.density-evaluation-page .evaluation-table th{font-weight:950}.density-evaluation-page .evaluation-table th:first-child,.density-evaluation-page .evaluation-table td:first-child{width:150px;padding-left:28px;text-align:left}.achievement-rate-button{display:inline-flex;align-items:center;justify-content:center;min-width:52px;height:28px;padding:0 10px;border:1px solid #cfe0ff;border-radius:9px;background:#eef4ff;color:#2f67ff;font:inherit;font-size:13px;font-weight:950;cursor:pointer}.achievement-rate-button:hover{border-color:#94b7ff;background:#e1ecff}.heart-recovery-dialog-backdrop{position:fixed;inset:0;z-index:80;display:grid;place-items:center;padding:22px;background:#0c18306b}.heart-recovery-rule-dialog{display:grid;gap:14px;width:min(860px,100%);max-height:min(720px,100vh - 44px);overflow:auto;padding:18px 20px;border:1px solid #dce7f7;border-radius:14px;background:linear-gradient(180deg,#fffffffa,#f7fafffa);box-shadow:0 14px 32px #2f67f614}.heart-recovery-rule-head{display:flex;align-items:center;justify-content:space-between;gap:14px;padding-right:42px;position:relative}.heart-recovery-rule-head>div{display:grid;gap:4px}.heart-recovery-rule-head span,.heart-recovery-current em{color:#667794;font-size:12px;font-weight:400}.heart-recovery-rule-head strong{color:#132342;font-size:28px;line-height:1;font-weight:950}.heart-recovery-rule-head>em{display:inline-flex;align-items:center;justify-content:center;min-height:34px;padding:0 12px;border-radius:10px;background:#eef4ff;color:#2f67ff;font-size:13px;font-style:normal;font-weight:950;white-space:nowrap}.dialog-close-button{position:absolute;top:0;right:0;display:grid;width:34px;height:34px;place-items:center;border:1px solid #dce7f7;border-radius:10px;background:#fff;color:#51617c;font-size:24px;line-height:1;cursor:pointer}.dialog-close-button:hover{background:#f5f8fd;color:#2f67ff}.heart-recovery-formula,.heart-recovery-source{margin:0}.heart-recovery-formula{padding:11px 12px;border-radius:10px;background:#f5f8fd;color:#243653;font-size:13px;font-weight:400;line-height:1.7}.heart-recovery-source{color:#667794;font-size:12px;font-weight:800;line-height:1.65}.heart-recovery-current{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:10px}.heart-recovery-current span{display:grid;gap:6px;min-width:0;padding:12px;border:1px solid #e4ecf8;border-radius:12px;background:#fff}.heart-recovery-current strong{min-width:0;color:#142342;font-size:16px;line-height:1.15;font-weight:950;overflow-wrap:anywhere}.evaluation-badge{display:inline-flex;align-items:center;justify-content:center;min-width:66px;height:28px;padding:0 14px;border-radius:10px;font-size:13px;font-weight:950}.evaluation-badge.is-green{background:#e7f8ef;color:#119858}.evaluation-badge.is-blue{background:#eaf2ff;color:#2364ff}.evaluation-badge.is-purple{background:#f0edff;color:#755cff}.evaluation-badge.is-orange{background:#fff2e3;color:#ff741c}.evaluation-badge.is-red{background:#ffeded;color:#e94b52}.density-evaluation-page .density-evaluation-tip{min-height:104px;padding:22px 250px 22px 86px;border-radius:14px;background:linear-gradient(90deg,#fffffffa,#f9fcfffa 58%,#e8f0fff5)}.density-evaluation-page .density-evaluation-tip:before{position:absolute;left:28px;top:25px;width:46px;height:46px;background:linear-gradient(135deg,#2f67ff,#72a2ff);color:#fff;content:"i"}.density-evaluation-page .density-evaluation-tip:after{right:36px;bottom:-2px;width:182px;height:92px;border-radius:0;background:linear-gradient(135deg,#2f67f61f,#75a4ff33),linear-gradient(90deg,transparent 12%,rgba(47,103,246,.16) 12% 20%,transparent 20% 38%,rgba(47,103,246,.12) 38% 46%,transparent 46%);clip-path:polygon(14% 34%,42% 14%,66% 32%,78% 8%,96% 22%,100% 88%,12% 88%);opacity:.78}.density-evaluation-page .density-evaluation-tip strong,.density-evaluation-page .density-evaluation-tip p{grid-column:auto}.density-evaluation-page .evaluation-analysis-lines{position:relative;z-index:1;display:grid;grid-column:auto;gap:7px}.density-evaluation-page .evaluation-analysis-lines p{margin:0}.analysis-page-content+.analysis-page-content{margin:0}.theory-evaluation-grid{display:grid;grid-template-columns:minmax(0,1fr) 180px;gap:12px;align-items:stretch}.theory-score-card{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:18px;border:1px solid var(--ui-line);border-radius:10px;background:#fff;box-shadow:var(--ui-soft-shadow);text-align:center}.theory-score-card span{color:var(--ui-text);font-size:12px;font-weight:800}.theory-score-card strong{margin:18px 0 4px;color:var(--ui-blue);font-size:44px;line-height:1;font-weight:400}.theory-score-card em{color:var(--ui-blue);font-size:15px;font-style:normal;font-weight:400}.score-stars{margin:14px 0 10px;color:#cbd3e3;font-size:18px}.score-stars .active{color:var(--ui-blue)}.theory-score-card p,.theory-score-card small{color:var(--ui-muted);font-size:12px;line-height:1.6}.voice-control-section,.voice-config-section,.preset-commands-section{margin-bottom:18px}.wake-word-section,.recognition-mode-section{border:1px solid var(--ui-line)!important;background:#fbfcff!important;border-radius:10px!important}.course-management-page,.management-shell{height:100%}.professional-page.course-management-page{height:auto;min-height:100%}.management-shell{display:flex;flex-direction:column;padding:18px;border:1px solid var(--ui-line);border-radius:10px;background:#fff;box-shadow:var(--ui-soft-shadow)}.management-title-row{display:flex;align-items:center;justify-content:space-between;gap:10px;flex-wrap:wrap;margin-bottom:18px}.management-title-row h2{color:var(--ui-ink);font-size:18px;font-weight:400}.management-title-actions{display:flex;gap:10px;flex-wrap:wrap;justify-content:flex-end}.filter-bar{display:grid;grid-template-columns:minmax(240px,1.4fr) 180px 260px auto auto;gap:10px;align-items:center;padding:12px;border:1px solid var(--ui-line);border-radius:9px;background:#fbfcff;margin-bottom:16px}.filter-search{position:relative}.filter-search svg{position:absolute;left:12px;top:50%;transform:translateY(-50%);width:16px;height:16px;color:var(--ui-muted)}.filter-search input{width:100%;height:36px;padding-left:36px}.filter-bar select,.filter-bar input,.date-range input{height:36px;padding:0 12px}.date-range{display:flex;align-items:center;gap:8px}.date-range input{min-width:0;width:100%}.course-table-card{flex:1;min-height:0;overflow:auto;border:1px solid var(--ui-line);border-radius:10px}.management-table th,.management-table td{padding:16px 18px;text-align:left}.management-table tbody tr{transition:background .18s ease}.management-table tbody tr:hover{background:#fbfcff}.course-cell{display:flex;align-items:center;gap:12px}.table-actions{display:flex;gap:8px}.table-actions button{display:grid;place-items:center;width:32px;height:32px;border:1px solid var(--ui-line);border-radius:8px;background:#fff;color:#53627d;cursor:pointer}.table-actions svg{width:16px;height:16px}.pagination-row{display:flex;align-items:center;justify-content:space-between;padding-top:14px;color:var(--ui-muted);font-size:13px}.student-management-shell{padding:18px}.student-tabs{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:10px;margin-bottom:16px}.student-tabs button{padding:13px 14px;border:1px solid var(--ui-line);border-radius:10px;background:#fbfcff;color:var(--ui-ink);text-align:left;cursor:pointer}.student-tabs button.active{border-color:#1890ff73;background:linear-gradient(135deg,#1890ff1f,#55c6c21a)}.student-tabs strong,.student-tabs span{display:block}.student-tabs span{margin-top:4px;color:var(--ui-muted);font-size:12px}.student-edit-grid{display:grid;grid-template-columns:320px minmax(0,1fr);gap:16px}.student-form-card,.student-table-card{min-width:0}.student-form-card{display:flex;flex-direction:column;gap:12px;padding:16px;border:1px solid var(--ui-line);border-radius:10px;background:#fff}.student-form-card h3{color:var(--ui-ink);font-size:17px;font-weight:400}.student-form-card label{display:flex;flex-direction:column;gap:6px;color:var(--ui-muted);font-size:13px;font-weight:800}.student-form-card input,.student-form-card select{height:38px;padding:0 12px;border:1px solid var(--ui-line);border-radius:8px;background:#fbfcff}.student-form-actions{display:flex;gap:10px;margin-top:4px}.student-filter-bar{grid-template-columns:minmax(240px,1fr) auto auto}.pagination-row div{display:flex;align-items:center;gap:6px}.pagination-row button{min-width:30px;height:30px;border:1px solid var(--ui-line);border-radius:7px;background:#fff;color:var(--ui-text)}.pagination-row button.active{border-color:var(--ui-blue);background:var(--ui-blue);color:#fff}@media(max-width:1320px){.dashboard-grid,.dashboard-stats{grid-template-columns:repeat(2,minmax(0,1fr))}.filter-bar{grid-template-columns:1fr 160px}}@media(max-width:1180px){.professional-page-hero,.bottom-controls,.voice-topbar{align-items:flex-start;flex-direction:column}.professional-metric-strip,.energy-summary-row{grid-template-columns:repeat(2,minmax(0,1fr))}.charts-grid,.charts-section,.theory-evaluation-grid{grid-template-columns:1fr}.density-evaluation-summary{grid-template-columns:repeat(2,minmax(0,1fr))}.density-charts-page .density-charts-hero{padding-right:300px}.density-charts-hero-copy{max-width:520px}.density-charts-hero-visual{width:340px;opacity:.76;transform:scale(.86);transform-origin:right center}.density-charts-page .chart-placeholder{height:252px}.energy-metric-strip{grid-template-columns:repeat(2,minmax(0,1fr))}.energy-stage-strip{grid-template-columns:repeat(3,minmax(0,1fr))}.density-evaluation-workbench{grid-template-columns:1fr}.professional-timer{width:100%;text-align:left}}@media(max-width:760px){.professional-page{gap:12px}.professional-page-hero{padding:16px}.professional-page-hero h2{font-size:20px}.professional-metric-strip,.density-evaluation-summary,.energy-summary-row,.filter-bar,.voice-mode-options,.voice-wake-form{grid-template-columns:1fr}.density-charts-page .density-charts-hero{height:auto;min-height:0;padding:16px}.density-charts-hero-copy{max-width:none}.density-charts-hero-visual{display:none}.density-charts-page .analysis-four-chart-grid{grid-template-columns:1fr}.density-charts-page .analysis-chart-card{min-height:310px;padding:16px}.density-charts-page .chart-placeholder{height:226px;padding:10px 8px 6px}.density-charts-page .density-chart-tip{min-height:0;padding:14px 16px 14px 58px}.density-charts-page .density-chart-tip:before{left:14px;top:16px}.density-charts-page .density-chart-tip:after{display:none}.energy-analysis-page .energy-hero{height:auto;min-height:0;padding:16px}.energy-hero-copy{max-width:none}.energy-hero-visual{display:none}.energy-metric-strip,.energy-stage-strip{grid-template-columns:1fr}.energy-analysis-page .energy-chart-section h3{align-items:flex-start;flex-direction:column;gap:6px}.energy-analysis-page .energy-analysis-tip{min-height:0;padding:14px 16px 14px 58px}.energy-analysis-page .energy-analysis-tip:before{left:14px;top:16px;width:38px;height:38px}.energy-analysis-page .energy-analysis-tip:after{display:none}.density-evaluation-page .evaluation-hero{height:auto;min-height:0;padding:16px}.density-evaluation-hero-copy{max-width:none}.density-evaluation-hero-visual{display:none}.density-evaluation-summary{grid-template-columns:1fr}.density-evaluation-page .evaluation-table-section{overflow:auto}.density-evaluation-page .evaluation-table{min-width:680px}.heart-recovery-dialog-backdrop{align-items:end;padding:12px}.heart-recovery-rule-dialog{max-height:calc(100vh - 24px);padding:14px}.heart-recovery-rule-head{align-items:flex-start;flex-direction:column;padding-right:40px}.heart-recovery-current{grid-template-columns:1fr}.density-evaluation-page .density-evaluation-tip{min-height:0;padding:14px 16px 14px 58px}.density-evaluation-page .density-evaluation-tip:before{left:14px;top:16px;width:38px;height:38px}.density-evaluation-page .density-evaluation-tip:after{display:none}}.analysis-filter-bar{display:grid;grid-template-columns:1fr 1.35fr 1fr auto;gap:14px;align-items:end;padding:0 0 18px;margin-bottom:16px;border-bottom:1px solid var(--ui-line)}.analysis-filter-bar label{display:flex;flex-direction:column;gap:7px}.analysis-filter-bar span,.voice-wake-form span{color:var(--ui-text);font-size:12px;font-weight:800}.analysis-filter-bar select,.analysis-filter-bar input{height:38px;padding:0 12px}.theory-content{display:flex;flex-direction:column;gap:14px}.theory-evaluation-grid{grid-template-columns:minmax(0,1fr) 190px;align-items:start}.theory-table{table-layout:fixed;margin-bottom:0}.theory-col-name{width:68%}.theory-col-desc,.theory-col-rating{width:auto}.theory-col-score{width:32%}.theory-table th,.theory-table td{padding:13px 14px;line-height:1.55}.theory-table th{color:#41506c;font-size:12px}.theory-table td{color:var(--ui-text);font-size:12px}.theory-table td:first-child{text-align:left}.theory-table td:nth-child(2){text-align:right;width:auto}.theory-table strong{color:var(--ui-ink);font-size:12px;font-weight:400}.star-rating{gap:6px;min-width:118px}.star{color:#cbd3e3;font-size:19px;line-height:1}.theory-score{color:var(--ui-blue)!important;font-size:16px!important;font-weight:400}.theory-score-card{min-height:216px;align-self:start}.theory-score-card strong{margin:14px 0 5px;font-size:45px}.theory-chart-section{padding:18px;border:1px solid var(--ui-line);border-radius:10px;background:#fff;box-shadow:var(--ui-soft-shadow)}.theory-chart-section .section-title{margin-bottom:12px}.voice-page{width:100%;max-width:1180px;margin:0 auto;padding:18px;border:1px solid var(--ui-line);border-radius:10px;background:var(--ui-card);box-shadow:var(--ui-soft-shadow)}.voice-topbar{display:flex;align-items:center;justify-content:space-between;gap:18px;margin-bottom:18px}.voice-topbar .section-title,.voice-page .section-title{margin-bottom:0}.voice-topbar-actions{display:flex;align-items:center;gap:18px}.voice-status{display:inline-flex;align-items:center;gap:7px;color:var(--ui-text);font-size:12px;font-weight:800}.voice-status i{display:block;width:8px;height:8px;border-radius:50%;background:var(--ui-green);box-shadow:0 0 0 4px #25c2761f}.voice-settings-grid{display:grid;grid-template-columns:1.05fr 2.15fr 1.05fr;gap:14px;margin-bottom:14px}.voice-card,.voice-wake-card,.voice-config-panel,.voice-preset-panel{border:1px solid var(--ui-line);border-radius:10px;background:#fff;box-shadow:0 8px 18px #1c38780d}.voice-card{min-height:118px;padding:16px}.voice-card h4,.voice-wake-card h4{margin-bottom:14px;color:var(--ui-ink);font-size:13px;font-weight:400}.voice-toggle-row{display:flex;align-items:center;justify-content:space-between;gap:16px}.voice-toggle-row strong,.voice-mode-option strong{display:block;color:var(--ui-ink);font-size:13px;font-weight:400}.voice-toggle-row small,.voice-mode-option small,.voice-wake-card small{display:block;margin-top:6px;color:var(--ui-muted);font-size:12px;line-height:1.5}.voice-toggle-row input[type=checkbox]{appearance:none;position:relative;width:40px;height:22px;flex:0 0 auto;border:0;border-radius:999px;background:#cbd5e1;cursor:pointer}.voice-toggle-row input[type=checkbox]:after{content:"";position:absolute;top:3px;left:3px;width:16px;height:16px;border-radius:50%;background:#fff;box-shadow:0 2px 6px #0f172a2e;transition:transform .18s ease}.voice-toggle-row input[type=checkbox]:checked{background:linear-gradient(135deg,var(--ui-blue),var(--ui-blue-2))}.voice-toggle-row input[type=checkbox]:checked:after{transform:translate(18px)}.voice-mode-options{display:grid;grid-template-columns:1fr 1fr;gap:12px}.voice-mode-option{display:grid;grid-template-columns:auto minmax(0,1fr);gap:10px;min-height:62px;padding:12px;border:1px solid var(--ui-line);border-radius:9px;background:#fbfcff;cursor:pointer}.voice-mode-option.is-active{border-color:#3267f68c;background:linear-gradient(180deg,#f5f8ff,#fff);box-shadow:inset 0 0 0 1px #3267f614}.voice-mode-option input{margin-top:3px}.voice-card select{width:100%;height:38px;padding:0 12px}.voice-main-grid{display:grid;grid-template-columns:minmax(0,1fr) 260px;gap:14px;align-items:start}.voice-config-panel{min-width:0;padding:16px}.voice-wake-card{padding:16px;margin-bottom:14px;background:linear-gradient(180deg,#fff,#fbfcff)}.voice-wake-form{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:12px;align-items:end}.voice-wake-form label{display:flex;flex-direction:column;gap:7px}.voice-wake-form input{height:38px;padding:0 12px}.voice-config-panel .config-header{margin-bottom:14px}.voice-config-table-wrapper{border:1px solid var(--ui-line);border-radius:10px;overflow:auto}.voice-config-table{table-layout:fixed}.voice-config-table th,.voice-config-table td{padding:12px 14px;text-align:left}.voice-config-table th{color:#41506c;font-size:12px}.voice-config-table td{vertical-align:middle}.voice-config-table th:first-child{width:30%}.voice-config-table th:last-child{width:92px;text-align:center}.config-input{height:34px;padding:0 10px;font-size:12px}.voice-table-actions{display:flex;justify-content:center;gap:8px}.icon-button{display:grid;place-items:center;width:30px;height:30px;border:1px solid var(--ui-line);border-radius:8px;background:#fff;color:#53627d;cursor:pointer}.icon-button:hover{border-color:#3267f659;color:var(--ui-blue);background:#f7faff}.icon-button svg{width:15px;height:15px}.voice-preset-panel{padding:16px}.preset-panel-title{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}.preset-panel-title button{border:0;background:transparent;color:var(--ui-blue);font-size:12px;font-weight:800;cursor:pointer}.preset-template-list{display:flex;flex-direction:column;gap:10px}.preset-template-item{display:flex;align-items:center;justify-content:space-between;gap:10px;min-height:34px;padding:0 10px;border:0;border-radius:8px;background:#f8fbff;color:var(--ui-text);cursor:pointer}.preset-template-item span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:12px;font-weight:700}.preset-template-item em{flex:0 0 auto;color:var(--ui-blue);font-size:12px;font-style:normal;font-weight:400}.preset-tip{margin-top:18px;padding:12px;border-radius:10px;background:#f7fbff;color:var(--ui-muted);font-size:12px;line-height:1.6}.preset-tip strong{display:block;margin-bottom:4px;color:var(--ui-blue)}.voice-page .preset-commands-section{max-width:none;margin:14px 0 0;padding:16px}.voice-page .preset-commands-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:12px}.voice-page .preset-command-card{min-height:58px;padding:12px}.preset-trigger{color:var(--ui-ink);font-size:12px}.preset-action{color:var(--ui-muted);font-size:12px}@media(max-width:1180px){.analysis-filter-bar,.voice-settings-grid,.voice-main-grid,.voice-page .preset-commands-grid{grid-template-columns:1fr}}
