:root{--bg:#faf8f4;--card:#fff;--surface-input:#fdfcf9;--surface-hover:#f5efe5;--ink:#1a1a1a;--muted:#6b6b6b;--on-accent:#fff;--line:#e8e3da;--line-strong:#d6cebd;--accent:#2d5a3d;--accent-strong:#234731;--accent-soft:#e7efe9;--accent-faint:#f0e9dc;--accent-disabled:#b8c4bb;--danger:#b3261e;--danger-soft:#fbeae9;--warn:#c47b00;--warn-soft:#fdf3e2;--radius:14px;--serif:"Iowan Old Style", "Charter", "Georgia", serif;--sans:-apple-system, BlinkMacSystemFont, "Inter", "Helvetica Neue", Arial, sans-serif;--mono:ui-monospace, SFMono-Regular, Menlo, monospace}*{box-sizing:border-box}html,body,#root{background:var(--bg);color:var(--ink);font-family:var(--sans);-webkit-font-smoothing:antialiased;margin:0;padding:0}@keyframes fadeUp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes pop{0%{opacity:0;transform:scale(.92)}60%{transform:scale(1.03)}to{opacity:1;transform:scale(1)}}.card{animation:.34s cubic-bezier(.2,.7,.3,1) both fadeUp}.q-anim{animation:.2s both fadeIn}.opts li{animation:.24s both fadeIn}.opts li:nth-child(2){animation-delay:40ms}.opts li:nth-child(3){animation-delay:80ms}.opts li:nth-child(4){animation-delay:.12s}.opts li:nth-child(5){animation-delay:.16s}.opts li:nth-child(6){animation-delay:.2s}@media (prefers-reduced-motion:reduce){*,:before,:after{transition:none!important;animation:none!important}}.topbar{border-bottom:1px solid var(--line);background:color-mix(in srgb, var(--bg) 92%, transparent);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);align-items:baseline;gap:10px;padding:16px 24px;display:flex;position:sticky;top:0}.brand-mark{font-family:var(--serif);font-size:18px;font-style:italic;font-weight:600}.brand-sub{color:var(--muted);font-size:13px}.wrap{max-width:640px;margin:0 auto;padding:36px 20px 80px}.wrap.wrap-wide{max-width:860px}.hub-grid{grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:16px;margin-top:24px;display:grid}.hub-card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);color:var(--ink);flex-direction:column;gap:6px;padding:22px;text-decoration:none;transition:transform .14s,box-shadow .14s,border-color .14s;animation:.34s cubic-bezier(.2,.7,.3,1) both fadeUp;display:flex;box-shadow:0 1px 2px #1414140a,0 4px 16px #1414140a}.hub-card:hover{border-color:var(--accent);transform:translateY(-2px);box-shadow:0 6px 22px #1414141a}.hub-card-title{font-family:var(--serif);letter-spacing:-.01em;font-size:19px}.hub-card-go{color:var(--accent);margin-top:8px;font-size:13px;font-weight:600}.hub-card-top{justify-content:space-between;align-items:flex-start;gap:8px;display:flex}.hub-card-top .kicker{margin-bottom:0}.badge{letter-spacing:.04em;text-transform:uppercase;white-space:nowrap;border:1px solid #0000;border-radius:999px;padding:3px 9px;font-size:11px;font-weight:700}.badge--final{background:var(--accent-faint);color:var(--accent-strong);border-color:var(--accent)}.badge--pending{color:#8a5a00;background:#fbeccd;border-color:#e7c477}.badge--dashboard{color:#2a5a87;background:#e3edf7;border-color:#b9d3ea}.card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:32px;box-shadow:0 1px 2px #1414140a,0 4px 16px #1414140a}.kicker{letter-spacing:.12em;text-transform:uppercase;color:var(--muted);margin-bottom:8px;font-size:12px}h1{font-family:var(--serif);letter-spacing:-.01em;margin:0 0 12px;font-size:30px;line-height:1.15}h3{margin:22px 0 6px;font-size:14px}.lede{color:var(--muted);margin:0 0 8px;font-size:16px}.muted{color:var(--muted)}.small{font-size:13px}.muted.small.nogoback{text-align:center;opacity:.8;margin-top:12px}ul.muted{padding-left:18px}ul.muted li{margin:4px 0}.form,.demo-list{flex-direction:column;gap:16px;margin-top:18px;display:flex}.field{flex-direction:column;gap:6px;display:flex}.field>span{font-size:14px;font-weight:600}input,select{font:inherit;border:1px solid var(--line);background:var(--surface-input);color:var(--ink);border-radius:8px;padding:10px 12px;font-size:16px;transition:border-color .15s,box-shadow .15s}input:focus,select:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft);outline:none}.other-input{margin-top:8px}.stepper{align-items:stretch;gap:8px;display:flex}.stepper-btn{width:44px;min-height:44px;font:inherit;border:1px solid var(--line);background:var(--surface-input);color:var(--ink);cursor:pointer;border-radius:8px;flex:none;justify-content:center;align-items:center;font-size:22px;font-weight:500;line-height:1;transition:border-color .15s,background .15s;display:flex}.stepper-btn:hover:not(:disabled){border-color:var(--line-strong);background:var(--surface-hover)}.stepper-btn:active:not(:disabled){transform:translateY(1px)}.stepper-btn:disabled{opacity:.4;cursor:default}.stepper-input{text-align:center;-moz-appearance:textfield;flex:auto;min-width:0}.stepper-input::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.stepper-input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.dd{position:relative}.dd-trigger{width:100%;font:inherit;text-align:left;border:1px solid var(--line);background:var(--surface-input);color:var(--ink);cursor:pointer;border-radius:8px;justify-content:space-between;align-items:center;gap:10px;padding:10px 12px;font-size:16px;transition:border-color .15s,box-shadow .15s;display:flex}.dd-trigger:hover{border-color:var(--line-strong)}.dd.open .dd-trigger{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}.dd-trigger.is-placeholder .dd-value{color:var(--muted)}.dd-value{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.dd-chevron{color:var(--muted);font-size:12px;transition:transform .18s}.dd.open .dd-chevron{transform:rotate(180deg)}.dd-combo{align-items:center;display:flex;position:relative}.dd-combo-input{width:100%;padding-right:36px}.dd-combo .dd-chevron{pointer-events:none;position:absolute;top:50%;right:12px;transform:translateY(-50%)}.dd.open .dd-combo .dd-chevron{transform:translateY(-50%)rotate(180deg)}.dd-panel{z-index:30;background:var(--card);border:1px solid var(--line);border-radius:10px;animation:.16s both fadeUp;position:absolute;top:calc(100% + 6px);left:0;right:0;overflow:hidden;box-shadow:0 8px 28px #1414141f}.dd-search{border:none;border-bottom:1px solid var(--line);background:var(--surface-input);border-radius:0;width:100%;padding:11px 14px;font-size:16px}.dd-search:focus{box-shadow:none;border-bottom-color:var(--accent);outline:none}.dd-list{max-height:240px;margin:0;padding:6px;list-style:none;overflow-y:auto}.dd-opt{text-align:left;width:100%;font:inherit;color:var(--ink);cursor:pointer;background:0 0;border:none;border-radius:7px;padding:9px 11px;font-size:14.5px;transition:background .1s}.dd-opt:hover{background:var(--surface-hover)}.dd-opt.sel{background:var(--accent-soft);color:var(--accent);font-weight:600}.dd-custom{color:var(--accent);font-style:italic}.dd-empty{color:var(--muted);padding:12px 14px;font-size:14px}.checkline{align-items:flex-start;gap:10px;margin:20px 0;font-size:14px;display:flex}.checkline input{width:18px;height:18px;accent-color:var(--accent)}.btn{background:var(--accent);color:var(--on-accent);cursor:pointer;border:none;border-radius:8px;margin-top:20px;padding:12px 22px;font-family:inherit;font-size:15px;font-weight:600;text-decoration:none;transition:background .15s,transform 80ms,box-shadow .15s,opacity .15s;display:inline-block}.btn:hover:not(:disabled){background:var(--accent-strong);box-shadow:0 4px 14px #2d5a3d38}.btn:active:not(:disabled){box-shadow:none;transform:translateY(1px)}.btn:disabled{background:var(--accent-disabled);cursor:default}.btn.ghost{color:var(--accent);border:1px solid var(--line);box-shadow:none;background:0 0}.btn.ghost:hover{background:var(--accent-faint);box-shadow:none}.row{align-items:center;gap:12px;display:flex}.error{color:var(--danger);background:var(--danger-soft);border-left:3px solid var(--danger);border-radius:8px;margin-top:12px;padding:10px 12px;font-size:14px}.rule{border:none;border-top:1px solid var(--line);margin:24px 0}.sheet-title{margin:0 0 12px;font-size:18px}.sheet{border:1px solid var(--line);background:var(--surface-input);border-radius:10px;max-height:360px;margin-bottom:8px;padding:18px 20px;overflow-y:auto}.sheet p{margin:0 0 12px;font-size:14px;line-height:1.55}.sheet-section{margin-top:14px}.sheet-section h3{color:var(--ink);margin:0 0 4px;font-size:13.5px}.consent-list,.instructions-list{margin:14px 0 0;padding-left:20px}.consent-list li,.instructions-list li{margin:8px 0;line-height:1.5}.consent-list li{color:var(--ink)}.consent-actions{flex-wrap:wrap;margin-top:24px}.progress{background:var(--line);border-radius:99px;height:4px;margin-bottom:20px;overflow:hidden}.progress-bar{background:var(--accent);height:100%;transition:width .25s}.topic-banner{font-family:var(--serif);color:var(--accent);border-bottom:1px solid var(--line);margin-bottom:14px;padding-bottom:10px;font-size:20px}.attention-tag{letter-spacing:.08em;text-transform:uppercase;color:var(--warn);background:var(--warn-soft);border-radius:5px;margin-bottom:10px;padding:3px 8px;font-size:11px;font-weight:700;display:inline-block}.q-prompt{margin-bottom:8px;font-size:17px;font-weight:600;line-height:1.45}.opts{flex-direction:column;gap:8px;margin:16px 0 0;padding:0;list-style:none;display:flex}.opt{text-align:left;width:100%;font:inherit;color:var(--ink);background:var(--surface-input);border:1px solid var(--line);cursor:pointer;border-radius:10px;align-items:flex-start;gap:12px;padding:12px 14px;font-size:15px;transition:background .14s,border-color .14s,transform .12s,box-shadow .14s;display:flex}.opt:hover{background:var(--surface-hover);border-color:var(--line-strong);transform:translate(3px)}.opt:active{transform:translate(1px)scale(.997)}.opt.on{background:var(--accent-soft);border-color:var(--accent);box-shadow:0 2px 10px #2d5a3d1f}.mark{border:1.5px solid var(--line);background:var(--card);width:22px;height:22px;color:var(--on-accent);flex-shrink:0;justify-content:center;align-items:center;font-size:12px;transition:background .14s,border-color .14s,transform .14s;display:inline-flex}.opt.on .mark{transform:scale(1.08)}.mark.circle{border-radius:50%}.mark.box{border-radius:5px}.mark.filled{background:var(--accent);border-color:var(--accent)}.code-block{background:var(--accent-soft);text-align:center;border-radius:12px;margin-top:22px;padding:20px;animation:.35s .1s both fadeUp}.code{font-family:var(--mono);letter-spacing:.04em;color:var(--accent);margin:8px 0 16px;font-size:26px;font-weight:700;animation:.45s cubic-bezier(.2,.7,.3,1) .2s both pop}.player{background:#000;border-radius:12px;margin-top:18px;overflow:hidden}.player video{aspect-ratio:16/9;background:#000;width:100%;display:block}.player-meta{margin-top:8px;padding:0 4px}.lecture-head .kicker{margin-bottom:8px}.lecture-head h1{font-size:34px}.mooc-h2{font-family:var(--serif);letter-spacing:-.005em;margin:0 0 14px;font-size:21px}.mooc-goals{flex-direction:column;gap:12px;margin:0;padding:0;list-style:none;display:flex}.mooc-goals li{align-items:flex-start;gap:12px;font-size:15px;display:flex}.mooc-goal-tick{background:var(--accent-soft);width:22px;height:22px;color:var(--accent);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:13px;font-weight:700;display:inline-flex}.exercise-intro p{margin:0 0 10px;font-size:14.5px;line-height:1.55}.exercise-intro p:last-child{margin-bottom:0}.foot{text-align:center;padding:24px 0 10px}.mq-list{flex-direction:column;gap:30px;display:flex}.mq-prompt{margin-bottom:10px;font-size:16px;font-weight:600;line-height:1.45}.mq-num{color:var(--accent);font-family:var(--mono);margin-right:6px;font-weight:700}.mq-hint{color:var(--muted);margin-bottom:10px;font-size:13px;font-style:italic}.mq-opts{flex-direction:column;gap:8px;margin:0;padding:0;list-style:none;display:flex}.mq-opt{text-align:left;width:100%;font:inherit;color:var(--ink);background:var(--surface-input);border:1px solid var(--line);cursor:pointer;border-radius:10px;align-items:flex-start;gap:12px;padding:12px 14px;font-size:15px;transition:background .12s,border-color .12s;display:flex}.mq-opt:hover:not(:disabled){background:var(--surface-hover);border-color:var(--line-strong)}.mq-opt:disabled{cursor:default}.mq-opt.on,.mq-opt.correct{background:var(--accent-soft);border-color:var(--accent)}.mq-opt.incorrect{background:var(--danger-soft);border-color:var(--danger)}.mq-opt.dim{opacity:.55}.mq-bullet{background:var(--accent-soft);width:24px;height:24px;color:var(--accent);font-family:var(--mono);border-radius:6px;flex-shrink:0;justify-content:center;align-items:center;font-size:12px;font-weight:700;display:inline-flex}.mq-opt.correct .mq-bullet{background:var(--accent);color:var(--on-accent)}.mq-opt.incorrect .mq-bullet{background:var(--danger);color:var(--on-accent)}.mq-check{border:1.5px solid var(--line);background:var(--card);width:22px;height:22px;color:var(--on-accent);border-radius:5px;flex-shrink:0;justify-content:center;align-items:center;font-size:13px;font-weight:700;display:inline-flex}.mq-check.checked{background:var(--accent);border-color:var(--accent)}.mq-text{flex:1}.mq-submit{margin-top:14px}.mq-explain{background:var(--accent-soft);border-left:3px solid var(--accent);border-radius:10px;margin-top:12px;padding:12px 14px;font-size:14px;line-height:1.5}.mq-explain.no{background:var(--danger-soft);border-left-color:var(--danger)}.survey-q{border-bottom:1px solid var(--line);margin:18px 0 24px;padding-bottom:18px}.survey-q:last-of-type{border-bottom:none;padding-bottom:0}.survey-text{width:100%;font:inherit;border:1px solid var(--line);background:var(--surface-input);color:var(--ink);resize:vertical;border-radius:8px;margin-top:10px;padding:10px 12px;font-size:16px}.survey-text:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft);outline:none}@media (width<=560px){.card{padding:22px}h1{font-size:25px}.row{flex-direction:column;align-items:stretch}}
