.elementor-23 .elementor-element.elementor-element-bb7fa33{--display:flex;--flex-direction:column;--container-widget-width:100%;--container-widget-height:initial;--container-widget-flex-grow:0;--container-widget-align-self:initial;--flex-wrap-mobile:wrap;--gap:0px 0px;--row-gap:0px;--column-gap:0px;--margin-top:0px;--margin-bottom:0px;--margin-left:0px;--margin-right:0px;--padding-top:0px;--padding-bottom:0px;--padding-left:0px;--padding-right:0px;}.elementor-23 .elementor-element.elementor-element-bb7fa33.e-con{--flex-grow:0;--flex-shrink:0;}:root{--page-title-display:none;}@media(max-width:767px){.elementor-23 .elementor-element.elementor-element-bb7fa33{--margin-top:-20px;--margin-bottom:0px;--margin-left:0px;--margin-right:0px;}}@media(min-width:768px){.elementor-23 .elementor-element.elementor-element-bb7fa33{--width:100%;}}/* Start custom CSS for html, class: .elementor-element-0d09ebb */.pp-hero-wrap{ font-family:'DM Sans',sans-serif; background:#f5f2ec; position: relative; }
.pp-hero-wrap *{margin:0;padding:0;box-sizing:border-box;}

/* INFO BAR */
.pp-info-bar{ background:#fff; border-bottom:1px solid rgba(0,0,0,0.08); }
.pp-info-inner{ max-width:1400px; margin:auto; padding:0 40px; height:52px; display:flex; align-items:center; justify-content:space-between; }
.pp-contact-items{ display:flex; gap:28px; }
.pp-contact-items a{ display:flex; align-items:center; gap:7px; font-size:11px; color:#888; text-decoration:none; }
.pp-contact-items i{ font-size:10px; color:#b8913a; }
.pp-info-tagline{ font-size:11px; color:#aaa; letter-spacing:0.5px; }

/* HERO */
.pp-hero{ padding:20px; background:#f5f2ec; }
.pp-slider-wrap{ position:relative; border-radius:20px; overflow:hidden; height:80vh; min-height:500px; background: #000; }

/* SLIDES */
.pp-slide{ position:absolute; inset:0; opacity:0; transition:opacity 1.2s ease; z-index: 1; }
.pp-slide.active{ opacity:1; z-index: 2; }
.pp-slide img, .pp-slide video { width:100%; height:100%; object-fit:cover; transform:scale(1); transition:transform 7s ease; }
.pp-slide.active img, .pp-slide.active video { transform:scale(1.05); }

.pp-overlay{ position:absolute; inset:0; background:linear-gradient(to right,rgba(0,0,0,0.5) 0%, transparent 100%); z-index: 3; }
.pp-overlay-bottom{ position:absolute; bottom:0; left:0; right:0; height:200px; background:linear-gradient(to top,rgba(0,0,0,0.5),transparent); z-index: 3; }

/* CONTENT */
.pp-content{ position:absolute; bottom:56px; left:56px; right:56px; display:flex; justify-content:space-between; align-items:flex-end; z-index:10; }
.pp-text h1{ font-family:'Playfair Display',serif; font-size:58px; color:#fff; line-height:1.1; margin-bottom:10px; font-feature-settings: "liga" 0; }
.pp-text h1 em { font-style: normal; color: #e8d5a3; }
.pp-text p{ font-size:13px; color:rgba(255,255,255,0.7); max-width:360px; }
.pp-eyebrow{ display:flex; align-items:center; gap:10px; font-size:10px; text-transform:uppercase; color:#e8d5a3; margin-bottom:12px; letter-spacing:2px; }
.pp-eyebrow::before{ content:''; width:20px; height:1px; background:#e8d5a3; }

/* SELF-CONTAINED BUTTON CLASS */
.pp-hero-cta-btn {
    display:inline-flex; align-items:center; gap:10px;
    padding:14px 28px; border-radius:50px;
    background:rgba(255,255,255,0.15); backdrop-filter:blur(10px);
    border:1px solid rgba(255,255,255,0.3);
    color:#fff; text-decoration:none; font-size:11px;
    text-transform:uppercase; transition: all 0.4s ease;
}
.pp-hero-cta-btn:hover { background:#e8d5a3; color:#000; border-color:#e8d5a3; }

/* NAVIGATION */
.pp-dots{ position:absolute; bottom:30px; left:56px; display:flex; gap:8px; z-index:15; }
.pp-dot{ width:20px; height:2px; background:rgba(255,255,255,0.3); cursor:pointer; transition:0.3s; }
.pp-dot.active{ width:40px; background:#e8d5a3; }

.pp-nav-arrows{ position:absolute; top:50%; width:100%; display:flex; justify-content:space-between; padding:0 30px; pointer-events:none; z-index:20; }
.pp-nav-arrows button{ pointer-events:all; width:45px; height:45px; border-radius:50%; border:1px solid rgba(255,255,255,0.2); background:rgba(0,0,0,0.2); color:#fff; cursor:pointer; transition:0.3s; }
.pp-nav-arrows button:hover{ background:#fff; color:#000; }

@media(max-width:768px){
    .pp-content{ flex-direction:column; align-items:flex-start; left:20px; bottom:60px; }
    .pp-text h1{ font-size:32px; }
    .pp-dots{ left:20px; }
}

/* Ampersand (&) ko fix karne ke liye extra CSS */
.pp-text h1 span.ampersand {
    display: inline-block;
    font-family: 'DM Sans', sans-serif !important; /* Stylish ki jagah clean font */
   
}


@media(max-width:768px){
  /* Info bar fix for small screens */
  .pp-info-inner {
    padding: 0 16px;
    height: 44px;
    justify-content: center; /* Mobile par center align behtar lagta hai */
  }
  .pp-info-tagline { display: none; }
  .pp-contact-items { gap: 15px; }
  .pp-contact-items a { font-size: 9px; }

  /* Hero section adjustments */
  .pp-hero { padding: 10px; }
  .pp-slider-wrap { 
    height: 65vh; /* Height thodi badhai hai taaki content saaf dikhe */
    border-radius: 15px; 
    min-height: 400px; 
  }

  /* Text & Heading adjustments */
  .pp-content {
    flex-direction: column; 
    align-items: flex-start; 
    gap: 15px;
    left: 20px; 
    right: 20px; 
    bottom: 60px; /* Dots ke liye jagah chhodi hai */
  }

  .pp-text h1 {
    font-size: 32px; /* Mobile par heading ka size balance kiya */
    line-height: 1.2;
    display: block; /* Flex ko block kiya taaki names wrap ho sakein */
  }

  /* Ampersand position fix for mobile */
  .pp-text h1 span.ampersand {
    font-size: 0.6em !important; 
    margin: 0 5px;
    vertical-align: middle;
  }

  .pp-text p {
    font-size: 12px;
    line-height: 1.6;
    max-width: 90%;
    color: rgba(255,255,255,0.8);
  }

  /* Navigation & Buttons */
  .pp-right {
    width: 100%;
    flex-direction: row;
    justify-content: space-between;
    align-items: center;
  }
  
  .pp-count { 
    display: block; /* Mobile par count wapas dikhaya hai par chhota */
    font-size: 10px; 
  }

  .pp-btn {
    font-size: 10px;
    padding: 10px 20px;
    letter-spacing: 1px;
  }

  /* Navigation Arrows - Mobile par chhote aur transparent */
  .pp-nav-arrows button {
    width: 38px;
    height: 38px;
    font-size: 10px;
    background: rgba(0,0,0,0.3);
  }

  /* Dots adjustment */
  .pp-dots {
    left: 20px;
    bottom: 25px;
  }
  .pp-dot { width: 15px; }
  .pp-dot.active { width: 30px; }
}
/* ===== SLIDES QUALITY FIX ===== */
.pp-slide img, .pp-slide video { 
    width: 100%; 
    height: 100%; 
    object-fit: cover; 
    /* Zoom effect ko yahan se hata diya gaya hai quality bachane ke liye */
    transform: scale(1) !important; 
    transition: opacity 0.8s ease; 
    
    /* Sharpening settings for modern browsers */
    image-rendering: -webkit-optimize-contrast; 
    image-rendering: crisp-edges;
}

/* Is section ko poora remove kar dein ya scale(1) rakhein */
.pp-slide.active img, .pp-slide.active video { 
    transform: scale(1) !important; 
}

/* Video specific sharpening */
video {
    outline: none;
    border: none;
    background-color: #000;
}

/* ===== MAXIMUM CLARITY & SHARPNESS CODE ===== */
.pp-slide img, 
.pp-slide video {
    width: 100%;
    height: 100%;
    /* 1. Zoom ko bilkul band kar dein */
    transform: translateZ(0) scale(1) !important; 
    
    /* 2. Hardware Acceleration force karein (GPU use hoga) */
    backface-visibility: hidden;
    perspective: 1000;
    -webkit-font-smoothing: subpixel-antialiased;
    
    /* 3. Sabse important: Pixels ko sharp karne ke liye */
    image-rendering: -webkit-optimize-contrast; /* Chrome/Safari ke liye */
    image-rendering: high-quality;             /* Standard */
    object-fit: cover;
    
    /* 4. Smoothness ke liye sirf opacity use karein */
    transition: opacity 1.2s ease-in-out;
}

/* Active slide par koi bhi movement band karein jo blur paida kare */
.pp-slide.active img, 
.pp-slide.active video {
    transform: translate3d(0, 0, 0) !important;
}

/* Container ki quality fix */
.pp-slider-wrap {
    /* Isse edge bleeding aur blurriness rukti hai */
    -webkit-mask-image: -webkit-radial-gradient(white, black);
    overflow: hidden;
    background: #000;
}/* End custom CSS */