.gallery-container{min-height:100vh;background:#f7fafc;padding:2rem 0}.container{max-width:1200px;margin:0 auto;padding:0 1rem}.gallery-controls{background:#ffffff;border:1px solid #e5e7eb;border-radius:12px;margin-bottom:1.5rem;box-shadow:0 1px 3px rgba(0,0,0,.05);overflow:hidden}.primary-controls{display:flex;align-items:center;gap:1rem;padding:1rem 1.5rem;border-bottom:1px solid #f3f4f6;flex-wrap:wrap}@media (max-width:768px){.primary-controls{flex-direction:column;align-items:stretch;gap:.75rem}}.search-container{flex:1;min-width:240px;max-width:400px}.search-input-wrapper{position:relative;display:flex;align-items:center}.search-icon{position:absolute;left:12px;color:#9ca3af;z-index:2}.search-input-modern{width:100%;padding:8px 12px 8px 40px;border:1px solid #d1d5db;border-radius:8px;font-size:14px;font-weight:400;background:#ffffff;transition:all .2s ease;outline:none}.search-input-modern:focus{border-color:#3b82f6;box-shadow:0 0 0 3px rgba(59,130,246,.1)}.search-input-modern::placeholder{color:#9ca3af}.search-clear{position:absolute;right:8px;padding:4px;border:none;background:none;color:#6b7280;cursor:pointer;border-radius:4px;transition:all .2s ease}.search-clear:hover{background:#f3f4f6;color:#374151}.control-pills{gap:.5rem;flex-wrap:wrap}.control-pills,.filter-pill{display:flex;align-items:center}.filter-pill{gap:4px;padding:4px 8px;background:#eff6ff;border:1px solid #dbeafe;border-radius:6px;font-size:12px;color:#1e40af;font-weight:500}.pill-label{color:#1e40af;font-weight:600}.pill-value{color:#1f2937}.pill-remove{border:none;background:none;color:#6b7280;cursor:pointer;width:16px;height:16px;display:flex;align-items:center;justify-content:center;border-radius:50%;font-weight:700;line-height:1;transition:all .2s ease}.pill-remove:hover{background:#fbbf24;color:#ffffff}.filter-toggle{display:flex;align-items:center;gap:6px;padding:6px 12px;border:1px solid #d1d5db;border-radius:8px;background:#ffffff;color:#374151;font-size:13px;font-weight:500;cursor:pointer;transition:all .2s ease;position:relative}.filter-toggle:hover{background:#f9fafb;border-color:#9ca3af}.filter-toggle.active{background:#3b82f6;border-color:#3b82f6;color:#ffffff}.filter-count{background:#dc2626;color:#ffffff;font-size:10px;font-weight:600;padding:2px 6px;border-radius:10px;line-height:1;margin-left:4px}.filter-toggle.active .filter-count{background:rgba(255,255,255,.2);color:#ffffff}.layout-view-controls{display:flex;align-items:center;gap:8px}.sort-dropdown{position:relative}.sort-select{padding:6px 28px 6px 12px;border:1px solid #d1d5db;border-radius:8px;background:#ffffff url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 20 20'%3e%3cpath stroke='%236b7280' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='M6 8l4 4 4-4'/%3e%3c/svg%3e") no-repeat right 8px center/16px 16px;font-size:13px;font-weight:500;color:#374151;cursor:pointer;outline:none;appearance:none;transition:all .2s ease}.sort-select:hover{border-color:#9ca3af}.sort-select:focus{border-color:#3b82f6;box-shadow:0 0 0 3px rgba(59,130,246,.1)}.layout-toggle{display:flex;border:1px solid #d1d5db;border-radius:8px;overflow:hidden;background:#ffffff}.layout-btn{padding:6px 10px;background:#ffffff;color:#6b7280;font-size:14px;cursor:pointer;transition:all .2s ease;border:none;border-right:1px solid #e5e7eb}.layout-btn:last-child{border-right:none}.layout-btn:hover{background:#f9fafb;color:#374151}.layout-btn.active{background:#3b82f6;color:#ffffff}.advanced-filters-panel{background:#ffffff;border-top:1px solid #e5e7eb;animation:slideDown .2s ease-out}@keyframes slideDown{0%{opacity:0;max-height:0}to{opacity:1;max-height:500px}}.filters-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.5rem .75rem;border-bottom:1px solid #f3f4f6}.filters-header h3{font-size:14px;font-weight:600;color:#111827;margin:0;text-transform:uppercase;letter-spacing:.05em}.clear-all-btn{padding:4px 8px;border:none;border-radius:4px;background:#f3f4f6;color:#6b7280;font-size:11px;font-weight:500;cursor:pointer;transition:all .15s ease;text-transform:uppercase;letter-spacing:.025em}.clear-all-btn:hover{background:#e5e7eb;color:#374151}.filters-content{padding:1rem 1.5rem 1.5rem}.inline-filters{display:flex;flex-wrap:wrap;gap:1.5rem;align-items:flex-start}@media (max-width:768px){.inline-filters{flex-direction:column;gap:1rem}}.filter-group{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap}.filter-label{font-size:12px;font-weight:600;color:#6b7280;text-transform:uppercase;letter-spacing:.025em;min-width:60px;flex-shrink:0}.filter-options{display:flex;flex-wrap:wrap;gap:4px}.option-pill{padding:3px 10px;border:1px solid #e5e7eb;border-radius:12px;background:#ffffff;color:#6b7280;font-size:12px;font-weight:500;cursor:pointer;transition:all .15s ease;white-space:nowrap;user-select:none}.option-pill:hover{border-color:#3b82f6;background:#f8faff;color:#3b82f6}.option-pill.selected{border-color:#3b82f6;background:#3b82f6;color:#ffffff}.date-range-compact{display:flex;align-items:center;gap:6px}.date-input-compact{padding:3px 8px;border:1px solid #e5e7eb;border-radius:4px;font-size:11px;color:#374151;background:#ffffff;width:90px;text-align:center}.date-input-compact:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 2px rgba(59,130,246,.1)}.date-separator{color:#d1d5db;font-size:11px}.date-range-inputs{display:flex;gap:12px;flex-wrap:wrap}.date-input-group{display:flex;flex-direction:column;gap:4px;flex:1;min-width:120px}.date-input-group label{font-size:12px;font-weight:500;color:#6b7280;text-transform:uppercase;letter-spacing:.025em}.date-input-modern{padding:6px 8px;border:1px solid #d1d5db;border-radius:6px;font-size:13px;color:#374151;background:#ffffff;cursor:pointer;transition:all .2s ease;outline:none}.date-input-modern:focus{border-color:#3b82f6;box-shadow:0 0 0 3px rgba(59,130,246,.1)}.results-bar{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1.5rem;background:#f9fafb;border-top:1px solid #f3f4f6;flex-wrap:wrap;gap:1rem}@media (max-width:768px){.results-bar{flex-direction:column;align-items:stretch;gap:.75rem}}.results-info{display:flex;align-items:center;gap:4px;font-size:13px;color:#6b7280}.results-count{font-weight:600;color:#111827}.separator{margin:0 4px;color:#d1d5db}.selected-count{font-weight:500;color:#3b82f6}.results-actions{align-items:center;flex-wrap:wrap}.batch-actions,.results-actions{display:flex;gap:8px}.action-btn{gap:6px;padding:6px 12px;border:1px solid #d1d5db;border-radius:6px;background:#ffffff;color:#374151;font-size:12px;font-weight:500;white-space:nowrap}.action-btn:hover{background:#f9fafb;border-color:#9ca3af}.download-btn:hover{background:#ecfdf5;border-color:#10b981;color:#059669}.delete-btn:hover{background:#fef2f2;border-color:#ef4444;color:#dc2626}.select-all-btn{padding:6px 12px;border:1px solid #d1d5db;border-radius:6px;background:#ffffff;color:#374151;font-size:12px;font-weight:500;cursor:pointer;transition:all .2s ease}.select-all-btn:hover{background:#f9fafb;border-color:#9ca3af}.generate-btn{display:flex;align-items:center;gap:6px;padding:6px 12px;border:none;border-radius:6px;background:#3b82f6;color:#ffffff;font-size:12px;font-weight:500;text-decoration:none;cursor:pointer;transition:all .2s ease;white-space:nowrap}.generate-btn:hover{background:#2563eb;transform:translateY(-1px);box-shadow:0 4px 8px rgba(59,130,246,.3)}@media (min-width:768px){.gallery-controls{flex-direction:row;align-items:center;justify-content:space-between}}.gallery-search{flex:1;max-width:400px}.search-input{width:100%;padding:.75rem 1rem;border:2px solid #e2e8f0;border-radius:8px;font-size:1rem;transition:all .2s ease;background:white}.search-input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px rgba(102,126,234,.1)}.gallery-actions{display:flex;gap:.75rem;flex-wrap:wrap;align-items:center}.btn{padding:.75rem 1.5rem;border:none;border-radius:8px;font-size:.875rem;font-weight:600;text-decoration:none;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease;white-space:nowrap}.btn-small{padding:.5rem 1rem;font-size:.75rem}.btn-primary{background:linear-gradient(135deg,#667eea,#764ba2);color:white}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 4px 12px rgba(102,126,234,.4)}.btn-secondary{background:#f7fafc;color:#4a5568;border:2px solid #e2e8f0}.btn-secondary:hover{background:#edf2f7;border-color:#cbd5e0}.btn-danger{background:#fed7d7;color:#c53030;border:2px solid #feb2b2}.btn-danger:hover{background:#fbb6ce;border-color:#f687b3}.gallery-grid{display:grid;gap:1.5rem}.gallery-grid.layout-compact{grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}.gallery-grid.layout-large{grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:2rem}.gallery-grid.layout-list{grid-template-columns:1fr;gap:1rem}.layout-list .image-card{display:flex;flex-direction:row;max-height:150px}.layout-list .image-preview{width:200px;height:150px;flex-shrink:0;aspect-ratio:auto}.layout-list .image-info{flex:1;padding:1rem;display:flex;flex-direction:column;justify-content:space-between}.layout-list .club-info{margin-bottom:.5rem}.layout-list .image-metadata{display:grid;grid-template-columns:repeat(2,1fr);gap:.25rem}.gallery-grid.layout-masonry{columns:280px;column-gap:1.5rem}.layout-masonry .image-card{break-inside:avoid;margin-bottom:1.5rem;display:inline-block;width:100%}.layout-masonry .image-preview{aspect-ratio:auto;height:auto}.image-card{background:var(--gray-50);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow);transition:var(--transition);cursor:pointer;position:relative;border:2px solid transparent}.image-card:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,var(--primary),var(--secondary));transform:scaleX(0);transition:transform .3s ease;z-index:10}.image-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-2px);border-color:var(--primary-light)}.image-card:hover:before{transform:scaleX(1)}.image-card.selected{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-light)}.image-card.selected:before{transform:scaleX(1)}.image-checkbox{position:absolute;top:.75rem;left:.75rem;z-index:10}.image-checkbox-right{left:auto;right:.75rem}.image-checkbox input[type=checkbox]{width:1.25rem;height:1.25rem;border-radius:4px;border:2px solid white;background:rgba(255,255,255,.9);cursor:pointer}.image-checkbox input[type=checkbox]:checked{background:#667eea;border-color:#667eea}.image-preview{position:relative;aspect-ratio:1;overflow:hidden;background:#f8f9fa;display:flex;align-items:center;justify-content:center;cursor:pointer}.image-preview img{width:100%;height:100%;object-fit:contain}.image-info{padding:1rem}.image-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:.5rem;gap:.5rem}.image-title{font-size:1.1rem;font-weight:700;color:#2d3748;line-height:1.2;flex:1;min-width:0}.boat-type-badge{background:var(--primary-light);color:var(--primary);padding:.125rem .375rem;border-radius:.25rem;font-size:.75rem;font-weight:600;flex-shrink:0;align-self:flex-start}.image-subtitle{font-size:.875rem;color:#718096;margin-bottom:.75rem}.image-created-date{position:absolute;bottom:.75rem;left:.75rem;font-size:.75rem;color:#9ca3af;opacity:.8}.club-info{display:flex;align-items:center;justify-content:space-between;gap:.5rem;margin-bottom:.75rem;padding:.5rem;background:#f8f9fa;border-radius:6px}.club-name-prominent{font-size:.875rem;color:#2d3748;font-weight:700;flex:1}.club-colors{display:flex;align-items:center;gap:.5rem;margin-bottom:.5rem}.club-name{font-size:.75rem;color:#4a5568;font-weight:600}.color-swatches{display:flex;gap:.25rem}.color-swatches.inline{margin-left:.5rem}.color-swatch{width:1rem;height:1rem;border-radius:50%;border:2px solid rgba(255,255,255,.8);box-shadow:0 1px 3px rgba(0,0,0,.1)}.image-metadata{margin-bottom:1rem;font-size:.75rem}.metadata-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:.25rem}.metadata-label{color:#6b7280;font-weight:500}.metadata-value{color:#374151;font-weight:600}.image-actions-hover{position:absolute;top:.75rem;right:.75rem;opacity:0;transform:translateY(-10px);transition:all .2s ease;z-index:20}.image-card:hover .image-actions-hover{opacity:1;transform:translateY(0)}.action-group{display:flex;gap:.25rem;background:rgba(0,0,0,.8);border-radius:6px;padding:.25rem;backdrop-filter:blur(4px)}.action-btn{width:2rem;height:2rem;border:none;border-radius:4px;background:rgba(255,255,255,.2);color:white;font-size:.875rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.action-btn:hover{background:rgba(255,255,255,.3);transform:scale(1.1)}.action-btn.download:hover{background:rgba(34,197,94,.8)}.action-btn.copy:hover{background:rgba(59,130,246,.8)}.action-btn.regenerate:hover{background:rgba(251,191,36,.8)}.action-btn.delete:hover{background:rgba(239,68,68,.8)}.image-actions-mobile{display:flex;gap:.5rem;flex-wrap:wrap}@media (min-width:768px){.image-actions-mobile{display:none}}@media (max-width:767px){.image-actions-hover{display:none}}.empty-state{text-align:center;padding:4rem 2rem;background:rgba(255,255,255,.95);backdrop-filter:blur(10px);border-radius:12px;box-shadow:0 8px 32px rgba(0,0,0,.1)}.empty-state h2{font-size:2rem;font-weight:700;color:#2d3748;margin-bottom:1rem}.empty-state p{font-size:1.1rem;color:#718096;margin-bottom:2rem;max-width:500px;margin-left:auto;margin-right:auto}.loading-state{text-align:center;padding:4rem 2rem;background:rgba(255,255,255,.95);backdrop-filter:blur(10px);border-radius:12px;box-shadow:0 8px 32px rgba(0,0,0,.1)}.loading-spinner{width:3rem;height:3rem;border:4px solid #e2e8f0;border-top-color:#667eea;border-radius:50%;animation:spin 1s linear infinite;margin:0 auto 1.5rem}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.loading-state h3{font-size:1.25rem;color:#4a5568;font-weight:600}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.8);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.modal-content{background:white;border-radius:12px;max-width:90vw;max-height:90vh;overflow:hidden;box-shadow:0 20px 60px rgba(0,0,0,.3);animation:modalSlideIn .3s ease-out}@keyframes modalSlideIn{0%{opacity:0;transform:scale(.9) translateY(20px)}to{opacity:1;transform:scale(1) translateY(0)}}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:1.5rem;border-bottom:1px solid #e2e8f0;background:#f7fafc}.modal-title{font-size:1.25rem;font-weight:700;color:#2d3748}.modal-close{background:none;border:none;font-size:1.5rem;color:#718096;cursor:pointer;padding:.25rem;border-radius:4px;transition:color .2s ease}.modal-close:hover{color:#4a5568}.modal-body{padding:2rem;overflow-y:auto;max-height:calc(90vh - 120px)}.fullscreen-image{width:100%;max-width:600px;height:auto;border-radius:8px;margin-bottom:2rem;box-shadow:0 4px 20px rgba(0,0,0,.1)}.modal-details{max-width:600px}.detail-section{margin-bottom:2rem}.detail-section h4{font-size:1.1rem;font-weight:700;color:#2d3748;margin-bottom:1rem;border-bottom:2px solid #e2e8f0;padding-bottom:.5rem}.detail-grid{display:grid;gap:.75rem}.detail-item{display:flex;align-items:center;gap:.75rem}.detail-label{font-weight:600;color:#4a5568;min-width:100px}.detail-value{color:#2d3748;display:flex;align-items:center;gap:.5rem}.modal-actions{display:flex;gap:1rem;margin-top:2rem;padding-top:2rem;border-top:1px solid #e2e8f0}@media (max-width:768px){.container{padding:0 .75rem}.gallery-container{padding:1rem 0}.gallery-controls{padding:1rem}.gallery-actions{width:100%;justify-content:stretch}.gallery-actions .btn{flex:1;min-width:0}.gallery-grid{grid-template-columns:1fr;gap:1rem}.image-actions{justify-content:stretch}.image-actions .btn{flex:1}.modal-content{margin:.5rem;max-width:calc(100vw - 1rem)}.modal-body{padding:1rem}.detail-item,.modal-actions{flex-direction:column}.detail-item{align-items:flex-start;gap:.25rem}.detail-label{min-width:auto}}@media (max-width:480px){.gallery-controls{padding:.75rem}.search-input{padding:.5rem .75rem;font-size:.875rem}.btn{padding:.5rem 1rem;font-size:.75rem}.btn-small{padding:.375rem .75rem;font-size:.6875rem}.image-info{padding:.75rem}.image-title{font-size:1rem}.empty-state{padding:2rem 1rem}.empty-state h2{font-size:1.5rem}.empty-state p{font-size:1rem}}.fade-in{animation:fadeIn .3s ease-in}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.slide-up{animation:slideUp .3s ease-out}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.btn:focus,.image-card:focus,.image-checkbox input:focus,.search-input:focus{outline:2px solid #667eea;outline-offset:2px}@media (prefers-contrast:high){.image-card{border:1px solid #000}.btn-secondary{border-color:#000}.detail-section h4{border-bottom-color:#000}}@media (prefers-reduced-motion:reduce){.btn,.image-card,.image-preview img,.loading-spinner,.modal-content,.search-input{transition:none;animation:none}.btn-primary:hover,.image-card:hover,.image-card:hover .image-preview img{transform:none}}.floating-actions{position:fixed;bottom:2rem;right:2rem;display:flex;flex-direction:column;gap:1rem;z-index:50}.fab{width:3.5rem;height:3.5rem;border-radius:50%;border:none;font-size:1.25rem;cursor:pointer;display:flex;align-items:center;justify-content:center;text-decoration:none;box-shadow:0 4px 20px rgba(0,0,0,.15);transition:all .3s ease;backdrop-filter:blur(10px)}.fab:hover{transform:scale(1.1);box-shadow:0 8px 32px rgba(0,0,0,.2)}.fab-primary{background:linear-gradient(135deg,#667eea,#764ba2);color:white}.fab-primary:hover{background:linear-gradient(135deg,#5a6fd8,#6a4190)}.fab-secondary{background:rgba(255,255,255,.9);color:#4a5568;border:2px solid rgba(0,0,0,.1)}.fab-secondary:hover{background:rgba(255,255,255,1);border-color:rgba(0,0,0,.2)}@media (max-width:768px){.floating-actions{bottom:1rem;right:1rem}.fab{width:3rem;height:3rem;font-size:1rem}}