:root {
    --radius: 0.75rem;
    --background: rgb(248, 251, 252);;
    --foreground: oklch(0.18 0.02 50);
    --card: oklch(1 0 0);
    --card-foreground: oklch(0.18 0.02 50);
    --popover: oklch(1 0 0);
    --popover-foreground: oklch(0.18 0.02 50);
    --primary: oklch(0.65 0.2 45);
    --primary-foreground: oklch(1 0 0);
    --secondary: oklch(0.96 0.015 80);
    --secondary-foreground: oklch(0.25 0.03 50);
    --muted: oklch(0.96 0.01 80);
    --muted-foreground: oklch(0.5 0.03 50);
    --accent: oklch(0.75 0.16 75);
    --accent-foreground: oklch(0.2 0.03 50);
    --destructive: oklch(0.577 0.245 27.325);
    --destructive-foreground: oklch(0.984 0.003 247.858);
    --border: oklch(0.92 0.01 80);
    --input: oklch(0.92 0.01 80);
    --ring: oklch(0.65 0.2 45);
    --chart-1: oklch(0.65 0.2 45);
    --chart-2: oklch(0.55 0.15 160);
    --chart-3: oklch(0.45 0.1 230);
    --chart-4: oklch(0.75 0.16 75);
    --chart-5: oklch(0.6 0.18 30);
    --sidebar: oklch(0.98 0.005 80);
    --sidebar-foreground: oklch(0.18 0.02 50);
    --sidebar-primary: oklch(0.65 0.2 45);
    --sidebar-primary-foreground: oklch(1 0 0);
    --sidebar-accent: oklch(0.96 0.015 80);
    --sidebar-accent-foreground: oklch(0.25 0.03 50);
    --sidebar-border: oklch(0.92 0.01 80);
	--brand-red: oklch(0.60 0.24 27);
	--brand-green: oklch(0.58 0.20 145);
	--font-body: "Manrope", system-ui, sans-serif;
	
	--sidebar-ring: rgb(0, 109, 176);
    --brand-blue: rgb(0, 109, 176);
    --brand-amber: rgb(255, 198, 30);
    --brand-dark: rgb(2, 23, 39);
    --brand-warm: rgb(235, 245, 234);
    --brand-green: rgb(88, 176, 87);
    --hero-overlay: rgba(0, 19, 38, 0.65);
}
body{
    font-family:  var(--font-body);
	color:--muted-foreground;
}
 .custom-caption{
    background:rgba(0,0,0,0.45);
    padding:10px 20px;
    border-radius:10px;
    width:fit-content;
    margin:auto;
    bottom:80px;
}
/* Mobile */
@media(max-width:768px){
    .custom-caption{
        padding:7px 15px;
        bottom:30px;
    }
    .custom-caption h1{
        font-size:20px !important;
    }
}
.hero-content{
    position:relative;
    z-index:2;
    max-width:600px;
    padding:50px 7%;
}
.badge{
    display:inline-block;
    background:rgba(31,108,176,0.18);
    color:#1F6CB0;
	font-size:14px;
    padding:12px 22px;
    border-radius:40px;
    margin-bottom:30px;
    font-weight:600;
    backdrop-filter:blur(6px);
}
.hero-content h1{
    font-size:40px;
    line-height:1.3;
    font-weight:700;
    margin-bottom:10px;
}
.hero-content h1 span{
    color:var(--brand-blue);
}.hero-content p{
    font-size:18px;
    line-height:1.8;
    margin-bottom:20px;
}
.hero-content .hero-buttons{
    display:flex;
    gap:20px;
    margin-bottom:50px;
    flex-wrap:wrap;
}
.hero-content .btn-primary,
.hero-content .btn-secondary{
    text-decoration:none;
    padding:12px 20px;
    border-radius:14px;
    font-weight:600;
    transition:0.3s;
}
.hero-content .btn-primary{
    color:#fff;
    background:rgba(255,255,255,0.05);
	background:#1F6CB0;
    backdrop-filter:blur(6px);
}
.hero-content .btn-primary:hover{
    background:var(--brand-green)
}
.hero-content .btn-secondary{
    border:1px solid rgba(255,255,255,0.3);
    color:#fff;
    background:rgba(255,255,255,0.05);
	background: linear-gradient(135deg, var(--brand-blue), var(--brand-green));
    backdrop-filter:blur(6px);
}
.hero-content .btn-secondary:hover{
    background:var(--brand-blue);
}

.hero-gradient {
    background: linear-gradient(135deg, var(--brand-blue), var(--brand-green));
}.px-4 {
    padding-inline: calc(var(--spacing) * 4);
}.gap-6 {
    gap: calc(var(--spacing) * 6);
}.justify-around {
    justify-content: space-around;
}.items-center {
    align-items: center;
}.flex-wrap {
    flex-wrap: wrap;
}.max-w-7xl {
    max-width: var(--container-7xl);
}.card-hover {
    transition: transform .3s, box-shadow .3s;
}.shadow-sm{
    box-shadow:0 4px 12px rgba(0,0,0,0.92);
}
.border-border, .border-border\/50 {
    border-color: var(--border);
} .footer h4{
	color: var(--brand-amber);
	    --tw-tracking: var(--tracking-wider);
    letter-spacing: var(--tracking-wider);
	    text-transform: uppercase;
} .footer p {
    margin-bottom: .5rem;
}


/* Page */
.page-content{
    padding:100px 10%;
}

.page-content h1{
    font-size:48px;
    margin-bottom:20px;
}

.page-content p{
    font-size:18px;
    line-height:1.8;
    max-width:700px;
}

.main-btn{
    margin-top:30px;
    padding:15px 30px;
    border:none;
    background:#f58b00;
    color:#fff;
    border-radius:10px;
    font-size:16px;
    cursor:pointer;
}
.text-orange{
	color:var(--brand-blue);
}.text-green{
	color:var(--brand-green);
}

.pillar-card{
    background:#fff;
    border:1px solid #E8F0F7;
    border-radius:20px;
    padding:25px;
    transition:
        transform 0.35s ease,
        box-shadow 0.35s ease,
        border-color 0.35s ease;
    /* Default shadow */
    box-shadow:
        0 2px 8px rgba(0,0,0,0.04);
    height:100%;
}
/* Hover Effect */
.pillar-card:hover{
    transform:translateY(-6px);
    border-color:rgba(0,0,0,0.08);
    box-shadow:
        0 12px 35px rgba(0,0,0,0.12),
        0 4px 12px rgba(0,0,0,0.06);
}
/* Icon */
.pillar-card .icon{
    font-size:34px;
    margin-bottom:20px;
    display:inline-block;
}
/* Title */
.pillar-card h3{
    font-size:22px;
    font-weight:700;
    margin-bottom:18px;
    color:#1F6CB0;
}


/* pillar-card2 */
.pillar-card2{
    background:#fff;
    border:1px solid #ddd;
    border-radius:10px;
    padding:15px;
    transition:
        transform 0.35s ease,
        box-shadow 0.35s ease,
        border-color 0.35s ease;
    
    box-shadow:
        0 2px 8px rgba(0,0,0,0.04);
    height:100%;
} .pillar-card2 p{
	color:#444;
	font-size:16px;
	font-weight:400;
	padding:0;
	margin:0;
}.pillar-card2 .icon{
    font-size:34px;
    margin-bottom:20px;
    display:inline-block;
}

/* pillar-card2 */
.pillar-card2{
    background:#fff;
    border:1px solid #ddd;
    border-radius:.75rem;
    padding:15px;
    transition:
        transform 0.35s ease,
        box-shadow 0.35s ease,
        border-color 0.35s ease;
    
    box-shadow:
        0 2px 8px rgba(0,0,0,0.04);
    height:100%;
} .pillar-card2 px{
	color:#444;
	font-size:16px;
	font-weight:500;
	padding:0;
	margin:0;
}.pillar-card2 p{
    display:flex;
    align-items:center;
    gap:18px;
    margin:0;
    font-size:18px;
    line-height:1.4;
}/* ICON CIRCLE */
.pillar-card2 .icon{
    width:28px;
    height:28px;
    min-width:28px;
    border-radius:50%;
    background:#1F6CB0;
    display:flex;
    align-items:center;
    justify-content:center;
	 flex-shrink:0;
}/* FEATHER ICON */
.pillar-card2 .icon svg{
    width:20px;
    height:20px;
    stroke:#fff;
    stroke-width:3;
}

/* pillar-card3 */
.pillar-card3{
    background:#FCF2EB;
    border:1px solid #ec5a00;
    border-radius:.75rem;
    padding:15px;
    transition:
        transform 0.35s ease,
        box-shadow 0.35s ease,
        border-color 0.35s ease;
    box-shadow:
        0 2px 8px rgba(0,0,0,0.04);
    height:100%;
} .pillar-card3 p{
	color:#444;
	font-size:16px;
	font-weight:400;
	padding:0;
	margin:0;
}.pillar-card3 .icon{
    font-size:34px;
    margin-right:15px;
}

.partner-card{
    background:#fff;
    border:1px solid #e5e5e5;
    border-radius:20px;
    padding:45px 35px;
    text-align:center;
    transition:
        transform 0.35s ease,
        box-shadow 0.35s ease,
        border-color 0.35s ease;
    box-shadow:
        0 4px 14px rgba(0,0,0,0.04);
    height:100%;
}
/* HOVER */
.partner-card:hover{
    transform:translateY(-6px);
    border-color:#f5a00055;
    box-shadow:
        0 18px 40px rgba(0,0,0,0.10);
}
/* LOGO */
.partner-logo{
    width:70px;
    height:70px;
    margin:0 auto 20px;
    border-radius:50%;
    background:#E8F0F7;
    display:flex;
    align-items:center;
    justify-content:center;
    font-size:23px;
    font-weight:800;
    color:#1F6CB0;
    letter-spacing:1px;
}
/* TITLE */
.partner-card h3{
    font-size:18px;
    font-weight:800;
    color:#111;
    margin-bottom:5px;
    line-height:1.5;
}
/* DESCRIPTION */
.partner-desc{
    font-size:16px;
    line-height:1.4;
    color:#666;
    margin-bottom:1px;
}
/* LOCATION */
.partner-location{
    display:block;
    font-size:16px;
    color:#8a8a8a;
}
/* MOBILE */
@media(max-width:768px){
    .partner-card{
        padding:35px 25px;
    }
    .partner-logo{
        width:60px;
        height:60px;
        font-size:24px;
    }
    .partner-card h3{
        font-size:18px;
    }
    .partner-desc{
        font-size:16px;
    }
    .partner-location{
        font-size:16px;
    }
}

/* SECTION */
.section{
    overflow:hidden;
}
/* TITLE */
.section-title{
    font-size:20px;
    font-weight:800;
    margin-bottom:18px;
}
/* TEXT */
.section-text{
    max-width:850px;
    margin:auto;
    font-size:20px;
    line-height:1.8;
    color:#666;
}
/* MOBILE */
@media(max-width:768px){
    .partners-section{
        padding-top:60px !important;
        padding-bottom:60px !important;
    }
    .section-title{
        font-size:34px;
    }
    .section-text{
        font-size:17px;
        line-height:1.7;
    }
}

/* SECTION */
.inclusion-section{
    position:relative;
    width:100%;
	height:500px;
	max-height:500px;
    background:url('../images/hero-inclusion.jpg') center center/cover no-repeat;
    display:flex;
    align-items:center;
    overflow:hidden;
}
/* DARK OVERLAY */
.inclusion-section .overlay{
    position:absolute;
    inset:0;
    background:
    linear-gradient(
        90deg,
        rgba(0,0,0,0.72) 0%,
        rgba(0,0,0,0.55) 40%,
        rgba(0,0,0,0.35) 100%
    );
}
/* CONTAINER */
.inclusion-section .container{
    position:relative;
    z-index:2;
    width:100%;
    max-width:1400px;
    padding:30px 8%;
}
/* CONTENT */
.inclusion-section .contentx{
    max-width:700px;
    color:#fff;
}
/* TAG */
.inclusion-section .tag{
    display:inline-block;
    font-size:18px;
    font-weight:700;
    color:#f5a000;
    letter-spacing:1px;
    margin-bottom:15px;
	text-transform:uppercase;
}
/* TITLE */
.inclusion-section h1{
    font-size:38px;
    line-height:1.05;
    font-weight:800;
    margin-bottom:15px;
	color:#FFFFFF;
}
/* TEXT */
.inclusion-section p{
    font-size:20px;
    line-height:1.4;
    color:rgba(255,255,255,0.62);
    margin-bottom:20px;
}



/* hero gradient SECTION */
.gradient-section{
    position:relative;
    width:100%;
    background: linear-gradient(135deg, var(--brand-blue), var(--brand-green));
    display:flex;
    align-items:center;
    overflow:hidden;
	padding:30px 10px;
	margin-top:10px;
}/* CONTAINER */
.gradient-section .container{
    position:relative;
    z-index:2;
    width:100%;
    max-width:1400px;
    padding:30px 8%;
}/* CONTENT */
.gradient-section .contentx{
    max-width:700px;
    color:#fff;
}/* TAG */
.gradient-section .tag{
    display:inline-block;
    font-size:16px;
    font-weight:600;
    color:rgba(255,255,255,0.70);
    letter-spacing:1px;
    margin-bottom:5px;
	text-transform:uppercase;
}
/* TITLE */
.gradient-section h1{
    font-size:35px;
    line-height:1.05;
    font-weight:700;
    margin-bottom:10px;
	color:#FFFFFF;
}
/* TEXT */
.gradient-section p{
    font-size:18px;
    line-height:1.6;
    color:rgba(255,255,255,0.80);
    margin-bottom:20px;
}

/* BUTTON */
.cta-btn{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    text-decoration:none;
    padding:12px 20px;
    border-radius:14px;
    font-size:20px;
    color:#333;
    background:rgba(255,255,255,0.05);
	background: var(--brand-amber);
    backdrop-filter:blur(6px);
    font-weight:600;
    transition:0.35s ease;
    box-shadow:
        0 12px 30px rgba(245,160,0,0.28);
}
/* BUTTON HOVER */
.cta-btn:hover{
    transform:translateY(-4px);
    background:#ffb100;
    box-shadow:
        0 18px 40px rgba(245,160,0,0.35);
}
/* RESPONSIVE */
@media(max-width:1200px){
    .inclusion-section h1{
        font-size:28px;
    }
    .inclusion-section p{
        font-size:16px;
    }
}

@media(max-width:992px){
    .inclusion-section{
        min-height:450px;
    }
    .inclusion-section h1{
        font-size:52px;
    }
    .inclusion-section p{
        font-size:20px;
    }
}

@media(max-width:768px){
    .inclusion-section{
        min-height:auto;
        padding:50px 0;
    }

    .inclusion-section .container{
        padding:50px 8%;
    }

    .inclusion-section h1{
        font-size:42px;
    }

    .inclusion-section p{
        font-size:18px;
        line-height:1.8;
    }

    .cta-btn{
        width:100%;
        text-align:center;
        padding:18px 25px;
        font-size:18px;
    }
}
@media(max-width:480px){
    .inclusion-section h1{
        font-size:34px;
    }
    .inclusion-section .tag{
        font-size:15px;
    }
    .inclusion-section p{
        font-size:17px;
    }
}


/* LIST ITEM */
.requirements-list{
    list-style:none;
    counter-reset:item;
    margin:0;
    display:flex;
    flex-direction:column;
    gap:2px;
	background:#fff;
}/* LIST ITEM */
.requirements-list li{
    counter-increment:item;
    position:relative;
    padding:18px 28px 8px 55px;
    font-size:17px;
    line-height:1.4;
    transition:
        transform 0.3s ease,
        box-shadow 0.3s ease,
        border-color 0.3s ease;
    box-shadow:
        0 2px 8px rgba(0,0,0,0.03);
}/* NUMBER */
.requirements-list li::before{
    content:counter(item) ".";
    position:absolute;
    left:18px;
    top:14px;
    font-size:20px;
    font-weight:700;
    color:#f57c00;
    line-height:1;
}/* HOVER */
.requirements-list li:hover{
    transform:translateY(-3px);
    border-color:#f5a00055;
    box-shadow:
        0 12px 30px rgba(0,0,0,0.08);
}/* MOBILE */
@media(max-width:768px){
    .requirements-list li{
        font-size:16px;
        padding:10px 10px 10px 45px;
    }
    .requirements-list li::before{
        left:22px;
        top:20px;
        font-size:24px;
    }
}

/*Gradient section brown*/
.brown-gradient-bg{
    background: linear-gradient(to bottom, #EAF6EA 0%, #ffffff 100%);
}.brown-bg{
    background:#E8F0F7 !important;
}


/* CARD */
.research-card{
    display:flex;
    align-items:stretch;
    overflow:hidden;
    background:#fff;
    border:1px solid #e5e5e5;
    border-radius:24px;
    transition:
        transform 0.35s ease,
        box-shadow 0.35s ease,
        border-color 0.35s ease;
    box-shadow:0 4px 14px rgba(0,0,0,0.04);
    height:100%;
}
/* HOVER */
.research-card:hover{
    transform:translateY(-5px);
    border-color:#117A9F55;
    box-shadow:0 18px 40px rgba(0,0,0,0.10);
}
/* IMAGE SIDE */
.research-image{
    position:relative;
    width:260px;
    min-width:260px;
    overflow:hidden;
	/* FALLBACK BACKGROUND */
    background:#0B75A5;
    display:flex;
    align-items:center;
    justify-content:center;
}
/* IMAGE */
.research-image img{
    width:100%;
    height:100%;
    object-fit:cover;
    display:block;
}
/* DARK OVERLAY */
.research-image::after{
    content:"";
    position:absolute;
    inset:0;
    background:linear-gradient(rgba(0,0,0,0.15), rgba(0,0,0,0.35));
}
/* BADGE */
.research-badge{
    position:absolute;
    left:20px;
    bottom:20px;
    z-index:2;
    background:rgba(245,160,0,0.92);
    color:#fff;
    padding:10px 18px;
    border-radius:12px;
    font-size:14px;
    font-weight:700;
    letter-spacing:1px;
    backdrop-filter:blur(5px);
}
/* CONTENT */
.research-content{
    flex:1;
    padding:35px 40px;
    display:flex;
    flex-direction:column;
    justify-content:center;
}
/* YEAR */
.research-year{
    display:inline-block;
    color:#888;
    font-size:17px;
    margin-bottom:12px;
}
/* TITLE */
.research-content h3{
    font-size:24px;
    font-weight:800;
    line-height:1.3;
    margin-bottom:16px;
    color:#111;
}
/* TEXT */
.research-content p{
    font-size:20px;
    line-height:1.8;
    color:#666;
    margin:0;
}

/* MOBILE */
@media(max-width:992px){
    .research-card{
        flex-direction:column;
    }
    .research-image{
        width:100%;
        min-width:100%;
        height:240px;
    }
    .research-content{
        padding:28px;
    }
    .research-content h3{
        font-size:28px;
    }
    .research-content p{
        font-size:17px;
    }
}


/* Accessibility Button */
.accessibility-btn{
    position:fixed;
    left:5px;
    top:0px;
    width:70px;
    height:70px;
    border:none;
    border-radius:5px;
    background:#1F6CB0;
    color:#fff;
    font-size:30px;
    cursor:pointer;
    z-index:1000;
}
/* Panel */
.accessibility-panel{
    position:fixed;
    left:10px;
    top:70px;
    width:300px;
    background:#fff;
    padding:25px;
    border-radius:5px;
    box-shadow:0 10px 40px rgba(0,0,0,0.15);
    display:none;
    z-index:1000;
}
.panel-header{
    display:flex;
    justify-content:space-between;
    align-items:center;
    margin-bottom:20px;
}
.panel-header h2{
    font-size:20px;
}
.panel-header button{
    border:none;
    background:none;
    font-size:20px;
    cursor:pointer;
}
.h3{
    margin-bottom:15px;
    margin-top:20px;
    color:#777;
    font-size:15px;
    letter-spacing:1px;
}
.options{
    display:grid;
    grid-template-columns:1fr 1fr;
    gap:15px;
}

.options button{
    padding:10px;
    border-radius:10px;
    border:1px solid #ddd;
    background:#fff;
    cursor:pointer;
    font-size:18px;
    transition:0.3s;
}
.options button:hover{
    border-color:#f58b00;
}
.reset-btn{
    width:100%;
    margin-top:20px;
    padding:15px;
    border:none;
    border-radius:14px;
    background:#eee;
    cursor:pointer;
    font-size:16px;
}

/* =========================
   DARK MODE
========================= */
body.dark{
    background:#121212;
    color:#ffffff;
}
/* Main Containers */
body.dark .accessibility-panel,
body.dark .brown-gradient-bg,
body.dark .brown-bg,
body.dark .card,
body.dark .navbar,
body.dark .info-box,
body.dark .pillar-card,
body.dark .pillar-card2,
body.dark .pillar-card3,
body.dark .partner-card,
body.dark .content-box{
    background:#1e1e1e!important;
    color:#ffffff;
    border-color:#333;
}
/* Headings */
body.dark h1,
body.dark h2,
body.dark h3,
body.dark h4,
body.dark h5,
body.dark h6
body.dark .text-dark{
    color:#ffffff;
}
/* Paragraphs & Text */
body.dark p,
body.dark span,
body.dark li,
body.dark label,
body.dark small{
    color:#d6d6d6;
}
/* Links */
body.dark a{
    color:#f5a000;
}
/* Inputs */
body.dark input,
body.dark textarea,
body.dark select{
    background:#2b2b2b;
    color:#fff;
    border:1px solid #444;
}
/* Buttons */
body.dark button,
body.dark .btn-secondary,
body.dark .btn-primary{
    background:#2b2b2b;
    color:#fff;
    border:1px solid #444;
}

/* Hover */
body.dark button:hover{
    background:#3a3a3a;
}
/* Cards */
body.dark .options button{
    background:#2b2b2b;
    color:#fff;
    border-color:#444;
}
body.dark .accessibility-panel{
    background:#1f1f1f;
    color:#fff;
}
body.dark .options button{
    background:#2c2c2c;
    color:#fff;
    border-color:#444;
}

/* HIGH CONTRAST */
body.high-contrast{
    background:#000;
    color:#ff0;
}
body.high-contrast .accessibility-panel{
    background:#000;
    color:#ff0;
    border:2px solid #ff0;
}
body.high-contrast .options button{
    background:#000;
    color:#ff0;
    border:1px solid #ff0;
}

/* LIGHT */
body.light{
    background:#fff;
    color:#000;
}

/* FONT SIZES */
body.font-small{
    font-size:14px;
}

body.font-medium,
body.font-medium p{
    font-size:18px;
}

body.font-large,
body.font-large p{
    font-size:24px;
}

/* Mobile */
@media(max-width:480px){

    .accessibility-panel{
        width:92%;
        right:4%;
        bottom:100px;
    }

    .page-content h1{
        font-size:36px;
    }
}


.faq-section{
    padding:30px 0;
}
.faq-section .container{
    width:90%;
    max-width:1200px;
    margin:auto;
}
.faq-wrapper{
    max-width:900px;
    margin:auto;
}
.faq-item{
}
.faq-question{
    width:100%;
    background:none;
    border:none;
    padding:20px 0;
    text-align:left;
    display:flex;
    justify-content:space-between;
    align-items:center;
    font-size:1.4rem;
    font-weight:600;
    color:#07140d;
    cursor:pointer;
	border-top:1px solid #e5e5e5;
}
.faq-question span{
    color:#01A451;
    font-size:2rem;
    transition:0.3s;
}
.faq-answer{
    max-height:0;
    overflow:hidden;
    color:#444;
	font-size:1.25rem;
    line-height:1.8;
    transition:all 0.4s ease;
}
.faq-item.active .faq-answer{
    max-height:300px;
    padding-bottom:25px;
}
.faq-item.active .faq-question span{
    transform:rotate(45deg);
}
@media(max-width:768px){
    .faq-section{
        padding:70px 0;
    }
    .faq-header h2{
        font-size:2.2rem;
    }
    .faq-question{
        font-size:1.15rem;
        padding:22px 0;
    }
    .faq-answer{
        font-size:0.95rem;
    }
}

.social-media {
    text-align: center;
    padding:10px 0px;
	background:#fff;
	padding:20px;
}
.social-media h2 {
    margin-bottom: 10px;
}
.social-links {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 15px;
    margin-top: 20px;
}
.social {
    padding: 10px 18px;
    border-radius: 25px;
    text-decoration: none;
    color: white;
    font-weight: 500;
    transition: 0.3s;
}
/* Brand colors */
.x { background: #000000; }
.linkedin { background: #0077b5; }
.youtube { background: #ff0000; }
.facebook { background: #1877f2; }
.instagram { background: linear-gradient(45deg, #f09433, #e6683c, #dc2743, #cc2366, #bc1888); }

.social:hover {
    transform: scale(1.05);
    opacity: 0.9;
}

.gallery-grid{
    display:grid;
    grid-template-columns:repeat(auto-fill,minmax(250px,1fr));
    gap:15px;
}
.gallery-grid img{
    width:100%;
    height:250px;
    object-fit:cover;
    border-radius:10px;
    cursor:pointer;
    transition:.3s;
}
.gallery-grid img:hover{
    transform:scale(1.03);
}


.publication-section{
    padding:50px 0;
}
.publication-grid{
    display:grid;
    grid-template-columns:repeat(auto-fit,minmax(330px,1fr));
    gap:25px;
}
.publication-card{
    background:#fff;
    border-radius:18px;
    overflow:hidden;
    box-shadow:0 8px 25px rgba(0,0,0,.06);
    transition:.35s;
    position:relative;
    border:1px solid #ececec;
}
.publication-card:hover{
    transform:translateY(-8px);
    box-shadow:0 18px 35px rgba(0,0,0,.12);
}
.publication-card .card-top{
    height:5px;
	background:#2E7D32;
}
.Reports .card-top{
    background:#2E7D32;
}
.Publications .card-top{
    background:#D89B00;
}
.archive .card-top{
    background:#7A8B72;
}
.publication-card .card-body{
    padding:28px;
}
.publication-card .card-body .card-header{
    display:flex;
    justify-content:space-between;
    align-items:flex-start;
}
.card-type{
    font-size:11px;
    text-transform:uppercase;
    letter-spacing:2px;
    font-weight:700;
    color:#2E7D32;
}
.technical .card-type{
    color:#D89B00;
}
.archive .card-type{
    color:#5F6F52;
}
.card-icon{
    width:48px;
    height:48px;
    border-radius:14px;
    background:#F5F8F3;
    display:flex;
    align-items:center;
    justify-content:center;
    color:#2E7D32;
    font-size:20px;
}
.technical .card-icon{
    color:#D89B00;
    background:#FFF8E7;
}
.archive .card-icon{
    color:#5F6F52;
    background:#F4F6F1;
}
.publication-card h3{
    font-size:28px;
    line-height:1.3;
    margin-bottom:10px;
    color:#252A2D;
    font-family:Georgia,serif;
}
.author{
    color:#666;
    margin-bottom:10px;
    font-size:15px;
}
.publication-card p{
    color:#6b7280;
    line-height:1.4;

    display:-webkit-box;
    -webkit-line-clamp:2;
    -webkit-box-orient:vertical;

    overflow:hidden;
    text-overflow:ellipsis;

    /* Fallback */
    max-height:3.6em; /* 2 × line-height */
}

.read-more,
.download{
    display:inline-flex;
    align-items:center;
    gap:8px;
    font-weight:700;
    text-decoration:none;
    color:#2E7D32;
    transition:.3s;
}

.download{
    color:#D89B00;
}
.read-more:hover,
.download:hover{
    gap:15px;

}

@media(max-width:768px){
    .publication-grid{
        grid-template-columns:1fr;
    }
    .publication-card h3{
        font-size:24px;
    }
}