img.emoji{vertical-align:-.1em;width:1em;height:1em;margin:0 .05em 0 .1em;display:inline-block}.board-grid-emoji img.emoji,.layout-option-emoji img.emoji,.layout-grid-option-emoji img.emoji{vertical-align:middle;width:1.6em;height:1.6em;margin:0}:root{--color-bg:#fff;--color-bg-alt:#fff;--color-surface:#fff;--color-surface-alt:#184a5c12;--color-text:#18313f;--color-text-muted:#5d6f76;--color-text-faint:#8fa0a6;--color-accent:#1683c7;--color-accent-active:#0d679f;--color-accent-tinted-bg:#e9f7ff;--color-accent-tinted-text:#0f70ad;--color-border:#184a5c24;--color-border-hover:#184a5c3b;--color-learning-mint:#dff6e9;--color-learning-sun:#fff1bd;--color-learning-coral:#ffe1d6;--color-learning-lavender:#ede9ff;--color-plant-active:#27a35f;--color-plant-visited:#b8dfc7;--color-plant-upcoming:#d0cfcd;--color-plant-stalled:#c62828;--color-danger:#c62828;--color-danger-active:#a01b1b;--color-status-submitted-bg:#f2f9ff;--color-status-submitted-text:#1565c0;--color-status-reviewed-bg:#e8f5e9;--color-status-reviewed-text:#2e7d32;--color-status-returned-bg:#ffebee;--color-status-returned-text:#c62828;--color-slot-placeholder:var(--color-surface-alt);--color-warning:#f59e0b;--color-warning-tinted-bg:#fef3c7;--color-quiz-difficulty-easy:#27a35f;--color-quiz-difficulty-medium:#c9a227;--color-quiz-difficulty-hard:#c62828;--color-vibe-rating:#f5a623;--color-vibe-rating-empty:#e5e5e5;--color-vibe-quota-ok:var(--color-plant-active);--color-vibe-quota-warn:#f5a623;--color-vibe-quota-danger:var(--color-danger);--color-vibe-sandbox-bg:#1a1a1a;--color-vibe-chat-user-bg:var(--color-accent-tinted-bg);--color-showcase:var(--color-vibe-rating);--color-oauth-google:#4285f4;--color-oauth-kakao:#fee500;--container-max-width:960px;--radius-card:16px;--radius-btn:10px;--radius-control:12px;--radius-pill:9999px;--font-display:"Pretendard Variable", "SUIT", "Noto Sans KR", "Segoe UI", sans-serif;--font-body:"Pretendard Variable", "SUIT", "Noto Sans KR", "Segoe UI", sans-serif;--font-display-tracking:0;--shadow-card:#184a5c14 0px 10px 28px, #184a5c0a 0px 2px 8px;--shadow-card-hover:#184a5c1f 0px 16px 36px, #184a5c0f 0px 4px 12px;--shadow-lift:#184a5c17 0px 3px 10px;--shadow-accent:0 8px 20px #1683c738;--shadow-accent-hover:0 10px 24px #1683c747;--border-card:1px solid var(--color-border);--color-bank-positive:#27a35f;--color-bank-negative:#c62828;--font-mono:"SF Mono", "Fira Code", ui-monospace, monospace;--text-display-size:26px;--text-display-weight:700;--text-display-ls:-.5px;--text-title-size:20px;--text-title-weight:700;--text-title-ls:-.3px;--text-subtitle-size:16px;--text-subtitle-weight:700;--text-subtitle-ls:-.25px;--text-section-size:15px;--text-section-weight:700;--text-section-ls:-.15px;--text-body-size:15px;--text-body-weight:400;--text-body-ls:0;--text-label-size:13px;--text-label-weight:600;--text-label-ls:0;--text-badge-size:12px;--text-badge-weight:600;--text-badge-ls:.125px;--text-micro-size:11px;--text-micro-weight:600;--text-micro-ls:.1px;--t-fast:.12s ease;--t-normal:.15s ease;--t-slow:.18s ease;--t-modal:.2s ease}*{box-sizing:border-box}html,body{min-height:100vh;margin:0;padding:0}body{font-family:var(--font-body);font-size:var(--text-body-size);color:var(--color-text);-webkit-font-smoothing:antialiased;font-feature-settings:"kern", "liga";background:#fff;font-weight:400;line-height:1.5}:focus-visible{outline:2px solid var(--color-accent-tinted-text);outline-offset:2px;border-radius:2px}button{font-family:inherit}button,input,textarea,select{font:inherit}button.side-panel-close.side-panel-close,button.quiz-modal-close.quiz-modal-close,button.portfolio-card-modal-close.portfolio-card-modal-close,button.card-engagement-modal-close.card-engagement-modal-close{border:1px solid var(--color-border);border-radius:var(--radius-control);width:36px;height:36px;color:var(--color-text-muted);cursor:pointer;background:#ffffffd1;justify-content:center;align-items:center;padding:0;font-size:0;line-height:1;display:inline-flex;position:relative}button.assign-modal__close.assign-modal__close{border-radius:var(--radius-control);color:#ffffffc7;cursor:pointer;background:#ffffff14;border:1px solid #ffffff2e;justify-content:center;align-items:center;width:40px;height:40px;padding:0;font-size:0;line-height:1;display:inline-flex;position:relative}button.side-panel-close.side-panel-close:before,button.side-panel-close.side-panel-close:after,button.quiz-modal-close.quiz-modal-close:before,button.quiz-modal-close.quiz-modal-close:after,button.portfolio-card-modal-close.portfolio-card-modal-close:before,button.portfolio-card-modal-close.portfolio-card-modal-close:after,button.card-engagement-modal-close.card-engagement-modal-close:before,button.card-engagement-modal-close.card-engagement-modal-close:after,button.assign-modal__close.assign-modal__close:before,button.assign-modal__close.assign-modal__close:after{content:"";background:currentColor;border-radius:999px;width:15px;height:2px;position:absolute}button.side-panel-close.side-panel-close:before,button.quiz-modal-close.quiz-modal-close:before,button.portfolio-card-modal-close.portfolio-card-modal-close:before,button.card-engagement-modal-close.card-engagement-modal-close:before,button.assign-modal__close.assign-modal__close:before{transform:rotate(45deg)}button.side-panel-close.side-panel-close:after,button.quiz-modal-close.quiz-modal-close:after,button.portfolio-card-modal-close.portfolio-card-modal-close:after,button.card-engagement-modal-close.card-engagement-modal-close:after,button.assign-modal__close.assign-modal__close:after{transform:rotate(-45deg)}
.h1,h1.ds-h1{font-family:var(--font-display);letter-spacing:var(--font-display-tracking);margin:0;font-size:32px;font-weight:700;line-height:1.15}.h2,h2.ds-h2{font-family:var(--font-display);font-size:var(--text-display-size);font-weight:var(--text-display-weight);letter-spacing:var(--text-display-ls);margin:0;line-height:1.2}.h3,h3.ds-h3{font-family:var(--font-display);font-size:var(--text-title-size);font-weight:var(--text-title-weight);letter-spacing:var(--text-title-ls);margin:0;line-height:1.3}.h4,h4.ds-h4{font-family:var(--font-display);font-size:var(--text-subtitle-size);font-weight:var(--text-subtitle-weight);letter-spacing:var(--text-subtitle-ls);margin:0;line-height:1.3}.h5,h5.ds-h5{font-family:var(--font-display);font-size:var(--text-section-size);font-weight:var(--text-section-weight);letter-spacing:var(--text-section-ls);margin:0;line-height:1.3}.ds-body{font-size:var(--text-body-size);font-weight:var(--text-body-weight);margin:0;line-height:1.5}.ds-label{font-size:var(--text-label-size);font-weight:var(--text-label-weight);color:var(--color-text-muted)}.ds-badge{font-size:var(--text-badge-size);font-weight:var(--text-badge-weight);letter-spacing:var(--text-badge-ls)}.ds-micro{font-size:var(--text-micro-size);font-weight:var(--text-micro-weight);letter-spacing:var(--text-micro-ls)}.ds-code{font-family:var(--font-mono);background:var(--color-surface-alt);border-radius:4px;padding:2px 6px;font-size:12px}.ds-card{background:var(--color-surface);border:var(--border-card);border-radius:var(--radius-card);box-shadow:var(--shadow-card);transition:box-shadow var(--t-slow), border-color var(--t-slow)}.ds-card:hover{box-shadow:var(--shadow-card-hover);border-color:var(--color-border-hover)}.ds-pill{border-radius:var(--radius-pill);background:var(--color-accent-tinted-bg);color:var(--color-accent-tinted-text);font-size:var(--text-badge-size);font-weight:var(--text-badge-weight);letter-spacing:var(--text-badge-ls);padding:2px 8px;display:inline-block}.ds-btn-primary{background:var(--color-accent);color:#fff;border-radius:var(--radius-btn);cursor:pointer;transition:background var(--t-normal);font-size:14px;font-weight:600;font-family:var(--font-body);border:none;padding:9px 20px}.ds-btn-primary:hover{background:var(--color-accent-active)}.ds-btn-primary:disabled{opacity:.5;cursor:default;pointer-events:none}.ds-btn-secondary{color:var(--color-text);border:1px solid var(--color-border);border-radius:var(--radius-btn);cursor:pointer;transition:background var(--t-normal), border-color var(--t-normal);font-size:14px;font-weight:500;font-family:var(--font-body);background:0 0;padding:9px 20px}.ds-btn-secondary:hover{background:var(--color-surface-alt);border-color:var(--color-border-hover)}.ds-btn-secondary:disabled{opacity:.5;cursor:default;pointer-events:none}.ab-logo-lockup{align-items:center;gap:10px;display:inline-flex}.ab-logo-img{border-radius:10px;width:40px;height:40px;display:block;box-shadow:0 6px 20px #8b79ff40}.ab-logo-img-lg{border-radius:16px;width:72px;height:72px;margin:0 auto 20px}.ab-logo-img-sm{border-radius:8px;width:32px;height:32px}.ab-logo-wordmark{font-family:var(--font-display);letter-spacing:-.3px;color:var(--color-text);font-size:20px;font-weight:700}
:root{--tap-min:44px;--modal-max:min(92vw, 640px);--fab-bottom-safe:calc(32px + env(safe-area-inset-bottom,0px))}@media (min-width:1280px){:root{--container-max-width:1240px}}
.board-page{background:linear-gradient(#eef7ff 0%,#dcecff 100%);flex-direction:column;min-height:100dvh;display:flex;overflow:auto}.board-page[data-board-theme=pastel-peach]{background:linear-gradient(#fff4ef 0%,#ffe7df 100%)}.board-page[data-board-theme=pastel-mint]{background:linear-gradient(#f1fff8 0%,#dff6ec 100%)}.board-page[data-board-theme=pastel-sky]{background:linear-gradient(#eef7ff 0%,#dcecff 100%)}.board-page[data-board-theme=pastel-lilac]{background:linear-gradient(#f8f2ff 0%,#eadfff 100%)}.board-page[data-board-theme=pastel-lemon]{background:linear-gradient(#fffcee 0%,#ffefc1 100%)}.board-header{background:var(--color-bg-alt);border-bottom:var(--border-card);z-index:20;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:20px;padding:18px 32px;display:flex;position:sticky;top:0}.board-header-left{align-items:center;gap:16px;min-height:36px;display:flex}.board-header-right{flex-wrap:wrap;align-items:center;gap:12px;display:flex}.board-title{font-family:var(--font-display);letter-spacing:var(--font-display-tracking);color:var(--color-text);margin:0;font-size:26px;font-weight:700;line-height:1.15}.board-canvas-wrap{flex:1;min-width:0;min-height:0;padding:32px;position:relative;overflow:auto}.board-page[data-board-theme^=pastel-] .board-header{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffffb8}.board-page[data-board-theme^=pastel-] .board-canvas-wrap{background:0 0}.board-title-editable{cursor:text;border-radius:6px;margin:-2px -6px;padding:2px 6px;transition:background .15s}.board-title-editable:hover{background:#0000000a}.board-title-input{font-family:var(--font-display);letter-spacing:var(--font-display-tracking);color:var(--color-text);background:var(--color-bg);border:2px solid var(--color-accent);border-radius:6px;outline:none;width:300px;margin:-4px -10px;padding:2px 8px;font-size:26px;font-weight:700;line-height:1.15}.board-canvas{min-width:900px;min-height:920px;position:relative}.board-empty{text-align:center;background:var(--color-surface);border:var(--border-card);border-radius:var(--radius-card);box-shadow:var(--shadow-card);max-width:360px;padding:32px 48px;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.board-empty p{color:var(--color-text-muted);margin:0;font-size:14px;line-height:1.5}.ab-topnav{z-index:5;-webkit-backdrop-filter:saturate(150%)blur(8px);border-bottom:1px solid var(--color-border);background:#f6f5f4eb;justify-content:space-between;align-items:center;gap:16px;padding:14px 32px;display:flex;position:sticky;top:0}.ab-topnav-left{align-items:center;gap:24px;display:flex}.ab-topnav-logo{color:inherit;background:0 0;border:none;align-items:center;padding:0;text-decoration:none;display:inline-flex}.ab-topnav-links{align-items:center;gap:2px;display:flex}.ab-topnav-link{color:var(--color-text-muted);font:inherit;cursor:pointer;transition:background var(--t-normal), color var(--t-normal);background:0 0;border:none;border-radius:6px;align-items:center;padding:6px 12px;font-size:14px;font-weight:500;text-decoration:none;display:inline-flex}.ab-topnav-link:hover{background:var(--color-surface-alt);color:var(--color-text)}.ab-topnav-link.active{color:var(--color-text);background:var(--color-surface-alt);font-weight:600}.ab-topnav-right{align-items:center;gap:10px;display:flex}@media (max-width:640px){.ab-topnav{padding:10px 16px}.ab-topnav-left{gap:12px}.ab-topnav-logo .ab-logo-wordmark{display:none}}
.board-share-btn{cursor:pointer;color:#1e293b;background:#fff;border:1px solid #d0d5e2;border-radius:6px;align-items:center;gap:4px;padding:4px 10px;font-size:13px;transition:background .12s;display:inline-flex}.board-share-btn:hover{background:#f1f5f9;border-color:#94a3b8}.board-share-badge{color:#475569;font-size:11px;font-weight:500}.share-qr-overlay{z-index:9999;background:#00000059;padding:24px;position:fixed;inset:0;overflow-y:auto}.share-qr-modal{background:#fff;border-radius:12px;width:min(400px,100vw - 48px);min-width:320px;max-width:400px;max-height:calc(100dvh - 48px);position:fixed;top:50%;left:50%;overflow-y:auto;transform:translate(-50%,-50%);box-shadow:0 8px 32px #0000002e}.share-qr-modal-header{justify-content:space-between;align-items:center;padding:16px 20px 0;display:flex}.share-qr-close{cursor:pointer;color:#64748b;background:0 0;border:none;padding:4px;font-size:16px;line-height:1}.share-qr-close:hover{color:#1e293b}.share-qr-modal-body{flex-direction:column;align-items:center;gap:16px;padding:20px;display:flex}.share-qr-code-wrap{justify-content:center;align-items:center;min-height:180px;display:flex}.share-qr-svg{justify-content:center;align-items:center;display:flex}.share-qr-svg svg{width:180px;height:180px}.share-qr-loading{color:#94a3b8;font-size:13px}.share-link-row{gap:6px;width:100%;display:flex}.share-link-input{color:#1e293b;background:#f8fafc;border:1px solid #d0d5e2;border-radius:6px;outline:none;flex:1;padding:8px 10px;font-family:inherit;font-size:12px}.share-link-input:focus{border-color:#3b82f6}.share-copy-btn{cursor:pointer;color:#1e293b;white-space:nowrap;background:#fff;border:1px solid #d0d5e2;border-radius:6px;padding:8px 14px;font-size:12px;font-weight:600;transition:background .12s}.share-copy-btn:hover{background:#f1f5f9}.share-tab{flex-direction:column;gap:20px;display:flex}.share-mode-row{flex-direction:column;gap:6px;display:flex}.share-mode-label{justify-content:space-between;align-items:center;gap:12px;display:flex}.share-mode-select{color:#1e293b;cursor:pointer;background:#fff;border:1px solid #d0d5e2;border-radius:6px;min-width:140px;padding:6px 12px;font-size:13px}.share-mode-select:disabled{opacity:.6;cursor:not-allowed}.share-error{color:#ef4444;margin:0;font-size:12px}.share-qr-area{background:#fafbfc;border:1px solid #e2e8f0;border-radius:8px;flex-direction:column;align-items:center;gap:14px;padding:16px;display:flex}.share-qr-wrap{justify-content:center;align-items:center;min-height:140px;display:flex}.share-qr-wrap .share-qr-svg svg{width:150px;height:150px}.share-actions{gap:8px;width:100%;display:flex}.share-rotate-btn{cursor:pointer;color:#1e293b;background:#fff;border:1px solid #d0d5e2;border-radius:6px;width:100%;padding:8px 14px;font-size:12px;font-weight:600;transition:background .12s}.share-rotate-btn:hover{background:#f1f5f9}.share-rotate-btn:disabled{opacity:.6;cursor:not-allowed}.share-off-notice{background:#fafbfc;border:1px solid #e2e8f0;border-radius:8px;align-items:center;gap:12px;padding:16px;display:flex}.share-off-notice p{color:#64748b;margin:0;font-size:13px}
.padlet-card{background:var(--color-surface);color:var(--color-text);border:var(--border-card);border-radius:var(--radius-card);box-shadow:var(--shadow-card);will-change:transform;-webkit-user-select:none;user-select:none;touch-action:none;padding:16px 18px 18px;transition:box-shadow .18s,border-color .18s}.padlet-card.is-draggable{cursor:grab}.padlet-card:hover{box-shadow:var(--shadow-card-hover);border-color:var(--color-border-hover)}.padlet-card.is-dragging{cursor:grabbing;box-shadow:var(--shadow-card-hover);opacity:.96}.padlet-card-title{font-family:var(--font-display);letter-spacing:-.25px;color:var(--color-text);margin:0 28px 8px 0;font-size:16px;font-weight:700;line-height:1.3}.padlet-card-content{font-family:var(--font-body);color:var(--color-text-muted);white-space:pre-wrap;word-break:break-word;margin:0;font-size:14px;line-height:1.5}.padlet-card-content.is-collapsed{text-overflow:ellipsis;-webkit-line-clamp:var(--card-content-preview-lines,5);-webkit-box-orient:vertical;max-height:7.5em;display:-webkit-box;overflow:hidden}.padlet-card-content-toggle{border:1px solid var(--color-border);background:var(--color-accent-tinted-bg);min-height:30px;color:var(--color-accent-tinted-text);font-family:var(--font-body);cursor:pointer;border-radius:999px;justify-content:center;align-items:center;margin-top:8px;padding:5px 10px;font-size:12px;font-weight:700;transition:background .15s,border-color .15s,transform .12s;display:inline-flex}.padlet-card-content-toggle:hover{background:var(--color-surface);border-color:var(--color-accent)}.padlet-card-content-toggle:active{transform:translateY(1px)}.padlet-card-content-toggle:focus-visible{outline:2px solid var(--color-accent);outline-offset:2px}.card-author-footer{border-top:1px solid var(--color-border);align-items:center;gap:8px;margin-top:10px;padding-top:8px;font-size:12px;display:flex}.card-author-chip{background:var(--color-accent-tinted-bg);color:var(--color-accent-tinted-text);border-radius:var(--radius-pill);pointer-events:none;align-items:center;max-width:120px;padding:2px 8px;display:inline-flex}.card-author-name{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.card-author-time{color:var(--color-text-muted)}@media (forced-colors:active){.card-author-chip{border:1px solid canvastext}}.sr-only{clip:rect(0, 0, 0, 0);white-space:nowrap;border:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}.padlet-card-delete{width:24px;height:24px;color:var(--color-text-muted);border-radius:var(--radius-pill);cursor:pointer;background:#0000000f;border:none;justify-content:center;align-items:center;padding:0;font-size:16px;line-height:1;transition:background .15s,color .15s;display:none;position:absolute;top:8px;right:8px}.padlet-card:hover .padlet-card-delete,.padlet-card:focus-within .padlet-card-delete{display:flex}.padlet-card-delete:hover{color:var(--color-text);background:#0000001f}.card-attachments{margin-bottom:10px}.card-attach-image{border-radius:8px;margin-bottom:8px;position:relative;overflow:hidden}.card-attach-image img{object-fit:cover;width:100%;max-height:152px;display:block}.card-attach-multi-badge{color:#fff;pointer-events:none;background:#000000a6;border-radius:999px;padding:2px 8px;font-size:11px;font-weight:600;position:absolute;top:6px;right:6px}.card-attach-file-wrap{position:relative}.card-attach-multi-badge.is-inline{top:4px;right:4px}.card-attach-video{border-radius:8px;margin-bottom:8px;overflow:hidden}.card-attach-video iframe{aspect-ratio:16/9;border:none;width:100%;display:block}.card-attach-media-poster{aspect-ratio:16/9;background:#111827;position:relative}.card-attach-media-poster.is-clickable{cursor:pointer}.card-attach-video-poster-img,.card-attach-video-placeholder{width:100%;height:100%;display:block}.card-attach-video-poster-img{object-fit:cover}.card-attach-youtube-play,.card-attach-video-play{pointer-events:none;justify-content:center;align-items:center;display:inline-flex;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.card-attach-youtube-play{color:#fff;background:#f03;border-radius:11px;width:58px;height:40px;padding-left:3px;font-size:19px;line-height:1;box-shadow:0 8px 22px #00000038}.card-attach-video-play{width:52px;height:52px;color:var(--color-text);background:#ffffffeb;border-radius:50%;padding-left:3px;font-size:20px;line-height:1;box-shadow:0 8px 22px #0003}.card-attach-video-source{color:#fff;pointer-events:none;background:#111827b8;border-radius:999px;padding:3px 9px;font-size:11px;font-weight:700;line-height:1.4;position:absolute;bottom:10px;left:10px}.card-attach-file{background:var(--color-surface-alt);border:1px solid var(--color-border);border-radius:8px;align-items:center;gap:10px;min-width:0;margin-bottom:8px;padding:10px 12px;display:flex}.card-attach-file-icon{flex:none;font-size:24px;line-height:1}.card-attach-file-body{flex-direction:column;flex:auto;gap:2px;min-width:0;display:flex}.card-attach-file-name{color:var(--color-text);text-overflow:ellipsis;white-space:nowrap;font-size:13px;font-weight:600;overflow:hidden}.card-attach-file-meta{color:var(--color-text-muted);font-size:11px}.card-attach-file-download{color:var(--color-accent);border:1px solid var(--color-accent);white-space:nowrap;background:0 0;border-radius:4px;flex:none;padding:5px 10px;font-size:12px;font-weight:600;text-decoration:none;transition:background .12s,color .12s}.card-attach-file-download:hover{background:var(--color-accent);color:#fff}.card-link-preview{border:1px solid var(--color-border);color:inherit;border-radius:8px;flex-direction:column;margin-bottom:8px;text-decoration:none;transition:border-color .15s,box-shadow .15s;display:flex;overflow:hidden}.card-link-preview:hover{border-color:var(--color-border-hover);box-shadow:var(--shadow-lift)}.card-link-preview-image{background:var(--color-bg);width:100%;height:156px;max-height:156px;overflow:hidden}.card-link-preview-image img{object-fit:cover;width:100%;height:100%;display:block}.card-link-preview-body{flex-direction:column;gap:2px;padding:8px 11px 9px;display:flex}.card-link-preview-title{color:var(--color-text);-webkit-line-clamp:2;-webkit-box-orient:vertical;font-size:12.5px;font-weight:600;line-height:1.25;display:-webkit-box;overflow:hidden}.card-link-preview-url{color:var(--color-text-faint);margin-top:2px;font-size:11px}.card-attach-video video{background:#000;border-radius:8px;width:100%;max-height:180px;display:block}.card-ctx-menu{display:block;position:absolute;top:8px;right:8px}:is(.column-card:has(>.card-ctx-menu),.grid-card:has(>.card-ctx-menu),.stream-card:has(>.card-ctx-menu),.padlet-card:has(>.card-ctx-menu)){padding-top:40px}@media (pointer:coarse){:is(.column-card:has(>.card-ctx-menu),.grid-card:has(>.card-ctx-menu),.stream-card:has(>.card-ctx-menu),.padlet-card:has(>.card-ctx-menu)){padding-top:56px}}@media (hover:hover){.card-ctx-menu{opacity:0;transition:opacity .12s}.column-card:hover .card-ctx-menu,.grid-card:hover .card-ctx-menu,.stream-card:hover .card-ctx-menu,.padlet-card:hover .card-ctx-menu,.column-card:focus-within .card-ctx-menu,.grid-card:focus-within .card-ctx-menu,.stream-card:focus-within .card-ctx-menu,.padlet-card:focus-within .card-ctx-menu{opacity:1}}.card-canva-embed{background:var(--color-bg);border-radius:8px;width:100%;min-height:90px;margin-bottom:8px;padding-bottom:56.25%;position:relative;overflow:hidden}.card-canva-embed>img,.card-canva-embed>iframe{border:0;width:100%;height:100%;position:absolute;inset:0}.card-canva-embed>img{object-fit:cover;opacity:1;transition:opacity .15s}.card-canva-embed[data-loaded=true]>img{opacity:0;pointer-events:none}@media (prefers-reduced-motion:reduce){.card-canva-embed>img{transition:none}}.card-canva-slot{flex-direction:column;gap:0;width:100%;margin-bottom:8px;display:flex;position:relative}.card-canva-slot-header{justify-content:flex-end;align-items:center;gap:8px;min-height:22px;display:flex}.card-canva-mode-badge{border:1px solid var(--color-border,#0000001f);background:var(--color-surface,#fff);color:var(--color-text-subtle,#666);cursor:pointer;-webkit-user-select:none;user-select:none;border-radius:999px;align-items:center;gap:6px;padding:3px 10px;font-size:11px;font-weight:600;line-height:1;transition:background .12s,color .12s,border-color .12s;display:inline-flex}.card-canva-mode-badge:hover{background:var(--color-surface-hover,#f5f5f5)}.card-canva-mode-badge:focus-visible{outline:2px solid var(--color-accent,#3b82f6);outline-offset:2px}.card-canva-mode-badge[data-mode=live]{color:#fff;background:#e11d48;border-color:#be123c}.card-canva-mode-badge[data-mode=live]:hover{background:#be123c}.card-canva-mode-dot{background:currentColor;border-radius:50%;width:6px;height:6px}.card-canva-mode-badge[data-mode=live] .card-canva-mode-dot{animation:1.4s ease-in-out infinite card-canva-pulse}@media (prefers-reduced-motion:reduce){.card-canva-mode-badge[data-mode=live] .card-canva-mode-dot{animation:none}}@keyframes card-canva-pulse{0%,to{opacity:1}50%{opacity:.35}}.card-canva-eviction-toast{color:var(--color-text-subtle,#666);background:var(--color-surface-hover,#f5f5f5);border-radius:6px;padding:2px 8px;font-size:11px;animation:1.8s forwards card-canva-fadeout}@media (prefers-reduced-motion:reduce){.card-canva-eviction-toast{animation:none}}@keyframes card-canva-fadeout{0%{opacity:0;transform:translateY(-2px)}10%{opacity:1;transform:translateY(0)}80%{opacity:1}to{opacity:0}}.card-canva-slot-frame{background:var(--color-bg,#f4f4f5);border-radius:8px;width:100%;min-height:76px;padding-bottom:50%;position:relative;overflow:hidden}.card-canva-slot-thumbnail,.card-canva-slot-iframe{border:0;width:100%;height:100%;position:absolute;inset:0}.card-canva-slot-thumbnail{object-fit:cover;opacity:1;transition:opacity .15s}.card-canva-slot[data-active=true][data-loaded=true] .card-canva-slot-thumbnail{opacity:0;pointer-events:none}@media (prefers-reduced-motion:reduce){.card-canva-slot-thumbnail{transition:none}}.card-canva-slot-activate-overlay{cursor:pointer;color:var(--color-text);background:#fff;flex-direction:column;justify-content:center;align-items:center;gap:8px;transition:background .15s;display:flex;position:absolute;inset:0}.card-canva-slot-activate-overlay:hover{background:#fff}.card-canva-slot[data-preview=true] .card-canva-slot-activate-overlay{background:0 0}.card-canva-slot[data-preview=true] .card-canva-slot-activate-overlay:hover{background:#ffffff14}.card-canva-slot-activate-overlay:focus-visible{outline:3px solid var(--color-accent,#3b82f6);outline-offset:-3px}@media (prefers-reduced-motion:reduce){.card-canva-slot-activate-overlay{transition:none}}.card-canva-slot-play-icon{color:#111;background:#ffffffeb;border-radius:50%;justify-content:center;align-items:center;width:48px;height:48px;display:flex;box-shadow:0 2px 8px #00000040}.card-canva-slot-overlay-label{letter-spacing:.02em;text-shadow:0 1px 2px #00000080;font-size:12px;font-weight:600}.card-author-editor{max-width:720px}.card-author-editor-body{grid-template-columns:minmax(200px,1fr) minmax(260px,1fr);gap:16px;display:grid}@media (max-width:640px){.card-author-editor-body{grid-template-columns:1fr}}.card-author-section-title{color:var(--color-text-muted);justify-content:space-between;align-items:baseline;margin:0 0 8px;font-size:13px;font-weight:700;display:flex}.card-author-count{color:var(--color-text-faint);font-size:11px;font-weight:600}.card-author-student-list{border:1px solid var(--color-border);border-radius:var(--radius-card);max-height:320px;margin:0;padding:0;list-style:none;overflow-y:auto}.card-author-student-row{cursor:pointer;border-bottom:1px solid var(--color-border);align-items:center;gap:8px;padding:6px 10px;font-size:14px;display:flex}.card-author-student-row:last-child{border-bottom:none}.card-author-student-row.is-selected{background:var(--color-accent-tinted-bg)}.card-author-num{width:28px;color:var(--color-text-faint);text-align:right;font-size:12px;font-weight:600}.card-author-selected-list{flex-direction:column;gap:6px;margin:0 0 8px;padding:0;list-style:none;display:flex}.card-author-selected-row{background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-btn);align-items:center;gap:8px;padding:6px 10px;display:flex}.card-author-primary-badge{text-align:center;width:24px;color:var(--color-text-muted);font-size:12px}.card-author-name-input{border:1px solid var(--color-border);border-radius:var(--radius-btn);background:var(--color-surface);flex:1;padding:6px 10px;font-family:inherit;font-size:14px}.card-author-row-actions{gap:6px;display:flex}.card-author-row-actions button{border:1px solid var(--color-border);border-radius:var(--radius-btn);width:32px;height:32px;color:var(--color-text-muted);cursor:pointer;background:0 0;padding:0;font-size:14px}@media (pointer:coarse){.card-author-row-actions button{width:var(--tap-min);height:var(--tap-min)}.card-author-student-row{min-height:var(--tap-min)}}.card-author-row-actions button:disabled{opacity:.3;cursor:not-allowed}.card-author-row-remove{color:var(--color-danger)!important}.card-author-add-freeform{border:1px dashed var(--color-border);border-radius:var(--radius-btn);width:100%;color:var(--color-text-muted);cursor:pointer;background:0 0;padding:8px;font-family:inherit;font-size:13px}.card-author-add-freeform:disabled{opacity:.4;cursor:not-allowed}.card-author-loading,.card-author-empty{color:var(--color-text-muted);text-align:center;padding:12px;font-size:13px}.card-author-error{color:var(--color-danger);padding:8px 0;font-size:13px}.card-author-save-error{background:var(--color-status-returned-bg);border-radius:var(--radius-btn);margin-top:8px;padding:8px 12px}.card-detail-edit-authors{border:1px solid var(--color-border);border-radius:var(--radius-btn);color:var(--color-text-muted);cursor:pointer;background:0 0;margin-top:10px;padding:6px 12px;font-family:inherit;font-size:13px}.card-detail-edit-authors:hover{color:var(--color-text);border-color:var(--color-border-hover)}.card-canva-slot-placeholder{color:var(--color-text);background:#fff;justify-content:center;align-items:center;width:100%;height:100%;display:flex;position:absolute;inset:0}.card-canva-slot-placeholder-label{letter-spacing:.2px;opacity:.92;text-shadow:0 1px 3px #0003;font-size:15px;font-weight:700}
.modal-backdrop{z-index:100;background:#0006;justify-content:center;align-items:center;padding:32px 16px;animation:.15s fadeIn;display:flex;position:fixed;inset:0;overflow-y:auto}.add-card-modal{width:520px;max-width:var(--modal-max);background:var(--color-surface);border:var(--border-card);border-radius:var(--radius-card);z-index:101;max-height:calc(100dvh - 64px);animation:.2s modalIn;position:fixed;top:50%;left:50%;overflow-y:auto;transform:translate(-50%,-50%);box-shadow:0 24px 80px #0000002e,0 8px 24px #0000001a}.card-detail-modal{width:min(1400px,100vw - 48px);max-width:calc(100vw - 48px);height:calc(100dvh - 48px);max-height:calc(100dvh - 48px);padding:0;overflow:hidden}.card-detail-close{z-index:5;position:absolute;top:20px;right:20px}.card-detail-fullscreen{z-index:3;border:1px solid var(--color-border,#e2e2ea);background:var(--color-surface,white);width:44px;height:44px;color:var(--color-text,#111);cursor:pointer;border-radius:50%;justify-content:center;align-items:center;padding:0;transition:transform .12s,box-shadow .12s;display:inline-flex;position:absolute;bottom:16px;right:16px;box-shadow:0 6px 16px #0000001a}.card-detail-fullscreen:hover{transform:scale(1.05);box-shadow:0 8px 20px #00000026}.card-detail-nav{z-index:3;border:1px solid var(--color-border,#e2e2ea);width:44px;height:64px;color:var(--color-text,#111);cursor:pointer;background:#ffffffeb;border-radius:8px;justify-content:center;align-items:center;padding:0;transition:transform .12s,box-shadow .12s;display:inline-flex;position:absolute;top:50%;transform:translateY(-50%);box-shadow:0 6px 16px #0000001a}.card-detail-nav:hover{transform:translateY(-50%)scale(1.05)}.card-detail-nav-prev{left:12px}.card-detail-nav-next{right:12px}.card-detail-indicator{z-index:4;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);pointer-events:auto;background:#14120fc7;border-radius:999px;justify-content:center;align-items:center;padding:8px 14px;display:flex;position:absolute;bottom:14px;left:50%;transform:translate(-50%);box-shadow:0 6px 16px #0000002e}.card-detail-indicator-dots{justify-content:center;align-items:center;gap:6px;display:flex}.card-detail-indicator-dot{cursor:pointer;background:#ffffff59;border:none;border-radius:50%;width:8px;height:8px;padding:0;transition:background .12s,transform .12s,width .16s}.card-detail-indicator-dot:hover{background:#fff9}.card-detail-indicator-dot.is-active{background:#fff;border-radius:4px;width:18px}.card-detail-modal[data-fullscreen=true]{border:none!important;border-radius:0!important;width:100vw!important;max-width:100vw!important;height:100vh!important;max-height:100vh!important;top:0!important;left:0!important;transform:none!important}.card-detail-modal[data-fullscreen=true] .card-detail-body{grid-template-columns:1fr}.card-detail-modal[data-fullscreen=true] .card-detail-rail,.card-detail-modal[data-fullscreen=true] .card-detail-nav,.card-detail-modal[data-fullscreen=true] .card-detail-indicator{display:none}.card-detail-modal[data-fullscreen=true] .card-detail-media .card-canva-slot-frame{min-height:100vh}.card-detail-modal[data-fullscreen=true] .card-detail-close,.card-detail-modal[data-fullscreen=true] .card-detail-fullscreen{opacity:0;transition:opacity .2s}.card-detail-modal[data-fullscreen=true]:hover .card-detail-close,.card-detail-modal[data-fullscreen=true]:hover .card-detail-fullscreen{opacity:1}.card-detail-body{grid-template-columns:1fr 280px;height:100%;min-height:0;display:grid;overflow:hidden}.card-detail-media{background:var(--color-surface);justify-content:center;align-items:center;min-width:0;min-height:0;padding:0;display:flex;position:relative;overflow:hidden}.card-detail-media-link{z-index:4;min-height:38px;color:var(--color-primary,#097fe8);background:#fffffff0;border:1px solid #ccdce8e6;border-radius:8px;justify-content:center;align-items:center;gap:6px;padding:8px 14px;font-size:13px;font-weight:700;line-height:1;text-decoration:none;display:inline-flex;position:absolute;bottom:24px;right:24px;box-shadow:0 10px 24px #0b1f2d2e}.card-detail-media-link:hover{border-color:var(--color-primary,#097fe8);background:#fff}.card-detail-media .card-attachments{background:var(--color-surface);flex:1;align-self:stretch;min-width:0;height:100%;padding:16px;overflow-y:auto}.card-detail-media .card-link-preview{border:1px solid var(--color-border);background:var(--color-surface);width:min(100%,980px);min-height:280px;box-shadow:var(--shadow-card);flex-direction:column;flex:none;justify-content:flex-start;align-items:stretch;margin:auto;display:flex;overflow:hidden}.card-detail-media .card-link-preview:hover{box-shadow:var(--shadow-card-hover)}.card-detail-media .card-link-preview-image{background:var(--color-bg);flex:auto;width:100%;height:auto;min-height:200px;max-height:none}.card-detail-media .card-link-preview-image img{object-fit:contain;background:var(--color-bg)}.card-detail-media .card-link-preview-body{border-top:1px solid var(--color-border);background:var(--color-surface);flex:none;padding:14px 16px;display:flex}.card-detail-media .card-link-preview-title{font-size:15px;line-height:1.35}.card-detail-media .card-link-preview-url{font-size:12px}.card-detail-media .card-attachment-image,.card-detail-media img:not(.emoji){object-fit:contain;object-position:center;width:100%;max-width:100%;height:100%;max-height:100%}.card-detail-media img.emoji{object-fit:initial;vertical-align:-.1em;width:1em;max-width:1em;height:1em;max-height:1em;display:inline-block}.card-detail-media .card-attachments{flex-direction:column;gap:12px;width:100%;height:100%;min-height:0;display:flex}.card-attach-carousel{flex:1;justify-content:center;align-self:stretch;align-items:center;width:100%;height:100%;min-height:0;display:flex;position:relative}.card-attach-carousel-viewport{justify-content:center;align-items:center;width:100%;height:100%;min-height:0;display:flex;position:relative;overflow:hidden}.card-attach-carousel-viewport>*{max-width:100%;max-height:100%}.card-attach-carousel-viewport .card-attach-image.is-detail{justify-content:center;align-items:center;width:100%;max-width:100%;height:100%;max-height:100%;display:flex}.card-attach-carousel-viewport .card-attach-image.is-detail img{object-fit:contain;object-position:center;width:100%;max-width:100%;height:100%;max-height:100%}.card-attach-carousel-viewport .card-attach-video{justify-content:center;align-items:center;width:100%;max-width:100%;max-height:100%;display:flex}.card-attach-carousel-viewport .card-attach-video iframe,.card-attach-carousel-viewport .card-attach-video video{aspect-ratio:16/9;object-fit:contain;width:100%;max-width:100%;max-height:100%}.card-attach-carousel-viewport .card-attach-file-wrap{color:#f5f5f5;background:#ffffff0d;border-radius:12px;padding:24px}.card-attach-carousel-arrow{color:#fff;cursor:pointer;z-index:3;-webkit-user-select:none;user-select:none;opacity:.55;text-shadow:0 1px 2px #0006;background:0 0;border:none;justify-content:center;align-items:center;padding:8px 12px;font-size:38px;line-height:1;transition:opacity .12s,transform .12s;display:flex;position:absolute;top:50%;transform:translateY(-50%)}.card-attach-carousel-arrow:hover{opacity:1;transform:translateY(-50%)scale(1.15)}.card-attach-carousel-arrow-prev{left:12px}.card-attach-carousel-arrow-next{right:12px}.card-attach-carousel-indicator{z-index:3;pointer-events:none;justify-content:center;align-items:center;display:flex;position:absolute;bottom:12px;left:0;right:0}.card-attach-carousel-dots{pointer-events:auto;background:#00000073;border-radius:999px;align-items:center;gap:6px;padding:6px 12px;display:inline-flex}.card-attach-carousel-dot{cursor:pointer;background:#fff6;border:none;border-radius:50%;width:7px;height:7px;padding:0;transition:background .12s,transform .12s}.card-attach-carousel-dot.is-active{background:#fff;transform:scale(1.15)}.card-attach-image.is-detail{background:0 0;flex:none;justify-content:center;width:100%;max-height:none;display:flex;position:relative}.card-attach-image.is-detail img{object-fit:contain;border-radius:8px;width:auto;max-width:100%;height:auto;max-height:70vh;display:block}.card-attach-image.is-detail img.is-clickable{cursor:zoom-in;transition:transform .12s ease-out}.card-attach-image.is-detail img.is-clickable:hover{transform:scale(1.01)}.card-detail-media .card-attach-file,.card-detail-media .card-attach-file-wrap{flex:none;width:100%}.card-detail-media .card-attach-video{background:var(--color-surface);flex:none;justify-content:center;width:100%;max-height:100%;display:flex}.card-detail-media .card-attach-video>iframe,.card-detail-media .card-attach-video>video{aspect-ratio:auto 16/9;object-fit:contain;background:var(--color-surface);border-radius:8px;width:100%;height:auto;max-height:100%}.card-detail-media .card-attach-video>video{max-height:70vh}.card-image-lightbox{z-index:100;background:#000000eb;justify-content:center;align-items:center;padding:32px;display:flex;position:fixed;inset:0}.card-image-lightbox-img{object-fit:contain;-webkit-user-select:none;user-select:none;-webkit-user-drag:none;width:auto;max-width:100%;height:auto;max-height:100%}.card-image-lightbox-close,.card-image-lightbox-nav{color:#fff;cursor:pointer;background:#ffffff1a;border:none;border-radius:50%;justify-content:center;align-items:center;width:44px;height:44px;font-size:22px;transition:background .12s;display:flex;position:absolute}.card-image-lightbox-close:hover,.card-image-lightbox-nav:hover{background:#ffffff40}.card-image-lightbox-close{top:16px;right:16px}.card-image-lightbox-nav.is-prev{top:50%;left:16px;transform:translateY(-50%)}.card-image-lightbox-nav.is-next{top:50%;right:16px;transform:translateY(-50%)}.card-image-lightbox-counter{color:#ffffffd9;font-variant-numeric:tabular-nums;background:#0006;border-radius:999px;padding:4px 12px;font-size:13px;position:absolute;bottom:16px;left:50%;transform:translate(-50%)}.card-detail-media .optimized-img-wrap,.card-detail-media .card-link-preview-image{width:100%;position:relative}.card-detail-media .card-link-preview-image.optimized-img-wrap{flex:auto;height:auto;min-height:0;max-height:none}.card-detail-media .card-canva-slot{flex-direction:column;width:100%;height:100%;margin-bottom:0;display:flex}.card-detail-media .card-canva-slot-frame{flex:auto;width:100%;height:auto;min-height:60vh;padding-bottom:0}.card-detail-media .card-canva-slot-iframe,.card-detail-media .card-canva-slot-thumbnail{width:100%;height:100%;position:absolute;inset:0}.card-detail-main{background:var(--color-surface);flex-direction:column;min-width:0;height:100%;min-height:0;display:flex}.card-detail-media{aspect-ratio:16/9;flex:none;width:100%;min-height:0;max-height:70%}.card-detail-content-zone{background:var(--color-surface);border-top:1px solid var(--color-border);flex-direction:column;flex:auto;gap:12px;min-height:0;padding:16px 24px 20px;display:flex;overflow-y:auto}.card-detail-body-text{flex-direction:column;gap:12px;display:flex}.card-detail-rail{border-left:1px solid var(--color-border);background:var(--color-surface);flex-direction:column;gap:16px;min-height:0;padding:24px 16px 20px;display:flex;overflow-y:auto}.card-detail-title{font-family:var(--font-display);color:var(--color-text);flex-shrink:0;margin:0;font-weight:700}.card-detail-file-list{flex-shrink:0;margin:0;padding:0;list-style:none}.card-detail-content{white-space:pre-wrap;color:var(--color-text);flex:1;min-height:0;margin:0;overflow-y:auto}.card-detail-content-title,.card-detail-link-title,.card-detail-link-desc{flex-shrink:0}.card-detail-meta{flex-direction:column;flex-shrink:0;gap:8px;font-size:15px;line-height:1.5;display:flex}.add-card-author-picker{grid-template-columns:minmax(200px,1fr) minmax(260px,1fr);gap:16px;display:grid}.add-card-author-picker .card-author-roster,.add-card-author-picker .card-author-selected{min-width:0}.add-card-author-picker[data-has-roster=false]{grid-template-columns:1fr}@media (max-width:640px){.add-card-author-picker{grid-template-columns:1fr}}.card-detail-link{color:var(--color-primary,#097fe8);border:1px solid var(--color-border);border-radius:6px;align-self:flex-start;padding:6px 10px;font-size:.875rem;text-decoration:none}.card-detail-link:hover{border-color:var(--color-border-hover)}.card-detail-modal[data-detail-layout=media-meta] .card-detail-content-zone,.card-detail-modal[data-has-body=false][data-has-media=true] .card-detail-content-zone{display:none}.card-detail-modal[data-detail-layout=media-meta] .card-detail-main,.card-detail-modal[data-has-body=false][data-has-media=true] .card-detail-main{max-width:100%}@media (orientation:portrait),(max-width:1199px){.card-detail-modal[data-detail-layout=media-meta] .card-detail-body,.card-detail-modal[data-has-body=false][data-has-media=true] .card-detail-body{grid-template-rows:1fr auto;grid-template-columns:1fr}}.card-detail-modal[data-detail-layout=text-meta] .card-detail-body,.card-detail-modal[data-has-media=false] .card-detail-body{grid-template-columns:1fr 280px}.card-detail-modal[data-detail-layout=text-meta] .card-detail-main,.card-detail-modal[data-has-media=false] .card-detail-main{display:flex}.card-detail-modal[data-detail-layout=text-meta],.card-detail-modal[data-has-media=false]{width:min(900px,100vw - 48px);height:auto;max-height:calc(100dvh - 48px);overflow-y:auto}.card-detail-modal[data-detail-layout=text-meta] .card-detail-content-zone,.card-detail-modal[data-has-media=false] .card-detail-content-zone{border-top:none}@media (orientation:portrait),(max-width:1199px){.card-detail-modal[data-detail-layout=text-meta] .card-detail-body,.card-detail-modal[data-has-media=false] .card-detail-body{grid-template-rows:auto auto;grid-template-columns:1fr}.card-detail-body{grid-template-rows:55dvh auto;grid-template-columns:1fr}.card-detail-rail{border-left:0;border-top:1px solid var(--color-border);overflow-y:auto}}@media (orientation:portrait) and (max-width:640px){.card-detail-body{grid-template-rows:45dvh 1fr}}.padlet-card.is-clickable,.stream-card.is-clickable,.grid-card.is-clickable,.column-card.is-clickable{cursor:pointer;outline-offset:2px}.padlet-card.is-clickable:focus-visible,.stream-card.is-clickable:focus-visible,.grid-card.is-clickable:focus-visible,.column-card.is-clickable:focus-visible{outline:2px solid var(--color-primary,#097fe8)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes modalIn{0%{opacity:0;transform:translate(-50%,-48%)}to{opacity:1;transform:translate(-50%,-50%)}}.modal-header{justify-content:space-between;align-items:center;padding:20px 24px 0;display:flex}.modal-title{font-family:var(--font-display);letter-spacing:-.3px;margin:0;font-size:20px;font-weight:700}.modal-close{border:1px solid var(--color-border);border-radius:var(--radius-control);cursor:pointer;width:36px;height:36px;color:var(--color-text-muted);transition:background var(--t-normal), border-color var(--t-normal), box-shadow var(--t-normal), color var(--t-normal);background:#ffffffd1;justify-content:center;align-items:center;padding:0;font-size:0;display:inline-flex;position:relative;box-shadow:0 4px 12px #184a5c14}.modal-close:before,.modal-close:after{content:"";background:currentColor;border-radius:999px;width:15px;height:2px;position:absolute}.modal-close:before{transform:rotate(45deg)}.modal-close:after{transform:rotate(-45deg)}@media (pointer:coarse){.modal-close{width:var(--tap-min);height:var(--tap-min)}}.modal-close:hover{border-color:var(--color-border-hover);color:var(--color-text);box-shadow:var(--shadow-lift);background:#fff}.card-detail-modal>.card-detail-close.card-detail-close{z-index:5;position:absolute;top:20px;right:20px}.modal-tabs{gap:4px;padding:16px 24px 0;display:flex}.modal-tab{font-family:var(--font-body);color:var(--color-text-muted);cursor:pointer;border-radius:var(--radius-btn);background:0 0;border:none;padding:8px 16px;font-size:13px;font-weight:500;transition:background .15s,color .15s}.modal-tab:hover{background:var(--color-surface-alt);color:var(--color-text)}.modal-tab-active{background:var(--color-accent-tinted-bg);color:var(--color-accent)}.modal-body{flex-direction:column;gap:12px;padding:16px 24px 24px;display:flex}.modal-input{font-family:var(--font-body);border:1px solid var(--color-border);color:var(--color-text);background:var(--color-bg);border-radius:8px;outline:none;width:100%;padding:10px 14px;font-size:14px;transition:border-color .15s}.modal-input:focus{border-color:var(--color-accent)}.modal-textarea{font-family:var(--font-body);border:1px solid var(--color-border);color:var(--color-text);background:var(--color-bg);resize:vertical;border-radius:8px;outline:none;width:100%;min-height:72px;padding:10px 14px;font-size:14px;transition:border-color .15s}.modal-textarea:focus{border-color:var(--color-accent)}.modal-link-promote{border:1px solid var(--color-border);background:var(--color-accent-tinted-bg);color:var(--color-accent);font-family:var(--font-body);cursor:pointer;border-radius:999px;align-self:flex-start;margin-top:-4px;padding:6px 10px;font-size:12px;font-weight:600;transition:border-color .15s,background .15s}.modal-link-promote:hover{border-color:var(--color-accent);background:var(--color-bg)}.modal-media-section{flex-direction:column;gap:12px;display:flex}.modal-preview{border:1px solid var(--color-border);background:var(--color-bg);border-radius:8px;overflow:hidden}.modal-preview-img{object-fit:cover;width:100%;max-height:240px;display:block}.modal-preview-video{aspect-ratio:16/9;border:none;width:100%;display:block}.modal-link-preview{background:var(--color-bg);border:1px solid var(--color-border);border-radius:8px;align-items:center;gap:8px;padding:10px 14px;display:flex}.modal-link-icon{font-size:16px}.modal-link-domain{color:var(--color-accent);font-size:13px;font-weight:500}.modal-attach-bar{flex-wrap:wrap;gap:8px;display:flex}.modal-attach-btn{border:1px solid var(--color-border);border-radius:var(--radius-pill);background:var(--color-surface);color:var(--color-text-muted);font-family:var(--font-body);cursor:pointer;align-items:center;gap:6px;padding:7px 14px;font-size:13px;font-weight:500;transition:border-color .15s,background .15s,color .15s;display:inline-flex}.modal-attach-btn:hover{border-color:var(--color-border-hover);color:var(--color-text)}.modal-attach-btn-active{border-color:var(--color-accent);background:var(--color-accent-tinted-bg);color:var(--color-accent)}.modal-attach-section{transform-origin:top;animation:.15s attachIn}@keyframes attachIn{0%{opacity:0;transform:scaleY(.8)translateZ(0)}to{opacity:1;transform:scaleY(1)translateZ(0)}}.modal-color-section{flex-direction:column;gap:8px;display:flex}.modal-color-label{color:var(--color-text-muted);letter-spacing:.2px;font-size:12px;font-weight:600}.modal-color-row{flex-wrap:wrap;gap:6px;display:flex}.modal-color-btn{border:2px solid var(--color-border);cursor:pointer;width:28px;height:28px;color:var(--color-text-muted);border-radius:50%;justify-content:center;align-items:center;padding:0;font-size:12px;transition:border-color .15s,transform .15s;display:flex}.modal-color-btn:hover{border-color:var(--color-border-hover);transform:scale(1.1)}.modal-color-btn-active{border-color:var(--color-accent);border-width:2.5px}.modal-actions{justify-content:flex-end;gap:10px;margin-top:8px;display:flex}.modal-btn-cancel{border:1px solid var(--color-border);background:var(--color-surface);color:var(--color-text);font-family:var(--font-body);cursor:pointer;border-radius:8px;padding:9px 20px;font-size:14px;font-weight:500;transition:background .15s}.modal-btn-cancel:hover:not(:disabled){background:var(--color-surface-alt)}.modal-btn-submit{background:var(--color-accent);color:#fff;font-family:var(--font-body);cursor:pointer;border:none;border-radius:8px;padding:9px 24px;font-size:14px;font-weight:600;transition:background .16s}.modal-btn-submit:hover:not(:disabled){background:var(--color-accent-active)}.modal-btn-submit:disabled,.modal-btn-cancel:disabled{opacity:.5;cursor:not-allowed}.link-preview-loading{color:var(--color-text-faint);padding:8px 0;font-size:12px}.link-preview-card{border:1px solid var(--color-border);border-radius:8px;overflow:hidden}.link-preview-card-image{background:var(--color-bg);max-height:160px;overflow:hidden}.link-preview-card-image img{object-fit:cover;width:100%;display:block}.link-preview-card-body{padding:10px 12px}.link-preview-card-title{color:var(--color-text);margin-bottom:4px;font-size:14px;font-weight:600}.link-preview-card-desc{color:var(--color-text-muted);-webkit-line-clamp:3;-webkit-box-orient:vertical;font-size:12px;display:-webkit-box;overflow:hidden}.modal-file-drop{border:2px dashed var(--color-border);color:var(--color-text-muted);cursor:pointer;border-radius:10px;flex-direction:column;justify-content:center;align-items:center;gap:8px;padding:24px 16px;font-size:13px;transition:border-color .15s,background .15s;display:flex}.modal-file-drop:hover,.modal-file-drop.drag-over{border-color:var(--color-accent);background:var(--color-accent-tinted-bg)}.modal-file-drop-icon{font-size:28px}.modal-file-preview{border:1px solid var(--color-border);border-radius:10px;position:relative;overflow:hidden}.modal-file-preview .modal-preview-img{object-fit:cover;width:100%;max-height:200px;display:block}.modal-preview-video-file{background:#000;width:100%;max-height:200px;display:block}.modal-file-remove{color:#fff;border-radius:var(--radius-pill);min-height:30px;font-family:var(--font-body);cursor:pointer;background:#18313fb8;border:none;padding:5px 12px;font-size:12px;font-weight:600;line-height:1;transition:background .15s,opacity .15s,transform .15s;position:absolute;top:8px;right:8px;box-shadow:0 4px 12px #00000029}.modal-file-remove:hover:not(:disabled){background:var(--color-danger,#c62828)}.modal-file-remove:active:not(:disabled){transform:scale(.97)}.modal-file-remove:disabled{opacity:.55;cursor:not-allowed}.modal-preview-img-clickable-wrap{cursor:pointer;outline-offset:3px;height:100%;transition:filter .15s;display:block;position:relative}@media (hover:hover) and (pointer:fine){.modal-preview-img-clickable-wrap:hover:not(.is-uploading){filter:brightness(.88)}}.modal-preview-img-clickable-wrap:focus-visible{outline:2px solid var(--color-accent)}.modal-preview-img-clickable-wrap:active:not(.is-uploading){filter:brightness(.82)}.modal-preview-img-clickable-wrap.is-uploading{cursor:wait}.modal-file-uploading-overlay{color:#fff;letter-spacing:.01em;pointer-events:none;background:#18313f8a;justify-content:center;align-items:center;font-size:13px;font-weight:700;line-height:1.2;display:flex;position:absolute;inset:0}.modal-file-preview-actions{z-index:1;justify-content:center;align-items:center;gap:6px;display:flex;position:absolute;bottom:8px;left:50%;transform:translate(-50%)}.modal-file-replace{background:var(--color-accent);color:#fff;border-radius:var(--radius-pill);min-height:30px;font-family:var(--font-body);cursor:pointer;border:none;padding:5px 13px;font-size:12px;font-weight:700;line-height:1;transition:background .15s,opacity .15s,transform .15s;box-shadow:0 4px 12px #00000029}.modal-file-replace:hover:not(:disabled){background:var(--color-accent-active)}.modal-file-replace:active:not(:disabled){transform:scale(.97)}.modal-file-replace:disabled{opacity:.7;cursor:wait}@media (pointer:coarse){.modal-file-replace,.modal-file-remove{min-height:var(--tap-min);padding-inline:16px}.modal-file-preview-actions{bottom:10px}}.modal-file-drop-hint{color:var(--color-text-faint);margin-top:2px;font-size:11px}.modal-file-preview-file{background:var(--color-surface-alt);border:1px solid var(--color-border);border-radius:10px;align-items:center;gap:12px;min-width:0;padding:12px 14px;display:flex;position:static;overflow:visible}.modal-file-preview-icon{flex:none;font-size:28px;line-height:1}.modal-file-preview-body{flex-direction:column;flex:auto;gap:2px;min-width:0;display:flex}.modal-file-preview-name{color:var(--color-text);text-overflow:ellipsis;white-space:nowrap;font-size:14px;font-weight:600;overflow:hidden}.modal-file-preview-meta{color:var(--color-text-muted);font-size:12px}.modal-file-preview-file .modal-file-remove{color:var(--color-danger);border:1px solid var(--color-border);background:0 0;flex:none;padding:6px 12px;position:static}.modal-file-preview-file .modal-file-remove:hover{background:var(--color-danger);color:#fff;border-color:var(--color-danger)}.modal-attach-notice{color:var(--color-text-muted);margin:4px 0 0;font-size:12px}.modal-attach-list{flex-direction:column;gap:8px;margin-bottom:10px;display:flex}.modal-attach-list:empty{display:none}.modal-attach-list-item{border:1px solid var(--color-border);border-radius:8px;position:relative;overflow:hidden}.modal-attach-list-item-image{background:var(--color-bg);justify-content:center;display:flex}.modal-attach-image-preview{width:auto;max-width:100%;height:auto;max-height:220px;display:block}.modal-attach-list-item-video video{background:#000;width:100%;max-height:160px;display:block}.modal-attach-item-remove{color:#fff;cursor:pointer;background:#0009;border:none;border-radius:50%;justify-content:center;align-items:center;width:28px;height:28px;font-size:18px;line-height:1;transition:background .12s;display:flex;position:absolute;top:6px;right:6px}.modal-attach-item-remove:hover{background:#000c}.modal-file-drop.is-disabled{opacity:.5;pointer-events:none}.modal-attach-reorder{flex:none;gap:2px;display:flex}.modal-attach-reorder-btn{border:1px solid var(--color-border);background:var(--color-surface);width:24px;height:24px;color:var(--color-text);cursor:pointer;border-radius:4px;justify-content:center;align-items:center;padding:0;font-size:12px;line-height:1;transition:background .12s,border-color .12s;display:flex}.modal-attach-reorder-btn:not(:disabled):hover{background:var(--color-surface-alt);border-color:var(--color-border-hover)}.modal-attach-reorder-btn:disabled{opacity:.3;cursor:not-allowed}.modal-attach-reorder-overlay{background:#ffffffe6;border-radius:6px;padding:2px;position:absolute;top:6px;left:6px}.modal-field-label{color:var(--color-text-muted);letter-spacing:.2px;margin-top:4px;font-size:12px;font-weight:600}.modal-select{font-family:var(--font-body);min-height:var(--tap-min);border:1px solid var(--color-border);border-radius:var(--radius-control);color:var(--color-text);cursor:pointer;transition:border-color var(--t-normal), box-shadow var(--t-normal), background var(--t-normal);appearance:none;padding:10px 14px;background-color:#fff;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' fill='none' stroke='%23615d59' stroke-width='2' stroke-linecap='round'%3E%3Cpath d='M2 4l4 4 4-4'/%3E%3C/svg%3E");background-position:right 12px center;background-repeat:no-repeat;outline:none;width:100%;padding-right:36px;font-size:14px}.modal-select:focus{border-color:var(--color-accent);box-shadow:0 0 0 3px #1683c724}@media (pointer:coarse){.modal-select{padding:12px 40px 12px 14px;font-size:16px}}
.grid-board{grid-template-columns:repeat(auto-fill,minmax(260px,1fr));align-items:start;gap:20px;padding:0;display:grid}.freeform-board{grid-template-columns:repeat(auto-fill,minmax(238px,238px));justify-content:start}.freeform-board .board-empty-inline{grid-column:1/-1}.grid-card{background:var(--color-surface);color:var(--color-text);border:var(--border-card);border-radius:var(--radius-card);box-shadow:var(--shadow-card);align-self:start;min-height:140px;padding:20px;transition:box-shadow .18s,border-color .18s;position:relative}.grid-card:hover{box-shadow:var(--shadow-card-hover);border-color:var(--color-border-hover)}.grid-card:hover .padlet-card-delete{display:flex}@media (max-width:560px){.freeform-board{grid-template-columns:1fr}}.stream-board-wrap{overflow-y:auto}.stream-feed{flex-direction:column;gap:18px;width:min(100%,720px);margin:0 auto;display:flex}.stream-composer,.stream-post,.stream-empty{background:var(--color-surface);color:var(--color-text);border:1px solid var(--color-border);box-shadow:var(--shadow-card);border-radius:8px}.stream-composer{padding:16px}.stream-composer-modal{width:min(92vw,640px)}.stream-composer-modal .stream-composer{box-shadow:none;border:0;border-radius:0;padding:0}.stream-composer textarea{resize:vertical;width:100%;min-height:92px;color:var(--color-text);font:inherit;background:0 0;border:0;outline:0;line-height:1.6}.stream-composer-preview{gap:10px;margin-top:12px;display:grid}.stream-composer-attachment,.stream-composer-link{border:1px solid var(--color-border);background:var(--color-surface-alt);border-radius:8px;align-items:center;gap:12px;min-width:0;padding:8px;display:flex}.stream-composer-attachment img,.stream-composer-attachment video,.stream-composer-link img{object-fit:cover;background:var(--color-border);border-radius:6px;width:64px;height:64px}.stream-composer-attachment button{margin-left:auto}.stream-composer-link span,.stream-composer-file{gap:3px;min-width:0;font-size:13px;display:grid}.stream-composer-link strong,.stream-composer-link small,.stream-composer-file{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.stream-composer-actions{border-top:1px solid var(--color-border);align-items:center;gap:8px;margin-top:12px;padding-top:12px;display:flex}.stream-composer-actions button,.stream-comment-form button,.stream-post-menu-popover button{border:1px solid var(--color-border);background:var(--color-surface);color:var(--color-text);border-radius:var(--radius-btn);cursor:pointer;padding:8px 12px;font-weight:700}.stream-composer-actions button[type=submit],.stream-comment-form button{background:var(--color-primary);border-color:var(--color-primary);color:#fff;margin-left:auto}.stream-composer-actions button:disabled,.stream-comment-form button:disabled{cursor:not-allowed;opacity:.55}.stream-post{overflow:hidden}.stream-post-head{grid-template-columns:44px 1fr auto;align-items:center;gap:12px;padding:14px 16px;display:grid}.stream-avatar{color:#fff;border-radius:50%;place-items:center;width:44px;height:44px;font-weight:800;display:grid}.stream-author-copy{gap:2px;min-width:0;display:grid}.stream-author-copy strong,.stream-author-copy time{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.stream-author-copy time,.stream-link-host,.stream-comment-meta,.stream-comment-readonly,.stream-comment-error{color:var(--color-text-faint);font-size:12px}.stream-post-menu{position:relative}.stream-post-menu-toggle{width:34px;height:34px;color:var(--color-text-muted);cursor:pointer;background:0 0;border:0;border-radius:50%;font-size:22px;line-height:1}.stream-post-menu-toggle:hover,.stream-post-menu-toggle:focus-visible{background:var(--color-surface-alt)}.stream-post-menu-popover{z-index:5;border:1px solid var(--color-border);background:var(--color-surface);min-width:104px;box-shadow:var(--shadow-dropdown);border-radius:8px;padding:6px;position:absolute;top:calc(100% + 6px);right:0}.stream-post-menu-popover button{color:#b42318;width:100%}.stream-media{background:#0f172a;position:relative}.stream-media-strip{scroll-snap-type:x mandatory;scrollbar-width:none;display:flex;overflow-x:auto}.stream-media-strip::-webkit-scrollbar{display:none}.stream-media-slide{scroll-snap-align:center;aspect-ratio:4/3;background:#0f172a;flex:0 0 100%;place-items:center;margin:0;display:grid}.stream-media-slide img,.stream-media-slide video{object-fit:contain;width:100%;height:100%}.stream-media-nav{color:#fff;cursor:pointer;background:#0f172a9e;border:0;border-radius:50%;width:36px;height:36px;font-size:28px;line-height:1;position:absolute;top:50%;transform:translateY(-50%)}.stream-media-prev{left:12px}.stream-media-next{right:12px}.stream-media-indicators{justify-content:center;gap:6px;display:flex;position:absolute;bottom:12px;left:0;right:0}.stream-media-indicators button{cursor:pointer;background:#ffffff73;border:0;border-radius:50%;width:7px;height:7px;padding:0}.stream-media-indicators button.is-active{background:#fff}.stream-post-body{gap:12px;padding:14px 16px 8px;display:grid}.stream-post-body h2{margin:0;font-size:18px;line-height:1.35}.stream-post-body p{white-space:pre-wrap;margin:0;line-height:1.65}.stream-link-preview{border:1px solid var(--color-border);color:inherit;background:var(--color-surface-alt);border-radius:8px;grid-template-columns:120px 1fr;gap:12px;text-decoration:none;display:grid;overflow:hidden}.stream-link-preview.is-plain{grid-template-columns:1fr}.stream-link-image{background:var(--color-border);min-height:96px}.stream-link-image img{object-fit:cover;width:100%;height:100%;display:block}.stream-link-copy{align-content:center;gap:4px;min-width:0;padding:10px 12px;display:grid}.stream-link-copy strong,.stream-link-copy span:not(.stream-link-host){text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.stream-file-list{gap:8px;display:grid}.stream-engagement{padding:0 16px 16px}.stream-actions{border-top:1px solid var(--color-border);gap:8px;padding-top:10px;display:flex}.stream-action{color:var(--color-text-muted);border-radius:var(--radius-btn);cursor:pointer;background:0 0;border:0;align-items:center;gap:6px;padding:7px 9px;font-weight:700;display:inline-flex}.stream-action:hover,.stream-action:focus-visible{background:var(--color-surface-alt)}.stream-action.is-liked{color:#e11d48}.stream-comments{gap:10px;margin-top:8px;display:grid}.stream-comments-more{width:fit-content;color:var(--color-text-faint);font:inherit;cursor:pointer;background:0 0;border:0;padding:0;font-size:13px}.stream-comment-list{gap:8px;margin:0;padding:0;list-style:none;display:grid}.stream-comment{gap:3px;display:grid}.stream-comment-copy{align-items:baseline;gap:6px;display:flex}.stream-comment-author{flex:none;font-weight:800}.stream-comment-copy p{white-space:pre-wrap;margin:0;line-height:1.5}.stream-comment-meta{gap:8px;padding-left:2px;display:flex}.stream-comment-meta button{color:inherit;cursor:pointer;background:0 0;border:0;padding:0}.stream-comment-form{align-items:center;gap:8px;display:flex}.stream-comment-form input{border:1px solid var(--color-border);background:var(--color-surface);min-width:0;color:var(--color-text);border-radius:999px;flex:1;padding:10px 14px}.stream-empty{text-align:center;color:var(--color-text-faint);padding:40px 20px}@media (max-width:640px){.stream-feed{gap:12px}.stream-composer,.stream-post,.stream-empty{border-left:0;border-right:0;border-radius:0}.stream-link-preview{grid-template-columns:92px 1fr}.stream-composer-actions{flex-wrap:wrap}}.board-page:has(.board-canvas-wrap-columns){height:100dvh;overflow:hidden}.board-canvas-wrap-columns{flex-direction:column;height:100%;min-height:0;padding-bottom:16px;display:flex;overflow:hidden}.columns-scrollbar{z-index:40;background:0 0;border:0;height:14px;padding:0;display:none;position:fixed;bottom:0;left:0;right:0;overflow:auto hidden}.columns-scrollbar.is-visible{display:block}.columns-scrollbar-rail{height:1px}.columns-scroll-area{-webkit-overflow-scrolling:touch;scrollbar-width:none;flex:1;min-height:0;overflow:auto visible}.columns-scroll-area::-webkit-scrollbar{height:0}.columns-board{flex:1;align-items:stretch;gap:24px;width:max-content;min-width:max-content;height:100%;min-height:0;padding:0 32px 0 0;display:flex;overflow:visible}.columns-board:not(:has(.column-add-stack)):after{content:"";pointer-events:none;flex:0 0 clamp(96px,18vw,220px);height:1px}.column{min-width:312px;box-shadow:none;background:0 0;border:0;flex-direction:column;flex:0 0 312px;gap:10px;min-height:0;padding:0;display:flex;overflow:visible}.column-cards-active{background:var(--color-accent-tinted-bg);border-radius:calc(var(--radius-card) - 2px);outline:2px dashed var(--color-accent);outline-offset:-4px}.column-empty{text-align:center;color:var(--color-text-faint);border:2px dashed var(--color-border);background:#ffffffa8;border-radius:8px;padding:16px 14px;font-size:12px}.column-empty.is-drop-target{color:var(--color-accent);border-color:var(--color-accent);background:var(--color-accent-tinted-bg);font-weight:700;box-shadow:inset 0 0 0 2px #ffffffa6}.column-header{background:var(--color-surface);border:var(--border-card);border-radius:var(--radius-card);box-shadow:var(--shadow-card);z-index:2;align-items:center;gap:10px;padding:10px 14px;display:flex;position:sticky;top:0}.column-title{font-family:var(--font-display);letter-spacing:-.15px;color:var(--color-text);flex:1;margin:0;font-size:15px;font-weight:700}.column-count{color:var(--color-accent-tinted-text);background:var(--color-accent-tinted-bg);border-radius:var(--radius-pill);letter-spacing:.1px;padding:2px 8px;font-size:11px;font-weight:600}.column-pin-btn{border:1px solid var(--color-border);background:var(--color-surface);color:var(--color-text-muted);border-radius:var(--radius-pill);cursor:pointer;flex-shrink:0;padding:3px 8px;font-size:11px;font-weight:700}.column-pin-btn:hover,.column-pin-btn.is-pinned{color:var(--color-accent-tinted-text);background:var(--color-accent-tinted-bg);border-color:var(--color-accent)}.column-header .ctx-menu-wrap{flex-shrink:0}.column-header.is-section-draggable{cursor:grab}.column-header.is-section-draggable:active{cursor:grabbing}.column-header.is-section-dragging{opacity:.4}.column-cards-scroll{box-sizing:content-box;overscroll-behavior:contain;scrollbar-gutter:stable;scrollbar-width:thin;scrollbar-color:#4e514073 transparent;flex:1;width:calc(100% + 10px);min-height:56px;margin-right:-16px;padding:8px 6px 0 0;overflow-y:auto}.column-cards-scroll::-webkit-scrollbar{width:10px}.column-cards-scroll::-webkit-scrollbar-track{background:0 0}.column-cards-scroll::-webkit-scrollbar-thumb{background:#4e514073 padding-box content-box;border:3px solid #0000;border-radius:999px}.column-cards-scroll::-webkit-scrollbar-button{background:0 0;width:0;height:0;display:none}.column-cards-scroll::-webkit-scrollbar-corner{background:0 0;width:0;height:0;display:none}.column-cards{border-radius:0;flex-direction:column;gap:24px;width:100%;min-height:56px;padding:0 0 2px;transition:background .2s;display:flex}.column-card-drop-wrap{flex-direction:column;gap:0;display:flex}.column-card-drop-placeholder{opacity:0;flex:none;transition:height .18s cubic-bezier(.2,0,0,1),opacity .14s;position:relative;overflow:hidden}.is-gap-before .column-card-drop-placeholder:first-child,.is-gap-after .column-card-drop-placeholder:last-child{opacity:1}.column-drop-indicator{z-index:3;pointer-events:none;align-items:center;height:100%;min-height:18px;margin:0 8px;display:flex;position:relative}.column-drop-indicator-line{background:var(--color-accent);width:100%;height:4px;box-shadow:0 0 0 4px var(--color-accent-tinted-bg), 0 6px 16px #0075de38;border-radius:999px;transition:height .2s,box-shadow .2s;display:block}.is-gap-before .column-drop-indicator-line,.is-gap-after .column-drop-indicator-line{height:5px;box-shadow:0 0 0 6px var(--color-accent-tinted-bg), 0 6px 24px #0075de59}.column-drop-indicator-label{border-radius:var(--radius-pill);background:var(--color-accent);color:#fff;white-space:nowrap;padding:3px 8px;font-size:10px;font-weight:700;position:absolute;top:50%;right:8px;transform:translateY(-50%);box-shadow:0 4px 12px #0075de38}.column-card{box-sizing:border-box;background:var(--color-surface);border:var(--border-card);border-radius:var(--radius-card);width:100%;box-shadow:var(--shadow-card);cursor:grab;-webkit-user-select:none;user-select:none;flex:none;padding:13px 15px 15px;transition:box-shadow .15s,border-color .15s,opacity .15s;position:relative}.column-card.is-drop-preview{border-color:var(--color-accent);box-shadow:var(--shadow-card-hover), 0 0 0 2px var(--color-accent-tinted-bg)}.column-cards>.column-empty{box-sizing:border-box;width:100%}.column-card:hover{box-shadow:var(--shadow-card-hover);border-color:var(--color-border-hover)}.column-card>.padlet-card-delete{display:none!important}.column-card:active{cursor:grabbing;opacity:.85}.column-card.is-dragging{opacity:.5;transform:scale(.985)}.column-card .padlet-card-title{margin-bottom:6px;font-size:14px;font-weight:600}.column-card .padlet-card-content{--card-content-preview-lines:4;font-size:13px;line-height:1.45}.column-card .padlet-card-content.is-collapsed{max-height:5.8em}.column-card .card-attachments{border-radius:var(--radius-card) var(--radius-card) 0 0;margin:-13px -15px 12px}.column-card .card-attachments>:first-child,.column-card .card-attach-image,.column-card .card-attach-video,.column-card .card-link-preview,.column-card .card-canva-slot-frame,.column-card .card-attach-image.optimized-img-wrap,.column-card .card-link-preview-image.optimized-img-wrap{border-radius:var(--radius-card) var(--radius-card) 0 0!important;overflow:hidden!important}.column-card .card-attach-image.optimized-img-wrap img,.column-card .card-link-preview-image.optimized-img-wrap img,.column-card .card-canva-slot-thumbnail{border-radius:inherit}.column-card:has(.card-attachments){padding-top:0}.column-card:has(.card-attachments) .card-attachments{margin-top:0}.column-card:has(>.card-ctx-menu):has(.card-attachments){padding-top:0}.column-card .card-author-footer{margin-top:8px}.column-card .card-canva-slot{gap:4px}.column-card .card-canva-slot-header{min-height:18px}.column-card .card-canva-mode-badge{padding:2px 8px;font-size:10px}.column-card .card-canva-slot-overlay-label{font-size:11px}.column-card .card-canva-slot-play-icon{width:40px;height:40px}.column-card:has(.card-attachments):not(:has(.padlet-card-content:not(:empty))){padding-bottom:12px}.column-card:has(.padlet-card-content:empty):not(:has(.card-attachments)){padding-top:12px;padding-bottom:12px}.column-unsectioned{opacity:.6}.column-inline-add{z-index:2;border:1px dashed var(--color-border);color:var(--color-text-faint);font-family:var(--font-body);cursor:pointer;text-align:center;background:0 0;border-radius:8px;padding:9px 14px;font-size:13px;font-weight:600;transition:border-color .15s,color .15s,background .15s;position:sticky;top:60px}.column-inline-add:hover{border-color:var(--color-accent);color:var(--color-accent);background:var(--color-accent-tinted-bg)}.column-add-btn{border:2px dashed var(--color-border);border-radius:var(--radius-card);color:var(--color-text-faint);cursor:pointer;background:0 0;flex:none;align-self:flex-start;min-width:200px;min-height:48px;padding:14px 20px;font-size:14px;font-weight:500;transition:border-color .15s,color .15s}.column-add-btn:hover{border-color:var(--color-accent);color:var(--color-accent)}.column-add-btn-seed{border-color:var(--color-accent);color:var(--color-accent);background:var(--color-accent-tinted-bg)}.column-add-stack{flex-direction:column;flex:0 0 312px;align-self:flex-start;gap:8px;min-width:312px;display:flex}.column-add-stack>.column-add-btn{align-self:stretch;width:100%}.dj-board{box-sizing:border-box;flex-direction:column;gap:20px;width:100%;max-width:1300px;margin:0 auto;padding:24px 24px 48px;display:flex}.dj-board-header{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:16px;display:flex}.dj-board-header h1{letter-spacing:-.3px;color:var(--color-text);margin:0;font-size:22px;font-weight:700}.dj-board-subtitle{color:var(--color-text-muted);margin:4px 0 0;font-size:13px}.dj-header-actions{gap:8px;display:flex}.dj-header-btn{background:var(--color-surface);color:var(--color-text);border:1px solid var(--color-border);border-radius:var(--radius-btn);cursor:pointer;padding:8px 14px;font-size:13px;font-weight:500;transition:background .15s,border-color .15s}.dj-header-btn:hover{background:var(--color-surface-alt);border-color:var(--color-border-hover)}.dj-nowplaying{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-card);width:100%;box-shadow:var(--shadow-card);box-sizing:border-box;flex-direction:column;gap:16px;padding:24px;display:flex}.dj-nowplaying-label{letter-spacing:1px;color:var(--color-accent);font-size:11px;font-weight:700}.dj-nowplaying-body{grid-template-columns:240px 1fr;align-items:center;gap:20px;display:grid}.dj-thumb{object-fit:cover;background:var(--color-surface-alt);border-radius:6px;flex:none;width:96px;height:54px}.dj-thumb-lg{color:#fff;background:#fff;border-radius:8px;justify-content:center;align-items:center;width:240px;height:135px;font-size:40px;display:flex;box-shadow:0 4px 14px #8b79ff59}.dj-nowplaying-info{min-width:0}.dj-nowplaying-empty-card{min-height:216px}.dj-nowplaying-placeholder{background:var(--color-surface-alt);color:var(--color-accent);box-shadow:none}.dj-track-title{letter-spacing:-.3px;color:var(--color-text);margin:0 0 6px;font-size:20px;font-weight:700}.dj-track-meta{color:var(--color-text-muted);word-break:break-word;margin:0;font-size:13px}.dj-nowplaying-actions{flex-wrap:wrap;gap:10px;margin-top:14px;display:flex}.dj-play-btn{background:var(--color-accent);color:#fff;border-radius:var(--radius-pill);cursor:pointer;border:none;padding:10px 20px;font-size:14px;font-weight:600;transition:background .15s}.dj-play-btn:hover{background:var(--color-accent-active)}.dj-play-btn[aria-pressed=true]{color:var(--color-accent);outline:1px solid var(--color-accent);background:0 0}.dj-next-btn{color:var(--color-text);border:1px solid var(--color-border);border-radius:var(--radius-pill);cursor:pointer;background:0 0;padding:10px 16px;font-size:14px;font-weight:500;transition:background .15s,border-color .15s}.dj-next-btn:hover{background:var(--color-surface-alt);border-color:var(--color-border-hover)}.dj-player-wrap{aspect-ratio:16/9;background:#000;border-radius:8px;width:240px;overflow:hidden}.dj-player-iframe{border:0;width:100%;height:100%}.dj-layout{box-sizing:border-box;grid-template-columns:minmax(0,1fr) 320px;align-items:start;gap:24px;width:100%;display:grid}.dj-queue-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-card);min-width:0;box-shadow:var(--shadow-card);box-sizing:border-box;padding:16px}.dj-queue-title{letter-spacing:-.15px;color:var(--color-text);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:8px;margin:0 0 12px;font-size:15px;font-weight:700;display:flex}.dj-queue-hint{color:var(--color-text-muted);font-size:12px;font-weight:500}.dj-queue-list{flex-direction:column;gap:4px;margin:0;padding:0;list-style:none;display:flex}.dj-queue-item{cursor:grab;border-radius:8px;grid-template-columns:24px 56px 1fr auto;align-items:center;gap:12px;padding:10px;transition:background .15s;display:grid}.dj-queue-item:hover{background:var(--color-surface-alt)}.dj-queue-item.is-pending{background:#f59e0b0f}.dj-queue-item.is-dragging{opacity:.4}.dj-queue-item.is-drag-over{outline:2px dashed var(--color-accent);outline-offset:-2px}.dj-queue-item.dj-status-played{opacity:.55}.dj-rank{color:var(--color-text-muted);text-align:center;font-family:SF Mono,ui-monospace,monospace;font-size:13px;font-weight:600}.dj-tinythumb{object-fit:cover;color:#fff;background:#fff;border-radius:4px;justify-content:center;align-items:center;width:56px;height:42px;font-size:16px;display:flex}.dj-info{flex-direction:column;gap:2px;min-width:0;display:flex}.dj-item-info{flex:180px;min-width:0}.dj-track{letter-spacing:-.1px;white-space:nowrap;text-overflow:ellipsis;color:var(--color-text);font-size:14px;font-weight:600;overflow:hidden}.dj-sub{color:var(--color-text-muted);font-size:12px}.dj-pending-pill{border-radius:var(--radius-pill);color:#92610a;background:#fef3c7;align-items:center;gap:4px;margin-left:6px;padding:1px 8px;font-size:11px;font-weight:600;display:inline-flex}.dj-pending-pill .dj-dot{background:currentColor;border-radius:50%;width:6px;height:6px}.dj-controls{gap:4px;display:flex}.dj-ctrl{color:var(--color-text-muted);cursor:pointer;background:0 0;border:1px solid #0000;border-radius:4px;padding:4px 10px;font-family:inherit;font-size:12px;font-weight:500;transition:background .15s,border-color .15s,color .15s}.dj-ctrl:hover{background:var(--color-surface-alt);color:var(--color-text);border-color:var(--color-border)}.dj-ctrl.approve:hover{color:#27a35f;background:#27a35f14;border-color:#27a35f4d}.dj-ctrl.reject:hover{color:var(--color-danger);background:#c6282814;border-color:#c628284d}.dj-ctrl.restore:hover{color:var(--color-accent);border-color:var(--color-accent-tinted-bg);background:var(--color-accent-tinted-bg)}.dj-empty{text-align:center;color:var(--color-text-muted);padding:32px 16px;font-size:13px}.dj-side{flex-direction:column;gap:16px;min-width:0;display:flex}.dj-submit-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-card);box-shadow:var(--shadow-card);padding:20px}.dj-submit-title{color:var(--color-text);margin:0 0 12px;font-size:14px;font-weight:700}.dj-submit-input{border:1px solid var(--color-border);background:var(--color-surface);width:100%;color:var(--color-text);box-sizing:border-box;border-radius:6px;padding:10px 12px;font-family:inherit;font-size:14px}.dj-submit-input:focus-visible{outline:2px solid var(--color-accent-tinted-text);outline-offset:1px}.dj-submit-btn{background:var(--color-accent);color:#fff;border-radius:var(--radius-btn);cursor:pointer;border:none;width:100%;margin-top:10px;padding:10px 16px;font-size:14px;font-weight:600;transition:background .12s}.dj-submit-btn:hover{background:var(--color-accent-active)}.dj-submit-btn:disabled{background:var(--color-text-faint);cursor:not-allowed}.dj-submit-note{color:var(--color-text-muted);margin:10px 0 0;font-size:11px;line-height:1.5}.dj-submit-error{color:var(--color-status-returned-text);margin:10px 0 0;font-size:12px}.dj-ranking{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-card);box-shadow:var(--shadow-card);padding:20px}.dj-ranking-list{margin:0;padding:0;list-style:none}.dj-ranking-row{align-items:center;gap:10px;padding:6px 0;font-size:13px;display:flex}.dj-ranking-pos{width:22px;color:var(--color-text-muted);text-align:center;font-family:SF Mono,ui-monospace,monospace;font-weight:700}.dj-ranking-pos.top{color:#c9a227}.dj-ranking-avatar{width:22px;height:22px;color:var(--color-text);background:#00000014;border-radius:50%;justify-content:center;align-items:center;font-size:10px;font-weight:600;display:inline-flex}.dj-ranking-avatar.top{color:#fff;background:#c9a227}.dj-ranking-name{color:var(--color-text);text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0;overflow:hidden}.dj-ranking-count{font-variant-numeric:tabular-nums;color:var(--color-text-muted);font-weight:500}.dj-ranking-meta{color:var(--color-text-faint);margin:0 0 8px;font-size:11px}.dj-ranking-loading,.dj-ranking-empty{color:var(--color-text-faint);margin:8px 0 0;font-size:12px}.dj-ranking-thumb{object-fit:cover;background:var(--color-surface-alt);border-radius:3px;width:48px;height:27px}.dj-ranking-thumb-blank{display:inline-block}.dj-ranking-section{margin-bottom:16px}.dj-ranking-title{color:var(--color-text);margin:0 0 6px;font-size:14px;font-weight:700}.dj-ranking-rank{color:var(--color-text-faint);text-align:right;font-weight:700}.dj-ranking-tag{border-radius:var(--radius-pill);background:var(--color-accent-tinted-bg);color:var(--color-accent-tinted-text);margin-left:4px;padding:1px 6px;font-size:10px;font-weight:600;display:inline-block}.dj-item-actions{flex:none;gap:4px;display:flex}.dj-action-btn{border:1px solid var(--color-border);background:var(--color-surface);color:var(--color-text);cursor:pointer;border-radius:4px;padding:4px 10px;font-size:12px;transition:background .12s,border-color .12s}.dj-action-btn:hover{border-color:var(--color-border-hover)}.dj-action-reject,.dj-action-delete{color:var(--color-danger)}.dj-action-cancel-own{border:1px solid var(--color-border);color:var(--color-text-muted);cursor:pointer;background:0 0;border-radius:4px;padding:4px 10px;font-size:12px}.dj-drag-handle{cursor:grab;color:var(--color-text-faint);-webkit-user-select:none;user-select:none;flex:none;padding:4px;font-size:16px}.dj-status-pill{white-space:nowrap;border-radius:999px;flex:none;padding:2px 8px;font-size:11px;font-weight:600}.dj-status-pill-pending{color:var(--color-text-muted);background:#0000000d}.dj-status-pill-approved{background:var(--color-status-reviewed-bg);color:var(--color-status-reviewed-text)}.dj-status-pill-played{color:var(--color-text-faint);background:0 0}.dj-status-pill-rejected{background:var(--color-status-returned-bg);color:var(--color-status-returned-text)}.classroom-dj-panel{border:1px solid var(--color-border);background:var(--color-surface);border-radius:8px;margin-top:24px;padding:16px}.classroom-dj-panel h3{margin:0 0 8px;font-size:15px;font-weight:700}.dj-panel-desc{color:var(--color-text-muted);margin:0 0 12px;font-size:12px}.dj-panel-current{flex-wrap:wrap;align-items:center;gap:6px;margin-bottom:8px;padding:8px 0;display:flex}.dj-panel-label{color:var(--color-text-muted);font-size:12px}.dj-panel-chip{background:var(--color-accent-tinted-bg);color:var(--color-accent-tinted-text);border-radius:999px;padding:3px 10px;font-size:12px;font-weight:600}.dj-panel-error{color:var(--color-status-returned-text);margin:8px 0;font-size:12px}.dj-panel-loading{color:var(--color-text-faint);margin:0;font-size:12px}.dj-panel-students{flex-direction:column;gap:4px;margin:8px 0 0;padding:0;list-style:none;display:flex}.dj-panel-student-row{border-top:1px solid var(--color-border);justify-content:space-between;align-items:center;padding:6px 0;font-size:13px;display:flex}.dj-panel-toggle{border:1px solid var(--color-border);background:var(--color-surface);color:var(--color-text);cursor:pointer;border-radius:4px;padding:4px 10px;font-size:12px}.dj-panel-toggle.is-on{background:var(--color-accent);color:#fff;border-color:var(--color-accent)}.dj-played-stack{z-index:40;background:var(--color-surface);border-right:1px solid var(--color-border);flex-direction:column;width:320px;transition:transform .26s cubic-bezier(.32,.72,0,1);display:flex;position:fixed;top:0;bottom:0;left:0;transform:translate(-100%);box-shadow:8px 0 24px #00000014}.dj-played-stack.is-open{transform:translate(0)}.dj-played-head{border-bottom:1px solid var(--color-border);justify-content:space-between;align-items:flex-start;gap:12px;padding:16px 20px;display:flex}.dj-played-title{letter-spacing:-.15px;color:var(--color-text);margin:0;font-size:14px;font-weight:700}.dj-played-subtitle{color:var(--color-text-muted);margin-top:2px;font-size:11px}.dj-played-close{border:1px solid var(--color-border);border-radius:var(--radius-btn);width:32px;height:32px;color:var(--color-text-muted);cursor:pointer;background:0 0;justify-content:center;align-items:center;font-size:16px;display:inline-flex}.dj-played-close:hover{background:var(--color-surface-alt);color:var(--color-text)}.dj-played-list{flex-direction:column;flex:1;gap:4px;margin:0;padding:8px;list-style:none;display:flex;overflow-y:auto}.dj-played-item{cursor:grab;-webkit-user-select:none;user-select:none;border-radius:8px;grid-template-columns:44px 1fr auto;align-items:center;gap:10px;padding:8px 10px;transition:background .15s;animation:.3s dj-played-slide-in;display:grid}.dj-played-item:hover{background:var(--color-surface-alt)}.dj-played-item.is-dragging{opacity:.4}.dj-played-item .dj-track{font-size:13px}.dj-played-item .dj-sub{font-size:11px}.dj-played-thumb{object-fit:cover;color:#fff;background:#fff;border-radius:4px;justify-content:center;align-items:center;width:44px;height:34px;font-size:14px;display:flex}.dj-played-item-title{color:var(--color-text);white-space:nowrap;text-overflow:ellipsis;font-size:13px;font-weight:600;overflow:hidden}.dj-played-delete{width:28px;height:28px;color:var(--color-text-muted);cursor:pointer;background:0 0;border:1px solid #0000;border-radius:4px;justify-content:center;align-items:center;font-size:14px;display:inline-flex}.dj-played-delete:hover{color:var(--color-danger);background:#c6282814;border-color:#c628284d}.dj-played-foot{border-top:1px solid var(--color-border);color:var(--color-text-muted);text-align:center;padding:10px 20px;font-size:11px}.dj-played-backdrop{z-index:39;opacity:0;pointer-events:none;background:#0000001f;transition:opacity .2s;position:fixed;inset:0}.dj-played-backdrop.is-open{opacity:1;pointer-events:auto}@keyframes dj-played-slide-in{0%{opacity:0;transform:translate(-16px)}to{opacity:1;transform:translate(0)}}@media (prefers-reduced-motion:reduce){.dj-played-stack,.dj-played-item,.dj-queue-item,.dj-next-btn,.dj-play-btn,.dj-submit-btn,.dj-ctrl,.dj-action-btn{transition:none!important;animation:none!important}}@media (max-width:959px){.dj-layout{grid-template-columns:minmax(0,1fr)}.dj-side{order:2}.dj-nowplaying-body{grid-template-columns:1fr}.dj-thumb-lg{aspect-ratio:16/9;width:100%;max-width:360px;height:auto}.dj-played-stack{width:min(320px,85vw)}}@media (max-width:640px){.dj-board{padding:16px 12px 32px}.dj-mini-player.is-expanded{width:280px;bottom:12px;right:12px}}.dj-mini-player{z-index:2000;background:var(--color-surface);flex-direction:column;display:flex}.dj-mini-player.is-hidden{display:none}.dj-mini-player.is-docked{box-shadow:none;border:0;border-radius:8px;padding:0;overflow:hidden}.dj-mini-player.is-pip{border:1px solid var(--color-border);resize:none;-webkit-user-select:none;user-select:none;border-radius:10px;gap:6px;padding:8px;box-shadow:0 12px 32px #0000002e}.dj-mini-body{background:#000;border-radius:6px;flex:auto;width:100%;min-height:0;overflow:hidden}.dj-mini-player.is-docked .dj-mini-body{border-radius:8px;height:100%}.dj-mini-player.is-pip .dj-mini-body{aspect-ratio:16/9}.dj-mini-iframe{width:100%;height:100%}.dj-mini-iframe iframe{border:0;width:100%;height:100%}.dj-mini-header{cursor:grab;touch-action:none;align-items:center;gap:8px;padding:2px 4px;display:flex}.dj-mini-header:active{cursor:grabbing}.dj-mini-drag-hint{color:var(--color-text-faint);letter-spacing:-2px;flex:none;padding:0 2px;font-size:12px}.dj-mini-title{color:var(--color-text);text-overflow:ellipsis;white-space:nowrap;flex:auto;min-width:0;font-size:12px;font-weight:600;overflow:hidden}.dj-mini-actions{flex:none;gap:4px;display:flex}.dj-mini-btn{border:1px solid var(--color-border);cursor:pointer;color:var(--color-text);touch-action:manipulation;background:0 0;border-radius:4px;padding:3px 8px;font-size:11px}.dj-mini-btn:hover{background:var(--color-surface-alt)}.dj-mini-close{color:var(--color-danger)}.dj-mini-resize{z-index:3;touch-action:none;background:0 0;position:absolute}.dj-mini-resize-e{cursor:ew-resize;width:6px;top:8px;bottom:22px;right:0}.dj-mini-resize-s{cursor:ns-resize;height:6px;bottom:0;left:8px;right:22px}.dj-mini-resize-se{cursor:nwse-resize;opacity:.7;background:#fff;border-radius:0 0 8px;width:18px;height:18px;bottom:0;right:0}.dj-mini-resize-e:hover,.dj-mini-resize-s:hover{background:var(--color-accent-tinted-bg);opacity:.6}.dj-mini-resize-se:hover{opacity:1}.dj-mini-external-placeholder{background:var(--color-surface-alt);width:100%;height:100%;color:var(--color-text-muted);text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:8px;padding:16px;display:flex}.dj-mini-external-emoji{opacity:.7;font-size:40px}.dj-mini-external-title{color:var(--color-text);font-size:13px;font-weight:600}.dj-mini-player.is-pip{position:fixed}.dj-nowplaying-host{justify-content:center;align-items:center;display:flex;position:relative;overflow:hidden}.dj-nowplaying-host-img{object-fit:cover;border-radius:8px;width:100%;height:100%;display:block}.dj-nowplaying-host-fallback{color:#fff;font-size:48px}.dj-recap-backdrop{z-index:1000;background:#00000080;justify-content:center;align-items:center;padding:24px;display:flex;position:fixed;inset:0}.dj-recap-modal{background:var(--color-surface);border-radius:var(--radius-card);box-shadow:var(--shadow-card-hover);flex-direction:column;width:100%;max-width:860px;max-height:92vh;display:flex;overflow:hidden}.dj-recap-head{border-bottom:1px solid var(--color-border);justify-content:space-between;align-items:flex-start;gap:16px;padding:24px 28px 16px;display:flex}.dj-recap-eyebrow{letter-spacing:.5px;color:var(--color-accent);margin-bottom:4px;font-size:12px;font-weight:700}.dj-recap-title{color:var(--color-text);margin:0;font-size:22px;font-weight:700}.dj-recap-close{border:1px solid var(--color-border);border-radius:var(--radius-btn);width:36px;height:36px;color:var(--color-text-muted);cursor:pointer;background:0 0;font-size:18px}.dj-recap-close:hover{background:var(--color-surface-alt);color:var(--color-text)}.dj-recap-monthbar{border-bottom:1px solid var(--color-border);justify-content:center;align-items:center;gap:16px;padding:12px 28px;display:flex}.dj-recap-monthbtn{border:1px solid var(--color-border);border-radius:var(--radius-btn);color:var(--color-text-muted);cursor:pointer;background:0 0;padding:6px 12px;font-size:12px}.dj-recap-monthbtn:hover{background:var(--color-surface-alt);color:var(--color-text)}.dj-recap-monthbtn:disabled{opacity:.4;cursor:not-allowed}.dj-recap-monthpill{background:var(--color-accent-tinted-bg);color:var(--color-accent-tinted-text);border-radius:var(--radius-pill);padding:4px 16px;font-size:15px;font-weight:700}.dj-recap-body{flex-direction:column;gap:24px;padding:24px 28px;display:flex;overflow-y:auto}.dj-recap-empty{text-align:center;color:var(--color-text-muted);flex-direction:column;align-items:center;gap:12px;padding:64px 20px;display:flex}.dj-recap-stats{grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:12px;display:grid}.dj-recap-stat{background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-card);text-align:center;padding:16px}.dj-recap-stat-value{letter-spacing:-.5px;color:var(--color-text);font-size:32px;font-weight:700}.dj-recap-stat-unit{color:var(--color-text-muted);margin-left:4px;font-size:14px;font-weight:500}.dj-recap-stat-label{color:var(--color-text-muted);margin-top:4px;font-size:12px}.dj-recap-spotlight{grid-template-columns:1fr 1fr;gap:12px;display:grid}@media (max-width:640px){.dj-recap-spotlight{grid-template-columns:1fr}}.dj-recap-spot{border-radius:var(--radius-card);text-align:center;background:#fff;border:1px solid #c9a2274d;flex-direction:column;align-items:center;gap:8px;padding:20px;display:flex}.dj-recap-spot-dj{background:#fff;border-color:#0075de4d}.dj-recap-spot-label{letter-spacing:.5px;color:var(--color-text-muted);font-size:11px;font-weight:700}.dj-recap-spot-thumb{object-fit:cover;background:var(--color-surface-alt);width:120px;height:68px;color:var(--color-text-faint);border-radius:8px;justify-content:center;align-items:center;font-size:24px;display:flex}.dj-recap-spot-thumb-fallback{color:#fff;background:#fff}.dj-recap-spot-avatar{color:#fff;background:#c9a227;border-radius:50%;justify-content:center;align-items:center;width:72px;height:72px;font-size:28px;font-weight:700;display:flex}.dj-recap-spot-title{color:var(--color-text);white-space:nowrap;text-overflow:ellipsis;max-width:100%;font-size:15px;font-weight:700;overflow:hidden}.dj-recap-spot-meta{color:var(--color-text-muted);font-size:13px}.dj-recap-section{flex-direction:column;gap:10px;display:flex}.dj-recap-sectiontitle{color:var(--color-text);margin:0;font-size:14px;font-weight:700}.dj-recap-songlist{flex-direction:column;gap:4px;margin:0;padding:0;list-style:none;display:flex}.dj-recap-songrow{background:var(--color-bg);border-radius:8px;grid-template-columns:28px 56px 1fr auto;align-items:center;gap:12px;padding:8px 12px;display:grid}.dj-recap-pos{color:var(--color-text-muted);text-align:center;font-family:SF Mono,ui-monospace,monospace;font-size:13px;font-weight:700}.dj-recap-pos.top{color:#c9a227}.dj-recap-songthumb{object-fit:cover;background:var(--color-surface-alt);border-radius:4px;justify-content:center;align-items:center;width:56px;height:32px;font-size:14px;display:flex}.dj-recap-songinfo{min-width:0}.dj-recap-songtitle{color:var(--color-text);white-space:nowrap;text-overflow:ellipsis;font-size:14px;font-weight:600;overflow:hidden}.dj-recap-songsub{color:var(--color-text-muted);font-size:11px}.dj-recap-songplays{font-variant-numeric:tabular-nums;color:var(--color-accent);font-size:13px;font-weight:600}.dj-recap-ranking{margin:0;padding:0;list-style:none}.dj-recap-rankrow{align-items:center;gap:10px;padding:6px 0;display:flex}.dj-recap-avatar{width:28px;height:28px;color:var(--color-text);background:#00000014;border-radius:50%;justify-content:center;align-items:center;font-size:12px;font-weight:600;display:inline-flex}.dj-recap-avatar.top{color:#fff;background:#c9a227}.dj-recap-rankname{color:var(--color-text);flex:1;font-size:13px}.dj-recap-rankcount{color:var(--color-text-muted);font-variant-numeric:tabular-nums;font-size:12px}.dj-recap-bars{background:var(--color-bg);border-radius:8px;grid-auto-columns:minmax(4px,1fr);grid-auto-flow:column;align-items:end;gap:2px;height:80px;padding:12px;display:grid}.dj-recap-bar{background:0 0;flex-direction:column;justify-content:flex-end;height:100%;display:flex}.dj-recap-bar-fill{background:var(--color-accent);opacity:.8;border-radius:2px}.dj-recap-bar:hover .dj-recap-bar-fill{opacity:1}.dj-recap-bars-xaxis{color:var(--color-text-faint);justify-content:space-between;padding:0 4px;font-size:11px;display:flex}@media (max-width:768px){.board-canvas-wrap-columns{overflow-x:auto}.columns-board{gap:16px;width:max-content;min-width:max-content}.column,.column-add-stack{flex-basis:288px;min-width:288px}.column-cards-scroll{min-height:56px}}
.assign-board{max-width:var(--container-max-width);margin:0 auto}.assign-description{background:var(--color-accent-tinted-bg);border-radius:var(--radius-card);color:var(--color-text);border:1px solid #0075de26;margin-bottom:20px;padding:16px 20px;font-size:14px;line-height:1.6}.assign-progress{margin-bottom:24px}.assign-progress-text{color:var(--color-text);margin-bottom:8px;font-size:14px;font-weight:600;display:block}.assign-progress-bar{background:var(--color-surface-alt);border-radius:4px;height:8px;overflow:hidden}.assign-progress-fill{background:var(--color-accent);border-radius:4px;height:100%;transition:width .3s}.assign-card{background:var(--color-surface);border:var(--border-card);border-radius:var(--radius-card);box-shadow:var(--shadow-card);cursor:pointer;text-align:center;flex-direction:column;align-items:center;gap:8px;padding:20px 12px;transition:box-shadow .15s,border-color .15s,transform .15s;display:flex}.assign-card:hover{box-shadow:var(--shadow-card-hover);transform:translateY(-2px)}.assign-card-none{opacity:.5;cursor:default}.assign-card-none:hover{box-shadow:var(--shadow-card);transform:none}.assign-card-submitted{border-color:#1565c0}.assign-card-reviewed{border-color:#2e7d32}.assign-card-returned{border-color:#c62828}.assign-card-avatar{background:var(--color-accent-tinted-bg);width:48px;height:48px;color:var(--color-accent);border-radius:50%;justify-content:center;align-items:center;font-size:20px;font-weight:700;display:flex}.assign-card-name{color:var(--color-text);font-size:13px;font-weight:600}.assign-card-status{border-radius:var(--radius-pill);padding:3px 8px;font-size:11px;font-weight:600}.assign-card-status.status-submitted{color:#1565c0;background:#e3f2fd}.assign-card-status.status-reviewed{color:#2e7d32;background:#e8f5e9}.assign-card-status.status-returned{color:#c62828;background:#fce4ec}.assign-card-grade{color:var(--color-accent);font-size:14px;font-weight:700}.assign-student-view{max-width:600px;margin:0 auto}.assign-my-submission{background:var(--color-surface);border:var(--border-card);border-radius:var(--radius-card);box-shadow:var(--shadow-card);padding:24px}.assign-my-header{align-items:center;gap:10px;margin-bottom:16px;display:flex}.assign-badge-submitted{color:#1565c0;border-radius:var(--radius-pill);background:#e3f2fd;padding:4px 12px;font-size:12px;font-weight:600}.assign-badge-reviewed{color:#2e7d32;border-radius:var(--radius-pill);background:#e8f5e9;padding:4px 12px;font-size:12px;font-weight:600}.assign-badge-returned{color:#c62828;border-radius:var(--radius-pill);background:#fce4ec;padding:4px 12px;font-size:12px;font-weight:600}.assign-my-grade{color:var(--color-accent);font-size:16px;font-weight:700}.assign-my-content{color:var(--color-text);white-space:pre-wrap;margin-bottom:12px;font-size:14px;line-height:1.6}.assign-empty-state{text-align:center;background:var(--color-surface);border:var(--border-card);border-radius:var(--radius-card);box-shadow:var(--shadow-card);padding:60px 24px}.assign-empty-state p{color:var(--color-text-muted);margin:0 0 20px;font-size:15px}.assign-submit-btn-large{padding:14px 32px;font-size:16px}.assign-table-wrap{border:var(--border-card);border-radius:var(--radius-card);background:var(--color-surface);box-shadow:var(--shadow-card);overflow-x:auto}.assign-table{border-collapse:collapse;width:100%;font-size:14px}.assign-th-task,.assign-th-student{text-align:left;color:var(--color-text-muted);border-bottom:1px solid var(--color-border);background:var(--color-bg);white-space:nowrap;padding:14px 16px;font-size:13px;font-weight:600}.assign-th-student{text-align:center;min-width:100px}.assign-td-task{color:var(--color-text);border-bottom:1px solid var(--color-border);max-width:240px;padding:14px 16px;font-weight:600}.assign-td-status{text-align:center;border-bottom:1px solid var(--color-border);cursor:pointer;padding:10px 12px;transition:background .1s}.assign-td-status:hover{background:var(--color-surface-alt)}.assign-badge{border-radius:var(--radius-pill);padding:4px 10px;font-size:12px;font-weight:600;display:inline-block}.status-submitted .assign-badge,.assign-badge.status-submitted{color:#1565c0;background:#e3f2fd}.status-reviewed .assign-badge,.assign-badge.status-reviewed{color:#2e7d32;background:#e8f5e9}.status-returned .assign-badge,.assign-badge.status-returned{color:#c62828;background:#fce4ec}.status-none{cursor:default}.assign-badge-empty{color:var(--color-text-faint);font-size:12px}.assign-add-btn{border:2px dashed var(--color-border);border-radius:var(--radius-card);color:var(--color-text-faint);font-family:var(--font-body);cursor:pointer;background:0 0;width:100%;margin-top:20px;padding:12px 24px;font-size:14px;font-weight:500;transition:border-color .15s,color .15s}.assign-add-btn:hover{border-color:var(--color-accent);color:var(--color-accent)}.assign-student-list{flex-direction:column;gap:16px;display:flex}.assign-student-card{background:var(--color-surface);border:var(--border-card);border-radius:var(--radius-card);box-shadow:var(--shadow-card);padding:20px 24px}.assign-student-card-header{justify-content:space-between;align-items:center;margin-bottom:12px;display:flex}.assign-student-task-title{font-family:var(--font-display);margin:0;font-size:16px;font-weight:700}.assign-student-submission{border-top:1px solid var(--color-border);color:var(--color-text-muted);padding:12px 0;font-size:14px}.assign-student-submission p{margin:0 0 8px}.assign-link{color:var(--color-accent);word-break:break-all;font-size:13px;text-decoration:none;display:inline-block}.assign-link:hover{text-decoration:underline}.assign-feedback{background:var(--color-accent-tinted-bg);border-radius:6px;margin-top:8px;padding:8px 12px;font-size:13px}.assign-grade{color:var(--color-accent);margin-top:4px;font-size:13px;font-weight:600}.assign-submit-btn{background:var(--color-accent);color:#fff;border-radius:var(--radius-btn);font-family:var(--font-body);cursor:pointer;border:none;margin-top:12px;padding:8px 20px;font-size:13px;font-weight:600;transition:background .15s}.assign-submit-btn:hover{background:var(--color-accent-active)}.assign-view-meta{align-items:center;gap:8px;margin-bottom:8px;display:flex}.assign-view-content{background:var(--color-bg);border:1px solid var(--color-border);white-space:pre-wrap;border-radius:8px;min-height:60px;padding:12px;font-size:14px}.assign-board--teacher,.assign-board--student{max-width:var(--container-max-width);margin:0 auto;padding-bottom:32px}.assign-guide{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-card);margin-bottom:16px;padding:14px 18px}.assign-guide__label{color:var(--color-text-muted);letter-spacing:.125px;margin-bottom:6px;font-size:12px;font-weight:600}.assign-guide__body{white-space:pre-wrap;font-size:15px;line-height:1.5}.assign-inline-error{background:var(--color-status-returned-bg);color:var(--color-status-returned-text);border-radius:var(--radius-btn);margin-bottom:12px;padding:10px 14px;font-size:13px}.assign-grid{grid-template-columns:repeat(5,minmax(0,1fr));gap:12px;display:grid}.assign-board--matrix .assign-grid{grid-template-columns:1fr}.assign-grid__empty{text-align:center;background:var(--color-surface);border:1px dashed var(--color-border);border-radius:var(--radius-card);color:var(--color-text-muted);padding:32px}.assign-grid__empty-hint{color:var(--color-text-faint);margin-top:6px;font-size:13px}.assign-slot{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-card);cursor:pointer;text-align:left;color:inherit;flex-direction:column;gap:8px;padding:10px;font-family:inherit;transition:border-color 80ms;display:flex}.assign-slot:hover{border-color:var(--color-border-hover)}.assign-slot:disabled{opacity:.6;cursor:not-allowed}.assign-slot__head{justify-content:space-between;align-items:center;gap:6px;display:flex}.assign-slot__num{color:var(--color-text-muted);letter-spacing:.1px;font-size:11px;font-weight:600}.assign-slot__thumb{aspect-ratio:4/3;background:var(--color-slot-placeholder);border-radius:8px;justify-content:center;align-items:center;display:flex;position:relative;overflow:hidden}.assign-slot__img{object-fit:cover;width:100%;height:100%;display:block}.assign-slot__placeholder{color:var(--color-text-faint);font-size:24px;font-weight:700}.assign-slot__name{font-size:13px;font-weight:600}.assign-badge{border-radius:var(--radius-pill);letter-spacing:.125px;white-space:nowrap;align-items:center;padding:2px 8px;font-size:12px;font-weight:600;display:inline-flex}.assign-badge--assigned{background:var(--color-surface-alt);color:var(--color-text-muted)}.assign-badge--submitted,.assign-badge--viewed{background:var(--color-status-submitted-bg);color:var(--color-status-submitted-text)}.assign-badge--reviewed{background:var(--color-status-reviewed-bg);color:var(--color-status-reviewed-text)}.assign-badge--returned{background:var(--color-status-returned-bg);color:var(--color-status-returned-text)}.assign-badge--orphaned{background:var(--color-surface-alt);color:var(--color-text-faint)}.assign-return-banner{background:var(--color-status-returned-bg);border-radius:var(--radius-card);border:1px solid #ffcdd2;align-items:flex-start;gap:12px;margin-bottom:14px;padding:14px 18px;display:flex}.assign-return-banner__icon{color:var(--color-status-returned-text);font-size:20px;font-weight:700;line-height:1.1}.assign-return-banner__title{color:var(--color-status-returned-text);letter-spacing:.1px;margin-bottom:4px;font-size:13px;font-weight:700}.assign-return-banner__reason{color:var(--color-text);white-space:pre-wrap;font-size:15px;line-height:1.5}.assign-student{flex-direction:column;gap:12px;display:flex}.assign-student--empty{text-align:center;color:var(--color-text-muted);padding:40px}.assign-submit-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-card);box-shadow:var(--shadow-card);flex-direction:column;gap:12px;padding:24px;display:flex}.assign-submit-card__label{color:var(--color-text-muted);letter-spacing:0;margin-bottom:-4px;font-size:13px;font-weight:600}.assign-submit-card__textarea,.assign-submit-card__input{background:var(--color-bg-alt);border:1px solid var(--color-border);border-radius:var(--radius-btn);color:var(--color-text);resize:vertical;transition:border-color var(--t-normal), box-shadow var(--t-normal);outline:none;padding:12px 14px;font-family:inherit;font-size:15px;line-height:1.5}.assign-submit-card__textarea{min-height:120px}.assign-submit-card__textarea:focus,.assign-submit-card__input:focus{border-color:var(--color-accent);box-shadow:0 0 0 3px #0075de26}.assign-submit-status{color:var(--color-text-muted);align-items:center;gap:10px;margin:0 0 4px;font-size:13px;display:flex}.assign-submit-card__actions{align-items:center;gap:10px;display:flex}.assign-submit-card__note{color:var(--color-text-muted);font-size:12px}.assign-submit-card__error{color:var(--color-status-returned-text);font-size:13px}.assign-btn{border-radius:var(--radius-btn);cursor:pointer;border:1px solid #0000;padding:8px 16px;font-family:inherit;font-size:14px;font-weight:600}.assign-btn:disabled{opacity:.5;cursor:not-allowed}.assign-btn--primary{background:var(--color-accent);color:#fff}.assign-btn--primary:not(:disabled):hover{background:var(--color-accent-active)}.assign-btn--ghost{border-color:var(--color-border);color:var(--color-text-muted);background:0 0}.assign-btn--ghost:not(:disabled):hover{border-color:var(--color-border-hover);color:var(--color-text)}.assign-btn--danger{background:var(--color-danger);color:#fff}.assign-btn--danger:not(:disabled):hover{background:var(--color-danger-active)}.assign-modal{color:#fffffff2;z-index:1000;background:#000000eb;flex-direction:column;display:flex;position:fixed;inset:0}.assign-modal__topbar{border-bottom:1px solid #ffffff24;justify-content:space-between;align-items:center;gap:16px;padding:12px 20px;display:flex}.assign-modal__student{align-items:center;gap:10px;min-width:0;display:flex}.assign-modal__num{color:#ffffffb3;font-size:13px;font-weight:600}.assign-modal__name{letter-spacing:-.3px;margin:0;font-size:20px;font-weight:700}.assign-modal__meta{color:#ffffffb3;align-items:center;gap:10px;font-size:13px;display:flex}.assign-modal__close{color:#ffffffb3;cursor:pointer;background:0 0;border:none;padding:6px 10px;font-size:22px}.assign-modal__close:hover{color:#fff}.assign-modal__stage{flex:1;grid-template-columns:48px 1fr 48px;min-height:0;display:grid}.assign-modal__nav{color:#ffffffb3;cursor:pointer;background:0 0;border:none;font-size:32px}.assign-modal__nav:disabled{opacity:.25;cursor:default}.assign-modal__nav:not(:disabled):hover{background:#ffffff14}.assign-modal__media{justify-content:center;align-items:center;min-height:0;padding:20px;display:flex}.assign-modal__media-box{max-width:min(90vw,1080px);max-height:calc(100dvh - 220px);color:var(--color-text);border-radius:var(--radius-card);object-fit:contain;background:#fff;box-shadow:0 20px 60px #0006}.assign-modal__media-box--text,.assign-modal__media-box--empty{white-space:pre-wrap;max-width:min(80vw,720px);max-height:calc(100dvh - 220px);padding:32px 40px;font-size:15px;line-height:1.6;overflow:auto}.assign-modal__media-box--empty{color:var(--color-text-muted);text-align:center}.assign-modal__footer{border-top:1px solid #ffffff24;justify-content:flex-end;gap:10px;padding:14px 20px;display:flex}.assign-reason-panel{background:#0009;border-top:1px solid #ffffff24;flex-direction:column;gap:8px;padding:14px 20px;display:flex}.assign-reason__label{color:#ffffffb3;letter-spacing:.1px;font-size:12px;font-weight:600}.assign-reason__textarea{color:#fff;resize:vertical;background:#ffffff14;border:1px solid #fff3;border-radius:6px;width:100%;min-height:72px;padding:10px;font-family:inherit;font-size:14px}.assign-reason__row{justify-content:space-between;align-items:center;display:flex}.assign-reason__counter{color:#ffffffb3;font-size:12px}.assign-reason__actions{gap:8px;display:flex}.parent-assign{flex-direction:column;gap:14px;max-width:720px;margin:0 auto;padding:16px;display:flex}.parent-assign__header{justify-content:space-between;align-items:center;gap:12px;display:flex}.parent-assign__title{letter-spacing:-.3px;margin:0;font-size:22px;font-weight:700}.parent-assign__content{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-card);flex-direction:column;gap:10px;padding:16px 18px;display:flex}.parent-assign__image{border-radius:8px;align-self:center;width:100%;max-width:480px}.parent-assign__text{white-space:pre-wrap;margin:0;line-height:1.55}.parent-assign__link{color:var(--color-accent);word-break:break-all;font-size:14px}.parent-assign__empty{color:var(--color-text-muted);margin:0}@media (prefers-reduced-motion:reduce){.assign-slot,.assign-modal,.assign-modal__nav{transition:none!important}}@media (max-width:767px){.assign-grid{grid-template-columns:repeat(3,minmax(0,1fr))}}.assign-fab{right:32px;bottom:var(--fab-bottom-safe,32px);background:var(--color-accent);color:#fff;letter-spacing:-.1px;cursor:pointer;min-width:56px;height:56px;box-shadow:var(--shadow-accent);z-index:30;border:none;border-radius:9999px;padding:0 18px;font-family:inherit;font-size:14px;font-weight:700;transition:background .16s,transform .16s,box-shadow .16s;position:fixed}.assign-fab:hover{background:var(--color-accent-active);box-shadow:var(--shadow-accent-hover);transform:translateY(-2px)}.assign-fab:active{transform:scale(.97)}
