/* =========================================================
   INNER PAGE CSS
   Apex Cell Energy
========================================================= */

/* =========================================================
   GLOBAL
========================================================= */

.inner-page{
    background:#f5f7fb;
    overflow-x:hidden;
}

.section-padding{
    padding:100px 0;
}

.container{
    width:92%;
    max-width:1400px;
    margin:auto;
}

img{
    max-width:100%;
    height:auto;
}

/* =========================================================
   HERO SYSTEM
========================================================= */

.page-hero{
    position:relative;
    width:100%;
    min-height:680px;
    display:flex;
    align-items:center;
    overflow:hidden;
    background-size:cover !important;
    background-position:center !important;
}

.page-hero::before{
    content:'';
    position:absolute;
    inset:0;
    background:
    linear-gradient(
        90deg,
        rgba(0,0,0,.88) 0%,
        rgba(0,0,0,.68) 40%,
        rgba(0,0,0,.28) 100%
    );
    z-index:1;
}

.page-hero.light-overlay::before{
    background:
    linear-gradient(
        90deg,
        rgba(255,255,255,.92) 0%,
        rgba(255,255,255,.55) 42%,
        rgba(255,255,255,.12) 100%
    );
}

.page-hero-content{
    position:relative;
    z-index:2;
    max-width:760px;
}

.page-hero-subtitle,
.hero-mini-tag,
.card-tag{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    height:44px;
    padding:0 22px;
    border-radius:50px;
    background:#15B012;
    color:#fff;
    font-size:11px;
    font-weight:700;
    letter-spacing:1px;
    text-transform:uppercase;
    margin-bottom:26px;
}

.page-hero-title{
    font-size:78px;
    line-height:1.02;
    color:#fff;
    font-weight:700;
    margin-bottom:28px;
}

.page-hero.light-overlay .page-hero-title{
    color:#111827;
}

.page-hero-description{
    max-width:700px;
    color:#e2e8f0;
    font-size:18px;
    line-height:1.9;
    margin-bottom:38px;
}

.page-hero.light-overlay .page-hero-description{
    color:#475569;
}

.page-breadcrumb{
    position:absolute;
    left:0;
    bottom:34px;
    width:100%;
    z-index:3;
}

.page-breadcrumb .container{
    color:#fff;
    font-size:14px;
}

.page-breadcrumb a{
    color:#fff;
    text-decoration:none;
}



.page-hero.light-overlay .page-breadcrumb .container,
.page-hero.light-overlay .page-breadcrumb a{
    color:#111827;
}

/* =========================================================
   HERO LAYOUTS
========================================================= */

.premium-about-hero,
.premium-contact-hero{
    min-height:760px;
}

.premium-hero-grid,
.premium-contact-grid{
    position:relative;
    z-index:2;
    display:grid;
    grid-template-columns:1.1fr .75fr;
    gap:60px;
    align-items:center;
    padding:120px 0;
}

.hero-glow{
    position:absolute;
    top:-120px;
    right:-120px;
    width:420px;
    height:420px;
    background:rgba(21,176,18,.18);
    filter:blur(100px);
    border-radius:50%;
    z-index:1;
}

/* =========================================================
   BUTTONS
========================================================= */

.hero-btn-wrap,
.action-buttons,
.success-actions{
    display:flex;
    gap:18px;
    flex-wrap:wrap;
}

.primary-btn,
.secondary-btn,
.outline-btn,
.dark-btn{
    min-width:180px;
    height:58px;
    padding:0 34px;
    border-radius:16px;
    display:inline-flex;
    align-items:center;
    justify-content:center;
    text-decoration:none;
    border:none;
    cursor:pointer;
    font-size:15px;
    font-weight:600;
    transition:.3s ease;
}

.primary-btn{
    background:#15B012;
    color:#fff;
}

.primary-btn:hover{
    background:#11940F;
}

.secondary-btn{
    background:rgba(255,255,255,.08);
    border:1px solid rgba(255,255,255,.25);
    color:#fff;
    backdrop-filter:blur(10px);
}

.secondary-btn:hover{
    background:#fff;
    color:#111827;
}

.outline-btn{
    background:#fff;
    border:1px solid #dbe2ea;
    color:#111827;
}

.outline-btn:hover{
    background:#f8fafc;
}

.dark-btn{
    background:#111827;
    color:#fff;
}

.dark-btn:hover{
    background:#15B012;
}

/* =========================================================
   SECTION TITLES
========================================================= */

.section-title{
    margin-bottom:60px;
}

.section-title.center{
    text-align:center;
}

.section-title span,
.section-subtitle{
    display:inline-block;
    color:#15B012;
    font-size:13px;
    font-weight:700;
    letter-spacing:1px;
    text-transform:uppercase;
    margin-bottom:16px;
}

.section-title h2{
    font-size:54px;
    line-height:1.12;
    color:#111827;
    margin-bottom:18px;
    font-weight:700;
}

.section-title p{
    max-width:760px;
    margin:auto;
    color:#64748b;
    line-height:1.9;
    font-size:17px;
}

/* =========================================================
   CONTENT BOXES
========================================================= */

.white-box,
.content-box,
.glass-card,
.feature-card,
.service-table,
.success-box{
    background:#fff;
    border-radius:32px;
    box-shadow:
    0 10px 35px rgba(0,0,0,.05);
}

.white-box,
.content-box{
    padding:45px;
}

.glass-card{
    background:rgba(255,255,255,.08);
    border:1px solid rgba(255,255,255,.10);
    backdrop-filter:blur(18px);
    padding:40px;
}

.success-box{
    max-width:760px;
    margin:auto;
    padding:70px 50px;
    text-align:center;
}

/* =========================================================
   HERO STATS
========================================================= */

.hero-mini-stats{
    display:flex;
    flex-wrap:wrap;
    gap:18px;
    margin-top:8px;
}

.mini-stat{
    min-width:150px;
    padding:22px 24px;
    border-radius:24px;
    background:rgba(255,255,255,.08);
    border:1px solid rgba(255,255,255,.10);
    backdrop-filter:blur(14px);
}

.mini-stat h3{
    font-size:32px;
    line-height:1;
    color:#15B012;
    margin-bottom:10px;
    font-weight:700;
}

.mini-stat span{
    color:#fff;
    font-size:14px;
}

/* =========================================================
   FEATURE POINTS
========================================================= */

.feature-points,
.about-card-points{
    display:grid;
    gap:16px;
}

.feature-point,
.about-point{
    padding:18px 20px;
    border-radius:18px;
    background:rgba(255,255,255,.06);
    color:#fff;
    font-size:15px;
    font-weight:500;
}

/* =========================================================
   ABOUT PAGE
========================================================= */

.about-page{
    background:
    linear-gradient(
        180deg,
        #f8fafc 0%,
        #eef2f7 100%
    );
}

/* =========================================================
   ABOUT COMPANY LAYOUT
========================================================= */

.about-grid{
    display:grid;
    grid-template-columns:1.02fr .98fr;
    gap:70px;
    align-items:start;
    position:relative;
}

/* =========================================================
   ABOUT IMAGE
========================================================= */

.about-image{
    position:relative;
}

.about-image img{
    width:100%;
    height:auto;
    display:block;
    border-radius:36px;
    transition:.5s ease;
    box-shadow:
    0 30px 60px rgba(15,23,42,.14);
}

.about-image:hover img{
    transform:translateY(-8px);
}

.premium-image-wrap{
    position:relative;
}

.premium-image-wrap::before{
    content:'';
    position:absolute;
    inset:-22px;
    border-radius:42px;
    background:
    linear-gradient(
        135deg,
        rgba(21,176,18,.10),
        rgba(255,255,255,0)
    );
    z-index:-1;
}

.premium-image-wrap::after{
    content:'';
    position:absolute;
    right:-28px;
    bottom:-28px;
    width:220px;
    height:220px;
    border-radius:34px;
    background:
    linear-gradient(
        135deg,
        #15B012,
        #11940F
    );
    opacity:.10;
    z-index:-1;
}

.about-content{
    max-width:640px;
}

.about-content h2{
    font-size:64px;
    line-height:1.02;
    letter-spacing:-2px;
    color:#111827;
    margin-bottom:30px;
}

.about-content p{
    color:#64748b;
    line-height:2;
    margin-bottom:22px;
    font-size:17px;
}

/* =========================================================
   FEATURE GRID
========================================================= */

.about-feature-grid{
    display:grid;
    grid-template-columns:repeat(4,1fr);
    gap:20px;
    margin-top:42px;
}

.why-grid{
    display:grid;
    grid-template-columns:repeat(2,1fr);
    gap:24px;
    margin-top:42px;
}

.feature-item,
.why-card{
    position:relative;
    overflow:hidden;
    background:#fff;
    border-radius:28px;
    padding:32px;
    border:1px solid #edf2f7;
    box-shadow:
    0 10px 35px rgba(15,23,42,.05);
    transition:.35s ease;
}

.feature-item::before,
.why-card::before{
    content:'';
    position:absolute;
    inset:0;
    background:
    linear-gradient(
        135deg,
        rgba(21,176,18,.06),
        transparent
    );
    opacity:0;
    transition:.35s ease;
}

.feature-item:hover,
.why-card:hover{
    transform:translateY(-8px);
    box-shadow:
    0 22px 45px rgba(15,23,42,.10);
}

.feature-item:hover::before,
.why-card:hover::before{
    opacity:1;
}

/* =========================================================
   FEATURE ITEM
========================================================= */

.feature-item{
    min-height:120px;
    display:flex;
    flex-direction:column;
    align-items:flex-start;
    justify-content:center;
    gap:18px;
}

.feature-item i,
.why-icon{
    width:72px;
    height:72px;
    min-width:72px;
    border-radius:22px;
    background:
    linear-gradient(
        135deg,
        #15B012,
        #11940F
    );
    color:#fff;
    display:flex;
    align-items:center;
    justify-content:center;
    font-size:26px;
    box-shadow:
    0 10px 24px rgba(21,176,18,.25);
}

.feature-item span{
    font-weight:700;
    color:#111827;
    font-size:16px;
    line-height:1.45;
}



.feature-text h4{
    font-size:18px;
    line-height:1.35;
    color:#111827;
    margin-bottom:10px;
    font-weight:700;
}

.feature-text p{
    margin:0;
    font-size:14px;
    line-height:1.7;
    color:#64748b;
}

/* =========================================================
   RESPONSIVE
========================================================= */

@media(max-width:1200px){

    .about-feature-grid{
        grid-template-columns:repeat(2,1fr);
    }

}

@media(max-width:768px){

    .about-feature-grid,
    .why-grid{
        grid-template-columns:1fr;
    }

}

/* =========================================================
   WHY SECTION
========================================================= */

.why-section{
    position:relative;
}

.why-section::before{
    content:'';
    position:absolute;
    top:120px;
    right:-120px;
    width:360px;
    height:360px;
    border-radius:50%;
    background:
    rgba(21,176,18,.08);
    filter:blur(100px);
}

.why-card h3{
    font-size:28px;
    color:#111827;
    margin:24px 0 16px;
    line-height:1.25;
}

.why-card p{
    color:#64748b;
    line-height:1.9;
    font-size:15px;
}

/* =========================================================
   DIRECTOR SECTION
========================================================= */

.director-section{

    padding:100px 0;

    background:#f8fafc;
}

/* GRID */

.director-grid{

    display:grid;

    grid-template-columns:
    350px
    1fr;

    gap:80px;

    align-items:center;
}

/* IMAGE BOX */

.director-image{

    position:relative;

    width:350px;

    border-radius:24px;

    overflow:hidden;

    box-shadow:
    0 18px 50px rgba(0,0,0,.08);
}

.director-image img{

    width:100%;

    height:420px;

    object-fit:cover;

    display:block;
}

/* =========================================================
   CONTENT
========================================================= */

.director-content .section-subtitle{

    display:inline-block;

    color:#15B012;

    font-size:14px;

    font-weight:600;

    text-transform:uppercase;

    letter-spacing:1px;

    margin-bottom:18px;
}

.director-content h2{

    font-size:52px;

    line-height:1.16;

    color:#111827;

    margin-bottom:26px;

    font-weight:700;

    max-width:720px;
}

.director-content p{

    color:#64748b;

    font-size:17px;

    line-height:1.9;

    margin-bottom:24px;

    max-width:760px;
}

/* =========================================================
   DIRECTOR INFO
========================================================= */

.director-info{

    margin-top:36px;

    padding-top:28px;

    border-top:1px solid #e5e7eb;
}

.director-info h4{

    font-size:24px;

    color:#111827;

    margin-bottom:8px;

    font-weight:700;
}

.director-info span{

    color:#15B012;

    font-size:15px;

    font-weight:600;

    letter-spacing:.5px;
}

/* =========================================================
   TABLET
========================================================= */

@media(max-width:992px){

    .director-section{
        padding:90px 0;
    }

    .director-grid{

        grid-template-columns:1fr;

        gap:40px;
    }

    .director-image{

        max-width:420px;

        margin:auto;
    }

    .director-image img{

        height:500px;
    }

    .director-content{

        text-align:center;
    }

    .director-content h2{

        font-size:42px;

        margin:auto auto 24px;
    }

    .director-content p{

        margin-left:auto;
        margin-right:auto;
    }

}

/* =========================================================
   MOBILE
========================================================= */

@media(max-width:768px){

    .director-section{
        padding:70px 0;
    }

    .director-grid{
        gap:30px;
    }

    .director-image{

        width:260px;

        margin:auto;

        border-radius:20px;
    }

    .director-image img{

        height:340px;
    }

    .director-content{

        text-align:center;
    }

    .director-content h2{

        font-size:32px;

        line-height:1.25;

        margin-bottom:22px;
    }

    .director-content p{

        font-size:15px;

        line-height:1.8;

        margin-bottom:18px;
    }

    .director-info{

        margin-top:28px;

        padding-top:22px;
    }

    .director-info h4{

        font-size:22px;
    }

}

/* =========================================================
   CTA
========================================================= */

.about-cta{
    padding:10px 0 110px;
}

.premium-cta-box{
    position:relative;
    overflow:hidden;
    background:
    linear-gradient(
        135deg,
        #0f172a 0%,
        #1e293b 100%
    );
    border-radius:42px;
    padding:95px 70px;
    text-align:center;
    box-shadow:
    0 35px 80px rgba(15,23,42,.18);
}

.premium-cta-box::before{
    content:'';
    position:absolute;
    top:-180px;
    right:-100px;
    width:420px;
    height:420px;
    border-radius:50%;
    background:
    rgba(21,176,18,.16);
    filter:blur(100px);
}

.cta-tag{
    position:relative;
    z-index:2;
    display:inline-flex;
    align-items:center;
    justify-content:center;
    height:46px;
    padding:0 24px;
    border-radius:50px;
    background:#15B012;
    color:#fff;
    font-size:11px;
    font-weight:700;
    letter-spacing:1px;
    margin-bottom:28px;
}

.premium-cta-box h2{
    position:relative;
    z-index:2;
    font-size:64px;
    line-height:1.05;
    letter-spacing:-2px;
    color:#fff;
    margin-bottom:26px;
}

.premium-cta-box p{
    position:relative;
    z-index:2;
    max-width:760px;
    margin:0 auto 40px;
    color:#dbe4f0;
    line-height:1.9;
    font-size:18px;
}

/* =========================================================
   FEATURE POINT ICONS
========================================================= */

.feature-point{
    display:flex;
    align-items:center;
    gap:12px;
}

.feature-point i{
    width:18px;
    min-width:18px;
    color:#15B012;
    font-size:15px;
}

/* =========================================================
   RESPONSIVE
========================================================= */

@media(max-width:1200px){

    .about-grid{
        gap:55px;
    }

    .about-image img{
        height:560px;
    }

}

@media(max-width:992px){

    .about-grid{
        grid-template-columns:1fr;
        gap:50px;
    }

    .about-content{
        max-width:100%;
    }

    .about-content h2{
        font-size:46px;
    }

    .about-image img{
        height:auto;
    }

    .premium-cta-box{
        padding:75px 40px;
    }

    .premium-cta-box h2{
        font-size:48px;
    }

}

@media(max-width:768px){

    .about-grid{
        gap:45px;
    }

    .about-content h2{
        font-size:38px;
        line-height:1.08;
    }

    .about-content p{
        font-size:15px;
        line-height:1.9;
    }

    .about-feature-grid,
    .why-grid{
        grid-template-columns:1fr;
        gap:18px;
    }

    .feature-item,
    .why-card{
        padding:24px;
    }

    .feature-item i,
    .why-icon{
        width:64px;
        height:64px;
        min-width:64px;
        font-size:22px;
    }

    .why-card h3{
        font-size:24px;
    }

    .premium-cta-box{
        padding:65px 28px;
        border-radius:32px;
    }

    .premium-cta-box h2{
        font-size:36px;
        line-height:1.15;
    }

    .premium-cta-box p{
        font-size:15px;
    }

}

/* =========================================================
   FORM SYSTEM
========================================================= */

.form-grid,
.support-form-grid{
    display:grid;
    grid-template-columns:repeat(2,1fr);
    gap:20px;
}

.form-group,
.support-form-group{
    display:flex;
    flex-direction:column;
}

.full-width{
    grid-column:1/-1;
}

.form-group label,
.support-form-group label{
    font-size:15px;
    font-weight:600;
    color:#111827;
    margin-bottom:10px;
}

.form-group input,
.form-group textarea,
.form-group select,
.support-form-group input,
.support-form-group textarea,
.support-form-group select{
    width:100%;
    border:1px solid #dbe2ea;
    border-radius:14px;
    background:#fff;
    font-size:15px;
    color:#111827;
    outline:none;
    transition:.3s;
    box-sizing:border-box;
    padding:16px 18px;
}

.form-group input,
.form-group select,
.support-form-group input,
.support-form-group select{
    height:56px;
}

.form-group textarea,
.support-form-group textarea{
    min-height:180px;
    resize:none;
}

.form-group input:focus,
.form-group textarea:focus,
.form-group select:focus,
.support-form-group input:focus,
.support-form-group textarea:focus,
.support-form-group select:focus{
    border-color:#15B012;
    box-shadow:0 0 0 4px rgba(21,176,18,.08);
}

/* =========================================================
   CONTACT
========================================================= */

.contact-section,
.support-main,
.thankyou-page{
    padding:100px 0;
}

.contact-wrapper{
    display:grid;
    grid-template-columns:1.1fr .9fr;
    gap:35px;
    align-items:start;
}

.contact-form,
.contact-info,
.support-box{
    background:#fff;
    border-radius:30px;
    padding:40px;
    box-shadow:
    0 10px 35px rgba(0,0,0,.05);
}

.contact-info h3{
    font-size:34px;
    margin-bottom:30px;
    color:#111827;
}

.info-item{
    display:flex;
    align-items:flex-start;
    gap:18px;
    margin-bottom:30px;
}

.info-icon{
    min-width:60px;
    width:60px;
    height:60px;
    border-radius:50%;
    background:#E8F9E8;
    display:flex;
    align-items:center;
    justify-content:center;
    font-size:24px;
    color:#15B012;
}

.info-content h4{
    font-size:20px;
    margin-bottom:8px;
    color:#111827;
}

.info-content p,
.info-content a{
    color:#64748b;
    line-height:1.9;
    text-decoration:none;
}

.map-section{
    margin-top:50px;
}

.map-box{
    overflow:hidden;
    border-radius:30px;
    box-shadow:
    0 10px 35px rgba(0,0,0,.05);
}

.map-box iframe{
    width:100%;
    height:480px;
    border:none;
    display:block;
}

/* =========================================================
   SUPPORT PAGE
========================================================= */

.issue-grid{
    display:grid;
    grid-template-columns:repeat(4,1fr);
    gap:16px;
    margin-top:25px;
}

.issue-item{
    display:flex;
    align-items:center;
    gap:12px;
    padding:16px;
    border-radius:16px;
    background:#f8fafc;
    border:1px solid #e5e7eb;
    transition:.3s ease;
}

.issue-item:hover{
    background:#fff;
    border-color:#15B012;
}

.issue-item span{
    font-size:14px;
    font-weight:500;
    color:#111827;
}

.filter-tabs,
.state-tabs{
    display:flex;
    gap:14px;
    flex-wrap:wrap;
    margin-bottom:35px;
}

.filter-tab,
.state-tab{
    padding:14px 24px;
    border-radius:50px;
    background:#fff;
    border:1px solid #e5e7eb;
    font-size:14px;
    font-weight:600;
    color:#111827;
    cursor:pointer;
    transition:.3s ease;
}

.filter-tab.active,
.filter-tab:hover,
.state-tab.active,
.state-tab:hover{
    background:#111827;
    border-color:#111827;
    color:#fff;
}

.service-table{
    overflow:hidden;
}

.service-row{
    display:grid;
    grid-template-columns:1.3fr 1fr 1.2fr 180px;
    gap:20px;
    align-items:center;
    padding:30px 35px;
    border-bottom:1px solid #e5e7eb;
}

.service-row:last-child{
    border-bottom:none;
}

.service-city h4{
    font-size:24px;
    margin-bottom:8px;
    color:#111827;
}

.service-city p{
    color:#64748b;
    line-height:1.7;
}

.service-phone,
.service-email{
    color:#111827;
    line-height:1.8;
    word-break:break-word;
}

.support-box{
    margin-bottom:50px;
}


/* =========================================================
   CUSTOMER SUPPORT HERO
========================================================= */

.customer-support-hero{

    background-image:
    linear-gradient(
        90deg,
        rgba(15,23,42,.92),
        rgba(15,23,42,.68)
    ),
    url('/assets/img/banner/customer-support-banner.webp');

    background-position:center;
    background-size:cover;
    background-repeat:no-repeat;
}

/* =========================================================
   LEGAL CONTENT
========================================================= */

.white-box h2,
.white-box h3,
.white-box h4{
    color:#111827;
    font-weight:700;
    line-height:1.3;
    margin-top:38px;
    margin-bottom:18px;
}

.white-box h2{
    font-size:38px;
}

.white-box h3{
    font-size:28px;
}

.white-box h4{
    font-size:22px;
}

.white-box p{
    color:#64748b;
    line-height:1.95;
    margin-bottom:22px;
    font-size:16px;
}

.white-box ul,
.white-box ol{
    margin:0 0 28px 22px;
    padding:0;
}

.white-box li{
    color:#64748b;
    line-height:1.9;
    margin-bottom:12px;
}

.white-box a{
    color:#15B012;
    text-decoration:none;
    font-weight:600;
}

.white-box a:hover{
    text-decoration:underline;
}

/* =========================================================
   THANK YOU
========================================================= */

.success-icon,
.thankyou-icon{
    width:100px;
    height:100px;
    margin:auto auto 30px;
    border-radius:50%;
    background:#E8F9E8;
    display:flex;
    align-items:center;
    justify-content:center;
    font-size:48px;
    color:#15B012;
}

.success-box span,
.thankyou-box span{
    display:inline-block;
    color:#15B012;
    font-size:15px;
    font-weight:600;
    text-transform:uppercase;
    letter-spacing:.5px;
    margin-bottom:18px;
}

.success-box h1,
.thankyou-box h1{
    font-size:54px;
    line-height:1.1;
    color:#111827;
    margin-bottom:20px;
}

.success-box p,
.thankyou-box p{
    max-width:620px;
    margin:auto;
    font-size:17px;
    line-height:1.9;
    color:#64748b;
}

/* =========================================================
   RESPONSIVE
========================================================= */

@media(max-width:1200px){

    .premium-hero-grid,
    .premium-contact-grid{
        grid-template-columns:1fr;
    }

    .issue-grid{
        grid-template-columns:repeat(2,1fr);
    }

}

@media(max-width:992px){

    .about-grid,
    .contact-wrapper,
    .about-feature-grid,
    .why-grid{
        grid-template-columns:1fr;
    }

    .service-row{
        grid-template-columns:1fr;
    }

    .page-hero-title{
        font-size:58px;
    }

}

@media(max-width:768px){

    .section-padding,
    .contact-section,
    .support-main,
    .thankyou-page{
        padding:70px 0;
    }

    .page-hero,
    .premium-about-hero,
    .premium-contact-hero{
        min-height:auto;
    }

    .premium-hero-grid,
    .premium-contact-grid{
        padding:90px 0 80px;
        gap:40px;
    }

    .page-hero-title{
        font-size:42px;
    }

    .page-hero-description{
        font-size:16px;
    }

    .section-title h2,
    .about-content h2,
    .premium-cta-box h2{
        font-size:36px;
    }

    .white-box,
    .content-box,
    .contact-form,
    .contact-info,
    .support-box,
    .glass-card,
    .success-box{
        padding:28px;
    }

    .form-grid,
    .support-form-grid,
    .issue-grid{
        grid-template-columns:1fr;
    }

    .hero-mini-stats{
        gap:14px;
    }

    .mini-stat{
        min-width:120px;
        padding:18px;
    }

    .map-box iframe{
        height:340px;
    }

    .success-box h1,
    .thankyou-box h1{
        font-size:38px;
    }

    .success-actions,
    .thankyou-buttons{
        flex-direction:column;
    }

    .primary-btn,
    .secondary-btn,
    .outline-btn,
    .dark-btn{
        width:100%;
    }

}

/* =========================================================
   CONTACT HERO 
========================================================= */

.contact-hero{
    position:relative;
}

.contact-hero::before{
    display:none;
}


/* =========================================================
   GALLERY PAGE
========================================================= */

.gallery-page{
    background:#f5f7fb;
}

/* =========================================================
   GALLERY HERO
========================================================= */

.gallery-hero{
    position:relative;
    min-height:680px;
    display:flex;
    align-items:center;
    overflow:hidden;
    background:
    linear-gradient(
        100deg,
        rgba(2,6,23,.92) 0%,
        rgba(2,6,23,.72) 42%,
        rgba(2,6,23,.28) 100%
    ),
    url('/assets/img/banner/gallery-banner.webp')
    center center/cover no-repeat;
}

.gallery-hero::before{
    content:'';
    position:absolute;
    top:-120px;
    right:-120px;
    width:420px;
    height:420px;
    background:rgba(21,176,18,.18);
    filter:blur(100px);
    border-radius:50%;
}

.gallery-hero-content{
    position:relative;
    z-index:2;
    max-width:760px;
}

.gallery-hero-content span{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    height:44px;
    padding:0 22px;
    border-radius:50px;
    background:#15B012;
    color:#fff;
    font-size:11px;
    font-weight:700;
    letter-spacing:1px;
    text-transform:uppercase;
    margin-bottom:26px;
}

.gallery-hero-content h1{
    font-size:78px;
    line-height:1.02;
    color:#fff;
    font-weight:700;
    margin-bottom:28px;
}

.gallery-hero-content p{
    max-width:700px;
    color:#e2e8f0;
    font-size:18px;
    line-height:1.9;
}

/* =========================================================
   GALLERY MAIN
========================================================= */

.gallery-main{
    padding:100px 0;
}

.gallery-grid{
    display:grid;
    grid-template-columns:repeat(3,1fr);
    gap:28px;
}

/* =========================================================
   GALLERY CARD
========================================================= */

.gallery-card{
    position:relative;
    border-radius:30px;
    overflow:hidden;
    background:#fff;
    box-shadow:
    0 10px 35px rgba(0,0,0,.05);
}

.gallery-image{
    position:relative;
    overflow:hidden;
}

.gallery-image img{
    width:100%;
    height:420px;
    object-fit:cover;
    display:block;
    transition:transform .6s ease;
}

.gallery-card:hover img{
    transform:scale(1.08);
}

/* =========================================================
   GALLERY OVERLAY
========================================================= */

.gallery-overlay{
    position:absolute;
    inset:0;
    display:flex;
    align-items:flex-end;
    padding:32px;
    background:
    linear-gradient(
        180deg,
        rgba(0,0,0,0) 0%,
        rgba(0,0,0,.82) 100%
    );
}

.gallery-content span{
    display:inline-block;
    color:#15B012;
    font-size:12px;
    font-weight:700;
    letter-spacing:1px;
    text-transform:uppercase;
    margin-bottom:14px;
}

.gallery-content h3{
    color:#fff;
    font-size:28px;
    margin-bottom:14px;
    line-height:1.2;
}

.gallery-content p{
    color:#dbe4f0;
    line-height:1.8;
    font-size:15px;
}

/* =========================================================
   VIDEO SECTION
========================================================= */

.gallery-video-section{
    padding:0 0 100px;
}

.video-box{
    position:relative;
    overflow:hidden;
    border-radius:40px;
    padding:120px 60px;
    text-align:center;
    background:
    linear-gradient(
        135deg,
        #111827 0%,
        #1f2937 100%
    );
}

.video-content h2{
    color:#fff;
    font-size:58px;
    line-height:1.12;
    margin-bottom:20px;
}

.video-content p{
    color:#dbe4f0;
    font-size:18px;
    margin-bottom:35px;
}

.play-btn{
    width:90px;
    height:90px;
    border-radius:50%;
    background:#15B012;
    color:#fff;
    display:inline-flex;
    align-items:center;
    justify-content:center;
    text-decoration:none;
    font-size:34px;
    transition:.3s ease;
}

.play-btn:hover{
    transform:scale(1.08);
}

/* =========================================================
   RESPONSIVE
========================================================= */

@media(max-width:1200px){

    .gallery-grid{
        grid-template-columns:repeat(2,1fr);
    }

}

@media(max-width:768px){

    .gallery-hero{
        min-height:auto;
        padding:120px 0 80px;
    }

    .gallery-hero-content h1{
        font-size:42px;
    }

    .gallery-hero-content p{
        font-size:16px;
    }

    .gallery-main{
        padding:70px 0;
    }

    .gallery-grid{
        grid-template-columns:1fr;
    }

    .gallery-image img{
        height:360px;
    }

    .gallery-video-section{
        padding:0 0 70px;
    }

    .video-box{
        padding:70px 28px;
    }

    .video-content h2{
        font-size:36px;
    }

}

/* =========================================================
   SITEMAP
========================================================= */

.sitemap-grid{
    display:grid;
    grid-template-columns:repeat(4,1fr);
    gap:30px;
    margin-top:50px;
}

.sitemap-grid .content-box{
    height:100%;
}

.sitemap-grid .content-box h3{
    margin-top:0 !important;
    margin-bottom:26px !important;
}

.sitemap-grid .content-box ul{
    list-style:none;
    margin:0;
    padding:0;
}

.sitemap-grid .content-box li{
    margin-bottom:16px;
}

.sitemap-grid .content-box li:last-child{
    margin-bottom:0;
}

/* =========================================================
   RESPONSIVE
========================================================= */

@media(max-width:1200px){

    .sitemap-grid{
        grid-template-columns:repeat(2,1fr);
    }

}

@media(max-width:768px){

    .sitemap-grid{
        grid-template-columns:1fr;
    }

}


/* =========================================================
   SUCCESS MESSAGE
========================================================= */


.success-message{

    background:#dcfce7;

    color:#166534;

    padding:18px 22px;

    border-radius:14px;

    margin-bottom:26px;

    font-weight:600;

    text-align:center;
}

/* =========================================================
   CONTACT PAGE MOBILE OVERFLOW 
========================================================= */

@media(max-width:768px){

    .contact-wrapper{

        display:flex;

        flex-direction:column;

        gap:24px;

        width:100%;
    }

    .contact-form,
    .contact-info{

        width:100%;

        max-width:100%;

        padding:24px;

        box-sizing:border-box;

        overflow:hidden;
    }

    .info-item{

        gap:14px;
    }

    .info-content{

        width:100%;

        overflow-wrap:anywhere;
    }

}