.hero {
    background:#f6f8f7;
    padding:80px 0;
}

.container {
    width:100%;
    max-width:1320px;   /* Grandoria wider container */
    margin:auto;
    display:flex;
    align-items:center;
    justify-content:space-between;
    gap:80px;
}

.hero-left {
    width:48%;
}

.hero-left h1 {
    font-size:56px;        /* Bigger heading like demo */
    font-weight:700;
    color:#183a2f;
    line-height:1.05;
    margin-bottom:28px;
}

.hero-desc {
    font-size:19px;
    color:#5f6f65;
    line-height:1.8;
    margin-bottom:30px;
    max-width:560px;
}

.hero-features {
    display:flex;
    gap:35px;
    margin-bottom:40px;
    font-size:15px;
    color:#355c4d;
}

.hero-features i {
    margin-right:8px;
    font-size:18px;
    color:#1f4f3a;
}

.hero-buttons {
    display:flex;
    gap:22px;
}

.btn-primary {
    background:#1f4f3a;
    color:#fff;
    padding:16px 38px;
    border-radius:60px;
    font-weight:600;
    text-decoration:none;
    transition:0.3s;
}

.btn-primary:hover {
    background:#163a2b;
}

.btn-outline {
    border:2px solid #1f4f3a;
    color:#1f4f3a;
    padding:14px 38px;
    border-radius:60px;
    font-weight:600;
    text-decoration:none;
    transition:0.3s;
}

.btn-outline:hover {
    background:#1f4f3a;
    color:#fff;
}

.hero-right {
    width:52%;
    position:relative;
}

.hero-img {
    width:100%;
    height:520px;           /* FIXED HEIGHT like demo */
    object-fit:cover;       /* Proper crop */
    border-radius:28px;
}

.rating-card {
    position:absolute;
    width:280px;
padding:20px 22px;

    bottom:45px;
    right:0;
    background:#fff;
    /* padding:22px 24px;        Less padding */
    border-radius:18px;
    /* width:300px;              Smaller width */
    box-shadow:0 25px 60px rgba(0,0,0,0.10);
}

.stars {
    color:#fbbf24;
    font-size:16px;           /* Smaller stars */
    margin-bottom:8px;
}

.rating-card h4 {
    font-weight:700;
    margin-bottom:6px;
    font-size:16px;           /* Smaller heading */
}

.rating-card p {
    font-size:13.5px;         /* Smaller paragraph */
    line-height:1.6;
    color:#555;
}

.review-user {
    display:flex;
    align-items:center;
    gap:10px;
    margin-top:12px;
}

.review-user img {
    width:38px;               /* Smaller image */
    height:38px;
    border-radius:50%;
    object-fit:cover;
}


.stars {
    color:#fbbf24;
    font-size:18px;
    margin-bottom:12px;
}

.rating-card h4 {
    font-weight:700;
    margin-bottom:10px;
    font-size:18px;
}

.rating-card p {
    font-size:15px;
    line-height:1.6;
    color:#555;
}

.review-user {
    display:flex;
    align-items:center;
    gap:12px;
    margin-top:18px;
}

.review-user img {
    width:45px;
    height:45px;
    border-radius:50%;
    object-fit:cover;
}

@media(max-width:1200px){
    .container{
        padding:0 20px;
    }
}

@media(max-width:992px){
    .container{
        flex-direction:column;
        text-align:center;
        gap:50px;
    }

    .hero-left,
    .hero-right{
        width:100%;
    }

    .hero-img{
        height:400px;
    }

    .rating-card{
        position:relative;
        right:-11%;
        bottom:10%;
        margin-top:30px;
    }

    .hero-features{
        justify-content:center;
        flex-wrap:wrap;
    }

    .hero-buttons{
        justify-content:center;
    }
}
.stats-section {
    background:#f6f8f7;
    padding:30px 0;
    border-top:1px solid #e5ece8;
}

.stats-container {
    max-width:1200px;
    margin:auto;
    display:flex;
    justify-content:space-between;
    text-align:center;
}

.stat-box {
    flex:1;
}

.stat-box h2 {
    font-size:56px;
    font-weight:700;
    color:#1f4f3a;
    margin-bottom:10px;
}

.stat-box p {
    font-size:14px;
    letter-spacing:1px;
    color:#6b7d75;
    font-weight:600;
}

@media(max-width:992px){
    .stats-container{
        flex-direction:column;
        gap:40px;
    }
}
/* ================= ABOUT SECTION ================= */

.about-section {
    background: #eef3f1;
    padding: 70px 0 60px;
}

.about-container {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 60px;
}

/* LEFT CONTENT */

.about-left {
    width: 48%;
}

.about-left h2 {
    font-size: 42px;
    color: #183a2f;
    margin-bottom: 14px;
    line-height: 1.2;
}

.about-left h5 {
    font-size: 17px;
    color: #355c4d;
    margin-bottom: 20px;
    font-weight: 500;
}

.about-left p {
    font-size: 16px;
    line-height: 1.7;
    color: #5f6f65;
    max-width: 520px;
}

/* RIGHT IMAGES */

.about-right {
    width: 52%;
    position: relative;
}

.image-wrapper {
    position: relative;
}

.img-main {
    margin-left: 60px;
    width: 92%;
    border-radius: 26px;
    height: 380px;
    object-fit: cover;
}

.img-overlay {
    position: absolute;
    bottom: -80px;
    left: -40px;
    width: 58%;
    border-radius: 18px;
    height: 250px;
    object-fit: cover;
    box-shadow: 0 15px 40px rgba(0,0,0,0.08);
}

/* EXPERIENCE BADGE */

.experience-badge {
    position: absolute;
    right: -20px;
    top: 22%;
    transform: translateY(-50%);
    background: #1f4f3a;
    color: #fff;
    width: 105px;
    height: 105px;
    border-radius: 50%;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
}

.experience-badge h3 {
    font-size: 24px;
    margin: 0;
}

.experience-badge span {
    font-size: 11px;
}

/* ================= ABOUT EXTRA INLINE ================= */

.about-extra-inline {
    margin-top: 35px;
}

.extra-stats {
    display: flex;
    gap: 45px;
    margin-bottom: 25px;
}

.extra-box h3 {
    font-size: 36px;
    color: #1f4f3a;
    font-weight: 700;
}

.extra-box p {
    font-size: 14px;
    color: #6b7d75;
    margin-top: 5px;
}

.extra-buttons {
    display: flex;
    gap: 18px;
}

/* ================= RESPONSIVE ================= */

@media (max-width: 992px) {

    .about-container {
        flex-direction: column;
        text-align: center;
        gap: 40px;
    }

    .about-left,
    .about-right {
        width: 100%;
    }

    .about-left p {
        margin: 0 auto;
    }

    .img-main {
        margin-left: 0;
        width: 100%;
        height: 340px;
    }

    .img-overlay {
        position: relative;
        left: 0;
        bottom: 0;
        width: 100%;
        height: 220px;
        margin-top: 15px;
    }

    .experience-badge {
        right: 15px;
        top: 15px;
        transform: none;
    }

    .extra-stats {
        flex-direction: column;
        gap: 25px;
    }

    .extra-buttons {
        justify-content: center;
    }
}
/* ==============================
   HOME ROOMS SECTION
============================== */

.home-rooms-section {
    background:#f6f8f7;
    padding:90px 0;
}

.rooms-header {
    text-align:center;
    margin-bottom:60px;
}

.rooms-header h2 {
    font-size:42px;
    color:#183a2f;
    margin-bottom:10px;
}

.rooms-header p {
    color:#6b7d75;
    font-size:16px;
}

/* GRID */

.rooms-grid {
    display:grid;
    grid-template-columns:repeat(3,1fr);
    gap:35px;
}

/* CARD */

.room-card {
    background:#fff;
    border-radius:24px;
    overflow:hidden;
    box-shadow:0 20px 50px rgba(0,0,0,0.05);
    transition:0.4s;
}

.room-card:hover {
    transform:translateY(-8px);
    box-shadow:0 30px 70px rgba(0,0,0,0.08);
}

.room-image {
    position:relative;
}

.room-image img {
    width:100%;
    height:260px;
    object-fit:cover;
    display:block;
}

.room-type {
    position:absolute;
    top:20px;
    left:20px;
    background:#1f4f3a;
    color:#fff;
    padding:6px 18px;
    border-radius:30px;
    font-size:13px;
    font-weight:600;
}

.room-content {
    padding:28px;
}

.room-top {
    display:flex;
    justify-content:space-between;
    align-items:center;
    margin-bottom:10px;
}

.room-top h3 {
    font-size:20px;
    color:#183a2f;
}

.room-rating {
    color:#fbbf24;
    font-size:14px;
}

.room-desc {
    font-size:14px;
    color:#6b7d75;
    margin-bottom:18px;
    line-height:1.6;
}

.room-meta {
    display:flex;
    flex-wrap:wrap;
    gap:18px;
    font-size:13px;
    color:#355c4d;
    margin-bottom:20px;
}

.room-meta i {
    margin-right:6px;
}

.room-bottom {
    display:flex;
    justify-content:space-between;
    align-items:center;
    flex-wrap:wrap;
    gap:10px;
}

.room-bottom .price {
    font-size:22px;
    font-weight:700;
    color:#1f4f3a;
}

.room-bottom .price span {
    font-size:13px;
    color:#6b7d75;
    font-weight:400;
}


/* ==============================
   FEATURED ROOMS SECTION
============================== */

.featured-rooms-section {
    padding:100px 0;
    background:#f6f8f7;
}

.featured-container {
    display:flex;
    gap:50px;
    align-items:flex-start;
}

/* LEFT BIG CARD */

.featured-left {
    flex:2;
    background:#fff;
    border-radius:24px;
    overflow:hidden;
    box-shadow:0 20px 50px rgba(0,0,0,0.05);
}

.big-room-image img {
    width:100%;
    height:420px;
    object-fit:cover;
    display:block;
}

.big-room-content {
    padding:35px;
}

.big-room-content h2 {
    font-size:32px;
    margin-bottom:10px;
    color:#183a2f;
}

.rating {
    color:#fbbf24;
    margin-bottom:15px;
}

.big-room-content p {
    color:#6b7d75;
    line-height:1.6;
    margin-bottom:20px;
}

.big-room-meta {
    display:flex;
    flex-wrap:wrap;
    gap:20px;
    margin-bottom:25px;
    color:#355c4d;
}

.big-room-bottom {
    display:flex;
    justify-content:space-between;
    align-items:center;
    flex-wrap:wrap;
    gap:15px;
}

.big-room-bottom .price {
    font-size:26px;
    font-weight:700;
    color:#1f4f3a;
}

/* RIGHT SIDE CARDS */
/* RIGHT COLUMN */

.featured-right {
    flex:1;
    display:flex;
    flex-direction:column;
    gap:30px;   /* thoda zyada breathing space */
}

/* SIDE CARD */

.side-room-card {
    display:flex;
    gap:18px;   /* image & content ke beech better gap */
    background:#fff;
    padding:20px;   /* equal internal spacing */
    border-radius:20px;
    box-shadow:0 12px 35px rgba(0,0,0,0.05);
    align-items:flex-start;   /* top aligned content */
    transition:0.3s ease;
}

.side-room-card:hover {
    transform:translateY(-4px);
    box-shadow:0 18px 45px rgba(0,0,0,0.08);
}

/* IMAGE */

.side-room-img img {
    width:115px;
    height:105px;
    object-fit:cover;
    border-radius:14px;
    display:block;
}

/* CONTENT */

.side-room-content {
    flex:1;
    display:flex;
    flex-direction:column;
    gap:6px;   /* heading, desc, price ke beech uniform gap */
}

.side-room-content h4 {
    font-size:17px;
    font-weight:600;
    color:#183a2f;
    margin:0;
}

.side-room-content p {
    font-size:13px;
    color:#6b7d75;
    line-height:1.5;
    margin:0;
}

/* PRICE */

/* ==============================
   ROOMS TITLE SECTION
============================== */

.rooms-title-section {
    padding:100px 0 60px;
    background:#f6f8f7;
    text-align:center;
    position:relative;
}

.rooms-title-container {
    position:relative;
    max-width:800px;
    margin:auto;
}

.bg-title {
    position:absolute;
    top:-40px;
    left:50%;
    transform:translateX(-50%);
    font-size:120px;
    font-weight:800;
    color:#000;
    opacity:0.04;   /* light faded effect */
    letter-spacing:10px;
    pointer-events:none;
}

.rooms-title-section h2 {
    font-size:42px;
    color:#183a2f;
    margin-bottom:15px;
    position:relative;
    z-index:2;
}

.rooms-title-section p {
    color:#6b7d75;
    font-size:16px;
    line-height:1.6;
    position:relative;
    z-index:2;
}

/* Responsive */

@media(max-width:768px){

    .bg-title{
        font-size:70px;
        top:-20px;
    }

    .rooms-title-section h2{
        font-size:28px;
    }

    .rooms-title-section{
        padding:70px 0 40px;
    }
}


.side-price {
    font-size:15px;
    font-weight:600;
    color:#1f4f3a;
    margin-top:4px;
}

/* BUTTON ALIGN */

.side-room-content .btn-primary {
    margin-top:8px;
    align-self:flex-start;
    padding:8px 22px;
    font-size:13px;
}

/* ==============================
   RESPONSIVE
============================== */

@media(max-width:1200px){
    .rooms-grid{
        grid-template-columns:repeat(2,1fr);
    }
}

@media(max-width:992px){

    .rooms-grid{
        grid-template-columns:1fr;
    }

    .featured-container{
        flex-direction:column;
        gap:40px;
    }

    .featured-left,
    .featured-right{
        width:100%;
    }

    .big-room-image img{
        height:280px;
    }

    .big-room-content{
        padding:25px;
    }

    .big-room-content h2{
        font-size:24px;
    }

    .big-room-bottom{
        flex-direction:column;
        align-items:flex-start;
    }

    .side-room-img img{
        width:90px;
        height:80px;
    }
}

@media(max-width:576px){

    .rooms-header h2{
        font-size:28px;
    }

    .room-content{
        padding:20px;
    }

    .big-room-content{
        padding:20px;
    }

    .side-room-card{
        flex-direction:column;
        text-align:center;
    }

    .side-room-img img{
        width:100%;
        height:180px;
    }
}
/* /* ==============================
   HOME AMENITIES SECTION
============================== */

.home-amenities-section {
    padding:100px 20px;
    background:#f6f8f7;
}

/* ================= TITLE ================= */

.amenities-title {
    text-align:center;
    margin-bottom:60px;
    position:relative;
}

.amenities-title .bg-title {
    position:absolute;
    top:-40px;
    left:50%;
    transform:translateX(-50%);
    font-size:110px;
    font-weight:800;
    opacity:0.05;
    letter-spacing:8px;
    white-space:nowrap;
}

.amenities-title h2 {
    font-size:42px;
    color:#183a2f;
    margin-bottom:15px;
    position:relative;
    z-index:2;
}

.amenities-title p {
    color:#6b7d75;
    font-size:16px;
    max-width:600px;
    margin:0 auto;
}

/* ================= GRID ================= */

.amenities-grid {
    max-width:1200px;
    margin:auto;
    display:grid;
    grid-template-columns:repeat(4,1fr);
    gap:35px;
}

/* ================= CARD ================= */

.amenity-card {
    background:#fff;
    border-radius:24px;
    overflow:hidden;
    box-shadow:0 15px 40px rgba(0,0,0,0.05);
    transition:0.4s ease;
    display:flex;
    flex-direction:column;
}

.amenity-card:hover {
    transform:translateY(-6px);
    box-shadow:0 25px 60px rgba(0,0,0,0.08);
}

/* IMAGE */

.amenity-image {
    position:relative;
    overflow:hidden;
}

.amenity-image img {
    width:100%;
    height:260px;
    object-fit:cover;
    display:block;
    transition:0.4s ease;
}

.amenity-card:hover .amenity-image img {
    transform:scale(1.05);
}

/* Overlay */

.amenity-overlay {
    position:absolute;
    inset:0;
    background:rgba(68,134,105,0.5);
    display:flex;
    align-items:center;
    justify-content:center;
    opacity:0;
    transition:0.3s ease;
}

.amenity-overlay i {
    font-size:38px;
    color:#fff;
}

.amenity-card:hover .amenity-overlay {
    opacity:1;
}

/* CONTENT */

.amenity-content {
    padding:25px;
    flex:1;
}

.amenity-content h3 {
    font-size:20px;
    color:#183a2f;
    margin-bottom:10px;
}

.amenity-content p {
    font-size:14px;
    color:#6b7d75;
    line-height:1.6;
}

/* ================= RESPONSIVE ================= */

/* Large Tablets */
@media(max-width:992px){

    .amenities-grid{
        grid-template-columns:repeat(2,1fr);
        gap:25px;
    }

    .amenities-title .bg-title{
        font-size:70px;
        top:-20px;
    }

    .amenities-title h2{
        font-size:32px;
    }
}

/* Mobile */

@media(max-width:576px){

    .home-amenities-section{
        padding:70px 15px;
    }

    .amenities-grid{
        grid-template-columns:1fr;
        gap:20px;
    }

    .amenities-title .bg-title{
        font-size:50px;
        letter-spacing:4px;
    }

    .amenities-title h2{
        font-size:26px;
    }

    .amenity-image img{
        height:200px;
    }

    .amenity-content{
        padding:20px;
    }

    .amenity-content h3{
        font-size:18px;
    }

    .amenity-content p{
        font-size:13px;
    }
}
/* ==============================
   TESTIMONIAL SECTION
============================== */

.home-testimonial-section {
    padding:120px 20px;
    background:#f6f8f7;
}

.testimonial-wrapper {
    max-width:1000px;
    margin:auto;
    position:relative;
}

.testimonial-slider {
    overflow:hidden;
    border-radius:30px;
}

.testimonial-track {
    display:flex;
    transition:transform 0.5s ease-in-out;
}

/* CARD */

/* ==============================
   GLASSY TESTIMONIAL CARD
============================== */

.testimonial-card {
    min-width:100%;
    padding:70px;
    border-radius:32px;

    position:relative;
    overflow:hidden;

    /* Glass Background */
    background:linear-gradient(
        135deg,
        rgba(15, 42, 33, 0.85),
        rgba(7, 26, 20, 0.85)
    );

    backdrop-filter:blur(18px);
    -webkit-backdrop-filter:blur(18px);

    border:1px solid rgba(255,255,255,0.08);

    box-shadow:
        0 30px 60px rgba(0,0,0,0.25),
        inset 0 1px 0 rgba(255,255,255,0.08);

    color:#fff;
}
/* Light reflection sweep */

.testimonial-card::before {
    content:"";
    position:absolute;
    top:0;
    left:-75%;
    width:50%;
    height:100%;
    background:linear-gradient(
        120deg,
        rgba(255,255,255,0.15),
        rgba(255,255,255,0.03),
        rgba(255,255,255,0)
    );
    transform:skewX(-25deg);
    transition:0.8s ease;
}

.testimonial-card:hover::before {
    left:120%;
}
.testimonial-wrapper {
    max-width:1000px;
    margin:auto;
    position:relative;
}

.testimonial-wrapper::after {
    content:"";
    position:absolute;
    inset:0;
    border-radius:32px;
    background:radial-gradient(
        circle at top left,
        rgba(31,79,58,0.15),
        transparent 60%
    );
    z-index:-1;
}

/* Stars */

.testimonial-stars {
    color:#fbbf24;
    font-size:22px;
    margin-bottom:25px;
}

/* Quote */

.quote-icon {
    position:absolute;
    top:30px;
    right:40px;
    background:#1f4f3a;
    width:55px;
    height:55px;
    border-radius:50%;
    display:flex;
    align-items:center;
    justify-content:center;
    font-size:22px;
}

/* Text */

.testimonial-text {
    font-size:18px;
    line-height:1.8;
    margin-bottom:40px;
    color:#e4f0ea;
}

/* User */

.testimonial-user {
    display:flex;
    align-items:center;
    gap:18px;
}

.testimonial-user img {
    width:70px;
    height:70px;
    border-radius:50%;
    object-fit:cover;
    border:3px solid #1f4f3a;
}

.testimonial-user h4 {
    margin:0;
    font-size:22px;
}

.testimonial-user span {
    font-size:14px;
    color:#9ed2bf;
}

/* Controls */

.testimonial-controls {
    position:absolute;
    top:50%;
    left:0;
    right:0;
    transform:translateY(-50%);
    display:flex;
    justify-content:space-between;
    pointer-events:none;
}

.testimonial-controls button {
    pointer-events:auto;
    background:#1f4f3a;
    border:none;
    color:#fff;
    width:55px;
    height:55px;
    border-radius:50%;
    font-size:20px;
    cursor:pointer;
    transition:0.3s;
}

.testimonial-controls button:hover {
    background:#163a2b;
}

/* ================= RESPONSIVE ================= */

@media(max-width:992px){

    .testimonial-card{
        padding:50px 40px;
    }

    .testimonial-controls{
        top:auto;
        bottom:-70px;
        transform:none;
        justify-content:center;
        gap:25px;
    }
}

@media(max-width:576px){

    .testimonial-card{
        padding:35px 25px;
    }

    .testimonial-text{
        font-size:16px;
    }

    .testimonial-user{
        flex-direction:column;
        text-align:center;
    }

    .testimonial-controls{
        bottom:-60px;
    }
}
/* ==============================
   TESTIMONIAL TITLE
============================== */

.testimonial-title {
    text-align:center;
    margin-bottom:80px;
    position:relative;
}

.testimonial-title .bg-title {
    position:absolute;
    top:-45px;
    left:50%;
    transform:translateX(-50%);
    font-size:110px;
    font-weight:800;
    color:#000;
    opacity:0.04;
    letter-spacing:8px;
    pointer-events:none;
    white-space:nowrap;
}

.testimonial-title h2 {
    font-size:42px;
    font-weight:700;
    color:#183a2f;
    position:relative;
    z-index:2;
}

/* Responsive */

@media(max-width:992px){
    .testimonial-title .bg-title{
        font-size:70px;
        top:-25px;
    }

    .testimonial-title h2{
        font-size:32px;
    }
}

@media(max-width:576px){
    .testimonial-title .bg-title{
        font-size:50px;
        letter-spacing:4px;
    }

    .testimonial-title h2{
        font-size:26px;
    }
}
/* ==============================
   LUXURY STATIC SECTION
============================== */

.luxury-static-section {
    background:#eef3f1;
    padding:100px 0;
}

.luxury-container {
    max-width:1320px;
    margin:auto;
    display:flex;
    align-items:center;
    justify-content:space-between;
    gap:80px;
    padding:0 20px;
}

/* LEFT */

.luxury-left {
    width:50%;
}

.luxury-left h2 {
    font-size:44px;
    color:#183a2f;
    margin-bottom:20px;
}

.luxury-left p {
    font-size:16px;
    line-height:1.7;
    color:#5f6f65;
    margin-bottom:25px;
}

.luxury-features {
    list-style:none;
    padding:0;
    margin-bottom:35px;
}

.luxury-features li {
    margin-bottom:12px;
    color:#355c4d;
    font-size:15px;
}

/* BUTTONS */

.luxury-buttons {
    display:flex;
    gap:20px;
}

/* RIGHT */

.luxury-right {
    width:50%;
    position:relative;
}

.luxury-right img {
    width:100%;
    height:420px;
    object-fit:cover;
    border-radius:28px;
}

/* OFFER BADGE */

.offer-badge {
    bottom: 15px;
    position: absolute;
    /* top: 165px; */
    right: 6px;
    background: #1f4f3a;
    color: #fff;
    padding: 20px 25px;
    border-radius: 16px;
    text-align: center;
    box-shadow: 0 20px 50px rgba(0, 0, 0, 0.15);
}

.offer-badge span {
    font-size:13px;
    opacity:0.9;
}

.offer-badge h4 {
    font-size:22px;
    margin-top:5px;
}

/* ================= RESPONSIVE ================= */

@media(max-width:992px){

    .luxury-container {
        flex-direction:column;
        text-align:center;
        gap:50px;
    }

    .luxury-left,
    .luxury-right {
        width:100%;
    }

    .luxury-buttons {
        justify-content:center;
    }

    .offer-badge {
        position:relative;
        top:auto;
        right:auto;
        margin-top:20px;
    }
}
/* ==============================
   HOME AUTO GALLERY
============================== */

.home-gallery-section {
    background:#f6f8f7;
    padding:100px 0;
    overflow:hidden;
}

.gallery-container {
    max-width:1320px;
    margin:auto;
    overflow:hidden;
}

.gallery-track {
    display:flex;
    gap:30px;
    width:max-content;
    animation:scrollGallery 35s linear infinite;
}

.gallery-item {
    flex:0 0 auto;
    width:260px;
    border-radius:20px;
    overflow:hidden;
    box-shadow:0 15px 40px rgba(0,0,0,0.06);
    transition:0.4s ease;
}

.gallery-item img {
    width:100%;
    height:320px;
    object-fit:cover;
    display:block;
    transition:0.4s ease;
}

.gallery-item:hover img {
    transform:scale(1.08);
}

@keyframes scrollGallery {
    0% {
        transform:translateX(0);
    }
    100% {
        transform:translateX(-50%);
    }
}

/* Responsive */

@media(max-width:992px){
    .gallery-item{
        width:220px;
    }
    .gallery-item img{
        height:280px;
    }
}

@media(max-width:576px){
    .gallery-item{
        width:180px;
    }
    .gallery-item img{
        height:240px;
    }
}
.home-gallery-section::before,
.home-gallery-section::after {
    content:"";
    position:absolute;
    top:0;
    width:120px;
    height:100%;
    z-index:2;
    pointer-events:none;
}

.home-gallery-section::before {
    left:0;
    background:linear-gradient(to right,#f6f8f7,transparent);
}

.home-gallery-section::after {
    right:0;
    background:linear-gradient(to left,#f6f8f7,transparent);
}

/* ==============================
   PROFESSIONAL GALLERY SECTION
============================== */

.home-gallery-section {
    background:#f6f8f7;
    padding:120px 0 100px;
    position:relative;
    overflow:hidden;
}

/* ===== TITLE ===== */

.gallery-title {
    text-align:center;
    margin-bottom:70px;
    position:relative;
}

.gallery-title .bg-title {
    position:absolute;
    top:-45px;
    left:50%;
    transform:translateX(-50%);
    font-size:120px;
    font-weight:800;
    color:#000;
    opacity:0.04;
    letter-spacing:10px;
    pointer-events:none;
    white-space:nowrap;
}

.gallery-title h2 {
    font-size:42px;
    color:#183a2f;
    margin-bottom:15px;
    position:relative;
    z-index:2;
}

.gallery-title p {
    font-size:16px;
    color:#6b7d75;
    max-width:600px;
    margin:0 auto;
    line-height:1.7;
}

/* ===== SLIDER ===== */

.gallery-container {
    max-width:1320px;
    margin:auto;
    overflow:hidden;
}

.gallery-track {
    display:flex;
    gap:30px;
    width:max-content;
    animation:scrollGallery 35s linear infinite;
}

.gallery-item {
    flex:0 0 auto;
    width:260px;
    border-radius:22px;
    overflow:hidden;
    box-shadow:0 15px 40px rgba(0,0,0,0.06);
    transition:0.4s ease;
}

.gallery-item img {
    width:100%;
    height:320px;
    object-fit:cover;
    display:block;
    transition:0.4s ease;
}

.gallery-item:hover img {
    transform:scale(1.08);
}

@keyframes scrollGallery {
    0% { transform:translateX(0); }
    100% { transform:translateX(-50%); }
}

/* ===== RESPONSIVE ===== */

@media(max-width:992px){
    .gallery-title .bg-title{
        font-size:70px;
        top:-25px;
    }

    .gallery-title h2{
        font-size:32px;
    }

    .gallery-item{
        width:220px;
    }

    .gallery-item img{
        height:280px;
    }
}

@media(max-width:576px){
    .gallery-title .bg-title{
        font-size:50px;
        letter-spacing:4px;
    }

    .gallery-title h2{
        font-size:26px;
    }

    .gallery-item{
        width:180px;
    }

    .gallery-item img{
        height:240px;
    }
}