:root{color:#172033;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Noto Sans TC,sans-serif;background:#f7f0df;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased}*{box-sizing:border-box}body{margin:0;min-width:320px;min-height:100vh;background:radial-gradient(circle at top left,rgba(255,205,92,.42),transparent 28rem),radial-gradient(circle at 85% 12%,rgba(111,203,255,.28),transparent 26rem),linear-gradient(135deg,#fff8e8,#ecf7ff)}button,textarea,input{font:inherit}button{cursor:pointer}button:disabled{cursor:not-allowed;opacity:.58}.app-shell{width:min(1180px,calc(100% - 32px));margin:0 auto;padding:32px 0 120px}.hero-panel,.setup-card,.class-board,.roll-call-bar,.result-modal{border:4px solid #172033;border-radius:30px;box-shadow:0 14px #172033}.hero-panel{display:flex;justify-content:space-between;gap:28px;align-items:center;margin-bottom:28px;padding:32px;background:linear-gradient(135deg,#ffd96d,#ff9ec7)}.eyebrow{margin:0 0 8px;color:#5f3dc4;font-size:.78rem;font-weight:900;letter-spacing:.12em;text-transform:uppercase}h1,h2,h3,p{margin-top:0}h1{max-width:760px;margin-bottom:12px;font-size:clamp(2.35rem,7vw,5.2rem);line-height:.95;letter-spacing:-.06em}h2{margin-bottom:4px;font-size:clamp(1.4rem,3vw,2.2rem);letter-spacing:-.04em}.hero-copy{max-width:640px;margin-bottom:0;color:#172033c2;font-size:1.08rem;line-height:1.8}.hero-monster{display:grid;flex:0 0 160px;width:160px;height:160px;place-items:center;border:4px solid #172033;border-radius:40px;background:#f7fff7;box-shadow:0 10px #172033;font-size:5rem;transform:rotate(5deg)}.workspace{display:grid;grid-template-columns:minmax(280px,360px) 1fr;gap:28px;align-items:start}.setup-card,.class-board{background:#ffffffe0;padding:24px}.setup-card{position:sticky;top:24px}.field-label{display:block;margin:14px 0 8px;font-weight:900;font-size:.88rem;color:#172033}.rules-textarea{min-height:120px;margin-bottom:4px}.rules-textarea--deduct{margin-bottom:8px}.batch-textarea{min-height:160px}.section-heading--spaced{margin-top:22px}.single-add-row{display:flex;gap:10px;align-items:stretch;margin-bottom:8px}.single-add-row input{flex:1;min-width:0;border:3px solid #172033;border-radius:18px;padding:12px 14px;background:#fffdf8;font-weight:700}.inline-button{flex:0 0 auto;padding:12px 18px;border:3px solid #172033;border-radius:18px;background:#7dd3ff;box-shadow:0 5px #172033;font-weight:950;white-space:nowrap}.inline-button:hover{transform:translateY(2px);box-shadow:0 3px #172033}.secondary-button{width:100%;margin-bottom:12px;border:3px solid #172033;border-radius:18px;padding:14px 16px;background:#ffe08a;box-shadow:0 7px #172033;color:#172033;font-weight:950}.secondary-button:hover{transform:translateY(2px);box-shadow:0 5px #172033}.hint-text{margin:0 0 14px;font-size:.85rem;color:#667085;line-height:1.5}.section-heading{display:flex;gap:14px;align-items:flex-start;margin-bottom:18px}.section-heading span{display:grid;flex:0 0 42px;width:42px;height:42px;place-items:center;border-radius:14px;background:#172033;color:#fff;font-weight:900}.section-heading p,.board-header p{margin-bottom:0;color:#667085}textarea{width:100%;min-height:280px;resize:vertical;border:3px solid #172033;border-radius:22px;outline:none;padding:18px;background:#fffdf8;color:#172033;line-height:1.7;box-shadow:inset 0 4px #17203314}textarea:focus,input:focus{box-shadow:0 0 0 5px #ffd96db3}.input-meta{display:flex;justify-content:space-between;gap:12px;margin:12px 0 18px;color:#667085;font-size:.92rem}.input-meta strong{color:#d92d20}.primary-button,.ghost-button,.danger-button{width:100%;border:3px solid #172033;border-radius:18px;padding:15px 18px;color:#172033;font-weight:950;transition:transform .16s ease,box-shadow .16s ease,background .16s ease}.primary-button{background:#51e08a;box-shadow:0 7px #172033}.ghost-button{margin-top:12px;background:#fff;box-shadow:0 7px #172033}.danger-button{background:#ff5b5f;box-shadow:0 7px #172033}.primary-button:hover,.ghost-button:hover,.danger-button:hover{transform:translateY(2px);box-shadow:0 5px #172033}.rules-board-summary{margin-bottom:18px;padding:14px 16px;border:3px solid #172033;border-radius:20px;background:#fafbff}.rules-board-summary summary{cursor:pointer;font-weight:950;letter-spacing:-.02em}.rules-board-summary summary::-webkit-details-marker{margin-right:8px}.rules-board-columns{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-top:12px}.rules-board-columns strong{display:block;margin-bottom:6px;font-size:.82rem;color:#5f3dc4}.rules-board-pre{margin:0;padding:12px;border:2px solid #172033;border-radius:14px;background:#fffdf8;font-family:inherit;font-size:.82rem;line-height:1.55;white-space:pre-wrap;word-break:break-word;max-height:160px;overflow-y:auto}.rules-board-pre--deduct{background:#fff5f5}.board-header{display:flex;justify-content:space-between;gap:20px;align-items:center;margin-bottom:20px}.bulk-actions-bar{display:flex;flex-wrap:wrap;gap:10px;align-items:center;margin-bottom:16px}.chip-button{padding:10px 14px;border:2px solid #172033;border-radius:999px;background:#fff;font-weight:900;font-size:.85rem;box-shadow:0 4px #172033}.chip-button:hover:not(:disabled){transform:translateY(1px);box-shadow:0 2px #172033}.chip-button--active{background:#ffe08a}.chip-button--danger{background:#ffc9c9}.chip-button:disabled{opacity:.55;box-shadow:0 2px #172033}.count-control{display:flex;align-items:center;gap:8px;font-weight:900;white-space:nowrap}.count-control input{width:74px;border:3px solid #172033;border-radius:14px;padding:8px 10px;background:#fffdf8;text-align:center;font-weight:900}.student-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(128px,1fr));gap:18px}.student-card{position:relative;display:grid;min-height:200px;place-items:center;align-content:center;border:3px solid #172033;border-radius:24px;padding:16px 12px 14px;background:#fff;box-shadow:0 7px #172033;animation:pop-in .36s ease both;transition:transform .16s ease,background .16s ease,box-shadow .16s ease}.card-delete{position:absolute;top:8px;right:8px;width:32px;height:32px;padding:0;border:2px solid #172033;border-radius:10px;background:#fff;font-size:1.35rem;font-weight:900;line-height:1;color:#d92d20}.card-delete:hover{background:#ffe4e4}.score-badge{margin-top:2px;padding:4px 10px;border-radius:999px;font-size:.82rem;font-weight:900;background:#eef1f6;color:#172033}.score-badge.positive{background:#cfffdf;color:#0b6b3a}.score-badge.negative{background:#ffe0e0;color:#a61e1e}.card-score-actions{display:flex;gap:8px;margin-top:10px}.score-btn{flex:1;padding:8px 6px;border:2px solid #172033;border-radius:12px;font-weight:950;font-size:.88rem}.score-btn--plus{background:#51e08a}.score-btn--minus{background:#ffc9c9}.student-card.large{min-width:180px;min-height:210px}.student-card.is-active{background:#ffe86b;transform:translateY(-8px) rotate(-2deg) scale(1.04);box-shadow:0 14px #172033}.student-card.is-winner{background:#b6ffce}.student-card.is-selected{outline:3px solid #6366f1;outline-offset:2px}.card-select{position:absolute;top:8px;left:8px;display:grid;place-items:center;width:28px;height:28px;margin:0}.card-select input{width:18px;height:18px;accent-color:#6366f1;cursor:pointer}.avatar-ring{display:grid;width:92px;height:92px;place-items:center;border:3px solid #172033;border-radius:999px;background:linear-gradient(135deg,#e5f6ff,#fff2bd);overflow:hidden}.student-card.large .avatar-ring{width:122px;height:122px}.avatar-ring img{width:82%;height:82%}.student-card h3{margin:10px 0 0;font-size:1.1rem;text-align:center}.empty-state{display:grid;min-height:360px;place-items:center;border:3px dashed #172033;border-radius:24px;color:#667085;text-align:center}.empty-state span{display:block;margin-bottom:12px;font-size:4rem}.roll-call-bar{position:fixed;right:24px;bottom:24px;left:24px;z-index:10;display:flex;justify-content:space-between;gap:20px;align-items:center;width:min(920px,calc(100% - 48px));margin:0 auto;padding:18px 20px;background:#fffffff2;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.roll-call-bar div{display:grid;gap:2px}.roll-call-bar span{color:#667085;font-size:.9rem}.roll-call-bar button{width:min(240px,42vw)}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:20;display:grid;place-items:center;padding:24px;background:#1720338c}.result-modal{width:min(720px,100%);padding:30px;background:radial-gradient(circle at 12% 18%,rgba(255,232,107,.75),transparent 13rem),#fff;text-align:center}.winner-grid{display:flex;flex-wrap:wrap;justify-content:center;gap:18px;margin:24px 0}@keyframes pop-in{0%{opacity:0;transform:translateY(12px) scale(.96)}to{opacity:1;transform:translateY(0) scale(1)}}@media(max-width:860px){.rules-board-columns,.hero-panel,.workspace,.board-header,.roll-call-bar{grid-template-columns:1fr}.hero-panel,.board-header,.roll-call-bar{flex-direction:column;align-items:stretch}.hero-monster{display:none}.setup-card{position:static}.roll-call-bar button{width:100%}}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;scroll-behavior:auto!important;transition-duration:.01ms!important}}
