.plant-select{padding:24px 32px 120px}.plant-select-title{font-family:var(--font-display);letter-spacing:-.3px;margin:0 0 8px;font-size:22px;font-weight:700}.plant-select-sub{color:var(--color-text-muted);margin:0 0 20px}.plant-species-grid{grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:14px;display:grid}.plant-species-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-card);cursor:pointer;text-align:left;font:inherit;color:inherit;flex-direction:column;gap:6px;padding:18px 14px;transition:border-color .12s,box-shadow .12s;display:flex}.plant-species-card:hover{border-color:var(--color-border-hover);box-shadow:var(--shadow-lift)}.plant-species-card[data-selected=true]{border-color:var(--color-plant-active);box-shadow:0 0 0 2px #27a35f33}.plant-species-emoji{font-size:36px;line-height:1}.plant-species-name{font-size:16px;font-weight:700}.plant-species-meta{color:var(--color-text-muted);flex-wrap:wrap;gap:8px;font-size:12px;display:flex}.plant-species-badge{background:var(--color-accent-tinted-bg);color:var(--color-accent-tinted-text);border-radius:var(--radius-pill);padding:1px 8px;font-size:11px;font-weight:600}.plant-select-bar{background:var(--color-bg-alt);border-top:1px solid var(--color-border);align-items:center;gap:12px;margin:24px -20px 0;padding:14px 20px;display:flex;position:sticky;bottom:0}.plant-select-bar input{border-radius:var(--radius-btn);border:1px solid var(--color-border);font:inherit;flex:1;padding:10px 12px}.plant-roadmap{padding:24px 32px}.plant-head-emoji{font-size:36px}.plant-head-name{font-size:18px;font-weight:700}.plant-head-nickname{color:var(--color-text-muted);font-size:14px}.plant-sheet-backdrop{z-index:90;background:#00000059;position:fixed;inset:0}.plant-sheet{background:var(--color-surface);z-index:100;max-height:78vh;box-shadow:var(--shadow-card);border-radius:16px 16px 0 0;padding:20px 20px 32px;position:fixed;bottom:0;left:0;right:0;overflow-y:auto}@media (min-width:768px){.plant-sheet{border-radius:16px 0 0 16px;width:420px;max-height:none;inset:0 0 0 auto}}.plant-sheet-head{justify-content:space-between;align-items:center;margin-bottom:12px;display:flex}.plant-sheet-title{font-size:18px;font-weight:700}.plant-sheet-points{background:var(--color-bg);border-radius:var(--radius-card);color:var(--color-text-muted);padding:12px 14px;font-size:14px;line-height:1.6}.plant-sheet-points h4{color:var(--color-text);margin:0 0 6px;font-size:13px}.plant-sheet-points ul{margin:0;padding-left:18px}.plant-obs-list{flex-direction:column;gap:14px;margin-top:16px;display:flex}.plant-obs-card{border:1px solid var(--color-border);border-radius:var(--radius-card);background:var(--color-surface);flex-shrink:0;width:220px;padding:12px 14px}.plant-obs-meta{color:var(--color-text-muted);justify-content:space-between;margin-bottom:6px;font-size:12px;display:flex}.plant-obs-imgs{gap:6px;margin:6px 0;display:flex;overflow-x:auto}.plant-obs-imgs img{object-fit:cover;cursor:pointer;border-radius:8px;flex:0 0 80px;width:80px;height:80px}.plant-obs-memo{white-space:pre-wrap;word-break:break-word;font-size:14px}.plant-obs-reason{color:var(--color-plant-stalled);margin-top:4px;font-size:12px}.plant-obs-actions{gap:8px;margin-top:6px;display:flex}.plant-obs-actions button{border:1px solid var(--color-border);border-radius:var(--radius-btn);cursor:pointer;background:0 0;padding:4px 10px;font-size:12px}.plant-sheet-actions{gap:10px;margin-top:18px;display:flex}.plant-sheet-actions button{border-radius:var(--radius-btn);cursor:pointer;border:1px solid var(--color-border);background:var(--color-surface);flex:1;padding:10px;font-weight:600}.plant-sheet-actions button.primary{background:var(--color-plant-active);border-color:var(--color-plant-active);color:#fff}.plant-teacher{padding:24px 32px}.plant-distribution{align-items:flex-end;gap:6px;margin-bottom:20px;padding-bottom:8px;display:flex;overflow-x:auto}.plant-dist-item{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-card);flex-direction:column;flex:0 0 80px;align-items:center;padding:10px 8px;display:flex}.plant-dist-count{color:var(--color-plant-active);font-size:22px;font-weight:800}.plant-dist-label{color:var(--color-text-muted);text-align:center;margin-top:2px;font-size:11px}.plant-student-table{border-collapse:collapse;width:100%}.plant-student-table th,.plant-student-table td{text-align:left;border-bottom:1px solid var(--color-border);padding:10px 8px;font-size:14px}.plant-student-table th{color:var(--color-text-muted);font-size:12px;font-weight:600}.plant-stalled-badge{color:var(--color-plant-stalled);border-radius:var(--radius-pill);background:#c628281a;padding:1px 8px;font-size:11px;font-weight:700}.plant-matrix-wrap{max-width:100%;padding:20px;overflow:auto}.plant-matrix{border-collapse:collapse}.plant-matrix th,.plant-matrix td{border:1px solid var(--color-border);text-align:center;vertical-align:middle;background:var(--color-surface);width:80px;height:80px}.plant-matrix thead th{background:var(--color-bg-alt);z-index:2;font-size:12px;position:sticky;top:0}.plant-matrix tbody th{background:var(--color-bg-alt);z-index:1;font-size:12px;position:sticky;left:0}.plant-matrix-cell img{object-fit:cover;cursor:zoom-in;border-radius:6px;width:64px;height:64px}.plant-matrix-empty{color:var(--color-text-faint);font-size:22px}.plant-matrix-forbidden{background:var(--color-surface);border-radius:var(--radius-card);border:1px solid var(--color-border);text-align:center;max-width:520px;margin:60px auto;padding:30px}.plant-modal-backdrop{z-index:200;background:#00000059;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.plant-modal{background:var(--color-surface);border-radius:var(--radius-card);width:100%;max-width:560px;max-height:92vh;box-shadow:var(--shadow-card);padding:22px;overflow-y:auto}.plant-modal h3{margin:0 0 12px}.plant-modal .plant-modal-row{margin-bottom:14px}.plant-modal textarea{border:1px solid var(--color-border);border-radius:var(--radius-btn);width:100%;font:inherit;min-height:90px;padding:10px}.plant-modal .plant-upload-drop{border:2px dashed var(--color-border);text-align:center;border-radius:var(--radius-card);cursor:pointer;color:var(--color-text-muted);padding:14px}.plant-modal .plant-upload-drop:hover{border-color:var(--color-plant-active);color:var(--color-plant-active)}.plant-thumb-grid{grid-template-columns:repeat(auto-fill,minmax(96px,1fr));gap:8px;margin-top:10px;display:grid}.plant-thumb{aspect-ratio:1;background:var(--color-bg);border-radius:8px;position:relative;overflow:hidden}.plant-thumb img{object-fit:cover;width:100%;height:100%}.plant-thumb .plant-thumb-x{color:#fff;cursor:pointer;background:#0000008c;border:0;border-radius:50%;width:24px;height:24px;font-size:14px;line-height:24px;position:absolute;top:2px;right:2px}.plant-modal-actions{justify-content:flex-end;gap:10px;margin-top:10px;display:flex}.plant-modal-actions button{border-radius:var(--radius-btn);border:1px solid var(--color-border);background:var(--color-surface);cursor:pointer;padding:8px 16px;font-weight:600}.plant-modal-actions button.primary{background:var(--color-plant-active);color:#fff;border-color:var(--color-plant-active)}.plant-modal-actions button:disabled{opacity:.5;cursor:not-allowed}.plant-observation-editor{gap:16px;display:grid}.plant-observation-editor h3,.plant-observation-editor .plant-modal-row,.plant-observation-editor .plant-modal-actions{margin:0}.plant-observation-editor .plant-modal-row{gap:10px;display:grid}.plant-observation-editor .plant-upload-drop{display:block}.plant-observation-editor .plant-thumb-grid,.plant-observation-editor .plant-upload-progress{margin-top:2px}.plant-observation-editor .plant-memo-count{color:var(--color-text-faint);text-align:right;margin-top:-2px;font-size:11px;line-height:1.3}.plant-observation-editor .plant-error{margin:-4px 0 0}.plant-reason-list label{border-radius:var(--radius-btn);cursor:pointer;align-items:center;gap:10px;padding:8px;display:flex}.plant-reason-list label:hover{background:var(--color-bg)}.plant-reason-other{border:1px solid var(--color-border);border-radius:var(--radius-btn);width:100%;font:inherit;padding:8px}.plant-error{color:var(--color-plant-stalled);margin-top:6px;font-size:13px}.plant-upload-progress{background:var(--color-plant-active);height:3px;animation:1.5s infinite plant-upload-indeterminate}@keyframes plant-upload-indeterminate{0%{width:0%}50%{width:70%}to{width:100%}}.plant-empty-state{text-align:center;color:var(--color-text-muted);padding:60px 20px}.plant-lightbox{z-index:300;cursor:zoom-out;background:#000000d9;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.plant-lightbox img{max-width:94vw;max-height:94vh}.plant-head-nickname{align-items:baseline;gap:8px;display:inline-flex}.plant-head-nickname-edit-btn{border:1px solid var(--color-border);border-radius:var(--radius-pill);color:var(--color-text-muted);cursor:pointer;background:0 0;padding:1px 10px;font-size:11px}.plant-head-nickname-edit-btn:hover{border-color:var(--color-border-hover);color:var(--color-text)}.plant-head-nickname-edit{gap:6px;margin-top:4px;display:flex}.plant-head-nickname-edit input{border:1px solid var(--color-border);border-radius:var(--radius-btn);font:inherit;max-width:200px;padding:4px 8px}.plant-head-nickname-edit button{border-radius:var(--radius-btn);border:1px solid var(--color-border);background:var(--color-surface);cursor:pointer;padding:4px 10px;font-size:12px}.plant-timeline{flex-direction:column;gap:18px;max-width:880px;margin:0 auto;display:flex}.plant-stage-row{grid-template-columns:48px 1fr;align-items:stretch;gap:14px;display:grid}.plant-stage-rail{flex-direction:column;justify-content:flex-start;align-items:center;min-height:100%;padding-top:10px;padding-bottom:10px;display:flex;position:relative}.plant-stage-connector{background:var(--color-plant-visited);border-radius:3px;flex:1 0 16px;width:3px}.plant-stage-connector[data-state=upcoming]{background:var(--color-plant-upcoming)}.plant-stage-connector[data-hidden=true]{background:0 0}.plant-stage-node{width:36px;height:36px;color:var(--color-text);z-index:1;background:var(--color-plant-visited);border-radius:50%;flex:none;justify-content:center;align-items:center;margin:4px 0;font-size:13px;font-weight:700;display:flex}.plant-stage-node[data-state=active]{background:var(--color-plant-active);color:#fff;box-shadow:0 2px 8px #27a35f59}.plant-stage-node[data-state=upcoming]{background:var(--color-bg-alt);color:var(--color-text-faint);border:2px solid var(--color-plant-upcoming)}.plant-stage-body{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-card);box-shadow:var(--shadow-sm);padding:16px 18px}.plant-stage-row[data-state=upcoming] .plant-stage-body{opacity:.6}.plant-stage-row[data-state=active] .plant-stage-body{border-color:var(--color-plant-active);box-shadow:0 0 0 2px #27a35f2e, var(--shadow-sm)}.plant-stage-body-head h3{align-items:center;gap:6px;margin:0 0 4px;font-size:15px;font-weight:700;display:flex}.plant-stage-body-head p{color:var(--color-text-muted);margin:0 0 10px;font-size:13px}.plant-stage-body-icon{font-size:18px;line-height:1}.plant-stage-body-pill{background:var(--color-plant-active);color:#fff;border-radius:var(--radius-pill);margin-left:4px;padding:1px 8px;font-size:11px;font-weight:700}.plant-stage-body-points{margin:6px 0 10px}.plant-stage-body-points h4{color:var(--color-text-muted);margin:0 0 4px;font-size:12px;font-weight:600}.plant-stage-body-points ul{color:var(--color-text);margin:0;padding-left:18px;font-size:13px;list-style:outside}.plant-stage-body-obs{margin-top:8px}.plant-stage-body-empty{color:var(--color-text-muted);margin:6px 0 4px;font-size:13px}.plant-stage-body-obs-grid{gap:10px;width:100%;padding-bottom:6px;display:flex;overflow-x:auto}.plant-stage-body-obs-grid::-webkit-scrollbar{height:4px}.plant-stage-body-obs-grid::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:4px}.plant-stage-body-actions{flex-wrap:wrap;gap:8px;margin-top:12px;display:flex}.plant-stage-body-actions button{border-radius:var(--radius-btn);border:1px solid var(--color-border);background:var(--color-surface);cursor:pointer;font:inherit;padding:6px 14px;font-size:13px}.plant-stage-body-actions button.primary{background:var(--color-plant-active);color:#fff;border-color:#0000}.plant-stage-body-actions button:disabled{opacity:.6;cursor:not-allowed}.plant-teacher-mode{padding:0}.plant-teacher-banner{background:var(--color-accent-tinted-bg);max-width:880px;color:var(--color-accent-tinted-text);border-radius:var(--radius-card);border:1px solid var(--color-border);align-items:center;gap:10px;margin:0 auto 14px;padding:10px 14px;font-size:13px;display:flex}.plant-teacher-banner-text{flex:1}.plant-teacher-banner-back{color:var(--color-accent-tinted-text);border:1px solid var(--color-border);border-radius:var(--radius-pill);background:var(--color-surface);padding:2px 10px;font-weight:600;text-decoration:none}.plant-teacher-banner-back:hover{border-color:var(--color-border-hover)}.plant-student-row-link{cursor:pointer;transition:background .12s}.plant-student-row-link:hover{background:var(--color-bg-alt)}.plant-student-row-link:focus{outline:2px solid var(--color-accent);outline-offset:-2px}.plant-student-row-name{color:var(--color-text);font-weight:600;text-decoration:none}.plant-student-row-name:hover{text-decoration:underline}.plant-matrix-secondary-link{color:var(--color-text-muted);border:1px solid var(--color-border);border-radius:var(--radius-btn);background:0 0;align-items:center;gap:4px;padding:5px 10px;font-size:12px;text-decoration:none;display:inline-flex}.plant-matrix-secondary-link:hover{border-color:var(--color-border-hover);color:var(--color-text)}@media (max-width:560px){.plant-stage-row{grid-template-columns:32px 1fr;gap:10px}.plant-stage-node{width:28px;height:28px;font-size:12px}.plant-stage-body{padding:12px 14px}.plant-stage-body-obs-grid{flex-wrap:nowrap}.plant-teacher-banner{flex-direction:column;align-items:flex-start}}@media (prefers-reduced-motion:reduce){.plant-stage-node,.plant-student-row-link{transition:none}}.plant-student-hero{grid-template-columns:repeat(2,minmax(0,1fr));align-items:stretch;gap:14px;max-width:1080px;margin:0 auto 22px;display:grid}.plant-hero-main-card,.plant-hero-mission-card,.plant-teacher-hero,.plant-teacher-panel,.plant-matrix-toolbar,.plant-matrix-drilldown{background:linear-gradient(145deg,#fffdf7,#f8f5ec);border:1px solid #5b805e2e;border-radius:22px;box-shadow:0 18px 42px #3d4e3014}.plant-hero-main-card{padding:22px;position:relative;overflow:hidden}.plant-hero-main-card:after{content:"";background:radial-gradient(circle,#27a35f29,#0000 66%);border-radius:50%;width:150px;height:150px;position:absolute;top:-44px;right:-44px}.plant-hero-eyebrow{color:#66825f;letter-spacing:.08em;text-transform:uppercase;align-items:center;gap:6px;font-size:11px;font-weight:800;display:inline-flex}.plant-hero-title-row{align-items:center;gap:12px;margin-top:12px;display:flex}.plant-hero-progress{margin-top:22px}.plant-hero-progress-head,.plant-hero-stat-row{color:var(--color-text-muted);justify-content:space-between;align-items:center;gap:10px;font-size:13px;display:flex}.plant-hero-progress-head strong,.plant-hero-stat-row strong{color:var(--color-text)}.plant-hero-progress-track{background:#27a35f1f;border-radius:999px;height:12px;margin-top:8px;overflow:hidden}.plant-hero-progress-track span{border-radius:inherit;background:linear-gradient(90deg,#27a35f,#9bbf52);height:100%;display:block}.plant-hero-stat-row{flex-wrap:wrap;justify-content:flex-start;margin-top:16px}.plant-hero-stat-row span{background:#ffffffb8;border:1px solid #5b805e29;border-radius:999px;padding:6px 10px}.plant-hero-mission-card{background:linear-gradient(145deg,#f2f8e9,#fffaf0);padding:20px}.plant-hero-mission-card h2{letter-spacing:-.3px;margin:10px 0 12px;font-size:20px}.plant-hero-mission-card ul{gap:8px;margin:0 0 16px;padding:0;list-style:none;display:grid}.plant-hero-mission-card li{color:var(--color-text);padding-left:20px;font-size:13px;line-height:1.45;position:relative}.plant-hero-mission-card li:before{content:"✓";color:var(--color-plant-active);font-weight:900;position:absolute;top:0;left:0}.plant-matrix-shell{padding:24px 32px}.plant-matrix-toolbar{justify-content:space-between;align-items:center;gap:14px;margin-bottom:14px;padding:20px;display:flex}.plant-matrix-toolbar-stats span{color:var(--color-text-muted);background:#ffffffbd;border:1px solid #5b805e29;border-radius:999px;padding:8px 12px;font-size:12px}.plant-matrix-toolbar-stats strong{color:var(--color-text)}.plant-matrix-layout{grid-template-columns:minmax(0,1fr) 300px;align-items:start;gap:14px;display:grid}.plant-matrix-wrap{border:1px solid var(--color-border);background:var(--color-surface);border-radius:18px;max-width:100%;padding:0;overflow:auto}.plant-matrix-student-head,.plant-matrix-photo-btn{font:inherit;cursor:pointer;background:0 0;border:0;padding:0}.plant-matrix-student-head{width:100%;color:inherit;gap:2px;display:grid}.plant-matrix-student-head span{font-size:14px}.plant-matrix-student-head strong{font-size:12px}.plant-matrix th[data-selected=true],.plant-matrix-cell[data-selected=true]{box-shadow:inset 0 0 0 2px #27a35f47}.plant-matrix-cell[data-current=true]{outline-offset:-3px;outline:2px solid #2563eb66}.plant-matrix-current-dot{background:#2563eb;border-radius:50%;width:9px;height:9px;position:absolute;top:4px;left:4px;box-shadow:0 0 0 3px #2563eb24}.plant-matrix-photo-btn img{display:block}.plant-matrix-drilldown{padding:18px;position:sticky;top:16px}.plant-matrix-drilldown-plant,.plant-matrix-drilldown-note{color:var(--color-text-muted);font-size:13px;line-height:1.5}.plant-matrix-drilldown-stats{grid-template-columns:repeat(3,1fr);gap:8px;margin:14px 0;display:grid}.plant-matrix-drilldown-stats span{text-align:center;color:var(--color-text-muted);background:#ffffffb8;border:1px solid #5b805e24;border-radius:14px;padding:10px 6px;font-size:11px}.plant-matrix-drilldown-stats strong{color:var(--color-text);font-size:14px;display:block}.plant-matrix-mini-strip{grid-template-columns:repeat(5,1fr);gap:6px;display:grid}.plant-matrix-mini-strip span{background:var(--color-bg-alt);height:34px;color:var(--color-text-muted);border-radius:10px;place-items:center;font-size:12px;font-weight:800;display:grid}.plant-matrix-mini-strip span[data-filled=true]{color:#854d0e;background:#fefce8}.plant-matrix-mini-strip span[data-photo=true]{color:#166534;background:#dcfce7}.plant-matrix-mini-strip span[data-current=true]{outline:2px solid #2563eb}.plant-hero-game{color:#fff;background:linear-gradient(135deg,#2d6a4f 0%,#40916c 100%);border-radius:24px;justify-content:space-between;align-items:center;margin-bottom:28px;padding:32px 36px;display:flex}.plant-hero-game h1{letter-spacing:-.3px;margin:0;font-size:26px;font-weight:800}.plant-hero-game p{opacity:.85;margin:6px 0 0;font-size:14px}.plant-hero-game-actions{gap:10px;display:flex}.plant-kpi-game-grid{grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:28px;display:grid}.plant-kpi-game-card{background:var(--color-surface);cursor:pointer;border:none;border-left:4px solid #0000;border-radius:20px;padding:22px 24px;transition:all .2s;position:relative;overflow:hidden;box-shadow:0 2px 12px #0000000a}.plant-kpi-game-card:hover{transform:translateY(-4px);box-shadow:0 8px 24px #00000014}.plant-kpi-game-card .kpi-icon{margin-bottom:6px;font-size:26px}.plant-kpi-game-card .kpi-label{color:var(--color-text-muted);letter-spacing:.3px;text-transform:uppercase;font-size:11px;font-weight:600}.plant-kpi-game-card .kpi-value{letter-spacing:-1px;margin:4px 0;font-size:34px;font-weight:800;line-height:1}.plant-kpi-game-card .kpi-sub{color:var(--color-text-muted);font-size:12px}.plant-kpi-game-card .kpi-micro{background:#ece6dc;border-radius:4px;height:4px;margin-top:10px;overflow:hidden}.plant-kpi-game-card .kpi-micro-fill{border-radius:4px;height:100%;transition:width .4s}.kpi-tone-green{border-left-color:#2d6a4f}.kpi-tone-green .kpi-value{color:#2d6a4f}.kpi-tone-green .kpi-micro-fill{background:#2d6a4f}.kpi-tone-red{border-left-color:#d62828}.kpi-tone-red .kpi-value{color:#d62828}.kpi-tone-red .kpi-micro-fill{background:#d62828}.kpi-tone-amber{border-left-color:#e9a820}.kpi-tone-amber .kpi-value{color:#b8860b}.kpi-tone-amber .kpi-micro-fill{background:#e9a820}.kpi-tone-blue{border-left-color:#1d3557}.kpi-tone-blue .kpi-value{color:#1d3557}.kpi-tone-blue .kpi-micro-fill{background:#1d3557}.plant-dist-game{align-items:flex-end;gap:6px;height:180px;padding:0 4px;display:flex}.plant-dist-game-wrap{flex-direction:column;flex:1;justify-content:flex-end;align-items:center;height:100%;display:flex}.plant-dist-game-bar{background:linear-gradient(#52b788 0%,#40916c 100%);border-radius:8px 8px 4px 4px;width:100%;max-width:44px;min-height:6px;transition:height .4s;position:relative}.plant-dist-game-wrap:hover .plant-dist-game-bar{background:linear-gradient(#74c69d 0%,#52b788 100%)}.plant-dist-game-count{color:#2d6a4f;margin-bottom:3px;font-size:11px;font-weight:700}.plant-dist-game-label{color:var(--color-text-muted);margin-top:4px;font-size:10px}.plant-alert-game{gap:8px;margin:0;padding:0;list-style:none;display:grid}.plant-alert-game-card{cursor:pointer;font:inherit;text-align:left;background:#fef9ee;border:none;border-radius:14px;align-items:center;width:100%;padding:12px 14px;transition:all .2s;display:flex}.plant-alert-game-card:hover{background:#fef3d9;transform:translate(4px)}.plant-alert-game-avatar{background:#e9c46a;border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;width:38px;height:38px;margin-right:12px;font-size:18px;display:flex}.plant-alert-game-info{flex:1;min-width:0}.plant-alert-game-name{font-size:14px;font-weight:600}.plant-alert-game-meta{color:var(--color-text-muted);font-size:12px}.plant-alert-game-badge{color:#fff;background:#d62828;border-radius:20px;flex-shrink:0;padding:2px 10px;font-size:10px;font-weight:700}.plant-attention-groups{gap:10px;max-height:400px;overflow-y:auto}.plant-attention-group{border:1px solid var(--color-border);background:var(--color-surface);border-radius:14px;overflow:hidden}.plant-attention-summary{cursor:pointer;justify-content:space-between;align-items:center;gap:10px;padding:10px 12px;font-size:13px;font-weight:700;display:flex}.plant-attention-summary span:last-child{color:var(--color-text-muted);font-size:11px;font-weight:500}.plant-attention-list{gap:8px;padding:0 10px 10px;display:grid}.plant-attention-empty{color:var(--color-text-muted);margin:0;padding:0 12px 12px;font-size:12px}.plant-student-game-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:10px;display:grid}.plant-student-game-card{background:var(--color-surface);border:1px solid var(--color-border);cursor:pointer;font:inherit;text-align:left;color:inherit;border-radius:16px;align-items:center;width:100%;padding:14px 16px;transition:all .2s;display:flex}.plant-student-game-card:hover{border-color:#95d5b2;transform:translateY(-2px);box-shadow:0 4px 16px #2d6a4f1a}.plant-student-game-avatar{background:#edf7ed;border-radius:14px;flex-shrink:0;justify-content:center;align-items:center;width:44px;height:44px;margin-right:14px;font-size:24px;display:flex}.plant-student-game-info{flex:1;min-width:0}.plant-student-game-name{font-size:14px;font-weight:600}.plant-student-game-plant{color:var(--color-text-muted);font-size:12px}.plant-student-game-stage{align-items:center;gap:6px;margin-top:2px;display:flex}.plant-student-game-stage .stage-dot{border-radius:50%;width:8px;height:8px}.plant-student-game-stage .stage-green{background:#52b788}.plant-student-game-stage .stage-yellow{background:#e9c46a}.plant-student-game-stage .stage-red{background:#d62828}.plant-student-game-badge{border-radius:20px;flex-shrink:0;padding:2px 10px;font-size:10px;font-weight:700}.badge-game-stalled{color:#d62828;background:#ffe0e0}.badge-game-ok{color:#2d6a4f;background:#e0f5e0}.badge-game-pending{color:#5b6b7f;background:#f0f2f5}.plant-matrix-game{background:var(--color-surface);border:1px solid var(--color-border);border-radius:20px;margin-top:28px;padding:24px}.plant-matrix-game-head{justify-content:space-between;align-items:center;margin-bottom:16px;display:flex}.plant-matrix-game-head h3{margin:0;font-size:16px;font-weight:700}.plant-matrix-game-stats{color:var(--color-text-muted);gap:12px;font-size:12px;display:flex}.plant-matrix-game-stats strong{color:var(--color-text)}.plant-matrix-game-grid{grid-template-columns:100px repeat(auto-fill,minmax(56px,1fr));gap:4px;display:grid}.plant-matrix-game-label{color:var(--color-text-muted);align-items:center;padding:4px;font-size:11px;display:flex}.plant-matrix-game-cell{aspect-ratio:1;cursor:pointer;border:none;border-radius:10px;justify-content:center;align-items:center;font-family:inherit;font-size:18px;transition:all .12s;display:flex}.plant-matrix-game-cell:hover{transform:scale(1.15);box-shadow:0 2px 8px #0000001f}.mgc-photo{background:#d8f3dc}.mgc-empty{color:#b8d0c0;background:#f0f7f0}.mgc-current{box-shadow:inset 0 0 0 2px #52b788}.mgc-stale{background:#fef3d9}.plant-matrix-game-header{color:var(--color-text-muted);justify-content:center;align-items:center;padding:4px;font-size:11px;font-weight:600;display:flex}.plant-view-toggle{background:#f0f2f5;border-radius:12px;gap:4px;padding:3px;display:flex}.plant-view-toggle button{cursor:pointer;color:var(--color-text-muted);background:0 0;border:none;border-radius:10px;padding:6px 14px;font-family:inherit;font-size:12px;font-weight:600;transition:all .15s}.plant-view-toggle button[data-active=true]{color:var(--color-text);background:#fff;box-shadow:0 1px 4px #0000000f}.plant-view-toggle button:hover:not([data-active=true]){color:var(--color-text)}.plant-dash-game{grid-template-columns:1.6fr 1fr;gap:18px;margin-bottom:28px;display:grid}.plant-panel-game{background:#fff;border:1px solid #0f172a14;border-radius:20px;padding:24px;box-shadow:0 8px 24px #0f172a0d}.plant-panel-game-head{justify-content:space-between;align-items:center;margin-bottom:16px;display:flex}.plant-panel-game-head h3{margin:0;font-size:16px;font-weight:700}.plant-panel-game-eyebrow{color:var(--color-text-muted);letter-spacing:.5px;text-transform:uppercase;font-size:11px;font-weight:600}@media (max-width:1100px){.plant-student-hero,.plant-teacher-dashboard-grid,.plant-dash-game,.plant-matrix-layout{grid-template-columns:1fr}.plant-matrix-drilldown{position:static}}@media (max-width:860px){.plant-teacher-hero,.plant-matrix-toolbar,.plant-teacher-panel-head,.plant-teacher-table-head{flex-direction:column;align-items:stretch}.plant-teacher-kpi-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (max-width:560px){.plant-roadmap,.plant-teacher,.plant-matrix-shell{padding:12px}.plant-student-hero,.plant-teacher-kpi-grid{grid-template-columns:1fr}.plant-hero-main-card,.plant-hero-mission-card,.plant-teacher-hero,.plant-teacher-panel,.plant-matrix-toolbar,.plant-matrix-drilldown{border-radius:16px;padding:14px}.plant-teacher-table-tools input,.plant-teacher-table-tools select{width:100%}}.plant-dist-item{position:relative;overflow:hidden}.plant-dist-bar{background:linear-gradient(to top, var(--color-plant-active), color-mix(in srgb, var(--color-plant-active) 60%, transparent));opacity:.35;z-index:0;border-radius:4px 4px 0 0;min-height:4px;transition:height .3s;position:absolute;bottom:0;left:0;right:0}.plant-dist-count,.plant-dist-label{z-index:1;position:relative}.plant-matrix-cell{position:relative}.plant-matrix-count-badge{background:var(--color-plant-active);color:#fff;border-radius:9px;justify-content:center;align-items:center;min-width:18px;height:18px;font-size:10px;font-weight:700;line-height:1;display:flex;position:absolute;top:2px;right:2px;box-shadow:0 1px 3px #0003}.plant-matrix-cell[data-freshness=recent]{background:#f0fdf4}.plant-matrix-cell[data-freshness=stale]{background:#fefce8}.plant-matrix-cell[data-freshness=stalled]{background:#fef2f2}.plant-matrix-cell[data-freshness=none]{background:var(--color-bg)}@media (max-width:1023px){.plant-matrix-cell img{width:44px;height:44px}.plant-matrix th,.plant-matrix td{width:60px;height:60px}}.plant-milestone-badge{color:#7c5a00;border-radius:var(--radius-pill);background:linear-gradient(135deg,gold,#fa0);align-items:center;gap:4px;margin-left:6px;padding:2px 10px;font-size:11px;font-weight:700;animation:.4s cubic-bezier(.175,.885,.32,1.275) plant-badge-pop;display:inline-flex}@keyframes plant-badge-pop{0%{opacity:0;transform:scale(0)}60%{transform:scale(1.2)}to{opacity:1;transform:scale(1)}}.plant-celebration-banner{text-align:center;border-radius:var(--radius-card);background:linear-gradient(135deg,#ffd70015,#ffaa0015);border:1px solid #ffd70040;margin-bottom:12px;padding:12px 16px;font-size:14px;font-weight:700;animation:3s ease-out forwards plant-celebrate-fade}@keyframes plant-celebrate-fade{0%,60%{opacity:1;transform:translateY(0)}to{opacity:0;pointer-events:none;transform:translateY(-10px)}}.plant-stall-indicator{border-radius:var(--radius-pill);align-items:center;gap:6px;margin-top:6px;padding:4px 12px;font-size:12px;font-weight:600;display:inline-flex}.plant-stall-indicator[data-level=ok]{color:#15803d;background:#f0fdf4}.plant-stall-indicator[data-level=warn]{color:#a16207;background:#fefce8}.plant-stall-indicator[data-level=danger]{color:#dc2626;background:#fef2f2;animation:2s infinite plant-pulse}@keyframes plant-pulse{0%,to{opacity:1}50%{opacity:.6}}.plant-head-nickname-click{cursor:pointer;border-radius:var(--radius-btn);border:1px solid #0000;padding:2px 8px;transition:background .12s}.plant-head-nickname-click:hover{background:var(--color-bg);border-color:var(--color-border)}.plant-head-nickname-click:after{content:"✏️";opacity:.4;margin-left:4px;font-size:11px;transition:opacity .12s}.plant-head-nickname-click:hover:after{opacity:1}.plant-img-fallback{background:var(--color-bg-alt);width:100%;height:100%;color:var(--color-text-faint);border-radius:8px;justify-content:center;align-items:center;font-size:32px;display:flex}.plant-compare-wrap{-webkit-user-select:none;user-select:none;border-radius:8px;margin-top:10px;position:relative;overflow:hidden}.plant-compare-img{object-fit:cover;width:100%;height:180px;display:block}.plant-compare-overlay{z-index:2;height:100%;position:absolute;top:0;left:0;overflow:hidden}.plant-compare-overlay img{object-fit:cover;width:100%;height:180px;display:block}.plant-compare-handle{z-index:3;cursor:col-resize;background:#fff;width:3px;position:absolute;top:0;bottom:0;box-shadow:0 0 6px #0006}.plant-compare-handle:after{content:"↔";background:#fff;border-radius:50%;justify-content:center;align-items:center;width:28px;height:28px;font-size:14px;display:flex;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);box-shadow:0 1px 4px #0000004d}.plant-compare-toggle{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-btn);cursor:pointer;color:var(--color-text-muted);align-items:center;gap:4px;margin-top:6px;padding:4px 10px;font-size:12px;transition:all .12s;display:inline-flex}.plant-compare-toggle:hover{border-color:var(--color-plant-active);color:var(--color-plant-active)}.plant-parent-list{gap:20px;display:grid}.plant-parent-section{background:var(--color-surface);border:1px solid var(--color-border);border-radius:12px;padding:16px}.plant-parent-header{flex-wrap:wrap;align-items:center;gap:8px;margin-bottom:12px;display:flex}.plant-parent-header-emoji{font-size:22px;line-height:1}.plant-parent-header h2{margin:0;font-size:16px}.plant-parent-meta{color:var(--color-text-muted);flex-basis:100%;margin-top:4px;font-size:12px}.plant-parent-timeline{gap:14px;margin:0;padding:0;list-style:none;display:grid}.plant-parent-entry{border-left:3px solid var(--color-primary-soft,#eef2ff);padding-left:14px}.plant-parent-entry-meta{color:var(--color-text-muted);font-size:11px}.plant-parent-entry-memo{margin:4px 0 6px;font-size:14px;line-height:1.45}.plant-parent-entry-reason{color:var(--color-text-muted);margin:4px 0 6px;font-size:12px;font-style:italic}.plant-parent-entry-images{grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:6px;margin-top:4px;display:grid}.plant-parent-entry-image{background:var(--color-surface-muted,#f9fafb);border-radius:6px;width:100%;height:120px;position:relative;overflow:hidden}.plant-parent-empty-note{color:var(--color-text-muted);margin:0;font-size:13px}.plant-parent-empty-state{background:var(--color-surface);border:1px dashed var(--color-border);color:var(--color-text-muted);border-radius:12px;padding:20px;font-size:14px}.plant-growth-summary{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-card);flex-direction:column;gap:8px;margin-bottom:14px;padding:14px 16px;display:flex}.plant-growth-row{justify-content:space-between;align-items:center;font-size:13px;display:flex}.plant-growth-label{color:var(--color-text-muted)}.plant-growth-value{font-weight:700}.plant-growth-bar-track{background:var(--color-bg-alt);border-radius:4px;width:100%;height:8px;overflow:hidden}.plant-growth-bar-fill{background:linear-gradient(90deg, var(--color-plant-active), color-mix(in srgb, var(--color-plant-active) 70%, gold));border-radius:4px;height:100%;transition:width .6s}.plant-skeleton{background:linear-gradient(90deg, var(--color-bg-alt) 25%, var(--color-border) 50%, var(--color-bg-alt) 75%);background-size:200% 100%;border-radius:8px;animation:1.5s infinite plant-shimmer}@keyframes plant-shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.plant-skeleton-head{align-items:center;gap:12px;margin-bottom:16px;display:flex}.plant-skeleton-emoji{border-radius:50%;width:36px;height:36px}.plant-skeleton-title{width:120px;height:18px}.plant-skeleton-stage{height:100px;margin-bottom:14px}.plant-skeleton-obs{height:60px;margin-bottom:10px}.plant-breadcrumb{color:var(--color-text-muted);align-items:center;gap:6px;margin-bottom:8px;font-size:12px;display:flex}.plant-breadcrumb a{color:inherit;font-weight:500;text-decoration:none}.plant-breadcrumb a:hover{color:var(--color-text);text-decoration:underline}.plant-breadcrumb-sep{color:var(--color-text-faint)}.plant-student-thumb{object-fit:cover;background:var(--color-bg);border-radius:6px;width:40px;height:40px}.plant-filter-select{border-radius:var(--radius-btn);border:1px solid var(--color-border);font:inherit;background:var(--color-surface);cursor:pointer;padding:6px 10px;font-size:13px}.plant-filter-select:focus{outline:2px solid var(--color-plant-active);outline-offset:-2px}.plant-editor-thumb{cursor:zoom-in;transition:transform .12s}.plant-editor-thumb:hover{transform:scale(1.05)}.plant-obs-feed{gap:14px;display:grid}.plant-obs-feed-card{cursor:pointer;text-align:left;width:100%;font:inherit;color:#fff;aspect-ratio:1.08;background:#0f172a;border:1px solid #0f172a14;border-radius:14px;flex-direction:column;align-items:stretch;gap:0;padding:0;transition:transform .12s,box-shadow .12s,border-color .12s;display:flex;position:relative;overflow:hidden;box-shadow:0 8px 18px #0f172a1f}.plant-obs-feed-card:hover{border-color:#2563eb2e;transform:translateY(-2px);box-shadow:0 12px 24px #0f172a1c}.plant-obs-feed-thumb{object-fit:cover;background:var(--color-surface-alt);border-radius:0;width:100%;height:100%;transition:transform .18s;display:block}.plant-obs-feed-noimg{background:radial-gradient(circle at 28% 22%,#ffffff57,#0000 30%),linear-gradient(135deg,#16a34a,#0f766e 56%,#164e63);border:0;border-radius:0;place-items:center;width:100%;height:100%;font-size:36px;display:grid}.plant-obs-feed-info{color:#fff;text-shadow:0 1px 2px #0f172a6b;background:linear-gradient(#0f172a00 0%,#0f172ab8 42%,#0f172af0 100%);gap:3px;min-width:0;padding:34px 12px 11px;display:grid;position:absolute;inset:auto 0 0}.plant-obs-feed-card:hover .plant-obs-feed-thumb{transform:scale(1.035)}.plant-obs-feed-student{color:#fff;font-size:13px;font-weight:700;line-height:1.3}.plant-obs-feed-plant{color:#ffffffdb;text-overflow:ellipsis;white-space:nowrap;font-size:11px;overflow:hidden}.plant-obs-feed-memo{color:#fffc;text-overflow:ellipsis;white-space:nowrap;max-width:100%;font-size:12px;display:none;overflow:hidden}.plant-obs-feed-time{color:#ffffffbd;font-size:11px}.plant-obs-detail-modal{background:var(--color-surface);cursor:default;border-radius:20px;flex-direction:column;width:90vw;max-width:580px;max-height:85vh;display:flex;position:relative;overflow-y:auto}.plant-obs-detail-close{z-index:2;position:absolute;top:12px;right:12px}.plant-obs-detail-img-wrap{aspect-ratio:16/10;background:var(--color-surface-alt);border-radius:20px 20px 0 0;width:100%;position:relative;overflow:hidden}.plant-obs-detail-info{gap:10px;padding:20px 24px 24px;display:grid}.plant-obs-detail-head{justify-content:space-between;align-items:center;gap:12px;display:flex}.plant-obs-detail-stage{color:var(--color-accent);font-size:13px;font-weight:600}.plant-obs-detail-student{color:var(--color-text);font-size:13px;font-weight:700}.plant-obs-detail-memo{color:var(--color-text);white-space:pre-wrap;margin:0;font-size:14px;line-height:1.6}.plant-obs-detail-nophoto{color:var(--color-text-muted);margin:0;font-size:13px}.plant-obs-detail-time{color:var(--color-text-faint);font-size:12px}.plant-obs-detail-img{object-fit:contain;width:100%;height:100%;display:block}.plant-obs-detail-empty{background:var(--color-surface-alt);border-radius:20px 20px 0 0;place-items:center;min-height:180px;font-size:52px;display:grid}.plant-obs-detail-title{color:var(--color-text);font-size:15px}.plant-obs-detail-link{justify-content:center;width:100%;margin-top:4px}.plant-obs-detail-history{gap:8px;margin-top:4px;display:grid}.plant-obs-detail-history>strong{color:var(--color-text);font-size:13px}.plant-obs-detail-history-list{gap:8px;padding-bottom:2px;display:flex;overflow-x:auto}.plant-obs-detail-history-item{border:1px solid var(--color-border);background:var(--color-surface);width:86px;min-width:86px;color:var(--color-text-muted);cursor:pointer;text-align:center;border-radius:8px;gap:4px;padding:6px;display:grid}.plant-obs-detail-history-item[data-active=true]{border-color:var(--color-accent);color:var(--color-text);box-shadow:0 0 0 2px #10b98129}.plant-obs-detail-history-item img,.plant-obs-detail-history-empty{aspect-ratio:1;object-fit:cover;background:var(--color-surface-alt);border-radius:6px;width:100%}.plant-obs-detail-history-empty{place-items:center;font-size:12px;display:grid}.plant-obs-detail-history-item span:last-child{font-size:11px;line-height:1.2}.plant-teacher .plant-obs-feed{grid-template-columns:repeat(4,minmax(0,1fr));gap:10px;display:grid}.plant-teacher .plant-obs-feed-card{border-radius:14px;padding:0}.plant-teacher .plant-obs-feed-thumb,.plant-teacher .plant-obs-feed-noimg{border-radius:0;width:100%;height:100%}.plant-teacher .plant-obs-feed-noimg{font-size:36px}.plant-teacher .plant-obs-feed-info{gap:3px;padding:34px 12px 11px}.plant-teacher .plant-obs-feed-student{font-size:13px;font-weight:800}.plant-teacher .plant-obs-feed-plant{font-size:11px}.plant-teacher .plant-obs-feed-memo{font-size:11px;display:none}.plant-teacher .plant-obs-feed-time{font-size:11px}@media (max-width:1180px){.plant-teacher .plant-obs-feed{grid-template-columns:repeat(3,1fr)}}@media (max-width:760px){.plant-teacher .plant-obs-feed{grid-template-columns:repeat(2,1fr)}}@media (max-width:640px){.plant-obs-feed-card{padding:10px}.plant-obs-feed-student{font-size:13px}.plant-obs-feed-time{font-size:10px}}
.side-panel-backdrop{z-index:9998;cursor:default;background:#00000059;border:0;padding:0;position:fixed;inset:0}.side-panel{background:var(--color-surface);width:420px;max-width:100%;box-shadow:-8px 0 24px #00000014, var(--shadow-card);z-index:9999;flex-direction:column;transition:transform .25s ease-out;display:flex;position:fixed;top:0;bottom:0;right:0;transform:translate(0)}@media (max-width:767px){.side-panel{border-radius:16px 16px 0 0;max-height:85vh;top:auto;left:0;right:0;transform:translateY(0);width:auto!important}}@media (prefers-reduced-motion:reduce){.side-panel{transition:none}}.side-panel-head{border-bottom:1px solid var(--color-border);flex:none;justify-content:space-between;align-items:center;gap:12px;padding:14px 20px;display:flex}.side-panel-title{color:var(--color-text);margin:0;font-size:18px;font-weight:700}.side-panel-close{cursor:pointer;color:var(--color-text-muted);background:0 0;border:0;border-radius:50%;justify-content:center;align-items:center;width:32px;height:32px;padding:6px;display:inline-flex}.side-panel-close:hover{background:var(--color-surface-alt);color:var(--color-text)}.side-panel-body{flex:auto;padding:16px 20px;overflow-y:auto}.side-panel-footer{border-top:1px solid var(--color-border);flex:none;padding:12px 20px}.side-panel-tabs{border-bottom:1px solid var(--color-border);background:var(--color-bg);flex:none;gap:4px;padding:0 20px;display:flex}.side-panel-tab{color:var(--color-text-muted);cursor:pointer;background:0 0;border:0;border-bottom:2px solid #0000;margin-bottom:-1px;padding:10px 12px;font-size:14px;font-weight:600}.side-panel-tab:hover{color:var(--color-text)}.side-panel-tab[aria-selected=true]{color:var(--color-text);border-bottom-color:var(--color-accent);background:var(--color-surface)}.side-panel-tab.danger[aria-selected=true]{color:var(--color-danger,#c62828);border-bottom-color:var(--color-danger,#c62828)}.section-actions-trigger{cursor:pointer;color:var(--color-text-muted);background:0 0;border:0;border-radius:6px;padding:4px 8px;font-size:18px;line-height:1}.section-actions-trigger:hover{background:var(--color-surface-alt);color:var(--color-text)}.section-rename-form{flex-direction:column;gap:12px;display:flex}.section-rename-form label{color:var(--color-text);font-size:13px;font-weight:600}.section-rename-form input{border:1px solid var(--color-border);border-radius:var(--radius-btn);background:var(--color-surface);color:var(--color-text);padding:10px 12px;font-size:14px}.section-rename-form input:focus{outline:2px solid var(--color-accent-tinted-text);outline-offset:2px}.section-rename-form .actions{justify-content:flex-end;gap:8px;margin-top:6px;display:flex}.section-rename-form button[type=submit]{background:var(--color-accent);color:#fff;border-radius:var(--radius-btn);cursor:pointer;border:0;padding:10px 16px;font-weight:600}.section-rename-form button[type=submit]:disabled{opacity:.5;cursor:not-allowed}.section-delete-confirm{border:1px solid var(--color-border);border-radius:var(--radius-card);background:var(--color-bg);flex-direction:column;gap:12px;padding:14px;display:flex}.section-delete-confirm p{color:var(--color-text);margin:0;font-size:14px;line-height:1.5}.section-delete-confirm .checkbox-row{align-items:center;gap:8px;font-size:14px;display:flex}.section-delete-btn{background:var(--color-danger,#c62828);color:#fff;border-radius:var(--radius-btn);cursor:pointer;border:0;align-self:flex-end;padding:10px 16px;font-weight:600}.section-delete-btn:hover:not(:disabled){background:var(--color-danger-active,#a01b1b)}.section-delete-btn:disabled{opacity:.4;cursor:not-allowed}.section-panel-notice{border-radius:var(--radius-card);background:var(--color-surface-alt);color:var(--color-text-muted);margin-bottom:12px;padding:12px;font-size:13px}.board-settings-trigger{background:var(--color-surface);border:1px solid var(--color-border);min-height:32px;font-family:var(--font-body);cursor:pointer;color:var(--color-text);border-radius:var(--radius-pill);white-space:nowrap;justify-content:center;align-items:center;margin-left:4px;padding:6px 12px;font-size:13px;font-weight:700;line-height:1.2;transition:background .15s,border-color .15s,color .15s;display:inline-flex}.board-settings-trigger:hover{border-color:var(--color-border-hover);background:var(--color-surface-alt);color:var(--color-text)}.board-settings-trigger:focus-visible{outline:2px solid var(--color-accent-tinted-text);outline-offset:2px}.board-settings-tab-meta{color:var(--color-text-muted);margin-left:2px;font-size:12px;font-weight:400}.board-settings-basic{flex-direction:column;gap:18px;display:flex}.board-settings-section{border-bottom:1px solid var(--color-border);flex-direction:column;gap:12px;padding-bottom:18px;display:flex}.board-settings-section:last-child{border-bottom:0;padding-bottom:0}.board-settings-section-title{color:var(--color-text);letter-spacing:0;margin:0;font-size:15px;font-weight:800}.board-settings-control-stack{flex-direction:column;gap:12px;display:flex}.board-settings-check-row{border:1px solid var(--color-border);cursor:pointer;background:var(--color-surface);border-radius:8px;align-items:flex-start;gap:12px;padding:14px;display:flex}.board-settings-check-row input{margin-top:2px}.board-settings-check-copy{flex-direction:column;gap:4px;display:flex}.board-settings-check-title{color:var(--color-text);font-size:14px;font-weight:700}.board-settings-check-desc{color:var(--color-text-muted);font-size:13px;line-height:1.5}.board-settings-error{color:var(--color-danger);margin:0;font-size:12px}.board-settings-placeholder-mark{border-radius:var(--radius-pill);background:var(--color-surface-alt);min-width:64px;min-height:32px;color:var(--color-text-muted);justify-content:center;align-items:center;padding:6px 12px;font-size:13px;font-weight:800;display:inline-flex}.board-settings-list{flex-direction:column;gap:14px;display:flex}.board-settings-row{border:1px solid var(--color-border);border-radius:var(--radius-card);background:var(--color-surface);flex-direction:column;gap:8px;padding:12px;display:flex}.board-settings-row-title{justify-content:space-between;align-items:center;gap:8px;display:flex}.board-settings-row-name{color:var(--color-text);overflow-wrap:anywhere;font-size:14px;font-weight:600}.board-settings-row-badge{white-space:nowrap;border-radius:999px;padding:2px 8px;font-size:11px;font-weight:600}.board-settings-row-badge.on{background:var(--color-accent-tinted,#e0f2fe);color:var(--color-accent-tinted-text,#0369a1)}.board-settings-row-badge.off{background:var(--color-surface-alt);color:var(--color-text-muted)}.board-settings-empty,.board-settings-placeholder{text-align:center;color:var(--color-text-muted);flex-direction:column;justify-content:center;align-items:center;gap:10px;padding:28px 16px;font-size:13px;line-height:1.55;display:flex}.board-settings-empty p,.board-settings-placeholder p{margin:0}.board-settings-archive-link{border-top:1px solid var(--color-border);margin-top:16px;padding-top:12px}.board-settings-archive-link a{color:var(--color-accent);align-items:center;font-size:13px;font-weight:700;text-decoration:none;display:inline-flex}.board-settings-archive-link a:hover{text-decoration:underline}.board-theme-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;display:grid}.board-theme-option{border:1px solid var(--color-border);background:var(--color-surface);width:100%;color:var(--color-text);text-align:left;cursor:pointer;border-radius:10px;align-items:center;gap:10px;padding:10px;transition:border-color .14s,box-shadow .14s,background .14s;display:flex}.board-theme-option:hover{border-color:var(--color-border-hover);background:var(--color-surface-alt)}.board-theme-option.is-selected{border-color:var(--color-accent);box-shadow:0 0 0 2px var(--color-accent-tinted-bg)}.board-theme-option:disabled{opacity:.7;cursor:wait}.board-theme-swatch{border:1px solid #0f172a14;border-radius:10px;flex:0 0 52px;width:52px;height:52px}.board-theme-copy{flex-direction:column;gap:2px;min-width:0;display:flex}.board-theme-label{color:var(--color-text);font-size:13px;font-weight:700}.board-theme-tone{color:var(--color-text-muted);font-size:12px}@media (max-width:480px){.board-theme-grid{grid-template-columns:minmax(0,1fr)}}
@media (max-width:1080px){.board-header{padding:16px 24px}.board-canvas-wrap{padding:24px}}@media (max-width:768px){.board-header{gap:12px;padding:14px 18px}.board-header-left{gap:12px}.board-title{font-size:22px}.board-canvas-wrap{padding:18px}.board-canvas{min-width:0}.add-card-btn,.add-card-form{bottom:18px;right:18px}}@media (max-width:560px){.board-header{padding:12px 14px}.board-header-right{gap:8px}.board-title{font-size:20px}.padlet-card{padding:14px 16px 16px}.add-card-form{min-width:auto;max-width:none;left:14px;right:14px}}
.optimized-img-wrap{background:var(--color-bg,#f5f5f5);width:100%;position:relative;overflow:hidden}.optimized-img-wrap img{object-fit:cover;display:block;width:100%!important;height:100%!important}.optimized-img-error{background:var(--color-bg,#f5f5f5);width:100%;min-height:60px;color:var(--color-text-muted,#888);text-align:center;justify-content:center;align-items:center;padding:12px;font-size:.875rem;display:flex}.card-attach-image.optimized-img-wrap{border-radius:8px;height:152px}.card-link-preview-image.optimized-img-wrap{height:112px}.modal-file-preview.optimized-img-wrap{height:200px}.link-preview-card-image.optimized-img-wrap{flex:0 0 140px;width:140px;height:100px}.export-design-thumb.optimized-img-wrap{border-radius:6px;flex:0 0 120px;width:120px;height:80px}.plant-obs-img.optimized-img-wrap{cursor:pointer;border-radius:8px;flex:0 0 80px;width:80px;height:80px}.plant-thumb.optimized-img-wrap{aspect-ratio:1}.plant-lightbox-frame.optimized-img-wrap{background:0 0;width:94vw;height:94vh}.plant-lightbox-frame.optimized-img-wrap img{object-fit:contain!important}
.drawing-board{flex:1;align-items:stretch;gap:16px;min-height:0;padding:16px;display:flex}.drawing-main{flex-direction:column;flex:1;min-width:0;display:flex}.drawing-tabs{gap:8px;padding-bottom:12px;display:flex}.drawing-tab{border:1px solid var(--color-border,#e0e0e0);background:var(--color-surface,#fff);color:var(--color-muted,#666);cursor:pointer;font:inherit;border-radius:8px;padding:8px 16px}.drawing-tab[aria-selected=true]{background:var(--color-bg,#fafafa);color:var(--color-text,#111);border-color:var(--color-text,#111)}.drawing-panel{background:var(--color-surface,#fff);border:1px solid var(--color-border,#e0e0e0);border-radius:12px;flex-direction:column;flex:1;min-height:480px;display:flex;overflow:hidden}.drawing-iframe{background:#fff;border:0;flex:1;width:100%;height:100%;min-height:480px}.drawing-placeholder{text-align:center;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:12px;padding:32px;display:flex}.drawing-placeholder .placeholder-icon{font-size:48px;line-height:1}.drawing-placeholder .muted{color:var(--color-muted,#666);font-size:13px}.drawing-gallery-wrap{flex:1;overflow:auto}.drawing-gallery{grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:12px;padding:16px;display:grid}.gallery-thumb{aspect-ratio:1;border:1px solid var(--color-border,#e0e0e0);background:var(--color-bg,#fafafa);cursor:pointer;border-radius:8px;padding:0;overflow:hidden}.gallery-thumb img{object-fit:cover;width:100%;height:100%}.gallery-empty{color:var(--color-muted,#666);text-align:center;padding:32px}.drawing-sidebar{background:var(--color-surface,#fff);border:1px solid var(--color-border,#e0e0e0);border-radius:12px;flex-direction:column;flex:0 0 280px;gap:12px;padding:12px;display:flex;overflow:auto}.drawing-sidebar-header{justify-content:space-between;align-items:center;font-weight:600;display:flex}.drawing-sidebar-upload{background:var(--color-bg,#fafafa);border:1px solid var(--color-border,#e0e0e0);cursor:pointer;border-radius:6px;padding:4px 10px;font-size:16px}.drawing-sidebar-upload:disabled{opacity:.6;cursor:wait}.library-list{flex-direction:column;gap:6px;margin:0;padding:0;list-style:none;display:flex}.library-item{background:var(--color-bg,#fafafa);border-radius:6px;align-items:center;gap:8px;padding:6px;display:flex}.library-item img{object-fit:cover;border-radius:6px;width:48px;height:48px}.library-item-title{text-overflow:ellipsis;white-space:nowrap;font-size:13px;overflow:hidden}.library-picker-overlay{z-index:60;background:#00000080;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.library-picker{background:var(--color-surface,#fff);border-radius:12px;width:min(640px,90vw);max-height:80vh;padding:16px;overflow:auto}.library-picker-grid{grid-template-columns:repeat(3,1fr);gap:12px;display:grid}.library-picker-item{aspect-ratio:1;cursor:pointer;background:var(--color-bg,#fafafa);border:2px solid #0000;border-radius:8px;padding:0;overflow:hidden}.library-picker-item.selected{border-color:var(--color-text,#111)}.library-picker-item img{object-fit:cover;width:100%;height:100%}@media (max-width:768px){.drawing-board{flex-direction:column}.drawing-sidebar{flex:none;max-height:240px}}.ds-root{background:var(--color-bg);width:100%;height:100%;min-height:640px;color:var(--color-text);font-family:var(--font-body);flex-direction:column;display:flex;position:relative}.ds-topbar{background:var(--color-surface);border-bottom:1px solid var(--color-border);flex-shrink:0;align-items:center;gap:8px;height:36px;padding:0 12px;display:flex}.ds-topbar-spacer{flex:auto}.ds-topbar-group{align-items:center;gap:6px;display:flex}.ds-topbar-btn{border:1px solid var(--color-border);border-radius:var(--radius-pill);background:var(--color-surface);height:28px;color:var(--color-text);cursor:pointer;justify-content:center;align-items:center;gap:4px;padding:0 10px;font-size:12px;font-weight:600;transition:background .12s,border-color .12s;display:inline-flex}.ds-topbar-btn:hover:not(:disabled){border-color:var(--color-border-hover);background:var(--color-surface-alt)}.ds-topbar-btn:disabled{opacity:.4;cursor:default}.ds-topbar-btn.is-active{background:var(--color-accent-tinted-bg);color:var(--color-accent-tinted-text);border-color:var(--color-accent)}.ds-topbar-btn.ds-save-btn{background:var(--color-accent);color:#fff;border-color:var(--color-accent)}.ds-topbar-btn.ds-save-btn:hover:not(:disabled){background:var(--color-accent-active);border-color:var(--color-accent-active)}.ds-zoom-indicator{color:var(--color-text-muted);text-align:right;min-width:40px;font-size:11px}.ds-workspace{flex:auto;grid-template-columns:1fr 64px;min-height:0;display:grid}.ds-viewport{touch-action:none;background:var(--color-bg);position:relative;overflow:hidden}.ds-paper{aspect-ratio:3/4;transform-origin:50%;will-change:transform;background:#fff;border-radius:2px;width:min(90%,75% - 48px);position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);box-shadow:0 10px 40px #00000026,0 2px 8px #00000014}.ds-canvas{touch-action:none;width:100%;height:100%;position:absolute;inset:0}.ds-brush-preview{pointer-events:none;border:1px solid #00000026;border-radius:50%;position:absolute;top:12px;right:12px}.ds-right-rail{background:var(--color-surface);border-left:1px solid var(--color-border);flex-direction:column;align-items:center;gap:14px;padding:14px 0;display:flex;overflow-y:auto}.ds-vslider{flex-direction:column;align-items:center;gap:4px;display:flex}.ds-vslider-label{color:var(--color-text-muted);font-size:10px}.ds-vslider-val{color:var(--color-text-muted);text-align:center;min-width:20px;font-size:10px}.ds-vslider-input{writing-mode:vertical-lr;direction:rtl;width:20px;height:200px;margin:0;padding:0}.ds-rail-layer-btn{border:1px solid var(--color-border);border-radius:var(--radius-pill);background:var(--color-surface);width:40px;height:40px;color:var(--color-text);cursor:pointer;margin-top:auto;font-size:16px;transition:background .12s,border-color .12s}.ds-rail-layer-btn:hover{border-color:var(--color-border-hover);background:var(--color-surface-alt)}.ds-rail-layer-btn.is-active{background:var(--color-accent-tinted-bg);color:var(--color-accent-tinted-text);border-color:var(--color-accent)}.ds-bottombar{background:var(--color-surface);border-top:1px solid var(--color-border);flex-shrink:0;grid-template-columns:auto 1fr auto;align-items:center;gap:12px;height:56px;padding:0 12px;display:grid}.ds-bb-left{align-items:center;gap:4px;display:flex}.ds-bb-btn{border-radius:var(--radius-btn);width:40px;height:40px;color:var(--color-text);cursor:pointer;background:0 0;border:1px solid #0000;justify-content:center;align-items:center;font-size:18px;transition:background .12s,border-color .12s;display:flex}.ds-bb-btn:hover:not(:disabled){background:var(--color-surface-alt);border-color:var(--color-border)}.ds-bb-btn:disabled{opacity:.4;cursor:default}.ds-bb-tools-wrap{-webkit-overflow-scrolling:touch;overflow:auto hidden}.ds-tool-strip{gap:6px;width:max-content;padding:4px 8px;display:flex}.ds-tool-btn{border-radius:var(--radius-btn);width:48px;height:48px;color:var(--color-text);cursor:pointer;background:0 0;border:1px solid #0000;flex-shrink:0;justify-content:center;align-items:center;font-size:22px;transition:background .12s,border-color .12s;display:flex}.ds-tool-btn:hover{background:var(--color-surface-alt);border-color:var(--color-border)}.ds-tool-btn.is-active{background:var(--color-accent-tinted-bg);color:var(--color-accent-tinted-text);border-color:var(--color-accent)}.ds-bb-colors{align-items:center;gap:8px;display:flex}.ds-color-current{border:2px solid var(--color-border);cursor:pointer;border-radius:50%;width:36px;height:36px;padding:0}.ds-color-current:hover{border-color:var(--color-accent)}.ds-colorbar-divider{background:var(--color-border);width:1px;height:24px}.ds-color-row{align-items:center;gap:4px;display:flex}.ds-color-swatch-sm{border:2px solid var(--color-border);cursor:pointer;border-radius:50%;width:24px;height:24px;padding:0;transition:transform 80ms}.ds-color-swatch-sm:hover{transform:scale(1.1)}.ds-color-swatch-sm.is-active{border-color:var(--color-accent);box-shadow:0 0 0 2px var(--color-accent-tinted-bg)}.ds-sheet-backdrop{z-index:45;cursor:pointer;background:#0000004d;border:none;padding:0;position:fixed;inset:0}.ds-layer-sheet{background:var(--color-surface);border-left:1px solid var(--color-border);z-index:50;flex-direction:column;width:340px;max-width:90vw;min-height:0;transition:transform .22s cubic-bezier(.2,0,.2,1);display:flex;position:fixed;top:36px;bottom:56px;right:0;transform:translate(100%);box-shadow:-8px 0 32px #0000001f}.ds-layer-sheet.is-open{transform:translate(0)}.ds-layer-sheet[aria-hidden=true]{pointer-events:none}.ds-layer-panel{flex-direction:column;height:100%;min-height:0;display:flex}.ds-layer-head{border-bottom:1px solid var(--color-border);justify-content:space-between;align-items:center;padding:10px 12px;font-size:13px;font-weight:700;display:flex}.ds-layer-head-actions{gap:4px;display:flex}.ds-mini-btn{border:1px solid var(--color-border);border-radius:var(--radius-btn);background:var(--color-surface);width:28px;height:28px;color:var(--color-text);cursor:pointer;padding:0;font-size:14px}.ds-mini-btn:hover:not(:disabled){border-color:var(--color-border-hover);background:var(--color-surface-alt)}.ds-mini-btn:disabled{opacity:.4;cursor:default}.ds-mini-btn-danger{color:var(--color-danger)}.ds-layer-list{flex-direction:column;flex:auto;gap:4px;margin:0;padding:6px;list-style:none;display:flex;overflow-y:auto}.ds-layer-card{border-radius:var(--radius-btn);background:var(--color-surface);cursor:pointer;border:2px solid #0000;align-items:center;gap:6px;padding:6px;transition:border-color .12s;display:flex}.ds-layer-card:hover{border-color:var(--color-border-hover)}.ds-layer-card.is-active{border-color:var(--color-accent);background:var(--color-accent-tinted-bg)}.ds-layer-visible{cursor:pointer;background:0 0;border:none;width:24px;height:24px;padding:0;font-size:14px}.ds-layer-body{cursor:pointer;background:0 0;border:none;flex:auto;align-items:center;gap:8px;min-width:0;padding:0;display:flex}.ds-layer-thumb{background:var(--color-surface-alt);border:1px solid var(--color-border);object-fit:cover;border-radius:4px;flex-shrink:0;width:36px;height:36px}.ds-layer-thumb-empty{display:block}.ds-layer-name{white-space:nowrap;text-overflow:ellipsis;text-align:left;flex:auto;font-size:13px;overflow:hidden}.ds-layer-settings{border-top:1px solid var(--color-border);flex-direction:column;gap:8px;padding:10px 12px;display:flex}.ds-slider-label{color:var(--color-text-muted);align-items:center;gap:6px;font-size:12px;display:inline-flex}.ds-slider{flex:auto}.ds-slider-val{color:var(--color-text-muted);text-align:right;min-width:24px;font-size:11px}.ds-field-label{color:var(--color-text-muted);flex-direction:column;gap:4px;font-size:12px;display:flex}.ds-select,.ds-text-input{border:1px solid var(--color-border);border-radius:var(--radius-btn);background:var(--color-surface);color:var(--color-text);padding:6px 8px;font-size:13px}.ds-hsv-backdrop{z-index:100;background:#00000080;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.ds-hsv-panel{background:var(--color-surface);border-radius:var(--radius-card);width:300px;box-shadow:var(--shadow-card-hover);flex-direction:column;gap:12px;padding:16px;display:flex}.ds-hsv-head{justify-content:space-between;align-items:center;font-size:14px;font-weight:700;display:flex}.ds-hsv-canvas{touch-action:none;-webkit-user-select:none;user-select:none;width:240px;height:240px;margin:0 auto}.ds-hsv-preview-row{align-items:center;gap:10px;display:flex}.ds-hsv-preview{border:2px solid var(--color-border);border-radius:50%;width:32px;height:32px}.ds-hsv-hex-row{align-items:center;gap:4px;font-family:SF Mono,Fira Code,monospace;font-size:13px;display:flex}.ds-hex-input{border:1px solid var(--color-border);border-radius:var(--radius-btn);background:var(--color-surface);width:100px;padding:4px 8px;font-family:inherit;font-size:12px}.ds-hsv-label{color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.06em;font-size:10px;font-weight:600}.ds-swatch-grid{grid-template-columns:repeat(8,24px);justify-content:center;gap:6px;display:grid}.ds-swatch{border:2px solid var(--color-border);cursor:pointer;border-radius:50%;width:24px;height:24px;padding:0}.ds-swatch:hover{border-color:var(--color-accent)}.ds-save-dialog-backdrop{z-index:100;background:#0006;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.ds-save-dialog{background:var(--color-surface);border-radius:var(--radius-card);width:320px;box-shadow:var(--shadow-card-hover);flex-direction:column;gap:14px;padding:24px;display:flex}.ds-save-dialog h3{color:var(--color-text);margin:0;font-size:18px;font-weight:700}.ds-checkbox-label{color:var(--color-text);align-items:center;gap:8px;font-size:14px;display:inline-flex}.ds-save-error{background:var(--color-surface-alt);border-left:3px solid var(--color-danger);border-radius:var(--radius-btn);color:var(--color-danger);padding:8px 12px;font-size:13px}.ds-save-actions{justify-content:flex-end;gap:8px;display:flex}@media (max-width:900px){.ds-workspace{grid-template-rows:1fr auto;grid-template-columns:1fr}.ds-right-rail{border-left:none;border-top:1px solid var(--color-border);flex-direction:row;order:2;justify-content:space-around;gap:8px;height:64px;padding:8px 12px;overflow:auto hidden}.ds-vslider{flex-direction:row}.ds-vslider-input{writing-mode:unset;appearance:auto;width:120px;height:20px}.ds-layer-sheet{width:100%;max-height:60%;inset:auto 0 56px;transform:translateY(100%)}.ds-layer-sheet.is-open{transform:translateY(0)}}@media (max-width:600px){.ds-tool-btn{width:40px;height:40px;font-size:18px}.ds-color-swatch-sm{width:22px;height:22px}}.ds-asset-fab{background:var(--color-surface);width:48px;height:48px;color:var(--color-text);cursor:pointer;box-shadow:var(--shadow-card-hover);z-index:25;border:none;border-radius:50%;font-size:22px;position:fixed;bottom:96px;right:32px}.ds-asset-fab:hover{transform:translateY(-1px)}.ds-asset-fab:active{transform:scale(.96)}.canvas-size-picker .layout-option{gap:6px}.asset-insert-modal .drawing-gallery{max-height:60vh;padding:4px;overflow-y:auto}
.assessment-shell{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-card);max-width:1040px;box-shadow:var(--shadow-card);margin:24px auto;padding:24px 32px}.assessment-empty{color:var(--color-text-muted);text-align:center;flex-direction:column;align-items:center;gap:12px;padding:60px 16px;display:flex}.assessment-empty-icon{font-size:48px}.assessment-error,.assessment-gradebook-error,.assessment-take-error{background:var(--color-status-returned-bg);color:var(--color-status-returned-text);border-radius:var(--radius-btn);margin:12px 0;padding:10px 14px;font-size:14px}.assessment-btn{border:1px solid var(--color-border);border-radius:var(--radius-btn);font-size:14px;font-family:var(--font-body);cursor:pointer;background:var(--color-surface);color:var(--color-text);padding:8px 16px;transition:background-color .12s,transform 80ms}.assessment-btn:disabled{opacity:.5;cursor:not-allowed}.assessment-btn-primary{background:var(--color-accent);border-color:var(--color-accent);color:#fff}.assessment-btn-primary:hover:not(:disabled){background:var(--color-accent-active)}.assessment-btn-ghost{background:0 0}.assessment-input{border:1px solid var(--color-border);border-radius:var(--radius-btn);font-size:14px;font-family:var(--font-body);box-sizing:border-box;width:100%;padding:8px 10px}.assessment-input:focus{outline:2px solid var(--color-accent);outline-offset:-1px}.assessment-composer{padding:0}.assessment-composer-head{justify-content:space-between;align-items:center;margin-bottom:16px;display:flex}.assessment-composer-title{margin:0;font-size:20px;font-weight:600}.assessment-composer-meta{align-items:flex-end;gap:12px;margin-bottom:16px;display:flex}.assessment-field{color:var(--color-text-muted);flex-direction:column;flex:1;gap:4px;font-size:13px;display:flex}.assessment-field-duration{flex-direction:row;flex:0 0 140px;align-items:center;gap:8px}.assessment-field-duration span:first-child{white-space:nowrap}.assessment-field-duration input{width:64px}.assessment-field-suffix{color:var(--color-text-muted);font-size:13px}.assessment-question-list{flex-direction:column;gap:0;display:flex}.assessment-question-card{border:none;border-top:1px solid var(--color-border);border-radius:0;flex-direction:column;gap:10px;padding:16px 0;display:flex}.assessment-question-card:last-child{border-bottom:1px solid var(--color-border)}.assessment-question-head{justify-content:space-between;align-items:center;display:flex}.assessment-question-num{color:var(--color-text-muted);font-size:13px;font-weight:600}.assessment-question-remove,.assessment-choice-remove{cursor:pointer;color:var(--color-text-muted);background:0 0;border:none;font-size:16px}.assessment-question-remove:disabled,.assessment-choice-remove:disabled{opacity:.3;cursor:not-allowed}.assessment-choice-list{flex-direction:column;gap:6px;display:flex}.assessment-choice{align-items:center;gap:8px;display:flex}.assessment-choice-check{-webkit-user-select:none;user-select:none;align-items:center;gap:4px;display:flex}.assessment-choice-letter{color:var(--color-text-muted);width:16px;font-weight:600}.assessment-choice-input{flex:1}.assessment-question-meta{color:var(--color-text-muted);font-size:13px}.assessment-score-input{width:64px}.assessment-composer-actions{justify-content:space-between;gap:8px;margin-top:20px;display:flex}.assessment-take{padding:0 0 80px}.assessment-take-timer{z-index:10;background:var(--color-bg-alt);border-bottom:1px solid var(--color-border);align-items:center;gap:12px;margin:0 0 16px;padding:10px 12px;font-size:14px;display:flex;position:sticky;top:0}.assessment-take-timer-icon{font-size:18px}.assessment-take-timer-value{font-variant-numeric:tabular-nums;font-size:20px;font-weight:700}.assessment-take-timer-label{color:var(--color-text-muted);flex:1}.assessment-take-timer.is-low{color:var(--color-danger);background:var(--color-status-returned-bg)}.assessment-take-timer.is-low .assessment-take-timer-value{animation:1s ease-in-out infinite assessment-pulse}.assessment-take-timer.is-expired{color:var(--color-danger);background:var(--color-status-returned-bg)}@keyframes assessment-pulse{0%,to{opacity:1}50%{opacity:.5}}@media (prefers-reduced-motion:reduce){.assessment-take-timer.is-low .assessment-take-timer-value{animation:none}}.assessment-take-save{color:var(--color-text-muted);text-align:right;min-width:64px;font-size:12px}.assessment-take-title{margin:0 0 16px;font-size:18px;font-weight:600}.assessment-take-questions{flex-direction:column;gap:16px;margin:0;padding:0;list-style:none;display:flex}.assessment-take-question{border:none;border-top:1px solid var(--color-border);border-radius:0;padding:16px 0}.assessment-take-question:last-child{border-bottom:1px solid var(--color-border)}.assessment-take-q-num{color:var(--color-text-muted);margin-bottom:4px;font-size:12px}.assessment-take-q-prompt{margin-bottom:10px;font-size:15px;font-weight:500}.assessment-take-choices{flex-direction:column;gap:6px;display:flex}.assessment-take-choice{border:1px solid var(--color-border);border-radius:var(--radius-btn);cursor:pointer;align-items:center;gap:10px;min-height:44px;padding:8px 10px;display:flex}.assessment-take-choice.is-checked{background:var(--color-accent-tinted-bg);border-color:var(--color-accent)}.assessment-take-choice-letter{width:18px;color:var(--color-text-muted);font-weight:600}.assessment-take-choice-text{flex:1}.assessment-take-submit-bar{background:var(--color-surface);border-top:1px solid var(--color-border);justify-content:center;margin:20px 0 0;padding:12px 0;display:flex;position:sticky;bottom:0}.assessment-take-loading,.assessment-result-loading,.assessment-gradebook-loading{text-align:center;color:var(--color-text-muted);padding:40px 16px}.assessment-gradebook{padding:0}.assessment-gradebook-head{grid-template-rows:auto auto;grid-template-columns:1fr auto;align-items:center;column-gap:12px;margin-bottom:16px;display:grid}.assessment-gradebook-title{grid-area:1/1;margin:0;font-size:18px;font-weight:600}.assessment-gradebook-meta{color:var(--color-text-muted);grid-area:2/1;font-size:13px}.assessment-gradebook-head .assessment-btn-primary{grid-area:1/2/span 2}.assessment-gradebook-empty{color:var(--color-text-muted);text-align:center;padding:40px 16px}.assessment-gradebook-matrix-wrap{border:1px solid var(--color-border);border-radius:var(--radius-card);max-height:70vh;overflow:auto}.assessment-gradebook-matrix{border-collapse:collapse;width:100%;font-size:13px}.assessment-gradebook-matrix th,.assessment-gradebook-matrix td{border-bottom:1px solid var(--color-border);border-right:1px solid var(--color-border);background:var(--color-surface);text-align:center;white-space:nowrap;padding:8px 10px}.assessment-gradebook-matrix thead th{background:var(--color-bg-alt);z-index:1;font-weight:600;position:sticky;top:0}.assessment-gradebook-name{text-align:left;background:var(--color-bg-alt);z-index:2;min-width:120px;position:sticky;left:0}.assessment-gradebook-matrix thead th.assessment-gradebook-name{z-index:3}.assessment-gradebook-cell-correct{background:var(--color-status-reviewed-bg);color:var(--color-status-reviewed-text);font-weight:600}.assessment-gradebook-cell-wrong{background:var(--color-status-returned-bg);color:var(--color-status-returned-text)}.assessment-gradebook-cell-empty{color:var(--color-text-faint)}.assessment-badge{border-radius:var(--radius-pill);background:var(--color-surface-alt);color:var(--color-text-muted);padding:2px 8px;font-size:11px;display:inline-block}.assessment-badge-success{background:var(--color-status-reviewed-bg);color:var(--color-status-reviewed-text)}.assessment-result{padding:0}.assessment-result-pending,.assessment-result-error{background:var(--color-surface);text-align:center;color:var(--color-text-muted);padding:60px 0}.assessment-result-icon{margin-bottom:12px;font-size:48px}.assessment-result-title{color:var(--color-text);margin-bottom:6px;font-size:18px;font-weight:600}.assessment-result-sub{font-size:13px}.assessment-result-score{text-align:center;padding:20px 0 24px}.assessment-result-score-value{font-variant-numeric:tabular-nums;font-size:44px;font-weight:700}.assessment-result-score-label{color:var(--color-text-muted);font-size:14px}.assessment-result-questions{flex-direction:column;gap:10px;margin:0;padding:0;list-style:none;display:flex}.assessment-result-question{border:none;border-top:1px solid var(--color-border);border-radius:0;padding:14px 0}.assessment-result-question:last-child{border-bottom:1px solid var(--color-border)}.assessment-result-question-correct{border-left:3px solid var(--color-status-reviewed-text);padding-left:12px}.assessment-result-question-wrong{border-left:3px solid var(--color-status-returned-text);padding-left:12px}.assessment-result-q-head{color:var(--color-text-muted);justify-content:space-between;margin-bottom:4px;font-size:13px;display:flex}.assessment-result-q-prompt{margin-bottom:4px;font-weight:500}.assessment-result-q-detail{color:var(--color-text-muted);font-size:13px}.assessment-take-multi-hint{color:var(--color-text-muted);padding-left:4px;font-size:12px}@media (max-width:600px){.assessment-shell{margin:12px auto;padding:0 8px}.assessment-composer-meta{flex-direction:column;align-items:stretch}.assessment-gradebook-head{grid-template-columns:1fr}.assessment-gradebook-head .assessment-btn-primary{grid-area:3/1;margin-top:8px}}.omr-grid-wrap{flex-wrap:wrap;justify-content:center;gap:40px;display:flex}.omr-grid{flex:0 360px;width:100%;max-width:360px}.omr-grid-header{border-bottom:2px solid var(--color-text);align-items:center;margin-bottom:2px;padding-bottom:6px;display:flex}.omr-grid-header .omr-grid-num{color:var(--color-text-muted);font-size:12px;font-weight:600}.omr-grid-col-header{text-align:center;color:var(--color-text-muted);flex:1;font-size:13px;font-weight:600}.omr-grid-row{border-bottom:1px solid var(--color-border);align-items:center;min-height:40px;display:flex}.omr-grid-row:nth-child(5n+1){border-bottom:1px solid var(--color-border-hover)}.omr-grid-num{text-align:center;font-variant-numeric:tabular-nums;width:48px;color:var(--color-text);flex-shrink:0;font-size:14px;font-weight:600}.omr-bubble{cursor:pointer;color:var(--color-border-hover);-webkit-tap-highlight-color:transparent;background:0 0;border:none;flex:1;justify-content:center;align-items:center;min-width:44px;min-height:44px;padding:6px 0;font-size:20px;transition:color .12s;display:flex}.omr-bubble:hover:not(:disabled){color:var(--color-text-muted)}.omr-bubble.is-filled{color:var(--color-accent);font-size:22px}.omr-bubble.is-filled:hover:not(:disabled){color:var(--color-accent-active)}.omr-bubble:focus-visible{outline:2px solid var(--color-accent);outline-offset:-6px;border-radius:50%}.omr-bubble:active:not(:disabled){transition:transform 80ms;transform:scale(.92)}.omr-bubble:disabled{cursor:not-allowed;opacity:.4}.assessment-field-sm{flex:0 0 100px}.assessment-field-row{align-items:center;gap:4px;display:flex}.assessment-composer-progress,.assessment-take-progress{color:var(--color-text-muted);font-size:13px}.assessment-take-submit-bar{background:var(--color-surface);border-top:1px solid var(--color-border);justify-content:space-between;align-items:center;margin-top:20px;padding:12px 0;display:flex;position:sticky;bottom:0}@media (max-width:767px){.omr-grid-wrap{gap:0}.omr-grid{flex:0 100%;max-width:100%}.omr-bubble{min-width:40px;min-height:40px;font-size:18px}.omr-grid-num{width:36px;font-size:13px}.omr-grid-row{min-height:40px}}.omr-grid-kind{text-align:center;width:44px;color:var(--color-text-muted);flex-shrink:0;font-size:12px;font-weight:600}.omr-kind-chip{border:1px solid var(--color-border);border-radius:var(--radius-pill);cursor:pointer;width:36px;height:28px;color:var(--color-text-muted);-webkit-tap-highlight-color:transparent;background:0 0;flex-shrink:0;justify-content:center;align-items:center;margin-right:8px;font-size:12px;font-weight:600;transition:background-color .12s,color .12s,border-color .12s;display:inline-flex}.omr-kind-chip-mcq{background:var(--color-accent-tinted-bg);color:var(--color-accent-tinted-text);border-color:#0000}.omr-kind-chip-short{background:var(--color-warning-tinted-bg);color:#a46a00;border-color:#0000}.omr-kind-chip.is-readonly{cursor:default;pointer-events:none}.omr-kind-chip:hover:not(:disabled):not(.is-readonly){filter:brightness(.95)}.omr-kind-chip:focus-visible{outline:2px solid var(--color-accent);outline-offset:1px}.omr-grid-short{flex:calc(var(--choice-span,5));align-items:center;padding:4px 0;display:flex}.omr-short-input{width:100%;min-height:36px;font-size:14px}.assessment-composer-bulk{flex-wrap:wrap;align-items:center;gap:8px;margin:4px 0 16px;display:flex}.assessment-composer-bulk-label{color:var(--color-text-muted);margin-right:4px;font-size:13px}.omr-kind-chip-manual{background:var(--color-surface-alt);color:var(--color-text);border-color:#0000}.omr-grid-manual{color:var(--color-text-muted);align-items:center;font-size:12px;font-style:italic}.omr-manual-input{resize:vertical;min-height:60px;font-family:var(--font-body);line-height:1.4}.assessment-gradebook-manual-banner{background:var(--color-warning-tinted-bg);color:#8a5a00;border-radius:var(--radius-card);justify-content:space-between;align-items:center;gap:12px;margin-bottom:12px;padding:12px 16px;font-size:14px;display:flex}.assessment-gradebook-manual-hint{color:#a46a00;font-size:13px}.assessment-gradebook-cell-pending{background:var(--color-warning-tinted-bg);padding:2px}.assessment-gradebook-pending-btn{cursor:pointer;color:#a46a00;background:0 0;border:none;width:100%;height:100%;font-size:14px;font-weight:700}.assessment-gradebook-pending-btn:hover{background:#fde68a}.manual-grade-modal{max-width:720px}.manual-grade-progress{color:var(--color-text-muted);margin-bottom:12px;font-size:13px}.manual-grade-empty{text-align:center;color:var(--color-text-muted);padding:40px 16px}.manual-grade-list{flex-direction:column;gap:0;margin:0;padding:0;list-style:none;display:flex}.manual-grade-row{border-top:1px solid var(--color-border);grid-template-columns:120px 1fr auto;align-items:center;gap:12px;padding:12px 4px;display:grid}.manual-grade-row:last-child{border-bottom:1px solid var(--color-border)}.manual-grade-row.is-highlight{background:var(--color-accent-tinted-bg)}.manual-grade-student{font-size:14px;font-weight:600}.manual-grade-answer{white-space:pre-wrap;word-break:break-word;font-family:var(--font-body);background:var(--color-surface-alt);border-radius:var(--radius-btn);min-height:36px;margin:0;padding:8px 10px;font-size:14px}.manual-grade-actions{align-items:center;gap:6px;display:flex}.manual-grade-nav{border-top:1px solid var(--color-border);background:var(--color-bg-alt);justify-content:flex-end;align-items:center;gap:8px;padding:12px 20px;display:flex}.manual-grade-nav-pos{color:var(--color-text-muted);text-align:center;min-width:44px;font-size:13px}@media (max-width:600px){.manual-grade-row{grid-template-columns:1fr;gap:6px}.manual-grade-actions{flex-wrap:wrap}}
.va-root{background:var(--color-bg);min-height:calc(100vh - 80px);padding:32px}.va-loading{text-align:center;color:var(--color-text-muted);padding:48px}.va-header{justify-content:space-between;align-items:center;margin-bottom:16px;padding-bottom:12px;display:flex}.va-title{letter-spacing:-.5px;color:var(--color-text);margin:0;font-size:26px;font-weight:700}.va-subtitle{color:var(--color-text-muted);margin:4px 0 0;font-size:14px;font-weight:400}.va-gate-off{justify-content:center;padding:64px 32px;display:flex}.va-gate-off-inner{text-align:center;background:var(--color-surface);border:var(--border-card);border-radius:var(--radius-card);max-width:420px;box-shadow:var(--shadow-card);padding:40px 32px}.va-gate-off-inner h2{letter-spacing:-.3px;margin:16px 0 8px;font-size:20px;font-weight:700}.va-gate-off-inner p{color:var(--color-text-muted);font-size:15px;line-height:1.5}.va-gate-off-icon{color:var(--color-text-faint);font-size:32px}.va-gate-off-link{color:var(--color-accent);font-weight:500;text-decoration:none}.va-gate-off-link:hover{text-decoration:underline}.va-gate-off-actions{flex-direction:column;align-items:center;gap:8px;margin-top:20px;display:flex}.va-gate-off-enable{background:var(--color-accent);color:#fff;border-radius:var(--radius-btn);cursor:pointer;border:none;padding:12px 22px;font-size:14px;font-weight:600;transition:background .15s}.va-gate-off-enable:hover:not(:disabled){background:var(--color-accent-active)}.va-gate-off-enable:disabled{opacity:.6;cursor:default}.va-gate-off-error{color:var(--color-danger,#dc3545);margin:0;font-size:12px}.va-tabs{flex-wrap:wrap;gap:8px;padding:8px 0 20px;display:flex}.va-tab{font:600 13px/1 var(--font-body);border-radius:var(--radius-pill);color:var(--color-text-muted);cursor:pointer;background:0 0;border:0;padding:6px 12px}.va-tab.is-active{background:var(--color-accent-tinted-bg);color:var(--color-accent-tinted-text)}.va-grid{grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:20px;margin:0;padding:0;list-style:none;display:grid}.va-card{background:var(--color-surface);border:var(--border-card);border-radius:var(--radius-card);box-shadow:var(--shadow-card);transition:box-shadow .15s,border-color .15s;overflow:hidden}.va-card:hover{box-shadow:var(--shadow-card-hover);border-color:var(--color-border-hover)}.va-card-thumb{aspect-ratio:4/3;background:var(--color-surface-alt);justify-content:center;align-items:center;display:flex}.va-card-thumb img{object-fit:cover;width:100%;height:100%;display:block}.va-card-thumb-fallback{background:var(--color-surface-alt);width:100%;height:100%}.va-card-meta{padding:12px 14px}.va-card-title{letter-spacing:-.15px;color:var(--color-text);white-space:nowrap;text-overflow:ellipsis;margin:0 0 6px;font-size:15px;font-weight:700;overflow:hidden}.va-card-stats{font:600 12px/1 var(--font-body);color:var(--color-text-muted);align-items:center;gap:8px;display:flex}.va-card-plays{letter-spacing:.125px}.va-card-skeleton{background:#fff 0 0/200% 100%;min-height:260px;animation:1.4s linear infinite va-shimmer}@media (prefers-reduced-motion:reduce){.va-card-skeleton{animation:none}}@keyframes va-shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.va-empty{text-align:center;color:var(--color-text-muted);padding:64px 32px}.va-error{background:var(--color-status-returned-bg);color:var(--color-status-returned-text);border-radius:var(--radius-card);justify-content:space-between;align-items:center;padding:16px;display:flex}.va-cta{font:600 14px/1 var(--font-body);background:var(--color-accent);color:#fff;border-radius:var(--radius-btn);box-shadow:var(--shadow-accent);cursor:pointer;border:0;margin-top:16px;padding:10px 20px}.va-cta:hover{background:var(--color-accent-active);box-shadow:var(--shadow-accent-hover)}.va-fab{border-radius:var(--radius-pill);background:var(--color-accent);color:#fff;width:56px;height:56px;box-shadow:var(--shadow-accent);cursor:pointer;border:0;font-size:24px;position:fixed;bottom:24px;right:24px}.va-fab:hover{background:var(--color-accent-active);box-shadow:var(--shadow-accent-hover)}@media (max-width:1080px){.va-root{padding:24px}.va-grid{grid-template-columns:repeat(auto-fill,minmax(200px,1fr))}}@media (max-width:768px){.va-root{padding:18px}.va-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width:560px){.va-grid{grid-template-columns:1fr}}.vg-empty-hint{color:var(--color-text-muted);margin-top:8px;font-size:13px}.vs-grid{grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:14px;margin:0;padding:0;list-style:none;display:grid}.vs-slot{text-align:left;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-card);min-height:200px;box-shadow:var(--shadow-card);cursor:pointer;color:inherit;transition:box-shadow var(--t-slow), border-color var(--t-slow), transform var(--t-slow);flex-direction:column;align-items:stretch;gap:10px;padding:14px;font-family:inherit;display:flex;position:relative}.vs-slot:hover:not(:disabled){box-shadow:var(--shadow-card-hover);border-color:var(--color-border-hover);transform:translateY(-2px)}.vs-slot:disabled{cursor:default}.vs-slot.is-self{border-color:var(--color-accent);box-shadow:0 0 0 3px var(--color-accent-tinted-bg), var(--shadow-card)}.vs-slot.is-empty .vs-slot-body{opacity:.72}.vs-slot-header{justify-content:space-between;align-items:center;gap:8px;display:flex}.vs-slot-name{color:var(--color-text);letter-spacing:-.1px;align-items:baseline;gap:6px;font-size:14px;font-weight:700;display:inline-flex}.vs-slot-num{color:var(--color-text-faint);font-size:11px;font-weight:600;font-family:var(--font-mono)}.vs-self-badge{border-radius:var(--radius-pill);background:var(--color-accent);color:#fff;letter-spacing:.1px;margin-left:4px;padding:0 6px;font-size:10px;font-weight:700}.vs-pill{border-radius:var(--radius-pill);letter-spacing:.1px;white-space:nowrap;padding:2px 8px;font-size:11px;font-weight:600;display:inline-block}.vs-pill-empty{background:var(--color-surface-alt);color:var(--color-text-muted)}.vs-pill-draft{color:#8a5a00;background:#fef3c7}.vs-pill-review{background:var(--color-warning-tinted-bg);color:var(--color-warning)}.vs-pill-submitted{background:var(--color-status-reviewed-bg);color:var(--color-status-reviewed-text)}.vs-pill-returned{background:var(--color-status-returned-bg);color:var(--color-status-returned-text)}.vs-slot-body{flex-direction:column;flex:1;gap:8px;display:flex}.vs-slot-body-empty{text-align:center;justify-content:center;align-items:center;padding:16px 4px}.vs-slot-empty-icon{opacity:.6;font-size:28px}.vs-slot-empty-hint{color:var(--color-text-muted);margin:0;font-size:12px}.vs-slot-thumb{aspect-ratio:4/3;object-fit:cover;background:var(--color-surface-alt);border-radius:8px;width:100%}.vs-slot-thumb-fallback{background:#fff}.vs-slot-title{color:var(--color-text);text-overflow:ellipsis;-webkit-line-clamp:2;-webkit-box-orient:vertical;margin:0;font-size:13px;font-weight:600;display:-webkit-box;overflow:hidden}.vs-slot-note{color:var(--color-danger);background:var(--color-status-returned-bg);border-radius:6px;margin:0;padding:6px 10px;font-size:12px;line-height:1.4}.vs-slot-cta{border-radius:var(--radius-pill);background:var(--color-accent-tinted-bg);color:var(--color-accent-tinted-text);align-self:flex-start;padding:4px 10px;font-size:12px;font-weight:700}.vs-backdrop{z-index:60;background:#0000008c;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.vs-studio{background:var(--color-surface);border-radius:var(--radius-card);width:min(96vw,1100px);height:min(92vh,760px);box-shadow:var(--shadow-card-hover);flex-direction:column;display:flex;overflow:hidden}.vs-studio-head{border-bottom:1px solid var(--color-border);justify-content:space-between;align-items:center;gap:12px;padding:14px 18px;display:flex}.vs-studio-head-left{flex:1;align-items:baseline;gap:10px;min-width:0;display:flex}.vs-studio-title,.vs-studio-title-input{font-family:var(--font-display);letter-spacing:-.2px;color:var(--color-text);background:0 0;border:1px solid #0000;border-radius:6px;max-width:100%;margin:0;padding:2px 6px;font-size:18px;font-weight:700}.vs-studio-title-input:focus{border-color:var(--color-accent);outline:none;box-shadow:0 0 0 3px #0075de26}.vs-studio-author{color:var(--color-text-muted);font-size:12px}.vs-studio-close{width:32px;height:32px;color:var(--color-text-muted);cursor:pointer;background:0 0;border:none;border-radius:6px;font-size:22px}.vs-studio-close:hover{background:var(--color-surface-alt);color:var(--color-text)}.vs-studio-body{flex:1;grid-template-columns:1fr 1fr;min-height:0;display:grid}.vs-studio-editor{border-right:1px solid var(--color-border);flex-direction:column;min-width:0;display:flex}.vs-studio-tabs{border-bottom:1px solid var(--color-border);background:#faf9f7;gap:4px;padding:8px 10px;display:flex}.vs-studio-tab{font-family:var(--font-mono);color:var(--color-text-muted);cursor:pointer;transition:background var(--t-normal), color var(--t-normal);background:0 0;border:none;border-radius:6px;padding:5px 12px;font-size:12px;font-weight:600}.vs-studio-tab:hover{background:var(--color-surface-alt);color:var(--color-text)}.vs-studio-tab.is-active{background:var(--color-surface);color:var(--color-text);border:1px solid var(--color-border)}.vs-studio-textarea{resize:none;font-family:var(--font-mono);color:var(--color-text);background:var(--color-surface);border:none;outline:none;flex:1;padding:12px 14px;font-size:13px;line-height:1.5}.vs-studio-textarea:focus{background:#fff}.vs-studio-preview{background:#f0ede9;flex-direction:column;min-width:0;display:flex}.vs-studio-preview-label{font-family:var(--font-mono);letter-spacing:.08em;color:var(--color-text-muted);text-transform:uppercase;border-bottom:1px solid var(--color-border);background:#faf9f7;padding:8px 14px;font-size:11px;font-weight:700}.vs-studio-iframe{background:#fff;border:none;flex:1;width:100%}.vs-studio-foot{border-top:1px solid var(--color-border);background:#faf9f7;align-items:center;gap:10px;padding:10px 18px;display:flex}.vs-studio-err{color:var(--color-danger);flex:1;font-size:12px}.vs-studio-tag{color:var(--color-text-muted);align-items:center;gap:6px;margin-left:auto;font-size:12px;display:inline-flex}.vs-studio-tag select{font:inherit;border:1px solid var(--color-border);border-radius:var(--radius-btn);background:var(--color-surface);padding:4px 8px;font-size:12px}.vs-studio-save{border-radius:var(--radius-btn);background:var(--color-accent);color:#fff;cursor:pointer;transition:background var(--t-normal);border:none;padding:8px 18px;font-size:13px;font-weight:600}.vs-studio-save:hover:not(:disabled){background:var(--color-accent-active)}.vs-studio-save:disabled{opacity:.5;cursor:not-allowed}.vs-studio-teacher-hint{color:var(--color-text-muted);margin-left:auto;font-size:12px}.vs-chat{flex-direction:column;flex:1;min-height:0;display:flex}.vs-chat-log{flex-direction:column;flex:1;gap:10px;padding:14px;display:flex;overflow:auto}.vs-chat-hint{text-align:center;max-width:320px;color:var(--color-text-muted);margin:auto;font-size:13px;line-height:1.5}.vs-chat-msg{white-space:pre-wrap;word-break:break-word;border-radius:10px;max-width:85%;padding:8px 12px;font-size:13px;line-height:1.5}.vs-chat-msg-user{background:var(--color-accent);color:#fff;align-self:flex-end}.vs-chat-msg-assistant{background:var(--color-surface-alt);color:var(--color-text);align-self:flex-start}.vs-chat-msg.is-streaming:after{content:"▎";margin-left:2px;animation:1s steps(2,end) infinite vs-blink}@keyframes vs-blink{50%{opacity:.2}}.vs-chat-form{border-top:1px solid var(--color-border);background:var(--color-surface);gap:8px;padding:10px 14px;display:flex}.vs-chat-input{resize:none;border:1px solid var(--color-border);font-family:var(--font-body);transition:border-color var(--t-normal);border-radius:8px;outline:none;flex:1;padding:8px 12px;font-size:13px;line-height:1.4}.vs-chat-input:focus{border-color:var(--color-accent);box-shadow:0 0 0 3px #0075de26}.vs-chat-send{background:var(--color-accent);color:#fff;cursor:pointer;transition:background var(--t-normal);border:none;border-radius:8px;padding:0 14px;font-size:13px;font-weight:600}.vs-chat-send:hover:not(:disabled){background:var(--color-accent-active)}.vs-chat-send:disabled{opacity:.45;cursor:not-allowed}@media (max-width:820px){.vs-studio-body{grid-template-rows:1fr 1fr;grid-template-columns:1fr}.vs-studio-editor{border-right:none;border-bottom:1px solid var(--color-border)}}.vp-modal{background:var(--color-vibe-sandbox-bg,#1a1a1a);border-radius:var(--radius-card);width:min(96vw,960px);height:min(88vh,640px);box-shadow:var(--shadow-card-hover);flex-direction:column;display:flex;overflow:hidden}.vp-head{color:#fff;background:#111;border-bottom:1px solid #ffffff14;flex-shrink:0;justify-content:space-between;align-items:center;padding:10px 16px;display:flex}.vp-title{letter-spacing:-.1px;margin:0;font-size:14px;font-weight:600}.vp-head .vs-studio-close{color:#fff;background:0 0}.vp-head .vs-studio-close:hover{color:#fff;background:#ffffff1a}.vp-body{background:#000;flex:1;justify-content:stretch;align-items:stretch;min-height:0;display:flex}.vp-iframe{background:#000;border:none;width:100%;height:100%}.vp-err{text-align:center;color:#ffb0b0;max-width:340px;margin:auto;padding:16px;font-size:13px}.vp-loading{color:#fff9;margin:auto;font-size:13px}.vg-card-btn{text-align:left;width:100%;font-family:inherit;font-size:inherit;color:inherit;cursor:pointer;flex-direction:column;gap:8px;display:flex}.vg-card-btn:disabled{cursor:default}.va-header{justify-content:space-between;align-items:flex-start;gap:16px;display:flex}.va-header-actions{flex-shrink:0;gap:8px;display:flex}.va-header-btn{background:var(--color-surface);border:var(--border-card);border-radius:var(--radius-btn);color:var(--color-text);cursor:pointer;padding:8px 14px;font-family:inherit;font-size:13px;font-weight:500;transition:background .15s,border-color .15s}.va-header-btn:hover{background:var(--color-surface-alt);border-color:var(--color-accent)}.va-mod-modal,.va-settings-modal{background:var(--color-surface);border-radius:var(--radius-card);z-index:101;flex-direction:column;width:min(720px,100vw - 32px);max-height:calc(100vh - 64px);display:flex;position:fixed;top:50%;left:50%;overflow:hidden;transform:translate(-50%,-50%);box-shadow:0 20px 60px #00000040}.va-settings-modal{width:min(560px,100vw - 32px)}.va-mod-modal-header{border-bottom:1px solid var(--color-border);justify-content:space-between;align-items:center;padding:18px 22px;display:flex}.va-mod-modal-title{font-family:var(--font-display);color:var(--color-text);margin:0;font-size:18px;font-weight:700}.va-mod-tabs{border-bottom:1px solid var(--color-border);gap:4px;padding:12px 18px 0;display:flex;overflow-x:auto}.va-mod-tab{color:var(--color-text-muted);cursor:pointer;white-space:nowrap;background:0 0;border:none;border-bottom:2px solid #0000;border-radius:8px 8px 0 0;align-items:center;gap:6px;padding:8px 12px;font-size:13px;font-weight:500;display:inline-flex}.va-mod-tab:hover{color:var(--color-text)}.va-mod-tab.is-active{color:var(--color-accent);border-bottom-color:var(--color-accent)}.va-mod-tab-count{background:var(--color-accent);color:#fff;text-align:center;border-radius:999px;min-width:18px;padding:1px 7px;font-size:11px}.va-mod-body,.va-settings-body{flex:1;padding:18px 22px;overflow-y:auto}.va-mod-loading,.va-mod-empty{text-align:center;color:var(--color-text-muted);padding:32px 0}.va-mod-error{border-left:3px solid var(--color-danger,#dc3545);color:var(--color-danger,#dc3545);border-radius:var(--radius-btn);background:#dc354514;padding:12px 14px;font-size:13px}.va-mod-list{flex-direction:column;gap:12px;margin:0;padding:0;list-style:none;display:flex}.va-mod-item{background:var(--color-surface-alt);border-radius:var(--radius-card);grid-template-columns:120px 1fr auto;align-items:start;gap:14px;padding:12px;display:grid}.va-mod-item-thumb{border-radius:var(--radius-btn);background:var(--color-border);width:120px;height:90px;overflow:hidden}.va-mod-item-thumb img{object-fit:cover;width:100%;height:100%;display:block}.va-mod-item-thumb-fallback{background:#fff;width:100%;height:100%}.va-mod-item-title{color:var(--color-text);font-size:14px;font-weight:700}.va-mod-item-ver{color:var(--color-text-muted);font-size:12px;font-weight:400}.va-mod-item-sub{color:var(--color-text-muted);margin-top:2px;font-size:12px}.va-mod-item-desc{color:var(--color-text);-webkit-line-clamp:2;-webkit-box-orient:vertical;margin:8px 0 0;font-size:13px;line-height:1.4;display:-webkit-box;overflow:hidden}.va-mod-item-note{color:var(--color-danger,#dc3545);margin:6px 0 0;font-size:12px;font-style:italic}.va-mod-item-actions{flex-direction:column;align-items:stretch;gap:6px;min-width:88px;display:flex}.va-mod-btn{border:1px solid var(--color-border);border-radius:var(--radius-btn);cursor:pointer;background:var(--color-surface);color:var(--color-text);text-align:center;padding:6px 12px;font-family:inherit;font-size:12px;font-weight:600;text-decoration:none;transition:background .15s,border-color .15s;display:inline-block}.va-mod-btn:hover:not(:disabled){background:var(--color-surface-alt)}.va-mod-btn:disabled{opacity:.55;cursor:default}.va-mod-btn.is-approve{background:var(--color-accent);color:#fff;border-color:var(--color-accent)}.va-mod-btn.is-approve:hover:not(:disabled){background:var(--color-accent-active)}.va-mod-btn.is-reject{color:var(--color-danger,#dc3545);border-color:var(--color-danger,#dc3545);background:0 0}.va-mod-btn.is-reject:hover:not(:disabled){background:#dc354514}.va-mod-btn.is-ghost{color:var(--color-text-muted);background:0 0}.va-settings-section{border-bottom:1px solid var(--color-border);padding:12px 0}.va-settings-section:last-of-type{border-bottom:none}.va-settings-heading{color:var(--color-text);letter-spacing:.2px;margin:0 0 8px;font-size:13px;font-weight:700}.va-settings-row{justify-content:space-between;align-items:center;gap:12px;padding:6px 0;display:flex}.va-settings-row-col{flex-direction:column;align-items:stretch}.va-settings-label{color:var(--color-text);font-size:13px;font-weight:500}.va-settings-hint{color:var(--color-text-muted);margin:4px 0 0;font-size:11.5px}.va-settings-input,.va-settings-select{border:1px solid var(--color-border);border-radius:var(--radius-btn);background:var(--color-surface);color:var(--color-text);outline:none;min-width:160px;padding:8px 10px;font-family:inherit;font-size:13px;transition:border-color .15s}.va-settings-input:focus,.va-settings-select:focus{border-color:var(--color-accent)}.va-settings-ok{color:var(--color-accent);margin:8px 0 0;font-size:13px}.va-settings-footer{border-top:1px solid var(--color-border);justify-content:flex-end;gap:8px;margin-top:12px;padding:14px 0 0;display:flex}.vs-starter-grid{grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:10px;padding:20px 4px;display:grid}.vs-starter-title{color:var(--color-text);text-align:center;grid-column:1/-1;margin:0 0 4px;font-size:15px;font-weight:600}.vs-starter-card{border:1px solid var(--color-border);background:var(--color-surface);color:var(--color-text);cursor:pointer;border-radius:12px;flex-direction:column;justify-content:center;align-items:center;gap:8px;padding:20px 12px;transition:background .12s,border-color .12s,transform .12s;display:flex}.vs-starter-card:hover:not(:disabled){background:var(--color-surface-alt);border-color:var(--color-accent);transform:translateY(-1px)}.vs-starter-card:disabled{opacity:.5;cursor:not-allowed}.vs-starter-emoji{font-size:32px;line-height:1}.vs-starter-label{font-size:13px;font-weight:600}.vs-starter-custom{border-style:dashed}.va-student-landing{justify-content:center;align-items:center;padding:32px;display:flex}.va-student-landing-inner{text-align:center;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-card);max-width:520px;box-shadow:var(--shadow-card);flex-direction:column;align-items:center;gap:16px;padding:48px 40px;display:flex}.va-student-landing-inner .va-title{margin:0;font-size:28px}.va-student-landing-inner .va-subtitle{color:var(--color-text-muted);margin:0 0 8px;font-size:14px}.va-student-enter{background:var(--color-accent);color:#fff;border-radius:var(--radius-btn);transition:background var(--t-normal), transform var(--t-fast);align-items:center;gap:8px;padding:14px 32px;font-size:16px;font-weight:700;text-decoration:none;display:inline-flex}.va-student-enter:hover{background:var(--color-primary-dark,#388e3c);transform:translateY(-1px)}.va-student-enter-secondary{background:var(--color-surface);color:var(--color-text);border:2px solid var(--color-border)}.va-student-enter-secondary:hover{border-color:var(--color-primary);background:var(--color-primary-bg,#e8f5e9)}.va-student-enter:active{transform:translateY(0)}.va-studio-page{background:var(--color-bg);flex-direction:column;height:100vh;display:flex}.va-studio-bar{border-bottom:1px solid var(--color-border);background:var(--color-surface);align-items:center;gap:12px;padding:10px 18px;display:flex}.va-studio-back{border-radius:var(--radius-btn);background:var(--color-surface-alt);color:var(--color-text);transition:background var(--t-normal);padding:6px 12px;font-size:13px;font-weight:600;text-decoration:none}.va-studio-back:hover{background:var(--color-border)}.va-studio-bar-center{flex:1;align-items:baseline;gap:10px;min-width:0;display:flex}.va-studio-title{border-radius:var(--radius-btn);min-width:0;color:var(--color-text);background:0 0;border:1px solid #0000;outline:none;flex:1;padding:6px 10px;font-size:15px;font-weight:600}.va-studio-title:focus{border-color:var(--color-border);background:var(--color-surface)}.va-studio-author{color:var(--color-text-muted);white-space:nowrap;font-size:12px}.va-studio-bar-actions{align-items:center;gap:10px;display:flex}.va-studio-tag{color:var(--color-text-muted);align-items:center;gap:6px;font-size:12px;display:inline-flex}.va-studio-tag select{font:inherit;border:1px solid var(--color-border);border-radius:var(--radius-btn);background:var(--color-surface);padding:4px 8px;font-size:12px}.va-studio-submit{border-radius:var(--radius-btn);background:var(--color-accent);color:#fff;cursor:pointer;transition:background var(--t-normal);border:none;padding:8px 18px;font-size:13px;font-weight:600}.va-studio-submit:hover:not(:disabled){background:var(--color-accent-active)}.va-studio-submit:disabled{opacity:.5;cursor:not-allowed}.va-studio-err{border-bottom:1px solid var(--color-danger);color:var(--color-danger);background:#fff4f4;padding:8px 18px;font-size:12px}.va-studio-grid{flex:1;grid-template-rows:minmax(0,1fr);grid-template-columns:1fr 1fr;min-height:0;display:grid}.va-studio-chat{border-right:1px solid var(--color-border);background:var(--color-surface);flex-direction:column;min-width:0;min-height:0;display:flex}.va-studio-chat-log{flex-direction:column;flex:1;gap:10px;min-height:0;padding:16px;display:flex;overflow:auto}.va-studio-chat-form{border-top:1px solid var(--color-border);background:#faf9f7;gap:8px;padding:12px 14px;display:flex}.va-studio-chat-input{resize:none;font:inherit;border:1px solid var(--color-border);border-radius:var(--radius-btn);background:var(--color-surface);color:var(--color-text);outline:none;flex:1;padding:10px 12px;font-size:13px;line-height:1.5}.va-studio-chat-input:focus{border-color:var(--color-accent)}.va-studio-chat-send{border-radius:var(--radius-btn);background:var(--color-accent);color:#fff;cursor:pointer;transition:background var(--t-normal);border:none;padding:8px 18px;font-size:13px;font-weight:600}.va-studio-chat-send:hover:not(:disabled){background:var(--color-accent-active)}.va-studio-chat-send:disabled{opacity:.5;cursor:not-allowed}.va-studio-preview{background:#f0ede9;flex-direction:column;min-width:0;min-height:0;display:flex}.va-studio-preview-head{border-bottom:1px solid var(--color-border);background:#faf9f7;align-items:center;gap:4px;padding:6px 10px;display:flex}.va-studio-preview-tab{font-family:var(--font-mono);color:var(--color-text-muted);cursor:pointer;border-radius:var(--radius-btn);transition:background var(--t-normal), color var(--t-normal);background:0 0;border:none;padding:6px 14px;font-size:12px;font-weight:600}.va-studio-preview-tab:hover{background:var(--color-surface);color:var(--color-text)}.va-studio-preview-tab.is-active{background:var(--color-surface);color:var(--color-text);border:1px solid var(--color-border)}.va-studio-code{min-height:0;font-family:var(--font-mono);color:var(--color-text);white-space:pre;tab-size:2;background:#fff;flex:1;margin:0;padding:14px 16px;font-size:12px;line-height:1.55;overflow:auto}.va-studio-code-editor{flex:1;min-height:0;display:flex}.va-studio-code-editor .monaco-canvas{border:0;border-radius:0;flex:1;min-height:0}.va-studio-code-editor .monaco-canvas-tabs,.va-studio-code-editor .monaco-canvas-editor{min-height:0}.va-studio-code-empty{color:var(--color-text-muted);background:#fff;flex:1;justify-content:center;align-items:center;font-size:13px;display:flex}.va-studio-iframe{background:#fff;border:none;flex:1;width:100%}
