.project-gallery{width:100%;max-width:1200px;padding-top:var(--spacing-4);align-self:flex-start;margin-top:auto}.section-title{color:var(--color-text-primary);margin-bottom:var(--spacing-3);letter-spacing:.2px;font-size:15px;font-weight:600}.gallery-grid{gap:var(--spacing-5);grid-template-columns:repeat(auto-fill,minmax(280px,1fr));width:100%;display:grid}.project-card{border-radius:var(--radius-lg);transition:all var(--transition-normal);position:relative;overflow:hidden}.project-card:hover{box-shadow:var(--shadow-md);transform:translateY(-4px)}.new-card{background-color:var(--color-surface-hover);border:1px dashed var(--color-border);height:220px}.new-card:hover{border-color:var(--color-border-hover);background-color:#efefef}.new-card .card-image-placeholder{justify-content:center;align-items:center;gap:var(--spacing-2);height:100%;color:var(--color-text-secondary);flex-direction:column;display:flex}.new-icon{margin-bottom:var(--spacing-1)}.new-text{font-size:14px;font-weight:500}.active-card{background-color:var(--color-surface);border:1px solid var(--color-border);flex-direction:column;height:220px;display:flex}.card-image-box{border-bottom:1px solid var(--color-border);flex:1;width:100%;position:relative;overflow:hidden}.card-image{object-fit:cover;width:100%;height:100%;transition:transform var(--transition-slow)}.active-card:hover .card-image{transform:scale(1.05)}.card-carousel-img{object-fit:cover;opacity:0;width:100%;height:100%;transition:opacity .4s;position:absolute;inset:0}.card-carousel-img.active{opacity:1}.card-carousel-dots{z-index:2;gap:4px;display:flex;position:absolute;bottom:8px;left:50%;transform:translate(-50%)}.card-carousel-dot{background:#ffffff80;border-radius:50%;width:6px;height:6px;transition:all .2s}.card-carousel-dot.active{background:#fff;transform:scale(1.3)}.card-carousel-count{color:#fff;z-index:2;background:#00000073;border-radius:4px;padding:2px 6px;font-size:11px;position:absolute;top:8px;right:8px}.card-info{padding:var(--spacing-3);background-color:var(--color-surface);position:relative}.card-title-row{justify-content:space-between;align-items:center;gap:var(--spacing-1);display:flex}.card-title{color:var(--color-text-primary);text-overflow:ellipsis;white-space:nowrap;flex:1;margin-bottom:2px;font-size:14px;font-weight:500;overflow:hidden}.card-actions{opacity:0;transition:opacity var(--transition-fast);gap:2px;display:flex}.project-card:hover .card-actions{opacity:1}.card-action-btn{border-radius:var(--radius-sm);width:26px;height:26px;color:var(--color-text-tertiary);cursor:pointer;transition:all var(--transition-fast);background:0 0;border:none;flex-shrink:0;justify-content:center;align-items:center;display:flex}.card-action-btn:hover{background:var(--color-surface-hover);color:var(--color-text-primary)}.card-action-delete:hover{color:#dc2626;background:#fef2f2}.card-title-edit{align-items:center;gap:var(--spacing-1);display:flex}.card-title-input{border:1px solid var(--color-primary);border-radius:var(--radius-sm);background:var(--color-surface);outline:none;flex:1;padding:4px 8px;font-size:14px;font-weight:500}.card-date{color:var(--color-text-tertiary);font-size:12px}.card-description{color:var(--color-text-secondary);text-overflow:ellipsis;white-space:nowrap;margin-top:4px;font-size:12px;overflow:hidden}.card-action-enter:hover{color:#2563eb;background:#eff6ff}.bg-pattern{background:linear-gradient(135deg,#f5f7fa 0%,#c3cfe2 100%)}.card-delete-overlay{-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);z-index:10;border-radius:var(--radius-lg);background:#00000073;justify-content:center;align-items:center;display:flex;position:absolute;inset:0}.card-delete-confirm{background:var(--color-surface);border-radius:var(--radius-md);padding:var(--spacing-4);width:85%;box-shadow:var(--shadow-lg)}.card-delete-warning{color:var(--color-text-primary);margin-bottom:var(--spacing-2);font-size:14px;font-weight:600}.card-delete-detail{color:var(--color-text-secondary);margin-bottom:var(--spacing-3);font-size:12px;line-height:1.5}.card-delete-actions{justify-content:flex-end;gap:var(--spacing-2);display:flex}.card-delete-cancel,.card-delete-confirm-btn{border-radius:var(--radius-sm);cursor:pointer;border:1px solid var(--color-border);background:var(--color-surface);color:var(--color-text-primary);transition:all var(--transition-fast);padding:6px 14px;font-size:13px}.card-delete-cancel:hover{background:var(--color-surface-hover)}.card-delete-confirm-btn{color:#fff;background:#dc2626;border-color:#dc2626}.card-delete-confirm-btn:hover{background:#b91c1c}.card-delete-confirm-btn:disabled{opacity:.6;cursor:not-allowed}.card-deleting-overlay{justify-content:center;align-items:center;gap:var(--spacing-2);-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);z-index:20;border-radius:var(--radius-lg);background:#ffffffbf;flex-direction:column;display:flex;position:absolute;inset:0}.card-deleting-spinner{border:2px solid var(--color-border);border-top-color:var(--color-primary);border-radius:50%;width:24px;height:24px;animation:.6s linear infinite card-spin}.card-deleting-overlay span{color:var(--color-text-secondary);font-size:13px}@keyframes card-spin{to{transform:rotate(360deg)}}.pagination{justify-content:center;align-items:center;gap:var(--spacing-4);margin-top:var(--spacing-6);padding:var(--spacing-4);display:flex}.pagination-btn{border:1px solid var(--color-border);border-radius:var(--radius-sm);background-color:var(--color-surface);color:var(--color-text-primary);cursor:pointer;transition:all var(--transition-fast);padding:8px 16px;font-size:14px}.pagination-btn:hover:not(:disabled){background-color:var(--color-surface-hover);border-color:var(--color-border-hover)}.pagination-btn:disabled{opacity:.5;cursor:not-allowed}.pagination-info{color:var(--color-text-secondary);font-size:14px}.gallery-view-all{text-align:center;margin-top:var(--spacing-4)}.view-all-link{color:var(--color-text-secondary);transition:color var(--transition-fast);font-size:14px;text-decoration:none}.view-all-link:hover{color:var(--color-primary)}.gallery-search{align-items:center;gap:var(--spacing-2);margin-bottom:var(--spacing-4);border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-surface);max-width:360px;padding:8px 12px;display:flex}.gallery-search-icon{color:var(--color-text-tertiary);flex-shrink:0}.gallery-search-input{color:#1a1a1a;background:0 0;border:none;outline:none;flex:1;font-size:14px}.gallery-search-clear{color:#999;cursor:pointer;background:0 0;border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:24px;height:24px;display:flex}.gallery-search-clear:hover{color:#666;background:#f0f0f0}.gallery-search-btn{border-radius:var(--radius-sm);background:var(--color-primary,#1a1a1a);color:#fff;cursor:pointer;border:none;flex-shrink:0;padding:4px 14px;font-size:13px}.gallery-search-btn:hover{opacity:.85}.gallery-search-input::placeholder{color:var(--color-text-tertiary)}
