/* ---------------------------------- */
/* VARIABLES                          */
/* ---------------------------------- */
:root {
    /* --- Core Branding --- */
    --color-orange: #e99648;
    --color-dark-blue: #3137a9;
    --color-main-blue: #89cbf0;
    --color-white: #ffffff;
    --color-dark-text: #222222;
    --color-footer-text: #222221; 
    --color-light-grey: #f8f9fa;
    --color-border-grey: #eeeeee;
    --color-bg: #FDFBF7; /* New Background */
    
    /* --- Dimensions --- */
    --header-height: 120px; 
    --container-width: 1256px; /* UPDATED STRICT WIDTH */
    --hero-height: 43vh;       /* UPDATED HERO HEIGHT */
    --brand-radius: 0 30px 0 30px;

    /* --- New Homepage Vars --- */
    --primary-orange: #F58220;
    --primary-purple: #5B4A9C; 
    --text-light: #555555;
    --card-shadow: 0 20px 40px rgba(0,0,0,0.1);
    --gap: 5rem;
    --scroll-duration: 50s;
    
    --afghan-shape-url: url("data:image/svg+xml,%3Csvg viewBox='0 0 800 600' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath fill='black' d='M737.2,120.4l0.2,0.4l0.1,0.4l-0.1,0.4l-0.2,0.5l-0.3,2l-0.8,0.2l-1-0.9l-0.9-1.3l-0.2-0.2l-0.2-0.1l-1-0.3l-1.1,0.1l-2,0.6l-1.3,1.1l-4.1,2.6l-2.4,2l-1.2,0.4l-3.2-0.4l-0.8,0.2l-0.7,0.5l-0.3,0.9l-0.2,2.1l-0.5,0.6l-2.9,1l-1.4,0l-1.5-0.6l-1.5-0.4l-4-2.6l-1.5-0.6l-3-0.6l-3-0.1l0,0l0,0l-0.1,0l-3.4-0.1l-6.4,1.1l-1.6-0.3l-1.5-0.2l-3.3,0.4l-2.4-0.2l-2.5,0.9l-0.7,0.1l-0.7-0.1l-1.4-0.4l-1.6-0.2l-7.3,0.8l-0.8,0.3l-1.2,0.8l-0.6,0.3l-0.7,0l-1.5-0.6l-1.2,0.3l-1.2,0.6l-1.4,0.4l-4.3,0.2l-4.1-0.6l-3.3,0.2l-3.2,0.8l-2.4,1.2l-3.1,2.6l-1,0.3l-2.3-0.1l-2,0.7l-2.2,0.1l-4.3,1l-2.2,0.9l-0.8,0.6l-0.2,0.8l0.7,1.2l0.3,1l-0.9,0.5l-2.9,0.4l-1.2,0.4l-0.6,0.3l-0.4,0.5l0.1,0.5l0.2,0.5l-0.1,0.6l-0.8,0.8l-2,0.5l-1,0.6l-0.8,0.8l-2.3,1.3l-0.7,0.6l-0.6,0.6l-0.6,0.5l-0.8,0.3L602,153l-1,0.7l0.1,1.9l0.8,1.7l0.1,0.8l-0.6,0.7l-0.8,0.3l-0.8,0l-0.7-0.3l-1.4-1.6l-2.8-1.9l-1-0.4l-0.9,0.1l-0.5,0.5l-0.6,1.9l-0.4,1l-0.4,0.7l-1.2,1.2l-0.2,0.9l0.5,0.9l0.3,0.8l-1,0.5l-1.2,0.2l-0.9,0.3l-0.8,0.6l-3.8,4.2l-1,0.8l-3.1,1.1l-0.3,0.4l-0.2,1.3l-0.3,0.6l-0.5,0.3l-1.5,0.7l-1.9,1.3l-0.3,0.4l-0.2,1.3l-0.2,0.6l-1.6,1.6l-0.5,0.9l0.2,0.9l0.1,0.2l0.5,0.5l1.8,1l0.7,0.5l1.3,1.4l1.3,0.6l1.4,0.3l1.4,0.6l0.7,0.9l0.2,2l0.5,0.9l2.2,1.6l0.7,0.9l1.6,3l0.3,0.9l0.1,0.6l-0.1,0.5l0,0.5l0.2,0.7l0.3,0.4l0.7,0.6l0.3,0.3l0.6,1.1l0.2,1.1l-0.3,1.1l-0.9,1.1l-0.6,1.2l0.5,1l1,0.8l2.7,1.3l0.8,0.6l0.5,0.9l0,1.2l-0.3,1.1l-0.2,1.1l0.3,1.3l0.3,0.4l0.4,0.5l0.7,0.7l0.4,0.8l-0.1,1.2l-0.5,0.9l-2.4,2.1l-1.5,2l-0.1,1.6l0.9,1.5l2.7,3.1l1.5,1.2l0.2,0.8l-0.4,1.2l-1.2,1.9l-3.4,2.4l-1.3,1.6l-0.1,2.6l0.3,0.6l-0.1,0.6l-0.3,0.5l-0.5,0.4h0v0l-0.4,0.6l-0.4,1.4l-0.4,0.6l-0.5,0.4l-0.7,0.3l-5.9,2.4l-1.7,1.4l-0.9,1.8l-0.7,2l-2.6,3.7l-0.7,0.7l-1.9,1l-3.5,2.8l-0.5,0.7l-0.1,0.9l0.4,1.3l0.2,1.2l-0.2,1.5l-0.5,1.2l-0.9,0.4l-2-0.3l-1,0l-0.1,0.1l-0.7,0.3l-0.6,1.1l-0.1,1.3l0.3,1.3l0.5,1.1l1,1.5l1.4,1.7l1.5,1.5l3.5,2l0.2,1.5l-1.4,4.2l0,1.1l0.5,2.1l0.1,1.2l-0.1,1.4l-0.3,0.8l-1.4,1.6l-0.5,1.2l0.1,1l0.2,0.9l-0.2,1.1l-0.8,0.7l-2.4,0.5l-1,0.4l-0.6,0.8l-0.6,0.5l-0.7,0.2l-0.9-0.1l-1.3-0.4l-0.5,0.1l-0.2,0.8l-0.9,1.7l-3.5,0.7l-6.6-0.1l-6.6,1l-1.5-0.1l-4.1-0.9l-4-0.2l-0.9-0.3l-1.7-0.9l-2.8-0.3l-10.6-3.7l-1.7-0.1l-2.6,0.4l-1.3,0.5l-0.8,0.8l-0.1,0.9l0.2,0.9l-0.1,0.9l-0.9,0.9l-0.6,0.9l0.3,0.9l1.4,1.4l0.4,0.8l0.7,2.2l0.4,0.9l1.2,1.7l0.4,0.9l0.4,1.2l0.5,1.1l0.7,0.5l1.2,0.2l0.8,0.1l2.6,1.1l2.1-0.4l0.5,0.6l0.4,2.3l0.3,0.9l0.2,0.3l0.4,0.4l0.8,0.4l0.4,0.3l0.2,0.4l0,1.4l-1,3.7l-0.1,1.1l0.2,1.1l0.4,1.1l0.7,0.9l0.4,0.3l1.4,0.4l0.3,0.3l0.4,0.9l0.3,0.4l2.6,2.9l0.8,1.8l-0.4,1.9l-8.3,7.1l-1,0.5l-1.1-0.1l-1.2-0.4l-0.6,0.2l-1.6,3.1l-0.4,0.5l-0.6,0.3l-1.4-0.1l-0.5,0.1l-3.7,2.3l-2.1,0.2l-3.3-1.7l-1.9,0.3l-2.3,1.7l-0.9,0.2l-0.4-0.1l-0.4-0.2l-0.5-0.1l-1.6,0.3l-1,0l-2,0.3l-1.6,1.1l-1.3,1.7l-0.5,1l-0.5,1l0.9,6.4l-0.5,1.7l-0.3,0.3l-1.3,1l-1.2,1.7l-1.7,1.3l-0.5,0.8l0.1,1.1l0.3,0.5l0.4,0.4l0.4,0.3l0.4,0.2l0.3,0.3l0.1,0.4l0.1,1l0.5,1.9l-0.2,0.7l-0.6,1.1l-2.6,3.9l-0.9,0.7l-2,0.7l-1,0.6l-1.5,1.9l-0.9,2.2l-0.2,2.4l0.5,2.5l1.3,3.3l0.2,1.2l-0.1,1.3l-0.3,2.5l0,2.5l-0.4,2.5l0,1.3l1,5.5l1.6,4.4l0.1,0.8l-0.2,0.3l-0.1,0.2l-2.4,1.8l-1.3,1.5l-5.4,8.3l-0.7,0.8l-0.8,0.5l-0.6,1l-1.6,1.4l-1.8,1.3l-1.3,0.6l-1.8-0.1l-1.7,0.5l-3.1,1.6l-2,0.2l-1.3-0.9l-2.3-3.3l-1.3-1.5l-0.4-0.8l-0.1-2.3l-0.3-0.7l-0.6-0.4l-2.8-0.5l-2.9-1.6l-1.7-0.6l-1.1,0l-1.2,0.4l-2.1,1.1l-1,0.8l0.2,0.6l0.9,0.4l1.1,0.2l2.9-0.1l1,0.1l0.5,0.5l-0.6,0.7l-1.1,0.6l-0.8,0.3L438,436l-5.2-1.9l-1.9-0.2l-1.9,0.1l-1.1-0.2l-0.6-0.6l-0.5-0.8l-1.3-1l-1.1-0.6l-1.3-0.4l-1,0.1l-0.6,0.8l-1,2.5l-0.3,0.6l-0.2,0.4l-1.6,1.5l-0.2,0.5l-0.2,1.2l-0.3,0.4l-2.6,1.4l-0.8,0.7l-0.6,0.8l-0.5,0.3l-2,0.1l-1.5-0.2l-0.7,0l-1.4,0.7l-3,3.4l-1.6,1.1l-1.1,0.7l-1.5,0.6l-1.5,0.2l-3.2-0.7l-1.6,0l-0.6,1l0.4,0.9l0.7,0.9l0.6,1l0.3,2.3l0.7,0.9l1,0.6l1,0.3l4.1-0.5l1.8,0.6l0.2,2.4l-0.5,1.1l-0.8,0.3l-2-0.1l-0.8,0.2l-0.7,0.5l-0.6,0.6l-3.1,2l-0.9,0.3l-2.6,0.5l-1.8,0.8l-2.9,0.4L384,466l-0.9,0.2l-3.2-0.3l-2.6,0.1l-0.8-0.1l-1-0.4l-1.8-1l-1-0.3l-1,0l-1.9,0.5l-1,0l-1.1-0.2l-0.6-0.2l-0.4-0.3l-0.1-0.5l0.2-0.3l0.3-0.4l0.1-0.5l-0.1-1.3l-0.3-0.8l-0.7-0.4l-2.9,0.1l-1.8,0.5l-3.3,1.6l-1.5,1.3l-1.1,1.3l-1.3,1l-1.9,0.3l-1.2,0.8l-1.7,6.5l-0.9,1.3l-4.6,4.8l-1.1,0.5l-6.7,1.4l-0.8,0.5l-0.4,0.8L330,501l-0.1,2.5l0.8,2.3l1.2,1.5l0.4,0.7l0.3,1.2l0.1,1.2l-0.9,7.5l0.1,3.4l-0.2,1.1l-3.2,6.5l-0.7,2.2l-0.1,0.9l0.3,0.8l1.7,1.2l2,2.1l1.5,1.2l0.4,0.5l-0.2,0.3l-0.4,0.1l-0.3,0.2l-1,1.8l-1.3,1.7l-3.9,2.8l-4.2,1.2l-2.9,0.8l-2.9,0.8l-2.9,0.8l-2.8,0.8L308,550l-2.9,0.8l-2.9,0.8l-2.9,0.8l-2.9,0.8l-2.9,0.8l-2.9,0.8l-2.9,0.8l-2.8,0.8l-2.9,0.8l-2.9,0.8l-2.9,0.8l-7.1,2.1l-2.4-0.1l-8.2-1.5l-6.7-0.1l-9.1-0.1l-1.1,0l-13.3,4l-1.7,0.9l-1.1,1.5l-1.8,3.5l-1.3,0.5l-5.6-2.4l-9.1-1.8l-10.8-2.1l-7.5,0.7l-2.4,0.2l-2.4,0.2l-2.4,0.2l-2.4,0.2l-2.4,0.2l-2.4,0.2l-2.4,0.2l-2.4,0.2l-2.4,0.2l-2.4,0.2l-2.4,0.2l-2.4,0.2l-2.4,0.2l-1.4,0.1l-6.2,0.6l-5.1-1l-4.7-1.5l-4.1-1.3l-4.1-1.3l-4.1-1.3l-4.1-1.3l-4.1-1.3l-4.1-1.3l-4.1-1.3l-4.1-1.3l-4.1-1.3l-4.1-1.3l-4.1-1.3l-4.1-1.3l-3.5-1.1l-1.6-0.7L66,540l3.7-4.4l0,0l7.6-9.1l4.1-4.9l2.8-3.3l5.3-6.4l4-4.8l5.6-6.8l6.2-7.5l4.1-4.9l0.8-0.9l-0.1-0.3l-0.1-0.1l0.1-1l0.1-0.4l0.3-0.2l-0.2-3.9l-0.2-0.7l0.9-1.9l0.4-1.2l0-1.1l-0.2-1.1l-0.6-1.9l-0.9-1.8l-0.1-0.6l-0.1-1.7l-0.4-1.3l-1.3-2.2l-0.5-1.2l0-1.1l0.3-2.5l-0.3-1.1l-1.8-2.2l-1-0.8l-1.3-0.5l-2.7-0.4L95,455l-9.6-1.4l-8.3-1.2l-0.1,0l-8.2-1.2l-5-0.7l-1.6-0.7l-0.6-5.4l-0.7-2.8l-0.1-1.4l0.6-4.3l-0.7-5.4l-0.1-2.8l0.4-3.6l-0.1-1.3l-0.2-0.6l-0.2-0.6l-0.1-0.6l0.4-1.3l-0.3-0.3l-0.4-0.2l-0.2-0.4l0.4-0.9l1.3-1.7l0.3-1l0.7-4.6l0.1-4.7l-1.7-6.2l-2.2-8.1l-2-6.8l-1.8-6.2l-1.7-5.8l-1.7-5.7l-1.4-4.8l-0.7-3.8l-0.1-4.6l0.3-0.8l2.4-3.2l2.7-3.6l2.4-3.3l1.9-2.6l1.4-1.3l1.6-1l0.5-0.7l0.3-1.2l-0.1-1l-0.2-1l0.1-0.8l0.9-0.6l2.3-0.2l0.7-0.3l0.4-0.7l0.1-0.1l-0.4-0.8l-0.8-0.7l-0.8-0.4l-1.7-0.4l-1.9-0.1l-3.6,0.2l-3.9-0.3l-4-1.6l-3.1-3l-1.2-4.3l0.4-1.9l1.5-3.4l0.1-2.3l-1.4-9.1l-0.5-5.1l-0.1-0.8l0.3-2.7l1.4-2.8l1.6-2l1.7-1.8l2.3-1.2l0.8-0.8l-0.3-1.3l3.5-0.2l5-0.3l3.7-0.2l-0.6-1.1l-3.7-4.8l-0.8-1.6L60,276l-0.6-0.5l-1.2-0.6l-0.4-0.4l-0.4-1.4l-0.3-0.4l-0.4-0.2l-0.5-0.1l0.7-1.3l1.2-0.6l2.7-0.4l1.2-0.3l1-0.7l2.2-2.6l0.2-0.5l0.3-0.4l0.7-0.4l0.7-0.1l0.6,0.1l0.6-0.1l0.5-0.7l0.2-1.5l-0.2-1.5l0.1-1.4l0.9-1l1.6-1.2l1-1.7l0.3-1l1.5-0.5l0.4-2l0.2-2.1l0-0.5l-0.2-1.1l-0.1-0.6l0.2-0.8l0.7-1.1l0.2-0.6l0.2-1.2l0.7-2.3l0.3-2.5l0.4-0.9l1.2-1.7l-0.5-0.5l-0.1-0.5l0.1-0.5l0.1-0.7l-0.1-0.3l-1.7-2.4l-0.3-0.6l0.3-0.3l0.5-0.3l0-0.6l-0.2-0.6l-0.3-0.3l0-0.6l0-1.3l0.3-1.3l0.7-0.6l1,0l1.2-0.2l0.9-0.5l0.4-1.1l-0.2-3.1l0.2-1.2l0.3-0.7l1-1.4l0.3-0.6l0.4-1.9l0.5-1.2l1.2-1.4l0.7-1.1l0.3-1.3l-0.1-1.2l-0.5-2.5l-0.4-0.6l0.7-0.3l2.6-0.5h0.4l0.4,0.2l0.5,0.4l0,0.2l-0.4,0.7l0.6,0.5l0.1,0l0.1,0l0.8,0.7l0,0.3l-0.2,0.7l0,0.2l0.3,0.5l0.3,0.4l0.4,0.2l0.6,0.1l0.3,0.1l0.4,0.2l3.2,2.9l2.3,2.5l3.2,1.3l6.6,1l2.9-0.2l5.9-2.1l2.9,0.1l1.5,0.7l1.3,0.9l5,5l1.4,0.9l2.7,1.2l0.7,0.8l0.5,0.9l0.3,1.1l0.1,1.1l-0.1,2.4l0.3,0.9l0.9,2.2l0.5,0.6l0.8-0.4l4.8-6.5l1.6-1.5l1.3-0.1l3.2,3l0.5,0.3l0.5,0l0.5-0.1l0.5,0l1.4,0.6l0.4,0.1l0.8-0.2l3.6-1.5l0.7-0.5l0.6-0.6l0.6-0.9l1.3-1.3l3.1-1.5l0.2-0.1l4.5-3.6l3.3-1.6l1-0.2l2-0.2l1-0.3l0.7-0.7l0.3-1.1l0.2-2.3l0.5-1.9l-0.2-0.6l-0.8-0.7l-0.2-0.7l-0.1-3.1l0.1-0.9l1.3-1.3l3.8-1.2l1.4-1l0.3-0.6l0-0.4l-0.2-0.3l-1.3-0.5l-0.3-0.3l-0.7-0.9l-2.5-2.3l-0.3-0.8l-0.2-1.1l-0.5-0.8l-0.3-0.8l0.2-1.1l0.8-0.8l1-0.2l10.7,0.2l4.3-0.9l4-1.9l0.7-0.7l1.2-1.6l0.7-0.7l0.9-0.5l1-0.2l6.1-0.4l2-0.5l4.6-2.7l1.5-0.5l0.8-0.1l0.8-0.1l1.4,0.3l4.7,1.8l0-0.8l-0.5-2.9l0-1.1l0.4-1l0.6-0.8l3.3-2.5l1.7-0.9l1.8-0.3l2,0.3l0.8,0.3l0.6,0.1l0.5-0.4l0.8-2.5l0.6-0.7l0.8-0.5l0.9-0.4l3.6-0.8l1.7-0.6l1.6-1.3l1-1.2l3.9-6l0.9-2.1l0.6-2.3l0.2-2.4l-0.1-1.3l-0.7-2.3l-0.2-1.3l0-1.2l0.2-1.3l0.6-2.4l0.8-2l5.3-9.7l1.8-3.3l0.7-2.1l-0.2-2.4l-0.9-4.7l0.2-2.4l0.9-1.6l1.4-1.1l8.9-4.8l3.6-1.2l20.9-0.5l0.7,0l1.7-0.9l2.3-3.2l1.4-1.4l0.6-0.9l0.3-1.3l0-1.4l-0.4-2.7l0.2-1.4l0.5-1.3l0.6-1.2l0,0l0,0l0.5-1l0.5-0.6l0.6-0.4L302,89l2,0l0.7-0.5l0.3-1.6l0.1-0.9l0.7,0.3l1,0.2l0.4,0.3l0.8,1.9l0.4,0.6l0.3,0.4l0.9,0.7l11,4.2l0.9,0.8l1.4,1.8l0.9,0.8l1,0.5l0.6,0.1l1.6-0.1l0.5,0.1l0.7,0.6l0.5,0.1l0.4,0.2l0.3,0.2l0.8,0.8l1,0.7l1.3,0.1l3.4-1.1l1.2-0.2l0.5,0.2l0.7,1.1l0.6,0.3l0.5-0.1l0.4-0.3l0.8-0.8l0.9-0.8l0.8-0.5l1-0.3l1.3-0.1l1.2,0.1l3.3,1.4l0.6,0.1l1.3,0.1l0.5-0.2l1-0.8l0.5-0.2l6.4-0.3l4.5-1.1l2.4,0.1l0.9,0.4l2,1.4l1,0.3l0.6,0.6l0.8,2.7l0.5,0.9l1,0.6l2.2,0.8l1,0.9l0.5,1.1l0.4,1.1l0.6,0.9l1.1,0.4l1.1-0.2l1.9-1.2l1.3-0.3l1.2-0.1l1.1-0.3l1-0.5l1-0.7l1.6-1.6l0.9-0.7l1-0.3l1.1,0.6l0.9,2.6l0.8,0.7l0.5-0.2l0.4-0.6l0.3-0.6l0.3-0.3l0.5-0.1l0.9-0.3l0.6-0.1l0.6,0.2l1.1,0.8l0.5,0.3l0.6,0.1l1.8-0.1l1,0.3l0.9,0.5l0.6,0.8l0.2,1.2l-0.4,3.9l0.1,0.9l0.6,0.8l1.1,0.8l1.2,0.6l2.2,0.5l0.7,0.8l0.5,1.1l0.8,1.3l0.5,0.5l1.2,0.6l0.4,0.4l1.7,2.1l0.3,0.5l0.2,0.5l0.2,0.5l0.4,0.3l0.2,0l0.4,0l0.6-0.2l0.5-0.3l3.3-2.8l0.6-0.4l0.9-0.4l0.8-0.8l0.9-0.8l1.3-0.2l2,0.7l1.2,0l0.5-0.9l-0.3-2.6l0-1.2l0.4-1l0.9-0.7l1,0.1l1,0.4l1,0.2l1.3-0.1l1-0.5l0.3-0.9l-0.7-1.4l3.1-0.2l2.3-0.5l0.5,0l0.4-0.3l0.7-1.2l0.2-0.3l1-0.1l1.8-0.6l0.9-0.1l0.2-0.5l0.3-1l0.6-0.9l1.1-0.2l-0.3-0.8l-0.1-0.3l-0.3-0.2l0.6-0.7l0.9,0l1.9,0.3l1-0.1l0.6,0.1l0.6,0.3l1.8,1.2l0.6,0l0.2-0.6l-0.1-1.3l-0.6-1.9l0.2-0.7l1.1-0.4l1,0.3l0.6,0.8l0.4,1l0.7,0.9l0.7,0.3l0.5-0.1l0.3-0.5l-0.2-0.9l-0.2-0.3l-0.8-0.6l-0.3-0.4l-0.3-0.7l0.1-0.2l0.3,0.1l0.2,0.1l3.4,0.4l1,0.5l1,0.9l0.8,1.1l0.7,2.2l1,0.9l1.1,0.7l0.9,0.8l0.9,2.2l0.5,0.5l1.1,0.8l0.3,0.1l4.7,3.2l1-0.1l1-0.5l1.1-0.2l0.2,0l0.6-0.2l0.5-0.5l0.8-0.9l2-1.3l0.8-0.8l1.7-2.9l0.1-0.8l-0.9-0.2l-0.8-0.4l0.4-1.4l-0.4-0.6l-0.3-2.1l-0.4-0.9l-0.3-0.4l-0.1-0.5l-0.1-0.6l0-0.6l0.1-0.2l0.1,0l0.1-0.1l0-0.3l-0.1-0.3l-0.5-0.1l-0.1-0.2l0-2.4l0.1-1.1l0.3-1l0.3-0.3l0.7-0.5l0.4-0.4l0.2-0.3l0.3-0.7l0.2-0.3l2.2-1.6l1.1-1l0.8-2.6l1-0.4l6.7,0.6l1.1-0.2l2.1-0.9l1.2-0.2l0.4,0.1l1.1,0.3l0.4,0.3l0.5,0.3l0.5-0.3L505,85l0.5-0.2l1-0.3l2.1-1.1l1.2,0.1l0.8,0.7l0.5,1l0.5,0.9l1,0.4l0.6,0.1l0.3,0.3l0.2,0.4l0.3,0.3l0.2,0.2l0.5,0.2l1.5,0.3l-0.3-0.5l1.4,0.2l1.5,0.5l1.5,0.3l1.4-0.6l1.7-2.1l0.3-0.2l0.1-0.5l0.7-1.8l0.1,0l0.9,0l0.2,0.1l0.3-0.3l0.1-0.1l0.3-0.5l0.1-0.4l-0.1-0.6l0-0.5l0.2-0.2l0.2-0.2l0.6-0.9l0.1-0.8l0.2-0.5l0.1-0.5l-0.1-0.9l-0.5-1.8l-0.1-0.9l0.3-0.7l-0.5-0.4l-0.4-0.7l-0.3-0.8l-0.1-0.9l-0.3-0.5l-1.6-0.5l-0.6-0.3l-0.8-1.3l-0.7-1.8l-0.2-1.9l0.6-1.6l1,0.8l1.1,0.2l1.2-0.2l1.2-0.4l-0.4-0.5l-0.2-0.5l0-0.5l0.2-0.6l0.3-0.2l0.6-0.1l0.5-0.2l0.2-0.6l0.2-0.3l0.2-0.1l1-0.5l0.4-0.3L532,56l2.2-2.3l0.5-0.4l1.7-0.7l0.5-0.5l0.6-1.1l1.3-3.5l1.4-2.9l0.5-1.5l0.6-0.3l0.7-0.2l0.5-0.3l0.7-2.1l0-0.5l-0.1-0.6l0-0.7l0.2-0.6l0.5-0.3l1.1,0.1l0.5-0.3l1.7-1.3l0.4-0.7l-1-0.8v-0.4l0.9-0.6l2.9-0.3l0.6-1.1l0.3-0.4l0.8-0.2l1.6,0l0.4,0.1l0.8,0.3l0.4,0l0.3-0.2l0.2-0.3l0.3-0.3l0.6-0.1l2,1l1.2,0.3l0.5-0.6l-0.2-1.4l0.4-0.4l1.1,0l0.6,0.2l0.6,0.3l0.5,0.4l0.5,0.6l0.3,0.5l0.4,1.1l0.3,0.5l0.5,0.4l0.4,0l0.4-0.2l0.6,0l0.6,0.1l1.4,0.7l1.9,1.4l3,3.2l4.1,1.7l1.7,1.1l1.2,1.8l0.3,2.8l-0.3,1.4l-0.9,2.7l-0.3,1.8l-0.9,1.8l-0.7,2.6l-1.5,2.8l-0.3,1.6l-0.5,1.4l-0.1,0.7l0.2,0.8l0.3,0.1l0.4-0.1l0.5,0.1l1.9,1.5l1.1,0.5l1-0.5l0.9-0.7l6-2.1l1.8,0.1l1.5,1l1.5,1.9l-0.4,0.4l0.2,0.8l0.1,1.4l0,1.5l-0.2,1.1l-0.8,1.1l-1.8,1.2l-0.4,1.1l0.1,0.6l0.4,1.3l0.1,0.7l-0.1,0.6l-0.6,1.9l-0.2,1.9l-0.1,0.6l-0.2,0.5l-0.6,0.8l-0.2,0.4l-0.2,2.7l0.7,5l-0.5,2.5l-0.6,1.4l-0.2,0.9l0.4,2.4l0.1,2.6l-0.1,1.3l-0.3,0.8l0,1.7l-1.8,3.1l0.2,1.5l-0.3,0.6l-0.3,0.9l-0.4,2.5l-0.1,3.7l0.1,0.8l0.3,0.7l0.8,1.3l0.2,0.7v2.5l0.2,1.3l0.4,1.1l2.8,4.5l0.5,1.2l0.3,2.8l0.4,1.3l0.5,1.2l0.7,1.1l1.7,1.7l2.1,1.1l2.3,0.5h2.4l2.4-0.5l1.9-0.8l14.3-10.7l1.3-1.4l1.7-1l0.4-0.5l0.7-1.1l0.5-0.6l1.9-1.3l5-2l2.2-0.5l3.4,0.6l1.7-0.8l7.3-1.1l0.4-0.6l0.3-1.2l2-3.2l2.3-4.8l1.5-2l2-1.2l2.3-0.4l1.2-0.4l1.1-1.3l3.5-2.1l3.5-0.4l1-0.7l0.6-0.9l0.8-1.8l0.8-0.9l1.9-1.5l0.4-0.2l1.1,0.4l0.5-0.3l2.4-2.6l0.8-0.6l1-0.3l1.2-0.1l1.2,0.2l0.8,0.5l0.8,0.2L683,92l2.2-0.1l5.9,2.2l3.4,0.9l2.1,0l1.8,0.2l-0.3,1.6l-0.1,0.5l0,2.6l-0.3,0.9l-0.8,1l-0.8,0.7l-0.7,0.4l-1.9,0.2l-1,0.4l-1,0.9l-0.6,1.2l0.2,1.3l0.8,0.5l2.1-0.7l1,0.1l0.4,0.3l0.7,1l0.3,0.3l0.5,0l0.8-0.6l0.5-0.2l1.1,0.1l0.8,0.2l0.7-0.2l1.9-1.7l1-0.3l2.1-0.2l2.8-1.3l1-0.2l3.7-1.4l5.5-1.1l1.2-0.5l0.9-1.1l0.1-2.1l0.8-0.8l1.3,0l1.4,0.4l1.2-0.2l0.6-1.7l0.3,0.8l0.6-0.4l0.6,0l0.5,0.3l0.7,1.2l0.5,0.2l0.6,0l1.4,0.3l0.9-0.2l0.9-0.1l1.1,0.5l1.8,0.5l0.4,0.1l0.4,0l5-0.3l1.4-0.8l6.3,3.9l1.4,1.5l2.3,3.9l1.5,0.8l-3.9,1l-0.9,0.1l-0.5-0.4l-1.9-4.2l-0.3-0.5l-0.8-0.1l-0.6,0.4l-0.5,0.7l-1.1,1l-0.3,0.1l-1,0.1l-0.2,0.3l-0.2,0.4l-0.6,0.6l-0.1,0.2l-0.2,0.2l-0.4,0.2l-0.3-0.1l-0.6-0.7l-0.3-0.2l-0.7,0.1l-2.2,0.6l-1.6,0l-0.6,0.4l-0.5,1l-0.4,1.2l-0.5,0.8l-0.7,0.4l-1,0.2l-1.9-0.2l-0.7,0.3l-0.1,1.2l0.8,1.3l1.6,1.2l3.1,1.5l0.9,1l0.6,1.2l0.7,1L737.2,120.4z'/%3E%3C/svg%3E"); /* Add path if you have the shape file */

    /* --- Fonts --- */
    --font-headings: 'Oswald', sans-serif;
    --font-body: 'Lato', sans-serif;
    --font-poppins: 'Poppins', sans-serif;
}

/* ---------------------------------- */
/* RESET & BASE                       */
/* ---------------------------------- */
* { margin: 0; padding: 0; box-sizing: border-box; }
html { scroll-behavior: smooth; }

body {
    font-family: var(--font-body);
    color: var(--color-dark-text);
    line-height: 1.6;
    background-color: var(--color-white); /* UPDATED BG */
    display: flex;
    flex-direction: column;
    min-height: 100vh;
    overflow-x: hidden;
}

/* Drupal Admin Toolbar Fix */
body.toolbar-fixed { padding-top: 39px; }
body.toolbar-horizontal.toolbar-fixed { padding-top: 79px; }

/* UPDATED STRICT CONTAINER WIDTH */
.container {
    width: 100%; /* Ensure fluid behavior below max-width */
    max-width: var(--container-width); 
    margin: 0 auto;
    padding: 0 20px;
    position: relative;
}

a { text-decoration: none; color: var(--color-dark-blue); transition: color 0.3s ease; }
a:hover { color: var(--color-orange); }

/* Buttons */
.btn { display: inline-block; padding: 12px 28px; border-radius: 5px; font-family: var(--font-headings); font-weight: 500; text-transform: uppercase; text-align: center; transition: all 0.3s ease; border: 2px solid transparent; white-space: nowrap; letter-spacing: 1px; cursor: pointer; }
.btn-orange { background-color: var(--color-orange); color: var(--color-white) !important; border-color: var(--color-orange); border-radius: 0px 30px 0px 30px;}
.btn-orange:hover { background-color: var(--color-white); color: var(--color-orange) !important; border-color: var(--color-orange); }

/* New Homepage Buttons */
.btn-primary { display: inline-block; background: linear-gradient(135deg, #2d2d2d 0%, #1a1a1a 100%); color: #fff; padding: 18px 45px; border-radius: 0px 30px 30px 30px; text-decoration: none; font-family: var(--font-headings); font-weight: 700; font-size: 1rem; letter-spacing: 1px; transition: all 0.3s; box-shadow: 0 8px 30px rgba(0, 0, 0, 0.2); }
.btn-primary:hover { background: linear-gradient(135deg, var(--color-orange) 0%, #d4943a 100%); transform: translateY(-3px); box-shadow: 0 12px 40px rgba(233, 150, 72, 0.4); color: #fff; }

.btn-dark { display: inline-block; background: linear-gradient(135deg, #222 0%, #1a1a1a 100%); color: #fff; padding: 14px 45px; font-family: var(--font-headings); font-weight: 500; font-size: 0.95rem; letter-spacing: 1px; text-decoration: none; transition: all 0.3s; border-radius: 0px 30px 30px 30px; box-shadow: 0 6px 25px rgba(0, 0, 0, 0.15); }
.btn-dark:hover { background: linear-gradient(135deg, var(--color-orange) 0%, #d4943a 100%); transform: translateY(-3px); box-shadow: 0 10px 35px rgba(233, 150, 72, 0.4); }

/* ---------------------------------- */
/* HEADER & NAVIGATION (REFACTORED)   */
/* ---------------------------------- */

/* 1. CONTAINER & VISIBILITY FIXES */
/* We must allow 'overflow: visible' so flyout menus aren't cut off */
.site-header { 
    position: sticky; 
    top: 0; 
    left: 0; 
    width: 100%; 
    height: var(--header-height); 
    background-color: var(--color-white); 
    box-shadow: 0 2px 10px rgba(0,0,0,0.08); 
    z-index: 500; 
    display: flex; 
    align-items: center; 
    transition: height 0.3s ease;
    overflow: visible !important; /* Critical for flyouts */
}

.header-container { 
    display: flex; 
    justify-content: space-between; 
    align-items: center; 
    width: 100%; 
    overflow: visible !important; /* Critical for flyouts */
}

/* 2. LOGO & ACTIONS */
.logo a { display: block; line-height: 0; }
.logo img { height: 170px; width: auto; transition: height 0.3s ease; }

.header-actions { display: flex; align-items: center; gap: 20px; }
.header-actions a { border-radius: var(--brand-radius); }
.mobile-nav-toggle { display: none; font-size: 2rem; cursor: pointer; color: var(--color-dark-text); }

/* 3. MAIN NAVIGATION BAR */
.main-nav { overflow: visible !important; }

/* Level 1: Top Bar Items */
.main-nav ul:not(.dropdown-menu) { 
    display: flex; 
    list-style: none; 
    align-items: center; 
    margin: 0; 
    padding: 0; 
}

.main-nav ul:not(.dropdown-menu) > li { 
    position: relative; /* Anchor for dropdowns */
    list-style: none; 
}

.main-nav ul:not(.dropdown-menu) > li > a { 
    font-family: var(--font-headings); 
    position: relative; 
    display: inline-block; 
    width: auto; 
    padding: 1.7rem 1rem; 
    font-size: 1.5rem; 
    line-height: 130%; 
    color: var(--color-dark-text); 
    font-weight: 500; 
    text-transform: uppercase; 
    letter-spacing: 0.5px; 
}

/* Orange underline effect on Level 1 */
.main-nav ul:not(.dropdown-menu) > li > a::after { 
    content: ''; 
    position: absolute; 
    bottom: 22px; 
    left: 1rem; 
    width: 0; 
    height: 2px; 
    background-color: var(--color-orange); 
    transition: width 0.3s ease; 
}
.main-nav ul:not(.dropdown-menu) > li > a:hover::after, 
.main-nav ul:not(.dropdown-menu) > li > a.is-active::after { 
    width: calc(100% - 2rem); 
}

/* 4. DROPDOWN MENUS (GENERAL) */
.dropdown-menu { 
    display: none; /* Hidden by default */
    position: absolute; 
    background-color: var(--color-white); 
    box-shadow: 0 8px 16px rgba(0,0,0,0.1); 
    border-radius: 0 0 5px 5px; 
    padding: 0; 
    min-width: 260px; 
    list-style: none; 
    z-index: 1001; 
    flex-direction: column;
    text-align: left;
}

/* Link Styling inside Dropdowns */
.dropdown-menu li { width: 100%; display: block; position: relative; }
.dropdown-menu li a { 
    font-family: var(--font-body); 
    display: block; 
    width: 100%; 
    padding: 15px 20px; 
    font-size: 1rem; 
    border-bottom: 1px solid var(--color-border-grey); 
    border-left: 5px solid transparent; 
    transition: all 0.2s ease; 
    color: var(--color-dark-text); 
    text-transform: none; 
}
.dropdown-menu li a:hover { 
    background-color: var(--color-light-grey); 
    border-left-color: var(--color-orange); 
    color: var(--color-orange); 
    padding-left: 25px; 
}

/* ----------------------------------------------------------- */
/* FIXED LEVEL 3 FLYOUT POSITIONING                           */
/* ----------------------------------------------------------- */

/* 5. LEVEL 2: FIRST DROPDOWN (Drops DOWN) */
.main-nav li.dropdown:hover>.dropdown-menu {
    display: block;
    top: 100%;
    left: 0;
}

/* 6. LEVEL 3: NESTED FLYOUT (Flies RIGHT) */

/* Ensure the parent LI is the anchor for the flyout */
.dropdown-menu li {
    position: relative;
}

/* Style and Position the Level 3 Menu */
.dropdown-menu .dropdown-menu {
    display: none;
    position: absolute;

    /* POSITIONING FIX */
    top: 0 !important;
    /* Align with the top of the parent item */
    left: 100% !important;
    /* Push it completely to the right side */
    margin-top: 0;
    margin-left: 0;
    /* Remove any gaps */

    /* Visuals */
    border-radius: 0 5px 5px 5px;
    border-left: 4px solid var(--color-orange);
    box-shadow: 5px 5px 15px rgba(0, 0, 0, 0.15);
    min-width: 260px;
    z-index: 1002;
}

/* Trigger: Show Level 3 ONLY when hovering Level 2 Parent */
.dropdown-menu li:hover>.dropdown-menu {
    display: block;
}

/* 7. ICONS (Chevron Rotation) */
/* Default: Down Arrow (Orange) */
.dropdown > a i.fa-chevron-down { 
    font-size: 0.7em; 
    margin-left: 10px; 
    vertical-align: middle; 
    color: var(--color-orange);
    transition: transform 0.3s ease;
    display: inline-block;
}

/* Rotate: When hovering a sub-menu parent, rotate icon -90deg (to point right) */
.dropdown-menu li.dropdown:hover > a i.fa-chevron-down {
    transform: rotate(-90deg);
}

/* ---------------------------------- */
/* MOBILE NAVIGATION (RESPONSIVE)     */
/* ---------------------------------- */
@media (max-width: 992px) {
    /* Reset Layout */
    :root { --header-height: 90px; }
    .mobile-nav-toggle { display: block; }
    
    /* Mobile Menu Container */
    .main-nav { 
        position: fixed; 
        top: var(--header-height); 
        left: -100%; 
        width: 100%; 
        height: calc(100vh - var(--header-height)); 
        background-color: var(--color-white); 
        transition: left 0.3s ease-in-out; 
        overflow-y: auto !important; /* Needs scroll on mobile */
        border-top: 1px solid var(--color-border-grey); 
    }
    .main-nav.active { left: 0; } 

    /* List Items Stack Vertical */
    .main-nav ul:not(.dropdown-menu) { 
        flex-direction: column; 
        align-items: flex-start; 
        padding-bottom: 50px; 
    }
    .main-nav ul:not(.dropdown-menu) > li { width: 100%; }
    
    /* Level 1 Links */
    .main-nav ul:not(.dropdown-menu) > li > a { 
        display: flex; 
        justify-content: space-between; 
        align-items: center; 
        width: 100%; 
        padding: 20px; 
        font-size: 1.2rem; 
        text-align: left; 
        border-bottom: 1px solid var(--color-border-grey); 
    }
    .main-nav ul:not(.dropdown-menu) > li > a::after { display: none; } 

    /* RESET DROPDOWNS FOR MOBILE (Stacking) */
    /* Force all dropdowns to be static blocks */
    .dropdown-menu,
    .dropdown-menu .dropdown-menu {
        display: block !important; /* Always expanded on mobile */
        position: static !important;
        box-shadow: none;
        border-radius: 0;
        padding: 0;
        background-color: var(--color-light-grey);
        width: 100%;
        border-left: none; /* Remove desktop accent */
    }

    /* Level 2 Indentation */
    .dropdown-menu li a { 
        padding-left: 40px; 
        background-color: #f4f4f4;
    }

    /* Level 3 Indentation (Deep) */
    .dropdown-menu .dropdown-menu li a {
        padding-left: 70px !important;
        background-color: #e9e9e9;
        font-size: 0.95rem;
    }

    /* Reset Icon Rotation on Mobile */
    .dropdown-menu li.dropdown:hover > a i.fa-chevron-down {
        transform: rotate(0deg);
    }
    
    /* Ensure icon stays visible */
    .dropdown > a i.fa-chevron-down {
        display: inline-block;
    }
}

/* ---------------------------------- */
/* HOMEPAGE SPECIFIC STYLES           */
/* ---------------------------------- */
.sub-title { font-family: var(--font-headings); font-size: 1.2rem; color: var(--color-orange); font-weight: 600; letter-spacing: 1px; display: inline-block; margin-bottom: 10px; text-transform: uppercase; }

/* Background Decorations */

/* --- GLOBAL BACKGROUND DECORATIONS --- */
.bg-decorations {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    z-index: 0; /* Behind content */
    pointer-events: none;
    overflow: hidden;
}

.bg-dot {
    position: absolute;
    border-radius: 50%;
    opacity: 0.6; /* UPDATED: Increased from 0.1 to 0.4 (Clearer) */
    filter: blur(0px); /* UPDATED: Removed blur to make them sharp/clear "dots" */
}
/* Define colors if not already defined */
.bg-dot-orange { background-color: var(--color-orange); }
.bg-dot-blue   { background-color: var(--color-dark-blue); }
.bg-dot-purple { background-color: var(--color-main-blue); }

/* Dot Positions (You can adjust these) */
.dot-1 { 
    top: 15%; left: 5%; 
    width: 55px; height: 55px; /* Reduced size */
}

.dot-2 { 
    top: 45%; right: 2%; 
    width: 40px; height: 40px; 
}

.dot-3 { 
    bottom: 15%; left: 10%; 
    width: 50px; height: 50px; 
}

.dot-4 { 
    top: 25%; right: 15%; 
    width: 25px; height: 25px; /* Small detail dot */
}

.dot-5 { 
    bottom: 35%; right: 8%; 
    width: 50px; height: 50px; 
}

.dot-6 { 
    top: 65%; left: 3%; 
    width: 45px; height: 45px; 
}


/* HERO SECTION */
.hero-section { display: flex; align-items: center; overflow: visible; padding-top: 40px; padding-bottom: 40px; }
.hero-container-wide { width: 100%; max-width: 1920px; margin: 0 auto; padding: 0 clamp(20px, 8vw, 154px); position: relative; z-index: 2; display: flex; align-items: center; justify-content: space-between; gap: 60px; }
.hero-text { flex: 1.2; max-width: 700px; z-index: 10; animation: fadeInUp 0.8s ease-out; display: flex; flex-direction: column; align-items: flex-start; gap: 20px; }
@keyframes fadeInUp { from { opacity: 0; transform: translateY(30px); } to { opacity: 1; transform: translateY(0); } }
.hero-text h1 { font-size: clamp(2.2rem, 3.5vw, 3.5rem); margin-bottom: 25px; line-height: 1.1; color: var(--color-dark-text); letter-spacing: -0.5px; }
.hero-text p { font-size: clamp(1rem, 1.3vw, 1.15rem); font-weight: 400; margin-bottom: 40px; color: var(--color-dark-text); max-width: 520px; line-height: 1.8; }
.hero-image-wrapper { flex: 1; display: flex; justify-content: flex-end; animation: fadeInRight 0.8s ease-out 0.2s both; }
@keyframes fadeInRight { from { opacity: 0; transform: translateX(30px); } to { opacity: 1; transform: translateX(0); } }
.afghan-map-masked { width: clamp(320px, 45vw, 900px); aspect-ratio: 800 / 592; background-color: #222; background-image: url('../images/hero.jpg'); background-size: cover; background-position: center center; mask-image: var(--afghan-shape-url); -webkit-mask-image: var(--afghan-shape-url); mask-size: contain; mask-repeat: no-repeat; -webkit-mask-size: contain; -webkit-mask-repeat: no-repeat; filter: drop-shadow(0px 25px 50px rgba(0, 0, 0, 0.15)); }

/* SECTORS SECTION */
.sectors-section { padding: clamp(80px, 12vw, 120px) 0; text-align: center; position: relative; }
.section-header { max-width: 750px; margin: 0 auto 80px; }
.section-header h2 { font-size: clamp(2.2rem, 4vw, 3.2rem); margin-bottom: 20px; font-family: var(--font-headings); }
.section-header p { font-size: 1.05rem; line-height: 1.8; color: #666; }

.cards-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 20px; }
.card { background: #ffffff; padding: 40px 20px; border-radius: 0 30px 0 30px; border: none; box-shadow: 0 8px 30px rgba(0, 0, 0, 0.08), 0 4px 15px rgba(0, 0, 0, 0.05); text-align: center; transition: all 0.4s cubic-bezier(0.4, 0, 0.2, 1); position: relative; }
.card:hover { box-shadow: 0 25px 60px rgba(0, 0, 0, 0.12), 0 10px 30px rgba(0, 0, 0, 0.08); }
.card h3 { margin-bottom: 15px; font-size: 1.3rem; transition: all 0.3s ease; font-family: var(--font-headings); }
.card:hover h3 { font-size: 1.4rem; color: var(--color-orange); }
.icon-box { width: 80px; height: 80px; margin: 0 auto 25px; border-radius: 50%; display: flex; align-items: center; justify-content: center; font-size: 35px; transition: all 0.4s; }
.icon-orange { background: rgba(233, 150, 72, 0.12); color: var(--color-orange); }
.icon-green { background: rgba(132, 204, 22, 0.12); color: #84cc16; }
.icon-gold { background: rgba(212, 175, 55, 0.12); color: #d4af37; }
.icon-blue { background: rgba(59, 130, 246, 0.12); color: #3b82f6; }
.card:hover .icon-box { transform: scale(1.1); }
.card p { font-size: 0.9rem; line-height: 1.6; color: #666; }

/* ABOUT SECTION */
.about-section { padding: clamp(80px, 12vw, 120px) 0; position: relative; background: #ffffff; }
.about-container { display: flex; align-items: center; gap: clamp(40px, 6vw, 80px); }
.about-images-wrapper { flex: 1; position: relative; height: clamp(380px, 50vw, 580px); width: 100%; max-width: 600px; min-width: 280px; }
.dotted-blob { position: absolute; width: clamp(300px, 42vw, 580px); height: clamp(300px, 42vw, 580px); left: -50px; top: -40px; background-image: radial-gradient(var(--color-orange) 1.5px, transparent 1.5px); background-size: 20px 20px; border-radius: 50%; z-index: 0; opacity: 0.3; }
.about-images-wrapper img { width: 100%; height: 100%; object-fit: cover; display: block; }
.img-main-box { position: absolute; width: clamp(220px, 32vw, 420px); height: clamp(220px, 32vw, 420px); top: 50%; left: 50%; transform: translate(-50%, -50%); border-radius: 50%; overflow: hidden; z-index: 1; border: 12px solid var(--color-white); box-shadow: 0 25px 60px rgba(0, 0, 0, 0.12); }
.img-sub-box { position: absolute; border-radius: 50%; overflow: hidden; z-index: 2; border: 8px solid var(--color-white); box-shadow: 0 15px 40px rgba(0, 0, 0, 0.1); }
.sub-right { width: clamp(110px, 16vw, 210px); height: clamp(110px, 16vw, 210px); top: 15px; right: -10px; }
.sub-left { width: clamp(90px, 13vw, 150px); height: clamp(90px, 13vw, 150px); bottom: 35px; left: 5px; }
.about-text { flex: 1; padding-left: 20px; }
.title-wrapper { display: flex; align-items: center; gap: 15px; margin-bottom: 15px; }
.dot-ring-blue { width: 18px; height: 18px; border: 3px solid var(--color-dark-blue); border-radius: 50%; display: inline-block; }
.about-text h2 { font-size: clamp(2rem, 3.5vw, 3.2rem); line-height: 1.2; margin-bottom: 25px; color: var(--color-dark-text); text-transform: none; font-family: var(--font-headings); }
.intro-bold { font-weight: 700; color: #000; font-size: 1.1rem; margin-bottom: 20px; }
.desc { color: #555; margin-bottom: 40px; font-size: 1rem; line-height: 1.8; max-width: 550px; }

/* PART 2 - Wrapper for Font */
.part2-wrapper { font-family: var(--font-poppins); }

/* ACHIEVEMENTS SECTION */
.achievements-section { padding: 80px 20px; display: flex; align-items: center; justify-content: space-between; gap: 40px; min-height: 600px; }
.stats-column { flex: 0.8; max-width: 45%; }
.achievements-section .section-title, .trusted-by-section .section-title { font-size: 2.5rem; font-weight: 700; margin-bottom: 40px; line-height: 1.2; color: #222; font-family: var(--font-headings); }
.stats-grid-p2 { display: grid; grid-template-columns: repeat(2, 1fr); gap: 25px; }
.stat-card { background: #fff; padding: 25px; border-radius: 0 25px 0 25px; box-shadow: var(--card-shadow); display: flex; align-items: flex-start; gap: 15px; transition: transform 0.3s ease; }
.stat-card:hover { transform: translateY(-5px); }
.stat-icon { font-size: 1.5rem; color: var(--primary-orange); margin-top: 5px; }
.stat-info h3 { font-size: 1.8rem; font-weight: 700; margin-bottom: 5px; line-height: 1; }
.stat-info p { font-size: 0.75rem; color: var(--text-light); line-height: 1.4; margin-top: 5px; }

.map-column { flex: 1.2; display: flex; justify-content: center; align-items: center; position: relative; }
svg.afghan-map { width: 100%; height: auto; max-height: 500px; filter: drop-shadow(0 15px 30px rgba(0,0,0,0.2)); }
.city-group { cursor: pointer; }
.map-dot { fill: var(--primary-orange); stroke: #ffffff; stroke-width: 4px; r: 7px; animation: pulse-stroke 2s infinite ease-in-out; transition: fill 0.3s ease; }
.city-group:hover .map-dot { fill: var(--primary-purple); }
@keyframes pulse-stroke { 0% { stroke-width: 4px; } 50% { stroke-width: 8px; } 100% { stroke-width: 4px; } }
.map-label { opacity: 0; pointer-events: none; transition: opacity 0.3s ease, transform 0.3s ease; font-family: 'Poppins', sans-serif; font-weight: 700; font-size: 16px; fill: #333; text-anchor: middle; text-shadow: -1px -1px 0 #fff, 1px -1px 0 #fff, -1px 1px 0 #fff, 1px 1px 0 #fff; }
.city-group:hover .map-label { opacity: 1; transform: translateY(-5px); }

/* FEATURE SECTION */
.feature-section { padding: 80px 20px 150px; position: relative; z-index: 5; }
.feature-wrapper { position: relative; width: 100%; min-height: 500px; }
.feature-bg-image { width: 100%; height: 550px; overflow: hidden; position: relative; z-index: 1; border-radius: 0 60px 0 60px; box-shadow: 0 10px 30px rgba(0,0,0,0.1); }
.feature-bg-image img { width: 100%; height: 100%; object-fit: cover; }
.feature-text-overlay { position: absolute; bottom: 60px; left: 60px; z-index: 2; color: white; text-shadow: 0 4px 15px rgba(0,0,0,0.6); }
.feature-text-overlay span { color: var(--primary-orange); font-weight: 700; font-size: 0.9rem; letter-spacing: 1px; text-transform: uppercase; display: block; margin-bottom: 10px; }
.feature-text-overlay h2 { font-size: 3rem; font-weight: 700; line-height: 1.1; max-width: 450px; }
.info-card { position: absolute; z-index: 10; background: white; padding: 45px; box-shadow: var(--card-shadow); width: 45%; right: 50px; bottom: -100px; border-radius: 0 60px 0 60px; }
.card-tabs { display: flex; justify-content: space-between; margin-bottom: 30px; border-bottom: 1px solid #eee; padding-bottom: 20px; }
.tab { display: flex; flex-direction: column; align-items: center; gap: 10px; color: #ccc; font-size: 0.75rem; cursor: pointer; transition: all 0.3s ease; text-align: center; }
.tab i { font-size: 1.4rem; transition: all 0.3s ease; }
.tab:hover { color: var(--primary-purple); }
.tab.active { color: var(--primary-orange); font-weight: 600; }
.tab.active i { transform: scale(1.1); }
.info-content h3 { font-size: 1.8rem; font-weight: 700; margin-bottom: 15px; color: #222; }
.info-content p { color: var(--text-light); font-size: 1rem; line-height: 1.8; animation: fadeIn 0.5s ease; }
@keyframes fadeIn { from { opacity: 0; transform: translateY(5px); } to { opacity: 1; transform: translateY(0); } }

/* PARTNERS SECTION */
.trusted-by-section { position: relative; width: 100%; padding: 100px 20px 80px; text-align: center; overflow: hidden;  margin-top: 50px; }
.trusted-by-section p { color: var(--text-light); margin-bottom: 60px; }
.logo-scroller { position: relative; z-index: 2; max-width: 1200px; margin: 0 auto; padding: 2.5rem 0; background: #ffffff;  border-radius: 20px;  overflow: hidden; mask-image: linear-gradient(to right, transparent, black 15%, black 85%, transparent); }
.scroller-inner { display: flex; gap: var(--gap); width: max-content; animation: scroll var(--scroll-duration) linear infinite; }
.logo-scroller:hover .scroller-inner { animation-play-state: paused; }
.scroller-slide { display: flex; align-items: center; gap: var(--gap); padding-right: var(--gap); }
@keyframes scroll { to { transform: translateX(calc(-50% - var(--gap) / 2)); } }
.partner-logo { display: flex; align-items: center;  }
.partner-logo img { height: 65px; width: auto; filter: grayscale(1); opacity: 0.8; transition: filter 0.3s ease, opacity 0.3s ease, transform 0.3s ease; display: block; }
.partner-logo img:hover { filter: grayscale(0); opacity: 1; transform: scale(1.1); }
.partner-logo:hover { opacity: 1; transform: scale(1.05); color: var(--primary-purple); }

/* CTA SECTION */
.cta-section { margin-top: 60px; margin-bottom: 80px; height: 450px; position: relative; overflow: hidden; border-radius: 0 60px 0 60px; width: 100%; max-width: var(--container-width) !important; margin-left: auto; margin-right: auto; }
.cta-bg { position: absolute; width: 100%; height: 100%; object-fit: cover; }
.cta-overlay { position: absolute; top: 0; left: 0; width: 60%; height: 100%; background: linear-gradient(90deg, #2d2621 0%, rgba(45, 38, 33, 0.9) 60%, rgba(45, 38, 33, 0) 100%); display: flex; flex-direction: column; justify-content: center; padding-left: 10%; color: white; }
.cta-content { max-width: 450px; z-index: 10; position: relative; }
.cta-label { color: var(--primary-orange); font-size: 0.9rem; font-weight: 700; margin-bottom: 20px; text-transform: uppercase; letter-spacing: 1px; }
.cta-title { font-size: 2.8rem; font-weight: 700; line-height: 1.2; margin-bottom: 20px; }

/* FOOTER (Kept from prev) */
.site-footer { margin-top: auto; background-color: var(--color-white); color: var(--color-footer-text); }
.footer-accent-line { width: 100%; height: 2px; background-color: var(--color-orange); margin-bottom: 60px; }
.footer-content { display: grid; grid-template-columns: 1.5fr 1fr 1fr 1fr; gap: 40px; margin-bottom: 50px; }
.footer-col h2 { font-family: var(--font-headings); color: var(--color-footer-text); font-weight: 500; text-transform: uppercase; font-size: 1.125rem; margin-bottom: 25px; letter-spacing: 1px; line-height: 140%; }
.footer-col ul { list-style: none; padding: 0; margin: 0; }
.footer-col ul li { margin-bottom: 12px; }
.footer-col ul a { font-family: "Lato", helvetica, sans-serif; color: var(--color-footer-text); font-weight: 400; font-size: 0.95rem; line-height: 130%; display: inline-block; }
.footer-col ul a:hover { color: var(--color-orange); text-decoration: none; }
.social-links { display: flex; gap: 30px; }
.social-links a { color: var(--color-orange); font-size: 1.2rem; transition: color 0.3s ease; }
.social-links a:hover { color: var(--color-footer-text); }
.footer-separator { border: 0; height: 1px; background: #999; margin-bottom: 25px; }
.footer-bottom { padding-bottom: 40px; }
.legal-nav, .footer-bottom ul { list-style: none; display: flex; flex-wrap: wrap; gap: 15px; margin-bottom: 15px; padding: 0; }
.legal-nav li, .footer-bottom ul li { display: flex; align-items: center; margin-left: 0; padding-left: 0; }
.legal-nav li:not(:last-child)::after, .footer-bottom ul li:not(:last-child)::after { content: '|'; margin-left: 15px; color: var(--color-vertical-divider); }
.legal-nav a, .footer-bottom ul a { font-family: "Lato", helvetica, sans-serif; color: var(--color-footer-text); font-weight: 400; line-height: 130%; }
.legal-nav a:hover, .footer-bottom ul a:hover { color: var(--color-orange); text-decoration: none; }
.footer-message-block p { font-family: "Lato",helvetica,sans-serif; font-size: 1rem; line-height: 1.3; color: #222221; padding: 0; }

/* ---------------------------------- */
/* GLOBAL INNER PAGE HERO (Shared)    */
/* ---------------------------------- */
.hero, .inner-hero {
    height: var(--hero-height);
    width: 100%;
    background-size: cover;
    background-position: center center;
    background-repeat: no-repeat;
    background-color: #222;
    display: flex;
    justify-content: center;
    align-items: center;
    position: relative;
    margin-bottom: 0px; /* Reset margins */
}

.hero h1, .inner-hero h1 {
    font-family: var(--font-headings);
    color: var(--color-white);
    font-size: clamp(2.5rem, 5vw, 4.5rem);
    font-weight: 900;
    text-transform: uppercase;
    text-align: center;
    padding: 0 20px;
    text-shadow: 0 2px 15px rgba(0,0,0,0.5);
    z-index: 2;
}

.hero-deco-line {
    position: absolute;
    bottom: 0;
    left: 0;
    display: flex;
    gap: 5px;
}
.hero-deco-line div { height: 10px; background-color: var(--color-orange); }
.line-1 { width: 300px; } .line-2 { width: 30px; } .line-3 { width: 15px; } .line-4 { width: 3px; }

.section-label { color: var(--color-orange); font-family: var(--font-headings); font-weight: 600; font-size: 1rem; text-transform: uppercase; letter-spacing: 2px; display: block; margin-bottom: 15px; text-align: center; }

/* Intro Section */
.intro { text-align: center; padding: 0 0 50px; max-width: 900px; margin: 0 auto; }
.intro h2 { font-size: 2.5rem; margin-bottom: 25px; font-weight: 500; font-family: var(--font-headings); line-height: 1.2; }
.intro-content { text-align: left; color: #444; font-size: 1.05rem; font-family: var(--font-body); }

/* ---------------------------------- */
/* WHAT WE DO PAGE                    */
/* ---------------------------------- */
.overview-section { text-align: center; padding: 60px 0 50px; max-width: 900px; margin: 0 auto; display: flex; flex-direction: column; align-items: center; }
.overview-section h2 { font-size: 3rem; margin-bottom: 20px; font-weight: 700; font-family: var(--font-headings); color: var(--color-dark-text); width: 100%; }
.overview-intro { font-size: 1.05rem; color: #666; line-height: 1.6; max-width: 800px; }
.sectors-view-grid .views-element-container > div { display: grid !important; grid-template-columns: repeat(2, 1fr) !important; gap: 40px; width: 100%; margin-top: 20px; }
.sector-card-link { text-decoration: none; color: inherit; display: block; height: 100%; }
.sector-card { background: #fff; border-radius: 0 30px 0 30px; overflow: hidden; box-shadow: 0 10px 30px rgba(0,0,0,0.08); transition: all 0.3s ease; display: flex; flex-direction: column; height: 100%; border: 1px solid #eee; }
.sector-card:hover { transform: translateY(-10px); box-shadow: 0 20px 50px rgba(0,0,0,0.15); border-color: transparent; }
.card-image { height: 260px; width: 100%; overflow: hidden; position: relative; }
.card-image img { width: 100%; height: 100%; object-fit: cover; transition: transform 0.5s ease; }
.sector-card:hover .card-image img { transform: scale(1.05); }
.card-content { padding: 30px 40px; text-align: center; flex-grow: 1; display: flex; flex-direction: column; align-items: center; }
.card-title { font-size: 1.6rem; font-weight: 600; margin-bottom: 20px; position: relative; color: var(--color-dark-text); font-family: var(--font-headings); text-transform: capitalize; }
.card-title::after { content: ""; position: absolute; bottom: -10px; left: 50%; transform: translateX(-50%); width: 40px; height: 3px; background-color: var(--color-orange); }
.card-desc { font-size: 0.95rem; color: #666; font-family: var(--font-body); line-height: 1.6; }
.read-more-btn { margin-top: auto; padding-top: 20px; font-size: 0.9rem; font-weight: 700; color: var(--color-orange); text-transform: uppercase; letter-spacing: 1px; display: flex; align-items: center; gap: 8px; font-family: var(--font-headings); }
.sector-card:hover .read-more-btn i { transform: translateX(5px); transition: transform 0.3s ease; }

/* ---------------------------------- */
/* NEWS / MEDIA CENTER STYLES (NEW)   */
/* ---------------------------------- */
.news-section { padding: 80px 0; }
.news-main-header { border-bottom: 4px solid var(--color-dark-text); padding-bottom: 10px; margin-bottom: 50px; }
.news-main-header h2 { font-size: 2.5rem; margin: 0; text-transform: uppercase; font-family: var(--font-headings); color: var(--color-dark-text); }

.news-item { display: grid; grid-template-columns: 350px 1fr; gap: 40px; margin-bottom: 50px; border-bottom: 1px solid #eee; padding-bottom: 50px; }
.news-item:last-child { border-bottom: none; }
.news-img { width: 100%; height: 230px; overflow: hidden; border-radius: var(--brand-radius); }
.news-img img { width: 100%; height: 100%; object-fit: cover; transition: transform 0.5s; }
.news-item:hover .news-img img { transform: scale(1.05); }

.news-meta { font-size: 0.85rem; font-weight: 700; color: #999; margin-bottom: 10px; text-transform: uppercase; letter-spacing: 1px; }
.news-meta span { color: var(--color-orange); margin-left: 10px; }
.news-title { font-size: 1.8rem; margin-bottom: 15px; line-height: 1.2; color: var(--color-dark-text); font-weight: 700; text-transform: uppercase; font-family: var(--font-headings); }
.news-excerpt { font-size: 1rem; color: #666; margin-bottom: 20px; line-height: 1.6; }
.read-more { color: var(--color-orange); font-weight: 700; text-transform: uppercase; text-decoration: none; font-family: var(--font-headings); font-size: 0.9rem; display: inline-flex; align-items: center; gap: 5px; transition: gap 0.3s; }
.read-more:hover { gap: 10px; color: var(--color-dark-blue); }

/* --- Single Article Styles --- */
.article-header-section { background: #fff; padding: 100px 0 60px; border-bottom: 1px solid #eee; }
.article-meta { color: var(--color-orange); font-weight: 700; text-transform: uppercase; font-size: 0.9rem; letter-spacing: 1px; margin-bottom: 15px; display: block; }
.article-title { font-family: var(--font-headings); font-size: 3rem; color: var(--color-dark-text); line-height: 1.2; text-transform: uppercase; max-width: 1000px; margin: 0 auto; text-align: center; }

.article-content-wrapper { max-width: 1000px; margin: 60px auto; } 
.featured-img { width: 100%; height: 500px; object-fit: cover; border-radius: var(--brand-radius); margin-bottom: 50px; box-shadow: 0 20px 40px rgba(0,0,0,0.1); }

.article-body { font-size: 1.15rem; color: #444; }
.article-body p { margin-bottom: 25px; }
.article-body h3 { font-family: var(--font-headings); font-size: 1.8rem; color: var(--color-dark-blue); margin-top: 40px; margin-bottom: 15px; }
.lead-text { font-size: 1.3rem; font-weight: 300; color: #222; margin-bottom: 30px; }

/* Quote Box Component */
.quote-box { background-color: #fff; border-left: 5px solid var(--color-orange); padding: 30px; margin: 40px 0; font-style: italic; font-size: 1.2rem; color: #333; border-radius: 0 20px 20px 0; box-shadow: 0 10px 30px rgba(0,0,0,0.05); }
.quote-author { display: block; margin-top: 15px; font-size: 0.9rem; font-weight: 700; color: var(--color-dark-blue); font-style: normal; text-transform: uppercase; }

/* Top Nav (Back Button) */
.top-bar { padding: 30px 0; }
.back-btn { text-decoration: none; color: var(--color-dark-text); font-weight: 700; font-family: var(--font-headings); display: inline-flex; align-items: center; gap: 10px; font-size: 1rem; transition: color 0.3s; }
.back-btn:hover { color: var(--color-orange); }

/* --- OTHER PREV STYLES (Project, Sector, etc.) --- */
/* About Page Stats */
.stats-section { display: flex; flex-wrap: wrap; align-items: center; gap: 60px; padding: 50px 0; }
.stats-grid { flex: 0 0 40%; display: grid; grid-template-columns: 1fr 1fr; gap: 20px; min-width: 300px; }
.stats-text { flex: 1; text-align: left; }
.stats-text h2 { font-family: var(--font-headings); font-size: 2.5rem; margin-bottom: 20px; }
.stats-desc, .stats-desc p { color: #5a5a5a; font-family: var(--font-body); font-size: 1rem; line-height: 1.7; margin-bottom: 1rem; }
.stats-grid .stat-card { align-items: center; padding: 20px; } 
.stats-grid .stat-number { font-family: var(--font-headings); font-size: 1.5rem; font-weight: 500; color: var(--color-dark-text); line-height: 1.1; }
.stats-grid .stat-label { font-family: var(--font-headings); font-size: 0.75rem; font-weight: 400; color: #666; margin-top: 2px; text-transform: uppercase; }

/* Mission & Vision */
.mission-vision-section { padding-top: 20px; padding-bottom: 60px; }
.main-image-wrapper { width: 100%; height: 500px; overflow: hidden; margin-bottom: 40px; position: relative; border-radius: 0 80px 0 80px; box-shadow: 0 20px 50px rgba(0,0,0,0.1); }
.main-image-wrapper img { width: 100%; height: 100%; object-fit: cover; object-position: center 20%; }
.mv-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 60px; text-align: left; }
.mv-col h3 { color: var(--color-orange); font-family: var(--font-headings); font-size: 2.8rem; font-weight: 500; margin-bottom: 15px; }
.mv-col p { font-family: var(--font-body); font-size: 1rem; color: #5a5a5a; }

/* Core Values */
.core-values { padding: 80px 0; margin-top: 40px; }
.core-values h2 { font-size: 2.8rem; margin-bottom: 50px; text-align: center; font-family: var(--font-headings); }
.values-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 40px 60px; }
.value-item h4 { font-size: 1.4rem; margin-bottom: 15px; color: var(--color-dark-text); font-weight: 600; display: flex; align-items: center; font-family: var(--font-headings); }
.value-item h4::before { content: ""; display: inline-block; width: 10px; height: 10px; background-color: var(--color-orange); border-radius: 50%; margin-right: 15px; flex-shrink: 0; }
.value-item p { padding-left: 25px; font-family: var(--font-body); color: #5a5a5a; }

/* Timeline */
.history-section { padding: 60px 0 100px; }
.history-section h2 { font-size: 2.8rem; margin-bottom: 20px; text-align: center; font-family: var(--font-headings); }
.history-intro { text-align: center; max-width: 800px; margin: 0 auto 60px; font-size: 1.1rem; color: #666; font-family: var(--font-body); }
.timeline-wrapper { position: relative; width: 100%; height: 150px; margin-bottom: 50px; display: flex; align-items: flex-end; }
.timeline-axis { position: absolute; bottom: 0; left: 0; width: 100%; height: 4px; background-color: #e0e0e0; border-radius: 2px; background-image: linear-gradient(to right, #ccc 2px, transparent 2px); background-size: 20px 100%; }
.timeline-nodes { position: relative; width: 100%; height: 100%; display: flex; justify-content: space-between; align-items: flex-end; z-index: 2; padding: 0 20px; }
.node-item { position: relative; cursor: pointer; display: flex; flex-direction: column; align-items: center; width: 150px; text-align: center; padding-bottom: 4px; transition: transform 0.3s ease; }
.node-item:hover { transform: translateY(-5px); }
.node-content { margin-bottom: 5px; }
.node-title { font-family: var(--font-body); font-weight: 600; color: #777; font-size: 0.85rem; line-height: 1.2; display: block; margin-bottom: 5px; }
.node-year { font-family: var(--font-headings); font-size: 1.8rem; color: var(--color-orange); font-weight: 700; display: block; }
.node-line { width: 2px; height: 30px; background-color: #bbb; transition: all 0.3s ease; }
.node-item.active .node-line { background-color: var(--color-orange); height: 60px; }
.node-item.active .node-year { font-size: 2.2rem; text-shadow: 0 2px 5px rgba(233, 150, 72, 0.3); }
.node-item.active .node-title { color: #000; font-weight: 700; }
.timeline-display { display: none; grid-template-columns: 1fr 1fr; gap: 50px; align-items: center; animation: fadeIn 0.5s ease forwards; margin-top: 30px; }
.timeline-display.active { display: grid; }
.timeline-img { width: 100%; height: 400px; border-radius: 0 60px 0 60px; overflow: hidden; box-shadow: 0 15px 40px rgba(0,0,0,0.1); }
.timeline-img img { width: 100%; height: 100%; object-fit: cover; }
.timeline-text h3 { font-size: 2.2rem; color: var(--color-orange); margin-bottom: 20px; font-family: var(--font-headings); }
.timeline-desc, .timeline-desc p { font-family: var(--font-body); color: #555; font-size: 1.1rem; }
.timeline-mobile-nav { display: none; }
.mobile-year-btn { padding: 10px 20px; background: #eee; border: none; border-radius: 20px; font-family: var(--font-headings); cursor: pointer; }
.mobile-year-btn.active { background: var(--color-orange); color: white; }

/* Sector Page Layout */
.sector-layout { display: grid; grid-template-columns: 2fr 1fr; gap: 60px; padding: 80px 0; }
.content-block h2 { font-size: 2.5rem; margin-bottom: 20px; position: relative; display: inline-block; font-family: var(--font-headings); }
.content-block h2::after { content: ""; position: absolute; bottom: 8px; right: -15px; width: 8px; height: 8px; background: var(--color-orange); border-radius: 50%; }
.context-box { background-color: #f4f4f4; border-left: 5px solid var(--color-dark-blue); padding: 30px; margin: 30px 0; border-radius: 0 30px 0 30px; }
.context-box h3 { color: var(--color-dark-blue); font-size: 1.4rem; margin-bottom: 10px; font-family: var(--font-headings); }
.sidebar-card { background: #fff; padding: 30px; margin-bottom: 30px; border: 1px solid #f0f0f0; box-shadow: 0 10px 30px rgba(0,0,0,0.08); border-radius: 0 30px 0 30px; }
.sidebar-title { font-size: 1.5rem; margin-bottom: 20px; border-bottom: 2px solid #eee; padding-bottom: 10px; font-family: var(--font-headings); }
.key-stat { display: flex; align-items: center; margin-bottom: 20px; }
.key-stat i { font-size: 2rem; color: var(--color-orange); margin-right: 15px; width: 40px; text-align: center; }
.key-stat div span { display: block; font-size: 1.6rem; font-family: var(--font-headings); font-weight: 700; line-height: 1; color: var(--color-dark-blue); }
.key-stat div label { font-size: 0.85rem; color: #666; text-transform: uppercase; letter-spacing: 1px; }

/* Project Single Layout */
.project-single-layout { max-width: 1000px; margin: 40px auto 80px; }
.project-main-card { background: #fff; overflow: hidden; box-shadow: 0 20px 40px rgba(0,0,0,0.08); padding: 0 0 60px; border-radius: 0 30px 0 30px; }
.project-title { font-family: var(--font-headings); font-size: 2.5rem; margin: 40px 40px 20px; border-bottom: 1px solid #eee; padding-bottom: 20px; }
.project-content { padding: 0 40px; }
.meta-row { display: flex; flex-wrap: wrap; gap: 30px; margin-bottom: 40px; padding: 15px 20px; background-color: var(--color-light-grey); border-radius: 10px; }
.meta-item { display: flex; align-items: center; gap: 10px; font-weight: 700; font-size: 0.95rem; font-family: var(--font-headings); }
.meta-item i { color: var(--color-orange); }
.project-content h3 { font-family: var(--font-headings); color: var(--color-dark-blue); font-size: 1.4rem; margin-top: 30px; margin-bottom: 10px; font-weight: 600; }
.text-block p { margin-bottom: 15px; color: #555; font-size: 1.05rem; line-height: 1.8; text-align: justify; }
.project-bottom-img { margin-top: 50px; width: 100%; height: 400px; border-radius: 0 30px 0 30px; overflow: hidden; position: relative; }
.project-bottom-img img { width: 100%; height: 100%; object-fit: cover; }
.img-caption { position: absolute; bottom: 0; left: 0; width: 100%; background: rgba(0,0,0,0.7); color: #fff; padding: 20px; font-size: 0.9rem; }

/* Projects List Grid (Corrected) */
.projects-list-section { padding: 80px 0; background: var(--color-light-grey); }
.view-sector-projects-list { display: grid !important; grid-template-columns: repeat(auto-fill, minmax(300px, 1fr)); gap: 30px; width: 100%; padding-top: 20px; }
.view-sector-projects-list .views-row { display: flex; flex-direction: column; height: 100%; width: 100%; }
.project-item-card { background: #fff; border-radius: 0 30px 0 30px; overflow: hidden; box-shadow: 0 5px 15px rgba(0,0,0,0.05); transition: transform 0.3s ease; display: flex; flex-direction: column; height: 100%; border: 1px solid #eee; text-decoration: none; }
.project-item-card:hover { transform: translateY(-5px); box-shadow: 0 15px 30px rgba(0,0,0,0.1); }
.p-card-img { height: 200px; position: relative; overflow: hidden; }
.p-card-img img { width: 100%; height: 100%; object-fit: cover; }
.status-tag { position: absolute; top: 15px; right: 15px; background: #4caf50; color: #fff; padding: 4px 12px; border-radius: 15px; font-size: 0.75rem; font-weight: 700; text-transform: uppercase; }
.status-tag.ongoing { background-color: var(--color-dark-blue) !important; }
.status-tag.completed { background-color: var(--color-orange) !important; }
.p-card-body { padding: 20px; flex-grow: 1; display: flex; flex-direction: column; }
.p-donor { color: var(--color-orange); font-weight: 700; font-size: 0.85rem; text-transform: uppercase; display: block; margin-bottom: 5px; font-family: var(--font-headings); }
.project-item-card h4 { color: #222; font-size: 1.25rem; margin: 0 0 10px; line-height: 1.3; font-family: var(--font-body); font-weight: 700; }
.p-summary { font-size: 0.95rem; color: #666; line-height: 1.6; border-top: 1px solid #eee; padding-top: 15px; margin-top: 15px; font-family: var(--font-body); }
.view-sector-projects-list header { grid-column: 1 / -1; width: 100%; text-align: center; margin-bottom: 20px; }

/* MEDIA QUERIES */
@media (min-width: 1920px) {
    .hero-text h1 { font-size: 3.5rem; }
    .hero-text p { font-size: 1.15rem; }
    .afghan-map-masked { width: 900px; }
    .section-header h2 { font-size: 3.2rem; }
    .about-text h2 { font-size: 3.2rem; }
}
@media (max-width: 1200px) {
    .main-nav ul:not(.dropdown-menu) > li > a { padding: 1.7rem 0.7rem; }
    .logo img { height: 80px; }
}
@media (max-width: 992px) {
    :root { --header-height: 90px; }
    .mobile-nav-toggle { display: block; }
    .main-nav { position: fixed; top: var(--header-height); left: -100%; width: 100%; height: calc(100vh - var(--header-height)); background-color: var(--color-white); transition: left 0.3s ease-in-out; overflow-y: auto; border-top: 1px solid var(--color-border-grey); }
    .main-nav.active { left: 0; } 
    .main-nav ul:not(.dropdown-menu) { flex-direction: column; align-items: flex-start; padding-bottom: 50px; }
    .main-nav ul:not(.dropdown-menu) > li { width: 100%; }
    .main-nav ul:not(.dropdown-menu) > li > a { display: flex; justify-content: space-between; align-items: center; width: 100%; padding: 20px; font-size: 1.2rem; text-align: left; border-bottom: 1px solid var(--color-border-grey); }
    .main-nav ul:not(.dropdown-menu) > li > a::after { display: none; } 
    .dropdown:hover .dropdown-menu { display: none; } 
    .dropdown-menu { display: block !important; position: static; box-shadow: none; border-radius: 0; padding: 0; background-color: var(--color-light-grey); width: 100%; }
    .dropdown-menu li a { padding: 15px 20px 15px 40px; font-size: 1rem; border-left: none; white-space: normal; border-bottom: 1px solid #e0e0e0; }
    .dropdown-menu li a:hover { background-color: #ececec; border-left: none; padding-left: 40px; }
    .dropdown .fa-chevron-down { display: none; } 
    .footer-content { grid-template-columns: 1fr 1fr; gap: 30px; }
    .footer-logo { grid-column: span 2; margin-bottom: 10px; }

    /* Homepage Mobile Adjustments */
    .hero-container-wide { flex-direction: column; text-align: center; padding-top: 40px; }
    .hero-text { max-width: 100%; }
    .hero-text p { margin-left: auto; margin-right: auto; }
    .hero-image-wrapper { justify-content: center; margin-top: 50px; }
    .about-container { flex-direction: column; }
    .about-images-wrapper { margin: 0 auto; }
    .about-text { padding-left: 0; text-align: center; }
    .title-wrapper { justify-content: center; }
    .desc, .intro-bold { margin-left: auto; margin-right: auto; }
    .achievements-section { flex-direction: column-reverse; }
    .stats-column { max-width: 100%; width: 100%; }
    .feature-bg-image { height: 350px; border-radius: 20px; }
    .info-card { width: 90%; position: relative; bottom: auto; right: auto; margin: -50px auto 0; z-index: 10; border-radius: 20px; }
    .feature-section { padding-bottom: 50px; }
    .feature-text-overlay { bottom: 80px; left: 30px; }
    .feature-text-overlay h2 { font-size: 2rem; }
    .cta-overlay { width: 100%; background: rgba(45, 38, 33, 0.85); padding: 40px; }
    .cta-title { font-size: 2rem; }
    .sector-layout { grid-template-columns: 1fr; }
    .projects-list-section { padding-top: 40px; }
    .project-single-layout { margin: 20px auto; width: 100%; padding: 0 15px; }
    .project-single-layout .project-hero-img { height: 300px; }
    .project-content { padding: 0 20px; }
}
@media (max-width: 768px) {
    .hero-section { padding-bottom: 60px; }
    .afghan-map-masked { width: 100%; max-width: 380px; }
    .cards-grid { grid-template-columns: 1fr; gap: 25px; }
    .about-images-wrapper { height: 380px; }
    .stats-grid-p2 { grid-template-columns: 1fr; }
    .sectors-view-grid .views-element-container > div { grid-template-columns: 1fr !important; }
    /* News specific */
    .news-item { grid-template-columns: 1fr; gap: 20px; }
    .article-title { font-size: 2rem; }
    .featured-img { height: 300px; }
}
@media (max-width: 600px) {
    .footer-content { grid-template-columns: 1fr; }
    .footer-logo { grid-column: span 1; }
    .legal-nav, .footer-bottom ul { flex-direction: column; gap: 5px; }
    .legal-nav li:not(:last-child)::after, .footer-bottom ul li:not(:last-child)::after { display: none; }
    .stats-section { flex-direction: column-reverse; }
    .stats-grid { width: 100%; flex: 0 0 100%; }
    .mv-grid, .values-grid, .timeline-display { grid-template-columns: 1fr; }
    .timeline-wrapper { display: none; }
    .timeline-mobile-nav { display: flex; flex-wrap: wrap; gap: 10px; justify-content: center; margin-bottom: 30px; }
    .timeline-img { height: 250px; order: -1; }
}
@media (max-width: 480px) {
    :root { --header-height: 80px; }
    .logo img { height: 60px; }
    .btn { padding: 8px 16px; font-size: 0.9rem; }
    .mobile-nav-toggle { font-size: 1.6rem; }
    .card { padding: 40px 28px; }
    .about-images-wrapper { height: 320px; }
    .img-main-box { border-width: 8px; }
    .img-sub-box { border-width: 6px; }
}

/* ---------------------------------- */
/* FORCE ARTICLE BODY TYPOGRAPHY      */
/* ---------------------------------- */

/* Target H3s specifically inside the article body */
.article-body h3, 
.article-body .field--name-body h3 { 
    font-family: var(--font-headings) !important; 
    color: var(--color-dark-blue) !important; 
    font-size: 1.8rem; 
    font-weight: 700; 
    margin-top: 40px; 
    margin-bottom: 15px; 
    line-height: 1.2;
    text-transform: uppercase; /* Optional: matches your static feel */
}

/* Ensure Paragraphs look right too */
.article-body p, 
.article-body .field--name-body p {
    margin-bottom: 25px;
    font-family: var(--font-body);
    font-size: 1.15rem;
    color: #444;
    line-height: 1.8;
}

/* Fix for the "Lead Text" if it's inside the body field */
.article-body strong, 
.article-body b {
    color: var(--color-dark-text);
    font-weight: 700;
}

/* Tighter Spacing for News List */
.news-content h3.news-title {
    margin-bottom: 10px !important; /* Force smaller gap */
}

.news-content .news-excerpt p {
    margin-top: 0 !important;       /* Remove top gap from paragraph */
    margin-bottom: 0 !important;    /* Remove bottom gap if needed */
}

/* Prevent Text Overflow */
.news-content {
    min-width: 0; /* Critical flexbox fix for overflow */
    word-wrap: break-word; /* Break long words if necessary */
}

.news-excerpt {
    overflow: hidden;
    text-overflow: ellipsis;
    display: -webkit-box;
    -webkit-line-clamp: 3; /* Show only 3 lines */
    -webkit-box-orient: vertical;
}

/* ---------------------------------- */
/* MEDIA CENTER LIST FIX              */
/* ---------------------------------- */

/* Target the rows specifically inside your news view */
.news-listing-view .views-row {
    max-width: 1256px;      /* Strict width */
    margin: 0 auto;         /* Center it */
    padding: 0 20px;        /* Safety padding for mobile */
    box-sizing: border-box; /* Ensure padding doesn't break width */
    width: 100%;            /* Prevent collapsing */
}

/* Ensure the hero stays full width */
.news-listing-view header {
    width: 100%;
    max-width: 100%;
}

/* --- NEWS LIST SPECIFIC FIXES --- */

/* 1. Fix the Paragraph Color & Spacing */
/* We target the 'p' tag inside the excerpt to override browser defaults */
.news-excerpt p {
    color: #666666 !important;      /* Your requested color */
    margin-top: 0 !important;       /* Removes gap between Title and Text */
    margin-bottom: 25px !important; /* Adds MORE gap between Text and Read More */
    line-height: 1.6;
}

/* 2. Tighten the Title Spacing */
.news-content h3.news-title {
    margin-bottom: 8px !important;  /* Very small gap to the paragraph */
}

/* 3. Ensure the container handles the spacing correctly */
.news-excerpt {
    margin-bottom: 0;
}

/* --- PROCUREMENT & TENDERS PAGE --- */
.procurement-section { padding: 60px 0; }

/* Tabs Navigation */
.tabs-nav { display: flex; gap: 10px; margin-bottom: 0; }
.tab-btn { padding: 15px 40px; background-color: #f4f4f4; border: none; border-radius: 10px 10px 0 0; font-family: var(--font-headings); font-size: 1.1rem; color: #777; cursor: pointer; transition: all 0.3s ease; }
.tab-btn:hover { background-color: #ffead1; color: var(--color-orange); }
.tab-btn.active { background-color: var(--color-orange); color: var(--color-white); font-weight: 700; }

/* Table Styling */
.table-container { background: #fff; padding: 30px; border-top: 5px solid var(--color-orange); box-shadow: 0 10px 30px rgba(0,0,0,0.08); border-radius: var(--brand-radius); overflow-x: auto; }
.procurement-table { width: 100%; border-collapse: collapse; min-width: 800px; }

.procurement-table th { text-align: left; padding: 15px; background-color: #fff; color: var(--color-dark-blue); font-family: var(--font-headings); font-weight: 700; border-bottom: 2px solid #eee; text-transform: uppercase; letter-spacing: 1px; }
.procurement-table td { padding: 15px; border-bottom: 1px solid #eee; font-size: 0.95rem; vertical-align: middle; color: #555; }
.procurement-table tr:hover { background-color: #fffbf5; }

/* Table Elements */
.ref-code { font-weight: 700; font-size: 0.85rem; color: #999; }
.tender-name { font-weight: 700; color: var(--color-dark-text); display: block; font-size: 1rem; }
.deadline { color: #c5221f; font-weight: 700; }

/* Dynamic Status Colors */
.status-open { color: #15803d; font-weight: 700; background: #dcfce7; padding: 5px 10px; border-radius: 20px; font-size: 0.75rem; text-transform: uppercase; }
.status-closed { color: #991b1b; font-weight: 700; background: #fee2e2; padding: 5px 10px; border-radius: 20px; font-size: 0.75rem; text-transform: uppercase; }

/* Download Button */
.dl-btn { background-color: var(--color-orange); color: #fff; width: 40px; height: 40px; border-radius: 50%; display: flex; align-items: center; justify-content: center; text-decoration: none; transition: background 0.3s; }
.dl-btn:hover { background-color: var(--color-dark-blue); color: #fff; }

/* Tab Logic */
.tab-content { display: none; animation: fadeIn 0.5s; }
.tab-content.active { display: block; }
@keyframes fadeIn { from { opacity: 0; transform: translateY(10px); } to { opacity: 1; transform: translateY(0); } }

/* Sidebar Specifics */
.layout-grid { display: grid; grid-template-columns: 3fr 1fr; gap: 40px; }
.sidebar-card { background: #fff; padding: 30px; border-radius: var(--brand-radius); box-shadow: 0 20px 40px rgba(0,0,0,0.08); margin-bottom: 30px; }
.sidebar-title { font-family: var(--font-headings); font-size: 1.4rem; border-bottom: 2px solid var(--color-orange); padding-bottom: 10px; margin-bottom: 20px; display: inline-block; color: var(--color-dark-text); }
.sidebar-list { list-style: none; padding: 0; }
.sidebar-list li { margin-bottom: 15px; display: flex; align-items: flex-start; font-size: 0.95rem; color: #666; }
.sidebar-list li i { color: var(--color-orange); margin-right: 12px; margin-top: 5px; }

@media (max-width: 900px) { .layout-grid { grid-template-columns: 1fr; } }

/* --- PROCUREMENT TABLE FIXES --- */

/* 1. Prevent "Reference No." (Column 1) from breaking lines */
.procurement-table th:first-child, 
.procurement-table td:first-child {
    white-space: nowrap;
    width: 1%; /* Shrinks column to minimum width needed */
}

/* 2. Prevent "Deadline" (Column 4) from breaking lines */
.procurement-table th:nth-child(4), 
.procurement-table td:nth-child(4) {
    white-space: nowrap;
    width: 1%; /* Shrinks column to minimum width needed */
}

/* --- CAREERS PAGE STYLES (Updated) --- */

:root {
    --color-dark-brown: #2b2320;
}

/* Intro Section */
.intro-section { padding: 80px 0; text-align: center; }
.intro-header h2 { font-size: 2.8rem; margin-bottom: 10px; font-family: var(--font-headings); }
.intro-subtitle { color: var(--color-orange); font-weight: 700; text-transform: uppercase; letter-spacing: 2px; font-size: 0.9rem; margin-bottom: 50px; display: block; font-family: var(--font-body); }

.intro-layout { display: grid; grid-template-columns: 1fr 1.2fr; gap: 50px; align-items: start; text-align: left; }
.intro-img { width: 100%; height: 500px; border-radius: var(--brand-radius); overflow: hidden; box-shadow: 0 20px 40px rgba(0,0,0,0.1); }
.intro-img img { width: 100%; height: 100%; object-fit: cover; }
.intro-text p { font-size: 1rem; color: #666; margin-bottom: 20px; line-height: 1.8; text-align: justify; font-family: var(--font-body); }

/* Strength Section */
.strength-section { background-color: var(--color-dark-brown); color: #fff; padding: 60px 0; border-radius: var(--brand-radius); margin: 60px auto; max-width: 1256px; position: relative; overflow: hidden; }
.strength-layout { display: grid; grid-template-columns: 1fr 1fr; gap: 50px; align-items: center; padding: 0 60px; }
.strength-text h2 { color: #fff; font-size: 2.5rem; margin-bottom: 20px; font-family: var(--font-headings); }
.strength-text p { color: #ccc; margin-bottom: 30px; font-size: 1rem; }
.province-list { display: grid; grid-template-columns: 1fr 1fr; list-style: none; padding: 0; }
.province-list li { color: #ddd; margin-bottom: 10px; display: flex; align-items: center; font-size: 0.9rem; }
.province-list li::before { content: "•"; color: var(--color-orange); font-size: 1.5rem; margin-right: 10px; line-height: 0; }

/* SVG MAP STYLING */
.map-container { text-align: center; }
.map-svg { width: 100%; max-width: 450px; height: auto; filter: drop-shadow(0px 10px 20px rgba(0,0,0,0.3)); transition: transform 0.3s ease; }
.map-svg:hover { transform: scale(1.02); }

/* Jobs Section Layout */
.jobs-section { padding-bottom: 100px; }
.jobs-layout { display: grid; grid-template-columns: 300px 1fr; gap: 50px; align-items: start; }

/* Sidebar Menu */
.jobs-menu { background: #fff; padding: 20px 0; border-radius: var(--brand-radius); box-shadow: 0 10px 30px rgba(0,0,0,0.05); border: 1px solid #eee; position: sticky; top: 140px; }
.job-tab-btn { display: block; width: 100%; padding: 15px 30px; background: none; border: none; text-align: left; font-family: var(--font-headings); font-size: 1.1rem; color: #555; cursor: pointer; border-bottom: 1px solid #f5f5f5; transition: all 0.2s; }
.job-tab-btn:hover { color: var(--color-orange); background: #fdfbf7; }
.job-tab-btn.active { color: var(--color-orange); font-weight: 700; border-left: 4px solid var(--color-orange); background: #fffbf5; }

/* Job Details Logic */
.job-details { display: none; animation: fadeIn 0.5s ease; }
.job-details.active { display: block; }

/* Job Table */
.job-table-container { background: #fff; padding: 30px; border-radius: var(--brand-radius); box-shadow: 0 10px 25px rgba(0,0,0,0.05); margin-bottom: 40px; border-top: 4px solid var(--color-orange); }
.job-summary-table { width: 100%; border-collapse: collapse; }
.job-summary-table td { padding: 12px 15px; border-bottom: 1px solid #f0f0f0; vertical-align: top; }
.job-summary-table tr:last-child td { border-bottom: none; }
.tbl-label { width: 35%; font-weight: 700; color: var(--color-dark-text); font-family: var(--font-headings); text-transform: uppercase; font-size: 0.85rem; letter-spacing: 0.5px; }
.tbl-value { color: #555; font-size: 0.95rem; }

/* Apply Button */
/* FORCE BUTTON STYLE */
a.apply-btn-large, 
.apply-btn-large { 
    display: inline-block !important; 
    background-color: var(--color-orange); 
    color: #fff !important; 
    padding: 15px 50px; 
    font-family: var(--font-heading); 
    font-weight: 700; 
    text-decoration: none !important; 
    text-transform: uppercase; 
    border-radius: 30px; 
    box-shadow: 0 5px 15px rgba(232, 157, 72, 0.4); 
    transition: transform 0.3s; 
    margin-top: 30px; 
}

a.apply-btn-large:hover,
.apply-btn-large:hover { 
    transform: translateY(-3px); 
    background-color: var(--color-blue); 
    color: #fff !important;
}

@media (max-width: 900px) {
    .intro-layout, .strength-layout, .jobs-layout { grid-template-columns: 1fr; }
    .province-list { text-align: left; margin-left: 20px; }
    .intro-img { height: 300px; }
}

/* --- JOB DETAILS SPECIFIC STYLES --- */

/* 1. Scoped Headers: Only change font inside Job Details */
.job-details .section-title {
    font-family: 'Oswald', sans-serif !important;
    font-size: 1.6rem;
    color: var(--color-text-dark);
    margin-bottom: 15px;
    border-bottom: 2px solid #eee;
    padding-bottom: 10px;
    display: inline-block;
    font-weight: 700;
    position: relative;
    text-transform: uppercase;
}

/* 2. Scoped Orange Line: Only appear inside Job Details */
.job-details .section-title::after {
    content: "";
    position: absolute;
    bottom: -2px;
    left: 0;
    width: 50px;
    height: 3px;
    background-color: #E89D48 !important; /* The Orange Color */
    z-index: 1;
}

/* 3. Scoped Apply Button: Force styling only here */
.job-details .apply-btn-large {
    display: inline-block !important;
    background-color: #E89D48 !important; /* Orange */
    color: #fff !important;
    padding: 15px 50px;
    font-family: 'Oswald', sans-serif !important;
    font-weight: 700;
    text-decoration: none !important;
    text-transform: uppercase;
    border-radius: 30px;
    box-shadow: 0 5px 15px rgba(232, 157, 72, 0.4);
    transition: transform 0.3s;
    margin-top: 30px;
}

.job-details .apply-btn-large:hover {
    transform: translateY(-3px);
    background-color: #3C4690 !important; /* Blue hover */
}

/* 4. Submission Box Styling */
.job-details .submission-box {
    background: #f4f8fb;
    padding: 20px;
    border-left: 4px solid #3C4690; /* Blue border */
    border-radius: 0 10px 10px 0;
    margin-top: 30px;
}


/* JOB TITLE HEADER (The Big Blue Title) */
.job-title-header h3 {
    font-family: 'Oswald', sans-serif !important;
    font-size: 2.5rem !important; /* Makes it big */
    color: #3C4690 !important;    /* The Blue Color */
    font-weight: 700;
    margin-bottom: 5px;
    margin-top: 0;
    text-transform: capitalize;
}

/* --- SPACING FIX --- */

/* This pushes the next section down, creating space between the paragraph and the next title */
.job-details .content-section {
    margin-bottom: 50px !important; 
    display: block; /* Ensures it takes up full width */
}

/* Optional: Ensure the titles themselves have a little space above them just in case */
.job-details .section-title {
    margin-top: 10px;
    margin-bottom: 20px !important; /* Space between title and its own paragraph */
}

/* Ensure paragraphs have breathing room */
.job-details .content-text {
    margin-bottom: 20px;
    line-height: 1.8; /* Makes the text easier to read */
}

/* ---------------------------------- */
/* POLICY / LEGAL PAGE STYLES         */
/* ---------------------------------- */

/* Hero Adjustment: Corporate Blue */
.policy-hero {
    height: 35vh; 
    min-height: 250px;
    display: flex;
    align-items: center;
    justify-content: center;
    position: relative;
    margin-bottom: 0;
   
}
.policy-hero-subtitle {
    color: rgba(255,255,255,0.8);
    margin-top: 10px;
    font-family: var(--font-body);
    text-transform: uppercase;
    letter-spacing: 1px;
}

/* Layout Adjustments */
.policy-layout-adjustment {
    margin-top: 40px; 
    gap: 40px;
    padding-bottom: 80px;
}

/* Main Card Styling */
.policy-card {
    background: #fff;
    padding: 50px;
    border-radius: 0 30px 0 30px;
    box-shadow: 0 10px 40px rgba(0,0,0,0.08);
    border: 1px solid #eee;
}

.policy-meta {
    font-family: var(--font-headings);
    color: #999;
    font-size: 0.9rem;
    text-transform: uppercase;
    letter-spacing: 1px;
    margin-bottom: 30px;
    padding-bottom: 20px;
    border-bottom: 1px solid #eee;
}

/* Typography for Legal Text */
.policy-body h3, 
.policy-body h2 {
    font-family: var(--font-headings);
    color: var(--color-dark-blue);
    margin-top: 40px;
    margin-bottom: 20px;
    font-size: 1.6rem;
    position: relative;
    font-weight: 500;
}

/* Orange marker next to headers */
.policy-body h3::before,
.policy-body h2::before {
    content: '';
    display: inline-block;
    width: 6px;
    height: 6px;
    background-color: var(--color-orange);
    border-radius: 50%;
    margin-right: 12px;
    vertical-align: middle;
}

.policy-body p {
    font-family: var(--font-body);
    font-size: 1.05rem;
    line-height: 1.8;
    color: #444;
    margin-bottom: 20px;
    text-align: justify; 
}

/* Custom List Styling */
.policy-body ul { list-style: none; margin-bottom: 30px; padding-left: 10px; }
.policy-body ul li { position: relative; padding-left: 30px; margin-bottom: 12px; color: #444; line-height: 1.7; }
.policy-body ul li::before {
    content: "\f00c"; /* FontAwesome Check */
    font-family: "Font Awesome 6 Free";
    font-weight: 900;
    position: absolute;
    left: 0;
    top: 5px;
    color: var(--color-orange);
    font-size: 0.8rem;
}

.policy-body ol { margin-left: 20px; margin-bottom: 30px; color: #444; line-height: 1.8; }
.policy-body ol li { margin-bottom: 10px; padding-left: 10px; }

/* Sidebar Menu */
.policy-menu-list { list-style: none; padding: 0; margin: 0; }
.policy-menu-list li { margin-bottom: 10px; }
.policy-menu-list a {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 15px 20px;
    background: #f8f9fa;
    color: var(--color-dark-text);
    font-family: var(--font-headings);
    font-weight: 500;
    text-transform: uppercase;
    font-size: 0.95rem;
    border-radius: 5px;
    transition: all 0.3s ease;
    text-decoration: none;
    border-left: 3px solid transparent;
}
.policy-menu-list a:hover {
    background: #fff;
    box-shadow: 0 5px 15px rgba(0,0,0,0.05);
    color: var(--color-orange);
    border-left-color: var(--color-orange);
    padding-left: 25px; 
}
.policy-menu-list a.active {
    background: var(--color-dark-blue);
    color: #fff;
    border-left-color: var(--color-orange);
}
.policy-menu-list a.active i { color: var(--color-orange); }

/* Download Box */
.download-box { background: var(--color-light-grey); border: none; }
.download-title { font-size: 1.2rem; }
.download-text { font-size: 0.9rem; color: #666; margin-bottom: 15px; }
.full-width-btn { width: 100%; font-size: 0.9rem; }

/* Responsive */
@media (max-width: 900px) {
    .policy-card { padding: 30px 20px; }
    .policy-hero { height: 250px; }
    .sector-layout.policy-layout-adjustment { grid-template-columns: 1fr; }
    .sidebar { order: -1; margin-bottom: 30px; }
}

/* ---------------------------------- */
/* CONTACT PAGE STYLES                */
/* ---------------------------------- */

/* Head Office Section */
.head-office-section { 
    padding: 60px 0; 
    border-bottom: 1px solid #eee; 
}

/* The Orange Line Title */
.brand-line-title {
    border-top: 4px solid var(--color-orange);
    padding-top: 15px;
    font-size: 2rem;
    margin-bottom: 20px;
    display: inline-block;
    width: 100%;
    font-family: var(--font-headings);
    color: var(--color-dark-text);
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

.address-block { 
    font-weight: 700; 
    color: #333; 
    margin-bottom: 30px; 
    font-style: normal; 
    font-size: 1.1rem;
    line-height: 1.6;
}

.contact-intro { 
    max-width: 800px; 
    margin-bottom: 20px; 
    font-size: 1rem; 
    color: #666; 
}

.highlight-phone { 
    font-weight: 700; 
    color: var(--color-dark-text); 
    font-size: 1.1rem; 
    margin-top: 20px; 
    display: block; 
}

/* Action Strip */
.action-strip {
    padding: 30px 0;
    border-top: 1px solid #ddd;
    border-bottom: 1px solid #ddd;
    margin: 40px 0;
    display: flex;
    justify-content: space-between;
    align-items: center;
    flex-wrap: wrap;
    gap: 20px;
}

.action-text { 
    font-weight: 700; 
    font-family: var(--font-headings); 
    color: #444; 
    font-size: 1.1rem; 
    text-transform: uppercase; 
}

/* Regions List */
.regions-section { padding-bottom: 80px; }
.region-list { display: flex; flex-direction: column; gap: 20px; margin-top: 30px; }

.region-item {
    display: flex;
    border-bottom: 1px solid #eee;
    padding-bottom: 30px;
    padding-top: 10px;
}

.region-item:last-child { border-bottom: none; }

.region-name {
    width: 25%;
    font-weight: 700;
    font-family: var(--font-body);
    font-size: 1.1rem;
    color: #333;
    padding-right: 20px;
}

.region-details { width: 75%; }

.r-manager { 
    font-weight: 700; 
    color: var(--color-dark-blue); 
    margin-bottom: 5px; 
    display: block; 
}

.r-address { 
    font-size: 0.95rem; 
    margin-bottom: 10px; 
    color: #666; 
}

.r-contact { 
    font-size: 0.9rem; 
    display: flex; 
    gap: 20px; 
    flex-wrap: wrap; 
}

.r-contact span { 
    display: flex; 
    align-items: center; 
    gap: 8px; 
    color: #555; 
}

.r-contact i { color: var(--color-orange); }

/* Map Container */
.map-container {
    width: 100%;
    height: 450px;
    background-color: #f4f4f4;
    display: flex;
    justify-content: center;
    align-items: center;
    border-top: 4px solid var(--color-dark-blue);
    margin-top: 40px;
    overflow: hidden; /* Ensures iframe doesn't spill */
}

.map-container iframe {
    width: 100%;
    height: 100%;
    border: 0;
}

/* Responsive */
@media (max-width: 768px) {
    .action-strip { flex-direction: column; text-align: center; }
    .region-item { flex-direction: column; }
    .region-name { 
        width: 100%; 
        margin-bottom: 10px; 
        color: var(--color-orange); 
        font-size: 1.3rem; 
        font-family: var(--font-headings); 
    }
    .region-details { width: 100%; }
}

/* ---------------------------------- */
/* DONATE PAGE STYLES (Simple Version)*/
/* ---------------------------------- */

.donate-container {
    max-width: 900px;
    /* Limits width so it looks good on big screens */
    margin: 0 auto;
    padding: 80px 20px;
    text-align: center;
}

/* Intro Text */
.donate-intro {
    margin-bottom: 50px;
}

.donate-intro h2 {
    font-size: 2.5rem;
    margin-bottom: 25px;
    color: var(--color-dark-blue);
    font-family: var(--font-headings);
    text-transform: uppercase;
}

.donate-intro p {
    font-size: 1.2rem;
    color: #555;
    line-height: 1.8;
    max-width: 800px;
    margin: 0 auto 20px auto;
}

/* Bank Details Card */
.bank-card {
    background-color: #fff;
    border-top: 6px solid var(--color-orange);
    /* Thick orange top border */
    border-bottom: 1px solid #ddd;
    border-left: 1px solid #ddd;
    border-right: 1px solid #ddd;
    padding: 50px;
    border-radius: 0 40px 0 40px;
    /* Brand Radius */
    box-shadow: 0 15px 40px rgba(0, 0, 0, 0.08);
    text-align: left;
    /* Keep text aligned left for readability */
    margin-top: 40px;
}

.bank-card h3 {
    font-family: var(--font-headings);
    color: var(--color-dark-text);
    font-size: 1.8rem;
    margin-bottom: 30px;
    border-bottom: 1px solid #eee;
    padding-bottom: 20px;
    display: flex;
    align-items: center;
    gap: 15px;
}

/* Bank Rows */
.bank-row {
    display: flex;
    justify-content: space-between;
    margin-bottom: 18px;
    border-bottom: 1px dashed #eee;
    /* Dashed line for clean look */
    padding-bottom: 18px;
    flex-wrap: wrap;
    gap: 10px;
}

.bank-row:last-child {
    border-bottom: none;
    margin-bottom: 0;
    padding-bottom: 0;
}

.bank-label {
    font-weight: 700;
    color: #888;
    font-family: var(--font-headings);
    text-transform: uppercase;
    font-size: 1rem;
    letter-spacing: 0.5px;
}

.bank-value {
    font-weight: 700;
    color: var(--color-dark-blue);
    text-align: right;
    font-family: var(--font-body);
    font-size: 1.1rem;
}

/* Responsive Mobile */
@media (max-width: 600px) {
    .bank-card {
        padding: 30px 20px;
    }

    .bank-row {
        flex-direction: column;
        text-align: left;
    }

    .bank-value {
        text-align: left;
        margin-top: 5px;
        color: var(--color-orange);
    }
}

/* ---------------------------------- */
/* MEDIA GALLERY STYLES (Restored & Fixed) */
/* ---------------------------------- */

.gallery-section {
    padding: 80px 0;
}

/* 1. HEADER & TEXT STYLING */
.gallery-header {
    text-align: center;
    margin-bottom: 40px;
}

.gallery-header h2 {
    font-size: 2.5rem;
    margin-bottom: 20px;
    color: var(--color-dark-text);
    font-family: var(--font-headings);
    text-transform: uppercase;
    letter-spacing: 1px;
}

/* Specific selector for the intro paragraph */
.gallery-intro p {
    font-size: 1.2rem;
    max-width: 800px;
    margin: 0 auto;
    color: #555;
    line-height: 1.6;
    font-family: var(--font-body, sans-serif);
}

/* 2. FILTER BUTTONS STYLING */
.filter-bar {
    display: flex;
    justify-content: center;
    gap: 15px;
    margin-bottom: 50px;
    flex-wrap: wrap;
    /* Good for mobile */
}

.filter-btn {
    padding: 12px 35px;
    background: #fff;
    border: 1px solid #ddd;
    border-radius: 0 25px 0 25px;
    /* RRAA Brand Shape */
    font-family: var(--font-headings, sans-serif);
    font-weight: 700;
    font-size: 1rem;
    color: #555;
    cursor: pointer;
    transition: all 0.3s ease;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    outline: none;
}

.filter-btn:hover,
.filter-btn.active {
    background: var(--color-orange);
    /* Ensure variable exists or use #e89d48 */
    color: #fff;
    border-color: var(--color-orange);
    transform: translateY(-3px);
    box-shadow: 0 5px 15px rgba(232, 157, 72, 0.3);
}

/* 3. GALLERY GRID LAYOUT */
/* Target the inner views containers to force Grid */
.gallery-grid .views-element-container>div,
.gallery-grid>div {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(350px, 1fr));
    gap: 30px;
    width: 100%;
}

.gallery-grid .views-row {
    display: flex;
    width: 100%;
}

/* 4. CARD STYLING */
.gallery-item {
    position: relative;
    border-radius: 0 30px 0 30px;
    overflow: hidden;
    background: #000;
    height: 300px;
    width: 100%;
    cursor: pointer;
    box-shadow: 0 10px 30px rgba(0, 0, 0, 0.1);
    transition: transform 0.3s ease;
}

.gallery-item:hover {
    transform: translateY(-5px);
}

.gallery-item img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    opacity: 0.95;
    transition: opacity 0.3s, transform 0.5s;
    display: block;
}

.gallery-item:hover img {
    opacity: 0.8;
    transform: scale(1.05);
}

/* 5. OVERLAY STYLING */
.item-overlay {
    position: absolute;
    bottom: 0;
    left: 0;
    width: 100%;
    padding: 25px;
    background: linear-gradient(to top, rgba(0, 0, 0, 0.9), transparent);
    color: #fff;
    transform: translateY(20px);
    transition: transform 0.3s;
    pointer-events: none;
}

.gallery-item:hover .item-overlay {
    transform: translateY(0);
}

.item-title {
    font-family: var(--font-headings);
    font-size: 1.3rem;
    line-height: 1.2;
    font-weight: 500;
}

.item-meta,
.item-meta p {
    font-size: 0.85rem;
    color: var(--color-orange);
    text-transform: uppercase;
    font-weight: 700;
    margin: 0 0 5px 0;
    display: block;
}

/* Video Icon */
.video-icon {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: 60px;
    height: 60px;
    background: rgba(255, 255, 255, 0.2);
    border: 2px solid #fff;
    border-radius: 50%;
    display: flex;
    justify-content: center;
    align-items: center;
    font-size: 1.5rem;
    color: #fff;
    backdrop-filter: blur(5px);
    z-index: 2;
    pointer-events: none;
}

/* 6. LIGHTBOX OVERRIDES (The "Smaller Image" Fix) */
/* This restricts the image size so it has padding around it */
.gslide-image img {
    max-height: 85vh !important;
    /* Leaves space top/bottom */
    max-width: 85vw !important;
    /* Leaves space left/right */
    border-radius: 5px;
    /* Optional: slight curve */
    box-shadow: 0 0 20px rgba(0, 0, 0, 0.5);
}

/* Ensure background is dark */
.glightbox-container .gslide-container {
    background: rgba(0, 0, 0, 0.9);
}

/* 7. HIDING EXTRA IMAGES LOGIC */
.gallery-trigger-wrapper {
    width: 100%;
    height: 100%;
}

.gallery-trigger-wrapper a {
    display: none;
}

.gallery-trigger-wrapper a:first-child {
    display: block;
    width: 100%;
    height: 100%;
}

/* Mobile Response */
@media (max-width: 768px) {
    .gallery-grid .views-element-container>div {
        grid-template-columns: 1fr;
    }

    .gallery-header h2 {
        font-size: 2rem;
    }
}

/* =========================================
   FINANCIALS PAGE STYLES (FINAL)
   ========================================= */

/* --- TRANSPARENCY SECTION LAYOUT --- */
.transparency-content { 
    padding: 100px 0; 
    background: #fff; 
    overflow: hidden; 
}

/* Flexbox Container */
.transparency-layout {
    display: flex;
    flex-direction: column-reverse; /* Mobile: Text first, Image bottom */
    gap: 40px;
}

/* Desktop Layout (Min 992px) */
@media (min-width: 992px) {
    .transparency-layout {
        flex-direction: row;        
        align-items: flex-start;  /* Start from top */
        justify-content: center;    
        gap: 30px; 
    }

    /* IMAGE COLUMN (Left) */
    .trans-col-img {
        flex: 0 0 421px;            
        width: 421px;               
    }

    /* TEXT COLUMN (Right) */
    .trans-col-text {
        flex: 1;                    
        max-width: 650px;           
        padding-left: 10px;
        padding-top: 10px; /* Visual alignment */
    }
}

/* --- TYPOGRAPHY --- */
.transparency-content .section-title {
    font-family: var(--font-headings);
    color: var(--color-dark-text);
    font-size: 2.8rem;
    line-height: 1.1;
    font-weight: 500; /* Thinner */
    text-transform: none; /* Normal Case */
    margin-bottom: 25px;
}

.intro-paragraph {
    font-size: 1.15rem;
    color: #222;
    font-weight: 400;
    margin-bottom: 20px;
}

.transparency-body p {
    font-family: var(--font-body);
    font-size: 1rem;
    line-height: 1.6;
    color: #444;
    text-align: justify;
    margin-bottom: 15px;
}

.sub-heading {
    font-family: var(--font-headings);
    color: var(--color-dark-blue);
    font-size: 1.25rem;
    font-weight: 700;
    margin-bottom: 10px;
    display: flex;
    align-items: center;
}

.sub-heading::before {
    content: '';
    display: inline-block;
    width: 5px;
    height: 20px;
    background-color: var(--color-orange);
    margin-right: 12px;
    border-radius: 4px;
}

.content-block {
    margin-top: 25px;
}

/* --- IMAGE WRAPPER --- */
.rraa-image-wrapper {
    position: relative;
    border-radius: 0 30px 0 30px; 
    box-shadow: 0 20px 40px rgba(0,0,0,0.15);
    overflow: hidden;
    width: 100%;
    height: 544px;      
    background-color: #f0f0f0;
}

.rraa-image-wrapper img {
    width: 100%;
    height: 100%;
    object-fit: cover;  
    object-position: center;
    display: block;
}

/* --- ACTION AREA --- */
.action-area {
    margin-top: 20px; 
}

.btn-lg {
    padding: 12px 35px;
    font-size: 1rem;
    display: inline-flex;
    align-items: center;
    gap: 10px;
    box-shadow: 0 10px 20px rgba(233, 150, 72, 0.2);
}

.btn-lg:hover {
    transform: translateY(-3px);
    box-shadow: 0 15px 30px rgba(233, 150, 72, 0.3);
}

@media (max-width: 991px) {
    .transparency-layout {
        flex-direction: column-reverse; 
        align-items: center;
    }
    .trans-col-img {
        width: 100%;
        max-width: 421px; 
    }
    .rraa-image-wrapper {
        height: 400px; 
    }
    .transparency-content .section-title { font-size: 2.2rem; }
}

/* DASHBOARD WRAPPER */
.dashboard-wrapper { 
  background-color: #f4f6f9; padding: 80px 0; position: relative; border-top: 1px solid #ddd;
}
.dashboard-header { text-align: center; margin-bottom: 50px; }
.dashboard-header h2 { font-family: var(--font-headings); font-size: 3rem; color: var(--color-dark-text); margin-bottom: 5px; }
.dashboard-header span { color: var(--color-orange); font-weight: 700; text-transform: uppercase; letter-spacing: 2px; font-size: 0.9rem; }

/* KPI CARDS */
.kpi-container { display: grid; grid-template-columns: repeat(4, 1fr); gap: 25px; margin-bottom: 50px; }
.kpi-card {
  background: #fff; padding: 25px 20px; border-radius: var(--brand-radius);
  box-shadow: 0 10px 25px rgba(0,0,0,0.05); display: flex; align-items: center; gap: 20px;
  border-bottom: 4px solid transparent; transition: all 0.3s;
}
.kpi-card:hover { transform: translateY(-5px); border-bottom-color: var(--color-orange); box-shadow: 0 20px 40px rgba(0,0,0,0.1); }
.kpi-icon-box { width: 60px; height: 60px; border-radius: 50%; display: flex; align-items: center; justify-content: center; font-size: 1.5rem; flex-shrink: 0; }

.bg-purple { background: rgba(91, 74, 156, 0.15); color: #5B4A9C; }
.bg-blue { background: rgba(49, 55, 169, 0.15); color: #3137a9; }
.bg-orange { background: rgba(233, 150, 72, 0.15); color: #e99648; }
.bg-green { background: rgba(21, 128, 61, 0.15); color: #15803d; }

.kpi-text h3 { font-family: var(--font-headings); font-size: 2.2rem; font-weight: 700; color: var(--color-dark-text); line-height: 1; margin-bottom: 5px; }
.kpi-text p { font-size: 0.8rem; text-transform: uppercase; letter-spacing: 0.5px; color: #666; font-weight: 600; margin-bottom: 0; }

/* CHARTS ROW */
.charts-row { display: grid; grid-template-columns: 1fr 1fr; gap: 40px; }
.chart-card {
  background: #fff; border-radius: var(--brand-radius);
  box-shadow: 0 15px 40px rgba(0,0,0,0.08); 
  display: flex; flex-direction: column; overflow: hidden; 
  border: 1px solid #eee; height: 550px; 
}
.chart-header { padding: 20px; border-bottom: 1px solid #f0f0f0; text-align: center; background: #fff; flex-shrink: 0; }
.chart-header h4 { font-family: var(--font-headings); font-size: 1.3rem; color: var(--color-dark-blue); margin: 0; text-transform: uppercase; }
.chart-box { width: 100%; flex-grow: 1; min-height: 400px; }
.chart-footer { padding: 15px 20px; background: #f9f9f9; border-top: 1px solid #eee; }
.legend-grid { display: flex; flex-wrap: wrap; justify-content: center; gap: 15px; }
.legend-item { display: flex; align-items: center; gap: 8px; font-size: 0.8rem; font-weight: 700; color: #555; }
.l-dot { width: 12px; height: 12px; border-radius: 50%; display: inline-block; border: 2px solid white; box-shadow: 0 0 2px rgba(0,0,0,0.2); }

/* TABLE */
.projects-table-wrap { padding: 80px 0; background: #fff; }
.table-container-styled {
  border-radius: var(--brand-radius); box-shadow: 0 10px 40px rgba(0,0,0,0.08);
  overflow: hidden; background: #fff; border: 1px solid #eee;
}
.fin-table { width: 100%; border-collapse: collapse; min-width: 900px; }
.fin-table thead { background: var(--color-orange); color: #fff; }
.fin-table th { padding: 20px; text-align: left; font-family: var(--font-headings); font-weight: 500; letter-spacing: 1px; text-transform: uppercase; font-size: 0.9rem; }
.fin-table td { padding: 18px 20px; border-bottom: 1px solid #eee; color: #555; vertical-align: middle; }
.fin-table tr:hover { background-color: #fcfcfc; }

.status-badge { padding: 6px 12px; border-radius: 20px; font-size: 0.75rem; font-weight: 700; text-transform: uppercase; display: inline-block; white-space: nowrap; }
.st-active { background: #dcfce7; color: #166534; }
.st-completed { background: #fee2e2; color: #991b1b; }
.st-terminated { background: #f3f4f6; color: #374151; border: 1px solid #d1d5db; }

.pagination-container { display: flex; justify-content: center; align-items: center; gap: 10px; margin-top: 30px; }
.page-btn { background: #f4f4f4; border: none; padding: 10px 15px; border-radius: 5px; cursor: pointer; font-family: var(--font-headings); font-weight: 700; color: #555; transition: all 0.3s; }
.page-btn.active { background: var(--color-orange); color: #fff; }

/* Responsive */
@media(max-width: 992px) {
  .kpi-container { grid-template-columns: 1fr 1fr; }
  .charts-row { grid-template-columns: 1fr; }
  .policy-grid { grid-template-columns: 1fr; }
  .report-download-area { flex-direction: column; text-align: center; gap: 20px; }
}
@media(max-width: 600px) {
  .kpi-container { grid-template-columns: 1fr; }
}

/* Custom Footer Logo Class */
.footer-logo-img {
    width: auto;
    height: auto;
    max-width: 200px; /* Your desired big size */
    display: block;
}

/* Responsive: Shrink on mobile */
@media (max-width: 600px) {
    .footer-logo-img {
        max-width: 160px; /* Smaller on phones */
        margin-bottom: 20px; /* Add space below it on mobile */
    }
}

