/* company-gallery.css | Raviera Ceylon | All values from main.css tokens */
#loading-overlay { position: fixed; inset: 0; z-index: 9999; background: var(--bg-primary); display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 1rem; transition: opacity 0.5s ease; }
.spinner { width: 48px; height: 48px; border: 3px solid rgba(251,191,36,0.2); border-top-color: var(--primary-gold); border-radius: 50%; animation: rcSpinRing 0.8s linear infinite; }
@keyframes rcSpinRing { to { transform: rotate(360deg); } }
.loading-text { font-family: var(--font-heading); color: var(--primary-gold); font-size: 1rem; letter-spacing: 0.15em; }
/* Filter buttons */
.filter-buttons { display: flex; gap: 0.5rem; justify-content: center; flex-wrap: wrap; margin-top: 1.5rem; }
.btn-filter { font-family: var(--font-primary); font-size: 0.82rem; font-weight: var(--font-weight-semibold); color: rgba(255,255,255,0.80); background: rgba(255,255,255,0.10); border: 1px solid rgba(255,255,255,0.20); border-radius: 100px; padding: 0.4rem 1.1rem; cursor: pointer; transition: background 0.25s ease, color 0.25s ease, border-color 0.25s ease; }
.btn-filter:hover, .btn-filter.active { background: var(--primary-gold); color: var(--bg-primary); border-color: var(--primary-gold); }
/* Gallery grid */
.gallery-main { background: var(--bg-primary); }
.gallery-card { position: relative; border-radius: 12px; overflow: hidden; background: var(--bg-secondary); box-shadow: var(--shadow-md); transition: transform 0.3s ease, box-shadow 0.3s ease; }
.gallery-card:hover { transform: translateY(-4px); box-shadow: var(--shadow-luxury); }
.gallery-card img { width: 100%; height: 220px; object-fit: cover; display: block; transition: transform 0.5s ease; }
.gallery-card:hover img { transform: scale(1.06); }
.gallery-overlay { position: absolute; inset: 0; background: linear-gradient(to top, rgba(0,0,0,0.80) 0%, transparent 55%); opacity: 0; transition: opacity 0.3s ease; display: flex; align-items: flex-end; padding: 1rem; }
.gallery-card:hover .gallery-overlay { opacity: 1; }
.gallery-info { flex: 1; }
.gallery-title { font-family: var(--font-heading); font-size: 0.92rem; font-weight: var(--font-weight-bold); color: var(--white); margin-bottom: 0.25rem; }
.gallery-description { font-family: var(--font-primary); font-size: 0.78rem; color: rgba(255,255,255,0.75); margin: 0 0 0.5rem; }
.gallery-categories { display: flex; flex-wrap: wrap; gap: 0.3rem; }
.gallery-icon { position: absolute; top: 0.75rem; right: 0.75rem; color: var(--primary-gold); font-size: 1rem; }
/* Instagram section */
.instagram-feed { background: var(--bg-secondary); }
.section-title { font-family: var(--font-heading); font-size: clamp(1.4rem, 3vw, 2rem); font-weight: var(--font-weight-bold); color: var(--text-primary); }
.section-subtitle { font-family: var(--font-primary); font-size: 0.95rem; color: var(--primary-gold); }
.btn-gallery-instagram { font-family: var(--font-primary); font-weight: var(--font-weight-semibold); color: var(--primary-gold); border: 1.5px solid var(--primary-gold); background: transparent; transition: background 0.25s ease, color 0.25s ease; }
.btn-gallery-instagram:hover { background: var(--primary-gold); color: var(--bg-primary); }
.instagram-item { position: relative; border-radius: 8px; overflow: hidden; aspect-ratio: 1; }
.instagram-item img { width: 100%; height: 100%; object-fit: cover; transition: transform 0.4s ease; }
.instagram-item:hover img { transform: scale(1.08); }
.instagram-item-overlay { position: absolute; inset: 0; background: rgba(0,0,0,0.45); display: flex; align-items: center; justify-content: center; opacity: 0; transition: opacity 0.3s ease; text-decoration: none; }
.instagram-item:hover .instagram-item-overlay { opacity: 1; }
.instagram-icon { font-size: 1.5rem; color: var(--primary-gold); }
/* CTA */
.gallery-cta { background: var(--bg-primary); }
.cta-card { background: var(--gradient-luxury); border-radius: 16px; padding: 2rem 2.5rem; }
.cta-card h2 { font-family: var(--font-heading); color: var(--white); font-size: clamp(1.3rem, 2.5vw, 1.8rem); margin-bottom: 0.5rem; }
.cta-card p { font-family: var(--font-primary); color: rgba(255,255,255,0.75); margin: 0; }
.btn-gallery-cta { font-family: var(--font-primary); font-weight: var(--font-weight-semibold); color: var(--bg-primary); background: var(--gradient-gold); border: none; box-shadow: var(--shadow-gold); transition: box-shadow 0.3s ease, transform 0.2s ease; }
.btn-gallery-cta:hover { box-shadow: 0 8px 30px rgba(251,191,36,0.5); transform: translateY(-2px); color: var(--bg-primary); }
@media (max-width: 767.98px) { .gallery-card img { height: 180px; } }
