@import"https://fonts.googleapis.com/css2?family=Noto+Sans+KR:wght@400;500;600;700&family=Space+Grotesk:wght@400;500;600;700&display=swap";.project-card-gallery{position:relative;border-radius:20px;background:var(--bg-card);box-shadow:0 16px 32px #0f172a1f;overflow:hidden;cursor:pointer;aspect-ratio:4 / 3;transition:all .3s cubic-bezier(.4,0,.2,1);border:1px solid rgba(148,163,184,.3)}.project-card-gallery:hover{box-shadow:0 24px 40px #0f172a29;transform:translateY(-3px)}.project-card-gallery.selected{box-shadow:0 0 0 2px #1d4ed866,0 18px 36px #0f172a29}.card-media{width:100%;height:100%;background-size:cover;background-position:center;background-repeat:no-repeat;transition:transform .5s cubic-bezier(.4,0,.2,1);position:relative}.card-image{width:100%;height:100%;-o-object-fit:cover;object-fit:cover;transition:transform .5s cubic-bezier(.4,0,.2,1);display:block}.project-card-gallery:hover .card-media,.project-card-gallery:hover .card-image{transform:scale(1.1)}.placeholder-content{width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;color:#ffffffe6;gap:12px;padding:20px;text-align:center;background:#0000001a}.placeholder-text{font-size:18px;font-weight:700;text-shadow:0 2px 4px rgba(0,0,0,.2);word-break:break-word;display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.placeholder-icon{filter:drop-shadow(0 2px 4px rgba(0,0,0,.2))}.selection-checkbox{position:absolute;top:12px;right:12px;width:28px;height:28px;border-radius:8px;background:#ffffff40;border:2px solid rgba(255,255,255,.6);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);cursor:pointer;display:flex;align-items:center;justify-content:center;z-index:10;transition:all .2s}.selection-checkbox:hover{background:#fff6;border-color:#fff;transform:scale(1.05)}.selection-checkbox.selected{background:var(--primary);border-color:var(--primary)}.checkbox-inner{width:12px;height:12px;background:#fff;border-radius:3px;box-shadow:0 1px 2px #0000001a}.iframe-container{width:300%;height:300%;transform:scale(.333);transform-origin:top left;overflow:hidden;pointer-events:none;background:#fff}.card-iframe{width:100%;height:100%;border:none;display:block}.card-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(to top,#000000d9,#0009,#0003);opacity:0;transition:opacity .3s cubic-bezier(.4,0,.2,1);padding:20px;display:flex;flex-direction:column;justify-content:space-between;-webkit-backdrop-filter:blur(0px);backdrop-filter:blur(0px)}.project-card-gallery:hover .card-overlay{opacity:1;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.overlay-header{display:flex;gap:8px;transform:translateY(-8px);transition:transform .3s cubic-bezier(.4,0,.2,1);flex-wrap:wrap;opacity:0}.project-card-gallery:hover .overlay-header{transform:translateY(0);opacity:1}.grade-badge-sm,.team-badge-sm{padding:4px 10px;border-radius:6px;font-size:11px;font-weight:700;color:#fff;box-shadow:0 2px 4px #0000001a}.grade-badge-sm{background:#2563ebe6}.team-badge-sm{background:#fff3;border:1px solid rgba(255,255,255,.4);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.overlay-content{display:flex;flex-direction:column;gap:10px;transform:translateY(8px);transition:transform .3s cubic-bezier(.4,0,.2,1);opacity:0}.project-card-gallery:hover .overlay-content{transform:translateY(0);opacity:1}.project-title-overlay{font-size:18px;font-weight:800;color:#fff;margin:0;line-height:1.3;text-shadow:0 2px 8px rgba(0,0,0,.5);display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.team-info{display:flex;flex-direction:column;gap:6px;color:#fffffff2;font-size:12px;font-weight:500;text-shadow:0 1px 2px rgba(0,0,0,.3)}.leader-info,.members-count,.members-info{display:flex;align-items:center;gap:5px}.members-info span{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:200px}.project-desc-overlay{font-size:12px;color:#ffffffd9;line-height:1.5;display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;margin:0;text-shadow:0 1px 2px rgba(0,0,0,.3)}.action-buttons{display:flex;gap:10px;margin-top:6px}.icon-btn{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:50%;border:none;cursor:pointer;background:#ffffff26;color:#fff;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);transition:all .2s cubic-bezier(.4,0,.2,1);border:1px solid rgba(255,255,255,.3);box-shadow:0 2px 4px #0000001a}.icon-btn:hover{background:#fff;color:#0f172a;transform:translateY(-2px);box-shadow:0 4px 12px #0003}.icon-btn.delete:hover{background:#ef4444;color:#fff;border-color:#ef4444}.icon-btn.view:hover{background:#3b82f6;color:#fff;border-color:#3b82f6}.custom-select{position:relative;width:100%}.custom-select-trigger{width:100%;height:48px;padding:0 16px;background:var(--bg-glass);border:2px solid var(--border);border-radius:12px;color:var(--text);font-size:15px;font-weight:500;font-family:inherit;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);box-shadow:0 2px 6px var(--shadow);display:flex;align-items:center;justify-content:space-between;gap:12px}.custom-select-trigger:hover{border-color:var(--border-hover);box-shadow:0 4px 12px var(--shadow-md);background:#fff}.custom-select-trigger.open{border-color:var(--primary);box-shadow:0 0 0 4px #0052cc1a,0 4px 12px var(--shadow-md);background:#fff}.custom-select-trigger:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 4px #0052cc1a,0 4px 12px var(--shadow-md);background:#fff}.custom-select-value{flex:1;text-align:left;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.custom-select-value.placeholder{color:var(--text-tertiary);font-weight:400}.custom-select-arrow{display:flex;align-items:center;justify-content:center;color:var(--text-secondary);transition:color .2s ease;flex-shrink:0}.custom-select-trigger:hover .custom-select-arrow,.custom-select-trigger.open .custom-select-arrow{color:var(--primary)}.custom-select-dropdown{position:absolute;top:calc(100% + 8px);left:0;right:0;background:#fff;border:2px solid var(--primary);border-radius:12px;box-shadow:0 8px 24px var(--shadow-lg);z-index:1000;max-height:280px;overflow-y:auto;list-style:none;margin:0;padding:8px}.custom-select-dropdown::-webkit-scrollbar{width:6px}.custom-select-dropdown::-webkit-scrollbar-track{background:transparent}.custom-select-dropdown::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}.custom-select-dropdown::-webkit-scrollbar-thumb:hover{background:var(--text-secondary)}.custom-select-option{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px 14px;cursor:pointer;border-radius:8px;transition:all .2s cubic-bezier(.4,0,.2,1);color:var(--text);font-size:15px;font-weight:500;-webkit-user-select:none;-moz-user-select:none;user-select:none}.custom-select-option:hover{background:var(--hover-bg)}.custom-select-option.selected{background:#0052cc14;color:var(--primary);font-weight:600}.custom-select-option.selected:hover{background:#0052cc1f}.custom-select-option span{flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.custom-select-option svg{color:var(--primary);flex-shrink:0}@keyframes selectSlideDown{0%{opacity:0;transform:translateY(-8px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000a6;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);z-index:9999;display:flex;align-items:center;justify-content:center;padding:40px 20px;overflow-y:auto}.modal,.modal-content{position:relative;background:#fff;border:1px solid #e5e7eb;border-radius:16px;width:100%;max-width:620px;max-height:85vh;overflow-y:auto;z-index:10000;box-shadow:0 20px 60px #0000004d,0 0 0 1px #0000000d;margin:0}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:28px 32px;border-bottom:1px solid #e5e7eb;position:sticky;top:0;background:#fff;z-index:10;border-radius:16px 16px 0 0}.modal-header h2{font-size:24px;font-weight:700;color:#111827;letter-spacing:-.02em;margin:0}.modal-close{background:#f3f4f6;border:none;color:#6b7280;cursor:pointer;padding:10px;transition:all .2s;display:flex;align-items:center;justify-content:center;border-radius:8px;width:40px;height:40px}.modal-close:hover{background:#e5e7eb;color:#111827;transform:scale(1.05)}.modal-form{padding:32px;display:flex;flex-direction:column;gap:24px;background:#fff}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}.form-group{display:flex;flex-direction:column;gap:8px}.form-group label{font-size:13px;font-weight:600;color:#111827;letter-spacing:-.01em}.form-group input,.form-group select,.select-input,.form-group textarea{padding:0 16px;min-height:48px;background:#f9fafb;border:1px solid #e5e7eb;border-radius:8px;color:#111827;font-size:15px;font-family:inherit;font-weight:500;transition:all .2s cubic-bezier(.4,0,.2,1)}.form-group textarea{padding:12px 16px;min-height:120px;resize:vertical}.form-group input:hover,.form-group select:hover,.form-group textarea:hover{border-color:#d1d5db;background:#fff}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:#3b82f6;background:#fff;box-shadow:0 0 0 3px #3b82f61a}.form-group select{cursor:pointer}.modal-actions,.form-actions{display:flex;gap:12px;margin-top:24px;padding-top:24px;border-top:1px solid #e5e7eb}.cancel-button,.submit-button{flex:1;min-height:50px;padding:14px 24px;border:none;border-radius:12px;font-size:15px;font-weight:700;cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1);letter-spacing:-.01em;display:flex;align-items:center;justify-content:center;gap:8px}.cancel-button{background:#fff;color:#6b7280;border:2px solid #e5e7eb}.cancel-button:hover{background:#f9fafb;border-color:#d1d5db;color:#111827;transform:translateY(-1px);box-shadow:0 2px 8px #00000014}.cancel-button:disabled{opacity:.5;cursor:not-allowed;transform:none}.submit-button{background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff;box-shadow:0 4px 12px #3b82f640;border:2px solid transparent}.submit-button:hover:not(:disabled){background:linear-gradient(135deg,#2563eb,#1d4ed8);transform:translateY(-2px);box-shadow:0 8px 20px #3b82f659}.submit-button:disabled{opacity:.6;cursor:not-allowed;transform:none;box-shadow:none}.submit-button:active:not(:disabled),.cancel-button:active:not(:disabled){transform:scale(.98)}.form-section{display:flex;flex-direction:column;gap:16px;padding:24px;background:var(--bg-glass);border:1px solid var(--border);border-radius:12px}.section-title{font-size:14px;font-weight:700;color:var(--text);margin:0;letter-spacing:-.01em;display:flex;align-items:center;gap:8px}.section-description{font-size:12px;color:var(--text-secondary);margin:8px 0 0;line-height:1.5}.input-group{display:grid;grid-template-columns:1fr 1.5fr auto auto;gap:10px;align-items:center}.form-input-small,.form-select-small{padding:0 14px;height:42px;background:var(--bg-elevated);border:1px solid var(--border);border-radius:8px;color:var(--text);font-size:14px;font-family:inherit;font-weight:500;transition:all .2s cubic-bezier(.4,0,.2,1)}.form-input-small:focus,.form-select-small:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #0052cc1a}.upload-area{margin:16px 0;display:flex;justify-content:flex-start}.upload-button{display:inline-flex;align-items:center;gap:8px;padding:12px 24px;background:var(--primary);color:#fff;border:none;border-radius:8px;cursor:pointer;font-size:14px;font-weight:600;transition:all .2s cubic-bezier(.4,0,.2,1);box-shadow:0 2px 4px var(--shadow-accent)}.upload-button:hover{background:var(--primary-hover);transform:translateY(-1px);box-shadow:0 4px 8px var(--shadow-accent)}.upload-button .spinner{animation:spin 1s linear infinite}.add-item-button{width:42px;height:42px;background:var(--primary);color:#fff;border:none;border-radius:8px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s cubic-bezier(.4,0,.2,1);flex-shrink:0;box-shadow:0 2px 4px var(--shadow-accent)}.add-item-button:hover{background:var(--primary-hover);transform:scale(1.05);box-shadow:0 4px 8px var(--shadow-accent)}.added-items{display:flex;flex-direction:column;gap:10px;margin-top:0}.added-item{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;background:var(--bg-elevated);border:1px solid var(--border);border-radius:8px;font-size:14px;font-weight:500;color:var(--text);transition:all .2s}.added-item:hover{border-color:var(--border-hover);background:var(--hover-bg)}.remove-item-button{background:transparent;border:none;color:var(--text-tertiary);cursor:pointer;padding:4px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:all .2s}.remove-item-button:hover{background:#da1e281a;color:var(--danger)}.upload-progress-section{margin-top:16px;padding:16px;background:var(--bg-elevated);border:1px solid var(--border);border-radius:8px}.progress-info{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.progress-text{font-size:13px;font-weight:600;color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1;margin-right:12px}.progress-percentage{font-size:14px;font-weight:700;color:var(--primary);flex-shrink:0}.progress-bar-container{width:100%;height:8px;background:var(--bg-secondary);border-radius:4px;overflow:hidden;box-shadow:inset 0 1px 2px #0000001a}.progress-bar{height:100%;background:linear-gradient(90deg,var(--primary),var(--secondary));border-radius:4px;transition:width .3s ease;box-shadow:0 0 10px #0052cc4d}@media (max-width: 640px){.modal-overlay{padding:10px}.modal{max-height:95vh}.modal-header{padding:24px 24px 20px}.modal-header h2{font-size:20px}.modal-form{padding:24px;gap:20px}.form-row{grid-template-columns:1fr;gap:20px}.form-group input,.form-group select,.cancel-button,.submit-button{height:44px}.input-group{grid-template-columns:1fr}.form-input-small,.form-select-small{height:42px}.add-item-button{width:100%;height:42px}}.detail-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000a6;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);z-index:9999;display:flex;align-items:center;justify-content:center;padding:40px 20px;overflow-y:auto}.detail-modal{position:relative;background:var(--bg-elevated);border:1px solid var(--border);border-radius:16px;width:100%;max-width:1200px;max-height:85vh;overflow-y:auto;z-index:10000;box-shadow:0 20px 60px var(--shadow-xl),0 0 0 1px var(--border);margin:0}.detail-modal-header{position:sticky;top:0;background:var(--bg-elevated);border-bottom:1px solid var(--border);padding:28px 32px;display:flex;justify-content:space-between;align-items:flex-start;z-index:10;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.detail-header-actions{display:flex;gap:8px;align-items:center}.edit-button{display:flex;align-items:center;gap:6px;padding:8px 16px;background:linear-gradient(135deg,#10b981,#059669);color:#fff;border:none;border-radius:8px;cursor:pointer;font-size:14px;font-weight:500;transition:all .2s}.edit-button:hover{transform:translateY(-1px);box-shadow:0 4px 12px #10b9814d}.detail-header-content{flex:1}.detail-badges{display:flex;gap:8px;margin-bottom:12px}.detail-grade-badge,.detail-team-badge{padding:6px 14px;font-size:12px;font-weight:700;letter-spacing:.02em;border-radius:6px}.detail-grade-badge{background:var(--primary);color:#fff;box-shadow:0 2px 4px var(--shadow-accent)}.detail-team-badge{background:var(--bg-glass);color:var(--text-secondary);border:1px solid var(--border)}.detail-title{font-size:28px;font-weight:700;color:var(--text);margin:0;letter-spacing:-.02em;line-height:1.3}.detail-header-actions{display:flex;align-items:center;gap:12px}.download-all-button{display:flex;align-items:center;gap:8px;padding:8px 16px;background:var(--success);color:#fff;border:none;border-radius:6px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s;box-shadow:0 2px 4px #22c55e4d}.download-all-button:hover{background:#16a34a;transform:translateY(-1px);box-shadow:0 4px 8px #22c55e66}.view-gallery-button{display:flex;align-items:center;gap:8px;padding:8px 16px;background:var(--primary);color:#fff;border:none;border-radius:6px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s;box-shadow:0 2px 4px var(--shadow-accent)}.view-gallery-button:hover{background:var(--primary-hover);transform:translateY(-1px);box-shadow:0 4px 8px var(--shadow-accent)}.detail-close-button{background:transparent;border:none;color:var(--text-tertiary);cursor:pointer;padding:8px;transition:all .2s;display:flex;align-items:center;justify-content:center;border-radius:6px}.detail-close-button:hover{background:var(--bg-glass);color:var(--text)}.detail-modal-content{padding:32px;display:flex;flex-direction:column;gap:32px}.detail-section{display:flex;flex-direction:column;gap:16px}.detail-section-title{font-size:16px;font-weight:700;color:var(--text);margin:0;letter-spacing:-.01em;text-transform:uppercase;font-size:12px;color:var(--text-secondary);display:flex;align-items:center;gap:8px}.detail-info-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:20px}.detail-info-item{display:flex;gap:12px;padding:20px;background:var(--bg-secondary);border:1px solid var(--border);border-radius:8px;transition:all .2s cubic-bezier(.4,0,.2,1)}.detail-info-item:hover{border-color:var(--border-hover);box-shadow:0 2px 6px var(--shadow)}.detail-info-item.full-width{grid-column:1 / -1}.detail-info-icon{color:var(--primary);flex-shrink:0;margin-top:2px}.detail-info-label{font-size:12px;font-weight:600;color:var(--text-tertiary);margin-bottom:4px;text-transform:uppercase;letter-spacing:.05em}.detail-info-value{font-size:14px;font-weight:500;color:var(--text);line-height:1.5}.detail-tags{display:flex;flex-wrap:wrap;gap:8px;margin-top:4px}.detail-tag{padding:6px 12px;background:var(--bg-glass);color:var(--text-secondary);font-size:12px;font-weight:600;border-radius:6px;border:1px solid var(--border);letter-spacing:.01em}.detail-files-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:12px}.detail-file-card{display:flex;align-items:center;gap:12px;padding:16px;background:var(--bg-secondary);border:1px solid var(--border);border-radius:8px;cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1);position:relative}.detail-file-card:hover{border-color:var(--primary);box-shadow:0 4px 12px var(--shadow-md);transform:translateY(-2px)}.detail-file-card.active{border-color:var(--primary);background:#0052cc0d;box-shadow:0 0 0 3px #0052cc1a}.detail-file-icon{width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:#0052cc1a;color:var(--primary);border-radius:8px;flex-shrink:0}.detail-file-info{flex:1;min-width:0}.detail-file-name{font-size:14px;font-weight:600;color:var(--text);margin-bottom:2px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.detail-file-type{font-size:11px;font-weight:600;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.05em}.detail-file-download{width:32px;height:32px;display:flex;align-items:center;justify-content:center;color:var(--text-tertiary);background:transparent;border:none;border-radius:4px;cursor:pointer;transition:all .2s;flex-shrink:0}.detail-file-download:hover{background:var(--primary);color:#fff}.detail-file-viewer{margin-top:16px;background:var(--bg-secondary);border:1px solid var(--border);border-radius:8px;overflow:hidden}.detail-viewer-header{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;background:var(--bg-glass);border-bottom:1px solid var(--border);font-size:13px;font-weight:600;color:var(--text-secondary)}.detail-viewer-close{background:transparent;border:none;color:var(--text-tertiary);cursor:pointer;padding:4px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:all .2s}.detail-viewer-close:hover{background:var(--bg-elevated);color:var(--text)}.detail-viewer-iframe{width:100%;height:600px;border:none;display:block}.detail-links-grid{display:grid;gap:20px}.detail-link-container{display:flex;flex-direction:column;gap:12px}.detail-link-card{display:flex;align-items:center;gap:12px;padding:16px;background:var(--bg-secondary);border:1px solid var(--border);border-radius:8px;text-decoration:none;transition:all .2s cubic-bezier(.4,0,.2,1)}.detail-link-card:hover{border-color:var(--primary);box-shadow:0 4px 12px var(--shadow-md);transform:translateY(-2px)}.detail-website-preview{background:var(--bg-secondary);border:1px solid var(--border);border-radius:8px;overflow:hidden}.detail-preview-header{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;background:var(--bg-glass);border-bottom:1px solid var(--border);font-size:13px;font-weight:600;color:var(--text-secondary)}.detail-preview-open{color:var(--primary);text-decoration:none;font-size:12px;font-weight:600;transition:all .2s}.detail-preview-open:hover{color:var(--primary-hover);text-decoration:underline}.detail-preview-iframe{width:100%;height:600px;border:none;display:block;background:#fff}.detail-link-icon{width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:#0052cc1a;color:var(--primary);border-radius:8px;flex-shrink:0}.detail-link-info{flex:1;min-width:0}.detail-link-title{font-size:14px;font-weight:600;color:var(--text);margin-bottom:4px}.detail-link-url{font-size:12px;color:var(--text-tertiary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.detail-link-external{color:var(--text-tertiary);flex-shrink:0;transition:all .2s}.detail-link-card:hover .detail-link-external{color:var(--primary);transform:translate(4px)}.detail-github-link{display:flex;align-items:center;justify-content:center;gap:12px;padding:18px 32px;background:var(--primary);color:#fff;text-decoration:none;font-size:15px;font-weight:700;border-radius:8px;transition:all .2s cubic-bezier(.4,0,.2,1);box-shadow:0 4px 12px var(--shadow-accent)}.detail-github-link:hover{background:var(--primary-hover);transform:translateY(-2px);box-shadow:0 6px 20px var(--shadow-accent)}.preview-tabs{display:flex;gap:8px;margin-bottom:16px;border-bottom:2px solid var(--border);padding-bottom:0;overflow-x:auto}.preview-tab{display:inline-flex;align-items:center;gap:8px;padding:12px 20px;background:transparent;border:none;border-bottom:3px solid transparent;color:var(--text-secondary);font-size:14px;font-weight:600;cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1);white-space:nowrap;margin-bottom:-2px;font-family:inherit}.preview-tab:hover{color:var(--text);background:var(--hover-bg)}.preview-tab.active{color:var(--primary);border-bottom-color:var(--primary);background:#0052cc0d}.preview-container{background:var(--bg-secondary);border:1px solid var(--border);border-radius:12px;overflow:hidden;box-shadow:0 4px 12px var(--shadow)}.preview-toolbar{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;background:var(--bg-glass);border-bottom:1px solid var(--border)}.preview-url{display:flex;align-items:center;gap:8px;flex:1;min-width:0}.preview-url span{font-size:13px;color:var(--text-secondary);font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.preview-url svg{color:var(--text-tertiary);flex-shrink:0}.preview-actions{display:flex;gap:8px;flex-shrink:0}.preview-action-btn{display:flex;align-items:center;justify-content:center;width:32px;height:32px;background:transparent;border:1px solid var(--border);border-radius:6px;color:var(--text-secondary);cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1);text-decoration:none}.preview-action-btn:hover{background:var(--primary);border-color:var(--primary);color:#fff;transform:scale(1.05);box-shadow:0 2px 6px var(--shadow-accent)}.preview-frame-wrapper{width:100%;height:600px;background:#fff;position:relative;overflow:hidden}.preview-iframe{width:100%;height:100%;border:none;display:block;background:#fff}.iframe-loading,.iframe-error{position:absolute;top:0;left:0;right:0;bottom:0;display:flex;flex-direction:column;align-items:center;justify-content:center;background:var(--bg-secondary);z-index:10}.iframe-loading{gap:16px}.loading-spinner{width:48px;height:48px;border:4px solid var(--border);border-top-color:var(--primary);border-radius:50%;animation:spin 1s linear infinite}.iframe-loading p{color:var(--text-secondary);font-size:14px;font-weight:500;margin:0}.iframe-error{gap:16px;padding:40px;text-align:center}.error-icon{font-size:64px;line-height:1}.iframe-error h4{font-size:18px;font-weight:700;color:var(--text);margin:0;letter-spacing:-.01em}.iframe-error p{font-size:14px;color:var(--text-secondary);margin:0;max-width:400px}.error-link-button{display:inline-flex;align-items:center;gap:10px;padding:12px 24px;background:var(--primary);color:#fff;text-decoration:none;font-weight:600;font-size:14px;border-radius:8px;margin-top:16px;transition:all .2s cubic-bezier(.4,0,.2,1);box-shadow:0 2px 6px var(--shadow-accent)}.error-link-button:hover{background:var(--primary-hover);transform:translateY(-2px);box-shadow:0 4px 12px var(--shadow-accent)}@media (max-width: 768px){.detail-modal-overlay{padding:10px}.detail-modal{max-height:95vh}.detail-modal-header{padding:20px}.detail-title{font-size:22px}.detail-modal-content{padding:20px;gap:24px}.detail-info-grid,.detail-files-grid{grid-template-columns:1fr}.detail-viewer-iframe,.detail-preview-iframe,.preview-frame-wrapper{height:400px}.preview-toolbar{flex-direction:column;align-items:flex-start;gap:12px}.preview-actions{width:100%;justify-content:flex-end}.preview-tabs{overflow-x:auto;-webkit-overflow-scrolling:touch}.preview-tab{padding:10px 16px;font-size:13px}}.html-previews-container{display:flex;gap:16px;overflow-x:auto;padding-bottom:12px;scrollbar-width:thin;scrollbar-color:#cbd5e1 transparent}.html-previews-container::-webkit-scrollbar{height:6px}.html-previews-container::-webkit-scrollbar-track{background:transparent}.html-previews-container::-webkit-scrollbar-thumb{background-color:#cbd5e1;border-radius:3px}.html-preview-card{flex:0 0 280px;background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;overflow:hidden;cursor:pointer;transition:all .2s ease;display:flex;flex-direction:column}.html-preview-card:hover{transform:translateY(-2px);box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;border-color:#cbd5e1}.html-preview-header{padding:8px 12px;background:#fff;border-bottom:1px solid #e2e8f0;display:flex;justify-content:space-between;align-items:center}.html-preview-title{font-size:13px;font-weight:500;color:#334155;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.html-preview-link{display:flex;align-items:center;justify-content:center;width:24px;height:24px;border-radius:4px;color:#64748b;transition:all .2s}.html-preview-link:hover{background:#f1f5f9;color:#0f172a}.html-preview-content{height:160px;position:relative;background:#fff}.html-preview-iframe{width:100%;height:100%;border:none;pointer-events:none}.html-preview-loading{display:flex;align-items:center;justify-content:center;height:100%;background:#f8fafc}.loading-spinner-small{width:20px;height:20px;border:2px solid #e2e8f0;border-top-color:#3b82f6;border-radius:50%;animation:spin 1s linear infinite}.html-preview-error{display:flex;align-items:center;justify-content:center;height:100%;background:#fef2f2;color:#ef4444;font-size:13px}@keyframes spin{to{transform:rotate(360deg)}}.shortcut-help-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1400;display:flex;align-items:center;justify-content:center}.shortcut-help-backdrop{position:absolute;top:0;right:0;bottom:0;left:0;background:#0f172a66;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px)}.shortcut-help-panel{position:relative;width:min(520px,92vw);background:#fffffff2;border-radius:20px;border:1px solid rgba(148,163,184,.3);box-shadow:0 24px 60px #0f172a33;padding:20px 22px;display:grid;gap:16px}.shortcut-help-header{display:flex;align-items:center;justify-content:space-between;gap:12px}.shortcut-help-title{display:inline-flex;align-items:center;gap:10px;font-size:16px;font-weight:700;color:var(--text)}.shortcut-help-close{width:34px;height:34px;border-radius:10px;border:1px solid rgba(148,163,184,.35);background:#fffc;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;color:var(--text-secondary);transition:all .2s ease}.shortcut-help-close:hover{border-color:#1d4ed866;color:var(--primary);background:#fff}.shortcut-help-body{display:grid;gap:10px}.shortcut-help-row{display:grid;grid-template-columns:minmax(110px,140px) 1fr;gap:12px;align-items:center;padding:10px 12px;border-radius:12px;background:#f8fafcb3;border:1px solid rgba(148,163,184,.2)}.shortcut-help-keys{font-weight:700;font-size:13px;color:var(--primary);background:#1d4ed81a;padding:4px 8px;border-radius:999px;text-align:center;letter-spacing:.02em}.shortcut-help-desc{font-size:13px;color:var(--text-secondary)}.shortcut-help-footer{font-size:12px;color:var(--text-tertiary);text-align:right}@media (max-width: 600px){.shortcut-help-panel{padding:18px}.shortcut-help-row{grid-template-columns:1fr}.shortcut-help-keys{justify-self:flex-start}}.all-projects-gallery{min-height:100vh;height:100vh;width:100vw;padding:0;display:flex;flex-direction:column;position:relative;overflow:hidden;isolation:isolate;background:radial-gradient(circle at top,rgba(15,118,110,.16),transparent 55%),radial-gradient(circle at 20% 80%,rgba(29,78,216,.2),transparent 55%),#0b1220}.all-projects-gallery.empty{align-items:center;justify-content:center}.all-projects-gallery:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(circle 640px at 80% 12%,rgba(56,189,248,.16),transparent 70%),radial-gradient(circle 520px at 10% 90%,rgba(20,184,166,.14),transparent 70%);opacity:.7;pointer-events:none;z-index:0}.all-projects-gallery:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background-image:linear-gradient(transparent 0,transparent 28px,rgba(226,232,240,.06) 28px,rgba(226,232,240,.06) 29px),linear-gradient(90deg,transparent 0,transparent 28px,rgba(226,232,240,.06) 28px,rgba(226,232,240,.06) 29px);background-size:29px 29px;opacity:.2;pointer-events:none;z-index:0}.all-gallery-header{position:fixed;top:16px;left:50%;transform:translate(-50%,-12px);width:min(1180px,calc(100vw - 32px));display:flex;align-items:center;justify-content:space-between;gap:16px;background:#ffffffe6;border:1px solid rgba(148,163,184,.35);border-radius:20px;padding:14px 18px;box-shadow:0 24px 50px #0f172a33;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);opacity:0;pointer-events:none;transition:opacity .3s ease,transform .3s ease;z-index:30}.all-gallery-header:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border-radius:20px;padding:1px;background:linear-gradient(135deg,#1d4ed866,#0ea5e914,#0f766e4d);-webkit-mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);-webkit-mask-composite:xor;mask-composite:exclude;pointer-events:none}.all-gallery-header.visible{opacity:.98;transform:translate(-50%);pointer-events:auto}.all-gallery-left{display:flex;align-items:center;gap:12px}.all-gallery-context{display:inline-flex;align-items:center;gap:8px;padding:6px 12px;border-radius:999px;background:#0f172a0f;color:var(--text-secondary);font-size:12px;font-weight:600}.all-gallery-context span:not(:last-child):after{content:"·";margin-left:8px;color:#0f172a66}.all-gallery-back{display:inline-flex;align-items:center;gap:6px;border:1px solid rgba(148,163,184,.35);background:#fffc;border-radius:12px;padding:8px 12px;cursor:pointer;color:var(--text-secondary);transition:all .2s ease}.all-gallery-back:hover{border-color:var(--primary);color:var(--primary);background:var(--bg-card)}.all-gallery-title{display:inline-flex;align-items:center;gap:8px;font-weight:700;color:var(--text);letter-spacing:.02em;font-size:14px}.all-gallery-controls{display:inline-flex;align-items:center;gap:10px;padding:4px;border-radius:999px;background:#0f172a0a;border:1px solid rgba(148,163,184,.2)}.all-gallery-title{font-weight:700;color:var(--text)}.all-gallery-progress{display:inline-flex;align-items:center;gap:6px;padding:6px 10px;border-radius:999px;background:#0f172a0f;border:1px solid rgba(148,163,184,.3);color:var(--text-secondary);font-size:12px;font-weight:600}.all-gallery-progress-label{color:var(--text-tertiary)}.all-gallery-progress-divider{opacity:.5}.all-gallery-control{border:1px solid rgba(148,163,184,.35);background:#fffc;border-radius:12px;padding:8px 12px;display:inline-flex;align-items:center;gap:6px;color:var(--text-secondary);cursor:pointer;transition:all .2s ease;font-size:12px;font-weight:600}.all-gallery-control:hover{border-color:var(--primary);color:var(--primary);background:var(--bg-card)}.all-gallery-control.tap{background:linear-gradient(135deg,#0ea5e9e6,#0f766ee6);color:#fff;border-color:transparent;font-weight:700;box-shadow:0 8px 18px #0ea5e947}.all-gallery-body{position:relative;flex:1;min-height:0;display:flex;flex-direction:column;padding:0;z-index:1}.all-gallery-card{border:1px solid rgba(255,255,255,.08);border-radius:16px;padding:14px 16px;background:#0f172aa3;cursor:pointer;text-align:left;transition:all .25s ease;color:#ffffffe6;scroll-snap-align:start}.all-gallery-card:hover{border-color:#fff6;box-shadow:0 14px 24px #0f172a59;transform:translateY(-2px)}.all-gallery-card.active{border-color:#ffffff8c;background:linear-gradient(135deg,#1d4ed8e6,#0ea5e9db);color:#fff;box-shadow:0 18px 36px #0ea5e959}.all-gallery-card-title{font-size:15px;font-weight:700;margin-bottom:6px}.all-gallery-card-meta{display:flex;justify-content:space-between;font-size:12px;color:#ffffffb3}.all-gallery-card.active .all-gallery-card-meta{color:#ffffffd9}.all-gallery-preview{position:fixed;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;background:#0b1220;border-radius:0;border:none;padding:0;gap:0;min-height:0;flex:1;box-shadow:none;overflow:hidden;z-index:1}.all-gallery-preview-header{position:fixed;top:96px;left:24px;display:flex;justify-content:space-between;align-items:flex-start;gap:12px;padding:10px 14px;background:#ffffffeb;border:1px solid rgba(148,163,184,.35);border-radius:16px;box-shadow:0 18px 32px #0f172a2e;backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);z-index:25;opacity:0;transform:translateY(-8px);pointer-events:none;transition:opacity .25s ease,transform .25s ease;max-width:min(420px,75vw)}.all-gallery-preview-header.visible{opacity:.98;transform:translateY(0);pointer-events:auto}.preview-project-title{font-size:18px;font-weight:700;color:var(--text)}.preview-project-meta{font-size:12px;color:var(--text-tertiary);margin-top:4px}.preview-external-link{display:inline-flex;align-items:center;gap:6px;padding:6px 10px;border-radius:10px;border:1px solid rgba(148,163,184,.35);background:#fffc;color:var(--text-secondary);text-decoration:none;transition:all .2s ease;pointer-events:auto}.preview-external-link:hover{border-color:var(--primary);color:var(--primary)}.all-gallery-edge{position:fixed;left:0;right:0;height:40px;z-index:22;pointer-events:auto;background:transparent}.all-gallery-edge-top{top:0}.all-gallery-edge-bottom{bottom:0}.all-gallery-preview-frame{flex:1;border-radius:0;border:none;overflow:hidden;background:#0f172a;display:flex;align-items:center;justify-content:center;min-height:0;height:100%}.preview-frame-shell{width:100%;height:100%;border-radius:0;overflow:hidden;background:#0f172a;border:none;box-shadow:none;display:flex;align-items:center;justify-content:center}.preview-iframe{width:100%;height:100%;border:none;background:#fff}.preview-loading,.preview-empty,.preview-error{color:#e2e8f0e6;font-size:14px;padding:16px;text-align:center}.all-gallery-dock{position:fixed;left:18px;right:18px;bottom:18px;background:#0f172aa8;border:1px solid rgba(148,163,184,.2);border-radius:20px;padding:10px 12px 16px;box-shadow:0 24px 50px #0f172a73;backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px);transform:translateY(62%);opacity:0;pointer-events:none;transition:transform .35s ease,opacity .35s ease;z-index:25;max-height:40vh}.all-gallery-dock.visible{transform:translateY(0);opacity:1;pointer-events:auto}.all-gallery-dock:hover,.all-gallery-dock:focus-within{transform:translateY(0);opacity:1}.all-gallery-dock-top{display:flex;align-items:center;gap:12px;padding:12px 8px;color:#ffffffb8;position:relative}.all-gallery-dock-handle{width:36px;height:4px;border-radius:999px;background:#ffffff4d;position:absolute;top:2px;left:50%;transform:translate(-50%)}.all-gallery-dock-title{font-size:12px;text-transform:uppercase;letter-spacing:.12em;font-weight:700}.all-gallery-dock-meta{margin-left:auto;font-size:12px;color:#fff9}.all-gallery-dock-track{display:grid;gap:18px;max-height:32vh;overflow-y:auto;padding-right:6px;padding-bottom:6px}.all-gallery-dock-track::-webkit-scrollbar{width:6px}.all-gallery-dock-track::-webkit-scrollbar-thumb{background:#ffffff40;border-radius:999px}.all-gallery-group{display:grid;gap:10px}.all-gallery-group-title{font-size:12px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:#ffffffc7;padding:0 6px}.all-gallery-group-track{display:grid;grid-auto-flow:column;grid-auto-columns:minmax(190px,240px);gap:12px;overflow-x:auto;padding-bottom:6px;scroll-snap-type:x mandatory}.all-gallery-group-track::-webkit-scrollbar{height:6px}.all-gallery-group-track::-webkit-scrollbar-thumb{background:#ffffff40;border-radius:999px}.all-gallery-empty{padding:24px 32px;border-radius:16px;border:1px dashed var(--border);background:var(--bg-glass);color:var(--text-secondary);font-size:15px}@media (max-width: 720px){.all-projects-gallery{padding:0}.all-gallery-header{flex-direction:column;align-items:flex-start;top:12px;left:50%;width:calc(100vw - 24px)}.all-gallery-controls{width:100%;flex-wrap:wrap}.all-gallery-progress{order:3}.all-gallery-preview-header{top:112px;left:12px;right:12px;max-width:none}.all-gallery-dock{left:12px;right:12px;bottom:12px;max-height:45vh}.all-gallery-dock-track{max-height:36vh}.all-gallery-group-track{grid-auto-columns:minmax(160px,1fr)}}.search-filter{display:flex;gap:12px;margin-bottom:0}.search-box{flex:1;position:relative;display:flex;align-items:center}.search-icon{position:absolute;left:18px;color:var(--text-tertiary);pointer-events:none;z-index:1;transition:color .2s ease}.search-box:hover .search-icon,.search-input:focus+.search-icon{color:var(--primary)}.search-input{width:100%;height:48px;padding:0 20px 0 50px;background:var(--bg-glass);border:2px solid var(--border);border-radius:12px;color:var(--text);font-size:15px;font-weight:500;font-family:inherit;transition:all .3s cubic-bezier(.4,0,.2,1);box-shadow:0 2px 6px var(--shadow)}.search-input::-moz-placeholder{color:var(--text-tertiary);font-weight:400}.search-input::placeholder{color:var(--text-tertiary);font-weight:400}.search-input:hover{border-color:var(--border-hover);box-shadow:0 4px 12px var(--shadow-md);background:#fff}.search-input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 4px #1d4ed81f,0 4px 12px var(--shadow-md);background:#fff}.filter-button{display:inline-flex;align-items:center;gap:10px;padding:0 24px;height:48px;background:var(--bg-glass);border:2px solid var(--border);border-radius:12px;color:var(--text-secondary);font-size:15px;font-weight:600;font-family:inherit;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);box-shadow:0 2px 6px var(--shadow);white-space:nowrap}.filter-button:hover{background:#fff;border-color:var(--primary);color:var(--primary);box-shadow:0 4px 12px var(--shadow-md);transform:translateY(-2px)}.filter-button:active{transform:translateY(0) scale(.98)}@media (max-width: 768px){.search-filter{flex-direction:column}.filter-button{width:100%;justify-content:center}}.class-tree-sidebar{width:300px;min-width:300px;background:transparent;border-right:none;height:calc(100vh - 160px);overflow-y:auto;overflow-x:hidden;position:sticky;top:120px}.sidebar-content{padding:24px 16px}.sidebar-title{font-size:14px;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:16px;padding:0 12px}.class-tree{display:flex;flex-direction:column;gap:4px}.tree-item{display:flex;align-items:center;width:100%;max-width:100%;padding:0;background:transparent;border:none;border-radius:8px;cursor:pointer;transition:all .2s ease;position:relative;color:var(--text-primary);overflow:hidden}.tree-item:hover{background:var(--hover-bg)}.tree-item.active{background:var(--primary-color);color:#fff}.tree-item.active .tree-item-count{background:#fff3;color:#fff}.tree-item-all{padding:12px;margin-bottom:12px;font-weight:600}.tree-item-grade{padding:0;font-weight:600}.tree-item-expand{padding:10px;background:transparent;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--text-secondary);transition:color .2s ease;flex-shrink:0}.tree-item-expand:hover{color:var(--text-primary)}.tree-item-button{flex:1;display:flex;align-items:center;padding:10px 12px 10px 4px;background:transparent;border:none;cursor:pointer;color:inherit}.tree-item-grade.active .tree-item-expand,.tree-item-grade.active .tree-item-button{color:#fff}.tree-item-class{padding:8px 12px 8px 48px;font-size:14px;width:100%;max-width:100%}.tree-item-class.empty{opacity:.5;cursor:default}.tree-item-class.empty:hover{background:transparent}.tree-item-icon{display:flex;align-items:center;justify-content:center;margin-right:12px;flex-shrink:0}.tree-item-content{display:flex;align-items:center;justify-content:space-between;flex:1;gap:8px;min-width:0;overflow:hidden}.tree-item-label{font-size:15px;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex-shrink:1}.tree-item-class .tree-item-label{font-size:14px;font-weight:400}.tree-item-count{font-size:12px;font-weight:600;background:var(--count-bg);color:var(--text-secondary);padding:2px 8px;border-radius:12px;min-width:24px;text-align:center;flex-shrink:0}.tree-grade-group{margin-bottom:4px}.tree-class-list{overflow:hidden;display:flex;flex-direction:column;gap:2px;margin-top:4px}.tree-class-group{display:flex;flex-direction:column;width:100%;max-width:100%}.tree-class-group .tree-item-class{padding:0;margin-left:24px;width:calc(100% - 24px);max-width:calc(100% - 24px)}.tree-class-group .tree-item-class .tree-item-expand{padding:8px 6px;flex-shrink:0}.tree-class-group .tree-item-class .tree-item-button{flex:1;display:flex;align-items:center;padding:8px 12px 8px 0;min-width:0;overflow:hidden}.tree-team-list{overflow:hidden;display:flex;flex-direction:column;gap:2px;margin-top:4px;margin-bottom:4px}.tree-item-team{padding:6px 12px;font-size:13px;color:var(--text-secondary);margin-left:52px;background:transparent;border:none;cursor:pointer;width:calc(100% - 52px);max-width:calc(100% - 52px);text-align:left;border-radius:8px;transition:all .2s ease;overflow:hidden}.tree-item-team:hover{background:var(--hover-bg);color:var(--text-primary)}.tree-item-team.active{background:var(--primary-color);color:#fff}.tree-item-team.active .tree-item-count{background:#fff3;color:#fff}.tree-item-team.active .tree-item-leader{color:#fbbf24}.tree-item-team .tree-item-content{display:flex;align-items:center;justify-content:space-between;gap:8px}.tree-item-team-info{display:flex;flex-direction:column;gap:2px;flex:1;min-width:0;overflow:hidden}.tree-item-team .tree-item-label{font-size:13px;font-weight:400;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.tree-item-leader{display:flex;align-items:center;gap:4px;font-size:11px;color:var(--text-tertiary);font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.tree-item-team .tree-item-count{font-size:11px;flex-shrink:0}.class-tree-sidebar::-webkit-scrollbar{width:6px}.class-tree-sidebar::-webkit-scrollbar-track{background:transparent}.class-tree-sidebar::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}.class-tree-sidebar::-webkit-scrollbar-thumb:hover{background:var(--text-secondary)}@media (max-width: 1024px){.class-tree-sidebar{width:240px;min-width:240px}.sidebar-content{padding:20px 12px}}@media (max-width: 768px){.class-tree-sidebar{display:none}}.login-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000bf;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);z-index:99999;display:flex;align-items:center;justify-content:center;padding:20px}.login-modal{background:var(--bg-elevated);border:1px solid var(--border);border-radius:20px;padding:48px 40px;width:100%;max-width:450px;box-shadow:0 25px 70px #0000004d,0 0 0 1px var(--border)}.login-header{text-align:center;margin-bottom:32px}.login-icon{display:inline-flex;align-items:center;justify-content:center;width:80px;height:80px;background:linear-gradient(135deg,var(--primary),var(--primary-hover));border-radius:20px;margin-bottom:24px;color:#fff;box-shadow:0 10px 30px #6366f14d}.login-header h2{font-size:28px;font-weight:700;color:var(--text);margin:0 0 8px;letter-spacing:-.02em}.login-header p{font-size:15px;color:var(--text-muted);margin:0}.login-form{display:flex;flex-direction:column;gap:20px}.password-input{width:100%;padding:16px 20px;font-size:16px;border:2px solid var(--border);border-radius:12px;background:var(--bg);color:var(--text);transition:all .2s ease;font-family:inherit;text-align:center;letter-spacing:.05em}.password-input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 4px #6366f11a}.password-input:disabled{opacity:.6;cursor:not-allowed}.error-message{display:flex;align-items:center;gap:8px;padding:12px 16px;background:#ef44441a;border:1px solid rgba(239,68,68,.3);border-radius:8px;color:#ef4444;font-size:14px}.login-button{padding:16px 24px;font-size:16px;font-weight:600;border:none;border-radius:12px;background:linear-gradient(135deg,var(--primary),var(--primary-hover));color:#fff;cursor:pointer;transition:all .2s ease;box-shadow:0 4px 12px #6366f14d}.login-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 16px #6366f166}.login-button:active:not(:disabled){transform:translateY(0)}.login-button:disabled{opacity:.6;cursor:not-allowed;transform:none}.login-hint{text-align:center;padding-top:16px;border-top:1px solid var(--border)}.login-hint p{margin:0;font-size:13px;color:var(--text-muted)}@media (max-width: 640px){.login-modal{padding:36px 28px}.login-icon{width:70px;height:70px}.login-header h2{font-size:24px}}.gallery-view-container{display:flex;height:100vh;width:100vw;background-color:#f8f9fa;color:#2c3e50;position:fixed;top:0;left:0;z-index:1000;overflow:hidden}@media (max-width: 768px){.gallery-view-container{flex-direction:column}}.gallery-sidebar{width:280px;background-color:#fff;border-right:1px solid #e0e0e0;display:flex;flex-direction:column;flex-shrink:0;overflow:hidden;position:relative}.resizer{width:5px;cursor:col-resize;background-color:transparent;transition:background-color .2s;z-index:100;flex-shrink:0;margin-left:-2px;margin-right:-2px}.resizer:hover,.resizer:active{background-color:#3b82f6}@media (max-width: 1024px) and (min-width: 769px){.gallery-sidebar{width:200px}}@media (max-width: 768px){.gallery-sidebar{width:100%;max-width:280px;position:fixed;left:-100%;top:0;height:100vh;z-index:1001;border-right:none;box-shadow:2px 0 10px #0000001a;transition:left .3s ease}.gallery-sidebar.mobile-open{left:0}}.gallery-sidebar-header{padding:16px;border-bottom:1px solid #e0e0e0}.back-button{display:flex;align-items:center;gap:8px;background:none;border:none;color:#666;cursor:pointer;font-size:14px;padding:8px;border-radius:4px;width:100%;transition:all .2s}.back-button:hover{background-color:#f0f0f0;color:#333}.gallery-main{flex:1;display:flex;flex-direction:column;height:100%;overflow:hidden}.gallery-toolbar{min-height:50px;background-color:#fff;border-bottom:1px solid #dee2e6;display:flex;align-items:center;justify-content:space-between;padding:0 20px;box-shadow:0 1px 2px #00000008;gap:16px;flex-wrap:wrap}@media (max-width: 1024px){.gallery-toolbar{padding:0 16px;gap:12px}}@media (max-width: 768px){.gallery-toolbar{min-height:60px;padding:8px 12px;gap:8px;flex-direction:column;align-items:stretch}}.toolbar-title{font-size:14px;color:#6c757d;font-family:SF Mono,Monaco,Consolas,monospace;font-weight:500}@media (max-width: 768px){.toolbar-title{font-size:12px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}}.toolbar-actions{display:flex;gap:12px}@media (max-width: 768px){.toolbar-actions{width:100%;gap:8px;flex-wrap:wrap}}.toolbar-button{display:flex;align-items:center;gap:6px;background:#f8f9fa;border:1px solid #dee2e6;color:#495057;padding:8px 14px;border-radius:6px;font-size:13px;font-weight:500;cursor:pointer;text-decoration:none;transition:all .2s ease}.toolbar-button.code-editor-button{background:linear-gradient(135deg,#0052cc,#0065ff);color:#fff;border-color:#0052cc;font-weight:700}.toolbar-button.code-editor-button:hover{background:linear-gradient(135deg,#003d99,#0052cc);border-color:#003d99;color:#fff;box-shadow:0 4px 12px #0052cc4d;transform:translateY(-1px)}@media (max-width: 1024px){.toolbar-button{padding:7px 12px;font-size:12px}}@media (max-width: 768px){.toolbar-button{padding:10px 12px;font-size:12px;flex:1;justify-content:center}}@media (max-width: 480px){.toolbar-button span{display:none}.toolbar-button{padding:10px;min-width:44px}}.toolbar-button:hover{background-color:#e9ecef;border-color:#adb5bd;color:#212529;transform:translateY(-1px);box-shadow:0 2px 4px #00000014}.gallery-content-area{flex:1;padding:0;overflow-y:auto;overflow-x:hidden;background-color:#f8f9fa;-webkit-overflow-scrolling:touch}.gallery-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:20px;padding:24px;width:100%;box-sizing:border-box}@media (min-width: 1441px){.gallery-grid{grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:24px;padding:32px}}@media (max-width: 1440px) and (min-width: 1025px){.gallery-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:20px;padding:24px}}@media (max-width: 1024px) and (min-width: 769px){.gallery-grid{grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:16px;padding:20px}}@media (max-width: 768px){.gallery-grid{grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:16px;padding:16px}}@media (max-width: 480px){.gallery-grid{grid-template-columns:1fr;gap:12px;padding:12px}}.pages-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:20px;padding:24px;width:100%;box-sizing:border-box}.page-card{background-color:#fff;border-radius:10px;overflow:hidden;cursor:pointer;border:1px solid #dee2e6;transition:all .3s cubic-bezier(.4,0,.2,1);box-shadow:0 2px 4px #0000000a;display:flex;flex-direction:column;height:100%;position:relative}@media (max-width: 768px){.page-card{border-radius:8px}.page-card:active{transform:scale(.98)}}.page-card:hover{border-color:#adb5bd;box-shadow:0 8px 16px #00000014;transform:translateY(-2px)}.page-preview{height:200px;background:linear-gradient(135deg,#f8f9fa,#e9ecef);position:relative;overflow:hidden;flex-shrink:0}@media (max-width: 1024px) and (min-width: 769px){.page-preview{height:180px}}@media (max-width: 768px){.page-preview{height:160px}}@media (max-width: 480px){.page-preview{height:140px}}.page-preview img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover;transition:transform .3s}.page-card:hover .page-preview img{transform:scale(1.05)}.page-preview-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;color:#ccc}.page-overlay{position:absolute;top:0;left:0;width:100%;height:100%;background-color:#00000080;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .2s;color:#fff}.page-card:hover .page-overlay{opacity:1}.page-info{padding:12px 16px;flex:1;display:flex;flex-direction:column;justify-content:center}.page-name{display:block;font-size:14px;font-weight:600;color:#212529;margin-bottom:4px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;letter-spacing:-.01em}.page-path{display:block;font-size:12px;color:#6c757d;font-family:SF Mono,Monaco,Consolas,monospace}.single-page-view{width:100%;height:100%;display:flex;align-items:center;justify-content:center}.preview-container{width:100%;height:100%;background-color:#fff;border-radius:4px;overflow:hidden}.page-iframe{width:100%;height:100%;border:none}.no-preview{width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;color:#999;background-color:#fafafa}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;width:100%;text-align:center;padding:40px}.file-type-badge{position:absolute;top:10px;right:10px;background:linear-gradient(135deg,#007bffe6,#0056b3e6);color:#fff;padding:5px 12px;border-radius:6px;font-size:10px;font-weight:700;letter-spacing:.8px;z-index:10;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);box-shadow:0 2px 8px #007bff40}.code-preview-card{position:relative;width:100%;height:100%;overflow:hidden}.code-preview-overlay{position:absolute;top:0;left:0;width:100%;height:100%;background:#ffffffd9;display:flex;flex-direction:column;align-items:center;justify-content:center;opacity:0;transition:opacity .2s ease;color:#333;pointer-events:none}.page-card:hover .code-preview-overlay{opacity:1}.code-preview-placeholder{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;color:#999;width:100%;height:100%;background:#fafafa}.code-viewer{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;background:#fff;color:#666}.download-button{position:absolute;bottom:12px;right:12px;background:#fffffffa;border:1px solid #dee2e6;border-radius:8px;padding:10px;cursor:pointer;opacity:0;transition:all .2s ease;z-index:10;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 8px #0000001a}@media (max-width: 768px){.download-button{opacity:1;padding:8px;bottom:8px;right:8px}}.page-card:hover .download-button{opacity:1}.download-button:hover{background:#007bff;color:#fff;border-color:#007bff;transform:scale(1.1);box-shadow:0 4px 12px #007bff4d}.code-viewer-container{background:#fff;border-radius:8px;border:1px solid #dee2e6;height:100%;display:flex;flex-direction:column;overflow:hidden}.code-viewer-header{padding:12px 16px;background:#f8f9fa;border-bottom:1px solid #dee2e6;display:flex;justify-content:space-between;align-items:center;font-weight:600;color:#495057;gap:12px;flex-wrap:wrap}.code-control-btn{background:transparent;border:1px solid #dee2e6;padding:6px;border-radius:4px;cursor:pointer;color:#6c757d;transition:all .2s;display:flex;align-items:center;justify-content:center}.code-control-btn:hover{background:#e9ecef;color:#212529;border-color:#adb5bd}.code-control-btn:active{transform:scale(.95)}.close-code-btn{background:transparent;border:1px solid #dee2e6;padding:4px 12px;border-radius:4px;cursor:pointer;font-size:12px;color:#6c757d;transition:all .2s}.close-code-btn:hover{background:#e9ecef;color:#212529}.code-content-wrapper{flex:1;overflow:hidden;background:#fff;border:1px solid #dee2e6;border-top:none;border-radius:0 0 8px 8px}.search-container{position:relative;display:flex;align-items:center;flex:1;max-width:400px}@media (max-width: 768px){.search-container{max-width:100%;width:100%}}.search-icon{position:absolute;left:12px;color:#6c757d;pointer-events:none}.search-input{width:100%;padding:8px 36px;border:1px solid #dee2e6;border-radius:6px;font-size:13px;color:#495057;background-color:#f8f9fa;transition:all .2s ease}@media (max-width: 768px){.search-input{padding:12px 40px;font-size:14px}}.search-input:focus{outline:none;border-color:#80bdff;background-color:#fff;box-shadow:0 0 0 3px #007bff1a}.search-input::-moz-placeholder{color:#adb5bd}.search-input::placeholder{color:#adb5bd}.clear-search-btn{position:absolute;right:8px;background:none;border:none;color:#6c757d;cursor:pointer;padding:4px;border-radius:4px;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.clear-search-btn:hover{background-color:#e9ecef;color:#495057}.empty-gallery{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;width:100%;text-align:center;padding:40px}@media (max-width: 768px){.empty-gallery{min-height:300px;padding:24px}}.mobile-sidebar-toggle{display:none;position:fixed;bottom:20px;right:20px;width:56px;height:56px;border-radius:50%;background:#007bff;color:#fff;border:none;box-shadow:0 4px 12px #007bff66;cursor:pointer;z-index:1000;align-items:center;justify-content:center;transition:all .3s ease}@media (max-width: 768px){.mobile-sidebar-toggle{display:flex}}.mobile-sidebar-toggle:active{transform:scale(.95)}.mobile-overlay{display:none;position:fixed;top:0;left:0;width:100%;height:100%;background:#00000080;z-index:1000;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}@media (max-width: 768px){.mobile-overlay.active{display:block}}@media (hover: none) and (pointer: coarse){.page-card:hover{transform:none}.page-card:hover .page-overlay,.page-card:hover .code-preview-overlay{opacity:0}.toolbar-button:hover{transform:none}}.gallery-section-header{padding:16px 24px;font-size:18px;font-weight:700;color:#2c3e50;background-color:#f8f9fa;display:flex;align-items:center;border-bottom:1px solid #e0e0e0;margin-bottom:8px}.pagination-controls{display:flex;align-items:center;justify-content:center;gap:20px;padding:24px;background:#fff;border-top:1px solid #dee2e6;margin-top:auto}.pagination-button{display:flex;align-items:center;gap:8px;padding:10px 20px;background:#f8f9fa;border:1px solid #dee2e6;border-radius:8px;color:#495057;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease}.pagination-button:hover:not(:disabled){background:#e9ecef;border-color:#adb5bd;transform:translateY(-1px);box-shadow:0 2px 4px #0000001a}.pagination-button:disabled{opacity:.4;cursor:not-allowed}.pagination-info{display:flex;flex-direction:column;align-items:center;gap:4px}.page-numbers{font-size:16px;font-weight:600;color:#212529}.total-items{font-size:12px;color:#6c757d}.loading-indicator{position:fixed;bottom:80px;right:20px;display:flex;align-items:center;gap:12px;padding:12px 20px;background:#fffffffa;border:1px solid #dee2e6;border-radius:8px;box-shadow:0 4px 12px #00000026;font-size:14px;color:#495057;z-index:999}.loading-spinner{width:20px;height:20px;border:3px solid #f3f3f3;border-top:3px solid #007bff;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media (max-width: 768px){.pagination-controls{gap:12px;padding:16px}.pagination-button span{display:none}.pagination-button{padding:10px;min-width:44px;justify-content:center}.page-numbers{font-size:14px}.total-items{font-size:11px}.loading-indicator{bottom:90px;right:10px;padding:10px 16px;font-size:12px}}:root{--font-sans: "Noto Sans KR", "Space Grotesk", sans-serif;--font-display: "Space Grotesk", "Noto Sans KR", sans-serif;--primary: #1d4ed8;--primary-hover: #1e40af;--primary-color: #1d4ed8;--secondary: #0ea5e9;--accent: #0f766e;--success: #16a34a;--warning: #f59e0b;--danger: #dc2626;--bg: #f4f6fb;--bg-secondary: #f8fafc;--bg-card: rgba(255, 255, 255, .96);--bg-glass: rgba(255, 255, 255, .82);--bg-elevated: rgba(255, 255, 255, .94);--card-bg: #ffffff;--text: #0f172a;--text-primary: #0f172a;--text-secondary: #475569;--text-tertiary: #94a3b8;--border: rgba(148, 163, 184, .35);--border-hover: rgba(100, 116, 139, .45);--hover-bg: rgba(15, 23, 42, .04);--count-bg: rgba(15, 23, 42, .06);--shadow: rgba(15, 23, 42, .08);--shadow-md: rgba(15, 23, 42, .12);--shadow-lg: rgba(15, 23, 42, .18);--shadow-xl: rgba(15, 23, 42, .24);--shadow-accent: rgba(37, 99, 235, .2);--shadow-green: rgba(16, 185, 129, .18);--gradient-1: linear-gradient(135deg, #1d4ed8 0%, #38bdf8 100%);--gradient-2: linear-gradient(135deg, #0f766e 0%, #14b8a6 100%);--gradient-3: linear-gradient(135deg, #16a34a 0%, #4ade80 100%);--gradient-4: linear-gradient(135deg, #1d4ed8 0%, #0ea5e9 100%)}*{margin:0;padding:0;box-sizing:border-box}body{font-family:var(--font-sans);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:radial-gradient(circle at 15% 12%,#fff,#f6f8fc 40%,#eef2f7);color:var(--text);min-height:100vh;line-height:1.6;transition:background .4s ease,color .3s ease;font-feature-settings:"rlig" 1,"calt" 1;position:relative;overflow-x:hidden}body:before{content:"";position:fixed;top:0;left:0;width:100%;height:100%;background:radial-gradient(circle 720px at 8% 18%,rgba(29,78,216,.08),transparent),radial-gradient(circle 560px at 92% 8%,rgba(15,118,110,.08),transparent),radial-gradient(circle 520px at 88% 78%,rgba(14,165,233,.08),transparent);z-index:-1;pointer-events:none;transition:opacity .4s ease}body:after{content:"";position:fixed;top:0;right:0;bottom:0;left:0;background-image:linear-gradient(transparent 0,transparent 28px,rgba(15,23,42,.03) 28px,rgba(15,23,42,.03) 29px),linear-gradient(90deg,transparent 0,transparent 28px,rgba(15,23,42,.03) 28px,rgba(15,23,42,.03) 29px);background-size:29px 29px;opacity:.12;z-index:-1;pointer-events:none}.app{max-width:1680px;margin:0 auto;padding:32px 48px 56px;position:relative;z-index:1}.header{margin-bottom:32px;position:relative;background:var(--bg-elevated);border:1px solid var(--border);border-radius:22px;padding:30px 34px;box-shadow:0 18px 40px #0f172a1f;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);overflow:hidden}.header:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(circle 320px at 8% 20%,rgba(29,78,216,.16),transparent 70%),radial-gradient(circle 260px at 92% 10%,rgba(15,118,110,.14),transparent 68%);opacity:.6;pointer-events:none}.header:after{content:"";position:absolute;right:-120px;top:-140px;width:280px;height:280px;background:radial-gradient(circle,rgba(14,165,233,.2),transparent 70%);opacity:.5;pointer-events:none}.header-content{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:24px;position:relative;z-index:1}.header-title{display:flex;align-items:center;gap:20px}.header-title-text{display:flex;flex-direction:column;gap:6px}.header-icon{color:var(--primary);filter:drop-shadow(0 4px 12px rgba(99,102,241,.3))}.header-logo{width:56px;height:56px;-o-object-fit:contain;object-fit:contain;filter:drop-shadow(0 4px 12px rgba(0,0,0,.08));transition:transform .3s ease}.header-logo:hover{transform:scale(1.05) rotate(2deg)}.header h1{font-size:32px;font-weight:800;background:linear-gradient(135deg,var(--text) 0%,var(--primary) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;letter-spacing:-.04em;line-height:1.1;margin:0;position:relative;font-family:var(--font-display)}.header-subtitle{font-size:14px;color:var(--text-secondary);letter-spacing:-.01em}.header-overview{margin-top:20px;display:grid;grid-template-columns:minmax(240px,1.1fr) minmax(260px,1fr);gap:24px;position:relative;z-index:1}.header-intro{display:grid;gap:10px;padding:16px 18px;border-radius:14px;border:1px solid rgba(29,78,216,.18);background:#ffffffd1;box-shadow:0 12px 24px #091e421f;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px)}.header-kicker{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.12em;color:var(--primary)}.header-description{font-size:14px;color:var(--text-secondary);line-height:1.6}.header-metrics{display:grid;grid-template-columns:repeat(4,minmax(90px,1fr));gap:12px}.metric-card{border-radius:14px;padding:12px 14px;border:1px solid rgba(255,255,255,.7);background:#ffffffeb;box-shadow:0 12px 24px #091e421f;display:grid;gap:6px;min-height:76px}.metric-card.accent{background:linear-gradient(135deg,#0ea5e924,#0f766e2e);border-color:#0ea5e947}.metric-card.success{background:linear-gradient(135deg,#00875a1f,#36b37e29);border-color:#00875a3d}.metric-label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--text-tertiary)}.metric-value{font-size:20px;font-weight:800;color:var(--text);letter-spacing:-.02em}@keyframes gradientShift{0%,to{background-position:0% 50%}50%{background-position:100% 50%}}.header-actions{display:flex;align-items:center;gap:12px;position:relative;z-index:1}.utility-button{display:flex;align-items:center;justify-content:center;position:relative;width:44px;height:44px;background:#ffffffe6;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid rgba(148,163,184,.3);border-radius:12px;color:var(--text-secondary);cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1);box-shadow:0 8px 18px #0f172a14}.utility-button:hover{background:var(--bg-card);border-color:#1d4ed866;color:var(--primary);transform:translateY(-2px);box-shadow:0 12px 24px #0f172a1f}.utility-button.delete{border-color:var(--danger);color:var(--danger);background:#de350b0d}.utility-button.delete:hover{background:var(--danger);color:#fff;border-color:var(--danger)}.utility-button.reset{border-color:var(--warning);color:var(--warning)}.utility-button.reset:hover{background:var(--warning);color:#fff;border-color:var(--warning)}.utility-button .badge{position:absolute;top:-8px;right:-8px;background:var(--danger);color:#fff;font-size:11px;font-weight:700;padding:2px 6px;border-radius:10px;min-width:20px;text-align:center}.add-button{display:inline-flex;align-items:center;gap:10px;padding:0 32px;height:44px;background:var(--gradient-1);color:#fff;border:none;border-radius:12px;font-size:14px;font-weight:700;letter-spacing:.01em;cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1);box-shadow:0 12px 24px #1d4ed840;position:relative;overflow:hidden}.add-button:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.3),transparent);transition:left .5s}.add-button:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(circle at center,rgba(255,255,255,.2),transparent 70%);opacity:0;transition:opacity .3s}.add-button:hover:before{left:100%}.add-button:hover{transform:translateY(-2px);box-shadow:0 16px 28px #1d4ed847}.add-button:hover:after{opacity:1}.add-button:active{transform:translateY(0)}.gallery-button{display:inline-flex;align-items:center;gap:8px;padding:0 20px;height:44px;background:var(--gradient-2);color:#fff;border:none;border-radius:12px;font-size:14px;font-weight:700;letter-spacing:.01em;cursor:pointer;box-shadow:0 12px 24px #0f766e40;transition:all .2s cubic-bezier(.4,0,.2,1)}.gallery-button:hover{transform:translateY(-2px);box-shadow:0 16px 28px #0f766e4d}.stats-overview{max-width:1800px;margin:0 auto 40px;padding:0}.main-layout{display:flex;gap:28px;align-items:flex-start;position:relative}.sidebar{width:280px;flex-shrink:0;position:sticky;top:40px}.sidebar-content{background:var(--bg-card);border:1px solid rgba(148,163,184,.3);border-radius:18px;padding:28px 22px;box-shadow:0 16px 32px #0f172a14;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);position:relative;transition:all .2s cubic-bezier(.4,0,.2,1)}.sidebar-content:hover{box-shadow:0 18px 36px #0f172a1f}.sidebar-title{font-size:12px;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.08em;margin-bottom:16px;padding:0 8px}.grade-nav{display:flex;flex-direction:column;gap:2px}.grade-nav-button{display:flex;align-items:center;gap:14px;padding:14px 18px;background:transparent;border:none;border-left:4px solid transparent;border-radius:6px;cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden}.grade-nav-button:before{content:"";position:absolute;top:0;left:0;bottom:0;right:0;background:var(--bg-glass);opacity:0;transition:opacity .2s}.grade-nav-button:hover{background:var(--bg-glass);border-left-color:var(--border-hover)}.grade-nav-button.active{background:#1d4ed81f;border-left-color:var(--primary);box-shadow:inset 0 1px 2px #1d4ed81f}.grade-nav-button.active .grade-nav-icon{color:var(--primary)}.grade-nav-button.active .grade-nav-label{color:var(--primary);font-weight:600}.grade-nav-icon{display:flex;align-items:center;justify-content:center;width:20px;height:20px;color:var(--text-secondary);transition:all .12s ease-in-out;flex-shrink:0}.grade-nav-info{display:flex;flex-direction:row;align-items:center;gap:8px;flex:1;color:var(--text);transition:color .2s}.grade-nav-label{font-size:14px;font-weight:500;line-height:1.4;letter-spacing:0;color:var(--text)}.grade-nav-count{font-size:12px;color:var(--text-tertiary);font-weight:500;background:var(--bg-glass);padding:2px 8px;border-radius:12px;margin-left:auto}.grade-nav-button.active .grade-nav-count{background:#0066cc1f;color:var(--primary)}.grade-nav-indicator{display:none}.main-content{flex:1;min-width:0;background:var(--bg-card);border:1px solid rgba(148,163,184,.3);border-radius:20px;padding:26px;box-shadow:0 18px 36px #0f172a1a;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px)}.controls-row{display:flex;gap:16px;align-items:center;margin-bottom:24px;padding:16px;border:1px solid rgba(148,163,184,.3);border-radius:16px;background:#ffffffd9;box-shadow:0 12px 24px #0f172a14}.sort-controls{display:flex;gap:8px;flex-shrink:0}.sort-button{display:inline-flex;align-items:center;gap:6px;padding:0 16px;height:44px;background:#fffc;border:1px solid rgba(148,163,184,.3);border-radius:12px;color:var(--text-secondary);font-size:13px;font-weight:600;font-family:inherit;cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1);box-shadow:0 6px 16px #0f172a14;white-space:nowrap}.sort-button:hover{background:var(--bg-glass);border-color:#1d4ed84d;color:var(--text);box-shadow:0 10px 20px #0f172a1f}.sort-button.active{background:var(--gradient-1);border-color:transparent;color:#fff;box-shadow:0 12px 20px #1d4ed83d}.sort-button.active:hover{background:var(--gradient-4);border-color:transparent}.projects-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:24px}.projects-grid-header{display:flex;align-items:center;justify-content:space-between;padding:12px 0;margin-bottom:8px}.projects-grid-header h3{font-size:18px;font-weight:700;color:var(--text);margin:0;display:flex;align-items:center;gap:12px;font-family:var(--font-display)}.projects-grid-header h3:before{content:"";width:4px;height:24px;background:var(--gradient-1);border-radius:4px}.projects-count-badge{background:#ffffffc7;color:var(--text-secondary);padding:6px 14px;border-radius:20px;font-size:13px;font-weight:600;border:1px solid rgba(148,163,184,.3);box-shadow:0 6px 12px #0f172a14}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:100px 32px;text-align:center;background:var(--bg-glass);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border:2px dashed var(--border);border-radius:24px;box-shadow:0 4px 24px var(--shadow);position:relative;overflow:hidden}.empty-state:before{content:"";position:absolute;top:-2px;right:-2px;bottom:-2px;left:-2px;background:conic-gradient(from 0deg,transparent,var(--primary),transparent);opacity:.1;animation:borderRotate 8s linear infinite;border-radius:24px}.empty-icon{color:var(--text-tertiary);margin-bottom:24px;opacity:.5;position:relative;z-index:1;animation:float 3s ease-in-out infinite}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.empty-state h2{font-size:24px;margin-bottom:12px;color:var(--text);font-weight:700;position:relative;z-index:1}.empty-state p{color:var(--text-secondary);font-size:16px;position:relative;z-index:1}@media (max-width: 1200px){.main-layout{flex-direction:column}.sidebar{width:100%;position:relative;top:0}.grade-nav{flex-direction:row;overflow-x:auto;padding-bottom:8px}.grade-nav-button{flex-shrink:0;min-width:200px}.projects-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width: 768px){.app{padding:24px 16px}.header h1{font-size:32px}.grade-title{font-size:26px}.header-content{flex-direction:column;align-items:flex-start;gap:16px}.header-overview{grid-template-columns:1fr}.header-metrics{grid-template-columns:repeat(2,minmax(120px,1fr))}.header-title{gap:12px}.header-icon{width:32px;height:32px}.header-actions{width:100%}.add-button{flex:1;justify-content:center}.sidebar-content{padding:20px}.grade-nav-button{min-width:160px;padding:14px 16px}.grade-nav-icon{width:40px;height:40px}.projects-grid{grid-template-columns:1fr}}.projects-container{width:100%}.grade-header{margin-bottom:32px}.grade-header-content{display:flex;align-items:center;gap:16px;margin-bottom:16px}.grade-title{font-size:36px;font-weight:700;color:var(--text);letter-spacing:-.03em;margin:0;line-height:1.2;font-family:var(--font-display)}.grade-count-badge{padding:10px 18px;background:#ffffffdb;border:1px solid rgba(148,163,184,.3);border-radius:12px;font-size:15px;font-weight:700;color:var(--text-secondary);letter-spacing:-.01em;box-shadow:0 10px 18px #0f172a1a}.grade-divider{height:2px;background:var(--border);border-radius:2px;position:relative;overflow:hidden}.tab-switcher-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#091e4266;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:1200}.tab-switcher{width:min(980px,92vw);max-height:80vh;background:var(--bg-card);border:1px solid var(--border);border-radius:18px;padding:20px 24px;box-shadow:0 24px 64px var(--shadow-xl);display:flex;flex-direction:column;gap:16px;overflow:hidden}.tab-switcher-header{display:flex;align-items:flex-start;justify-content:space-between;gap:16px}.tab-switcher-title{font-size:18px;font-weight:700;color:var(--text)}.tab-switcher-subtitle{font-size:13px;color:var(--text-tertiary);margin-top:4px}.tab-switcher-close{border:1px solid var(--border);background:var(--bg-glass);border-radius:8px;padding:6px 10px;cursor:pointer;color:var(--text-secondary);transition:all .2s ease}.tab-switcher-close:hover{border-color:var(--primary);color:var(--primary);background:var(--bg-card)}.tab-switcher-tabs{display:flex;flex-wrap:wrap;gap:10px}.tab-switcher-tabs.secondary{gap:8px}.tab-switcher-tab{border:1px solid var(--border);background:var(--bg-glass);border-radius:999px;padding:6px 14px;font-size:13px;color:var(--text-secondary);cursor:pointer;transition:all .2s ease}.tab-switcher-tab:hover{border-color:var(--primary);color:var(--primary)}.tab-switcher-tab.active{background:var(--gradient-1);color:#fff;border-color:transparent;box-shadow:0 6px 12px var(--shadow-accent)}.tab-switcher-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(210px,1fr));gap:12px;overflow-y:auto;padding-right:4px}.tab-switcher-empty{padding:18px;background:var(--bg-glass);border-radius:12px;border:1px dashed var(--border);color:var(--text-tertiary);text-align:center}.tab-project-card{border:1px solid var(--border);border-radius:12px;padding:12px 14px;background:var(--bg-elevated);cursor:pointer;text-align:left;transition:all .2s ease}.tab-project-card:hover{transform:translateY(-2px);border-color:var(--primary);box-shadow:0 10px 18px var(--shadow-md)}.tab-project-title{font-weight:600;color:var(--text);font-size:14px;margin-bottom:6px}.tab-project-meta{display:flex;justify-content:space-between;font-size:12px;color:var(--text-tertiary)}@media (max-width: 720px){.tab-switcher{padding:16px}.tab-switcher-grid{grid-template-columns:1fr}}*{box-sizing:border-box}body{margin:0;padding:0;font-feature-settings:"rlig" 1,"calt" 1}
