   :root {
            --primary-color: #bc2a35;
            --secondary-color: #4ecdc4;
            --dark-color: #2c3e50;
            --light-bg: #f8f9fa;
        }
        
        body {
            font-family: "Lato", sans-serif;
            line-height: 1.5;
            font-weight: 300;
            font-size: 18px;
  font-style: normal;
  overflow-x: hidden;
        }
        section, header, footer {position: relative;}

.fixed-top {animation: slideDown 0.3s ease-in-out;}
@keyframes slideDown {
  from {        transform: translateY(-100%);}
  to {        transform: translateY(0);}    
  
}

        .navbar-brand {
            font-weight: bold;
            font-size: 1.5rem;
            
        }
        .nav-link {font-size: 18px; letter-spacing: 0.3px; font-weight: semibold;}

.nav-link.active, .navbar-nav .nav-link.show {
    color: var(--primary-color) !important
}


        .hero-section {
            background: linear-gradient(to top, #FFFFFF 0%, #F6F6F6 100%);
            min-height: 100vh;
            position: relative;
            overflow: hidden;
        }
        
        .hero-content {
            position: relative;
            z-index: 2;
            padding: 100px 0;
        }
        .position-relative {position: relative;}
        .right-edge-image {width: 45vw; 
            height: auto; 
            object-fit: cover;
            border-radius: 100px 0 0 0; 
            margin-right: calc(-50vw + 100%);
            float: right; }
            
            .left-edge-image {width: 45vw; 
            height: auto; 
            object-fit: cover;
            border-radius: 0  100px 0 0; 
            margin-left: calc(-50vw + 100%);
            float: left; }

         .rounded-brand {border-radius: 0 100px 0 0;}
         .rounded-brand-small {border-radius: 0 100px 0 0;}
        .hero-image {
          right:0px;
          top:-25px;
          position: absolute;
            width: auto;
            width: 60vw;
             min-height:100vh;
            background: url(../images/home-hero-photo.png) no-repeat top right/contain;
            opacity: 1;
        }
        
        .hero-title {
            font-size: 2.5rem;
            font-weight: 500;
            color: #313131;
            margin-bottom: 1rem;
        }
        
        .hero-subtitle {
              color: #313131;
            font-size: 1.1rem;
            margin-bottom: 2rem;
            max-width: 500px;
        }
        
        .btn-outline-light {
            border: 2px solid var(--primary-color);
            padding: 12px 30px;
            margin-right: 15px;
            color: var(--primary-color);
        }
        .btn-outline-light:hover {
            border: 2px solid var(--primary-color);
            padding: 12px 30px;
            margin-right: 15px;
            color: #FFFFFF;
            background-color: var(--primary-color);

        }
        
        .section-padding {
            padding: 80px 0;
        }
        
        .section-title {
            font-size: 2.5rem;
            font-weight: 300;
            margin-bottom: 1rem;
            color: var(--dark-color);
        }
        .brand-rounded {
            border-radius:0 100px 0 0;
        }
        .studio-section {
            background: white;
            position: relative;
        }
        .position-relative {
            position: relative;
        }
       .full-height-left {
  position: absolute;

 
  height: auto;
  object-fit: cover;
}
        
      
        
     
        .outreach-section, .interest-section {
            background: white;
        }
        
        .card-placeholder {
           
            background: #f8f9fa;
          
            border-radius: 25px;
            display: flex;
            flex-direction: column;
            gap: 10px;
            align-items: center;
            justify-content: center;
            color: #333333;
            margin-bottom: 20px;
        }
        
        .contact-section {

            background: #eccfcf url(../images/footer-temple-sketch-bg.png) no-repeat  25% bottom; background-size:auto 60%;
        }


        .form-control {
            border: 1px solid #dee2e6;
            padding: 15px;
            margin-bottom: 20px;
        }
        
        .btn-primary {
            background: var(--primary-color);
            border: none;
            padding: 15px 40px;
        }
        
        .footer {
            background: white;
            padding: 60px 0 40px;
            border-top: 1px solid #eee;
        }
        
        .footer-logo {
            width: 100px;
            height: 60px;
            background: url('data:image/svg+xml,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 60"><rect width="100" height="60" fill="%234ecdc4"/><path d="M20 20 Q50 10 80 30 Q70 50 40 40 Q10 45 20 20" fill="%2326a69a"/></svg>') center/cover;
        }
        
        .social-icons a {
            color: var(--dark-color);
            font-size: 1.5rem;
            margin-right: 15px;
            transition: color 0.3s;
        }
        
        .social-icons a:hover {
            color: var(--primary-color);
        }

         .rotating-gallery {
                        position: relative;
                    }
.rotating-gallery-right .rotating-gallery-image {
     top: 0;
                        right: 0;
                        left: auto;
}
                    .rotating-gallery-image {
                        position: absolute;
                        top: 0;
                        left: 0;
                        opacity: 0;
                        transition: opacity 1s ease-in-out;
                        margin-top: 25px;
                        height: auto;
                        width: 100%;
                    }
                    .rotating-gallery-image.active {
                        opacity: 1;
                    }
                    #navbarNav {width: 100vw !important;}
                      .onlyDesktop {display: block !important;}
         .onlyMobile {display: none !important;}
        @media (max-width: 768px) {
            .onlyDesktop {display: none !important;}
            .onlyMobile {display: block !important;}
            #navbarNav {display: block !important;}
            #navbarNav .navbar-nav{display: none !important;}
            #navbarNav.show .navbar-nav{display: block !important; position: fixed; top: 60px;          height: 100vh;       z-index: 111; left: 0; width: 100vw !important; background:rgba(255,255,255,0.95); backdrop-filter: blur(5px); padding: 20px 0; box-shadow: 0 2px 6px rgba(0,0,0,0.1);}
            .navbar-nav {flex-direction: column; text-align: center;}
            .fixed-top #navbarNav.show .navbar-nav {top: 60px;}
            .navbar-toggler, button:focus:not(:focus-visible) {border: none; font-size: 24px; outline: none; box-shadow: none; }
            .hero-title {
                font-size: 2.5rem;
            }
            
            .hero-image {
               display: block !important;
    position: relative !important;
    width: 100vw !important;
    min-height: 100vw !important;
            }
            
            .section-padding {
                padding: 50px 0;
            }
            .rotating-gallery, .rotating-gallery-right {display: none;}
            .left-edge-image, .right-edge-image {max-width: 100%; width: 100%; float:none !important; margin: 0 !important;}
            .filter-btn {margin: 10px !important;}
        }


          .gallery-section {
          background: url(../images/bg_gallery.jpg) no-repeat calc(100% + 300px) top;
          background-blend-mode: lighten;
          background-size: auto 90% ;
            padding: 80px 0;
            min-height: 100vh;
        }
         .gallery-page{
          background: url(../images/bg_gallery-2.jpg) no-repeat calc(100% + 300px) top;
          background-blend-mode: lighten;
          background-size: auto 80% ;
            padding: 80px 0;
            min-height: 100vh;
        }
        
        .section-title {
            color: white;
            text-align: center;
            margin-bottom: 50px;
            font-weight: 300;
            text-shadow: 0 2px 4px rgba(0,0,0,0.3);
        }
        
        .gallery-item {
            margin-bottom: 30px;
            cursor: pointer;
           
            border-radius: 0px;
          
            transition: all 0.3s ease;
           
        }
        .gallery-item a {
            text-decoration: none;
            color: inherit;
            display: block;
            border-radius: 0px;
            overflow: hidden;
            position: relative;
    
        }
       
     .gallery-item a .caption {
        color:#FFF;
        font-size: 30px;
        font-weight: 500;
          padding:0px 0 0 0px;
          text-transform: capitalize;
          letter-spacing: 0.5px;
       position: absolute;
            bottom: -12px;
            width: 100%;
          
          display: block;
          border: solid 0px #DDD;
          text-align: left;
        }
        
        .gallery-item img {
            width: 100%;
            max-height: 300px;
            border-radius: 0 50px 0 0;
            object-fit: contain;
           background: #EEE;
            transition: transform 0.3s ease;
            box-shadow: 0 5px 10px rgba(0,0,0,0.1);
        }
        .gallery-item.rounded-5 img {
            border-radius: 30px;
        }
        .gallery-item:hover img {
           
        }
        
        .category-filter {
            text-align: center;
            /* background: url(../images/strock/strokes-gallery-tabs.png) no-repeat center center; */
          padding: 10px 0;
            background-size: cover;
            margin-bottom: 40px;
        }
        .category-filter.fixed {
    position: fixed;
    background: rgba(255,255,255,0.9);
    color:#000000 !important;
    backdrop-filter: blur(10px);
    padding: 20px 0;
    top: 55px;
    left: 0;
    width: 100%; /* adjust if needed */
    box-shadow: 0 2px 6px rgba(0,0,0,0.1); /* optional */
    z-index: 1000; /* ensure it stays above other content */
  }

  .nobg {background: none !important;}
  .category-filter.fixed  .filter-btn {  color:#000000 !important; border:0 !important;}
        .filter-btn {
          
            border: 2px solid  var(--primary-color); 
            color:  var(--primary-color);
            margin: 0 5px;
            padding: 10px 20px;
            border-radius: 25px;
            transition: all 0.3s ease;
           background: rgba(255,255,255,0.1);
           backdrop-filter: blur(3px);
              font-size: 18px;
        }
        
        .filter-btn:hover, .filter-btn.active {
         
            color: #fff;
            background: var(--primary-color);
            border: 2px solid var(--primary-color);
           
        }
        .category-filter.fixed  .filter-btn.active  , .category-filter.fixed  .filter-btn:hover    { color: #fff !important;  }
        
        .lightbox-modal .modal-dialog {
            max-width: 100vw;
            max-height: 100vh;
            margin: 0px auto;
        }
        
        .lightbox-content {
            background:rgb(0,0,0,0.2);
            border: none;
            border-radius: 0px;
            backdrop-filter: blur(10px);
        }
        
        .lightbox-header {
            border-bottom: 1px solid rgba(255,255,255,0.1);
            background:  rgba(0,0,0,0.1);
            color: #FFFFFF;
            text-align: center;
            padding: 15px 20px;
            position: relative;
            display: flex;
            font-weight: bold;
            text-transform: uppercase;
            
        }
        
        .lightbox-body {
            padding: 25px;
            text-align: center;
            position: relative;
            overflow: hidden;
        }
        
        .lightbox-image {
            max-width: 100%;
            max-height: calc(100vh - 120px);
            border-radius: 5px;
        }
        
        .lightbox-nav {
            position: absolute;
            top: 50%;
            transform: translateY(-50%);
            background: rgba(0,0,0,0.7);
            color: white;
            border: none;
            width: 50px;
            height: 50px;
            border-radius: 50%;
            font-size: 20px;
            cursor: pointer;
            transition: all 0.3s ease;
            backdrop-filter: blur(10px);
        }
        
        .lightbox-nav:hover {
            background: rgba(255,255,255,0.2);
            color: white;
            transform: translateY(-50%) scale(1.1);
        }
        
        .lightbox-prev {
            left: 20px;
        }
        
        .lightbox-next {
            right: 20px;
        }
        
        .image-counter {
            position: absolute;
            bottom: 20px;
            left: 50%;
            transform: translateX(-50%);
            background: rgba(0,0,0,0.7);
            color: white;
            padding: 8px 15px;
            border-radius: 20px;
            font-size: 14px;
            backdrop-filter: blur(10px);
        }
        
        .btn-close {
            filter: invert(1);
        }


        .exhibition-section{
margin-bottom:1.5rem;
}
.exhibition-section h2{
font-size:22px;
margin:0 0 1.2rem 0;
}
.exhibition-list{
display:grid;
grid-template-columns:80px 1fr;
gap:0.50rem 1rem;
align-items:start;
}
.exhibition-year{
color:var(--muted);
font-feature-settings: "tnum" 1;
}
.exhibition-item{
line-height:1.45;
}
.exhibition-note{font-style:italic;color:var(--muted);margin-top:1rem}
@media (max-width:600px){
.exhibition-list{grid-template-columns:70px 1fr}
}
/* Print-friendly tweaks */
@media print{
body{padding:0}
.page{box-shadow:none}
a{color:inherit}
}
        
        @media (max-width: 768px) {
            .lightbox-nav {
                width: 40px;
                height: 40px;
                font-size: 16px;
            }
            
            .lightbox-prev {
                left: 10px;
            }
            
            .lightbox-next {
                right: 10px;
            }
        }

           .whatsapp-float {
  position: fixed;
  width: 60px;
  height: 60px;
  bottom: 20px;
  right: 20px;
  background-color: #25D366;
  color: white;
  border-radius: 50%;
  text-align: center;
  font-size: 28px;
  box-shadow: 2px 2px 6px rgba(0,0,0,0.3);
  z-index: 1000;
  line-height: 60px;
  text-decoration: none;
  transition: background 0.3s ease;
  display: flex;
  align-items: center;
  justify-content: center;
}
.whatsapp-float:hover {
  background-color: #20b954;
}

.custom-form {display: flex; flex-direction: column; gap: 1rem; width: 100%;}
.custom-form label {font-size: 0.9rem; display: block; font-weight: 600; margin-bottom: 0.5rem; color: #333;}
.custom-form input, .custom-form select, .custom-form textarea { padding:5px 10px; border-radius: 10px; width: 100%; display: block; border: 1px solid #ccc; border-radius: 5px; font-size: 1rem; }