:root{--cp-green:#58cc02;--cp-green-dark:#46a302;--cp-sky:#1cb0f6;--cp-sky-dark:#1286c8;--cp-ink:#25364d;--cp-muted:#6f7d90;--cp-line:#e3edf5;--cp-shadow:0 9px 0 #e3ebf2,0 22px 46px rgba(37,54,77,.08)}*{box-sizing:border-box}html{scroll-behavior:smooth}body{margin:0;min-height:100vh;color:var(--cp-ink);font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,PingFang SC,Microsoft YaHei,sans-serif;background:radial-gradient(circle at 50% -10%,#dcf8ff 0 360px,transparent 361px),linear-gradient(180deg,#f8fdff,#eef8f1)}a{color:inherit;text-decoration:none}button,input,select{font:inherit}.cp-shell{display:grid;grid-template-columns:230px minmax(0,1fr);min-height:100vh}.cp-sidebar{position:sticky;top:0;height:100vh;background:#fff;border-right:2px solid var(--cp-line);padding:24px 16px;display:flex;flex-direction:column;gap:24px}.cp-brand{display:flex;align-items:center;gap:12px}.cp-brand-mark{width:50px;height:50px;border-radius:18px;background:#ecffd9;border:2px solid #c8f3ad;border-bottom:7px solid #c8f3ad;display:grid;place-items:center}.cp-brand-mark svg{width:34px}.cp-brand strong{display:block;font-size:22px;color:#58a700;letter-spacing:-.04em}.cp-brand small{display:block;margin-top:3px;color:var(--cp-muted);font-size:12px;font-weight:800}.cp-side-nav{display:grid;gap:10px}.cp-side-item{height:52px;display:flex;align-items:center;gap:12px;padding:0 14px;border-radius:17px;border:2px solid transparent;color:#657286;font-weight:950}.cp-side-item span{width:14px;height:14px;border-radius:50%;background:#cbd8e4;box-shadow:inset 0 -3px #00000014}.cp-side-item.active,.cp-side-item:hover{background:#eaf7ff;border-color:#bee8ff;color:#1286c8}.cp-side-item.active span{background:var(--cp-sky)}.cp-mini-entry{margin-top:auto;padding:16px;border-radius:22px;background:#fbfff7;border:2px solid #ddf7ce;border-bottom:7px solid #ddf7ce}.cp-mini-entry b{color:#58a700}.cp-mini-entry p{margin:8px 0 0;color:var(--cp-muted);font-size:13px;line-height:1.55;font-weight:750}.cp-mobile-header{display:none}.cp-main-area{padding:22px clamp(18px,3vw,38px) 48px;display:grid;grid-template-columns:minmax(0,1fr) 300px;gap:22px;align-items:start}.cp-status-bar{grid-column:1/-1;position:sticky;top:0;z-index:30;display:flex;justify-content:center;gap:12px;padding-bottom:18px;background:#f6fbffe6;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px)}.cp-status-chip{height:48px;min-width:118px;display:grid;grid-template-columns:auto 1fr;grid-template-areas:"icon value" "icon label";align-items:center;column-gap:9px;background:#fff;border:2px solid var(--cp-line);border-bottom:6px solid #dbe6ee;border-radius:17px;padding:0 13px;font-weight:950}.cp-status-chip span{grid-area:icon;width:28px;height:28px;border-radius:10px;display:grid;place-items:center;color:#fff;background:var(--cp-green);font-size:13px}.cp-status-chip b{grid-area:value;font-size:16px;line-height:1}.cp-status-chip small{grid-area:label;color:var(--cp-muted);font-size:11px}.cp-status-chip.heart span{background:#ff4b6e}.cp-status-chip.xp span{background:#ff9600}.cp-status-chip.coin span{background:#ffc800;color:#5f4100}.cp-status-chip.streak span{background:#ff6b00}.cp-game-board{display:grid;grid-template-columns:minmax(110px,150px) minmax(390px,1fr) minmax(110px,150px);gap:16px;align-items:start;justify-content:center}.cp-path-card{position:relative;background:#fff;border:2px solid var(--cp-line);border-radius:32px;padding:28px clamp(18px,3vw,32px) 32px;box-shadow:var(--cp-shadow);overflow:hidden}.cp-path-card:before{content:"";position:absolute;inset:0 0 auto;height:12px;background:linear-gradient(90deg,var(--cp-green),#8ee63f,var(--cp-sky))}.cp-eyebrow{margin:8px 0 10px;color:#58a700;font-size:13px;font-weight:950;letter-spacing:.12em;text-transform:uppercase}.cp-path-card h1{margin:0;font-size:clamp(40px,5vw,60px);letter-spacing:-.07em;line-height:.95;text-align:center}.cp-intro{max-width:520px;margin:14px auto 10px;color:#627187;font-size:16px;line-height:1.65;font-weight:760;text-align:center}.cp-primary-cta{display:flex;align-items:center;justify-content:center;gap:8px;width:min(320px,100%);min-height:58px;margin:18px auto 12px;border-radius:20px;background:var(--cp-green);border:2px solid var(--cp-green-dark);border-bottom:8px solid var(--cp-green-dark);color:#fff;font-size:20px;font-weight:950;letter-spacing:.02em;box-shadow:0 12px 22px #58cc022e;cursor:pointer}.cp-primary-cta:after{content:"▶";font-size:16px}.cp-path-line{position:relative;min-height:470px;margin-top:8px;display:flex;flex-direction:column;align-items:center;gap:16px}.cp-path-line:before{content:"";position:absolute;top:42px;bottom:72px;left:50%;width:12px;transform:translate(-50%);border-radius:99px;background:linear-gradient(#b8f7a1 0,#b8f7a1 62%,#dbe6ef 62%)}.cp-path-node{position:relative;z-index:2;width:230px;text-align:center}.cp-path-node.left{right:82px}.cp-path-node.right{left:82px}.cp-path-node button{width:80px;height:74px;border:0;border-radius:50%;background:var(--cp-green);color:#fff;border-bottom:8px solid var(--cp-green-dark);box-shadow:0 7px #23500012;font-size:31px;font-weight:950;transition:.14s transform,.14s filter;cursor:pointer}.cp-path-node button:hover{filter:saturate(1.1);transform:translateY(-3px)}.cp-path-node.current button{width:94px;height:86px;background:var(--cp-sky);border-bottom-color:var(--cp-sky-dark);outline:9px solid #dff4ff;animation:cp-pulse 1.8s ease-in-out infinite}.cp-path-node.next button{background:#cfd9e4;border-bottom-color:#a7b4c1}.cp-path-node strong{display:block;margin-top:9px;font-size:18px}.cp-path-node small{display:block;margin-top:3px;color:var(--cp-muted);font-weight:800}.cp-path-node.current strong{color:#1286c8}@keyframes cp-pulse{50%{transform:scale(1.045)}}.cp-companion{position:sticky;top:92px;display:grid;justify-items:center;gap:12px;padding-top:40px}.cp-companion.compact{position:relative;top:auto;padding:0}.cp-speech{position:relative;max-width:200px;background:#fff;border:2px solid var(--cp-line);border-bottom:7px solid #dfe8ef;border-radius:20px;padding:13px 14px;color:#536176;font-size:14px;font-weight:850;line-height:1.45}.cp-speech:after{content:"";position:absolute;bottom:-10px;left:42%;width:18px;height:18px;background:#fff;border-right:2px solid var(--cp-line);border-bottom:2px solid var(--cp-line);transform:rotate(45deg)}.cp-pet-character{width:min(220px,100%);height:auto;filter:drop-shadow(0 18px 18px rgba(37,54,77,.13));animation:cp-breathe 2.6s ease-in-out infinite;transform-origin:50% 85%}.cp-xiaodou{animation-delay:.4s}.cp-eyes{transform-origin:center;animation:cp-blink 4.8s infinite}.cp-tail{transform-origin:160px 150px;animation:cp-tail 1.4s ease-in-out infinite}.cp-wave{transform-origin:62px 136px;animation:cp-wave 1.7s ease-in-out infinite}.cp-paw{transform-origin:75px 170px;animation:cp-paw 2.2s ease-in-out infinite}@keyframes cp-breathe{50%{transform:translateY(-10px) scale(1.025)}}@keyframes cp-blink{0%,92%,to{transform:scaleY(1)}95%{transform:scaleY(.08)}}@keyframes cp-tail{50%{transform:rotate(8deg)}}@keyframes cp-wave{50%{transform:rotate(-16deg)}}@keyframes cp-paw{50%{transform:rotate(7deg)}}.cp-right-panel{position:sticky;top:84px;display:grid;grid-template-columns:1fr;gap:16px}.cp-panel-card,.cp-feature-card,.cp-roles,.cp-weekly-report,.cp-flow-card{background:#fff;border:2px solid var(--cp-line);border-radius:25px;padding:19px;box-shadow:0 8px #e4ecf3}.cp-panel-title{display:flex;justify-content:space-between;gap:10px;align-items:center}.cp-panel-title h2{margin:0;font-size:22px}.cp-panel-title b{color:#58a700}.cp-panel-card p,.cp-feature-card p,.cp-roles p,.cp-weekly-report p{color:#667386;font-weight:780;line-height:1.55}.cp-progress{height:13px;background:#edf3f7;border-radius:99px;overflow:hidden}.cp-progress i{display:block;height:100%;background:linear-gradient(90deg,var(--cp-green),#8ee63f);border-radius:99px}.cp-rank-list{margin:14px 0 0;padding:0;display:grid;gap:9px}.cp-rank-list li{list-style:none;display:flex;justify-content:space-between;gap:8px;padding:10px 12px;border-radius:15px;background:#f8fbff;border:2px solid #edf3f7;font-weight:900}.cp-card-actions{display:grid;gap:10px;margin-top:12px}.cp-feature-grid{grid-column:1/-1;max-width:1100px;width:100%;margin:4px auto 0;display:grid;grid-template-columns:1fr 1fr;gap:16px}.cp-feature-card h2,.cp-roles h2,.cp-weekly-report h2{margin:0;font-size:clamp(30px,3.8vw,48px);letter-spacing:-.06em;line-height:1}.cp-form{display:grid;gap:12px}.cp-form label{display:grid;gap:8px;font-weight:950}.cp-form label span{font-size:13px;color:#58a700}.cp-input{height:54px;border-radius:17px;border:2px solid #d9e7f1;border-bottom-width:6px;padding:0 16px;color:#25364d;font-weight:900;background:#fff}.cp-button{min-height:52px;border:0;border-radius:16px;background:var(--cp-green);border-bottom:6px solid var(--cp-green-dark);color:#fff;font-weight:950;padding:0 16px;cursor:pointer}.cp-button.secondary{background:#eaf7ff;border:2px solid #bee8ff;border-bottom:6px solid #a8ddfa;color:#1286c8}.cp-button.dark{background:#243244;border-bottom-color:#111827}.cp-button.warning{background:#ff9600;border-bottom-color:#d97706}.cp-button:disabled{filter:grayscale(.7);opacity:.62;cursor:not-allowed}.cp-roles,.cp-weekly-report{grid-column:1/-1;max-width:1100px;width:100%;margin:4px auto 0}.cp-role-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-top:16px}.cp-role-grid article{border-radius:22px;background:#f8fbff;border:2px solid #e6f0f7;padding:18px}.cp-role-grid span{display:inline-grid;place-items:center;height:32px;padding:0 12px;border-radius:999px;background:#eaf7ff;color:#1286c8;font-weight:950}.cp-role-grid h3{margin:14px 0 6px;font-size:24px}.cp-role-grid button{width:100%;min-height:48px;border:0;border-radius:16px;background:#e9ffe0;border-bottom:6px solid #b7e79f;color:#3d8500;font-weight:950}.cp-weekly-report{display:grid;grid-template-columns:.9fr 1.1fr;gap:18px;align-items:start}.cp-report-card{border-radius:24px;background:linear-gradient(180deg,#fbfff7,#fff);border:2px solid #ddf7ce;padding:20px;white-space:pre-wrap}.cp-report-card b{display:block;color:#58a700;margin-top:10px}.cp-muted{color:var(--cp-muted);font-weight:850}.cp-error{grid-column:1/-1;border-color:#fecaca;background:#fef2f2;color:#b91c1c}.cp-success{border-radius:16px;background:#f0fdf4;padding:14px;color:#166534;font-weight:850}.cp-student-list{margin:0;padding-left:20px;color:#475569;font-weight:800}.cp-soft-links{display:flex;gap:9px;flex-wrap:wrap}.cp-soft-links a{padding:9px 12px;border-radius:999px;background:#fff;border:2px solid #e3edf5;color:#758196;font-weight:900;font-size:13px}.cp-entry-grid{grid-template-columns:repeat(4,1fr)}.cp-boundary-banner,.cp-first-run-card{grid-column:1/-1;max-width:1100px;width:100%;margin:4px auto 0}.cp-boundary-banner{background:linear-gradient(180deg,#fff7ed,#fff);border-color:#fed7aa;box-shadow:0 8px #ffedd5}.cp-checklist{margin:12px 0 0;padding:0;display:grid;gap:8px}.cp-checklist li{list-style:none;padding:12px 14px;border-radius:16px;border:2px solid #e6f0f7;background:#f8fbff;color:#5c6878;font-weight:850}.cp-checklist li.current{border-color:#bee8ff;background:#eaf7ff;color:#1286c8}.cp-checklist li.done{border-color:#bbf7d0;background:#f0fdf4;color:#15803d}.cp-route-card{display:block;transition:.14s transform,.14s box-shadow}.cp-route-card:hover{transform:translateY(-3px);box-shadow:0 11px #dbe7ef}.cp-link-button{display:grid;place-items:center;text-align:center}@media (max-width:1180px){.cp-shell{grid-template-columns:minmax(0,1fr);overflow-x:clip}.cp-sidebar{display:none}.cp-mobile-header{position:sticky;top:0;z-index:40;display:flex;align-items:center;justify-content:space-between;gap:12px;min-width:0;width:100%;background:var(--cp-green);color:#fff;border-bottom:5px solid var(--cp-green-dark);padding:12px 16px}.cp-mobile-header a{font-weight:950}.cp-mobile-header nav{display:flex;gap:8px;overflow-x:auto}.cp-mobile-header nav a{flex:0 0 auto;padding:8px 10px;border-radius:12px;background:#ffffff2e}.cp-main-area{display:block;overflow-x:clip}.cp-game-board{grid-template-columns:minmax(0,1fr);max-width:780px;width:100%;margin:auto}.cp-companion{position:relative;top:auto;padding-top:0}.cp-path-card{order:1}.cp-pet-character{width:180px}.cp-right-panel{position:static;display:grid;grid-template-columns:1fr 1fr;max-width:780px;width:100%;margin:24px auto 0}.cp-status-bar{overflow:auto;justify-content:flex-start}.cp-entry-grid{grid-template-columns:1fr 1fr}.cp-feature-grid,.cp-weekly-report{grid-template-columns:1fr}.cp-role-grid{grid-template-columns:1fr 1fr}}@media (max-width:720px){.cp-main-area{padding:16px 12px 42px}.cp-status-chip{min-width:104px}.cp-path-card{border-radius:25px;padding:24px 16px 28px}.cp-path-card h1{font-size:38px}.cp-intro{text-align:left;font-size:15px;line-height:1.45}.cp-path-node.left,.cp-path-node.right{left:auto;right:auto}.cp-path-node{width:178px}.cp-path-line{min-height:540px}.cp-path-node button{width:76px;height:70px;font-size:28px}.cp-path-node.current button{width:88px;height:82px}.cp-right-panel,.cp-feature-grid,.cp-entry-grid,.cp-role-grid,.cp-weekly-report{grid-template-columns:minmax(0,1fr)}.cp-speech{max-width:260px}.cp-mobile-header nav{width:auto}.cp-feature-card h2,.cp-roles h2,.cp-weekly-report h2{font-size:34px}.cp-rank-list li,.cp-panel-title{min-width:0;flex-wrap:wrap}.cp-game-board .cp-companion:last-child{display:none}}@media (prefers-reduced-motion:reduce){*{animation:none!important;transition:none!important;scroll-behavior:auto!important}}.cp-mini-panel{border:2px solid #e6f0f7;border-radius:18px;background:#f8fbff;padding:12px}.cp-status-pill{display:inline-grid;place-items:center;min-width:74px;height:24px;margin-right:6px;padding:0 8px;border-radius:999px;background:#e2e8f0;color:#475569;font-size:11px;font-weight:950;text-transform:uppercase}.cp-status-pill.pending{background:#fff7ed;color:#c2410c}.cp-status-pill.approved{background:#dcfce7;color:#15803d}.cp-status-pill.rejected{background:#fee2e2;color:#b91c1c}.cp-status-pill.audit{background:#e0f2fe;color:#0369a1}.cp-mini-panel small{color:#64748b;font-weight:800}.cp-filter-panel{display:grid;gap:12px}.cp-filter-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.cp-filter-grid label{display:grid;gap:6px;font-weight:950}.cp-filter-grid label span{font-size:12px;color:#58a700}.cp-filter-panel .cp-card-actions{grid-template-columns:repeat(2,minmax(0,1fr))}.cp-filter-panel .cp-button{display:grid;place-items:center;text-align:center;min-height:46px}@media (max-width:720px){.cp-filter-grid,.cp-filter-panel .cp-card-actions{grid-template-columns:1fr}}
