/* =========================
   FINAL COMPLETE CSS (IMAGE + TEXT DONO SIDE EQUAL SPACE)
   ========================= */

/* reset */
*{
  margin:0;
  padding:0;
  box-sizing:border-box;
}

body{
  font-family: Arial, sans-serif;
  background:#f8f9fa;
  margin:0;
  padding:0;
}

/* container */
.container{
  max-width:1200px;
  margin:0 auto;
  padding:0 2px;
}

/* header */
.section-header{
  text-align:center;
  margin-bottom:50px;
}

.section-title{
  font-size:18px;
  font-weight:600;
  color:#333;
  text-transform:uppercase;
  letter-spacing:2px;
  margin-bottom:15px;
}

.section-underline{
  width:100px;
  height:3px;
  background:linear-gradient(135deg,#ff6b35,#f7931e);
  margin:0 auto 30px;
}

/* search */
.search-container{
  max-width:600px;
  margin:0 auto 50px;
  position:relative;
  padding:0 2px;
}

.search-input{
  width:100%;
  padding:15px 50px 15px 20px;
  border:2px solid #e0e0e0;
  border-radius:5px;
  font-size:16px;
  outline:none;
  transition:all .3s ease;
  background:#fff;
  box-shadow:0 2px 10px rgba(0,0,0,.1);
}

.search-input:focus{
  border-color:#ff6b35;
  box-shadow:0 4px 20px rgba(255,107,53,.2);
}

.search-icon{
  position:absolute;
  right:20px;
  top:50%;
  transform:translateY(-50%);
  color:#666;
  font-size:18px;
}

/* GRID */
.services-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(320px,1fr));
  gap:25px;
  margin-top:40px;
  padding:0 2px 30px;
  position:relative;
}

/* CARD – padding se andar ka space (image + text same) */
.service-card{
  background:#fff;
  border-radius:5px;
  overflow:hidden;
  box-shadow:0 8px 25px rgba(0,0,0,.1);
  transition:all .3s ease;
  border:1px solid #f0f0f0;
  width:100%;
  max-width:400px;
  margin:0 auto;
  padding:0 8px 8px;   /* inner left-right space */
  box-sizing:border-box;
}

.service-card:hover{
  transform:translateY(-10px);
  box-shadow:0 15px 40px rgba(0,0,0,.15);
}

/* IMAGE – ab width 100% + koi margin nahi, space card padding se milega */
.card-image{
  width:100%;
  height:160px;
  background-size:cover;
  background-position:center;
  display:block;
  margin:0;
  padding:0;
  line-height:0;
  border-radius:5px 5px 0 0;
  overflow:hidden;
}

/* agar <img> tag use ho */
.card-image img{
  display:block;
  width:100%;
  height:100%;
  object-fit:cover;
  margin:0;
  padding:0;
}

/* CONTENT – horizontal padding 0, kyunki card pe already padding hai */
.card-content{
  padding:10px 0;
  text-align:center;
}

.card-title{
  font-size:16px;
  font-weight:600;
  color:#333;
  margin:0 0 10px;
  text-transform:uppercase;
  letter-spacing:1px;
  line-height:1.25;
}

.card-description{
  color:#666;
  line-height:1.5;
  margin:0 0 12px;
  font-size:13px;

  display:-webkit-box;
  -webkit-line-clamp:4;
  -webkit-box-orient:vertical;
  overflow:hidden;
}

/* price + button */
.price{
  float:left;
  font-weight:bold;
  color:#28a745;
  margin-top:5px;
  margin-left:1px;
}

.call-btn{
  background:linear-gradient(135deg,#43b849,#07a850);
  color:#fff;
  border:none;
  padding:10px 15px;
  border-radius:5px;
  font-size:10px;
  font-weight:600;
  text-transform:uppercase;
  letter-spacing:1px;
  cursor:pointer;
  transition:all .3s ease;
  text-decoration:none;
  display:inline-block;
  float:right;
  margin-right:1px;
}

.call-btn:hover{
  transform:translateY(-2px);
  box-shadow:0 8px 20px rgba(7,168,80,.3);
}

/* more btn */
.more-services-btn{
  background:linear-gradient(135deg,#28a745,#20c997);
  color:#fff;
  border:none;
  padding:15px 40px;
  border-radius:30px;
  font-size:16px;
  font-weight:600;
  text-transform:uppercase;
  letter-spacing:1px;
  cursor:pointer;
  transition:all .3s ease;
  margin:40px auto;
  display:block;
  box-shadow:0 4px 15px rgba(40,167,69,.3);
  position:relative;
  overflow:hidden;
}

.more-services-btn:hover{
  transform:translateY(-3px);
  box-shadow:0 8px 25px rgba(40,167,69,.4);
}

/* hidden services */
.hidden-services{
  display:none !important;
  opacity:0;
  transform:translateY(30px);
  transition:all .6s ease;
}

.hidden-services.show{
  display:block !important;
  opacity:1;
  transform:translateY(0);
}

/* dropdown */
.dropdown-suggestions{
  position:absolute;
  top:100%;
  left:0;
  right:0;
  background:#fff;
  border:1px solid #e0e0e0;
  border-radius:15px;
  margin-top:5px;
  max-height:200px;
  overflow-y:auto;
  z-index:1000;
  display:none;
  box-shadow:0 4px 15px rgba(0,0,0,.1);
}

.suggestion-item{
  padding:12px 20px;
  cursor:pointer;
  border-bottom:1px solid #f0f0f0;
}

.suggestion-item:hover{ background:#f8f9fa; }
.suggestion-item:last-child{ border-bottom:none; }

.clearfix::after{
  content:"";
  clear:both;
  display:table;
}

/* peek */
.services-grid::after{
  content:'';
  position:absolute;
  bottom:0;
  left:2px;
  width:calc(100% - 4px);
  height:30px;
  background:linear-gradient(to top,rgba(248,249,250,1),rgba(248,249,250,0));
  pointer-events:none;
}

/* =========================
   MOBILE
   ========================= */
@media (max-width:768px){

  .container{
    padding:0 1px;
  }

  .services-grid{
    grid-template-columns:repeat(2,minmax(0,1fr));
    gap:6px;
    padding:0 1px 10px;
    margin-top:12px;
  }

  .service-card{
    max-width:none;
    margin:0;
    border-radius:4px;
    box-shadow:0 4px 10px rgba(0,0,0,.08);
    padding:0 4px 5px;   /* mobile mein bhi equal space */
  }

  .card-image{
    height:auto !important;
    aspect-ratio:16/9;
    margin:0;
    border-radius:4px 4px 0 0;
  }

  .card-content{
    padding:5px 0;
  }

  .card-title{
    font-size:7px;
    line-height:1.1;
    margin-bottom:3px;
    letter-spacing:0.2px;
    font-weight:700;
  }

  .card-description{
    font-size:7px;
    line-height:1.35;
    margin-bottom:4px;

    display:-webkit-box;
    -webkit-line-clamp:3;
    -webkit-box-orient:vertical;
    overflow:hidden;
  }

  .price{
    font-size:7px;
    margin-top:2px;
    margin-left:1px;
  }

  .call-btn{
    font-size:7px;
    padding:3px 5px;
    border-radius:3px;
    letter-spacing:0.1px;
    margin-right:1px;
  }
}

#page4{
  display:none !important;
}

/* =========================
   OVERRIDE: OUR CHIMNEY SERVICES SECTION ONLY
   (#select-service ke baad wale container ka gap control)
   ========================= */

/* Desktop + tablet */
#select-service ~ .container{
  max-width:100% !important;
  padding-left:10px !important;   /* thoda sa outer gap */
  padding-right:10px !important;
}

/* search + grid ke side ka gap halka sa */
#select-service ~ .container .search-container{
  padding-left:6px !important;
  padding-right:6px !important;
}

#select-service ~ .container .services-grid{
  padding-left:4px !important;
  padding-right:4px !important;
}

/* gradient poori width pe hi rahe */
#select-service ~ .container .services-grid::after{
  left:0 !important;
  width:100% !important;
}

/* Mobile override */
@media (max-width:768px){
  #select-service ~ .container{
    padding-left:6px !important;   /* mobile pe thoda kam gap */
    padding-right:6px !important;
  }

  #select-service ~ .container .services-grid{
    padding-left:3px !important;
    padding-right:3px !important;
  }

  #select-service ~ .container .search-container{
    padding-left:4px !important;
    padding-right:4px !important;
  }
}
