:root{
    --bg: #f5f1e8;
    --surface: rgba(255,255,255,0.76);
    --surface-strong: #ffffff;
    --text: #012350;
    --muted: #526172;
    --line: rgba(1,35,80,0.10);
    --accent: #6BA300;
    --accent-2: #012350;
    --shadow: 0 30px 80px rgba(1,35,80,0.12);
    --radius: 28px;
}

*{
    box-sizing:border-box;
}

html{
    scroll-behavior:smooth;
}

body{
    margin:0;
    font-family:'Inter', sans-serif;
    color:var(--text);
    background:
        radial-gradient(circle at top left, rgba(107,163,0,0.15), transparent 32%),
        radial-gradient(circle at top right, rgba(1,35,80,0.12), transparent 28%),
        linear-gradient(180deg, #fbf8f1 0%, #f4efe5 100%);
    overflow-x:hidden;
}

img{
    max-width:100%;
    display:block;
}

a{
    color:inherit;
}

.container-fluid,
.container{
    position:relative;
}

.section{
    padding:80px 0;
}

.eyebrow{
    display:inline-flex;
    align-items:center;
    gap:10px;
    padding:10px 16px;
    border:1px solid var(--line);
    border-radius:999px;
    color:var(--accent);
    text-transform:uppercase;
    letter-spacing:.16em;
    font-size:12px;
    font-weight:700;
    background:rgba(255,255,255,0.45);
}

.eyebrow::before{
    content:'';
    width:8px;
    height:8px;
    border-radius:50%;
    background:var(--accent-2);
    box-shadow:0 0 0 6px rgba(1,35,80,0.12);
}

.section-title{
    font-family:'Cormorant Garamond', serif;
    font-size:clamp(2.4rem, 3vw, 4.5rem);
    line-height:.96;
    letter-spacing:-.03em;
    margin:18px 0 16px;
}

.section-lead{
    max-width:520px;
    color:#111827;
    font-size:1.05rem;
    line-height:1.9;
}

.glass{
    background:var(--surface);
    backdrop-filter:blur(14px);
    -webkit-backdrop-filter:blur(14px);
    border:1px solid rgba(255,255,255,0.7);
    box-shadow:var(--shadow);
}

.btn-elegant{
    display:inline-flex;
    align-items:center;
    gap:12px;
    padding:16px 26px;
    border-radius:999px;
    text-decoration:none;
    font-weight:700;
    transition:transform .25s ease, box-shadow .25s ease, background .25s ease;
}

.btn-elegant:hover{
    transform:translateY(-2px);
}

.btn-primary-elegant{
    background:var(--accent);
    color:var(--text);
    box-shadow:0 14px 30px rgba(107,163,0,0.28);
}

.btn-primary-elegant:hover{
    color:#fff;
    box-shadow:0 18px 34px rgba(107,163,0,0.34);
}

.btn-secondary-elegant{
    border:1px solid var(--line);
    color:var(--text);
    background:rgba(255,255,255,0.5);
}

/* Header */
.site-header{
    background:#fff;
    border-bottom:1px solid #e8e8e8;
}

.header-top{
    padding:18px 0 10px;
}

.header-top-grid{
    display:grid;
    grid-template-columns:minmax(170px, 210px) minmax(0, 1fr) auto;
    align-items:center;
    gap:20px;
}

.site-logo{
    display:inline-flex;
    align-items:center;
    text-decoration:none;
}

.site-logo img{
    max-width:220px;
    height:auto;
}

.award-marquee{
    min-width:0;
    border-radius:0;
    border-left:1px solid #ededed;
    border-right:1px solid #ededed;
    box-shadow:none;
    background:#fff;
    padding:4px 10px;
}

.header-awards{
    display:grid;
    grid-template-columns:repeat(3, minmax(0, 1fr));
    align-items:center;
    gap:0;
}

.award-marquee .owl-stage{
    display:flex;
    align-items:center;
}

.award-card{
    display:flex;
    align-items:center;
    gap:12px;
    padding:6px 14px;
    min-height:56px;
    border-right:1px solid #e5e5e5;
}

.header-awards .award-card{
    justify-content:center;
}

.award-card-center{
    position:relative;
}

.award-year{
    flex:0 0 auto;
    font-size:.86rem;
    font-weight:800;
    color:var(--accent);
    letter-spacing:.02em;
}

.award-text{
    display:flex;
    flex-direction:column;
    line-height:1.1;
}

.award-text strong{
    font-size:.72rem;
    text-transform:uppercase;
    letter-spacing:.04em;
    color:var(--text);
    white-space:nowrap;
}

.award-text span{
    font-size:.66rem;
    color:#6e6e6e;
    white-space:nowrap;
}

.header-actions{
    display:flex;
    align-items:center;
    gap:28px;
    font-size:1rem;
    color:#3a3a3a;
    white-space:nowrap;
}

.header-actions a{
    text-decoration:none;
    display:inline-flex;
    align-items:center;
    gap:10px;
    font-weight:500;
}

.header-actions a:hover{
    color:var(--accent);
}

.header-actions i{
    font-size:1.15rem;
}

.header-actions span{
    line-height:1;
}

.header-nav{
    border-top:1px solid #efefef;
    border-bottom:1px solid #ececec;
    background:linear-gradient(180deg, #ffffff 0%, #fcfcfb 100%);
    box-shadow:inset 0 1px 0 rgba(255,255,255,0.8);
}

.header-nav .navbar{
    padding:0;
    min-height:74px;
}

.header-menu{
    gap:10px 26px;
    align-items:center;
    margin-left:auto !important;
    margin-right:0 !important;
}

.header-menu .nav-link{
    position:relative;
    padding:20px 12px 18px !important;
    font-family:'Inter', sans-serif;
    font-size:1.35rem;
    line-height:1;
    font-weight:500;
    color:#1b1b1b !important;
    letter-spacing:-.02em;
    border-radius:14px 14px 0 0;
    transition:color .2s ease, background-color .2s ease, transform .2s ease;
}

.header-menu .nav-link:hover{
    background:rgba(107,163,0,0.06);
    transform:translateY(-1px);
    color:var(--accent) !important;
}

.header-menu .nav-link a{
    text-decoration:none;
}

.header-menu .nav-link::after{
    content:'';
    position:absolute;
    left:12px;
    right:12px;
    bottom:7px;
    height:3px;
    background:var(--accent);
    transform:scaleX(0);
    transform-origin:left;
    transition:transform .25s ease;
    border-radius:999px;
}

.header-menu .nav-link:hover::after{
    transform:scaleX(1);
}

.header-menu .nav-item.active .nav-link{
    color:var(--accent) !important;
    background:rgba(107,163,0,0.05);
}

.header-menu .dropdown-menu{
    border:none;
    border-radius:16px;
    padding:8px;
    min-width:240px;
    box-shadow:0 22px 50px rgba(1,35,80,0.10);
}

.header-menu .dropdown-item{
    border-radius:12px;
    padding:10px 14px;
    font-size:1rem;
}

.header-menu .dropdown-item:hover{
    background:rgba(107,163,0,0.10);
}

.navbar-toggler{
    color:var(--text);
    font-size:1.3rem;
}

.navbar-toggler:focus{
    box-shadow:none;
}

/* Header / Navbar submenu support */
header,
.navbar,
.header-area,
.site-header,
.header-nav{
    position:relative;
    z-index:9999;
    overflow:visible !important;
}

.header-menu .menu-item-has-children,
.header-menu .nav-item.dropdown{
    position:relative;
}

@media (min-width: 992px){
    .header-menu .sub-menu,
    .header-menu .dropdown-menu{
        position:absolute;
        top:100%;
        left:0;
        min-width:240px;
        background:#fff;
        padding:12px 0;
        margin:0;
        list-style:none;
        border:none;
        border-radius:12px;
        box-shadow:0 10px 30px rgba(0,0,0,0.08);
        display:block;
        opacity:0;
        visibility:hidden;
        transform:translateY(10px);
        transition:.3s ease;
        z-index:9999;
    }

    .header-menu .menu-item-has-children:hover > .sub-menu,
    .header-menu .nav-item.dropdown:hover > .dropdown-menu,
    .header-menu .nav-item.dropdown > .dropdown-menu.show{
        opacity:1;
        visibility:visible;
        transform:translateY(0);
    }
}

/* Hero */
.hero{
    padding:0 0 0px;
    /* background:var(--text); */
}

.hero-grid{
    position:relative;
    display:grid;
    align-items:center;
    width:100%;
    min-height:0;
    aspect-ratio:16 / 9;
    overflow:hidden;
    isolation:isolate;
}

.hero-copy{
    position:relative;
    z-index:2;
    width:min(760px, calc(100% - 40px));
    margin-left:clamp(24px, 7vw, 120px);
    padding:0;
    border-radius:0;
    display:flex;
    flex-direction:column;
    justify-content:center;
    align-items:flex-start;
    text-align:left;
    color:#000;
    background:none;
    border:0;
    box-shadow:none;
    backdrop-filter:none;
    -webkit-backdrop-filter:none;
}

.hero-copy h1{
    font-family:'Cormorant Garamond', serif;
    font-size:clamp(3.4rem, 3.5vw, 7rem);
    line-height:.9;
    letter-spacing:-.03em;
    margin:0 0 26px;

    text-wrap:balance;
    text-shadow:0 12px 28px rgba(255,255,255,0.46);
}

.hero-copy p{
    max-width:500px;
    font-size:clamp(1rem, 1.6vw, 1.25rem);
    line-height:1.75;
    color:#111827;
    margin-bottom:0;
    text-shadow:0 10px 24px rgba(255,255,255,0.5);
}

.hero-visual{
    position:absolute;
    inset:0;
    z-index:1;
    border-radius:0;
    overflow:hidden;
    min-height:100%;
    box-shadow:none;
    background:linear-gradient(180deg, #ffffff 0%, #bde889 100%);
}

.hero-visual img{
    width:100%;
    height:100%;
    object-fit:contain;
    object-position:center;
}

.hero-visual .overlay{
    display:none;
}

.award-strip{
    margin-top:22px;
    padding:18px 16px;
    border-radius:24px;
}

.award-strip .strip-label{
    display:flex;
    align-items:center;
    gap:10px;
    font-size:.78rem;
    text-transform:uppercase;
    letter-spacing:.18em;
    color:var(--muted);
    margin-bottom:16px;
}

.award-strip .strip-label::after{
    content:'';
    flex:1;
    height:1px;
    background:var(--line);
}

.header-top .award-slider .award-item{
    min-height:56px;
    padding:0 18px;
    border-radius:0;
    background:transparent;
    box-shadow:none;
    border:none;
}

.award-slider .award-item{
    display:flex;
    align-items:center;
    justify-content:center;
    gap:10px;
    min-height:72px;
    padding:8px 10px;
    border-radius:18px;
    background:rgba(255,255,255,0.72);
    border:1px solid rgba(1,35,80,0.08);
    color:var(--text);
    font-weight:700;
    text-align:center;
}

.award-slider .award-item img{
    max-height:64px;
    max-width:100%;
    width:auto;
    opacity:.92;
}

.award-slider .award-item i{
    color:var(--accent);
    font-size:1.05rem;
}

.award-slider .award-item span{
    font-size:.92rem;
}

.header-top .award-card{
    border-right:1px solid #dcdcdc;
}

.header-top .award-card img{
    max-height:70px;
    width:auto;
    object-fit:contain;
}

/* Process Showcase */
.process-showcase-section{
    position:relative;
    padding:0;
    overflow:hidden;
    background:#f4fae9;
}

.process-showcase-section .container{
    position:absolute;
    inset:0;
    z-index:1;
}

.process-showcase-image{
    position:relative;
    width:100%;
    /* height:620px; */
    object-fit:cover;
    object-position:center center;
}

.process-showcase-copy{
    position:absolute;
    top:50%;
    left:12px;
    transform:translateY(-50%);
    width:min(50%, 500px);
}

.process-showcase-copy .section-lead{
    margin:0;
}

/* Innovation */
.innovation-section{
    padding-top:94px;
    padding-bottom:94px;
    background:
        radial-gradient(circle at 8% 18%, rgba(107,163,0,0.10), transparent 28%),
        linear-gradient(180deg, #fbf8f1 0%, #f0f5ea 100%);
}

.innovation-panel{
    display:grid;
    grid-template-columns:minmax(0, 1fr) minmax(340px, .82fr);
    gap:46px;
    align-items:center;
    padding:52px;
    border-radius:8px;
    color:#fff;
    background:
        radial-gradient(circle at top right, rgba(107,163,0,0.22), transparent 36%),
        linear-gradient(135deg, #012350 0%, #001633 100%);
    box-shadow:0 24px 70px rgba(1,35,80,0.18);
}

.innovation-media{
    grid-column:1 / -1;
    width:100%;
    overflow:hidden;
    border-radius:8px;
    background:#fff;
}

.innovation-media img{
    width:100%;
    height:auto;
    object-fit:contain;
}

.innovation-panel .eyebrow{
    color:#fff;
    border-color:rgba(255,255,255,0.18);
    background:rgba(255,255,255,0.08);
}

.innovation-panel .eyebrow::before{
    background:var(--accent);
    box-shadow:0 0 0 6px rgba(107,163,0,0.18);
}

.innovation-panel .section-lead{
    color:rgba(255,255,255,0.78);
}

.innovation-points{
    display:grid;
    gap:16px;
}

.innovation-point{
    display:grid;
    grid-template-columns:52px minmax(0, 1fr);
    gap:18px;
    align-items:start;
    padding:18px;
    border-radius:8px;
    background:rgba(255,255,255,0.08);
    border:1px solid rgba(255,255,255,0.10);
}

.innovation-point i{
    width:52px;
    height:52px;
    display:grid;
    place-items:center;
    border-radius:8px;
    color:#012350;
    background:var(--accent);
    font-size:1.15rem;
}

.innovation-point h3{
    margin:0 0 6px;
    font-size:1.08rem;
    letter-spacing:-.02em;
}

.innovation-point p{
    margin:0;
    color:rgba(255,255,255,0.72);
    line-height:1.65;
    font-size:.95rem;
}

/* Our Operation */
.operation-section{
    padding:94px 0 0;
    background:
        linear-gradient(180deg, #ffffff 0%, #edf3f4 100%);
}

.operation-head{
    max-width:820px;
    margin:0 auto 38px;
    padding:0 20px;
    text-align:center;
}

.operation-map{
    position:relative;
    width:100%;
    height:clamp(520px, 48vw, 760px);
    overflow:hidden;
    background:
        linear-gradient(180deg, #ffffff 0%, #eef4ea 100%);
    border-top:1px solid rgba(1,35,80,0.08);
    border-bottom:1px solid rgba(1,35,80,0.08);
}

.operation-map img{
    display:block;
    width:100%;
    height:100%;
    object-fit:cover;
    object-position:center 64%;
}

.operation-map::before{
    content:'';
    position:absolute;
    inset:0;
    background:
        linear-gradient(90deg, rgba(247,249,247,0.72) 0%, rgba(247,249,247,0) 18%, rgba(247,249,247,0) 82%, rgba(247,249,247,0.72) 100%);
    pointer-events:none;
}

.operation-map-caption{
    position:absolute;
    left:50%;
    bottom:28px;
    display:flex;
    flex-wrap:wrap;
    gap:12px;
    transform:translateX(-50%);
}

.operation-map-caption span{
    display:inline-flex;
    align-items:center;
    min-height:40px;
    padding:9px 16px;
    border-radius:999px;
    color:#fff;
    background:rgba(1,35,80,0.92);
    box-shadow:0 14px 34px rgba(1,35,80,0.18);
    font-size:.9rem;
    font-weight:700;
}

/* Green Solutions */
.green-solutions{
    padding-top:94px;
    min-height:760px;
    background:#f4fae9;
}

.green-solutions-content{
    width:50%;
    max-width:640px;
}

.green-solutions-head{
    max-width:none;
    margin:0 0 42px;
    text-align:left;
}

.green-solutions-head .section-lead{
    margin:0;
}

.green-solutions-grid{
    display:grid;
    grid-template-columns:1fr;
    gap:14px;
}

.green-solution-card{
    position:relative;
    padding:16px 18px;
    border-radius:8px;
    overflow:hidden;
    display:grid;
    grid-template-columns:58px minmax(0, 1fr);
    gap:10px;
    align-items:start;
    background:
        linear-gradient(145deg, rgba(255,255,255,0.88), rgba(247,244,236,0.74));
    border:1px solid rgba(1,35,80,0.08);
    box-shadow:0 18px 44px rgba(1,35,80,0.08);
}

.green-solution-card::after{
    content:'';
    position:absolute;
    right:-42px;
    bottom:-42px;
    width:130px;
    height:130px;
    border-radius:50%;
    background:rgba(107,163,0,0.12);
}

.green-solution-icon{
    position:relative;
    z-index:1;
    width:52px;
    height:52px;
    display:grid;
    place-items:center;
    margin-bottom:0;
    border-radius:8px;
    color:#fff;
    background:var(--text);
    font-size:1.3rem;
}

.green-solution-copy{
    position:relative;
    z-index:1;
    grid-column:2;
}

.green-solution-card h3{
    margin:0 0 7px;
    font-size:1.15rem;
    letter-spacing:-.02em;
}

.green-solution-card p{
    margin:0;
    color:var(--muted);
    line-height:1.42;
}

/* Awards */
.awards-section{
    padding-top:94px;
    padding-bottom:94px;
    background:
        radial-gradient(circle at 15% 0%, rgba(1,35,80,0.08), transparent 30%),
        linear-gradient(180deg, #fffaf0 0%, #f7efe2 100%);
}

.awards-head{
    max-width:820px;
    margin:0 auto 42px;
    text-align:center;
}

.awards-head .section-lead{
    margin:0 auto;
}

.awards-grid{
    display:grid;
    grid-template-columns:repeat(2, minmax(0, 1fr));
    gap:26px;
    align-items:stretch;
}

.award-showcase-card{
    position:relative;
    height:100%;
    padding:0;
    border-radius:8px;
    background:#fff;
    border:1px solid rgba(1,35,80,0.08);
    box-shadow:0 18px 44px rgba(1,35,80,0.07);
    overflow:hidden;
}

.award-showcase-card.featured{
    color:var(--text);
    background:#fff;
}

.award-showcase-card img{
    width:100%;
    height:360px;
    margin:0;
    object-fit:cover;
    object-position:center;
}

.award-showcase-copy{
    padding:26px 28px 30px;
    border-top:5px solid var(--accent);
}

.award-showcase-card h3{
    margin:0 0 10px;
    font-size:1.35rem;
    letter-spacing:-.02em;
}

.award-showcase-card p{
    margin:0;
    color:var(--muted);
    line-height:1.7;
}

/* Cards */
.section-soft{
    margin:0;
}

.section-shell{
    padding:34px;
    border-radius:var(--radius);
    background:rgba(255,255,255,0.82);
}

.feature-card,
.service-card,
.insight-card{
    height:100%;
    padding:30px;
    border-radius:28px;
    background:rgba(255,255,255,0.72);
    border:1px solid rgba(1,35,80,0.08);
    box-shadow:0 18px 42px rgba(1,35,80,0.06);
    transition:transform .25s ease, box-shadow .25s ease;
}

.feature-card:hover,
.service-card:hover,
.insight-card:hover{
    transform:translateY(-6px);
    box-shadow:0 24px 58px rgba(1,35,80,0.10);
}

.feature-icon,
.service-icon{
    width:58px;
    height:58px;
    border-radius:18px;
    display:grid;
    place-items:center;
    color:#fff;
    background:linear-gradient(135deg, var(--accent), #4f7a00);
    margin-bottom:20px;
    font-size:1.25rem;
}

.feature-card h4,
.service-card h4{
    font-size:1.35rem;
    margin:0 0 12px;
    letter-spacing:-.02em;
}

.feature-card p,
.service-card p,
.insight-card p,
.about-copy p{
    color:var(--muted);
    line-height:1.85;
    margin:0;
}

/* About */
.about-section{
    background:
        radial-gradient(circle at 85% 12%, rgba(1,35,80,0.08), transparent 30%),
        linear-gradient(180deg, #edf4f2 0%, #f7fbf8 100%);
}

.about-frame{
    position:relative;
    overflow:hidden;
    border-radius:32px;
    /* min-height:580px; */
    box-shadow:var(--shadow);
}

.about-frame img{
    width:100%;
    height:100%;
    object-fit:cover;
}

.about-frame .frame-badge{
    position:absolute;
    left:20px;
    top:20px;
    padding:12px 16px;
    border-radius:999px;
    color:var(--text);
    background:rgba(255,255,255,0.82);
    border:1px solid rgba(1,35,80,0.08);
    font-weight:700;
    font-size:.9rem;
}

.about-head{
    max-width:980px;
    margin:0 auto 46px;
    text-align:center;
}

.about-head .section-lead{
    margin:0 auto;
}

.about-copy{
    padding-right:20px;
}

.mini-grid{
    display:grid;
    grid-template-columns:repeat(2, minmax(0,1fr));
    gap:16px;
    margin-top:0;
}

.mini-card{
    padding:18px;
    border-radius:22px;
    background:rgba(255,255,255,0.72);
    border:1px solid rgba(1,35,80,0.08);
}

.mini-card strong{
    display:block;
    margin-bottom:6px;
    font-size:1rem;
}

.mini-card span{
    color:var(--muted);
    font-size:.95rem;
    line-height:1.6;
}

/* Metrics */
.metrics-grid{
    display:grid;
    grid-template-columns:repeat(4, minmax(0,1fr));
    gap:18px;
}

.metric-card{
    padding:28px 24px;
    border-radius:26px;
    background:rgba(255,255,255,0.72);
    border:1px solid rgba(1,35,80,0.08);
    text-align:center;
}

.metric-card strong{
    display:block;
    font-family:'Cormorant Garamond', serif;
    font-size:3rem;
    line-height:1;
    letter-spacing:-.04em;
}

.metric-card span{
    display:block;
    margin-top:10px;
    color:var(--muted);
}

/* Contact */
.contact-hero{
    position:relative;
    height:300px;
    padding:40px 0;
    display:flex;
    align-items:center;
    color:#fff;
    background:
        linear-gradient(90deg, rgba(1,35,80,0.86) 0%, rgba(1,35,80,0.64) 48%, rgba(1,35,80,0.28) 100%),
        url("../img/banner.jpg") center / cover no-repeat;
    overflow:hidden;
}

.contact-hero-copy{
    width:min(760px, 100%);
}

.contact-hero h1{
    max-width:820px;
    margin:0 0 12px;
    font-family:'Cormorant Garamond', serif;
    font-size:clamp(2.8rem, 5vw, 4.8rem);
    line-height:1;
    letter-spacing:-.03em;
}

.contact-hero p{
    max-width:620px;
    margin:0;
    color:rgba(255,255,255,0.82);
    font-size:1.05rem;
    line-height:1.65;
}

.contact-section{
    background:
        radial-gradient(circle at 8% 18%, rgba(107,163,0,0.10), transparent 28%),
        linear-gradient(180deg, #fbf8f1 0%, #f3f7ef 100%);
}

.contact-grid{
    display:grid;
    grid-template-columns:minmax(0, .86fr) minmax(420px, 1fr);
    gap:42px;
    align-items:start;
}

.contact-details{
    position:sticky;
    top:24px;
}

.contact-info-list{
    display:grid;
    gap:14px;
    margin-top:34px;
}

.contact-info-item{
    display:grid;
    grid-template-columns:54px minmax(0, 1fr);
    gap:16px;
    align-items:center;
    padding:18px;
    color:var(--text);
    text-decoration:none;
    border:1px solid rgba(1,35,80,0.08);
    border-radius:8px;
    background:rgba(255,255,255,0.74);
    box-shadow:0 16px 38px rgba(1,35,80,0.06);
}

.contact-info-item i{
    display:grid;
    place-items:center;
    width:54px;
    height:54px;
    color:#fff;
    background:var(--text);
    border-radius:8px;
    font-size:1.1rem;
}

.contact-info-item strong{
    display:block;
    margin-bottom:4px;
    color:var(--text);
    font-size:.92rem;
    text-transform:uppercase;
    letter-spacing:.08em;
}

.contact-info-item span{
    color:var(--muted);
    line-height:1.55;
}

.contact-info-item:hover{
    color:var(--text);
}

.contact-form{
    padding:36px;
    border-radius:8px;
    background:#fff;
    border:1px solid rgba(1,35,80,0.08);
    box-shadow:0 24px 70px rgba(1,35,80,0.12);
}

.contact-form-head{
    margin-bottom:24px;
}

.contact-form-head h2{
    margin:0 0 8px;
    font-size:1.7rem;
    letter-spacing:-.03em;
}

.contact-form-head p{
    margin:0;
    color:var(--muted);
}

.form-row{
    display:grid;
    gap:8px;
    margin-bottom:18px;
}

.form-row label{
    color:var(--text);
    font-size:.92rem;
    font-weight:800;
}

.form-row input,
.form-row textarea{
    width:100%;
    border:1px solid rgba(1,35,80,0.14);
    border-radius:8px;
    padding:14px 16px;
    color:var(--text);
    background:#fbfcfa;
    font:inherit;
    outline:none;
    transition:border-color .2s ease, box-shadow .2s ease, background .2s ease;
}

.form-row textarea{
    resize:vertical;
    min-height:138px;
}

.form-row input:focus,
.form-row textarea:focus{
    border-color:var(--accent);
    background:#fff;
    box-shadow:0 0 0 4px rgba(107,163,0,0.12);
}

.contact-submit{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    gap:12px;
    width:100%;
    min-height:54px;
    padding:14px 22px;
    border:0;
    border-radius:8px;
    color:#fff;
    background:var(--text);
    font-weight:800;
    transition:transform .2s ease, background .2s ease;
}

.contact-submit:hover{
    transform:translateY(-2px);
    background:#001633;
}

.contact-map-section{
    width:100%;
    height:clamp(420px, 46vw, 640px);
    background:#edf3f4;
    border-top:1px solid rgba(1,35,80,0.08);
}

.contact-map-section iframe{
    display:block;
    width:100%;
    height:100%;
    border:0;
    filter:saturate(.92) contrast(.96);
}

/* Media */
.contact-hero.media-hero{
    height:300px;
    padding:40px 0;
    display:flex;
    align-items:center;
    background:
        linear-gradient(90deg, rgba(1,35,80,0.86) 0%, rgba(1,35,80,0.58) 48%, rgba(1,35,80,0.20) 100%),
        url("../img/award.jpg") center / cover no-repeat;
}

.media-section{
    background:
        radial-gradient(circle at 8% 18%, rgba(107,163,0,0.10), transparent 28%),
        linear-gradient(180deg, #fbf8f1 0%, #f3f7ef 100%);
}

.media-head{
    max-width:820px;
    margin:0 auto 42px;
    text-align:center;
}

.media-head .section-lead{
    margin:0 auto;
}

.media-grid{
    display:grid;
    grid-template-columns:repeat(4, minmax(0, 1fr));
    gap:18px;
}

.media-item{
    min-width:0;
}

.media-card{
    display:flex;
    flex-direction:column;
    min-width:0;
    overflow:hidden;
    border-radius:12px;
    background:#fff;
    border:1px solid rgba(1,35,80,0.08);
    box-shadow:0 18px 44px rgba(1,35,80,0.08);
    text-decoration:none;
    transition:transform .28s ease, box-shadow .28s ease, border-color .28s ease;
}

.media-card-image{
    position:relative;
    height:250px;
    overflow:hidden;
    background:#edf3f4;
}

.media-card-title{
    margin:0;
    padding:16px 18px;
    background:#fff;
    border-top:1px solid rgba(1,35,80,0.06);
    font-size:.95rem;
    font-weight:700;
    color:var(--text);
    line-height:1.4;
    text-align:center;
    transition:color .25s ease, background .25s ease;
}

.media-card-wide{
    grid-column:span 2;
}

.media-card-image img{
    width:100%;
    height:100%;
    object-fit:cover;
    transition:transform .35s ease, filter .35s ease;
}

.media-card-image::after{
    content:'';
    position:absolute;
    inset:0;
    background:linear-gradient(180deg, rgba(1,35,80,0) 35%, rgba(1,35,80,0.36) 100%);
    opacity:0;
    transition:opacity .25s ease;
}

.media-card-zoom{
    position:absolute;
    right:16px;
    bottom:16px;
    z-index:1;
    display:grid;
    place-items:center;
    width:44px;
    height:44px;
    color:var(--text);
    background:#fff;
    border-radius:8px;
    box-shadow:0 14px 34px rgba(1,35,80,0.18);
    opacity:0;
    transform:translateY(10px);
    transition:opacity .25s ease, transform .25s ease;
}

.media-card:hover{
    transform:translateY(-6px);
    border-color:rgba(107,163,0,0.22);
    box-shadow:0 28px 64px rgba(1,35,80,0.14);
}

.media-card:hover .media-card-image img{
    transform:scale(1.05);
    filter:saturate(1.05);
}

.media-card:hover .media-card-image::after,
.media-card:hover .media-card-zoom{
    opacity:1;
}

.media-card:hover .media-card-zoom{
    transform:translateY(0);
}

.media-card:hover .media-card-title{
    color:var(--accent);
    background:#fff;
}

/* Team, Event, Download */
.contact-hero.team-hero{
    background-position:center;
    background-size:cover;
    background-repeat:no-repeat;
}

.contact-hero.event-hero{
    background:
        linear-gradient(90deg, rgba(1,35,80,0.86) 0%, rgba(1,35,80,0.58) 48%, rgba(1,35,80,0.20) 100%),
        url("../img/award-2.jpeg") center / cover no-repeat;
}

.contact-hero.download-hero{
    background:
        linear-gradient(90deg, rgba(1,35,80,0.86) 0%, rgba(1,35,80,0.58) 48%, rgba(1,35,80,0.20) 100%),
        url("../img/banner.jpg") center / cover no-repeat;
}

.team-section,
.event-section,
.download-section{
    background:
        radial-gradient(circle at 8% 18%, rgba(107,163,0,0.10), transparent 28%),
        linear-gradient(180deg, #fbf8f1 0%, #f3f7ef 100%);
}

.team-section{
    position:relative;
    padding:80px 0 96px;
    background:
        radial-gradient(circle at 12% 12%, rgba(107,163,0,0.12), transparent 28%),
        radial-gradient(circle at 88% 8%, rgba(1,35,80,0.08), transparent 30%),
        linear-gradient(180deg, #fbf8f1 0%, #eef5ec 100%);
    overflow:hidden;
}

.team-section::before{
    content:none;
}

.team-section .container{
    z-index:1;
}

.team-heading{
    max-width:860px;
    margin:0 auto 44px;
    padding:34px 38px;
    text-align:center;
    background:rgba(255,255,255,0.92);
    border:1px solid rgba(255,255,255,0.85);
    border-radius:8px;
    box-shadow:0 28px 70px rgba(1,35,80,0.12);
}

.team-kicker{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    margin-bottom:12px;
    color:var(--accent);
    font-size:.76rem;
    font-weight:800;
    text-transform:uppercase;
    letter-spacing:.16em;
}

.team-heading h1{
    position:relative;
    display:inline-block;
    margin:0 0 24px;
    color:var(--text);
    font-family:'Cormorant Garamond', serif;
    font-size:3.85rem;
    line-height:.95;
    font-weight:800;
    letter-spacing:0;
}

.team-heading h1::after{
    content:'';
    position:absolute;
    left:50%;
    bottom:-13px;
    width:78px;
    height:2px;
    background:var(--accent);
    transform:translateX(-50%);
}

.team-heading p{
    max-width:620px;
    margin:0 auto;
    color:var(--muted);
    font-size:1rem;
    line-height:1.8;
}

.team-grid{
    display:grid;
    grid-template-columns:repeat(3, minmax(0, 1fr));
    gap:26px;
    max-width:1040px;
    margin:0 auto;
}

.download-grid{
    display:grid;
    grid-template-columns:repeat(4, minmax(0, 1fr));
    gap:18px;
}

.team-card,
.download-card,
.event-card{
    border:1px solid rgba(1,35,80,0.08);
    background:#fff;
    box-shadow:0 18px 44px rgba(1,35,80,0.08);
    overflow:hidden;
}

.team-card{
    position:relative;
    padding:14px;
    border-radius:8px;
    background:rgba(255,255,255,0.95);
    box-shadow:0 24px 58px rgba(1,35,80,0.10);
    transition:transform .25s ease, box-shadow .25s ease;
}

.team-card::after{
    content:'';
    position:absolute;
    left:24px;
    right:24px;
    top:14px;
    height:4px;
    background:var(--accent);
    opacity:0;
    transition:opacity .25s ease;
}

.team-card:hover{
    transform:translateY(-8px);
    box-shadow:0 34px 74px rgba(1,35,80,0.16);
}

.team-card:hover::after{
    opacity:1;
}

.team-photo{
    height:315px;
    background:#edf3f4;
    overflow:hidden;
    border-radius:6px;
}

.team-photo img{
    width:100%;
    height:100%;
    object-fit:cover;
    transition:transform .35s ease, filter .35s ease;
}

.team-card:hover .team-photo img{
    transform:scale(1.04);
    filter:saturate(1.04) contrast(1.02);
}

.team-card-body,
.download-card{
    padding:24px;
}

.team-card-body{
    padding:22px 6px 4px;
    text-align:left;
}

.team-card h2,
.event-card h3,
.download-card h3{
    margin:0 0 10px;
    font-size:1.18rem;
    font-weight:800;
    letter-spacing:-.02em;
}

.team-card h2{
    color:var(--text);
    font-size:1.12rem;
    letter-spacing:0;
}

.team-card p,
.event-card p,
.download-card p{
    margin:0;
    color:var(--muted);
    line-height:1.7;
}

.team-card p{
    color:var(--muted);
    font-size:.86rem;
    line-height:1.55;
}

.team-social{
    display:flex;
    justify-content:center;
    gap:9px;
    margin-top:18px;
}

.team-social a{
    display:grid;
    place-items:center;
    width:30px;
    height:30px;
    color:var(--accent);
    border:1px solid rgba(107,163,0,0.26);
    border-radius:50%;
    background:#f8fbf4;
    font-size:.78rem;
    text-decoration:none;
    transition:color .2s ease, background .2s ease, transform .2s ease;
}

.team-social a:hover{
    color:#fff;
    background:var(--accent);
    transform:translateY(-2px);
}

.event-blog-grid{
    display:grid;
    gap:28px;
}

.event-feature-card,
.event-card{
    background:#fff;
    border:1px solid rgba(1,35,80,0.08);
    border-radius:8px;
    box-shadow:0 24px 60px rgba(1,35,80,0.10);
    overflow:hidden;
}

.event-feature-card{
    display:grid;
    grid-template-columns:minmax(0, 1.08fr) minmax(360px, .92fr);
    align-items:stretch;
}

.event-feature-image,
.event-card-image{
    display:block;
    overflow:hidden;
    background:#edf3f4;
}

.event-feature-image img,
.event-card-image img{
    width:100%;
    height:100%;
    object-fit:cover;
    transition:transform .35s ease, filter .35s ease;
}

.event-feature-image{
    min-height:430px;
}

.event-feature-content{
    display:flex;
    flex-direction:column;
    justify-content:center;
    padding:44px;
}

.event-meta{
    display:flex;
    align-items:center;
    gap:14px;
    margin-bottom:16px;
    color:var(--muted);
    font-size:.82rem;
    font-weight:700;
}

.event-meta span{
    display:inline-flex;
    align-items:center;
    padding:8px 12px;
    color:var(--accent);
    background:rgba(107,163,0,0.10);
    border-radius:999px;
    text-transform:uppercase;
    letter-spacing:.12em;
    font-size:.68rem;
}

.event-feature-card h3,
.event-card h3{
    margin:0 0 14px;
    color:var(--text);
    font-weight:800;
    letter-spacing:-.03em;
}

.event-feature-card h3{
    font-family:'Cormorant Garamond', serif;
    font-size:clamp(2.4rem, 3.2vw, 3.7rem);
    line-height:.98;
}

.event-feature-card h3 a,
.event-card h3 a{
    color:inherit;
    text-decoration:none;
}

.event-feature-card p,
.event-card p{
    margin:0;
    color:var(--muted);
    line-height:1.8;
}

.event-read-more{
    display:inline-flex;
    align-items:center;
    gap:10px;
    width:max-content;
    margin-top:24px;
    color:var(--text);
    font-weight:800;
    text-decoration:none;
}

.event-read-more i{
    color:var(--accent);
    transition:transform .2s ease;
}

.event-read-more:hover{
    color:var(--accent);
}

.event-read-more:hover i{
    transform:translateX(4px);
}

.event-card-grid{
    display:grid;
    grid-template-columns:repeat(3, minmax(0, 1fr));
    gap:24px;
}

.event-card{
    display:flex;
    flex-direction:column;
    transition:transform .25s ease, box-shadow .25s ease;
}

.event-card-image{
    height:240px;
}

.event-card-content{
    display:flex;
    flex:1;
    flex-direction:column;
    padding:26px;
}

.event-card h3{
    font-size:1.3rem;
    line-height:1.2;
}

.event-card .event-read-more{
    margin-top:auto;
    padding-top:22px;
}

.event-feature-card:hover img,
.event-card:hover img{
    transform:scale(1.04);
    filter:saturate(1.04);
}

.event-card:hover{
    transform:translateY(-6px);
    box-shadow:0 32px 72px rgba(1,35,80,0.14);
}

.download-grid{
    grid-template-columns:repeat(3, minmax(0, 1fr));
}

.download-card{
    display:flex;
    flex-direction:column;
    min-height:300px;
}

.download-card > i{
    display:grid;
    place-items:center;
    width:62px;
    height:62px;
    margin-bottom:22px;
    color:#fff;
    background:var(--text);
    border-radius:8px;
    font-size:1.45rem;
}

.download-card a{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    gap:10px;
    min-height:48px;
    margin-top:auto;
    padding:12px 18px;
    color:#fff;
    background:var(--accent);
    border-radius:8px;
    font-weight:800;
    text-decoration:none;
}

.download-card a:hover{
    color:#fff;
    background:#5a8d00;
}

/* About */
.contact-hero.about-hero{
    height:300px;
    padding:40px 0;
    display:flex;
    align-items:center;
    background:
        linear-gradient(90deg, rgba(1,35,80,0.86) 0%, rgba(1,35,80,0.58) 48%, rgba(1,35,80,0.20) 100%),
        url("../img/section 1.png") center / cover no-repeat;
}

.about-story-section{
    background:
        radial-gradient(circle at 8% 18%, rgba(107,163,0,0.10), transparent 28%),
        linear-gradient(180deg, #fbf8f1 0%, #f3f7ef 100%);
}

.about-story-alt{
    background:
        radial-gradient(circle at 86% 18%, rgba(1,35,80,0.08), transparent 30%),
        linear-gradient(180deg, #ffffff 0%, #edf3f4 100%);
}

.about-split{
    display:grid;
    grid-template-columns:minmax(0, .92fr) minmax(420px, 1fr);
    gap:48px;
    align-items:center;
}

.about-split-reverse{
    grid-template-columns:minmax(420px, 1fr) minmax(0, .92fr);
}

.about-split-image{
    overflow:hidden;
    border-radius:8px;
    background:#fff;
    border:1px solid rgba(1,35,80,0.08);
    box-shadow:0 24px 70px rgba(1,35,80,0.12);
}

.about-split-image img{
    width:100%;
    height:520px;
    object-fit:cover;
    transition:transform .35s ease;
}

.about-split-image:hover img{
    transform:scale(1.03);
}

.about-value-list{
    display:grid;
    grid-template-columns:repeat(2, minmax(0, 1fr));
    gap:14px;
    margin-top:34px;
}

.about-value-list div{
    padding:18px;
    border-radius:8px;
    background:rgba(255,255,255,0.78);
    border:1px solid rgba(1,35,80,0.08);
    box-shadow:0 16px 38px rgba(1,35,80,0.06);
}

.about-value-list strong{
    display:block;
    margin-bottom:6px;
    color:var(--text);
    font-size:1rem;
}

.about-value-list span{
    display:block;
    color:var(--muted);
    line-height:1.6;
}

.about-gallery-section{
    background:
        radial-gradient(circle at 12% 0%, rgba(107,163,0,0.10), transparent 32%),
        linear-gradient(180deg, #fbf8f1 0%, #f4efe5 100%);
}

.about-gallery-grid{
    display:grid;
    grid-template-columns:repeat(4, minmax(0, 1fr));
    grid-auto-rows:260px;
    gap:18px;
}

.about-gallery-item{
    display:block;
    overflow:hidden;
    border-radius:8px;
    background:#fff;
    border:1px solid rgba(1,35,80,0.08);
    box-shadow:0 18px 44px rgba(1,35,80,0.08);
    text-decoration:none;
}

.about-gallery-item img{
    width:100%;
    height:100%;
    object-fit:cover;
    transition:transform .35s ease;
}

.about-gallery-item:hover img{
    transform:scale(1.04);
}

.about-gallery-item:focus-visible{
    outline:3px solid rgba(107,163,0,0.35);
    outline-offset:4px;
}

/* Let's Talk */
.lets-talk-section{
    position:relative;
    min-height:560px;
    overflow:hidden;
    background-color:#006f72;
}

.lets-talk-image{
    position:absolute;
    inset:0;
    width:100%;
    height:100%;
    object-fit:cover;
    object-position:center center;
}

.lets-talk-section::before{
    content:'';
    position:absolute;
    inset:auto auto -190px -160px;
    width:520px;
    height:520px;
    border-radius:50%;
    border:74px solid rgba(255,255,255,0.055);
    pointer-events:none;
}

.lets-talk-section::after{
    content:'';
    position:absolute;
    left:12%;
    right:12%;
    bottom:74px;
    height:1px;
    background:linear-gradient(90deg, rgba(255,255,255,0.22), rgba(244,216,0,0.9), rgba(255,255,255,0));
    pointer-events:none;
}

.lets-talk-overlay{
    position:relative;
    min-height:560px;
    display:flex;
    align-items:center;
    padding:58px 0 76px;
    background:
        radial-gradient(circle at 16% 32%, rgba(107,163,0,0.12), transparent 30%),
        linear-gradient(90deg, rgba(1,35,80,0.66) 0%, rgba(0,118,116,0.50) 48%, rgba(0,118,116,0.16) 100%),
        linear-gradient(90deg, rgba(0,150,148,0.05), rgba(1,35,80,0.06));
}

.lets-talk-content{
    position:relative;
    z-index:1;
    display:flex;
    flex-direction:column;
    align-items:center;
    justify-content:center;
    gap:34px;
    width:100%;
    text-align:center;
}

.lets-talk-content h2{
    margin:0;
    color:#fff;
    font-family:'Inter', sans-serif;
    max-width:1120px;
    font-size:clamp(2.75rem, 5vw, 5.6rem);
    line-height:1.05;
    font-weight:500;
    letter-spacing:0;
    text-wrap:balance;
    text-shadow:0 18px 48px rgba(0,0,0,0.18);
}

.lets-talk-content h2 span{
    color:#f4d800;
}

.lets-talk-btn{
    display:inline-grid;
    grid-template-columns:auto 54px;
    align-items:center;
    width:max-content;
    min-height:54px;
    border:1px solid rgba(255,255,255,0.72);
    color:#fff;
    text-decoration:none;
    font-weight:800;
    font-size:.88rem;
    background:rgba(255,255,255,0.08);
    box-shadow:0 18px 44px rgba(0,0,0,0.12);
    backdrop-filter:blur(8px);
    -webkit-backdrop-filter:blur(8px);
    transition:transform .2s ease, border-color .2s ease, background .2s ease;
}

.lets-talk-btn span{
    padding:0 22px;
}

.lets-talk-btn i{
    display:grid;
    place-items:center;
    height:54px;
    color:#009694;
    background:#fff;
}

.lets-talk-btn:hover{
    color:#fff;
    border-color:#fff;
    background:rgba(255,255,255,0.14);
    transform:translateY(-2px);
}

/* Footer */
.site-footer{
    position:relative;
    min-height:auto;
    padding:44px 0 42px;
    color:#fff;
    background:
        radial-gradient(circle at 12% 0%, rgba(107,163,0,0.34), transparent 34%),
        linear-gradient(135deg, var(--text) 0%, #001633 100%);
    overflow:hidden;
}

.footer-head{
    display:flex;
    align-items:flex-start;
    justify-content:space-between;
    gap:30px;
    max-width:1620px;
    margin:0 auto 34px;
}

.footer-logo{
    display:inline-flex;
    align-items:center;
    width:min(300px, 50vw);
    text-decoration:none;
}

.footer-logo img{
    width:100%;
    height:auto;
    filter:brightness(0) invert(1);
}

.footer-social{
    display:flex;
    align-items:center;
    gap:22px;
    padding-top:6px;
}

.footer-social a{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    width:30px;
    height:30px;
    color:#fff;
    text-decoration:none;
    font-size:1.45rem;
    transition:opacity .2s ease, transform .2s ease;
}

.footer-social a:hover{
    color:#fff;
    opacity:.78;
    transform:translateY(-2px);
}

.footer-links-grid{
    display:grid;
    grid-template-columns:1.1fr 1.1fr 1.1fr 1.25fr 1.1fr 1.1fr;
    gap:34px;
    max-width:1620px;
    margin:0 auto;
}

.footer-link-group h4{
    margin:0 0 14px;
    font-family:'Inter', sans-serif;
    font-size:1rem;
    font-weight:800;
    line-height:1.3;
}

.footer-link-group ul{
    padding:0;
    margin:0;
    list-style:none;
}

.footer-link-group li{
    margin-bottom:8px;
}

.footer-link-group a{
    color:#fff;
    font-size:.98rem;
    line-height:1.35;
    font-weight:500;
    text-decoration:none;
    transition:opacity .2s ease;
}

.footer-link-group a:hover{
    color:#fff;
    opacity:.75;
}

/* Responsive */
@media (max-width: 1199px){
    .hero{
        padding:0 0 56px;
    }

    .hero-grid{
        min-height:0;
    }

    .hero-copy{
        margin-left:clamp(24px, 6vw, 72px);
    }

    .site-footer{
        min-height:auto;
    }

    .footer-links-grid{
        grid-template-columns:repeat(3, minmax(0, 1fr));
        gap:28px 36px;
        padding-right:92px;
    }

    .lets-talk-content{
        gap:32px;
    }

    .header-menu{
        gap:8px 12px;
    }

    .header-menu .nav-link{
        padding-left:8px !important;
        padding-right:8px !important;
        font-size:1.08rem;
    }
}

@media (max-width: 991px){
    .section{
        padding:84px 0;
    }

    .process-showcase-copy{
        width:min(64%, 620px);
    }

    .innovation-section{
        padding-top:84px;
        padding-bottom:0;
    }

    .innovation-panel{
        grid-template-columns:1fr;
        padding:40px;
    }

    .green-solutions-grid{
        grid-template-columns:1fr;
    }

    .awards-grid{
        grid-template-columns:1fr;
    }

    .green-solution-card{
        min-height:auto;
    }

    .header-top-grid{
        grid-template-columns:1fr;
        justify-items:start;
    }

    .award-marquee{
        width:100%;
    }

    .header-actions{
        flex-wrap:wrap;
        gap:16px;
    }

    .header-actions a{
        font-size:.95rem;
    }

    .header-nav .navbar{
        min-height:auto;
        padding:10px 0;
    }

    .header-menu{
        gap:0;
        padding-top:10px;
        width:100%;
    }

    .header-menu .nav-link{
        padding:12px 0 !important;
        font-size:1.15rem;
    }

    .header-menu .nav-link::after{
        left:0;
        right:auto;
        width:72px;
    }

    .header-menu .menu-item,
    .header-menu .nav-item{
        width:100%;
        display:block;
    }

    .header-menu .menu-item-has-children,
    .header-menu .nav-item.dropdown{
        width:100%;
    }

    .header-menu .sub-menu,
    .header-menu .dropdown-menu{
        position:static;
        width:100%;
        min-width:100%;
        opacity:1;
        visibility:visible;
        transform:none;
        display:none;
        padding:10px 15px;
        margin-top:10px;
        border-radius:10px;
        box-shadow:none;
        background:#f7f7f7;
    }

    .header-menu .menu-item-has-children:hover > .sub-menu,
    .header-menu .nav-item.dropdown:hover > .dropdown-menu,
    .header-menu .nav-item.dropdown > .dropdown-menu.show{
        display:block;
    }

    .header-menu .sub-menu li a,
    .header-menu .dropdown-menu li a{
        padding:10px 0;
        display:block;
        width:100%;
    }

    .metrics-grid,
    .mini-grid{
        grid-template-columns:1fr 1fr;
    }

    .footer-head{
        margin-bottom:28px;
    }

    .footer-links-grid{
        grid-template-columns:repeat(2, minmax(0, 1fr));
        gap:24px 32px;
        padding-right:0;
    }

    .lets-talk-section,
    .lets-talk-overlay{
        min-height:460px;
    }

    .lets-talk-content{
        gap:30px;
    }

    .contact-grid{
        grid-template-columns:1fr;
    }

    .contact-details{
        position:relative;
        top:auto;
    }

    .media-grid{
        grid-template-columns:repeat(2, minmax(0, 1fr));
    }

    .team-grid{
        grid-template-columns:repeat(2, minmax(0, 1fr));
    }

    .download-grid{
        grid-template-columns:1fr;
    }

    .event-card{
        grid-template-columns:240px minmax(0, 1fr);
    }

    .event-feature-card{
        grid-template-columns:1fr;
    }

    .event-feature-image{
        min-height:360px;
    }

    .event-feature-content{
        padding:34px;
    }

    .event-card-grid{
        grid-template-columns:repeat(2, minmax(0, 1fr));
    }

    .about-split,
    .about-split-reverse{
        grid-template-columns:1fr;
    }

    .about-split-image img{
        height:440px;
    }

    .about-gallery-grid{
        grid-template-columns:repeat(2, minmax(0, 1fr));
    }

    .lets-talk-section::after{
        left:24px;
        right:24px;
        bottom:54px;
    }

}

@media (max-width: 767px){
    .section{
        padding:70px 0;
    }

    .process-showcase-section{
        padding:0;
    }

    .process-showcase-image{
        height:560px;
        object-position:center bottom;
    }

    .process-showcase-copy{
        top:70px;
        transform:none;
        width:100%;
    }

    .innovation-section{
        padding-top:70px;
        padding-bottom:0;
    }

    .innovation-panel{
        padding:28px 22px;
        gap:30px;
    }

    .innovation-point{
        grid-template-columns:1fr;
    }

    .operation-section{
        padding-top:70px;
    }

    .operation-head{
        margin-bottom:28px;
        text-align:left;
    }

    .operation-map{
        height:auto;
        min-height:0;
    }

    .operation-map img{
        height:auto;
        min-height:0;
        object-fit:contain;
    }

    .operation-map-caption{
        bottom:20px;
        justify-content:center;
        width:calc(100% - 32px);
    }

    .green-solutions{
        padding-top:70px;
        min-height:auto;
        background-position:center top;
    }

    .green-solutions-content{
        width:100%;
        max-width:none;
    }

    .green-solutions-head{
        margin-bottom:30px;
        text-align:left;
    }

    .green-solution-card{
        padding:24px;
        grid-template-columns:52px minmax(0, 1fr);
        gap:18px;
    }

    .awards-head{
        margin-bottom:30px;
        text-align:left;
    }

    .award-showcase-card{
        padding:0;
    }

    .award-showcase-card img{
        height:260px;
    }

    .award-showcase-copy{
        padding:22px;
    }

    .hero{
        padding:0 0 44px;
    }

    .hero-grid{
        min-height:0;
    }

    .section-shell{
        padding:24px;
    }

    .hero-copy{
        width:min(100%, calc(100% - 28px));
        margin-left:14px;
        padding:0 12px;
    }

    .award-card{
        justify-content:flex-start;
        border-right:none;
    }

    .header-awards{
        grid-template-columns:1fr;
    }

    .header-awards .award-card{
        justify-content:flex-start;
    }

    .award-text strong,
    .award-text span{
        white-space:normal;
    }

    .header-actions{
        gap:14px;
        font-size:.98rem;
    }

    .metrics-grid,
    .mini-grid{
        grid-template-columns:1fr;
    }

    .hero-copy h1{
        font-size:clamp(3rem, 13vw, 4.6rem);
    }

    .hero-copy p{
        font-size:1rem;
        line-height:1.7;
    }

    .contact-hero{
        height:300px;
        padding:36px 0;
    }

    .contact-hero h1{
        font-size:clamp(2.5rem, 12vw, 3.8rem);
    }

    .contact-grid{
        gap:28px;
    }

    .contact-form{
        padding:24px 20px;
    }

    .contact-info-item{
        grid-template-columns:48px minmax(0, 1fr);
        padding:16px;
    }

    .contact-info-item i{
        width:48px;
        height:48px;
    }

    .contact-map-section{
        height:420px;
    }

    .media-head{
        margin-bottom:30px;
        text-align:left;
    }

    .media-head .section-lead{
        margin:0;
    }

    .media-grid{
        grid-template-columns:1fr;
        gap:14px;
    }

    .media-card-image{
        height:220px;
    }

    .media-card-title{
        padding:14px 16px;
        font-size:.9rem;
    }

    .media-card-wide{
        grid-column:auto;
    }

    .media-card-zoom{
        opacity:1;
        transform:none;
    }

    .team-grid,
    .download-grid{
        grid-template-columns:1fr;
        gap:14px;
    }

    .team-photo{
        height:240px;
    }

    .event-card{
        grid-template-columns:1fr;
    }

    .event-card-grid{
        grid-template-columns:1fr;
        gap:16px;
    }

    .event-feature-image{
        min-height:260px;
    }

    .event-feature-content,
    .event-card-content{
        padding:22px;
    }

    .event-meta{
        align-items:flex-start;
        flex-direction:column;
        gap:8px;
    }

    .event-card img{
        height:240px;
    }

    .event-card div{
        padding:22px;
    }

    .download-card{
        min-height:0;
    }

    .about-split{
        gap:28px;
    }

    .about-split-image img{
        height:320px;
    }

    .about-value-list{
        grid-template-columns:1fr;
        margin-top:26px;
    }

    .about-gallery-grid{
        grid-template-columns:1fr;
        grid-auto-rows:240px;
        gap:14px;
    }

    .lets-talk-section{
        background-color:#006f72;
    }

    .lets-talk-image{
        object-position:center center;
    }

    .lets-talk-overlay{
        background:
            radial-gradient(circle at 16% 32%, rgba(107,163,0,0.12), transparent 30%),
            linear-gradient(90deg, rgba(1,35,80,0.72) 0%, rgba(0,132,129,0.50) 100%);
    }

    .lets-talk-section,
    .lets-talk-overlay{
        min-height:420px;
    }

    .lets-talk-content h2{
        font-size:clamp(2.2rem, 11vw, 3.6rem);
        line-height:1.08;
    }

    .lets-talk-section::before{
        width:340px;
        height:340px;
        border-width:48px;
    }

    .site-footer{
        padding:36px 0 40px;
    }

    .footer-head{
        flex-direction:column;
        gap:20px;
        margin-bottom:30px;
    }

    .footer-social{
        gap:24px;
        padding-top:0;
    }

    .footer-links-grid{
        grid-template-columns:1fr;
        gap:20px;
    }

    .footer-link-group h4{
        margin-bottom:14px;
    }

    .footer-link-group li{
        margin-bottom:9px;
    }

    .footer-link-group a{
        font-size:1.02rem;
    }

}
.fancybox__container{
    z-index: 999999 !important;
}

.fancybox__content{
    padding: 0 !important;
}

.fancybox__content img{
    width: auto !important;
    max-width: 90vw !important;
    max-height: 90vh !important;
    height: auto !important;
    object-fit: contain;
}

.fancybox__toolbar{
    opacity: 1 !important;
    visibility: visible !important;
}

.fancybox__button{
    display: flex !important;
}
.bio-cng .about-gallery-grid {
    display: grid;
    grid-template-columns: 1fr;
    grid-auto-rows: auto !important;
    gap: 18px;
}
.bio-cng  .about-gallery-item img {
    width: 100%;
    height: 260px;
    object-fit: cover;
    transition: transform .35s ease;
}

.bio-cng  .gallery-content{
	padding:15px;
}

.team-grid{
    display:flex;
    flex-direction:column;
    gap:30px;
}

.team-card{
    display:flex;
    align-items:center;
    gap:40px;
    background:#fff;
    border-radius:20px;
    padding:30px;
    box-shadow:0 10px 30px rgba(0,0,0,.08);
    overflow:hidden;
    transition:.3s ease;
}

.team-card:hover{
    transform:translateY(-5px);
}

.team-photo{
    flex:0 0 300px;
}

.team-photo img{
    width:100%;
    height:320px;
    object-fit:cover;
    border-radius:15px;
    display:block;
}

.team-card-body{
    flex:1;
}

.team-card-body h2{
    font-size:32px;
    font-weight:700;
    margin-bottom:10px;
    color:#111;
}

.team-card-body p{
    font-size:18px;
    color:#666;
    margin-bottom:25px;
}

.team-social{
    display:flex;
    gap:12px;
}

.team-social a{
    width:45px;
    height:45px;
    display:flex;
    align-items:center;
    justify-content:center;
    border-radius:50%;
    background:#f5f5f5;
    color:#111;
    text-decoration:none;
    transition:.3s;
}

.team-social a:hover{
    background:#0d6efd;
    color:#fff;
}

@media (max-width:991px){

    .team-card{
        flex-direction:column;
        text-align:center;
        gap:25px;
    }

    .team-photo{
        flex:0 0 auto;
        width:100%;
        max-width:350px;
        margin:auto;
    }

    .team-social{
        justify-content:center;
    }
}
.header-menu .sub-menu-dropdown .nav-link {
    position: relative;
    padding: 12px !important;
    font-family: 'Inter', sans-serif;
    font-size: 1.00rem;
    line-height: 1;
    font-weight: 500;
    color: #1b1b1b !important;
    letter-spacing: -.02em;
    border-radius: 14px 14px 0 0;
    transition: color .2s ease, background-color .2s ease, transform .2s ease;
}

/* About Us redesign */
.about-us-hero{
    position:relative;
    overflow:hidden;
    padding:86px 0 78px;
    background:
        linear-gradient(90deg, rgba(1,35,80,0.94) 0%, rgba(1,35,80,0.78) 52%, rgba(0,111,114,0.50) 100%),
        url("../img/banner.jpg") center / cover no-repeat;
    color:#fff;
}

.about-us-hero::after{
    content:'';
    position:absolute;
    inset:auto -10% -42% 42%;
    height:360px;
    border:70px solid rgba(107,163,0,0.18);
    border-radius:50%;
    pointer-events:none;
}

.about-us-hero-grid{
    display:grid;
    grid-template-columns:minmax(0, .95fr) minmax(380px, .82fr);
    gap:56px;
    align-items:center;
}

.about-us-hero-copy{
    position:relative;
    z-index:1;
}

.about-us-hero-copy .eyebrow{
    color:#d9ff8a;
    background:rgba(255,255,255,0.12);
    border-color:rgba(255,255,255,0.22);
}

.about-us-hero-copy .eyebrow::before{
    background:#d9ff8a;
    box-shadow:0 0 0 6px rgba(217,255,138,0.16);
}

.about-us-hero h1{
    max-width:760px;
    margin:20px 0 18px;
    font-family:'Cormorant Garamond', serif;
    font-size:clamp(3rem, 5.5vw, 5.8rem);
    line-height:.94;
    letter-spacing:-.03em;
}

.about-us-hero p{
    max-width:650px;
    margin:0;
    color:rgba(255,255,255,0.84);
    font-size:1.12rem;
    line-height:1.85;
}

.about-us-hero-actions{
    display:flex;
    flex-wrap:wrap;
    gap:14px;
    margin-top:32px;
}

.about-us-hero-media{
    position:relative;
    z-index:1;
    overflow:hidden;
    min-height:420px;
    border:1px solid rgba(255,255,255,0.24);
    border-radius:8px;
    background:rgba(255,255,255,0.12);
    box-shadow:0 28px 70px rgba(0,0,0,0.26);
}

.about-us-hero-media img{
    width:100%;
    height:100%;
    min-height:420px;
    object-fit:cover;
}

.about-us-hero-badge{
    position:absolute;
    left:18px;
    right:18px;
    bottom:18px;
    padding:16px 18px;
    border-radius:8px;
    background:rgba(255,255,255,0.92);
    color:var(--text);
    box-shadow:0 18px 36px rgba(0,0,0,0.20);
}

.about-us-hero-badge strong,
.about-us-hero-badge span{
    display:block;
}

.about-us-hero-badge strong{
    font-size:1.05rem;
    margin-bottom:4px;
}

.about-us-hero-badge span{
    color:var(--muted);
    line-height:1.45;
}

.about-us-intro{
    background:
        radial-gradient(circle at 12% 8%, rgba(107,163,0,0.12), transparent 30%),
        linear-gradient(180deg, #fbf8f1 0%, #f5f8ef 100%);
}

.about-us-intro-grid{
    display:grid;
    grid-template-columns:minmax(0, 1fr) minmax(300px, 380px);
    gap:46px;
    align-items:start;
}

.about-us-copy p{
    color:var(--muted);
    font-size:1.02rem;
    line-height:1.9;
    margin:0 0 18px;
}

.about-us-copy p:last-child{
    margin-bottom:0;
}

.about-us-stats{
    display:grid;
    gap:14px;
}

.about-us-stats div{
    padding:24px;
    border:1px solid rgba(1,35,80,0.09);
    border-radius:8px;
    background:#fff;
    box-shadow:0 16px 42px rgba(1,35,80,0.08);
}

.about-us-stats strong{
    display:block;
    color:var(--accent);
    font-family:'Cormorant Garamond', serif;
    font-size:3rem;
    line-height:1;
    margin-bottom:8px;
}

.about-us-stats span{
    display:block;
    color:var(--muted);
    line-height:1.55;
}

.about-us-platform{
    background:
        radial-gradient(circle at 88% 14%, rgba(1,35,80,0.08), transparent 32%),
        linear-gradient(180deg, #ffffff 0%, #eef5f4 100%);
}

.about-us-platform-grid{
    display:grid;
    grid-template-columns:minmax(360px, .86fr) minmax(0, 1fr);
    gap:50px;
    align-items:center;
}

.about-us-platform-image{
    overflow:hidden;
    border:1px solid rgba(1,35,80,0.08);
    border-radius:8px;
    background:#fff;
    box-shadow:0 24px 70px rgba(1,35,80,0.12);
}

.about-us-platform-image img{
    width:100%;
    height:620px;
    object-fit:cover;
}

.about-us-value-grid{
    display:grid;
    grid-template-columns:repeat(2, minmax(0, 1fr));
    gap:14px;
    margin-top:30px;
}

.about-us-value-grid div{
    padding:20px;
    border:1px solid rgba(1,35,80,0.08);
    border-radius:8px;
    background:rgba(255,255,255,0.82);
}

.about-us-value-grid i{
    width:38px;
    height:38px;
    display:inline-flex;
    align-items:center;
    justify-content:center;
    margin-bottom:14px;
    border-radius:50%;
    background:rgba(107,163,0,0.12);
    color:var(--accent);
}

.about-us-value-grid strong,
.about-us-value-grid span{
    display:block;
}

.about-us-value-grid strong{
    margin-bottom:6px;
    color:var(--text);
}

.about-us-value-grid span{
    color:var(--muted);
    line-height:1.6;
    font-size:.95rem;
}

.about-us-awards{
    position:relative;
    overflow:hidden;
    background:
        radial-gradient(circle at 10% 0%, rgba(107,163,0,0.14), transparent 30%),
        radial-gradient(circle at 92% 18%, rgba(1,35,80,0.08), transparent 28%),
        linear-gradient(180deg, #fbf8f1 0%, #f4efe5 100%);
}

.about-us-awards::before{
    content:'';
    position:absolute;
    left:-160px;
    top:-180px;
    width:420px;
    height:420px;
    border:70px solid rgba(107,163,0,0.08);
    border-radius:50%;
    pointer-events:none;
}

.about-us-awards .container{
    z-index:1;
}

.about-us-awards .media-head{
    max-width:820px;
    margin:0 auto 44px;
    text-align:center;
}

.about-us-awards .section-lead{
    max-width:650px;
    margin:0 auto;
}

.about-us-achievement-list{
    display:grid;
    grid-template-columns:repeat(3, minmax(0, 1fr));
    gap:22px;
    padding:0;
    margin:0;
    list-style:none;
    counter-reset:achievement;
}

.about-us-achievement-list li{
    position:relative;
    min-height:100%;
    padding:30px 28px 28px;
    overflow:hidden;
    border:1px solid rgba(1,35,80,0.08);
    border-radius:18px;
    background:rgba(255,255,255,0.88);
    box-shadow:0 22px 62px rgba(1,35,80,0.10);
    counter-increment:achievement;
    transition:transform .25s ease, box-shadow .25s ease, border-color .25s ease;
}

.about-us-achievement-list li::after{
    content:'0' counter(achievement);
    position:absolute;
    right:20px;
    top:18px;
    color:rgba(1,35,80,0.07);
    font-family:'Cormorant Garamond', serif;
    font-size:4rem;
    font-weight:700;
    line-height:1;
}

.about-us-achievement-list li:hover{
    transform:translateY(-6px);
    border-color:rgba(107,163,0,0.22);
    box-shadow:0 30px 78px rgba(1,35,80,0.16);
}

.about-us-achievement-icon{
    position:relative;
    z-index:1;
    display:grid;
    place-items:center;
    width:58px;
    height:58px;
    margin-bottom:24px;
    border-radius:16px;
    color:#fff;
    background:linear-gradient(135deg, var(--accent) 0%, #008c72 100%);
    box-shadow:0 16px 34px rgba(107,163,0,0.24);
    font-size:1.35rem;
}

.about-us-achievement-list div{
    position:relative;
    z-index:1;
}

.about-us-achievement-list strong{
    display:block;
    margin:0 0 12px;
    color:var(--text);
    font-size:1.18rem;
    line-height:1.3;
    font-weight:800;
}

.about-us-achievement-list p{
    margin:0;
    color:var(--muted);
    font-size:1rem;
    line-height:1.75;
}

.about-us-achievement-list a{
    color:var(--text);
    font-weight:700;
    text-decoration-thickness:1px;
    text-underline-offset:4px;
}

.about-us-achievement-list a:hover{
    color:var(--accent);
}

.about-us-award-grid{
    display:grid;
    grid-template-columns:repeat(3, minmax(0, 1fr));
    gap:18px;
}

.about-us-award-card{
    min-height:100%;
    overflow:hidden;
    border:1px solid rgba(1,35,80,0.08);
    border-radius:8px;
    background:#fff;
    box-shadow:0 18px 46px rgba(1,35,80,0.09);
}

.about-us-award-card img{
    width:100%;
    height:150px;
    padding:22px;
    object-fit:contain;
    background:#fff;
    border-bottom:1px solid rgba(1,35,80,0.08);
}

.about-us-award-card div{
    padding:22px;
}

.about-us-award-card h3{
    margin:0 0 10px;
    color:var(--text);
    font-size:1.12rem;
    font-weight:800;
}

.about-us-award-card p{
    margin:0;
    color:var(--muted);
    line-height:1.7;
}

.about-us-patent-note{
    display:flex;
    gap:18px;
    align-items:flex-start;
    margin-top:24px;
    padding:24px;
    border:1px solid rgba(107,163,0,0.22);
    border-radius:8px;
    background:#fff;
    box-shadow:0 18px 46px rgba(1,35,80,0.08);
}

.about-us-patent-note i{
    flex:0 0 auto;
    width:44px;
    height:44px;
    display:inline-flex;
    align-items:center;
    justify-content:center;
    border-radius:50%;
    background:rgba(107,163,0,0.13);
    color:var(--accent);
}

.about-us-patent-note p{
    margin:0;
    color:var(--muted);
    line-height:1.75;
}

.about-us-mission-vision{
    position:relative;
    overflow:hidden;
    background:
        radial-gradient(circle at 12% 8%, rgba(107,163,0,0.14), transparent 30%),
        radial-gradient(circle at 88% 20%, rgba(1,35,80,0.10), transparent 32%),
        linear-gradient(180deg, #ffffff 0%, #eef5f4 100%);
}

.about-us-mission-vision::before{
    content:'';
    position:absolute;
    inset:auto -140px -210px auto;
    width:430px;
    height:430px;
    border:70px solid rgba(107,163,0,0.10);
    border-radius:50%;
    pointer-events:none;
}

.about-us-mv-head{
    max-width:860px;
    margin:0 auto 42px;
    text-align:center;
}

.about-us-mv-head .section-lead{
    margin:0 auto;
}

.about-us-mv-grid{
    display:grid;
    grid-template-columns:repeat(2, minmax(0, 1fr));
    gap:28px;
}

.about-us-mv-card{
    position:relative;
    display:grid;
    grid-template-rows:260px minmax(0, 1fr);
    min-height:100%;
    overflow:hidden;
    border:1px solid rgba(1,35,80,0.09);
    border-radius:18px;
    background:#fff;
    box-shadow:0 24px 70px rgba(1,35,80,0.12);
    isolation:isolate;
    transition:transform .28s ease, box-shadow .28s ease;
}

.about-us-mv-card:hover{
    transform:translateY(-6px);
    box-shadow:0 30px 86px rgba(1,35,80,0.18);
}

.about-us-mv-image{
    position:relative;
    overflow:hidden;
    background:#0f2435;
}

.about-us-mv-image::after{
    content:'';
    position:absolute;
    inset:0;
    background:
        linear-gradient(180deg, rgba(1,35,80,0.02) 0%, rgba(1,35,80,0.54) 100%),
        linear-gradient(90deg, rgba(107,163,0,0.18), rgba(0,0,0,0));
}

.about-us-mv-card img{
    width:100%;
    height:100%;
    object-fit:cover;
    transform:scale(1.01);
    transition:transform .45s ease;
}

.about-us-mv-card:hover img{
    transform:scale(1.06);
}

.about-us-mv-copy{
    position:relative;
    display:flex;
    flex-direction:column;
    justify-content:flex-start;
    min-height:330px;
    padding:42px 38px 38px;
}

.about-us-mv-copy::before{
    content:'';
    position:absolute;
    left:38px;
    top:0;
    width:92px;
    height:5px;
    border-radius:999px;
    background:linear-gradient(90deg, var(--accent), rgba(107,163,0,0));
}

.about-us-mv-icon{
    position:absolute;
    top:-38px;
    right:34px;
    z-index:2;
    display:grid;
    place-items:center;
    width:76px;
    height:76px;
    border:7px solid #fff;
    border-radius:18px;
    color:#fff;
    background:linear-gradient(135deg, var(--accent) 0%, #008c72 100%);
    box-shadow:0 18px 36px rgba(1,35,80,0.20);
    font-size:1.7rem;
}

.about-us-mv-copy .eyebrow{
    align-self:flex-start;
    padding:9px 14px;
    color:var(--accent);
    background:rgba(107,163,0,0.08);
}

.about-us-mv-card h2{
    margin:20px 0 16px;
    font-family:'Cormorant Garamond', serif;
    font-size:clamp(2.15rem, 3vw, 3.2rem);
    line-height:1.02;
    letter-spacing:-.02em;
}

.about-us-mv-card p{
    margin:0;
    color:var(--muted);
    font-size:1.02rem;
    line-height:1.78;
}

@media (max-width:1199px){
    .about-us-hero-grid,
    .about-us-intro-grid,
    .about-us-platform-grid{
        gap:34px;
    }

    .about-us-mv-card{
        grid-template-rows:240px minmax(0, 1fr);
    }
}

@media (max-width:991px){
    .about-us-hero-grid,
    .about-us-intro-grid,
    .about-us-platform-grid,
    .about-us-mv-grid{
        grid-template-columns:1fr;
    }

    .about-us-hero{
        padding:68px 0;
    }

    .about-us-hero-media,
    .about-us-hero-media img{
        min-height:360px;
    }

    .about-us-platform-image img{
        height:460px;
    }

    .about-us-award-grid{
        grid-template-columns:1fr;
    }

    .about-us-achievement-list{
        grid-template-columns:1fr;
    }

    .about-us-mv-card{
        grid-template-rows:280px minmax(0, 1fr);
    }
}

@media (max-width:575px){
    .about-us-hero{
        padding:54px 0;
    }

    .about-us-hero-actions{
        flex-direction:column;
        align-items:stretch;
    }

    .about-us-hero-actions .btn-elegant{
        justify-content:center;
    }

    .about-us-hero-media,
    .about-us-hero-media img{
        min-height:300px;
    }

    .about-us-platform-image img{
        height:320px;
    }

    .about-us-value-grid{
        grid-template-columns:1fr;
    }

    .about-us-awards .media-head{
        margin-bottom:30px;
        text-align:left;
    }

    .about-us-awards .section-lead{
        margin:0;
    }

    .about-us-achievement-list li{
        padding:24px 22px;
        border-radius:14px;
    }

    .about-us-achievement-list li::after{
        right:16px;
        top:14px;
        font-size:3.2rem;
    }

    .about-us-achievement-icon{
        width:52px;
        height:52px;
        margin-bottom:18px;
        border-radius:14px;
        font-size:1.15rem;
    }

    .about-us-mv-head{
        margin-bottom:30px;
        text-align:left;
    }

    .about-us-mv-head .section-lead{
        margin:0;
    }

    .about-us-mv-card{
        grid-template-rows:220px minmax(0, 1fr);
        border-radius:14px;
    }

    .about-us-mv-copy{
        min-height:0;
        padding:34px 24px 28px;
    }

    .about-us-mv-copy::before{
        left:24px;
    }

    .about-us-mv-icon{
        top:-32px;
        right:22px;
        width:64px;
        height:64px;
        border-width:6px;
        border-radius:16px;
        font-size:1.35rem;
    }

    .about-us-patent-note{
        flex-direction:column;
    }
}

/* Reference footer layout */
.site-footer{
    padding:78px 0 30px;
    color:#fff;
    background:#101c31;
    overflow:hidden;
}

.site-footer .container-fluid{
    max-width:1700px;
}

.footer-main-grid{
    display:grid;
    grid-template-columns:minmax(300px, 1.28fr) minmax(190px, .72fr) minmax(300px, 1fr) minmax(320px, .95fr);
    gap:72px;
    align-items:start;
    max-width:1620px;
    margin:0 auto;
}

.footer-about{
    max-width:520px;
}

.footer-logo{
    display:inline-flex;
    align-items:center;
    width:220px;
    margin-bottom:34px;
    text-decoration:none;
}

.footer-logo img{
    width:100%;
    height:auto;
    filter:brightness(0) invert(1);
}

.footer-about p{
    margin:0;
    color:#fff;
    font-size:1.18rem;
    line-height:1.72;
}

.footer-social{
    display:flex;
    flex-wrap:wrap;
    align-items:center;
    gap:14px;
    margin-top:40px;
    padding-top:0;
}

.footer-social a{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    width:56px;
    height:56px;
    border:1px solid rgba(255,255,255,0.13);
    border-radius:14px;
    color:#fff;
    background:rgba(255,255,255,0.09);
    text-decoration:none;
    font-size:1.35rem;
    transition:background .2s ease, border-color .2s ease, transform .2s ease;
}

.footer-social a:hover{
    color:#fff;
    border-color:rgba(107,163,0,0.65);
    background:rgba(107,163,0,0.22);
    opacity:1;
    transform:translateY(-2px);
}

.footer-link-group h4,
.footer-contact h4{
    position:relative;
    margin:0 0 46px;
    color:#f3b10a;
    font-family:'Inter', sans-serif;
    font-size:1.42rem;
    font-weight:800;
    line-height:1.2;
}

.footer-link-group h4::after,
.footer-contact h4::after{
    content:'';
    position:absolute;
    left:0;
    bottom:-22px;
    width:62px;
    height:3px;
    border-radius:999px;
    background:linear-gradient(90deg, #f3b10a 0%, rgba(243,177,10,0) 100%);
}

.footer-link-group ul{
    padding:0;
    margin:0;
    list-style:none;
}

.footer-link-group li{
    margin-bottom:18px;
}

.footer-link-group a{
    position:relative;
    display:inline-flex;
    align-items:center;
    gap:10px;
    color:#fff;
    font-size:1.08rem;
    line-height:1.35;
    font-weight:500;
    text-decoration:none;
    transition:color .2s ease, transform .2s ease;
}

.footer-link-group a::before{
    content:'\f105';
    color:rgba(255,255,255,0.58);
    font-family:'Font Awesome 6 Free';
    font-size:.92rem;
    font-weight:900;
}

.footer-link-group a:hover{
    color:#f3b10a;
    opacity:1;
    transform:translateX(3px);
}

.footer-contact{
    min-width:0;
}

.footer-contact-item{
    display:grid;
    grid-template-columns:50px minmax(0, 1fr);
    gap:18px;
    align-items:start;
    padding:26px 0 25px;
    border-bottom:1px solid rgba(255,255,255,0.12);
}

.footer-contact-item:first-of-type{
    padding-top:0;
}

.footer-contact-item:last-child{
    border-bottom:0;
    padding-bottom:0;
}

.footer-contact-icon{
    display:grid;
    place-items:center;
    width:50px;
    height:50px;
    border-radius:13px;
    color:#fff;
    background:linear-gradient(135deg, #2b5fba 0%, #008c52 100%);
    font-size:1.08rem;
}

.footer-contact-item p{
    margin:0;
    color:#fff;
    font-size:1.06rem;
    font-weight:500;
    line-height:1.65;
}

.footer-contact-item a{
    display:block;
    color:#fff;
    text-decoration:none;
}

.footer-contact-item a:hover{
    color:#f3b10a;
}

.footer-disclaimer{
    max-width:1620px;
    margin:62px auto 0;
    padding:38px 14px 28px;
    border-top:1px solid rgba(255,255,255,0.14);
    border-bottom:1px solid rgba(255,255,255,0.14);
    text-align:center;
}

.footer-disclaimer p{
    margin:0;
    color:#fff;
    font-size:1rem;
    line-height:1.72;
}

.footer-disclaimer strong{
    color:#f3b10a;
}

.footer-copyright{
    margin:24px 0 0;
    color:#fff;
    font-size:1rem;
    line-height:1.5;
    text-align:center;
}

@media (max-width:1199px){
    .footer-main-grid{
        grid-template-columns:repeat(2, minmax(0, 1fr));
        gap:42px 52px;
    }

    .footer-about{
        max-width:none;
    }
}

@media (max-width:767px){
    .site-footer{
        padding:54px 0 28px;
    }

    .footer-main-grid{
        grid-template-columns:1fr;
        gap:38px;
    }

    .footer-logo{
        width:190px;
        margin-bottom:24px;
    }

    .footer-about p{
        font-size:1rem;
    }

    .footer-social{
        gap:12px;
        margin-top:28px;
    }

    .footer-social a{
        width:50px;
        height:50px;
        font-size:1.18rem;
    }

    .footer-link-group h4,
    .footer-contact h4{
        margin-bottom:38px;
        font-size:1.24rem;
    }

    .footer-link-group li{
        margin-bottom:13px;
    }

    .footer-link-group a,
    .footer-contact-item p{
        font-size:1rem;
    }

    .footer-contact-item{
        grid-template-columns:48px minmax(0, 1fr);
        gap:16px;
        padding:22px 0;
    }

    .footer-contact-icon{
        width:48px;
        height:48px;
    }

    .footer-disclaimer{
        margin-top:42px;
        padding:26px 0 24px;
        text-align:left;
    }

    .footer-copyright{
        text-align:left;
    }
}

/* Site-wide responsive and title typography fixes */
:root{
    --title-font:'Inter', sans-serif;
}

.section-title,
.hero-copy h1,
.contact-hero h1,
.team-heading h1,
.about-us-hero h1,
.about-us-mv-card h2{
    font-family:var(--title-font);
    font-weight:800;
    letter-spacing:0;
}

.section-title,
.hero-copy h1,
.contact-hero h1,
.team-heading h1,
.about-us-hero h1,
.about-us-mv-card h2,
.footer-contact-item p,
.footer-contact-item a,
.header-menu .nav-link,
.btn-elegant{
    overflow-wrap:anywhere;
}

.site-logo img{
    width:min(220px, 100%);
}

.header-actions{
    min-width:0;
}

.header-actions a{
    min-width:0;
}

.header-actions span{
    white-space:normal;
}

.hero-grid{
    min-height:clamp(420px, 56vw, 760px);
    aspect-ratio:auto;
}

.hero-copy h1{
    font-size:clamp(2.55rem, 5.4vw, 5.8rem);
    line-height:1.02;
}

.section-title{
    font-size:clamp(2rem, 4.2vw, 4rem);
    line-height:1.08;
}

.process-showcase-image{
    width:100%;
    min-height:clamp(420px, 48vw, 660px);
    object-fit:cover;
}

.green-solutions-content{
    min-width:0;
}

.team-card,
.about-us-patent-note,
.lets-talk-content{
    min-width:0;
}

@media (max-width:1399px){
    .header-top-grid{
        grid-template-columns:minmax(150px, 200px) minmax(280px, 1fr);
    }

    .header-actions{
        grid-column:1 / -1;
        justify-content:flex-end;
    }

    .footer-main-grid{
        gap:42px;
    }
}

@media (max-width:1199px){
    .hero{
        padding-bottom:0;
    }

    .hero-grid{
        min-height:clamp(380px, 58vw, 620px);
    }

    .header-menu{
        gap:6px 10px;
    }

    .header-menu .nav-link{
        font-size:1rem;
        padding-left:7px !important;
        padding-right:7px !important;
    }

    .about-us-achievement-list,
    .about-us-award-grid{
        grid-template-columns:repeat(2, minmax(0, 1fr));
    }
}

@media (max-width:991px){
    .header-top-grid{
        grid-template-columns:1fr;
        gap:14px;
    }

    .header-actions{
        grid-column:auto;
        justify-content:flex-start;
        white-space:normal;
    }

    .header-menu .dropdown-menu{
        max-width:100%;
    }

    .hero-copy{
        width:min(680px, calc(100% - 40px));
    }

    .innovation-panel,
    .about-us-intro-grid,
    .about-us-platform-grid,
    .about-us-hero-grid,
    .about-us-mv-grid{
        grid-template-columns:1fr;
    }

    .green-solutions-content{
        width:100%;
        max-width:none;
    }

    .event-card,
    .event-feature-card{
        grid-template-columns:1fr;
    }

    .bio-cng .about-gallery-grid{
        grid-template-columns:repeat(2, minmax(0, 1fr));
    }
}

@media (max-width:767px){
    .container,
    .container-fluid{
        max-width:100%;
    }

    .section{
        padding:56px 0;
    }

    .eyebrow{
        max-width:100%;
        white-space:normal;
        line-height:1.35;
    }

    .hero{
        padding-bottom:0;
    }

    .hero-grid{
        min-height:480px;
    }

    .hero-copy{
        width:calc(100% - 28px);
        margin-left:14px;
        padding:0;
    }

    .hero-copy h1{
        font-size:clamp(2.3rem, 12vw, 3.6rem);
    }

    .hero-copy p{
        max-width:92%;
    }

    .hero-visual img{
        object-fit:cover;
        object-position:center;
    }

    .process-showcase-section .container{
        position:relative;
        inset:auto;
    }

    .process-showcase-image{
        min-height:0;
        height:auto;
    }

    .process-showcase-copy{
        position:relative;
        top:auto;
        left:auto;
        transform:none;
        width:100%;
        padding:32px 12px 0;
    }

    .innovation-panel{
        padding:26px 18px;
    }

    .innovation-point,
    .green-solution-card,
    .footer-contact-item{
        grid-template-columns:1fr;
    }

    .award-showcase-card img,
    .about-split-image img,
    .about-us-platform-image img{
        height:auto;
        max-height:none;
    }

    .about-us-hero-media,
    .about-us-hero-media img{
        min-height:260px;
    }

    .about-us-achievement-list,
    .about-us-award-grid,
    .bio-cng .about-gallery-grid{
        grid-template-columns:1fr;
    }

    .team-card{
        flex-direction:column;
        align-items:stretch;
        gap:0;
    }

    .team-card img,
    .team-photo{
        width:100%;
        height:auto;
    }

    .btn-elegant{
        justify-content:center;
        width:100%;
        padding:14px 18px;
        text-align:center;
    }
}

@media (max-width:480px){
    .header-top .container-fluid,
    .header-nav .container-fluid{
        padding-left:16px !important;
        padding-right:16px !important;
    }

    .header-awards{
        grid-template-columns:1fr;
    }

    .award-card{
        justify-content:flex-start;
        border-right:0;
    }

    .header-actions{
        flex-direction:column;
        align-items:flex-start;
    }

    .section-title{
        font-size:clamp(1.85rem, 10vw, 2.8rem);
    }

    .hero-grid{
        min-height:430px;
    }
}
:root{
    --bg: #f5f1e8;
    --surface: rgba(255,255,255,0.76);
    --surface-strong: #ffffff;
    --text: #012350;
    --muted: #526172;
    --line: rgba(1,35,80,0.10);
    --accent: #6BA300;
    --accent-2: #012350;
    --shadow: 0 30px 80px rgba(1,35,80,0.12);
    --radius: 28px;
}

*{
    box-sizing:border-box;
}

html{
    scroll-behavior:smooth;
}

body{
    margin:0;
    font-family:'Inter', sans-serif;
    color:var(--text);
    background:
        radial-gradient(circle at top left, rgba(107,163,0,0.15), transparent 32%),
        radial-gradient(circle at top right, rgba(1,35,80,0.12), transparent 28%),
        linear-gradient(180deg, #fbf8f1 0%, #f4efe5 100%);
    overflow-x:hidden;
}

img{
    max-width:100%;
    display:block;
}

a{
    color:inherit;
}

.container-fluid,
.container{
    position:relative;
}

.section{
    padding:80px 0;
}

.eyebrow{
    display:inline-flex;
    align-items:center;
    gap:10px;
    padding:10px 16px;
    border:1px solid var(--line);
    border-radius:999px;
    color:var(--accent);
    text-transform:uppercase;
    letter-spacing:.16em;
    font-size:12px;
    font-weight:700;
    background:rgba(255,255,255,0.45);
}

.eyebrow::before{
    content:'';
    width:8px;
    height:8px;
    border-radius:50%;
    background:var(--accent-2);
    box-shadow:0 0 0 6px rgba(1,35,80,0.12);
}

.section-title{
    font-family:'Cormorant Garamond', serif;
    font-size:clamp(2.4rem, 2.8vw, 4.5rem);
    line-height:.96;
    letter-spacing:-.03em;
    margin:18px 0 16px;
}

.section-lead{
    max-width:520px;
    color:#111827 !important;
    font-size:1.05rem;
    line-height:1.9;
}

.glass{
    background:var(--surface);
    backdrop-filter:blur(14px);
    -webkit-backdrop-filter:blur(14px);
    border:1px solid rgba(255,255,255,0.7);
    box-shadow:var(--shadow);
}

.btn-elegant{
    display:inline-flex;
    align-items:center;
    gap:12px;
    padding:16px 26px;
    border-radius:999px;
    text-decoration:none;
    font-weight:700;
    transition:transform .25s ease, box-shadow .25s ease, background .25s ease;
}

.btn-elegant:hover{
    transform:translateY(-2px);
}

.btn-primary-elegant{
    background:var(--accent);
    color:var(--text);
    box-shadow:0 14px 30px rgba(107,163,0,0.28);
}

.btn-primary-elegant:hover{
    color:#fff;
    box-shadow:0 18px 34px rgba(107,163,0,0.34);
}

.btn-secondary-elegant{
    border:1px solid var(--line);
    color:var(--text);
    background:rgba(255,255,255,0.5);
}

/* Header */
.site-header{
    background:#fff;
    border-bottom:1px solid #e8e8e8;
}

.header-top{
    padding:18px 0 10px;
}

.header-top-grid{
    display:grid;
    grid-template-columns:minmax(170px, 210px) minmax(0, 1fr) auto;
    align-items:center;
    gap:20px;
}

.site-logo{
    display:inline-flex;
    align-items:center;
    text-decoration:none;
}

.site-logo img{
    max-width:220px;
    height:auto;
}

.award-marquee{
    min-width:0;
    border-radius:0;
    border-left:1px solid #ededed;
    border-right:1px solid #ededed;
    box-shadow:none;
    background:#fff;
    padding:4px 10px;
}

.header-awards{
    display:grid;
    grid-template-columns:repeat(3, minmax(0, 1fr));
    align-items:center;
    gap:0;
}

.award-marquee .owl-stage{
    display:flex;
    align-items:center;
}

.award-card{
    display:flex;
    align-items:center;
    gap:12px;
    padding:6px 14px;
    min-height:56px;
    border-right:1px solid #e5e5e5;
}

.header-awards .award-card{
    justify-content:center;
}

.award-card-center{
    position:relative;
}

.award-year{
    flex:0 0 auto;
    font-size:.86rem;
    font-weight:800;
    color:var(--accent);
    letter-spacing:.02em;
}

.award-text{
    display:flex;
    flex-direction:column;
    line-height:1.1;
}

.award-text strong{
    font-size:.72rem;
    text-transform:uppercase;
    letter-spacing:.04em;
    color:var(--text);
    white-space:nowrap;
}

.award-text span{
    font-size:.66rem;
    color:#6e6e6e;
    white-space:nowrap;
}

.header-actions{
    display:flex;
    align-items:center;
    gap:28px;
    font-size:1rem;
    color:#3a3a3a;
    white-space:nowrap;
}

.header-actions a{
    text-decoration:none;
    display:inline-flex;
    align-items:center;
    gap:10px;
    font-weight:500;
}

.header-actions a:hover{
    color:var(--accent);
}

.header-actions i{
    font-size:1.15rem;
}

.header-actions span{
    line-height:1;
}

.header-nav{
    border-top:1px solid #efefef;
    border-bottom:1px solid #ececec;
    background:linear-gradient(180deg, #ffffff 0%, #fcfcfb 100%);
    box-shadow:inset 0 1px 0 rgba(255,255,255,0.8);
}

.header-nav .navbar{
    padding:0;
    min-height:74px;
}

.header-menu{
    gap:10px 26px;
    align-items:center;
    margin-left:auto !important;
    margin-right:0 !important;
}

.header-menu .nav-link{
    position:relative;
    padding:20px 12px 18px !important;
    font-family:'Inter', sans-serif;
    font-size:1.35rem;
    line-height:1;
    font-weight:500;
    color:#1b1b1b !important;
    letter-spacing:-.02em;
    border-radius:14px 14px 0 0;
    transition:color .2s ease, background-color .2s ease, transform .2s ease;
}

.header-menu .nav-link:hover{
    background:rgba(107,163,0,0.06);
    transform:translateY(-1px);
    color:var(--accent) !important;
}

.header-menu .nav-link a{
    text-decoration:none;
}

.header-menu .nav-link::after{
    content:'';
    position:absolute;
    left:12px;
    right:12px;
    bottom:7px;
    height:3px;
    background:var(--accent);
    transform:scaleX(0);
    transform-origin:left;
    transition:transform .25s ease;
    border-radius:999px;
}

.header-menu .nav-link:hover::after{
    transform:scaleX(1);
}

.header-menu .nav-item.active .nav-link{
    color:var(--accent) !important;
    background:rgba(107,163,0,0.05);
}

.header-menu .dropdown-menu{
    border:none;
    border-radius:16px;
    padding:8px;
    min-width:240px;
    box-shadow:0 22px 50px rgba(1,35,80,0.10);
}

.header-menu .dropdown-item{
    border-radius:12px;
    padding:10px 14px;
    font-size:1rem;
}

.header-menu .dropdown-item:hover{
    background:rgba(107,163,0,0.10);
}

.navbar-toggler{
    color:var(--text);
    font-size:1.3rem;
}

.navbar-toggler:focus{
    box-shadow:none;
}

/* Header / Navbar submenu support */
header,
.navbar,
.header-area,
.site-header,
.header-nav{
    position:relative;
    z-index:9999;
    overflow:visible !important;
}

.header-menu .menu-item-has-children,
.header-menu .nav-item.dropdown{
    position:relative;
}

@media (min-width: 992px){
    .header-menu .sub-menu,
    .header-menu .dropdown-menu{
        position:absolute;
        top:100%;
        left:0;
        min-width:240px;
        background:#fff;
        padding:12px 0;
        margin:0;
        list-style:none;
        border:none;
        border-radius:12px;
        box-shadow:0 10px 30px rgba(0,0,0,0.08);
        display:block;
        opacity:0;
        visibility:hidden;
        transform:translateY(10px);
        transition:.3s ease;
        z-index:9999;
    }

    .header-menu .menu-item-has-children:hover > .sub-menu,
    .header-menu .nav-item.dropdown:hover > .dropdown-menu,
    .header-menu .nav-item.dropdown > .dropdown-menu.show{
        opacity:1;
        visibility:visible;
        transform:translateY(0);
    }
}

/* Hero */

.hero-grid{
    position:relative;
    display:grid;
    align-items:center;
    width:100%;
    min-height:0;
    aspect-ratio:16 / 9;
    overflow:hidden;
    isolation:isolate;
}

.hero-copy{
    position:relative;
    z-index:2;
    width:min(760px, calc(100% - 40px));
    margin-left:clamp(24px, 7vw, 120px);
    padding:0;
    border-radius:0;
    display:flex;
    flex-direction:column;
    justify-content:center;
    align-items:flex-start;
    text-align:left;
    color:#000;
    background:none;
    border:0;
    box-shadow:none;
    backdrop-filter:none;
    -webkit-backdrop-filter:none;
}

.hero-copy h1{
    font-family:'Cormorant Garamond', serif;
    font-size:clamp(3.4rem, 4.5vw, 7rem);
    line-height:.9;
    letter-spacing:-.03em;
    margin:0 0 26px;

    text-wrap:balance;
    text-shadow:0 12px 28px rgba(255,255,255,0.46);
}

.hero-copy p{
    max-width:500px;
    font-size:clamp(1rem, 1.6vw, 1.25rem);
    line-height:1.75;
    color:#111827;
    margin-bottom:0;
    text-shadow:0 10px 24px rgba(255,255,255,0.5);
}

.hero-visual{
    position:absolute;
    inset:0;
    z-index:1;
    border-radius:0;
    overflow:hidden;
    min-height:100%;
    box-shadow:none;
    background:linear-gradient(180deg, #ffffff 0%, #bde889 100%);
}

.hero-visual img{
    width:100%;
    height:100%;
    object-fit:contain;
    object-position:center;
}

.hero-visual .overlay{
    display:none;
}

.award-strip{
    margin-top:22px;
    padding:18px 16px;
    border-radius:24px;
}

.award-strip .strip-label{
    display:flex;
    align-items:center;
    gap:10px;
    font-size:.78rem;
    text-transform:uppercase;
    letter-spacing:.18em;
    color:var(--muted);
    margin-bottom:16px;
}

.award-strip .strip-label::after{
    content:'';
    flex:1;
    height:1px;
    background:var(--line);
}

.header-top .award-slider .award-item{
    min-height:56px;
    padding:0 18px;
    border-radius:0;
    background:transparent;
    box-shadow:none;
    border:none;
}

.award-slider .award-item{
    display:flex;
    align-items:center;
    justify-content:center;
    gap:10px;
    min-height:72px;
    padding:8px 10px;
    border-radius:18px;
    background:rgba(255,255,255,0.72);
    border:1px solid rgba(1,35,80,0.08);
    color:var(--text);
    font-weight:700;
    text-align:center;
}

.award-slider .award-item img{
    max-height:64px;
    max-width:100%;
    width:auto;
    opacity:.92;
}

.award-slider .award-item i{
    color:var(--accent);
    font-size:1.05rem;
}

.award-slider .award-item span{
    font-size:.92rem;
}

.header-top .award-card{
    border-right:1px solid #dcdcdc;
}

.header-top .award-card img{
    max-height:70px;
    width:auto;
    object-fit:contain;
}

/* Process Showcase */
.process-showcase-section{
    position:relative;
    padding:0;
    overflow:hidden;
    background:#f4fae9;
}

.process-showcase-section .container{
    position:absolute;
    inset:0;
    z-index:1;
}

.process-showcase-image{
    position:relative;
    width:100%;
    /* height:620px; */
    object-fit:cover;
    object-position:center center;
}

.process-showcase-copy{
    position:absolute;
    top:50%;
    left:12px;
    transform:translateY(-50%);
    width:min(50%, 500px);
	color:#000 !important
}

.process-showcase-copy .section-lead{
    margin:0;
}

/* Innovation */
.innovation-section{
    padding-top:94px;
    padding-bottom:94px;
    background:
        radial-gradient(circle at 8% 18%, rgba(107,163,0,0.10), transparent 28%),
        linear-gradient(180deg, #fbf8f1 0%, #f0f5ea 100%);
}

.innovation-panel{
    display:grid;
    grid-template-columns:minmax(0, 1fr) minmax(340px, .82fr);
    gap:46px;
    align-items:center;
    padding:52px;
    border-radius:8px;
    color:#fff;
    background:
        radial-gradient(circle at top right, rgba(107,163,0,0.22), transparent 36%),
        linear-gradient(135deg, #012350 0%, #001633 100%);
    box-shadow:0 24px 70px rgba(1,35,80,0.18);
}

.innovation-media{
    grid-column:1 / -1;
    width:100%;
    overflow:hidden;
    border-radius:8px;
    background:#fff;
}

.innovation-media img{
    width:100%;
    height:auto;
    object-fit:contain;
}

.innovation-panel .eyebrow{
    color:#fff;
    border-color:rgba(255,255,255,0.18);
    background:rgba(255,255,255,0.08);
}

.innovation-panel .eyebrow::before{
    background:var(--accent);
    box-shadow:0 0 0 6px rgba(107,163,0,0.18);
}

.innovation-panel .section-lead{
    color:rgba(255,255,255,0.78);
}

.innovation-points{
    display:grid;
    gap:16px;
}

.innovation-point{
    display:grid;
    grid-template-columns:52px minmax(0, 1fr);
    gap:18px;
    align-items:start;
    padding:18px;
    border-radius:8px;
    background:rgba(255,255,255,0.08);
    border:1px solid rgba(255,255,255,0.10);
}

.innovation-point i{
    width:52px;
    height:52px;
    display:grid;
    place-items:center;
    border-radius:8px;
    color:#012350;
    background:var(--accent);
    font-size:1.15rem;
}

.innovation-point h3{
    margin:0 0 6px;
    font-size:1.08rem;
    letter-spacing:-.02em;
}

.innovation-point p{
    margin:0;
    color:rgba(255,255,255,0.72);
    line-height:1.65;
    font-size:.95rem;
}

/* Our Operation */
.operation-section{
    padding:94px 0 0;
    background:
        linear-gradient(180deg, #ffffff 0%, #edf3f4 100%);
}

.operation-head{
    max-width:820px;
    margin:0 auto 38px;
    padding:0 20px;
    text-align:center;
}

.operation-map{
    position:relative;
    width:100%;
    height:clamp(520px, 48vw, 760px);
    overflow:hidden;
    background:
        linear-gradient(180deg, #ffffff 0%, #eef4ea 100%);
    border-top:1px solid rgba(1,35,80,0.08);
    border-bottom:1px solid rgba(1,35,80,0.08);
}

.operation-map img{
    display:block;
    width:100%;
    height:100%;
    object-fit:cover;
    object-position:center 64%;
}

.operation-map::before{
    content:'';
    position:absolute;
    inset:0;
    background:
        linear-gradient(90deg, rgba(247,249,247,0.72) 0%, rgba(247,249,247,0) 18%, rgba(247,249,247,0) 82%, rgba(247,249,247,0.72) 100%);
    pointer-events:none;
}

.operation-map-caption{
    position:absolute;
    left:50%;
    bottom:28px;
    display:flex;
    flex-wrap:wrap;
    gap:12px;
    transform:translateX(-50%);
}

.operation-map-caption span{
    display:inline-flex;
    align-items:center;
    min-height:40px;
    padding:9px 16px;
    border-radius:999px;
    color:#fff;
    background:rgba(1,35,80,0.92);
    box-shadow:0 14px 34px rgba(1,35,80,0.18);
    font-size:.9rem;
    font-weight:700;
}

/* Green Solutions */
.green-solutions{
    padding-top:94px;
    min-height:760px;
    background:#f4fae9;
}

.green-solutions-content{
    width:50%;
    max-width:640px;
}

.green-solutions-head{
    max-width:none;
    margin:0 0 42px;
    text-align:left;
}

.green-solutions-head .section-lead{
    margin:0;
}

.green-solutions-grid{
    display:grid;
    grid-template-columns:1fr;
    gap:14px;
}

.green-solution-card{
    position:relative;
    padding:16px 18px;
    border-radius:8px;
    overflow:hidden;
    display:grid;
    grid-template-columns:58px minmax(0, 1fr);
    gap:10px;
    align-items:start;
    background:
        linear-gradient(145deg, rgba(255,255,255,0.88), rgba(247,244,236,0.74));
    border:1px solid rgba(1,35,80,0.08);
    box-shadow:0 18px 44px rgba(1,35,80,0.08);
}

.green-solution-card::after{
    content:'';
    position:absolute;
    right:-42px;
    bottom:-42px;
    width:130px;
    height:130px;
    border-radius:50%;
    background:rgba(107,163,0,0.12);
}

.green-solution-icon{
    position:relative;
    z-index:1;
    width:52px;
    height:52px;
    display:grid;
    place-items:center;
    margin-bottom:0;
    border-radius:8px;
    color:#fff;
    background:var(--text);
    font-size:1.3rem;
}

.green-solution-copy{
    position:relative;
    z-index:1;
    grid-column:2;
}

.green-solution-card h3{
    margin:0 0 7px;
    font-size:1.15rem;
    letter-spacing:-.02em;
}

.green-solution-card p{
    margin:0;
    color:var(--muted);
    line-height:1.42;
}

/* Awards */
.awards-section{
    padding-top:94px;
    padding-bottom:94px;
    background:
        radial-gradient(circle at 15% 0%, rgba(1,35,80,0.08), transparent 30%),
        linear-gradient(180deg, #fffaf0 0%, #f7efe2 100%);
}

.awards-head{
    max-width:820px;
    margin:0 auto 42px;
    text-align:center;
}

.awards-head .section-lead{
    margin:0 auto;
}

.awards-grid{
    display:grid;
    grid-template-columns:repeat(2, minmax(0, 1fr));
    gap:26px;
    align-items:stretch;
}

.award-showcase-card{
    position:relative;
    height:100%;
    padding:0;
    border-radius:8px;
    background:#fff;
    border:1px solid rgba(1,35,80,0.08);
    box-shadow:0 18px 44px rgba(1,35,80,0.07);
    overflow:hidden;
}

.award-showcase-card.featured{
    color:var(--text);
    background:#fff;
}

.award-showcase-card img{
    width:100%;
    height:360px;
    margin:0;
    object-fit:cover;
    object-position:center;
}

.award-showcase-copy{
    padding:26px 28px 30px;
    border-top:5px solid var(--accent);
}

.award-showcase-card h3{
    margin:0 0 10px;
    font-size:1.35rem;
    letter-spacing:-.02em;
}

.award-showcase-card p{
    margin:0;
    color:var(--muted);
    line-height:1.7;
}

/* Cards */
.section-soft{
    margin:0;
}

.section-shell{
    padding:34px;
    border-radius:var(--radius);
    background:rgba(255,255,255,0.82);
}

.feature-card,
.service-card,
.insight-card{
    height:100%;
    padding:30px;
    border-radius:28px;
    background:rgba(255,255,255,0.72);
    border:1px solid rgba(1,35,80,0.08);
    box-shadow:0 18px 42px rgba(1,35,80,0.06);
    transition:transform .25s ease, box-shadow .25s ease;
}

.feature-card:hover,
.service-card:hover,
.insight-card:hover{
    transform:translateY(-6px);
    box-shadow:0 24px 58px rgba(1,35,80,0.10);
}

.feature-icon,
.service-icon{
    width:58px;
    height:58px;
    border-radius:18px;
    display:grid;
    place-items:center;
    color:#fff;
    background:linear-gradient(135deg, var(--accent), #4f7a00);
    margin-bottom:20px;
    font-size:1.25rem;
}

.feature-card h4,
.service-card h4{
    font-size:1.35rem;
    margin:0 0 12px;
    letter-spacing:-.02em;
}

.feature-card p,
.service-card p,
.insight-card p,
.about-copy p{
    color:var(--muted);
    line-height:1.85;
    margin:0;
}

/* About */
.about-section{
    background:
        radial-gradient(circle at 85% 12%, rgba(1,35,80,0.08), transparent 30%),
        linear-gradient(180deg, #edf4f2 0%, #f7fbf8 100%);
}

.about-frame{
    position:relative;
    overflow:hidden;
    border-radius:32px;
    /* min-height:580px; */
    box-shadow:var(--shadow);
}

.about-frame img{
    width:100%;
    height:100%;
    object-fit:cover;
}

.about-frame .frame-badge{
    position:absolute;
    left:20px;
    top:20px;
    padding:12px 16px;
    border-radius:999px;
    color:var(--text);
    background:rgba(255,255,255,0.82);
    border:1px solid rgba(1,35,80,0.08);
    font-weight:700;
    font-size:.9rem;
}

.about-head{
    max-width:980px;
    margin:0 auto 46px;
    text-align:center;
}

.about-head .section-lead{
    margin:0 auto;
}

.about-copy{
    padding-right:20px;
}

.mini-grid{
    display:grid;
    grid-template-columns:repeat(2, minmax(0,1fr));
    gap:16px;
    margin-top:0;
}

.mini-card{
    padding:18px;
    border-radius:22px;
    background:rgba(255,255,255,0.72);
    border:1px solid rgba(1,35,80,0.08);
}

.mini-card strong{
    display:block;
    margin-bottom:6px;
    font-size:1rem;
}

.mini-card span{
    color:var(--muted);
    font-size:.95rem;
    line-height:1.6;
}

/* Metrics */
.metrics-grid{
    display:grid;
    grid-template-columns:repeat(4, minmax(0,1fr));
    gap:18px;
}

.metric-card{
    padding:28px 24px;
    border-radius:26px;
    background:rgba(255,255,255,0.72);
    border:1px solid rgba(1,35,80,0.08);
    text-align:center;
}

.metric-card strong{
    display:block;
    font-family:'Cormorant Garamond', serif;
    font-size:3rem;
    line-height:1;
    letter-spacing:-.04em;
}

.metric-card span{
    display:block;
    margin-top:10px;
    color:var(--muted);
}

/* Contact */
.contact-hero{
    position:relative;
    height:300px;
    padding:40px 0;
    display:flex;
    align-items:center;
    color:#fff;
    background:
        linear-gradient(90deg, rgba(1,35,80,0.86) 0%, rgba(1,35,80,0.64) 48%, rgba(1,35,80,0.28) 100%),
        url("../img/banner.jpg") center / cover no-repeat;
    overflow:hidden;
}

.contact-hero-copy{
    width:min(760px, 100%);
}

.contact-hero h1{
    max-width:820px;
    margin:0 0 12px;
    font-family:'Cormorant Garamond', serif;
    font-size:clamp(2.8rem, 5vw, 4.8rem);
    line-height:1;
    letter-spacing:-.03em;
}

.contact-hero p{
    max-width:620px;
    margin:0;
    color:rgba(255,255,255,0.82);
    font-size:1.05rem;
    line-height:1.65;
}

.contact-section{
    background:
        radial-gradient(circle at 8% 18%, rgba(107,163,0,0.10), transparent 28%),
        linear-gradient(180deg, #fbf8f1 0%, #f3f7ef 100%);
}

.contact-grid{
    display:grid;
    grid-template-columns:minmax(0, .86fr) minmax(420px, 1fr);
    gap:42px;
    align-items:start;
}

.contact-details{
    position:sticky;
    top:24px;
}

.contact-info-list{
    display:grid;
    gap:14px;
    margin-top:34px;
}

.contact-info-item{
    display:grid;
    grid-template-columns:54px minmax(0, 1fr);
    gap:16px;
    align-items:center;
    padding:18px;
    color:var(--text);
    text-decoration:none;
    border:1px solid rgba(1,35,80,0.08);
    border-radius:8px;
    background:rgba(255,255,255,0.74);
    box-shadow:0 16px 38px rgba(1,35,80,0.06);
}

.contact-info-item i{
    display:grid;
    place-items:center;
    width:54px;
    height:54px;
    color:#fff;
    background:var(--text);
    border-radius:8px;
    font-size:1.1rem;
}

.contact-info-item strong{
    display:block;
    margin-bottom:4px;
    color:var(--text);
    font-size:.92rem;
    text-transform:uppercase;
    letter-spacing:.08em;
}

.contact-info-item span{
    color:var(--muted);
    line-height:1.55;
}

.contact-info-item:hover{
    color:var(--text);
}

.contact-form{
    padding:36px;
    border-radius:8px;
    background:#fff;
    border:1px solid rgba(1,35,80,0.08);
    box-shadow:0 24px 70px rgba(1,35,80,0.12);
}

.contact-form-head{
    margin-bottom:24px;
}

.contact-form-head h2{
    margin:0 0 8px;
    font-size:1.7rem;
    letter-spacing:-.03em;
}

.contact-form-head p{
    margin:0;
    color:var(--muted);
}

.form-row{
    display:grid;
    gap:8px;
    margin-bottom:18px;
}

.form-row label{
    color:var(--text);
    font-size:.92rem;
    font-weight:800;
}

.form-row input,
.form-row textarea{
    width:100%;
    border:1px solid rgba(1,35,80,0.14);
    border-radius:8px;
    padding:14px 16px;
    color:var(--text);
    background:#fbfcfa;
    font:inherit;
    outline:none;
    transition:border-color .2s ease, box-shadow .2s ease, background .2s ease;
}

.form-row textarea{
    resize:vertical;
    min-height:138px;
}

.form-row input:focus,
.form-row textarea:focus{
    border-color:var(--accent);
    background:#fff;
    box-shadow:0 0 0 4px rgba(107,163,0,0.12);
}

.contact-submit{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    gap:12px;
    width:100%;
    min-height:54px;
    padding:14px 22px;
    border:0;
    border-radius:8px;
    color:#fff;
    background:var(--text);
    font-weight:800;
    transition:transform .2s ease, background .2s ease;
}

.contact-submit:hover{
    transform:translateY(-2px);
    background:#001633;
}

.contact-map-section{
    width:100%;
    height:clamp(420px, 46vw, 640px);
    background:#edf3f4;
    border-top:1px solid rgba(1,35,80,0.08);
}

.contact-map-section iframe{
    display:block;
    width:100%;
    height:100%;
    border:0;
    filter:saturate(.92) contrast(.96);
}

/* Media */
.contact-hero.media-hero{
    height:300px;
    padding:40px 0;
    display:flex;
    align-items:center;
    background:
        linear-gradient(90deg, rgba(1,35,80,0.86) 0%, rgba(1,35,80,0.58) 48%, rgba(1,35,80,0.20) 100%),
        url("../img/award.jpg") center / cover no-repeat;
}

.media-section{
    background:
        radial-gradient(circle at 8% 18%, rgba(107,163,0,0.10), transparent 28%),
        linear-gradient(180deg, #fbf8f1 0%, #f3f7ef 100%);
}

.media-head{
    max-width:820px;
    margin:0 auto 42px;
    text-align:center;
}

.media-head .section-lead{
    margin:0 auto;
}

.media-grid{
    display:grid;
    grid-template-columns:repeat(4, minmax(0, 1fr));
    gap:18px;
}

.media-item{
    min-width:0;
}

.media-card{
    display:flex;
    flex-direction:column;
    min-width:0;
    overflow:hidden;
    border-radius:12px;
    background:#fff;
    border:1px solid rgba(1,35,80,0.08);
    box-shadow:0 18px 44px rgba(1,35,80,0.08);
    text-decoration:none;
    transition:transform .28s ease, box-shadow .28s ease, border-color .28s ease;
}

.media-card-image{
    position:relative;
    height:250px;
    overflow:hidden;
    background:#edf3f4;
}

.media-card-title{
    margin:0;
    padding:16px 18px;
    background:#fff;
    border-top:1px solid rgba(1,35,80,0.06);
    font-size:.95rem;
    font-weight:700;
    color:var(--text);
    line-height:1.4;
    text-align:center;
    transition:color .25s ease, background .25s ease;
}

.media-card-wide{
    grid-column:span 2;
}

.media-card-image img{
    width:100%;
    height:100%;
    object-fit:cover;
    transition:transform .35s ease, filter .35s ease;
}

.media-card-image::after{
    content:'';
    position:absolute;
    inset:0;
    background:linear-gradient(180deg, rgba(1,35,80,0) 35%, rgba(1,35,80,0.36) 100%);
    opacity:0;
    transition:opacity .25s ease;
}

.media-card-zoom{
    position:absolute;
    right:16px;
    bottom:16px;
    z-index:1;
    display:grid;
    place-items:center;
    width:44px;
    height:44px;
    color:var(--text);
    background:#fff;
    border-radius:8px;
    box-shadow:0 14px 34px rgba(1,35,80,0.18);
    opacity:0;
    transform:translateY(10px);
    transition:opacity .25s ease, transform .25s ease;
}

.media-card:hover{
    transform:translateY(-6px);
    border-color:rgba(107,163,0,0.22);
    box-shadow:0 28px 64px rgba(1,35,80,0.14);
}

.media-card:hover .media-card-image img{
    transform:scale(1.05);
    filter:saturate(1.05);
}

.media-card:hover .media-card-image::after,
.media-card:hover .media-card-zoom{
    opacity:1;
}

.media-card:hover .media-card-zoom{
    transform:translateY(0);
}

.media-card:hover .media-card-title{
    color:var(--accent);
    background:#fff;
}

/* Team, Event, Download */
.contact-hero.team-hero{
    background-position:center;
    background-size:cover;
    background-repeat:no-repeat;
}

.contact-hero.event-hero{
    background:
        linear-gradient(90deg, rgba(1,35,80,0.86) 0%, rgba(1,35,80,0.58) 48%, rgba(1,35,80,0.20) 100%),
        url("../img/award-2.jpeg") center / cover no-repeat;
}

.contact-hero.download-hero{
    background:
        linear-gradient(90deg, rgba(1,35,80,0.86) 0%, rgba(1,35,80,0.58) 48%, rgba(1,35,80,0.20) 100%),
        url("../img/banner.jpg") center / cover no-repeat;
}

.team-section,
.event-section,
.download-section{
    background:
        radial-gradient(circle at 8% 18%, rgba(107,163,0,0.10), transparent 28%),
        linear-gradient(180deg, #fbf8f1 0%, #f3f7ef 100%);
}

.team-section{
    position:relative;
    padding:80px 0 96px;
    background:
        radial-gradient(circle at 12% 12%, rgba(107,163,0,0.12), transparent 28%),
        radial-gradient(circle at 88% 8%, rgba(1,35,80,0.08), transparent 30%),
        linear-gradient(180deg, #fbf8f1 0%, #eef5ec 100%);
    overflow:hidden;
}

.team-section::before{
    content:none;
}

.team-section .container{
    z-index:1;
}

.team-heading{
    max-width:860px;
    margin:0 auto 44px;
    padding:34px 38px;
    text-align:center;
    background:rgba(255,255,255,0.92);
    border:1px solid rgba(255,255,255,0.85);
    border-radius:8px;
    box-shadow:0 28px 70px rgba(1,35,80,0.12);
}

.team-kicker{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    margin-bottom:12px;
    color:var(--accent);
    font-size:.76rem;
    font-weight:800;
    text-transform:uppercase;
    letter-spacing:.16em;
}

.team-heading h1{
    position:relative;
    display:inline-block;
    margin:0 0 24px;
    color:var(--text);
    font-family:'Cormorant Garamond', serif;
    font-size:3.85rem;
    line-height:.95;
    font-weight:800;
    letter-spacing:0;
}

.team-heading h1::after{
    content:'';
    position:absolute;
    left:50%;
    bottom:-13px;
    width:78px;
    height:2px;
    background:var(--accent);
    transform:translateX(-50%);
}

.team-heading p{
    max-width:620px;
    margin:0 auto;
    color:var(--muted);
    font-size:1rem;
    line-height:1.8;
}

.team-grid{
    display:grid;
    grid-template-columns:repeat(3, minmax(0, 1fr));
    gap:26px;
    max-width:1040px;
    margin:0 auto;
}

.download-grid{
    display:grid;
    grid-template-columns:repeat(4, minmax(0, 1fr));
    gap:18px;
}

.team-card,
.download-card,
.event-card{
    border:1px solid rgba(1,35,80,0.08);
    background:#fff;
    box-shadow:0 18px 44px rgba(1,35,80,0.08);
    overflow:hidden;
}

.team-card{
    position:relative;
    padding:14px;
    border-radius:8px;
    background:rgba(255,255,255,0.95);
    box-shadow:0 24px 58px rgba(1,35,80,0.10);
    transition:transform .25s ease, box-shadow .25s ease;
}

.team-card::after{
    content:'';
    position:absolute;
    left:24px;
    right:24px;
    top:14px;
    height:4px;
    background:var(--accent);
    opacity:0;
    transition:opacity .25s ease;
}

.team-card:hover{
    transform:translateY(-8px);
    box-shadow:0 34px 74px rgba(1,35,80,0.16);
}

.team-card:hover::after{
    opacity:1;
}

.team-photo{
    height:315px;
    background:#edf3f4;
    overflow:hidden;
    border-radius:6px;
}

.team-photo img{
    width:100%;
    height:100%;
    object-fit:cover;
    transition:transform .35s ease, filter .35s ease;
}

.team-card:hover .team-photo img{
    transform:scale(1.04);
    filter:saturate(1.04) contrast(1.02);
}

.team-card-body,
.download-card{
    padding:24px;
}

.team-card-body{
    padding:22px 6px 4px;
    text-align:left;
}

.team-card h2,
.event-card h3,
.download-card h3{
    margin:0 0 10px;
    font-size:1.18rem;
    font-weight:800;
    letter-spacing:-.02em;
}

.team-card h2{
    color:var(--text);
    font-size:1.12rem;
    letter-spacing:0;
}

.team-card p,
.event-card p,
.download-card p{
    margin:0;
    color:var(--muted);
    line-height:1.7;
}

.team-card p{
    color:var(--muted);
    font-size:.86rem;
    line-height:1.55;
}

.team-social{
    display:flex;
    justify-content:center;
    gap:9px;
    margin-top:18px;
}

.team-social a{
    display:grid;
    place-items:center;
    width:30px;
    height:30px;
    color:var(--accent);
    border:1px solid rgba(107,163,0,0.26);
    border-radius:50%;
    background:#f8fbf4;
    font-size:.78rem;
    text-decoration:none;
    transition:color .2s ease, background .2s ease, transform .2s ease;
}

.team-social a:hover{
    color:#fff;
    background:var(--accent);
    transform:translateY(-2px);
}

.event-blog-grid{
    display:grid;
    gap:28px;
}

.event-feature-card,
.event-card{
    background:#fff;
    border:1px solid rgba(1,35,80,0.08);
    border-radius:8px;
    box-shadow:0 24px 60px rgba(1,35,80,0.10);
    overflow:hidden;
}

.event-feature-card{
    display:grid;
    grid-template-columns:minmax(0, 1.08fr) minmax(360px, .92fr);
    align-items:stretch;
}

.event-feature-image,
.event-card-image{
    display:block;
    overflow:hidden;
    background:#edf3f4;
}

.event-feature-image img,
.event-card-image img{
    width:100%;
    height:100%;
    object-fit:cover;
    transition:transform .35s ease, filter .35s ease;
}

.event-feature-image{
    min-height:430px;
}

.event-feature-content{
    display:flex;
    flex-direction:column;
    justify-content:center;
    padding:44px;
}

.event-meta{
    display:flex;
    align-items:center;
    gap:14px;
    margin-bottom:16px;
    color:var(--muted);
    font-size:.82rem;
    font-weight:700;
}

.event-meta span{
    display:inline-flex;
    align-items:center;
    padding:8px 12px;
    color:var(--accent);
    background:rgba(107,163,0,0.10);
    border-radius:999px;
    text-transform:uppercase;
    letter-spacing:.12em;
    font-size:.68rem;
}

.event-feature-card h3,
.event-card h3{
    margin:0 0 14px;
    color:var(--text);
    font-weight:800;
    letter-spacing:-.03em;
}

.event-feature-card h3{
    font-family:'Cormorant Garamond', serif;
    font-size:clamp(2.4rem, 3.2vw, 3.7rem);
    line-height:.98;
}

.event-feature-card h3 a,
.event-card h3 a{
    color:inherit;
    text-decoration:none;
}

.event-feature-card p,
.event-card p{
    margin:0;
    color:var(--muted);
    line-height:1.8;
}

.event-read-more{
    display:inline-flex;
    align-items:center;
    gap:10px;
    width:max-content;
    margin-top:24px;
    color:var(--text);
    font-weight:800;
    text-decoration:none;
}

.event-read-more i{
    color:var(--accent);
    transition:transform .2s ease;
}

.event-read-more:hover{
    color:var(--accent);
}

.event-read-more:hover i{
    transform:translateX(4px);
}

.event-card-grid{
    display:grid;
    grid-template-columns:repeat(3, minmax(0, 1fr));
    gap:24px;
}

.event-card{
    display:flex;
    flex-direction:column;
    transition:transform .25s ease, box-shadow .25s ease;
}

.event-card-image{
    height:240px;
}

.event-card-content{
    display:flex;
    flex:1;
    flex-direction:column;
    padding:26px;
}

.event-card h3{
    font-size:1.3rem;
    line-height:1.2;
}

.event-card .event-read-more{
    margin-top:auto;
    padding-top:22px;
}

.event-feature-card:hover img,
.event-card:hover img{
    transform:scale(1.04);
    filter:saturate(1.04);
}

.event-card:hover{
    transform:translateY(-6px);
    box-shadow:0 32px 72px rgba(1,35,80,0.14);
}

.download-grid{
    grid-template-columns:repeat(3, minmax(0, 1fr));
}

.download-card{
    display:flex;
    flex-direction:column;
    min-height:300px;
}

.download-card > i{
    display:grid;
    place-items:center;
    width:62px;
    height:62px;
    margin-bottom:22px;
    color:#fff;
    background:var(--text);
    border-radius:8px;
    font-size:1.45rem;
}

.download-card a{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    gap:10px;
    min-height:48px;
    margin-top:auto;
    padding:12px 18px;
    color:#fff;
    background:var(--accent);
    border-radius:8px;
    font-weight:800;
    text-decoration:none;
}

.download-card a:hover{
    color:#fff;
    background:#5a8d00;
}

/* About */
.contact-hero.about-hero{
    height:300px;
    padding:40px 0;
    display:flex;
    align-items:center;
    background:
        linear-gradient(90deg, rgba(1,35,80,0.86) 0%, rgba(1,35,80,0.58) 48%, rgba(1,35,80,0.20) 100%),
        url("../img/section 1.png") center / cover no-repeat;
}

.about-story-section{
    background:
        radial-gradient(circle at 8% 18%, rgba(107,163,0,0.10), transparent 28%),
        linear-gradient(180deg, #fbf8f1 0%, #f3f7ef 100%);
}

.about-story-alt{
    background:
        radial-gradient(circle at 86% 18%, rgba(1,35,80,0.08), transparent 30%),
        linear-gradient(180deg, #ffffff 0%, #edf3f4 100%);
}

.about-split{
    display:grid;
    grid-template-columns:minmax(0, .92fr) minmax(420px, 1fr);
    gap:48px;
    align-items:center;
}

.about-split-reverse{
    grid-template-columns:minmax(420px, 1fr) minmax(0, .92fr);
}

.about-split-image{
    overflow:hidden;
    border-radius:8px;
    background:#fff;
    border:1px solid rgba(1,35,80,0.08);
    box-shadow:0 24px 70px rgba(1,35,80,0.12);
}

.about-split-image img{
    width:100%;
    height:520px;
    object-fit:cover;
    transition:transform .35s ease;
}

.about-split-image:hover img{
    transform:scale(1.03);
}

.about-value-list{
    display:grid;
    grid-template-columns:repeat(2, minmax(0, 1fr));
    gap:14px;
    margin-top:34px;
}

.about-value-list div{
    padding:18px;
    border-radius:8px;
    background:rgba(255,255,255,0.78);
    border:1px solid rgba(1,35,80,0.08);
    box-shadow:0 16px 38px rgba(1,35,80,0.06);
}

.about-value-list strong{
    display:block;
    margin-bottom:6px;
    color:var(--text);
    font-size:1rem;
}

.about-value-list span{
    display:block;
    color:var(--muted);
    line-height:1.6;
}

.about-gallery-section{
    background:
        radial-gradient(circle at 12% 0%, rgba(107,163,0,0.10), transparent 32%),
        linear-gradient(180deg, #fbf8f1 0%, #f4efe5 100%);
}

.about-gallery-grid{
    display:grid;
    grid-template-columns:repeat(4, minmax(0, 1fr));
    grid-auto-rows:260px;
    gap:18px;
}

.about-gallery-item{
    display:block;
    overflow:hidden;
    border-radius:8px;
    background:#fff;
    border:1px solid rgba(1,35,80,0.08);
    box-shadow:0 18px 44px rgba(1,35,80,0.08);
    text-decoration:none;
}

.about-gallery-item img{
    width:100%;
    height:100%;
    object-fit:cover;
    transition:transform .35s ease;
}

.about-gallery-item:hover img{
    transform:scale(1.04);
}

.about-gallery-item:focus-visible{
    outline:3px solid rgba(107,163,0,0.35);
    outline-offset:4px;
}

/* Let's Talk */
.lets-talk-section{
    position:relative;
    min-height:560px;
    overflow:hidden;
    background-color:#006f72;
}

.lets-talk-image{
    position:absolute;
    inset:0;
    width:100%;
    height:100%;
    object-fit:cover;
    object-position:center center;
}

.lets-talk-section::before{
    content:'';
    position:absolute;
    inset:auto auto -190px -160px;
    width:520px;
    height:520px;
    border-radius:50%;
    border:74px solid rgba(255,255,255,0.055);
    pointer-events:none;
}

.lets-talk-section::after{
    content:'';
    position:absolute;
    left:12%;
    right:12%;
    bottom:74px;
    height:1px;
    background:linear-gradient(90deg, rgba(255,255,255,0.22), rgba(244,216,0,0.9), rgba(255,255,255,0));
    pointer-events:none;
}

.lets-talk-overlay{
    position:relative;
    min-height:560px;
    display:flex;
    align-items:center;
    padding:58px 0 76px;
    background:
        radial-gradient(circle at 16% 32%, rgba(107,163,0,0.12), transparent 30%),
        linear-gradient(90deg, rgba(1,35,80,0.66) 0%, rgba(0,118,116,0.50) 48%, rgba(0,118,116,0.16) 100%),
        linear-gradient(90deg, rgba(0,150,148,0.05), rgba(1,35,80,0.06));
}

.lets-talk-content{
    position:relative;
    z-index:1;
    display:flex;
    flex-direction:column;
    align-items:center;
    justify-content:center;
    gap:34px;
    width:100%;
    text-align:center;
}

.lets-talk-content h2{
    margin:0;
    color:#fff;
    font-family:'Inter', sans-serif;
    max-width:1120px;
    font-size:clamp(2.75rem, 5vw, 5.6rem);
    line-height:1.05;
    font-weight:500;
    letter-spacing:0;
    text-wrap:balance;
    text-shadow:0 18px 48px rgba(0,0,0,0.18);
}

.lets-talk-content h2 span{
    color:#f4d800;
}

.lets-talk-btn{
    display:inline-grid;
    grid-template-columns:auto 54px;
    align-items:center;
    width:max-content;
    min-height:54px;
    border:1px solid rgba(255,255,255,0.72);
    color:#fff;
    text-decoration:none;
    font-weight:800;
    font-size:.88rem;
    background:rgba(255,255,255,0.08);
    box-shadow:0 18px 44px rgba(0,0,0,0.12);
    backdrop-filter:blur(8px);
    -webkit-backdrop-filter:blur(8px);
    transition:transform .2s ease, border-color .2s ease, background .2s ease;
}

.lets-talk-btn span{
    padding:0 22px;
}

.lets-talk-btn i{
    display:grid;
    place-items:center;
    height:54px;
    color:#009694;
    background:#fff;
}

.lets-talk-btn:hover{
    color:#fff;
    border-color:#fff;
    background:rgba(255,255,255,0.14);
    transform:translateY(-2px);
}

/* Footer */
.site-footer{
    position:relative;
    min-height:auto;
    padding:44px 0 42px;
    color:#fff;
    background:
        radial-gradient(circle at 12% 0%, rgba(107,163,0,0.34), transparent 34%),
        linear-gradient(135deg, var(--text) 0%, #001633 100%);
    overflow:hidden;
}

.footer-head{
    display:flex;
    align-items:flex-start;
    justify-content:space-between;
    gap:30px;
    max-width:1620px;
    margin:0 auto 34px;
}

.footer-logo{
    display:inline-flex;
    align-items:center;
    width:min(300px, 50vw);
    text-decoration:none;
}

.footer-logo img{
    width:100%;
    height:auto;
    filter:brightness(0) invert(1);
}

.footer-social{
    display:flex;
    align-items:center;
    gap:22px;
    padding-top:6px;
}

.footer-social a{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    width:30px;
    height:30px;
    color:#fff;
    text-decoration:none;
    font-size:1.45rem;
    transition:opacity .2s ease, transform .2s ease;
}

.footer-social a:hover{
    color:#fff;
    opacity:.78;
    transform:translateY(-2px);
}

.footer-links-grid{
    display:grid;
    grid-template-columns:1.1fr 1.1fr 1.1fr 1.25fr 1.1fr 1.1fr;
    gap:34px;
    max-width:1620px;
    margin:0 auto;
}

.footer-link-group h4{
    margin:0 0 14px;
    font-family:'Inter', sans-serif;
    font-size:1rem;
    font-weight:800;
    line-height:1.3;
}

.footer-link-group ul{
    padding:0;
    margin:0;
    list-style:none;
}

.footer-link-group li{
    margin-bottom:8px;
}

.footer-link-group a{
    color:#fff;
    font-size:.98rem;
    line-height:1.35;
    font-weight:500;
    text-decoration:none;
    transition:opacity .2s ease;
}

.footer-link-group a:hover{
    color:#fff;
    opacity:.75;
}

/* Responsive */
@media (max-width: 1199px){
    .hero{
        padding:0 0 56px;
    }

    .hero-grid{
        min-height:0;
    }

    .hero-copy{
        margin-left:clamp(24px, 6vw, 72px);
    }

    .site-footer{
        min-height:auto;
    }

    .footer-links-grid{
        grid-template-columns:repeat(3, minmax(0, 1fr));
        gap:28px 36px;
        padding-right:92px;
    }

    .lets-talk-content{
        gap:32px;
    }

    .header-menu{
        gap:8px 12px;
    }

    .header-menu .nav-link{
        padding-left:8px !important;
        padding-right:8px !important;
        font-size:1.08rem;
    }
}

@media (max-width: 991px){
    .section{
        padding:84px 0;
    }

    .process-showcase-copy{
        width:min(64%, 620px);
    }

    .innovation-section{
        padding-top:84px;
        padding-bottom:0;
    }

    .innovation-panel{
        grid-template-columns:1fr;
        padding:40px;
    }

    .green-solutions-grid{
        grid-template-columns:1fr;
    }

    .awards-grid{
        grid-template-columns:1fr;
    }

    .green-solution-card{
        min-height:auto;
    }

    .header-top-grid{
        grid-template-columns:1fr;
        justify-items:start;
        gap:0px;
    }

    .award-marquee{
        width:100%;
    }

    .header-actions{
        flex-wrap:wrap;
        gap:16px;
    }

    .header-actions a{
        font-size:.95rem;
    }

    .header-nav .navbar{
        min-height:auto;
        padding:10px 0;
    }

    .header-menu{
        gap:0;
        padding-top:10px;
        width:100%;
    }

    .header-menu .nav-link{
        padding:12px 0 !important;
        font-size:1.00rem;
    }

    .header-menu .nav-link::after{
        left:0;
        right:auto;
        width:72px;
    }

    .header-menu .menu-item,
    .header-menu .nav-item{
        width:100%;
        display:block;
    }

    .header-menu .menu-item-has-children,
    .header-menu .nav-item.dropdown{
        width:100%;
    }

    .header-menu .sub-menu,
    .header-menu .dropdown-menu{
        position:static;
        width:100%;
        min-width:100%;
        opacity:1;
        visibility:visible;
        transform:none;
        display:none;
        padding:10px 15px;
        margin-top:10px;
        border-radius:10px;
        box-shadow:none;
        background:#f7f7f7;
    }

    .header-menu .menu-item-has-children:hover > .sub-menu,
    .header-menu .nav-item.dropdown:hover > .dropdown-menu,
    .header-menu .nav-item.dropdown > .dropdown-menu.show{
        display:block;
    }

    .header-menu .sub-menu li a,
    .header-menu .dropdown-menu li a{
        padding:10px 0;
        display:block;
        width:100%;
    }

    .metrics-grid,
    .mini-grid{
        grid-template-columns:1fr 1fr;
    }

    .footer-head{
        margin-bottom:28px;
    }

    .footer-links-grid{
        grid-template-columns:repeat(2, minmax(0, 1fr));
        gap:24px 32px;
        padding-right:0;
    }

    .lets-talk-section,
    .lets-talk-overlay{
        min-height:460px;
    }

    .lets-talk-content{
        gap:30px;
    }

    .contact-grid{
        grid-template-columns:1fr;
    }

    .contact-details{
        position:relative;
        top:auto;
    }

    .media-grid{
        grid-template-columns:repeat(2, minmax(0, 1fr));
    }

    .team-grid{
        grid-template-columns:repeat(2, minmax(0, 1fr));
    }

    .download-grid{
        grid-template-columns:1fr;
    }

    .event-card{
        grid-template-columns:240px minmax(0, 1fr);
    }

    .event-feature-card{
        grid-template-columns:1fr;
    }

    .event-feature-image{
        min-height:360px;
    }

    .event-feature-content{
        padding:34px;
    }

    .event-card-grid{
        grid-template-columns:repeat(2, minmax(0, 1fr));
    }

    .about-split,
    .about-split-reverse{
        grid-template-columns:1fr;
    }

    .about-split-image img{
        height:440px;
    }

    .about-gallery-grid{
        grid-template-columns:repeat(2, minmax(0, 1fr));
    }

    .lets-talk-section::after{
        left:24px;
        right:24px;
        bottom:54px;
    }

}

@media (max-width: 767px){
    .section{
        padding:70px 0;
    }

    .process-showcase-section{
        padding:0;
    }

    .process-showcase-image{
        height:790px;
        object-position:center bottom;
    }

    .process-showcase-copy{
        top:70px;
        transform:none;
        width:100%;
    }
.contact-info-item span {
    color: var(--muted);
    line-height: 1.55;
    font-size: 14px !important;
}
    .innovation-section{
        padding-top:70px;
        padding-bottom:0;
    }

    .innovation-panel{
        padding:28px 22px;
        gap:30px;
    }

    .innovation-point{
        grid-template-columns:1fr;
    }

    .operation-section{
        padding-top:70px;
    }

    .operation-head{
        margin-bottom:28px;
        text-align:left;
    }

    .operation-map{
        height:auto;
        min-height:0;
    }

    .operation-map img{
        height:auto;
        min-height:0;
        object-fit:contain;
    }

    .operation-map-caption{
        bottom:20px;
        justify-content:center;
        width:calc(100% - 32px);
    }

    .green-solutions{
        padding-top:70px;
        min-height:auto;
        background-position:center top;
    }

    .green-solutions-content{
        width:100%;
        max-width:none;
    }

    .green-solutions-head{
        margin-bottom:30px;
        text-align:left;
    }

    .green-solution-card{
        padding:24px;
        grid-template-columns:52px minmax(0, 1fr);
        gap:18px;
    }

    .awards-head{
        margin-bottom:30px;
        text-align:left;
    }

    .award-showcase-card{
        padding:0;
    }

    .award-showcase-card img{
        height:260px;
    }

    .award-showcase-copy{
        padding:22px;
    }

    .hero{
        padding:0 0 0px;
    }

    .hero-grid{
        min-height:0;
    }

    .section-shell{
        padding:24px;
    }

    .hero-copy{
        width:min(100%, calc(100% - 28px));
        margin-left:14px;
        padding:0 12px;
    }

    .award-card{
        justify-content:flex-start;
        border-right:none;
    }

    .header-awards{
        /* Keep the three award items in one row on mobile. */
        grid-template-columns:repeat(3, minmax(0, 1fr));
    }

    .header-awards .award-card{
        justify-content:flex-start;
    }

    .award-text strong,
    .award-text span{
        white-space:normal;
    }

    .header-actions{
        gap:14px;
        font-size:.98rem;
    }

    .metrics-grid,
    .mini-grid{
        grid-template-columns:1fr;
    }

    .hero-copy h1{
        font-size:clamp(3rem, 13vw, 4.6rem);
    }

    .hero-copy p{
        font-size:1rem;
        line-height:1.7;
    }

    .contact-hero{
        height:300px;
        padding:36px 0;
    }

    .contact-hero h1{
        font-size:clamp(2.5rem, 12vw, 3.8rem);
    }

    .contact-grid{
        gap:28px;
    }

    .contact-form{
        padding:24px 20px;
    }

    .contact-info-item{
        grid-template-columns:48px minmax(0, 1fr);
        padding:16px;
    }

    .contact-info-item i{
        width:48px;
        height:48px;
    }

    .contact-map-section{
        height:420px;
    }

    .media-head{
        margin-bottom:30px;
        text-align:left;
    }

    .media-head .section-lead{
        margin:0;
    }

    .media-grid{
        grid-template-columns:1fr;
        gap:14px;
    }

    .media-card-image{
        height:220px;
    }

    .media-card-title{
        padding:14px 16px;
        font-size:.9rem;
    }

    .media-card-wide{
        grid-column:auto;
    }

    .media-card-zoom{
        opacity:1;
        transform:none;
    }

    .team-grid,
    .download-grid{
        grid-template-columns:1fr;
        gap:14px;
    }

    .team-photo{
        height:240px;
    }

    .event-card{
        grid-template-columns:1fr;
    }

    .event-card-grid{
        grid-template-columns:1fr;
        gap:16px;
    }

    .event-feature-image{
        min-height:260px;
    }

    .event-feature-content,
    .event-card-content{
        padding:22px;
    }

    .event-meta{
        align-items:flex-start;
        flex-direction:column;
        gap:8px;
    }

    .event-card img{
        height:240px;
    }

    .event-card div{
        padding:22px;
    }

    .download-card{
        min-height:0;
    }

    .about-split{
        gap:28px;
    }

    .about-split-image img{
        height:320px;
    }

    .about-value-list{
        grid-template-columns:1fr;
        margin-top:26px;
    }

    .about-gallery-grid{
        grid-template-columns:1fr;
        grid-auto-rows:240px;
        gap:14px;
    }

    .lets-talk-section{
        background-color:#006f72;
    }

    .lets-talk-image{
        object-position:center center;
    }

    .lets-talk-overlay{
        background:
            radial-gradient(circle at 16% 32%, rgba(107,163,0,0.12), transparent 30%),
            linear-gradient(90deg, rgba(1,35,80,0.72) 0%, rgba(0,132,129,0.50) 100%);
    }

    .lets-talk-section,
    .lets-talk-overlay{
        min-height:420px;
    }

    .lets-talk-content h2{
        font-size:clamp(2.2rem, 11vw, 3.6rem);
        line-height:1.08;
    }

    .lets-talk-section::before{
        width:340px;
        height:340px;
        border-width:48px;
    }

    .site-footer{
        padding:36px 0 40px;
    }

    .footer-head{
        flex-direction:column;
        gap:20px;
        margin-bottom:30px;
    }

    .footer-social{
        gap:24px;
        padding-top:0;
    }

    .footer-links-grid{
        grid-template-columns:1fr;
        gap:20px;
    }

    .footer-link-group h4{
        margin-bottom:14px;
    }

    .footer-link-group li{
        margin-bottom:9px;
    }

    .footer-link-group a{
        font-size:1.02rem;
    }

}
.fancybox__container{
    z-index: 999999 !important;
}

.fancybox__content{
    padding: 0 !important;
}

.fancybox__content img{
    width: auto !important;
    max-width: 90vw !important;
    max-height: 90vh !important;
    height: auto !important;
    object-fit: contain;
}

.fancybox__toolbar{
    opacity: 1 !important;
    visibility: visible !important;
}

.fancybox__button{
    display: flex !important;
}
.bio-cng .about-gallery-grid {
    display: grid;
    grid-template-columns: 1fr;
    grid-auto-rows: auto !important;
    gap: 18px;
}
.bio-cng  .about-gallery-item img {
    width: 260px;
    height: 260px;
    object-fit: cover;
    transition: transform .35s ease;
}

.bio-cng  .gallery-content{
	padding:15px;
}

.team-grid{
    display:flex;
    flex-direction:column;
    gap:30px;
}

.team-card{
    display:flex;
    align-items:center;
    gap:40px;
    background:#fff;
    border-radius:20px;
    padding:30px;
    box-shadow:0 10px 30px rgba(0,0,0,.08);
    overflow:hidden;
    transition:.3s ease;
}

.team-card:hover{
    transform:translateY(-5px);
}

.team-photo{
    flex:0 0 300px;
}

.team-photo img{
    width:100%;
    height:320px;
    object-fit:cover;
    border-radius:15px;
    display:block;
}

.team-card-body{
    flex:1;
}

.team-card-body h2{
    font-size:32px;
    font-weight:700;
    margin-bottom:10px;
    color:#111;
}

.team-card-body p{
    font-size:18px;
    color:#666;
    margin-bottom:25px;
}

.team-social{
    display:flex;
    gap:12px;
}

.team-social a{
    width:45px;
    height:45px;
    display:flex;
    align-items:center;
    justify-content:center;
    border-radius:50%;
    background:#f5f5f5;
    color:#111;
    text-decoration:none;
    transition:.3s;
}

.team-social a:hover{
    background:#0d6efd;
    color:#fff;
}

@media (max-width:991px){

    .team-card{
        flex-direction:column;
        text-align:center;
        gap:25px;
    }

    .team-photo{
        flex:0 0 auto;
        width:100%;
        max-width:350px;
        margin:auto;
    }

    .team-social{
        justify-content:center;
    }
}
.header-menu .sub-menu-dropdown .nav-link {
    position: relative;
    padding: 12px !important;
    font-family: 'Inter', sans-serif;
    font-size: 1.00rem;
    line-height: 1;
    font-weight: 500;
    color: #1b1b1b !important;
    letter-spacing: -.02em;
    border-radius: 14px 14px 0 0;
    transition: color .2s ease, background-color .2s ease, transform .2s ease;
}

/* About Us redesign */
.about-us-hero{
    position:relative;
    overflow:hidden;
    padding:86px 0 78px;
    background:
        linear-gradient(90deg, rgba(1,35,80,0.94) 0%, rgba(1,35,80,0.78) 52%, rgba(0,111,114,0.50) 100%),
        url("../img/banner.jpg") center / cover no-repeat;
    color:#fff;
}

.about-us-hero::after{
    content:'';
    position:absolute;
    inset:auto -10% -42% 42%;
    height:360px;
    border:70px solid rgba(107,163,0,0.18);
    border-radius:50%;
    pointer-events:none;
}

.about-us-hero-grid{
    display:grid;
    grid-template-columns:minmax(0, .95fr) minmax(380px, .82fr);
    gap:56px;
    align-items:center;
}

.about-us-hero-copy{
    position:relative;
    z-index:1;
}

.about-us-hero-copy .eyebrow{
    color:#d9ff8a;
    background:rgba(255,255,255,0.12);
    border-color:rgba(255,255,255,0.22);
}

.about-us-hero-copy .eyebrow::before{
    background:#d9ff8a;
    box-shadow:0 0 0 6px rgba(217,255,138,0.16);
}

.about-us-hero h1{
    max-width:760px;
    margin:20px 0 18px;
    font-family:'Cormorant Garamond', serif;
    font-size:clamp(3rem, 5.5vw, 5.8rem);
    line-height:.94;
    letter-spacing:-.03em;
}

.about-us-hero p{
    max-width:650px;
    margin:0;
    color:rgba(255,255,255,0.84);
    font-size:1.12rem;
    line-height:1.85;
}

.about-us-hero-actions{
    display:flex;
    flex-wrap:wrap;
    gap:14px;
    margin-top:32px;
}

.about-us-hero-media{
    position:relative;
    z-index:1;
    overflow:hidden;
    min-height:420px;
    border:1px solid rgba(255,255,255,0.24);
    border-radius:8px;
    background:rgba(255,255,255,0.12);
    box-shadow:0 28px 70px rgba(0,0,0,0.26);
}

.about-us-hero-media img{
    width:100%;
    height:100%;
    min-height:420px;
    object-fit:cover;
}

.about-us-hero-badge{
    position:absolute;
    left:18px;
    right:18px;
    bottom:18px;
    padding:16px 18px;
    border-radius:8px;
    background:rgba(255,255,255,0.92);
    color:var(--text);
    box-shadow:0 18px 36px rgba(0,0,0,0.20);
}

.about-us-hero-badge strong,
.about-us-hero-badge span{
    display:block;
}

.about-us-hero-badge strong{
    font-size:1.05rem;
    margin-bottom:4px;
}

.about-us-hero-badge span{
    color:var(--muted);
    line-height:1.45;
}

.about-us-intro{
    background:
        radial-gradient(circle at 12% 8%, rgba(107,163,0,0.12), transparent 30%),
        linear-gradient(180deg, #fbf8f1 0%, #f5f8ef 100%);
}

.about-us-intro-grid{
    display:grid;
    grid-template-columns:minmax(0, 1fr) minmax(300px, 380px);
    gap:46px;
    align-items:start;
}

.about-us-copy p{
    color:var(--muted);
    font-size:1.02rem;
    line-height:1.9;
    margin:0 0 18px;
}

.about-us-copy p:last-child{
    margin-bottom:0;
}

.about-us-stats{
    display:grid;
    gap:14px;
}

.about-us-stats div{
    padding:24px;
    border:1px solid rgba(1,35,80,0.09);
    border-radius:8px;
    background:#fff;
    box-shadow:0 16px 42px rgba(1,35,80,0.08);
}

.about-us-stats strong{
    display:block;
    color:var(--accent);
    font-family:'Cormorant Garamond', serif;
    font-size:3rem;
    line-height:1;
    margin-bottom:8px;
}

.about-us-stats span{
    display:block;
    color:var(--muted);
    line-height:1.55;
}

.about-us-platform{
    background:
        radial-gradient(circle at 88% 14%, rgba(1,35,80,0.08), transparent 32%),
        linear-gradient(180deg, #ffffff 0%, #eef5f4 100%);
}

.about-us-platform-grid{
    display:grid;
    grid-template-columns:minmax(360px, .86fr) minmax(0, 1fr);
    gap:50px;
    align-items:center;
}

.about-us-platform-image{
    overflow:hidden;
    border:1px solid rgba(1,35,80,0.08);
    border-radius:8px;
    background:#fff;
    box-shadow:0 24px 70px rgba(1,35,80,0.12);
}

.about-us-platform-image img{
    width:100%;
    height:620px;
    object-fit:cover;
}

.about-us-value-grid{
    display:grid;
    grid-template-columns:repeat(2, minmax(0, 1fr));
    gap:14px;
    margin-top:30px;
}

.about-us-value-grid div{
    padding:20px;
    border:1px solid rgba(1,35,80,0.08);
    border-radius:8px;
    background:rgba(255,255,255,0.82);
}

.about-us-value-grid i{
    width:38px;
    height:38px;
    display:inline-flex;
    align-items:center;
    justify-content:center;
    margin-bottom:14px;
    border-radius:50%;
    background:rgba(107,163,0,0.12);
    color:var(--accent);
}

.about-us-value-grid strong,
.about-us-value-grid span{
    display:block;
}

.about-us-value-grid strong{
    margin-bottom:6px;
    color:var(--text);
}

.about-us-value-grid span{
    color:var(--muted);
    line-height:1.6;
    font-size:.95rem;
}

.about-us-awards{
    position:relative;
    overflow:hidden;
    background:
        radial-gradient(circle at 10% 0%, rgba(107,163,0,0.14), transparent 30%),
        radial-gradient(circle at 92% 18%, rgba(1,35,80,0.08), transparent 28%),
        linear-gradient(180deg, #fbf8f1 0%, #f4efe5 100%);
}

.about-us-awards::before{
    content:'';
    position:absolute;
    left:-160px;
    top:-180px;
    width:420px;
    height:420px;
    border:70px solid rgba(107,163,0,0.08);
    border-radius:50%;
    pointer-events:none;
}

.about-us-awards .container{
    z-index:1;
}

.about-us-awards .media-head{
    max-width:820px;
    margin:0 auto 44px;
    text-align:center;
}

.about-us-awards .section-lead{
    max-width:650px;
    margin:0 auto;
}

.about-us-achievement-list{
    display:grid;
    grid-template-columns:repeat(3, minmax(0, 1fr));
    gap:22px;
    padding:0;
    margin:0;
    list-style:none;
    counter-reset:achievement;
}

.about-us-achievement-list li{
    position:relative;
    min-height:100%;
    padding:30px 28px 28px;
    overflow:hidden;
    border:1px solid rgba(1,35,80,0.08);
    border-radius:18px;
    background:rgba(255,255,255,0.88);
    box-shadow:0 22px 62px rgba(1,35,80,0.10);
    counter-increment:achievement;
    transition:transform .25s ease, box-shadow .25s ease, border-color .25s ease;
}

.about-us-achievement-list li::after{
    content:'0' counter(achievement);
    position:absolute;
    right:20px;
    top:18px;
    color:rgba(1,35,80,0.07);
    font-family:'Cormorant Garamond', serif;
    font-size:4rem;
    font-weight:700;
    line-height:1;
}

.about-us-achievement-list li:hover{
    transform:translateY(-6px);
    border-color:rgba(107,163,0,0.22);
    box-shadow:0 30px 78px rgba(1,35,80,0.16);
}

.about-us-achievement-icon{
    position:relative;
    z-index:1;
    display:grid;
    place-items:center;
    width:58px;
    height:58px;
    margin-bottom:24px;
    border-radius:16px;
    color:#fff;
    background:linear-gradient(135deg, var(--accent) 0%, #008c72 100%);
    box-shadow:0 16px 34px rgba(107,163,0,0.24);
    font-size:1.35rem;
}

.about-us-achievement-list div{
    position:relative;
    z-index:1;
}

.about-us-achievement-list strong{
    display:block;
    margin:0 0 12px;
    color:var(--text);
    font-size:1.18rem;
    line-height:1.3;
    font-weight:800;
}

.about-us-achievement-list p{
    margin:0;
    color:var(--muted);
    font-size:1rem;
    line-height:1.75;
}

.about-us-achievement-list a{
    color:var(--text);
    font-weight:700;
    text-decoration-thickness:1px;
    text-underline-offset:4px;
}

.about-us-achievement-list a:hover{
    color:var(--accent);
}

.about-us-award-grid{
    display:grid;
    grid-template-columns:repeat(3, minmax(0, 1fr));
    gap:18px;
}

.about-us-award-card{
    min-height:100%;
    overflow:hidden;
    border:1px solid rgba(1,35,80,0.08);
    border-radius:8px;
    background:#fff;
    box-shadow:0 18px 46px rgba(1,35,80,0.09);
}

.about-us-award-card img{
    width:100%;
    height:150px;
    padding:22px;
    object-fit:contain;
    background:#fff;
    border-bottom:1px solid rgba(1,35,80,0.08);
}

.about-us-award-card div{
    padding:22px;
}

.about-us-award-card h3{
    margin:0 0 10px;
    color:var(--text);
    font-size:1.12rem;
    font-weight:800;
}

.about-us-award-card p{
    margin:0;
    color:var(--muted);
    line-height:1.7;
}

.about-us-patent-note{
    display:flex;
    gap:18px;
    align-items:flex-start;
    margin-top:24px;
    padding:24px;
    border:1px solid rgba(107,163,0,0.22);
    border-radius:8px;
    background:#fff;
    box-shadow:0 18px 46px rgba(1,35,80,0.08);
}

.about-us-patent-note i{
    flex:0 0 auto;
    width:44px;
    height:44px;
    display:inline-flex;
    align-items:center;
    justify-content:center;
    border-radius:50%;
    background:rgba(107,163,0,0.13);
    color:var(--accent);
}

.about-us-patent-note p{
    margin:0;
    color:var(--muted);
    line-height:1.75;
}

.about-us-mission-vision{
    position:relative;
    overflow:hidden;
    background:
        radial-gradient(circle at 12% 8%, rgba(107,163,0,0.14), transparent 30%),
        radial-gradient(circle at 88% 20%, rgba(1,35,80,0.10), transparent 32%),
        linear-gradient(180deg, #ffffff 0%, #eef5f4 100%);
}

.about-us-mission-vision::before{
    content:'';
    position:absolute;
    inset:auto -140px -210px auto;
    width:430px;
    height:430px;
    border:70px solid rgba(107,163,0,0.10);
    border-radius:50%;
    pointer-events:none;
}

.about-us-mv-head{
    max-width:860px;
    margin:0 auto 42px;
    text-align:center;
}

.about-us-mv-head .section-lead{
    margin:0 auto;
}

.about-us-mv-grid{
    display:grid;
    grid-template-columns:repeat(2, minmax(0, 1fr));
    gap:28px;
}

.about-us-mv-card{
    position:relative;
    display:grid;
    grid-template-rows:260px minmax(0, 1fr);
    min-height:100%;
    overflow:hidden;
    border:1px solid rgba(1,35,80,0.09);
    border-radius:18px;
    background:#fff;
    box-shadow:0 24px 70px rgba(1,35,80,0.12);
    isolation:isolate;
    transition:transform .28s ease, box-shadow .28s ease;
}

.about-us-mv-card:hover{
    transform:translateY(-6px);
    box-shadow:0 30px 86px rgba(1,35,80,0.18);
}

.about-us-mv-image{
    position:relative;
    overflow:hidden;
    background:#0f2435;
}

.about-us-mv-image::after{
    content:'';
    position:absolute;
    inset:0;
    background:
        linear-gradient(180deg, rgba(1,35,80,0.02) 0%, rgba(1,35,80,0.54) 100%),
        linear-gradient(90deg, rgba(107,163,0,0.18), rgba(0,0,0,0));
}
.about-gallery-section.section.bio-cng .about-gallery-item {
    display: flex;
    overflow: hidden;
    border-radius: 8px;
    background: #fff;
    border: 1px solid rgba(1, 35, 80, 0.08);
    box-shadow: 0 18px 44px rgba(1, 35, 80, 0.08);
    text-decoration: none;
}
.about-us-mv-card img{
    width:100%;
    height:100%;
    object-fit:cover;
    transform:scale(1.01);
    transition:transform .45s ease;
}

.about-us-mv-card:hover img{
    transform:scale(1.06);
}

.about-us-mv-copy{
    position:relative;
    display:flex;
    flex-direction:column;
    justify-content:flex-start;
    min-height:330px;
    padding:42px 38px 38px;
}

.about-us-mv-copy::before{
    content:'';
    position:absolute;
    left:38px;
    top:0;
    width:92px;
    height:5px;
    border-radius:999px;
    background:linear-gradient(90deg, var(--accent), rgba(107,163,0,0));
}

.about-us-mv-icon{
    position:absolute;
    top:-38px;
    right:34px;
    z-index:2;
    display:grid;
    place-items:center;
    width:76px;
    height:76px;
    border:7px solid #fff;
    border-radius:18px;
    color:#fff;
    background:linear-gradient(135deg, var(--accent) 0%, #008c72 100%);
    box-shadow:0 18px 36px rgba(1,35,80,0.20);
    font-size:1.7rem;
}

.about-us-mv-copy .eyebrow{
    align-self:flex-start;
    padding:9px 14px;
    color:var(--accent);
    background:rgba(107,163,0,0.08);
}

.about-us-mv-card h2{
    margin:20px 0 16px;
    font-family:'Cormorant Garamond', serif;
    font-size:clamp(2.15rem, 3vw, 3.2rem);
    line-height:1.02;
    letter-spacing:-.02em;
}

.about-us-mv-card p{
    margin:0;
    color:var(--muted);
    font-size:1.02rem;
    line-height:1.78;
}

@media (max-width:1199px){
    .about-us-hero-grid,
    .about-us-intro-grid,
    .about-us-platform-grid{
        gap:34px;
    }

    .about-us-mv-card{
        grid-template-rows:240px minmax(0, 1fr);
    }
}

@media (max-width:991px){
    .about-us-hero-grid,
    .about-us-intro-grid,
    .about-us-platform-grid,
    .about-us-mv-grid{
        grid-template-columns:1fr;
    }

    .about-us-hero{
        padding:68px 0;
    }

    .about-us-hero-media,
    .about-us-hero-media img{
        min-height:360px;
    }

    .about-us-platform-image img{
        height:460px;
    }

    .about-us-award-grid{
        grid-template-columns:1fr;
    }

    .about-us-achievement-list{
        grid-template-columns:1fr;
    }

    .about-us-mv-card{
        grid-template-rows:280px minmax(0, 1fr);
    }
}

@media (max-width:575px){
    .about-us-hero{
        padding:54px 0;
    }

    .about-us-hero-actions{
        flex-direction:column;
        align-items:stretch;
    }

    .about-us-hero-actions .btn-elegant{
        justify-content:center;
    }

    .about-us-hero-media,
    .about-us-hero-media img{
        min-height:300px;
    }

    .about-us-platform-image img{
        height:320px;
    }

    .about-us-value-grid{
        grid-template-columns:1fr;
    }

    .about-us-awards .media-head{
        margin-bottom:30px;
        text-align:left;
    }

    .about-us-awards .section-lead{
        margin:0;
    }

    .about-us-achievement-list li{
        padding:24px 22px;
        border-radius:14px;
    }

    .about-us-achievement-list li::after{
        right:16px;
        top:14px;
        font-size:3.2rem;
    }

    .about-us-achievement-icon{
        width:52px;
        height:52px;
        margin-bottom:18px;
        border-radius:14px;
        font-size:1.15rem;
    }

    .about-us-mv-head{
        margin-bottom:30px;
        text-align:left;
    }

    .about-us-mv-head .section-lead{
        margin:0;
    }

    .about-us-mv-card{
        grid-template-rows:220px minmax(0, 1fr);
        border-radius:14px;
    }

    .about-us-mv-copy{
        min-height:0;
        padding:34px 24px 28px;
    }

    .about-us-mv-copy::before{
        left:24px;
    }

    .about-us-mv-icon{
        top:-32px;
        right:22px;
        width:64px;
        height:64px;
        border-width:6px;
        border-radius:16px;
        font-size:1.35rem;
    }

    .about-us-patent-note{
        flex-direction:column;
    }
}

/* Reference footer layout */
.site-footer{
    padding:78px 0 30px;
    color:#fff;
    background:#101c31;
    overflow:hidden;
}

.site-footer .container-fluid{
    max-width:1700px;
}

.footer-main-grid{
    display:grid;
    grid-template-columns:minmax(300px, 1.28fr) minmax(190px, .72fr) minmax(300px, 1fr) minmax(320px, .95fr);
    gap:72px;
    align-items:start;
    max-width:1620px;
    margin:0 auto;
}

.footer-about{
    max-width:520px;
}

.footer-logo{
    display:inline-flex;
    align-items:center;
    width:220px;
    margin-bottom:34px;
    text-decoration:none;
}

.footer-logo img{
    width:100%;
    height:auto;
    filter:brightness(0) invert(1);
}

.footer-about p{
    margin:0;
    color:#fff;
    font-size:1.18rem;
    line-height:1.72;
}

.footer-social{
    display:flex;
    flex-wrap:wrap;
    align-items:center;
    gap:14px;
    margin-top:40px;
    padding-top:0;
}

.footer-social a{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    width:56px;
    height:56px;
    border:1px solid rgba(255,255,255,0.13);
    border-radius:14px;
    color:#fff;
    background:rgba(255,255,255,0.09);
    text-decoration:none;
    font-size:1.35rem;
    transition:background .2s ease, border-color .2s ease, transform .2s ease;
}

.footer-social a:hover{
    color:#fff;
    border-color:rgba(107,163,0,0.65);
    background:rgba(107,163,0,0.22);
    opacity:1;
    transform:translateY(-2px);
}

.footer-link-group h4,
.footer-contact h4{
    position:relative;
    margin:0 0 46px;
    color:#f3b10a;
    font-family:'Inter', sans-serif;
    font-size:1.42rem;
    font-weight:800;
    line-height:1.2;
}

.footer-link-group h4::after,
.footer-contact h4::after{
    content:'';
    position:absolute;
    left:0;
    bottom:-22px;
    width:62px;
    height:3px;
    border-radius:999px;
    background:linear-gradient(90deg, #f3b10a 0%, rgba(243,177,10,0) 100%);
}

.footer-link-group ul{
    padding:0;
    margin:0;
    list-style:none;
}

.footer-link-group li{
    margin-bottom:18px;
}

.footer-link-group a{
    position:relative;
    display:inline-flex;
    align-items:center;
    gap:10px;
    color:#fff;
    font-size:1.08rem;
    line-height:1.35;
    font-weight:500;
    text-decoration:none;
    transition:color .2s ease, transform .2s ease;
}

.footer-link-group a::before{
    content:'\f105';
    color:rgba(255,255,255,0.58);
    font-family:'Font Awesome 6 Free';
    font-size:.92rem;
    font-weight:900;
}

.footer-link-group a:hover{
    color:#f3b10a;
    opacity:1;
    transform:translateX(3px);
}

.footer-contact{
    min-width:0;
}

.footer-contact-item{
    display:grid;
    grid-template-columns:50px minmax(0, 1fr);
    gap:18px;
    align-items:start;
    padding:26px 0 25px;
    border-bottom:1px solid rgba(255,255,255,0.12);
}

.footer-contact-item:first-of-type{
    padding-top:0;
}

.footer-contact-item:last-child{
    border-bottom:0;
    padding-bottom:0;
}

.footer-contact-icon{
    display:grid;
    place-items:center;
    width:50px;
    height:50px;
    border-radius:13px;
    color:#fff;
    background:linear-gradient(135deg, #2b5fba 0%, #008c52 100%);
    font-size:1.08rem;
}

.footer-contact-item p{
    margin:0;
    color:#fff;
    font-size:1.06rem;
    font-weight:500;
    line-height:1.65;
}

.footer-contact-item a{
    display:block;
    color:#fff;
    text-decoration:none;
}

.footer-contact-item a:hover{
    color:#f3b10a;
}

.footer-disclaimer{
    max-width:1620px;
    margin:62px auto 0;
    padding:38px 14px 28px;
    border-top:1px solid rgba(255,255,255,0.14);
    border-bottom:1px solid rgba(255,255,255,0.14);
    text-align:center;
}

.footer-disclaimer p{
    margin:0;
    color:#fff;
    font-size:1rem;
    line-height:1.72;
}

.footer-disclaimer strong{
    color:#f3b10a;
}

.footer-copyright{
    margin:24px 0 0;
    color:#fff;
    font-size:1rem;
    line-height:1.5;
    text-align:center;
}

@media (max-width:1199px){
    .footer-main-grid{
        grid-template-columns:repeat(2, minmax(0, 1fr));
        gap:42px 52px;
    }

    .footer-about{
        max-width:none;
    }
}

@media (max-width:767px){
    .site-footer{
        padding:54px 0 28px;
    }

    .footer-main-grid{
        grid-template-columns:1fr;
        gap:38px;
    }

    .footer-logo{
        width:190px;
        margin-bottom:24px;
    }

    .footer-about p{
        font-size:1rem;
    }

    .footer-social{
        gap:12px;
        margin-top:28px;
    }

    .footer-social a{
        width:50px;
        height:50px;
        font-size:1.18rem;
    }

    .footer-link-group h4,
    .footer-contact h4{
        margin-bottom:38px;
        font-size:1.24rem;
    }

    .footer-link-group li{
        margin-bottom:13px;
    }

    .footer-link-group a,
    .footer-contact-item p{
        font-size:1rem;
    }

    .footer-contact-item{
        grid-template-columns:48px minmax(0, 1fr);
        gap:16px;
        padding:22px 0;
    }

    .footer-contact-icon{
        width:48px;
        height:48px;
    }

    .footer-disclaimer{
        margin-top:42px;
        padding:26px 0 24px;
        text-align:left;
    }

    .footer-copyright{
        text-align:left;
    }
}

/* Home hero final responsive overrides */
.hero-copy h1{
    font-size:clamp(2.75rem, 3.4vw, 4.8rem);
    line-height:.98;
}

@media (max-width:991px){
    .hero-grid{
        aspect-ratio:auto;
        min-height:clamp(430px, 68vw, 600px);
    }

    .hero-copy h1{
        font-size:clamp(2.45rem, 7vw, 4rem);
        line-height:1;
        margin-bottom:18px;
    }
}

@media (max-width:767px){
    .hero-grid{
        align-items:center;
        min-height:clamp(410px, 112vw, 540px);
        padding:44px 0;
    }

    .hero-copy{
        width:calc(100% - 32px);
        margin-left:16px;
        padding:0;
    }

    .hero-copy h1{
        font-size:clamp(2rem, 9vw, 3rem);
        line-height:1.04;
        margin-bottom:14px;
    }

    .hero-copy p{
        max-width:100%;
        font-size:.96rem;
        line-height:1.58;
    }
}

@media (max-width:480px){
    .hero-grid{
        min-height:200px;
        padding:36px 0;
    }
}

/* Mobile header contact row */
@media (max-width:767px){
    .header-actions{
        flex-direction:column;
        flex-wrap:nowrap;
        align-items:flex-start;
        gap:14px;
        white-space:nowrap;
    }

    .header-actions a{
        gap:6px;
        font-size:.84rem;
        line-height:1.2;
    }

    .header-actions i{
        font-size:.95rem;
    }
}

@media (max-width:380px){
    .header-actions{
        gap:10px;
    }

    .header-actions a{
        font-size:.78rem;
    }

    .header-actions i{
        font-size:.88rem;
    }
}

/* Final heading size reduction */
.section-title{
    font-size:clamp(1.8rem, 2.8vw, 3.2rem);
    line-height:1.12;
}

.hero-copy h1{
    font-size:clamp(2.2rem, 3vw, 3.8rem);
    line-height:1.04;
}

.contact-hero h1,
.team-heading h1,
.about-us-hero h1{
    font-size:clamp(2rem, 3.4vw, 3.4rem);
    line-height:1.08;
}

.event-feature-card h3,
.lets-talk-content h2,
.about-us-mv-card h2{
    font-size:clamp(1.8rem, 3vw, 3rem);
    line-height:1.12;
}

.team-card-body h2,
.team-card h2,
.event-card h3,
.download-card h3,
.award-showcase-card h3,
.green-solution-card h3,
.innovation-point h3{
    font-size:clamp(1rem, 1.35vw, 1.25rem);
    line-height:1.25;
}

@media (max-width:767px){
    .section-title{
        font-size:clamp(1.55rem, 7vw, 2.25rem);
        line-height:1.16;
    }

    .hero-copy h1{
        font-size:clamp(1.75rem, 8vw, 2.55rem);
        line-height:1.08;
    }

    .contact-hero h1,
    .team-heading h1,
    .about-us-hero h1{
        font-size:clamp(1.8rem, 8vw, 2.6rem);
        line-height:1.1;
    }

    .event-feature-card h3,
    .lets-talk-content h2,
    .about-us-mv-card h2{
        font-size:clamp(1.55rem, 7vw, 2.35rem);
        line-height:1.14;
    }

    .team-card-body h2,
    .team-card h2,
    .event-card h3,
    .download-card h3,
    .award-showcase-card h3,
    .green-solution-card h3,
    .innovation-point h3{
        font-size:clamp(.95rem, 4.5vw, 1.15rem);
        line-height:1.28;
    }
}

/* Final home hero text sizing */
.hero-copy{
    width:min(620px, calc(100% - 40px));
}

.hero-copy h1{
    font-size:clamp(2rem, 2.55vw, 3.05rem);
    line-height:1.08;
    margin-bottom:18px;
}

.hero-copy p{
    max-width:440px;
    font-size:clamp(.9rem, 1.1vw, 1.05rem);
    line-height:1.62;
}

@media (max-width:767px){
    .hero-copy{
        width:calc(100% - 32px);
    }

    .hero-copy h1{
        font-size:clamp(1.55rem, 7vw, 2.2rem);
        line-height:1.12;
        margin-bottom:12px;
    }

    .hero-copy p{
        font-size:.88rem;
        line-height:1.52;
    }
}

/* Homepage section links */
.section-explore-btn{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    gap:11px;
    width:max-content;
    min-height:45px;
    margin-top:22px;
    padding:12px 18px;
    border:2px solid var(--text);
    border-radius:6px;
    color:#fff;
    background:var(--text);
    font-size:.88rem;
    font-weight:800;
    line-height:1;
    text-decoration:none;
    box-shadow:0 12px 28px rgba(1,35,80,.18);
    transition:background .2s ease, color .2s ease, transform .2s ease, box-shadow .2s ease;
}

.section-explore-btn i{
    color:var(--accent);
    background:none;
    font-size:.8rem;
    transition:transform .2s ease;
}

.section-explore-btn:hover{
    color:#fff;
    border-color:var(--accent);
    background:#001633;
    box-shadow:0 16px 34px rgba(1,35,80,.25);
    transform:translateY(-3px);
}

.section-explore-btn:hover i{
    transform:translateX(2px);
}

.section-explore-btn-light{
    border-color:#fff;
    color:var(--text);
    background:#fff;
    box-shadow:0 12px 28px rgba(0,0,0,.16);
}

.section-explore-btn-light:hover{
    color:#fff;
    border-color:var(--accent);
    background:var(--text);
}

.section-explore-btn:focus-visible{
    outline:3px solid rgba(107,163,0,.35);
    outline-offset:3px;
}

/* Final footer typography sizing */
.footer-about p{
    font-size:.94rem;
    line-height:1.6;
}

.footer-link-group h4,
.footer-contact h4{
    font-size:1.08rem;
}

.footer-link-group a,
.footer-contact-item p,
.footer-contact-item a{
    font-size:.9rem;
    line-height:1.5;
}

.footer-disclaimer p,
.footer-copyright{
    font-size:.84rem;
    line-height:1.55;
}

@media (max-width:767px){
    .section-explore-btn{
        min-height:42px;
        margin-top:18px;
        padding:11px 15px;
        font-size:.82rem;
    }

    .section-explore-btn i{
        font-size:.75rem;
    }

    .footer-about p{
        font-size:.88rem;
    }

    .footer-link-group h4,
    .footer-contact h4{
        font-size:1rem;
    }

    .footer-link-group a,
    .footer-contact-item p,
    .footer-contact-item a{
        font-size:.84rem;
    }

    .footer-disclaimer p,
    .footer-copyright{
        font-size:.78rem;
    }
}

/* About page icon box treatment */
.about-us-achievement-icon{
    position:relative;
    display:grid;
    place-items:center;
    width:64px;
    height:64px;
    margin-bottom:24px;
    border:1px solid rgba(107,163,0,.28);
    border-radius:8px;
    color:#fff;
    background:var(--text);
    box-shadow:
        8px 8px 0 rgba(107,163,0,.16),
        0 16px 32px rgba(1,35,80,.16);
    transition:transform .25s ease, box-shadow .25s ease, background .25s ease;
}

.about-us-achievement-icon::before{
    content:'';
    position:absolute;
    inset:7px;
    border:1px solid rgba(255,255,255,.18);
    border-radius:5px;
    pointer-events:none;
}

.about-us-achievement-icon i{
    position:relative;
    z-index:1;
    font-size:1.35rem;
}

.about-us-achievement-list li:hover .about-us-achievement-icon{
    background:#001633;
    box-shadow:
        5px 5px 0 var(--accent),
        0 20px 38px rgba(1,35,80,.22);
    transform:translate(-2px, -2px);
}

.about-us-mv-icon{
    position:absolute;
    top:-36px;
    right:32px;
    display:grid;
    place-items:center;
    width:72px;
    height:72px;
    border:6px solid #fff;
    border-radius:10px;
    color:#fff;
    background:var(--text);
    box-shadow:
        6px 6px 0 var(--accent),
        0 16px 34px rgba(1,35,80,.24);
    transition:transform .25s ease, box-shadow .25s ease;
}

.about-us-mv-icon::before{
    content:'';
    position:absolute;
    inset:7px;
    border:1px solid rgba(255,255,255,.2);
    border-radius:5px;
}

.about-us-mv-icon i{
    position:relative;
    z-index:1;
    font-size:1.45rem;
}

.about-us-mv-card:hover .about-us-mv-icon{
    box-shadow:
        3px 3px 0 var(--accent),
        0 20px 42px rgba(1,35,80,.3);
    transform:translate(-2px, -3px);
}

@media (max-width:575px){
    .about-us-achievement-icon{
        width:56px;
        height:56px;
        margin-bottom:20px;
        box-shadow:
            6px 6px 0 rgba(107,163,0,.16),
            0 12px 26px rgba(1,35,80,.14);
    }

    .about-us-achievement-icon i{
        font-size:1.15rem;
    }

    .about-us-mv-icon{
        top:-30px;
        right:22px;
        width:62px;
        height:62px;
        border-width:5px;
        box-shadow:
            5px 5px 0 var(--accent),
            0 14px 28px rgba(1,35,80,.22);
    }

    .about-us-mv-icon i{
        font-size:1.2rem;
    }
}

/* Footer follow spacing */
.footer-about > p + p{
    margin-top:28px;
}

.footer-about > p + p + .footer-social{
    margin-top:10px;
}

@media (max-width:767px){
    .footer-about > p + p{
        margin-top:22px;
    }

    .footer-about > p + p + .footer-social{
        margin-top:8px;
    }
}

/* Dropdown indicators */
.header-menu .nav-item.dropdown > .dropdown-toggle,
.header-menu .menu-item-has-children > .dropdown-link{
    padding-right:30px !important;
}

.header-menu .nav-item.dropdown > .dropdown-toggle::before,
.header-menu .menu-item-has-children > .dropdown-link::before{
    content:'';
    position:absolute;
    top:50%;
    right:10px;
    width:7px;
    height:7px;
    border-right:2px solid currentColor;
    border-bottom:2px solid currentColor;
    transform:translateY(-70%) rotate(45deg);
    transition:transform .2s ease;
}

.header-menu .nav-item.dropdown:hover > .dropdown-toggle::before,
.header-menu .nav-item.dropdown > .dropdown-toggle.show::before,
.header-menu .menu-item-has-children:hover > .dropdown-link::before,
.header-menu .menu-item-has-children:focus-within > .dropdown-link::before{
    transform:translateY(-25%) rotate(225deg);
}

/* Scroll to top */
.scroll-top-btn{
    position:fixed;
    right:24px;
    bottom:24px;
    z-index:999;
    width:48px;
    height:48px;
    border:0;
    border-radius:50%;
    display:flex;
    align-items:center;
    justify-content:center;
    color:#fff;
    background:var(--accent);
    box-shadow:0 14px 30px rgba(1,35,80,.24);
    cursor:pointer;
    opacity:0;
    visibility:hidden;
    pointer-events:none;
    transform:translateY(14px);
    transition:opacity .2s ease, visibility .2s ease, transform .2s ease, background .2s ease;
}

.scroll-top-btn.is-visible{
    opacity:1;
    visibility:visible;
    pointer-events:auto;
    transform:translateY(0);
}

.scroll-top-btn:hover,
.scroll-top-btn:focus-visible{
    background:var(--accent);
    outline:none;
}

/* Mobile banner: image first, copy second, with no overlap */
@media (max-width:991px){
    .hero-grid{
        display:flex;
        flex-direction:column;
        min-height:0;
        aspect-ratio:auto;
        padding:0;
        overflow:visible;
        background:#fff;
    }

    .hero-copy{
        position:relative;
        order:2;
        width:100%;
        margin:0;
        padding:38px 20px 30px;
        color:var(--text);
        background:
            radial-gradient(circle at top left, rgba(107,163,0,.12), transparent 42%),
            #fff;
    }

    .hero-copy p{
        max-width:100%;
    }

    .hero-visual{
        position:relative;
        inset:auto;
        order:1;
        width:100%;
        min-height:0;
        overflow:hidden;
        background:linear-gradient(180deg, #fff 0%, #bde889 100%);
    }

    .hero-visual img{
        width:100%;
        height:auto;
        object-fit:contain;
        object-position:center;
    }

    .process-showcase-section{
        overflow:visible;
    }

    .process-showcase-section .container{
        position:relative;
        inset:auto;
    }

    .process-showcase-image{
        display:block;
        min-height:0;
        height:auto;
        object-fit:contain;
    }

    .process-showcase-copy{
        position:relative;
        top:auto;
        left:auto;
        transform:none;
        width:100%;
        padding:32px 20px 0;
    }
}

@media (max-width:767px){
    .scroll-top-btn{
        right:16px;
        bottom:16px;
        width:44px;
        height:44px;
    }

    .header-menu .nav-item.dropdown > .dropdown-toggle,
    .header-menu .menu-item-has-children > .dropdown-link{
        padding-right:28px !important;
    }

    .header-menu .nav-item.dropdown > .dropdown-toggle::before,
    .header-menu .menu-item-has-children > .dropdown-link::before{
        right:8px;
    }

    .header-menu .menu-item-has-children > .sub-menu{
        display:none !important;
    }

    .header-menu .menu-item-has-children.submenu-open > .sub-menu{
        display:block !important;
    }

    .header-menu .menu-item-has-children:not(.submenu-open):focus-within > .dropdown-link::before{
        transform:translateY(-70%) rotate(45deg);
    }

    .header-menu .menu-item-has-children.submenu-open > .dropdown-link::before{
        transform:translateY(-25%) rotate(225deg);
    }
	.bio-cng .about-gallery-grid {
    display: grid;
    grid-template-columns: 1fr;
    grid-auto-rows: auto !important;
    gap: 18px;
}
.about-gallery-section.section.bio-cng .about-gallery-item{
    flex-direction:column
}
.bio-cng .about-gallery-item img {
    width: 100%;
    height: 260px;
    object-fit: cover;
    transition: transform .35s ease;
}
}
.innovation-panel .section-lead{
	color:#fff !important;
}
.media-head.award-head{
	max-width:100% !important;

}

.media-head.award-head h2.section-title{
		font-size:30px !important
	}
.award-section{
	padding:50px 0px;
}
.award-details{
	padding:12px;
}
.award-details h4{
	font-size:16px;
}
.award-section:nth-child(odd) {
     background-color: radial-gradient(circle at 8% 18%, rgba(107,163,0,0.10), transparent 28%),
        linear-gradient(180deg, #fbf8f1 0%, #f3f7ef 100%);
}

.award-section:nth-child(even) {

	   background-color: #fff;
}


