:root{--bg:#f6f7f9;--panel:#ffffff;--text:#172026;--muted:#66737f;--line:#dce3ea;--brand:#16756f;--brand-strong:#0e5d58;--nav:#132223;--nav-soft:#203637;--danger:#bd3b3b;--shadow:0 18px 40px rgba(26,38,48,0.1)}*{box-sizing:border-box}html{scroll-behavior:smooth}body{margin:0;min-width:320px;min-height:100vh;background:var(--bg);color:var(--text);font-family:Inter,PingFang SC,Microsoft YaHei,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}.visually-hidden{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0 0 0 0);white-space:nowrap;-webkit-clip-path:inset(50%);clip-path:inset(50%)}button,input,select{font:inherit}button{cursor:pointer}button:disabled{cursor:not-allowed;opacity:.5}.app-shell{display:grid;grid-template-columns:280px minmax(0,1fr);min-height:100vh}.sidebar{position:-webkit-sticky;position:sticky;top:0;display:flex;height:100vh;flex-direction:column;gap:22px;padding:24px;background:var(--nav);color:#f4fbfa}.brand{display:flex;align-items:center;gap:12px;min-height:56px}.brand strong{display:block;font-size:20px;line-height:1.1}.brand span{display:block;margin-top:5px;color:#a8bfbd;font-size:13px}.brand-mark{display:grid;width:44px;height:44px;place-items:center;border:1px solid rgba(255,255,255,.14);border-radius:8px;background:#1e4340;color:#8de1d6}.session-card{display:grid;grid-gap:5px;gap:5px;border:1px solid rgba(255,255,255,.12);border-radius:8px;background:var(--nav-soft);padding:14px}.session-card small,.session-card span{color:#a8bfbd;font-size:12px}.session-card strong{font-size:16px;line-height:1.25}.field-stack{display:grid;grid-gap:8px;gap:8px}.field-stack label,.form-card label,.limit-row label,.modal label{color:#cad8d6;font-size:13px}.field-stack select,.form-card input,.limit-row input,.modal input,.modal select,.search-box input{width:100%;min-height:42px;border:1px solid var(--line);border-radius:8px;background:#fff;color:var(--text);outline:none;padding:0 12px}.field-stack select{border-color:rgba(255,255,255,.14);background:var(--nav-soft);color:#fff}.form-card label{display:grid;grid-gap:7px;gap:7px;color:var(--muted)}.side-nav{display:grid;grid-gap:8px;gap:8px}.side-nav a{display:flex;align-items:center;min-height:44px;gap:10px;border-radius:8px;color:#d7e6e4;padding:0 12px;text-decoration:none}.side-nav a.active,.side-nav a:hover{background:#1c3b39;color:#fff}.workspace{display:grid;align-content:start;grid-gap:20px;gap:20px;padding:28px}.topbar{display:flex;align-items:center;justify-content:space-between;gap:20px;min-height:72px}.modal h2,.panel h2,.topbar h1{margin:0}.topbar h1{font-size:30px;line-height:1.15}.eyebrow{margin:0 0 6px;color:var(--muted);font-size:12px;font-weight:700;letter-spacing:0}.account-toolbar,.action-row,.button-row,.modal-actions,.profile-summary,.status-row{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.role-pill,.status-pill{display:inline-flex;align-items:center;justify-content:center;min-height:28px;border-radius:999px;padding:0 10px;font-size:13px;font-weight:700;white-space:nowrap}.status-pill.active{background:#ddf6ee;color:#116149}.status-pill.muted{background:#edf0f3;color:#697783}.role-pill{background:#e9efff;color:#264b9b}.notice-bar{margin:0;border:1px solid #d7eadf;border-radius:8px;background:#f0fbf5;color:#246344;padding:11px 14px}.metric-grid{display:grid;grid-template-columns:repeat(4,minmax(150px,1fr));grid-gap:14px;gap:14px}.metric-card,.panel{border:1px solid var(--line);border-radius:8px;background:var(--panel);box-shadow:var(--shadow)}.metric-card{display:flex;align-items:center;gap:14px;min-height:112px;padding:18px}.icon-slot{display:grid;width:44px;height:44px;flex:0 0 auto;place-items:center;border-radius:8px;background:#eef7f6;color:var(--brand)}.metric-card strong{display:block;font-size:26px;line-height:1.1}.metric-card p{margin:6px 0 0;color:var(--muted)}.panel{display:grid;grid-gap:18px;gap:18px;padding:20px}.panel-heading{display:flex;align-items:center;justify-content:space-between;gap:18px}.institution-list{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));grid-gap:14px;gap:14px}.institution-item{display:grid;grid-gap:14px;gap:14px;border:1px solid var(--line);border-radius:8px;padding:14px}.institution-item.selected{border-color:var(--brand);box-shadow:0 0 0 3px rgba(22,117,111,.12)}.plain-row{display:grid;border:0;background:transparent;color:inherit;padding:0;text-align:left}.plain-row strong{font-size:16px}.institution-meta,.plain-row span{color:var(--muted);font-size:13px}.limit-row{display:grid;grid-template-columns:1fr 1fr;grid-gap:10px;gap:10px}.limit-row label{color:var(--muted)}.limit-row input{margin-top:6px}.institution-meta{display:flex;gap:10px;flex-wrap:wrap}.profile-grid{grid-template-columns:minmax(0,1.4fr) minmax(280px,.8fr)}.form-card,.profile-grid{display:grid;grid-gap:14px;gap:14px}.form-card{align-content:start;border:1px solid var(--line);border-radius:8px;padding:16px}.form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));grid-gap:12px;gap:12px}.identifier-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));grid-gap:10px;gap:10px}.identifier-grid>div,.institution-id-row{display:grid;grid-gap:6px;gap:6px;border:1px solid var(--line);border-radius:8px;background:#f7faf9;padding:10px 12px}.field-hint,.identifier-grid span,.institution-id-row span{color:var(--muted);font-size:12px}.identifier-grid code,.institution-id-row code,.uid-cell code{color:#223039;font-family:inherit;font-size:12px;font-weight:700;line-height:1.35;overflow-wrap:anywhere}.form-card input[readonly]{background:#f4f7f7;color:#5d6d75;cursor:not-allowed}.form-card-heading{display:flex;align-items:center;gap:8px}.profile-summary{color:var(--muted);font-size:13px}.inline-message{margin:0;border-radius:8px;background:#fff4d8;color:#735500;padding:9px 11px}.invite-code-row{display:flex;align-items:center;gap:14px;flex-wrap:wrap}.invite-code-row code{display:inline-flex;align-items:center;min-height:42px;border-radius:8px;background:#11191f;color:#fff;font-size:18px;font-weight:800;letter-spacing:.08em;padding:0 14px}.invite-code-row span{color:var(--muted)}.account-toolbar{justify-content:space-between}.segmented-control{display:inline-flex;align-items:center;gap:4px;border:1px solid var(--line);border-radius:8px;background:#f3f6f8;padding:4px}.segmented-control button{min-height:34px;border:0;border-radius:6px;background:transparent;color:#53636f;font-weight:800;padding:0 12px}.segmented-control button.selected{background:#fff;color:var(--text);box-shadow:0 1px 4px rgba(26,38,48,.12)}.search-box{position:relative;display:flex;align-items:center;width:min(320px,100%);color:var(--muted)}.search-box svg{position:absolute;left:12px;pointer-events:none}.search-box input{padding-left:38px}.compact-button,.ghost-button,.icon-button,.primary-button{display:inline-flex;align-items:center;justify-content:center;border-radius:8px;border:1px solid transparent;text-decoration:none;white-space:nowrap}.compact-button,.ghost-button,.primary-button{min-height:40px;gap:8px;padding:0 13px;font-weight:700}.primary-button{background:var(--brand);color:#fff}.primary-button:hover{background:var(--brand-strong)}.ghost-button{margin-top:auto;border-color:rgba(255,255,255,.16);background:transparent;color:#e8f3f1}.modal-actions .ghost-button{margin-top:0;border-color:var(--line);color:var(--text)}.compact-button{width:-moz-fit-content;width:fit-content}.compact-button,.icon-button{border-color:var(--line);background:#fff;color:var(--text)}.icon-button{position:relative;width:36px;height:36px}.compact-button:hover,.icon-button:hover{border-color:#b9c5cf}.icon-button.danger{color:var(--danger)}[data-tooltip]:hover:after{position:absolute;bottom:calc(100% + 8px);left:50%;z-index:4;width:max-content;max-width:180px;transform:translateX(-50%);border-radius:6px;background:#11191f;color:#fff;content:attr(data-tooltip);font-size:12px;padding:6px 8px;pointer-events:none}.table-wrap{overflow-x:auto}table{width:100%;border-collapse:collapse;min-width:760px}td,th{border-bottom:1px solid var(--line);padding:14px 10px;text-align:left;vertical-align:middle}th{color:var(--muted);font-size:13px}td{color:#2c3941}.empty-cell{height:96px;color:var(--muted);text-align:center}.module-grid{display:grid;grid-template-columns:repeat(5,minmax(160px,1fr));grid-gap:14px;gap:14px}.module-card{display:grid;min-height:210px;align-content:start;grid-gap:12px;gap:12px;border:1px solid var(--line);border-radius:8px;padding:16px}.module-card.enabled{border-color:transparent}.module-card.locked{background:#f2f4f6;color:#71808c}.module-teal.enabled{background:#e9f7f4}.module-amber.enabled{background:#fff4d8}.module-blue.enabled{background:#eaf2ff}.module-rose.enabled{background:#ffecef}.module-violet.enabled{background:#f2edff}.module-top{display:flex;align-items:center;justify-content:space-between;gap:12px}.module-top>span:first-child{display:inline-flex;align-items:center;min-height:30px;border-radius:999px;background:rgba(255,255,255,.68);color:#26343c;font-size:13px;font-weight:800;padding:0 10px}.module-card h3{margin:0;font-size:18px}.module-card p{margin:0;color:#51616c;line-height:1.55}.module-card code{align-self:end;color:#526472;font-size:12px;overflow-wrap:anywhere}.module-link{display:inline-flex;align-items:center;justify-content:center;width:-moz-fit-content;width:fit-content;min-height:36px;border:1px solid rgba(23,32,38,.14);border-radius:8px;background:rgba(255,255,255,.76);color:var(--text);font-size:13px;font-weight:800;padding:0 12px;text-decoration:none}.module-link:hover{border-color:var(--brand);color:var(--brand-strong)}.switch{position:relative;display:inline-flex;width:46px;height:26px;align-items:center}.switch input{position:absolute;opacity:0}.switch i{position:absolute;inset:0;border-radius:999px;background:#bec8d0}.switch i:after{position:absolute;top:3px;left:3px;width:20px;height:20px;border-radius:50%;background:#fff;content:"";transition:transform .18s ease}.switch input:checked+i{background:var(--brand)}.switch input:checked+i:after{transform:translateX(20px)}.lock-mark{display:grid;width:34px;height:34px;place-items:center;border-radius:8px;background:rgba(255,255,255,.74)}.modal-backdrop{position:fixed;inset:0;z-index:10;display:grid;place-items:center;background:rgba(12,19,24,.52);padding:20px}.modal{display:grid;width:min(520px,100%);grid-gap:14px;gap:14px;border-radius:8px;background:#fff;box-shadow:0 24px 80px rgba(0,0,0,.24);padding:22px}.modal-heading{display:flex;align-items:center;justify-content:space-between;gap:14px}.modal label{display:grid;grid-gap:7px;gap:7px;color:var(--muted)}.modal-actions{justify-content:flex-end;padding-top:6px}.login-page{display:grid;min-height:100vh;place-items:center;padding:24px}.login-panel{display:grid;width:min(420px,100%);grid-gap:24px;gap:24px;border:1px solid var(--line);border-radius:8px;background:var(--panel);box-shadow:var(--shadow);padding:28px}.login-panel h1{margin:0;font-size:28px}.login-form{display:grid;grid-gap:14px;gap:14px}.auth-stack{display:grid;grid-gap:18px;gap:18px}.auth-mode-switch{width:100%}.auth-mode-switch button{flex:1 1}.login-form label{display:grid;grid-gap:7px;gap:7px;color:var(--muted);font-size:13px}.login-form input{min-height:44px;border:1px solid var(--line);border-radius:8px;color:var(--text);padding:0 12px}.form-message{margin:0;border-radius:8px;background:#fff4d8;color:#735500;padding:10px 12px}.empty-app{display:grid;min-height:100vh;place-items:center;padding:24px}.empty-state{display:grid;width:min(460px,100%);grid-gap:14px;gap:14px;justify-items:start;border:1px solid var(--line);border-radius:8px;background:var(--panel);box-shadow:var(--shadow);padding:28px}.empty-state h1,.empty-state p{margin:0}.empty-state p{color:var(--muted)}.module-page{display:grid;align-content:start;grid-gap:20px;gap:20px;min-height:100vh;padding:28px}.module-hero{display:grid;grid-gap:24px;gap:24px;border:1px solid var(--line);border-radius:8px;padding:28px}.module-guard h1,.module-guard p,.module-hero h1,.module-hero p{margin:0}.module-hero h1{font-size:32px}.module-hero>div>p:last-child{max-width:720px;color:#3e4e58;line-height:1.7}.module-back{display:inline-flex;align-items:center;width:-moz-fit-content;width:fit-content;min-height:38px;gap:8px;border:1px solid rgba(23,32,38,.16);border-radius:8px;background:rgba(255,255,255,.7);color:var(--text);font-weight:800;padding:0 12px;text-decoration:none}.module-meta-grid,.module-placeholder-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));grid-gap:14px;gap:14px}.module-guard,.module-meta-grid span,.module-placeholder-grid article{border:1px solid rgba(23,32,38,.12);border-radius:8px;background:rgba(255,255,255,.78);padding:16px}.module-meta-grid strong{display:block;margin-bottom:6px;color:var(--text);overflow-wrap:anywhere}.module-placeholder-grid p{margin:8px 0 0;color:var(--muted);line-height:1.65}.module-workbench{box-shadow:none}.module-guard{display:grid;width:min(560px,100%);grid-gap:16px;gap:16px;margin:10vh auto 0;background:var(--panel);box-shadow:var(--shadow)}.module-guard p{color:var(--muted);line-height:1.65}.points-page{background:#f6f7f9}.points-hero{background:#fff4d8}.petclass-module-page{min-height:100vh;background:#f9f9fa}.petclass-shell{min-height:100vh;--petclass-primary:#f7e8fb;--petclass-text:#333;--petclass-muted:#888;--petclass-progress-bg:#eee;--petclass-progress-fill:#e074b1;--petclass-card-bg:#fff;--petclass-bg:#f9f9fa;--petclass-accent:#8e62d6;background:var(--petclass-bg);color:var(--petclass-text);padding:20px 20px 90px}.petclass-header{display:flex;align-items:center;justify-content:space-between;gap:15px;margin-bottom:16px;flex-wrap:wrap}.petclass-batch-actions,.petclass-class-selector,.petclass-feature-ribbon,.petclass-top-actions{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.petclass-input,.petclass-select{min-height:38px;border:1px solid #ddd;border-radius:20px;background:#fff;color:var(--petclass-text);font-weight:700;outline:none;padding:0 15px}.petclass-select.class-select{border-color:var(--petclass-accent);background:#fdfafb;color:var(--petclass-accent);font-size:20px}.petclass-search{width:132px}.petclass-subtitle{display:inline-flex;align-items:center;min-height:32px;gap:6px;color:var(--petclass-muted);font-size:14px;font-weight:700}.petclass-subtitle strong{color:var(--petclass-accent)}.petclass-role-chip{display:inline-flex;align-items:center;min-height:30px;border-radius:999px;background:#fff0f6;color:#d9468d;font-size:13px;font-weight:900;padding:0 12px}.petclass-batch-bar button,.petclass-close-btn,.petclass-custom-score button,.petclass-feature-btn,.petclass-inline-form button,.petclass-nav-btn,.petclass-store-card button{display:inline-flex;align-items:center;justify-content:center;min-height:38px;border:1px solid #ddd;border-radius:20px;background:#fff;color:var(--petclass-text);font-weight:700;padding:0 16px;text-decoration:none;transition:transform .18s ease,box-shadow .18s ease,opacity .18s ease}.petclass-custom-score button:hover,.petclass-feature-btn:hover,.petclass-inline-form button:hover,.petclass-nav-btn:hover,.petclass-store-card button:hover{border-color:var(--petclass-accent);background:var(--petclass-primary);color:var(--petclass-accent)}.petclass-nav-btn.hint{min-height:30px;border-color:#c7d2fe;background:linear-gradient(135deg,#eef2ff,#e0e7ff);color:#4f46e5;font-size:13px}.petclass-nav-btn.store{border-color:#ffc9c9;background:#fff0f6;color:#e074b1}.petclass-nav-btn.settings{border:0;background:linear-gradient(135deg,#a18cd1,#fbc2eb);color:#fff}.petclass-nav-btn.back{border-color:#d1d5db;color:#64748b}.petclass-feature-ribbon{width:min(1320px,100%);margin:0 auto 18px;justify-content:flex-start;border-bottom:2px dashed #eadafb;padding:0 0 14px}.petclass-feature-btn{border-color:#e9d5ff;background:#fff;color:var(--petclass-accent);box-shadow:0 2px 8px rgba(142,98,214,.08)}.petclass-feature-btn span{margin-right:6px}.petclass-message{width:min(1120px,calc(100% - 32px));margin:14px auto 0;border:1px solid #f5c2d6;border-radius:18px;background:#fff0f6;color:#b83271;font-weight:800;padding:12px 16px}.petclass-main{width:min(1320px,100%);margin:0 auto}.petclass-welcome{display:grid;justify-items:center;grid-gap:14px;gap:14px;width:min(600px,100%);margin:8vh auto;border:3px solid #f9f2ff;border-radius:24px;background:#fff;box-shadow:0 15px 35px rgba(161,140,209,.15);padding:50px 40px;text-align:center}.petclass-welcome h1,.petclass-welcome p{margin:0}.petclass-welcome p{color:#6b6472;line-height:1.8}.petclass-student-grid{display:grid;grid-gap:20px;gap:20px}.petclass-class-section{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));grid-gap:20px;gap:20px}.petclass-class-divider{grid-column:1/-1;display:flex;align-items:center;gap:12px;margin-top:15px;margin-bottom:5px;border-bottom:2px dashed #eadafb;color:var(--petclass-accent);font-size:22px;font-weight:800;padding-bottom:8px}.petclass-class-divider span{color:#9ca3af;font-size:14px}.petclass-class-divider label{display:inline-flex;align-items:center;gap:6px;margin-left:10px;border-left:1px solid #ddd3e8;color:#7c7382;font-size:14px;font-weight:700;padding-left:14px}.petclass-student-card{position:relative;display:grid;grid-template-rows:auto auto auto auto;min-height:292px;overflow:hidden;border:2px solid transparent;border-radius:16px;background:var(--petclass-card-bg);box-shadow:0 4px 15px rgba(0,0,0,.04);padding:15px;transition:transform .18s ease,box-shadow .18s ease,border-color .18s ease}.petclass-student-card:hover{box-shadow:0 8px 25px rgba(0,0,0,.08);transform:translateY(-3px)}.petclass-student-card.selected{border-color:var(--petclass-accent);background:#fdfafb;box-shadow:0 4px 15px rgba(142,98,214,.08)}.petclass-student-card.current-user{border-color:#ffd89d}.petclass-checkbox{position:absolute;top:10px;right:10px;z-index:2;width:20px;height:20px}.petclass-card-top{display:flex;align-items:flex-start;justify-content:space-between;gap:10px;margin-bottom:10px}.petclass-card-top strong{display:block;color:var(--petclass-text);font-size:18px}.petclass-card-top strong em{display:inline-flex;margin-left:6px;border-radius:999px;background:#fff7ed;color:#ea580c;font-size:11px;font-style:normal;padding:2px 6px}.petclass-card-top small{display:inline-flex;margin-top:4px;border-radius:10px;background:#f0e6ff;color:var(--petclass-accent);font-size:11px;font-weight:700;padding:2px 8px}.petclass-badge-btn{align-self:start;min-height:30px;border:0;border-radius:999px;background:#fff7ed;color:#b45309;font-weight:900;padding:0 8px}.petclass-pet-area,.petclass-score-area{border:0;background:transparent;color:inherit;padding:0}.petclass-pet-area{display:grid;min-height:122px;border-radius:12px;margin:4px 0 12px;place-items:center}.petclass-pet-area:hover,.petclass-score-area:hover{background:#f5f5f5}.petclass-beast-wrap,.petclass-egg-wrap{display:grid;width:116px;height:116px;place-items:center;animation:petclass-float 3s ease-in-out infinite}.petclass-egg-svg{width:90px;height:110px;filter:drop-shadow(0 6px 10px rgba(230,212,250,.6))}.petclass-beast-wrap img{width:100%;height:100%;object-fit:contain;filter:drop-shadow(0 6px 10px color-mix(in srgb,var(--pet-accent) 22%,transparent))}.petclass-beast-wrap span{display:grid;width:128px;height:128px;place-items:center;border-radius:50%;background:color-mix(in srgb,var(--pet-accent) 16%,white);color:var(--pet-accent);font-size:46px;font-weight:900}.petclass-score-area{display:grid;grid-gap:7px;gap:7px;border-radius:8px;padding:5px;text-align:left}.petclass-card-footer,.petclass-egg-row,.petclass-progress-text{display:flex;align-items:center;justify-content:space-between;gap:8px}.petclass-egg-row strong,.petclass-pet-name{color:#3d3247;font-size:14px}.petclass-egg-row span{color:#f97316;font-size:13px;font-weight:900}.petclass-progress-text{color:var(--petclass-progress-fill);font-size:12px;font-weight:700}.petclass-progress{overflow:hidden;height:8px;border-radius:4px;background:var(--petclass-progress-bg)}.petclass-progress i{display:block;height:100%;border-radius:inherit;background:var(--petclass-progress-fill)}.petclass-card-footer{border-top:1px dashed #eee;color:var(--petclass-muted);font-size:12px;font-weight:700;padding-top:12px}.petclass-batch-bar{position:fixed;bottom:20px;left:50%;z-index:90;display:flex;align-items:center;justify-content:space-between;gap:16px;width:min(550px,80%);border-radius:40px;background:#fff;color:var(--petclass-text);box-shadow:0 4px 20px rgba(0,0,0,.08);padding:12px 25px;transform:translateX(-50%)}.petclass-batch-bar strong{font-size:20px}.petclass-batch-bar button{min-height:36px;border-color:#e5e7eb;border-radius:20px;background:#fff;color:#4b5563;padding:0 18px}.petclass-batch-bar button.score{border-color:transparent;background:linear-gradient(135deg,#c4b5fd,#fbc2eb);color:#fff;box-shadow:0 4px 10px rgba(196,181,253,.4)}.petclass-modal-overlay{position:fixed;inset:0;z-index:60;display:flex;align-items:center;justify-content:center;background:rgba(0,0,0,.5);padding:24px;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.petclass-modal{position:relative;display:grid;width:min(400px,90%);max-height:90vh;grid-gap:16px;gap:16px;overflow:auto;border-radius:20px;background:#fff;box-shadow:0 15px 40px rgba(0,0,0,.15);padding:25px}.petclass-modal.wide{width:min(800px,95vw)}.petclass-modal h2{margin:0;color:var(--petclass-text);font-size:20px;font-weight:800;text-align:center}.petclass-close-floating{position:absolute;top:10px;right:10px;width:32px;height:32px;border:0;border-radius:50%;background:#f0f0f0;color:#888;font-size:22px;font-weight:700;box-shadow:0 2px 8px rgba(0,0,0,.1)}.petclass-close-btn{width:100%;margin-top:2px;border:0;border-radius:10px;background:#f0f0f0;color:var(--petclass-text)}.petclass-help{color:#4b5563;line-height:1.75}.petclass-help h3{margin:10px 0 6px;border-bottom:2px dashed #eadafb;color:#a855f7;padding-bottom:5px}.petclass-help p,.petclass-muted{margin:0;color:#6b7280;line-height:1.7}.petclass-profile{display:flex;min-height:480px;overflow:hidden;border-radius:18px;background:#f8fafc}.petclass-profile-sidebar{display:flex;width:240px;flex-direction:column;align-items:center;gap:12px;border-right:1px solid #edf2f7;background:#fff;padding:40px 20px;text-align:center}.petclass-profile-avatar{display:grid;width:110px;height:110px;place-items:center;margin:0 auto;border-radius:50%;border:5px solid #fff;background:#f0f4ff;box-shadow:0 8px 25px rgba(79,70,229,.15);color:#4f46e5;font-size:45px;font-weight:900}.petclass-profile-sidebar h2,.petclass-profile-sidebar p{margin:0}.petclass-profile-sidebar p{color:#94a3b8}.petclass-profile-stat{display:flex;align-items:center;gap:12px;width:100%;border-radius:16px;border:1px solid #f1f5f9;background:#f8fafc;padding:15px;text-align:left}.petclass-profile-stat>span{font-size:26px}.petclass-profile-stat small{display:block;color:#8b7f91}.petclass-profile-stat strong{font-size:22px}.petclass-profile-main{display:flex;min-width:0;flex:1 1;flex-direction:column;background:#fff}.petclass-profile-tabs{display:flex;gap:30px;flex-wrap:wrap;border-bottom:1px solid #edf2f7;padding:0 30px}.petclass-profile-tabs button,.petclass-profile-tabs span{border:0;border-radius:0;background:transparent;color:#64748b;font-size:16px;font-weight:800;padding:20px 10px}.petclass-profile-tabs .active{border-bottom:3px solid #4f46e5;color:#4f46e5}.petclass-score-sections{display:grid;grid-gap:16px;gap:16px}.petclass-score-sections h3{margin:0 0 10px;color:#475569;font-size:15px;font-weight:800}.petclass-score-sections h3.negative{color:#dc2626}.petclass-action-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(130px,1fr));grid-gap:15px;gap:15px}.petclass-action-grid button{display:grid;grid-gap:6px;gap:6px;min-height:118px;border:1px solid #e2e8f0;border-radius:20px;background:#fff;color:#334155;padding:18px 10px;text-align:center;box-shadow:0 2px 6px rgba(0,0,0,.02)}.petclass-action-grid button.negative{border-color:#e2e8f0;background:#fff;color:#334155}.petclass-action-grid button.positive:hover{border-color:#a7f3d0}.petclass-action-grid button.negative:hover{border-color:#fecdd3}.petclass-action-grid button span{font-size:26px}.petclass-action-grid button em,.petclass-action-grid button strong{font-style:normal}.petclass-readonly-note{border-radius:18px;background:#f8fafc;color:#6b7280;padding:18px}.petclass-custom-score,.petclass-inline-form{display:grid;grid-template-columns:minmax(0,1fr) 90px auto;grid-gap:8px;gap:8px}.petclass-inline-form.reward{grid-template-columns:60px minmax(0,1fr) 82px auto}.petclass-custom-score input,.petclass-inline-form input{min-height:42px;border:2px solid #ead7f5;border-radius:14px;outline:none;padding:0 12px}.petclass-custom-score button,.petclass-inline-form button{border:0;background:linear-gradient(135deg,#a78bfa,#ec4899);color:#fff}.petclass-boss-grid,.petclass-feature-preview,.petclass-pokedex-grid,.petclass-store-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));grid-gap:15px;gap:15px}.petclass-boss-grid article,.petclass-feature-preview article,.petclass-pokedex-grid article,.petclass-store-card{display:grid;grid-gap:8px;gap:8px;border:2px solid #e0f2fe;border-radius:16px;background:#f0f9ff;padding:20px 10px;text-align:center;transition:.2s}.petclass-boss-grid article:hover,.petclass-feature-preview article:hover,.petclass-pokedex-grid article:hover,.petclass-store-card:hover{transform:translateY(-5px)}.petclass-boss-grid article:nth-child(4n+2),.petclass-feature-preview article:nth-child(4n+2),.petclass-pokedex-grid article:nth-child(4n+2),.petclass-store-card:nth-child(4n+2){border-color:#fbcfe8;background:#fdf2f8}.petclass-boss-grid article:nth-child(4n+3),.petclass-feature-preview article:nth-child(4n+3),.petclass-pokedex-grid article:nth-child(4n+3),.petclass-store-card:nth-child(4n+3){border-color:#ddd6fe;background:#f5f3ff}.petclass-boss-grid article:nth-child(4n+4),.petclass-feature-preview article:nth-child(4n+4),.petclass-pokedex-grid article:nth-child(4n+4),.petclass-store-card:nth-child(4n+4){border-color:#bbf7d0;background:#f0fdf4}.petclass-boss-grid article>span,.petclass-feature-preview article>span,.petclass-pokedex-grid article>span,.petclass-store-card>span{font-size:40px}.petclass-boss-grid p,.petclass-feature-preview p,.petclass-feature-preview small,.petclass-pokedex-grid p,.petclass-pokedex-grid small,.petclass-store-card p,.petclass-store-card small{margin:0;color:#6b7280;line-height:1.5}.petclass-store-card button{width:100%;min-height:34px;border:1px solid rgba(0,0,0,.1);border-radius:20px;background:#fff;color:var(--petclass-text);font-size:12px;padding:0 15px}.petclass-store-card em{border:1px dashed #d1d5db;border-radius:999px;color:#9ca3af;font-style:normal;padding:8px}.petclass-history-grid,.petclass-settings-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));grid-gap:18px;gap:18px}.petclass-history-grid h3,.petclass-settings-grid h3{margin:0 0 10px;color:#34263f}.petclass-history-line{display:grid;grid-template-columns:minmax(0,1fr) auto;grid-gap:6px 10px;gap:6px 10px;border-top:1px solid #f0e6f6;padding:10px 0}.petclass-history-line small{grid-column:1/-1;color:#6b7280}.petclass-history-line strong.positive{color:#16a34a}.petclass-history-line strong.negative{color:#dc2626}.petclass-chip-list,.petclass-settings-list{display:flex;max-height:180px;gap:8px;overflow:auto;flex-wrap:wrap;border:1px solid #eee;border-radius:10px;background:#fdfafb;margin-bottom:16px;padding:10px}.petclass-chip-list span,.petclass-settings-list span{display:inline-flex;align-items:center;min-height:34px;gap:8px;border-radius:999px;background:#fff;color:#6d4a8f;font-size:13px;font-weight:900;padding:0 11px}.petclass-settings-list small{color:#9ca3af}.petclass-import-box{border:1px dashed #c7d2fe;border-radius:10px;background:#f0f4ff;color:#4f46e5;line-height:1.7;padding:14px}.petclass-pokedex-grid article{border-color:color-mix(in srgb,var(--pet-accent) 34%,white);background:color-mix(in srgb,var(--pet-accent) 10%,white)}@keyframes petclass-float{0%,to{transform:translateY(0)}50%{transform:translateY(-8px)}}.points-workbench{display:grid;grid-gap:20px;gap:20px}.points-command-bar{display:grid;grid-template-columns:minmax(0,.9fr) minmax(420px,1.1fr);grid-gap:18px;gap:18px;align-items:center;border:1px solid #f2d9a0;border-radius:8px;background:#fff9ea;padding:18px 20px}.points-command-bar h2{margin:0 0 6px;font-size:22px}.points-command-bar span{color:#7a5b17;line-height:1.6}.points-stat-strip{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));grid-gap:10px;gap:10px}.points-stat-strip span{display:grid;min-height:82px;grid-gap:5px;gap:5px;border:1px solid #f0dfb7;border-radius:8px;background:#fff;color:var(--muted);padding:12px}.points-stat-strip svg{color:#b36b00}.points-stat-strip strong{display:block;color:var(--text);font-size:22px}.points-layout{display:grid;grid-template-columns:minmax(0,1.5fr) minmax(320px,.65fr);grid-gap:20px;gap:20px}.points-layout.lower{grid-template-columns:minmax(0,1.35fr) minmax(320px,.8fr)}.points-panel{display:grid;grid-gap:16px;gap:16px;border:1px solid var(--line);border-radius:8px;background:#fff;padding:20px}.points-side-stack{display:grid;align-content:start;grid-gap:20px;gap:20px}.points-search{max-width:380px}.points-toolbar{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.points-toolbar select{min-height:42px;border:1px solid var(--line);border-radius:8px;background:#fff;color:var(--text);padding:0 12px}.points-student-grid{display:grid;grid-template-columns:repeat(3,minmax(210px,1fr));grid-gap:14px;gap:14px}.pet-student-card{display:grid;grid-gap:12px;gap:12px;min-height:250px;border:1px solid var(--line);border-radius:8px;background:#fbfcfd;color:var(--text);padding:14px;text-align:left}.pet-student-card.selected{border-color:#f59e0b;background:#fff8e7;box-shadow:0 0 0 3px rgba(245,158,11,.16)}.pet-student-card:disabled{cursor:default;opacity:1}.history-line,.pet-card-meta,.pet-card-top{display:flex;align-items:center;justify-content:space-between;gap:12px}.active-student-summary strong,.pet-card-top strong,.reward-card strong{display:block}.active-student-summary p,.active-student-summary span,.history-line small,.pet-card-meta,.pet-card-top span,.pet-student-card small,.reward-card p{color:var(--muted)}.badge-count{display:inline-flex;align-items:center;gap:4px;border-radius:999px;background:#fff;color:#9a6700;font-size:12px;font-weight:800;padding:4px 8px}.pet-visual-card{display:grid;width:116px;height:116px;place-items:center;justify-self:center;border:2px solid color-mix(in srgb,var(--pet-accent) 46%,white);border-radius:50%;background:radial-gradient(circle at 36% 28%,rgba(255,255,255,.95),rgba(255,255,255,.18) 32%),color-mix(in srgb,var(--pet-accent) 20%,white);box-shadow:inset 0 -18px 34px rgba(0,0,0,.08)}.pet-visual-card.egg{border-radius:48% 48% 44% 44%/58% 58% 42% 42%}.pet-visual-card.compact{width:74px;height:74px}.pet-visual-card span{color:var(--pet-accent);font-size:34px;font-weight:900}.pet-progress{overflow:hidden;height:9px;border-radius:999px;background:#edf1f4}.pet-progress i{display:block;height:100%;border-radius:inherit;background:linear-gradient(90deg,#f59e0b,#22c55e)}.active-student-summary{display:flex;align-items:center;gap:14px}.active-student-summary p{margin:6px 0 0}.student-guide-panel{align-content:start;gap:8px;background:#f7fafc}.student-guide-panel svg{color:var(--brand)}.student-guide-panel p{margin:0;color:var(--muted);line-height:1.65}.rank-list{display:grid;grid-gap:8px;gap:8px}.rank-list div{display:grid;grid-template-columns:30px minmax(0,1fr) auto;align-items:center;grid-gap:10px;gap:10px;border:1px solid var(--line);border-radius:8px;background:#fbfcfd;padding:10px}.rank-list span{display:grid;width:26px;height:26px;place-items:center;border-radius:999px;background:#fff4d8;color:#9a6700;font-weight:800}.rank-list small{color:var(--muted);white-space:nowrap}.reward-grid,.score-rule-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));grid-gap:10px;gap:10px}.reward-card,.score-rule{display:grid;grid-gap:8px;gap:8px;border:1px solid var(--line);border-radius:8px;background:#fff;color:var(--text);padding:12px}.score-rule{grid-template-columns:minmax(0,1fr) auto;align-items:center;text-align:left}.score-rule.positive{background:#f0fdf4;border-color:#bbf7d0}.score-rule.negative{background:#fff1f2;border-color:#fecdd3}.positive-text,.score-rule strong{color:#15803d}.negative-text,.score-rule.negative strong{color:#be123c}.inline-form{display:grid;grid-template-columns:minmax(0,1fr) 100px auto;grid-gap:10px;gap:10px}.reward-form{grid-template-columns:64px minmax(0,1fr) 100px auto}.inline-form input{min-height:40px;border:1px solid var(--line);border-radius:8px;color:var(--text);padding:0 10px}.reward-card span:first-child{font-size:28px}.rule-list{display:flex;flex-wrap:wrap;gap:8px}.rule-list span{display:inline-flex;align-items:center;min-height:30px;gap:6px;border-radius:999px;background:#f3f6f8;color:#33424c;font-size:13px;padding:0 10px}.boss-preview-grid,.points-mini-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));grid-gap:10px;gap:10px}.boss-preview-grid article,.points-mini-grid article{display:grid;grid-gap:7px;gap:7px;border:1px solid var(--line);border-radius:8px;background:#fbfcfd;padding:12px}.points-mini-grid article{background:var(--points-card-bg,#fbfcfd)}.boss-preview-grid p,.points-mini-grid p,.points-mini-grid span{margin:0;color:var(--muted);line-height:1.5}.boss-preview-grid span{font-size:28px}.pet-type-row{display:flex;gap:8px;flex-wrap:wrap}.pet-type-row span{display:inline-flex;align-items:center;min-height:34px;border:1px solid color-mix(in srgb,var(--pet-accent) 40%,white);border-radius:999px;background:color-mix(in srgb,var(--pet-accent) 12%,white);color:#27343c;font-size:13px;font-weight:800;padding:0 11px}.points-history-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));grid-gap:16px;gap:16px}.points-history-grid h3{margin:0 0 10px;font-size:16px}.history-line{border-top:1px solid var(--line);padding:10px 0}@media (max-width:1180px){.petclass-header{align-items:flex-start;flex-direction:column}.petclass-class-section{grid-template-columns:repeat(auto-fill,minmax(190px,1fr))}.institution-list,.metric-grid,.module-grid,.module-meta-grid,.module-placeholder-grid,.points-command-bar,.points-history-grid,.points-layout,.points-layout.lower,.profile-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.points-student-grid{grid-template-columns:repeat(2,minmax(210px,1fr))}}@media (max-width:820px){.petclass-shell{padding:14px 14px 150px}.petclass-header{align-items:stretch}.petclass-class-selector,.petclass-feature-ribbon,.petclass-top-actions{width:100%}.petclass-input,.petclass-nav-btn,.petclass-select{flex:1 1 150px}.petclass-class-section{grid-template-columns:repeat(auto-fill,minmax(145px,1fr));gap:10px}.petclass-student-card{min-height:276px;padding:12px}.petclass-boss-grid,.petclass-feature-preview,.petclass-history-grid,.petclass-pokedex-grid,.petclass-profile,.petclass-settings-grid,.petclass-store-grid{grid-template-columns:1fr}.petclass-action-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.petclass-profile{display:block;max-height:70vh;overflow-y:auto}.petclass-profile-sidebar{width:100%;border-right:0;border-bottom:1px solid #edf2f7;padding:20px}.petclass-profile-tabs{justify-content:center;gap:15px;padding:0 15px}.petclass-profile-tabs button,.petclass-profile-tabs span{padding:10px 5px;font-size:14px}.petclass-batch-bar{align-items:flex-start;flex-direction:column}.app-shell{grid-template-columns:1fr}.sidebar{position:static;height:auto}.workspace{padding:18px}.panel-heading,.topbar{align-items:flex-start;flex-direction:column}.boss-preview-grid,.form-grid,.identifier-grid,.institution-list,.metric-grid,.module-grid,.module-meta-grid,.module-placeholder-grid,.points-command-bar,.points-history-grid,.points-layout,.points-layout.lower,.points-mini-grid,.points-stat-strip,.points-student-grid,.profile-grid{grid-template-columns:1fr}.ghost-button{margin-top:0}}@media (max-width:520px){.petclass-main{width:min(100% - 18px,1320px)}.petclass-action-grid,.petclass-class-section{grid-template-columns:1fr}.petclass-student-card{min-height:320px}.petclass-custom-score,.petclass-inline-form,.petclass-inline-form.reward{grid-template-columns:1fr}.petclass-modal-overlay{padding:12px}.petclass-modal{padding:22px 16px}.workspace{padding:14px}.topbar h1{font-size:24px}.panel{padding:16px}.module-page{padding:14px}.inline-form,.reward-form,.reward-grid,.score-rule-grid{grid-template-columns:1fr}.account-toolbar,.button-row,.compact-button,.ghost-button,.modal-actions,.primary-button,.search-box,.segmented-control,.segmented-control button{width:100%}}