/*
 * index2.css — Merged stylesheet for index2.html
 * Contains only styles actually used by index2.html
 * Replaces: bootstrap.min.css (kept separate), bootsnav.css (kept separate),
 *           style.css (kept separate), style1.css (NOT used),
 *           css.css (fonts only – merged below), animate.min.css (kept separate),
 *           styles.css (relevant rules merged below),
 *           charcoal-black.css (relevant rules merged below),
 *           + all inline <style> block from the HTML
 */

/* ============================================================
   FONT FACES (from css.css – only fonts referenced by styles.css body/headings)
   ============================================================ */

/* Montserrat */
@font-face { font-family: 'Montserrat'; font-style: normal; font-weight: 400; src: local('Montserrat Regular'), local('Montserrat-Regular'), url(https://fonts.gstatic.com/s/montserrat/v14/JTUSjIg1_i6t8kCHKm459WlhyyTh89Y.woff2) format('woff2'); unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+2000-206F, U+2074, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD; }
@font-face { font-family: 'Montserrat'; font-style: normal; font-weight: 400; src: local('Montserrat Regular'), local('Montserrat-Regular'), url(https://fonts.gstatic.com/s/montserrat/v14/JTUSjIg1_i6t8kCHKm459WdhyyTh89ZNpQ.woff2) format('woff2'); unicode-range: U+0100-024F, U+0259, U+1E00-1EFF, U+2020, U+20A0-20AB, U+20AD-20CF, U+2113, U+2C60-2C7F, U+A720-A7FF; }
@font-face { font-family: 'Montserrat'; font-style: normal; font-weight: 700; src: local('Montserrat Bold'), local('Montserrat-Bold'), url(https://fonts.gstatic.com/s/montserrat/v14/JTURjIg1_i6t8kCHKm45_dJE3gnD_vx3rCs.woff2) format('woff2'); unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+2000-206F, U+2074, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD; }
@font-face { font-family: 'Montserrat'; font-style: normal; font-weight: 700; src: local('Montserrat Bold'), local('Montserrat-Bold'), url(https://fonts.gstatic.com/s/montserrat/v14/JTURjIg1_i6t8kCHKm45_dJE3gfD_vx3rCubqg.woff2) format('woff2'); unicode-range: U+0100-024F, U+0259, U+1E00-1EFF, U+2020, U+20A0-20AB, U+20AD-20CF, U+2113, U+2C60-2C7F, U+A720-A7FF; }

/* Poppins */
@font-face { font-family: 'Poppins'; font-style: normal; font-weight: 400; src: local('Poppins Regular'), local('Poppins-Regular'), url(https://fonts.gstatic.com/s/poppins/v9/pxiEyp8kv8JHgFVrJJfecnFHGPc.woff2) format('woff2'); unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+2000-206F, U+2074, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD; }
@font-face { font-family: 'Poppins'; font-style: normal; font-weight: 400; src: local('Poppins Regular'), local('Poppins-Regular'), url(https://fonts.gstatic.com/s/poppins/v9/pxiEyp8kv8JHgFVrJJnecnFHGPezSQ.woff2) format('woff2'); unicode-range: U+0100-024F, U+0259, U+1E00-1EFF, U+2020, U+20A0-20AB, U+20AD-20CF, U+2113, U+2C60-2C7F, U+A720-A7FF; }
@font-face { font-family: 'Poppins'; font-style: normal; font-weight: 500; src: local('Poppins Medium'), local('Poppins-Medium'), url(https://fonts.gstatic.com/s/poppins/v9/pxiByp8kv8JHgFVrLGT9Z1xlFd2JQEk.woff2) format('woff2'); unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+2000-206F, U+2074, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD; }
@font-face { font-family: 'Poppins'; font-style: normal; font-weight: 700; src: local('Poppins Bold'), local('Poppins-Bold'), url(https://fonts.gstatic.com/s/poppins/v9/pxiByp8kv8JHgFVrLCz7Z11lFd2JQEl8qw.woff2) format('woff2'); unicode-range: U+0900-097F, U+1CD0-1CF6, U+1CF8-1CF9, U+200C-200D, U+20A8, U+20B9, U+25CC, U+A830-A839, U+A8E0-A8FB; }
@font-face { font-family: 'Poppins'; font-style: normal; font-weight: 700; src: local('Poppins Bold'), local('Poppins-Bold'), url(https://fonts.gstatic.com/s/poppins/v9/pxiByp8kv8JHgFVrLCz7Z1JlFd2JQEl8qw.woff2) format('woff2'); unicode-range: U+0100-024F, U+0259, U+1E00-1EFF, U+2020, U+20A0-20AB, U+20AD-20CF, U+2113, U+2C60-2C7F, U+A720-A7FF; }

/* Source Sans Pro */
@font-face { font-family: 'Source Sans Pro'; font-style: normal; font-weight: 400; src: local('Source Sans Pro Regular'), local('SourceSansPro-Regular'), url(https://fonts.gstatic.com/s/sourcesanspro/v13/6xK3dSBYKcSV-LCoeQqfX1RYOo3qOK7lujVj9w.woff2) format('woff2'); unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+2000-206F, U+2074, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD; }
@font-face { font-family: 'Source Sans Pro'; font-style: normal; font-weight: 400; src: local('Source Sans Pro Regular'), local('SourceSansPro-Regular'), url(https://fonts.gstatic.com/s/sourcesanspro/v13/6xK3dSBYKcSV-LCoeQqfX1RYOo3qNq7lujVj9_mf.woff2) format('woff2'); unicode-range: U+0100-024F, U+0259, U+1E00-1EFF, U+2020, U+20A0-20AB, U+20AD-20CF, U+2113, U+2C60-2C7F, U+A720-A7FF; }
@font-face { font-family: 'Source Sans Pro'; font-style: normal; font-weight: 600; src: local('Source Sans Pro SemiBold'), local('SourceSansPro-SemiBold'), url(https://fonts.gstatic.com/s/sourcesanspro/v13/6xKydSBYKcSV-LCoeQqfX1RYOo3i54rwlxdu3cOWxw.woff2) format('woff2'); unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+2000-206F, U+2074, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD; }
@font-face { font-family: 'Source Sans Pro'; font-style: normal; font-weight: 700; src: local('Source Sans Pro Bold'), local('SourceSansPro-Bold'), url(https://fonts.gstatic.com/s/sourcesanspro/v13/6xKydSBYKcSV-LCoeQqfX1RYOo3ig4vwlxdu3cOWxw.woff2) format('woff2'); unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+2000-206F, U+2074, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD; }

/* Avenir (local fonts from styles.css) */
@font-face { font-family: 'Avenir LT Std 45 Book'; font-style: normal; font-weight: normal; src: url('../assets/fonts/AvenirLTStd-Book.woff') format('woff'); }
@font-face { font-family: 'Avenir LT Std 85 Heavy'; font-style: normal; font-weight: normal; src: url('../assets/fonts/AvenirLTStd-Heavy.woff') format('woff'); }
@font-face { font-family: 'Avenir LT Std 35 Light'; font-style: normal; font-weight: normal; src: url('../assets/fonts/AvenirLTStd-Light.woff') format('woff'); }
@font-face { font-family: Montserrat-Ultralight; src: url(../assets/fonts/Montserrat-UltraLight.woff); }

/* ============================================================
   GENERAL BASE (from styles.css)
   ============================================================ */
::selection { color: white; background: #376582; }
::-moz-selection { color: white; background: #376582; }

html {
    font-size: 100%;
    width: auto !important;
    overflow-x: hidden !important;
    scroll-behavior: smooth;
}
body {
    height: 100%;
    background: #FFFFFF;
    font-family: 'Source Sans Pro', sans-serif;
    font-size: 16px;
    font-weight: 300;
    line-height: 28px;
    width: 100%;
    overflow-x: hidden !important;
    margin: auto !important;
}
hr { border-color: transparent; }
strong { font-weight: 700; }

*,
*:before,
*:after {
    -webkit-box-sizing: border-box;
    -moz-box-sizing: border-box;
    box-sizing: border-box;
}
ul, ol { padding-left: 0 !important; }
li { list-style: none; }

a {
    color: red;
    -webkit-transition: all ease 0.25s;
    transition: all ease 0.25s;
}
a:hover { text-decoration: none; opacity: 0.9; color: #376582; }
a:active { text-decoration: none; opacity: 0.7; color: #376582; }
a:visited { text-decoration: none; opacity: 0.7; }
a:focus { text-decoration: none; opacity: 0.7; color: #376582; }

h1 { font-size: 3.75rem; line-height: 4.688rem; }
h2 { font-family: 'Lato', sans-serif; font-weight: 700; font-size: 42px; letter-spacing: 1px; line-height: 4.063rem; text-transform: capitalize; }
h3 { font-size: 32px; line-height: 38px; font-weight: 300; }
h4 { font-size: 24px; line-height: 30px; font-weight: 400; }
h5 { font-size: 18px; font-weight: 400; }
h6 { font-size: 12px; font-family: 'Poppins', sans-serif; letter-spacing: 1px; font-weight: 500; text-transform: uppercase; }
p { color: #41454A; font-size: 16px; font-weight: 300; }

/* ============================================================
   VIEWPORT FIXES (from styles.css)
   ============================================================ */
@-webkit-viewport { width: device-width; }
@-moz-viewport { width: device-width; }
@-ms-viewport { width: device-width; }
@-o-viewport { width: device-width; }
@viewport { width: device-width; }

/* ============================================================
   PRELOADER (from styles.css)
   ============================================================ */
.no-js .preloader { display: none; }
.preloader {
    position: fixed;
    background-color: #fff;
    z-index: 99999;
    height: 100%;
    width: 100%;
    overflow: hidden !important;
}
.ip-header {
    position: fixed;
    top: 0;
    z-index: 100;
    min-height: 480px;
    width: 100%;
    height: 100%;
    background: #fdfdfd;
}
.ip-header h1 { margin: 0; }
.ip-loader {
    position: absolute;
    left: 0;
    width: 100%;
    opacity: 0;
    cursor: default;
    pointer-events: none;
    bottom: 50%;
}
.ip-header .ip-inner { display: block; margin: 0 auto; }
.ip-header .ip-loader svg path { fill: none; stroke-width: 3; }
.ip-header .ip-loader svg path.ip-loader-circlebg { stroke: #ddd; }
.ip-header .ip-loader svg path.ip-loader-circle {
    -webkit-transition: stroke-dashoffset 0.2s;
    transition: stroke-dashoffset 0.2s;
    stroke: #376582;
}
.loading .ip-loader {
    opacity: 1;
    -webkit-animation: animInitialHeader 1s cubic-bezier(0.7,0,0.3,1) both;
    animation: animInitialHeader 1s cubic-bezier(0.7,0,0.3,1) both;
    -webkit-animation-delay: 0.2s;
    animation-delay: 0.2s;
}
@-webkit-keyframes animInitialHeader { from { opacity: 0; -webkit-transform: translate3d(0,800px,0); } }
@keyframes animInitialHeader { from { opacity: 0; -webkit-transform: translate3d(0,800px,0); transform: translate3d(0,800px,0); } }
.loaded .ip-loader {
    opacity: 1;
    -webkit-animation: animLoadedLoader 0.5s cubic-bezier(0.7,0,0.3,1) forwards;
    animation: animLoadedLoader 0.5s cubic-bezier(0.7,0,0.3,1) forwards;
}
@-webkit-keyframes animLoadedLoader { to { opacity: 0; -webkit-transform: translate3d(0,-100%,0) scale3d(0.3,0.3,1); } }
@keyframes animLoadedLoader { to { opacity: 0; -webkit-transform: translate3d(0,-100%,0) scale3d(0.3,0.3,1); transform: translate3d(0,-100%,0) scale3d(0.3,0.3,1); } }
.loaded .ip-header {
    -webkit-animation: animLoadedHeader 1s cubic-bezier(0.7,0,0.3,1) forwards;
    animation: animLoadedHeader 1s cubic-bezier(0.7,0,0.3,1) forwards;
}
@-webkit-keyframes animLoadedHeader { to { -webkit-transform: translate3d(0,-100%,0); } }
@keyframes animLoadedHeader { to { -webkit-transform: translate3d(0,-100%,0); transform: translate3d(0,-100%,0); } }
.no-js .ip-header { position: relative; min-height: 0px; }
.no-js .ip-header .ip-logo { margin-top: 20px; height: 180px; opacity: 1; -webkit-transform: none; transform: none; }
.no-js .ip-header .ip-logo svg path { fill: #fff; }

/* ============================================================
   NAVBAR / BOOTSNAV (from styles.css + charcoal-black.css)
   ============================================================ */
nav.navbar.bootsnav ul.nav > li > a {
    font-family: 'Poppins', sans-serif;
    font-size: 14px;
    font-weight: 500;
    padding: 35px 15px;
    text-transform: uppercase;
    letter-spacing: 1px;
    color: #082639 !important;
}

nav.navbar.bootsnav ul.dropdown-menu.megamenu-content .content ul.menu-col li a:hover,
nav.navbar ul.nav > li > a:hover,
nav.navbar ul.nav li.active > a,
nav.navbar li.dropdown ul.dropdown-menu > li a:hover,
nav.navbar ul.nav li.dropdown.on > a {
    color: #376582;
    background: rgba(0, 0, 0, 0.07);
}

nav.navbar.navbar-transparent ul.nav > li > a:hover,
nav.navbar.no-background ul.nav > li > a:hover,
nav.navbar ul.nav li.scroll.active > a,
nav.navbar-dark ul.nav li.dropdown.on > a {
    color: #376582 !important;
    background: rgba(0, 0, 0, 0.07);
}

@media(max-width:920px) {
    nav.navbar .dropdown .megamenu-content .col-menu ul > li > a:hover {
        color: #376582 !important;
        background: rgba(0, 0, 0, 0.07);
    }
    .navbar-brand .logo-title { padding-top: 0px !important; }
}

ul.nav li.dropdown:hover > ul.dropdown-menu { display: block; }

.sticky-navigation {
    min-height: 90px;
    background: #FFFFFF;
    opacity: 1;
    padding-top: 70px;
    margin-bottom: 0 !important;
    -webkit-backface-visibility: hidden;
}
.sticky-navigation .navbar-header img { max-height: 30px; -webkit-backface-visibility: hidden; }
.sticky-navigation .main-navigation .current a { position: relative; outline: none; color: #376582; }
.sticky-navigation .main-navigation li a {
    font-family: 'Montserrat', sans-serif;
    letter-spacing: 1px;
    font-weight: 400;
    font-size: 12px;
    text-transform: uppercase;
}
.sticky-navigation .main-navigation li a:hover { background: none; color: #376582; }
.sticky-navigation .main-navigation li a:active { background: none; color: #376582; }
.sticky-navigation .main-navigation li a:focus { background: none; color: #376582; }
.sticky-navigation .main-navigation li .dropdown-menu a { color: #f0f0f0; }

.navbar-brand { padding: 10px; }
.navbar-brand .logo-title {
    padding-top: 20px !important;
    padding-left: 10px;
    display: inline-block;
    vertical-align: middle;
    font-family: 'Poppins', cursive;
    color: #082639;
    font-weight: 500;
    text-transform: capitalize;
    font-size: 27px;
    letter-spacing: -1px;
}
.navbar-brand .logo-title span {
    padding-left: 2px;
    font-family: 'Poppins', cursive;
    color: #f95231;
    font-weight: 700;
    text-transform: capitalize;
    font-size: 37px;
    letter-spacing: 0px;
}
.navbar-header a:hover,
.navbar-header a:focus,
.navbar-header a:active { color: rgba(0,0,0,0.5); }

.navbar-toggle .icon-bar { background-color: #376582; }

/* ============================================================
   BANNER / HERO (from styles.css)
   ============================================================ */
.banner-bottom {
    padding-top: 130px;
    padding-bottom: 30px;
    background: #ffffff;
}
.hey {
    position: relative;
    border-bottom: 1px solid #cadced;
}
.hey-left {
    float: right;
    width: 30%;
    margin-bottom: 5rem;
}
.hey-left img { width: 100%; }
.hey-right {
    position: absolute;
    top: 10%;
    right: 22%;
}
.hey-right-t {
    position: relative;
    font-family: 'Poppins', sans-serif;
    font-size: 40px;
    font-weight: 700;
    color: #082639;
    line-height: 1.8em;
    text-align: left;
    margin: 0;
    width: 85%;
}
.hey-right-t span {
    position: relative;
    font-family: 'Poppins', sans-serif;
    font-size: 42px;
    font-weight: 700;
    color: #f95231;
    line-height: 1.8em;
    text-align: left;
    margin: 0;
    width: 73%;
}
.hey-right p {
    font-family: 'Raleway', sans-serif;
    font-size: 23px;
    color: #203b4c;
    font-weight: 400;
    line-height: 1.5em;
    text-align: left;
    margin: 0;
    width: 90%;
}
.hey-right p a { color: blue; text-decoration: none; }

/* Hero social icons under photo */
.hey-left .social-icons {
    display: flex;
    flex-direction: row;
    justify-content: center;
    padding: 0;
    margin-top: 14px !important;
    list-style: none;
    width: 100%;
}
.hey-left .social-icons li { margin-right: 4px; }

.social-icons-left {
    padding: 15px 0 0 0;
    margin-left: 0px !important;
    text-align: left;
    margin-bottom: 0 !important;
}

/* Responsive hero */
@media screen and (max-width: 320px) {
    .hey-right p { font-size: 13px; width: 100%; }
    .navbar-brand .logo-title { padding-top: 0px !important; }
}
@media screen and (max-width: 480px) {
    .hey-left { float: none; width: 100%; margin: 62px 0px 0 0px; }
    .hey-right { top: 0; position: inherit; text-align: center; left: 0; margin: 1em 0 0; }
    .hey-right-t, .hey-right-t span { line-height: 1.1em !important; }
    .section-top { padding-top: 50px; }
    .banner-bottom { padding: 0px 0; background: #ffffff; }
}
@media screen and (max-width: 640px) {
    .hey-right p { font-size: 17px; }
    .hey-right { top: 9%; }
}
@media screen and (max-width: 768px) {
    .hey-right p { font-size: 18px; }
}
@media screen and (max-width: 1024px) {
    .hey-right p { width: 95%; }
}

/* ============================================================
   SECTIONS
   ============================================================ */
.section-top { padding-top: 90px; }

/* Alternating section backgrounds */
section#biography      { background: #ffffff; padding: 70px 0; }
section#expertise      { background: #fff6f6a6; padding: 70px 0; }
section#experience     { background: #ffffff; padding: 70px 0; }
section#certifications { background: #ffffff; padding: 70px 0; }
section#education      { background: #ffffff; padding: 70px 0; }
section.contact        { background: #fff6f6a6; padding: 70px 0; }

/* Section number tag */
.section-num {
    display: flex;
    align-items: center;
    gap: 10px;
    font-size: 0.7rem;
    font-weight: 500;
    letter-spacing: 0.16em;
    text-transform: uppercase;
    color: #e8372a;
    margin-bottom: 8px;
}
.section-num::before {
    content: '';
    display: inline-block;
    width: 22px;
    height: 1px;
    background: #e8372a;
}

/* ============================================================
   ABOUT / BIOGRAPHY (from styles.css)
   ============================================================ */
.about { background: #FFFFFF; }
.about-us { text-align: left; font-size: 16px; }
.about-descrp p { padding-bottom: 15px; padding-right: 40px; text-align: left; }
.about-us .col-md-6 { padding: 0px 30px; }
.about-subtitle {
    font-family: 'Poppins', sans-serif;
    font-weight: 500;
    font-size: 30px;
    text-align: left;
    text-transform: none;
    color: #082639;
}
.about-subtitle span {
    font-family: 'Poppins', sans-serif;
    font-weight: 400;
    font-size: 42px;
    text-align: left;
    color: #f95231;
    text-transform: none;
}
.about-us a { font-size: 17px; font-weight: 400; color: #000; }

#biography p { font-size: larger; text-align: left; }

/* Biography pull quote */
.bio-pullquote {
    border-left: 3px solid #1a1a1a;
    padding: 6px 0 6px 18px;
    margin: 20px 0;
    font-style: italic;
    font-size: 1rem;
    color: #333;
    line-height: 1.65;
}

/* LinkedIn recommendations link */
.rec-link-block {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    margin-top: 20px;
    color: #0E76A8 !important;
    font-size: 0.88rem;
    font-weight: 500;
    text-decoration: underline !important;
    text-underline-offset: 3px;
    transition: color 0.2s;
}
.rec-link-block:hover { color: #095a80 !important; }
.rec-link-block svg { flex-shrink: 0; }

/* ============================================================
   EXPERTISE GRID
   ============================================================ */
.expertise-grid-new {
    display: grid;
    grid-template-columns: 1fr 1fr;
    border-top: 1px solid #e0e0e0;
    border-left: 1px solid #e0e0e0;
}
.expertise-card {
    border-right: 1px solid #e0e0e0;
    border-bottom: 1px solid #e0e0e0;
    padding: 22px 24px;
    display: flex;
    align-items: flex-start;
    gap: 16px;
    background: #ffffff;
    transition: background 0.15s;
}
.expertise-card:hover { background: #fff6f6a6; }
.expertise-card-num {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 36px;
    height: 36px;
    border: 1px solid #ddd;
    font-size: 0.65rem;
    font-weight: 600;
    letter-spacing: 0.08em;
    color: #c0392b;
    flex-shrink: 0;
    font-family: monospace;
    transition: background 0.15s, color 0.15s, border-color 0.15s;
}
.expertise-card:hover .expertise-card-num {
    background: #e8372a;
    color: #ffffff;
    border-color: #e8372a;
}
.expertise-card-body h4 {
    font-size: 0.82rem !important;
    font-weight: 700 !important;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: #1a1a1a !important;
    margin: 0 0 5px 0 !important;
    line-height: 1.3;
}
.expertise-card-body p {
    font-size: 0.78rem;
    color: #777;
    margin: 0;
    line-height: 1.5;
}

/* ============================================================
   EXPERIENCE ACCORDION
   ============================================================ */
.exp-accordion {
    border-top: 1px solid #e0e0e0;
    margin-bottom: 32px;
}
.acc-item { border-bottom: 1px solid #e0e0e0; }
.acc-header {
    width: 100%;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    padding: 20px 0;
    background: none;
    border: none;
    cursor: pointer;
    text-align: left;
    transition: background 0.15s;
}
.acc-header:hover {
    background: #fff6f6a6;
    padding-left: 12px;
    padding-right: 12px;
    margin: 0 -12px;
    width: calc(100% + 24px);
}
.acc-header-left { display: flex; flex-direction: column; gap: 3px; }
.acc-date {
    font-size: 0.82rem;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: #e8372a;
    font-weight: 500;
}
.acc-role { font-size: 1.15rem; font-weight: 700; color: #1a1a1a; line-height: 1.2; }
.acc-company { font-size: 1.1rem !important; color: #888; }
.acc-icon {
    flex-shrink: 0;
    width: 22px;
    height: 22px;
    color: #e8372a;
    transition: transform 0.3s ease, color 0.2s;
}
.acc-icon svg { width: 22px; height: 22px; }
.acc-item.acc-open .acc-icon { transform: rotate(180deg); color: #e8372a; }
.acc-body {
    max-height: 0;
    overflow: hidden;
    transition: max-height 0.35s ease, padding 0.35s ease;
    padding: 0;
}
.acc-item.acc-open .acc-body {
    max-height: 600px;
    padding: 0 0 20px 0;
}

/* Experience bullet points */
.exp-bullets { list-style: none; padding: 8px 0 0 0; margin: 0; }
.exp-bullets li {
    position: relative;
    padding-left: 16px;
    margin-bottom: 7px;
    font-size: 1.15rem !important;
    color: #555;
    line-height: 1.7;
}
.exp-bullets li::before { content: '–'; position: absolute; left: 0; color: #aaa; }

/* CV CTA bar */
.exp-cv-cta {
    margin-top: 30px;
    padding: 22px 26px;
    background: #f7f7f7;
    border: 1px solid #e8e8e8;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    flex-wrap: wrap;
}
.exp-cv-cta p { margin: 0; font-size: 0.9rem; color: #555; }
.exp-cv-cta strong { display: block; color: #1a1a1a; margin-bottom: 2px; font-size: 0.95rem; }

/* ============================================================
   CV DOWNLOAD BUTTON
   ============================================================ */
.btn-download-cv {
    display: inline-flex;
    align-items: center;
    gap: 9px;
    margin-top: 18px;
    padding: 13px 28px;
    background: #1a1a1a;
    color: #fff !important;
    font-size: 0.78rem;
    font-weight: 600;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    border: 2px solid #1a1a1a;
    text-decoration: none;
    transition: background 0.2s, color 0.2s;
}
.btn-download-cv:hover { background: transparent; color: #1a1a1a !important; }
.btn-download-cv svg { width: 15px; height: 15px; flex-shrink: 0; }

/* ============================================================
   HERO STATS ROW
   ============================================================ */
.hero-stats-row {
    display: flex;
    align-items: center;
    gap: 0;
    margin: 22px 0 24px;
    flex-wrap: wrap;
}
.hero-stat {
    padding: 0 22px 0 0;
    margin-right: 22px;
    border-right: 1px solid #ddd;
}
.hero-stat:last-child { border-right: none; padding-right: 0; margin-right: 0; }
.hero-stat-num { font-size: 1.9rem; font-weight: 700; color: #1a1a1a; line-height: 1; margin-bottom: 2px; }
.hero-stat-label { font-size: 0.68rem; letter-spacing: 0.1em; text-transform: uppercase; color: #888; font-weight: 400; }

/* ============================================================
   OPPORTUNITY BADGE
   ============================================================ */
.opportunity-badge {
    display: inline-block;
    padding: 5px 14px;
    border: 1px solid #1a1a1a;
    font-size: 0.68rem;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: #1a1a1a;
    margin-bottom: 14px;
    font-weight: 500;
}

/* Grey divider after CV button */
.hero-divider { border: none; border-top: 1px solid #e5e5e5; margin: 28px 0 0 0; }

/* ============================================================
   CERTIFICATIONS
   ============================================================ */
.cert-groups {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 0;
    border-top: 1px solid #e0e0e0;
    border-left: 1px solid #e0e0e0;
    margin-bottom: 24px;
}
.cert-group {
    border-right: 1px solid #e0e0e0;
    border-bottom: 1px solid #e0e0e0;
    padding: 20px 22px;
    background: #ffffff !important;
    transition: background 0.2s;
}
.cert-group:hover { background: #ffe5e5 !important; }
.cert-group-header {
    display: flex;
    align-items: center;
    gap: 10px;
    margin-bottom: 10px;
    padding-bottom: 8px;
    border-bottom: 2px solid #e8372a;
}
.cert-group-issuer {
    font-size: 1.1rem !important;
    font-weight: 700;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: #e8372a;
}
.cert-group-list {
    list-style: none;
    padding: 0;
    margin: 0;
    display: flex;
    flex-direction: column;
    gap: 6px;
}
.cert-group-list li {
    font-size: 1.15rem !important;
    color: #333;
    line-height: 1.45;
    padding-left: 12px;
    position: relative;
}
.cert-group-list li::before { content: '·'; position: absolute; left: 0; color: #e8372a; font-size: 1.1rem; line-height: 1.2; }
.cert-meta { color: #999; font-size: 0.78rem; }
.cert-footer-note { font-size: 0.83rem; color: #888; margin-top: 4px; }
.cert-footer-note a { color: #0E76A8; }

/* ============================================================
   EDUCATION — TIMELINE (from styles.css)
   ============================================================ */
.timeline { margin-top: 20px; overflow: hidden; }
.timeline:before {
    content: "\A";
    display: block;
    opacity: 1;
    width: 1px;
    height: 100%;
    position: absolute;
    bottom: -200%;
    left: 19px;
    background: #395160;
    -webkit-transition: all 2s ease-out;
    -moz-transition: all 2s ease-out;
    -ms-transition: all 2s ease-out;
    -o-transition: all 2s ease-out;
    transition: all 2s ease-out;
}
.timeline.on:before { bottom: 50px; }
.timeline .entry {
    font-size: 14px;
    font-family: "Poppins", sans-serif;
    font-weight: 400;
    color: #8a8a8a;
    margin-bottom: 30px;
}
.timeline .last-entry .time { margin-bottom: 60px; }
.timeline .entry .content span {
    font-size: 18px;
    font-family: "Montserrat", sans-serif;
    text-transform: uppercase;
    font-weight: 400;
    color: #2c2c2c;
}
.timeline .entry .time {
    font-size: 15px;
    font-family: "Montserrat", sans-serif;
    font-weight: 400;
    color: #8a8a8a;
}
.timeline .entry:last-of-type { margin-bottom: 0px; }
.timeline .entry:before,
.timeline .entry:after { content: " "; display: table; }
.timeline .entry:after { clear: both; }
.timeline .entry .strong { display: block; color: #212121; font-weight: 700; }
.timeline .entry .time,
.timeline .entry .content { float: left; width: 100%; }
.timeline .entry .time { position: relative; padding-left: 40px; }
.timeline .entry .content { padding-top: 20px; padding-left: 50px; }
.timeline .entry .time:before {
    content: "\A";
    display: block;
    position: absolute;
    top: 6px;
    left: 0px;
    width: 10px;
    height: 10px;
    background: #f95231;
    border: 2px solid #f95231;
    -webkit-border-radius: 100%;
    -moz-border-radius: 100%;
    border-radius: 100%;
}
.timeline .entry .time.on:before { background: #f95231; border: 2px solid #f95231; }

@media only screen and (min-width: 480px) {
    .timeline .entry .time,
    .timeline .entry .content { width: 100%; }
    .timeline .entry .content { padding-top: 0px; padding-left: 0px; }
}
@media only screen and (min-width: 992px) {
    .timeline .entry .time:before { top: 6px; left: -4px; }
    .timeline:before { left: 15px; }
}
@media only screen and (min-width: 1200px) {
    .timeline .entry { font-size: 16px; }
}

/* ============================================================
   CONTACT (from styles.css)
   ============================================================ */
.contact .contact-box { }
.contact .contact-address { margin-top: 10px; margin-bottom: 30px; }
.contact .contact-address i { font-size: 22px; vertical-align: middle; margin-right: 6px; color: #376582; }
.contact .contact-address ul li {
    font-family: 'Montserrat', sans-serif;
    font-weight: 400;
    font-size: 15px;
    line-height: 18px;
    padding: 10px;
    letter-spacing: 2px;
}
.contact .contact-address ul li span {
    font-family: 'Montserrat', sans-serif;
    font-weight: 400;
    font-size: 18px;
    text-transform: none;
    letter-spacing: 1px;
}

/* ============================================================
   SOCIAL ICONS (from styles.css + charcoal-black.css)
   ============================================================ */
.social-icons { text-align: left; }
.social-icons li { display: inline-block; }
.social-icons li a {
    margin: 0 10px;
    height: 35px;
    width: 35px;
    border-radius: 50%;
    line-height: 37px;
    font-size: 14px;
    color: #949494;
}
.social-icons li a:hover { color: #376582; }

/* ============================================================
   FOOTER (from styles.css)
   ============================================================ */
.footer-section {
    background: #1d1d1d;
    padding-top: 30px;
    overflow-x: hidden;
}
.footer-content {
    padding: 20px 0 60px;
    text-align: left;
    color: #949494;
}
.footer-content .footer-column { padding: 0px auto; }
.footer-2 { background: #f8f8f8; }
.footer-2 .footer-column p {
    text-transform: uppercase;
    font-size: 13px;
    color: #082639;
    font-weight: 700;
    padding-left: 120px;
    font-family: "Montserrat", sans-serif;
}
.footer-2 .social-icons { text-align: right; padding: 0px; }
.footer-2 .social-icons li a { margin: 0px 2px; }

@media (max-width: 767px) {
    .footer-content { padding: 0px 0px; }
    .footer-column { text-align: center; padding: 20px 0px; }
    .footer-2 .footer-column p { padding-left: 0px; }
    .footer-2 .social-icons { text-align: center; padding: 10px; margin-left: 0px; }
}
@media (max-width: 480px) {
    .footer-content { padding: 0px 0px; }
    .footer-content .footer-column { text-align: center; padding: 10px 0px; }
    .footer-2 .footer-column p { padding-left: 0px; }
    .footer-2 .social-icons { text-align: center; padding: 10px; margin-left: 0px; }
}

/* ============================================================
   BUTTON SVG (social icon links)
   ============================================================ */
.button--svg { display: inline-block; }

/* Utility */
.social-icons-centered { justify-content: center; margin-top: 16px; }
.mt-0 { margin-top: 0 !important; }


/* ============================================================
   MOBILE — single column for expertise & certifications
   ============================================================ */
@media screen and (max-width: 767px) {
    .expertise-grid-new {
        grid-template-columns: 1fr;
    }
    .cert-groups {
        grid-template-columns: 1fr;
    }
}
