@import url('https://fonts.googleapis.com/css?family=Cormorant+Garamond:300,400,500,600,700|Roboto:100,300,400,500,700,900&display=swap');
@import url('https://fonts.googleapis.com/css2?family=Roboto:ital,wght@0,100;0,300;0,400;0,500;0,700;0,900;1,100;1,300;1,400;1,500;1,700;1,900&display=swap');
@import url('https://fonts.googleapis.com/css2?family=Merriweather:ital,wght@0,300;0,400;0,700;0,900;1,300;1,400;1,700;1,900&display=swap');

/*
font-family: 'Roboto', sans-serif;
font-family: 'Cormorant Garamond', serif;
font-family: 'Playfair Display', serif;
font-family: 'Merriweather', serif;
*/

/* 
---------
---------
CLEARING & RESETS
---------
---------
*/
    * {
        margin:0;
        padding:0;
    }

    .container, .pageBody {
        margin:0 auto;
        width:1220px;
        display:block;
    }

        .pageBody {
            padding-bottom:75px;;
            padding-top:75px;
        }

        .narrow {
            width:800px;;
        }

    .container:after { content: "\0020"; display: block; height: 0; clear: both; visibility: hidden; }

    /* Use clearfix class on parent to clear nested columns,
    or wrap each row of columns in a <div class="row"> */
    .clearfix:before,
    .clearfix:after,
    .row:before,
    .row:after {
      content: '\0020';
      display: block;
      overflow: hidden;
      visibility: hidden;
      width: 0;
      height: 0; }
    .row:after,
    .clearfix:after {
      clear: both; }
    .row,
    .clearfix {
      zoom: 1; }

    /* You can also use a <br class="clear" /> to clear columns */
    .clear {
      clear: both;
      display: block;
      overflow: hidden;
      visibility: hidden;
      width: 0;
      height: 0;
    }

    html, body, div, span, applet, object, iframe,
    h1, h2, h3, h4, h5, h6, p, blockquote, pre,
    a, abbr, acronym, address, big, cite, code,
    del, dfn, em, img, ins, kbd, q, s, samp,
    small, strike, strong, sub, sup, tt, var,
    b, u, i, center,
    dl, dt, dd, ol, ul, li,
    fieldset, form, label, legend,
    table, caption, tbody, tfoot, thead, tr, th, td,
    article, aside, canvas, details, embed, 
    figure, figcaption, footer, header, hgroup, 
    menu, nav, output, ruby, section, summary,
    time, mark, audio, video {
        margin: 0;
        padding: 0;
        border: 0;
        font-size: 100%;
        font: inherit;
        vertical-align: baseline;
    }

    article,aside,details,figcaption,figure,
    footer,header,hgroup,menu,nav,section { 
        display:block;
    }

    /**, *:after, *:before { -webkit-box-sizing: border-box; box-sizing: border-box; }
    .clearfix:before, .clearfix:after { display: table; content: ''; }
    .clearfix:after { clear: both; }*/


/* 
---------
---------
SITE WIDE 
---------
---------
*/

html {
    font-family: 'Merriweather', serif;
    color:#000201;
    background:#EAEAEA;
    -webkit-font-smoothing: antialiased; /* Fix for webkit rendering */
	-webkit-text-size-adjust: 100%;
	-moz-osx-font-smoothing: grayscale;
}

strong, b {
    font-weight:900;
}

em {
    font-style:italic;
}

.orange {
    color:#e5be82;
}

.darkTan {
    color:#8e6940;
    text-shadow:1px 1px 0 #000201;
}

.lightGreen {
   color:#94a187;
}

.green {
    color:#93A187;
}

.darkGreen {
    color:#2b490b;
    text-shadow:1px 1px 0 #000201;
}

.center {
    text-align:center;
}

.centered {
    float:none;
    margin:auto;
    display:block;
}

.right {
    text-align:right;
}

.noBottom {
    margin-bottom:0!important;
}

    .blogText p.noBottom {
        margin-bottom:0;
    }

.noTop {
    margin-top:0!important;
}

.light {
    font-weight:300;
}

.bold {
    font-weight:700;
}

.boldest, b {
    font-weight:900;
}

.marginLeft {
    display:inline-block;
    margin-left:10px;
}

.marginRight {
    display:inline-block;
    margin-right:10px;
}

/*.description {
    display:block;
    margin:1em auto;
    float:none;
    text-align:center;
    padding:0 5em;
}*/

section {
    display:block;
    padding:4em 5em;
}

section.wide {
    padding:4em 0;
}


/* iFrames */
iframe.video {
    width:80%;
    height:450px;
    display:block;
    margin:10px auto;
}



/* Asides */

aside {
    display:block;
    background:#eeeeee;
    border:1px solid #000201;
    border-radius:10px;
    padding:20px;
    width:90%;
    margin:25px auto;
    font-size:24px;
    line-height:36px;
    font-family: 'Cormorant Garamond', serif;
}

    aside h3 {
        text-align:center;
        font-size:28px;
        font-weight:800;
        margin-bottom:25px;
        border-bottom:1px solid #000201;
    }

    aside.right {
        width:40%;
        float:right;
        display:inline;
        margin:25px 0 25px 25px;
    }

    aside.left {
        width:40%;
        float:left;
        display:inline;
        margin:25px 25px 25px 0;
    }

        aside.left, aside.right, aside.left p, aside.right p, aside.left ul li, aside.right ul li {
            font-size:21px;
            line-height:28px;
            font-weight:800;
            margin-bottom:10px;
        }

        aside.left ul li, aside.right ul li {
            margin-bottom:10px;
        }

    aside.dark {
        /* Permalink - use to edit and share this gradient: https://colorzilla.com/gradient-editor/#2e302f+0,171918+100 */
        background: rgb(46,48,47); /* Old browsers */
        background: -moz-linear-gradient(45deg,  rgba(46,48,47,1) 0%, rgba(23,25,24,1) 100%); /* FF3.6-15 */
        background: -webkit-linear-gradient(45deg,  rgba(46,48,47,1) 0%,rgba(23,25,24,1) 100%); /* Chrome10-25,Safari5.1-6 */
        background: linear-gradient(45deg,  rgba(46,48,47,1) 0%,rgba(23,25,24,1) 100%); /* W3C, IE10+, FF16+, Chrome26+, Opera12+, Safari7+ */
        filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#2e302f', endColorstr='#171918',GradientType=1 ); /* IE6-9 fallback on horizontal gradient */

        border:2px solid #000201;
        box-shadow:2px 2px 1px #000;
    }

        aside.dark * {
            color:#eeeeee;
        }

        aside.dark h3 {
            border-bottom:1px solid #eee;
        }




/* Tip Box */
.tipBox {
    width:80%;
    display:block;
    margin:2em auto;
    clear:both;
    border:1px solid #000201;
    border-radius:10px;
    display:flex;
    overflow:hidden;
    align-items:stretch;
}

    .tipLabel {
        background:#000201;
        color:#eaeaea;
        padding:20px;
        text-align:center;
        min-width:150px;
        font-size:2.25em;
        font-weight:800;
    }

    .tipText {
        padding:20px;
    }

.tipText.red {
	font-weight:900;
}

.tipText.red strong {
	color:#EE1819;
}


        .tipText ul {
            margin-bottom:0;
        }

            .tipText ul li {
                margin-bottom:10px;
            }










/*
---------
---------
Images
---------
---------
*/
img {
    max-width:100%;
    height:auto;
}

    .alignleft, .alignright, .wp-caption.alignleft, .wp-caption.alignright {
        width:40%!important;
        height:auto!important;
    }

        .alignleft.tall, .alignright.tall {
            width:25%!important;
        }

        .alignleft.slim, .blogText .alignright.slim {
            width:10%!important;
        }

    .alignleft {
        margin-right:1em;
        margin-bottom:1em;
        float:left;
        display:inline;
    }

    .aligncenter {
        margin:1em auto;
        width:60%;
        display:block;
        clear:both;
    }

    .alignright {
        margin-left:1em;
        margin-bottom:1em;
        float:right;
        display:inline;
    }

        .smaller {
            width:25%!important;
        }

.fullWidth {
    display:block;
    clear:both;
    height:500px;
    width:100%;
    margin:1em auto 0;
    padding:0;
    overflow:hidden;
}


.fullWidth img {    
    float:left;
    width:100%;
    height:100%;
    object-fit:cover;
}

hr {
    display:block;
    margin:75px auto;
    clear:both;
    border:.5px solid #d5d5d5;
    width:60%;
}


.footnote {
    display:block;
    clear:both;
    margin:10px auto 50px auto;
    padding:0 25px 25px;
    font-size:14px;
    text-align:right;
    font-family: 'Cormorant Garamond', serif;
}



/* Galleries */
.rl-gallery-caption {
    display:none;
}


.breadcrumbs {
    font-size:12px;
    line-height:12px;
    margin-bottom:20px;
    margin-top:10px;
    padding-left:2em;
    font-family: 'Merriweather', serif;
}

.breadcrumbs a {
    font-weight:800;
    color:#8E6940;
}

.breadcrumbs br, .prevNext br {
    display:none;
}



/*
---------
---------
Forms
---------
---------
*/

.nf-form-fields-required {
    text-align:center;
    margin-bottom:20px;
    font-style:italic;
    font-family:'Roboto', sans-serif;
    display:block;
}

.nf-form-content .list-select-wrap .nf-field-element > div, .nf-form-content input:not([type="button"]), .nf-form-content textarea {
    background:#f5f4ff!important;
    font-size: 1.1em!important;
    padding:15px 20px!important;
    border-radius: 5px!important;
    font-family: 'Cormorant Garamond', serif;
    color:#000201!important;
}

.nf-form-content button, .nf-form-content input[type="button"], .nf-form-content input[type="submit"] {
    background-color:rgba(234,234,234,0.4)!important;
    border:3px solid #000201!important;
    border-radius:5px!important;
    padding:10px!important;
    display:block!important;
    margin:1em auto 2em auto!important;
    text-align:center!important;
    color:#000201!important;
    font-weight:500!important;
    text-transform:lowercase!important;
    font-size:24px!important;
    line-height:24px!important;
    -webkit-transition:all .25s ease!important;  
    -moz-transition:all .25s ease!important;  
    -o-transition:all .25s ease!important;  
    transition:all .25s ease!important;
    font-family: 'Cormorant Garamond', serif!important;
    cursor:pointer!important;
    width:60%!important;
}

    .nf-form-content button:hover, .nf-form-content input[type="button"]:hover, .nf-form-content input[type="submit"]:hover {
        background-color:rgba(0,2,1,0.8)!important;
        color:#EAEAEA!important;
        -webkit-transition:all .25s ease!important;  
        -moz-transition:all .25s ease!important;  
        -o-transition:all .25s ease!important;  
        transition:all .25s ease!important;
    }



/*
---------
---------
Text & Links 
---------
---------
*/
p, h1, h2, h3, h4, h5 {
    display:block;
}


p {
    font-family: 'Merriweather', serif;
    font-weight:500;
    font-size:21px;
    line-height:36px;
    color:#000201;
    margin-bottom:40px;
}

    p.intro {
        font-size:26px;
        line-height:48px;
        font-weight:300;
        margin-bottom:1em;
        display:block;
        text-align:center;
    }

        p.intro.resume {
            text-align:left;
            font-weight:500;
        }

h1 {
    font-family: 'Cormorant Garamond', serif;
    font-size:5em;
    line-height:1em;
    margin-bottom:.25em;
    text-align:center;
}

h2 {
    font-family: 'Cormorant Garamond', serif;
    font-size:32px;
    line-height:1.1em;
}

h2.title a {
    color:#162803;
}

h2.title a:hover {
    color:#2b490b;
}

h3 {
    font-size:32px;
    line-height:40px;
    font-family:'Roboto', sans-serif;
    font-weight:800;
}

h4 {
    font-size: 26px;
    line-height: 40px;
    font-family: 'Roboto', sans-serif;
    font-weight: 800;
}


h5 {
    font-size: 14px;
    text-align: center;
    font-weight: 700;
    color:#F9ECDC;
    text-shadow:1px 1px 0 #000000;
}

h6 {
    font-size:18px;
    font-weight:300;
    line-height: 40px;
    font-family: 'Roboto', sans-serif;
}

/* Links */
    a {
        color:#f05d23;
        font-weight:900;
        text-decoration:none;
        -webkit-transition:color .25s ease-in;  
        -moz-transition:color .25s ease-in;  
        -o-transition:color .25s ease-in;  
        transition:color .25s ease-in;
        cursor: pointer;
    }

        a:hover {
            color:#af441a;
            -webkit-transition:color .25s ease-in;  
            -moz-transition:color .25s ease-in;  
            -o-transition:color .25s ease-in;  
            transition:color .25s ease-in;
        }

        a.button {
            background-color:rgba(234,234,234,0.4);
            border:3px solid #000201;
            border-radius:5px;
            padding:10px;
            display:block;
            margin:1em auto 2em;
            text-align:center;
            color:#000201;
            font-weight:500;
            text-transform:lowercase;
            font-size:24px;
            line-height:24px;
            -webkit-transition:all .25s ease;  
            -moz-transition:all .25s ease;  
            -o-transition:all .25s ease;  
            transition:all .25s ease;
            font-family: 'Cormorant Garamond', serif;
        }

            a.button:hover {
                background-color:rgba(0,2,1,0.8);
                color:#EAEAEA;
                -webkit-transition:all .25s ease;  
                -moz-transition:all .25s ease;  
                -o-transition:all .25s ease;  
                transition:all .25s ease;
            }

            a.button.thin {
                width:60%;
            }

            a.button.small {
                width:60%;
                margin:10px auto;
                font-size:16px;
                line-height:16px;
                font-weight:800;
                border:1px solid #000201;
            }

                a.button.medium {
                    width:40%;
                    padding:.5em 1em;
                }

            a.button.full {
                width:90%;
            }

            ul.buttons {
                margin-top:2em;
                list-style-type:none;
                margin-left:0!important;
            }

                ul.buttons li {
                    margin-bottom:1em;
                }

        a.block {
            display:block;
        }





/*
---------
---------
LISTS
---------
---------
*/


ul.noBullet * {
    list-style-type:none;
}

ul.socialIcons {
    display:flex;
    flex-direction: row;
    justify-content: space-between;
    list-style-type: none;
}

    ul.socialIcons li a {
        font-weight:normal;
    }

    header ul.socialIcons {
        width:20%;
        padding:0 0 0 2em;
    }

    .socialIcons.large {
        margin:0 auto;
        width:60%;
    }

        .socialIcons.large li {
            font-size:72px;
            line-height:72px;
            margin:25px auto;
        }

            .socialIcons.large li a {
                color:#f05d23;
            }

                .socialIcons.large li a:hover {
                    color:#af441a;
                }

.sidePage ul, .sidePage ol {
    margin-left:50px;
    font-size:21px;
    line-height:36px;
    font-family: 'Merriweather', serif;
    margin-bottom:2em;
}

ul.noLeft, ol.noLeft {
    margin-left:0;
}

/*
---------
---------
HEADER
---------
---------
*/
header {
    grid-template-columns: 1fr 1fr;
    grid-template-rows: 1fr 1fr;
    grid-template-areas: "left rightTop" "left rightBottom";
    display:grid;
    position: fixed;
    width: 100%;
    -webkit-transition: all 0.4s ease;
    -moz-transition: all 0.4s ease;
    -o-transition: all 0.4s ease;
    transition: all 0.4s ease;
    z-index:100;
    overflow:hidden;
}

    header.sticky {
        height:75px;
        border-bottom:2px solid #000;
        background-color:#000201;
        -webkit-transition: all 0.4s ease;
        -moz-transition: all 0.4s ease;
        -o-transition: all 0.4s ease;
        transition: all 0.4s ease;
        top:0;
    }
    
        header.sticky #stickyLogo {
            display:block;
            padding:1em 0 1em 2em;
        }

            header.sticky #stickyLogo img {
                height:50px;
                -webkit-transition: all 0.4s ease;
                -moz-transition: all 0.4s ease;
                -o-transition: all 0.4s ease;
                transition: all 0.4s ease;
                top:-15px;
                position:relative;
            }

        header.sticky #topLogo {
            display:none;
        }

        header.sticky #searchBox {
            display:none;
        }

        header.sticky nav a {
            color:#EAEAEA;
        }

        header.sticky nav a:hover {
            color:#F9ECDC;
        }

        header.sticky nav li.current_page_item a {
            color:#f7f5f5;
            border-top:2px solid #f7f5f5;
            border-bottom:2px solid #f7f5f5;
        }

    #topLogo {
        grid-area: left;
        padding:1em 0 1em 2em;
    }

        #topLogo img {
            height:70px;
            width:auto;
            -webkit-transition: all 0.4s ease;
            -moz-transition: all 0.4s ease;
            -o-transition: all 0.4s ease;
            transition: all 0.4s ease;
            position:relative;
        }

        #stickyLogo {
            display:none;
        }

/* Navigation Menu */
    #primary-menu {
        width:100%;
    }

    nav {
        grid-area:rightTop;
        text-align:right;
        padding:1em 3em 0 0;
        font-size:.95em;
        font-weight:800;
        display:flex;
        flex-direction:row;
        flex-wrap:nowrap;
    }

        nav ul {
            list-style-type:none;
            display:flex;
            flex-direction:row;
            flex-wrap:nowrap;
            justify-content: space-between;
        }

            nav ul li {
                font-size:18px;
                text-transform:lowercase;
                font-weight:700;
                font-family: 'Cormorant Garamond', serif;
            }

        nav a {
            color:#000201;
            font-weight:700;
        }

            nav a:hover {
                color:#2b490b;
                -webkit-transition:color .25s ease-in;  
                -moz-transition:color .25s ease-in;  
                -o-transition:color .25s ease-in;  
                transition:color .25s ease-in;
            }

nav li.current_page_item a {
    color:#2b490b;
    font-weight:900;
    border-top:2px solid #2b490b;
    border-bottom:2px solid #2b490b;
    font-size:1.1em;
}


/* Mobile Menu */
    .panel {
        position: fixed; 
        right: -15.625em; 
        width: 15.625em; 
        background:#1A1B1A;
        z-index:10000000000000000000000;
    }

    .push {
        position:relative;
    }

    .menu-link {
        display:none;float:right;
    }

    .mobile-menu a {
        display:block;
        color:#EAEAEA;
        padding:10px 15px;
        -webkit-transition:all .25s ease;  
        -moz-transition:all .25s ease;  
        -o-transition:all .25s ease;  
        transition:all .25s ease;
    }

    .mobile-menu a:hover {
        color:#af441a;
        -webkit-transition:all .25s ease;  
        -moz-transition:all .25s ease;  
        -o-transition:all .25s ease;  
        transition:all .25s ease;
    }

    .mobile-menu ul {
        list-style-type:none;
    }

    .mobile-menu li {
        border-bottom:1px #444 solid;
    }


/* Search Box */
    #searchBox {
        grid-area: rightBottom;
        padding:0 2em 1em 0;
    }

#searchBox form {
    float:right;
}

            .search-form .search-submit {
                background-color:inherit;
                border:none;
                color:#000201;
                font-size:1.2em;
                padding-right:1em;
            }

            .search-field {
                font-size:1.1em;
                padding:.25em;
                background-color:#f5f4ff;
                border-radius:5px;
                margin-right:.25em;
                -webkit-transition: all 0.4s ease;
                -moz-transition: all 0.4s ease;
                -o-transition: all 0.4s ease;
                transition: all 0.4s ease;
                width:250px;
                font-family: 'Cormorant Garamond', serif;
            }

                .search-field:focus {
                    width:400px;
                    -webkit-transition: all 0.4s ease;
                    -moz-transition: all 0.4s ease;
                    -o-transition: all 0.4s ease;
                    transition: all 0.4s ease;
                }





/* 
---------
---------
Homepage
---------
---------
*/


/* Homepage Hero */
    #homeHero {
        background-image:url(images/homepage/hero/spocom-homepagehero-background.jpg);
        background-attachment:fixed;
        background-repeat: repeat;
        height:600px;
        overflow:hidden;
        position:relative;
        border-bottom:5px solid #000201;
    }

        /* HILLS */
            img.hills {
                position:absolute;
                bottom:-100px;
                left:0;
                right:0;
                height:auto;
                opacity:0.8;
                width:100%;
            }


        /* CLOUD POSITIONS */
            /* Keyframes */
                @-webkit-keyframes animateCloud {
                    0% {
                        margin-left: -300px;
                    }
                    100% {
                        margin-left: 100%;
                    }
                }

                @-moz-keyframes animateCloud {
                    0% {
                        margin-left: -300px;
                    }
                    100% {
                        margin-left: 100%;
                    }
                }

                @keyframes animateCloud {
                    0% {
                        margin-left: -300px;
                    }
                    100% {
                        margin-left: 100%;
                    }
                }       



                @-webkit-keyframes animateCloudTwo {
                    0% {
                        margin-left: -600px;
                    }
                    100% {
                        margin-left: 100%;
                    }
                }

                @-moz-keyframes animateCloudTwo {
                    0% {
                        margin-left: -600px;
                    }
                    100% {
                        margin-left: 100%;
                    }
                }

                @keyframes animateCloudTwo {
                    0% {
                        margin-left: -600px;
                    }
                    100% {
                        margin-left: 100%;
                    }
                }      



                @-webkit-keyframes animateCloudThree {
                    0% {
                        margin-left: -1000px;
                    }
                    100% {
                        margin-left: 100%;
                    }
                }

                @-moz-keyframes animateCloudThree {
                    0% {
                        margin-left: -1000px;
                    }
                    100% {
                        margin-left: 100%;
                    }
                }

                @keyframes animateCloudThree {
                    0% {
                        margin-left: -1000px;
                    }
                    100% {
                        margin-left: 100%;
                    }
                }      



                @-webkit-keyframes animateCloudFour {
                    0% {
                        margin-left: -1300px;
                    }
                    100% {
                        margin-left: 100%;
                    }
                }

                @-moz-keyframes animateCloudFour {
                    0% {
                        margin-left: -1300px;
                    }
                    100% {
                        margin-left: 100%;
                    }
                }

                @keyframes animateCloudFour {
                    0% {
                        margin-left: -1300px;
                    }
                    100% {
                        margin-left: 100%;
                    }
                }      



                @-webkit-keyframes animateCloudFive {
                    0% {
                        margin-left: -1700px;
                    }
                    100% {
                        margin-left: 100%;
                    }
                }

                @-moz-keyframes animateCloudFive {
                    0% {
                        margin-left: -1700px;
                    }
                    100% {
                        margin-left: 100%;
                    }
                }

                @keyframes animateCloudFive {
                    0% {
                        margin-left: -1700px;
                    }
                    100% {
                        margin-left: 100%;
                    }
                }


                @-webkit-keyframes animateCloudSix {
                    0% {
                        margin-left: -2100px;
                    }
                    100% {
                        margin-left: 100%;
                    }
                }

                @-moz-keyframes animateCloudSix {
                    0% {
                        margin-left: -2100px;
                    }
                    100% {
                        margin-left: 100%;
                    }
                }

                @keyframes animateCloudSix {
                    0% {
                        margin-left: -2100px;
                    }
                    100% {
                        margin-left: 100%;
                    }
                }       



                @-webkit-keyframes animateCloudSeven {
                    0% {
                        margin-left: -2600px;
                    }
                    100% {
                        margin-left: 100%;
                    }
                }

                @-moz-keyframes animateCloudSeven {
                    0% {
                        margin-left: -2600px;
                    }
                    100% {
                        margin-left: 100%;
                    }
                }

                @keyframes animateCloudSeven {
                    0% {
                        margin-left: -2600px;
                    }
                    100% {
                        margin-left: 100%;
                    }
                }      



                @-webkit-keyframes animateCloudEight {
                    0% {
                        margin-left: -3100px;
                    }
                    100% {
                        margin-left: 100%;
                    }
                }

                @-moz-keyframes animateCloudEight {
                    0% {
                        margin-left: -3100px;
                    }
                    100% {
                        margin-left: 100%;
                    }
                }

                @keyframes animateCloudEight {
                    0% {
                        margin-left: -3100px;
                    }
                    100% {
                        margin-left: 100%;
                    }
                }      



                @-webkit-keyframes animateCloudNine {
                    0% {
                        margin-left: -3500px;
                    }
                    100% {
                        margin-left: 100%;
                    }
                }

                @-moz-keyframes animateCloudNine {
                    0% {
                        margin-left: -3500px;
                    }
                    100% {
                        margin-left: 100%;
                    }
                }

                @keyframes animateCloudNine {
                    0% {
                        margin-left: -3500px;
                    }
                    100% {
                        margin-left: 100%;
                    }
                }      



                @-webkit-keyframes animateCloudTen {
                    0% {
                        margin-left: -4100px;
                    }
                    100% {
                        margin-left: 100%;
                    }
                }

                @-moz-keyframes animateCloudTen {
                    0% {
                        margin-left: -4100px;
                    }
                    100% {
                        margin-left: 100%;
                    }
                }

                @keyframes animateCloudTen {
                    0% {
                        margin-left: -4100px;
                    }
                    100% {
                        margin-left: 100%;
                    }
                }


            /* Animation */
                .cloudOne, .cloudTwo, .cloudThree, .cloudFour, .cloudFive, .cloudSix, .cloudSeven, .cloudEight, .cloudNine, .cloudTen {
                    opacity: 0.6;
                }

                    .cloudOne {
                        -webkit-animation: animateCloud 30s linear infinite;
                        -moz-animation: animateCloud 30s linear infinite;
                        animation: animateCloud 30s linear infinite;

                        -webkit-transform: scale(0.65);
                        -moz-transform: scale(0.65);
                        transform: scale(0.65);
                        position:absolute;
                        top:200px;
                    }

                    .cloudTwo {
                        -webkit-animation: animateCloudTwo 39s linear infinite;
                        -moz-animation: animateCloudTwo 39s linear infinite;
                        animation: animateCloudTwo 39s linear infinite;

                        -webkit-transform: scale(0.3);
                        -moz-transform: scale(0.3);
                        transform: scale(0.3);
                        position:absolute;
                        top:299px;
                    }

                    .cloudThree {
                        -webkit-animation: animateCloudThree 45s linear infinite;
                        -moz-animation: animateCloudThree 45s linear infinite;
                        animation: animateCloudThree 40s linear infinite;

                        -webkit-transform: scale(0.5);
                        -moz-transform: scale(0.5);
                        transform: scale(0.5);
                        position:absolute;
                        top:50px;
                    }

                    .cloudFour {
                        -webkit-animation: animateCloudFour 48s linear infinite;
                        -moz-animation: animateCloudFour 48s linear infinite;
                        animation: animateCloudFour 48s linear infinite;

                        -webkit-transform: scale(0.4);
                        -moz-transform: scale(0.4);
                        transform: scale(0.4);
                        position:absolute;
                        top:80px;
                    }

                    .cloudFive {
                        -webkit-animation: animateCloudFive 50s linear infinite;
                        -moz-animation: animateCloudFive 50s linear infinite;
                        animation: animateCloudFive 50s linear infinite;

                        -webkit-transform: scale(0.35);
                        -moz-transform: scale(0.35);
                        transform: scale(0.35);
                        position:absolute;
                        top:240px;
                    }

                    .cloudSix {
                        -webkit-animation: animateCloudSix 54s linear infinite;
                        -moz-animation: animateCloudSix 54s linear infinite;
                        animation: animateCloudSix 54s linear infinite;

                        -webkit-transform: scale(0.45);
                        -moz-transform: scale(0.45);
                        transform: scale(0.45);
                        position:absolute;
                        top:140px;
                    }

                    .cloudSeven {
                        -webkit-animation: animateCloudSeven 56s linear infinite;
                        -moz-animation: animateCloudSeven 56s linear infinite;
                        animation: animateCloudSeven 56s linear infinite;

                        -webkit-transform: scale(0.3);
                        -moz-transform: scale(0.3);
                        transform: scale(0.3);
                        position:absolute;
                        top:30px;
                    }

                    .cloudEight {
                        -webkit-animation: animateCloudEight 59s linear infinite;
                        -moz-animation: animateCloudEight 59s linear infinite;
                        animation: animateCloudEight 59s linear infinite;

                        -webkit-transform: scale(0.5);
                        -moz-transform: scale(0.5);
                        transform: scale(0.5);
                        position:absolute;
                        top:115px;
                    }

                    .cloudNine {
                        -webkit-animation: animateCloudNine 62s linear infinite;
                        -moz-animation: animateCloudNine 62s linear infinite;
                        animation: animateCloudNine 62s linear infinite;

                        -webkit-transform: scale(0.4);
                        -moz-transform: scale(0.4);
                        transform: scale(0.4);
                        position:absolute;
                        top:320px;
                    }

                    .cloudTen {
                        -webkit-animation: animateCloudTen 64s linear infinite;
                        -moz-animation: animateCloudTen 64s linear infinite;
                        animation: animateCloudTen 64s linear infinite;

                        -webkit-transform: scale(0.55);
                        -moz-transform: scale(0.55);
                        transform: scale(0.55);
                        position:absolute;
                        top:170px;
                    }


            /* Clouds */
                .cloud {
                    background: #EAEAEA;
                    background: -moz-linear-gradient(top,  #EAEAEA 5%, #f1f1f1 100%);
                    background: -webkit-gradient(linear, left top, left bottom, color-stop(5%,#EAEAEA), color-stop(100%,#f1f1f1));
                    background: -webkit-linear-gradient(top,  #EAEAEA 5%,#f1f1f1 100%);
                    background: -o-linear-gradient(top,  #EAEAEA 5%,#f1f1f1 100%);
                    background: -ms-linear-gradient(top,  #EAEAEA 5%,#f1f1f1 100%);
                    background: linear-gradient(top,  #EAEAEA 5%,#f1f1f1 100%);
                    filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#EAEAEA', endColorstr='#f1f1f1',GradientType=0 );

                    -webkit-border-radius: 100px;
                    -moz-border-radius: 100px;
                    border-radius: 100px;

                    -webkit-box-shadow: 0 8px 5px rgba(0, 0, 0, 0.1);
                    -moz-box-shadow: 0 8px 5px rgba(0, 0, 0, 0.1);
                    box-shadow: 0 8px 5px rgba(0, 0, 0, 0.1);

                    height: 120px;
                    position: relative;
                    width: 350px;
                }

                .cloud:after, .cloud:before {
                    background: #EAEAEA;
                    content: '';
                    position: absolute;
                    z-indeX: -1;
                }

                .cloud:after {
                    -webkit-border-radius: 100px;
                    -moz-border-radius: 100px;
                    border-radius: 100px;

                    height: 100px;
                    left: 50px;
                    top: -50px;
                    width: 100px;
                }

                .cloud:before {
                    -webkit-border-radius: 200px;
                    -moz-border-radius: 200px;
                    border-radius: 200px;

                    width: 180px;
                    height: 180px;
                    right: 50px;
                    top: -90px;
                }


            /* Flowers */
                .flowers {
                    height:100%;
                    width:100%;
                    display:relative;
                    overflow:hidden;
                }

                    .flowerOne {
                        height:160px;
                        position:absolute;
                        bottom:0;
                        right:650px;
                    }

                    .flowerTwo {
                        height:180px;
                        position:absolute;
                        bottom:0;
                        right:600px;
                    }

                    .flowerThree {
                        height:230px;
                        position:absolute;
                        bottom:0;
                        right:525px;
                    }

                    .flowerFour {
                        height:350px;
                        position:absolute;
                        bottom:0;
                        right:375px;
                    }

                    .flowerFive {
                        height:240px;
                        position:absolute;
                        bottom:0;
                        right:290px;
                    }

                    .flowerSix {
                        height:150px;
                        position:absolute;
                        bottom:0;
                        right:210px;
                    }

                    .flowerSeven {
                        height:190px;
                        position:absolute;
                        bottom:0;
                        right:100px;
                    }

                    .flowerEight {
                        height:229px;
                        position:absolute;
                        bottom:0;
                        right:50px;
                    }

                    /* Swaying Motion */
                        .swayMotion {
                            animation: sway 7800ms infinite;
                            transform-origin: 50% 100% 0;
                        }

                        @keyframes sway {
                            0%, 100%{ transform: rotate(-3deg);}
                            50%{ transform: rotate(4deg); }
                        }


                        .swayMotionTwo {
                            animation: swayTwo 5750ms infinite;
                            transform-origin: 50% 100% 0;
                        }

                        @keyframes swayTwo {
                            0%, 100%{ transform: rotate(-4deg);}
                            50%{ transform: rotate(5deg); }
                        }


                        .swayMotionThree {
                            animation: swayThree 6500ms infinite;
                            transform-origin: 50% 100% 0;
                        }

                        @keyframes swayThree {
                            0%, 100%{ transform: rotate(-4deg);}
                            50%{ transform: rotate(6deg); }
                        }

    /* HERO CAPTION */
        #heroCaption {
            width: 60%;
            color: #000201;
            display: block;
            float: none;
            top: 100px;
            position: absolute;
            padding:1em 4em;
        }

            #heroCaption h1 {
                font-size:7em; 
                margin-bottom:0;
                text-align:left;
            }

            #heroCaption h2 {
                font-size:3em;
                padding-right:1em;
                font-weight:700;
            }

            .heroButtons {
                padding-top:1em;
                display:flex;
                flex-direction:row;
                justify-content: space-between;
                width:70%;
            }

                .heroButtons a.button {
                    margin:1em 0;
                    padding:10px;
                    font-size:24px;
                    font-weight:600;
                    font-family: 'Roboto', sans-serif;
                }





/* Homepage 'What I Do' Bar */
    #homeServices {
        display:flex;
        flex-direction:row;
        justify-content: space-between;
        text-align:center;
        color:#000201;
        margin-top:3.5em;
    }

        .homeService {
            width:30%;
            position:relative;
            padding-bottom:50px;
        }

            .homeService .fas { 
                background: #5d5d5d;
                color: #262626;
                width: 100px;
                height: 100px;
                border-radius: 50%;
                text-align:center;
                line-height:100px;
                transition: all .3s ease;
                margin-bottom:1em;
            }

                .homeService:hover .fas {
                    transition: all .3s ease;
                    box-shadow: 5px 5px 5px #000;
                    transform: translateY(-5px);
                }

                .homeService:hover .fas.first {
                    background:#55acee;
                    color:#EAEAEA;
                }

                .homeService:hover .fas.second {
                    background:#3b5998;
                    color:#EAEAEA;
                }

                .homeService:hover .fas.third {
                    background:#0083be;
                    color:#EAEAEA;
                }

                .homeService h2 {
                    font-size:32px;
                    font-weight:800;
                }





/* Case Study Slider - Homepage */
    #homeCaseStudies {
        height:auto;
        display:block;
        color:#fbfcfd;
        font-family: 'Roboto', sans-serif;
        font-weight:100;
        padding:3em 0;
    }

            #homeCaseStudies h1 {
                color:#000201;
            }


            .caseStudyLoop {
                display:grid;
                grid-template-columns:repeat(3, 1fr);
                grid-gap:3em;
                margin-bottom:5em;
            }

    .caseStudyLoop article {
        background:#fcfafa;
        border-radius:5px;
        box-shadow:0 0 5px #000201;
        height:250px;
        padding:0;
        position:relative;
        overflow:hidden;
        border:20px solid #fcfafa;
        -webkit-transition:all .25s ease;  
        -moz-transition:all .25s ease;  
        -o-transition:all .25s ease;  
        transition:all .25s ease;
    }

        .caseStudyLoop article:hover {
            box-shadow:0 0 15px #000201;
            -webkit-transition:all .25s ease;  
            -moz-transition:all .25s ease;  
            -o-transition:all .25s ease;  
            transition:all .25s ease;
        }

            .caseStudyLoop article:hover img.texture {
                opacity:0;
                -webkit-transition:all .25s ease;  
                -moz-transition:all .25s ease;  
                -o-transition:all .25s ease;  
                transition:all .25s ease;
            }

            .caseStudyLoop article:hover .caseStudyCaption {
                background-color:rgba(0,2,1,.6);
                -webkit-transition:all .25s ease;  
                -moz-transition:all .25s ease;  
                -o-transition:all .25s ease;  
                transition:all .25s ease;
            }

            .caseStudyLoop article:hover a.button {
                background:#000201;
                color:#eaeaea;
            }

    .homeCaseStudiesImage {
        position:absolute;
        top:0;
        bottom:0;
        left:0;
        right:0;
    }

        .homeCaseStudiesImage img.background {
            object-fit:cover;
            height:400px;
            object-position: center;
        }

        .homeCaseStudiesImage img.texture {
            opacity:.5;
            width:100%;
            height:100%;
            position:absolute;
            top:0;
            bottom:0;
            left:0;
            right:0;
            max-width:none;
            -webkit-transition:all .25s ease;  
            -moz-transition:all .25s ease;  
            -o-transition:all .25s ease;  
            transition:all .25s ease;
        }

    .caseStudyCaption {
        position:absolute;
        top:0;
        bottom:0;
        left:0;
        right:0;
        padding:2em 1em 0;
        background-color:rgba(0,2,1,.8);
        -webkit-transition:all .25s ease;  
        -moz-transition:all .25s ease;  
        -o-transition:all .25s ease;  
        transition:all .25s ease;
    }

        .caseStudyCaption a.button {
            font-weight:800;
            font-size:21px;
        }

        .caseStudyCaption h3 {
            font-family: 'Roboto', sans-serif;
            color:#EAEAEA;
            font-weight:700;
            font-size:24px;
            line-height:28px;
            text-align:center;
        }

            .caseStudyCaption h3, .caseStudyCaption h5 {
                text-shadow:2px 2px 1px #000000;
            }

        .caseStudyCaption h5 span {
            font-weight:500;
            color:#fcfafa;
        }



/* 
---------
---------
SIDE PAGES GENERAL RULES
---------
---------
*/
.sidePage {
    position:relative;
}

.pageTitle {
    margin:2em auto 2em;
}

    .pageTitle.compact {
        margin:.5em auto 2em;
        padding:.5em 0 .2em;
        border-top:2px solid #000201;
        border-bottom:2px solid #000201;
    }

    .pageTitle h1 {
        font-weight:800;
        margin-bottom:0;
    }

        .pageTitle h1 span.thin {
            font-weight:100;
        }

    .pageTitle h2 {
        text-align:center;
        margin:1em auto 0;
        font-size:32px;
        line-height:36px;
    }

    .pageTitle h3 {
        font-size:100px;
        line-height:70px;
        text-align:center;
        font-size:40px;
        margin-bottom:0;
        font-family: 'Roboto', sans-serif;
    }

    .pageShowcase {
        display:block;
        overflow:hidden;
        background-image:url(images/goldpaperbg.jpg);
        background-repeat:repeat;
        background-attachment:fixed;
        padding:1em 0;
        border-top:3px solid #000201;
        border-bottom:3px solid #000201;
        margin:50px auto 0;
    }

        .showcaseCaption {
            display:block;
        }

            .showcaseTitle {
                grid-column:1/2;
            }

            .showcaseCaption h1 {
                color:#000201;
                text-shadow:-1px -1px 0 #000;
                margin-bottom:0;
                text-align:left;
            }

            .showcaseCaption h1.full {
                grid-column:1/3;
            }

    .jumpLinks {
        grid-column:2/3;
    }

        .jumpLinks ul {
            display:flex;
            flex-direction:row;
            flex-wrap:nowrap;
            justify-content: space-around;
            list-style-type:none;
            align-items:center;
            height:100%;
            margin:0;
        }

            .jumpLinks ul li a {
                background-color:rgba(234,234,234,0.4);
                border:2px solid #000201;
                border-radius:5px;
                padding:.5em;
                display:block;
                margin:0 auto;
                text-align:center;
                color:#000201;
                font-weight:500;
                text-transform:lowercase;
                font-size:18px;
                -webkit-transition:all .25s ease;  
                -moz-transition:all .25s ease;  
                -o-transition:all .25s ease;  
                transition:all .25s ease;
            }

                .jumpLinks ul li:hover a {
                    background-color:rgba(0,2,1,0.8);
                    color:#EAEAEA;
                    -webkit-transition:all .25s ease;  
                    -moz-transition:all .25s ease;  
                    -o-transition:all .25s ease;  
                    transition:all .25s ease;
                }

            .jumpLinks li h1 {
                font-size:28px;
                text-shadow:none;
                font-weight:900;
            }

.pageIntro {
    padding-bottom:2em;
    margin:0 auto;
    display:block;
    width:60%;
}

    .pageIntro p {
        color:#000201;
        grid-column:1/3;
        text-align:center;
        margin-top:.5em;
        font-size:21px;
        line-height:28px;
    }







/* 
---------
---------
BLOG LISTINGS & POSTS
---------
---------
*/

/* Blog Post Listings - General */
    article.homePosts:hover img, article.homeFeatured:hover img {
        opacity: 1;
        -webkit-filter: grayscale(0%);
        filter: grayscale(0%);
        -webkit-transition:all .25s ease;  
        -moz-transition:all .25s ease;  
        -o-transition:all .25s ease;  
        transition:all .25s ease;
    }

    .excerpt p {
        font-family: 'Roboto', sans-serif;
        color:#0D1A30;
        font-size:.95em;
        line-height:1.3em;
    }

        .excerpt a span {
            display:inline-block;
            margin-left:.25em;
            color:#BC8851;
            font-weight:800;
        }

        .excerpt.featured p {
            font-size:1.35em;
            line-height:1.25em;
            margin-top:.5em;
        }

        .excerpt.featured span {
            display:none;
        }



/* Blog Posts - Homepage */
    #homePosts {
        padding:2em 4em 200px;
        background-image:url(images/homepage/hero/spocom-homepagehero-background.jpg);
        background-attachment: fixed;
        border-top:5px solid #000201;
        position:relative;
    }

    #homeLoop {
        display:flex;
        flex-direction:row;
        flex-wrap:nowrap;
        justify-content: space-between;
        margin-bottom:100px;
    }

        #homeLoop h2 a, #homeLoop h3 a, #homeLoop h2 a:hover, #homeLoop h3 a:hover {
            line-height:1em;
            color:#000201;
        }

        #homeLoop h2 {
            margin:.3em auto 0;
            font-size:48px;
            font-family: 'Roboto', sans-serif;
        }

        #homeLoop br {
            display:none;
        }

        #homeLoop h3 {
            margin:0 auto .3em;
            font-size:1.65em;
            line-height:1em;
            display:block;
        }

        #homeLoop article {
            padding:1em 1em 1em 0;
            overflow:hidden;
            margin:auto;
        }

            #homeLoopRight article {
                padding:1em 0 1em 1em;
            }

        #homeFeaturedPost {
            overflow:hidden;
            padding:0 0 5em 0;
            position:relative;
            flex:0 0 50%;
        }

            #homeFeaturedPost a.button {
                position:absolute;
                bottom:0;
                right:15px;
                border:2px solid #000201;
                font-weight:800;
                font-size:21px;
            }

            #featuredText {
                overflow:hidden;
                display:block;
            }

            .postFigure {
                position: relative;
                overflow: hidden;
            }

                .postFigure img {
                    vertical-align: top;
                    object-fit:cover;
                    width:100%;
                    height:300px;
                    backface-visibility: hidden;
                    -webkit-filter: grayscale(100%);
                    filter: grayscale(100%);
                    opacity: 0.75;
                    -webkit-transition:all .25s ease;  
                    -moz-transition:all .25s ease;  
                    -o-transition:all .25s ease;  
                    transition:all .25s ease;
                }

                    .homeFeatured .postFigure img {
                        height:400px;
                    }

                .postFigure figcaption {
                    z-index: 1;
                    align-items: center;
                    position: absolute;
                    width: 13%;
                    top:0;
                    left:0;
                    display: flex;
                    flex-direction: column;
                    justify-content: center;
                    background-color: rgba(252, 247, 255, 0.85);
                    padding: 7px;
                }

                    .postFigure.smallPost figcaption {
                        width:25%;
                    }

                    .postFigure figcaption span.month, .postFigure figcaption span.year {
                        font-size:1em;
                        line-height:1em;
                        color:#16171A;
                        font-family: 'Cormorant Garamond', serif;
                        text-transform:uppercase;
                    }

                        .postFigure.smallPost figcaption span.month, .postFigure.smallPost figcaption span.year {
                            font-size:.75em;
                        }

                    .postFigure figcaption span.day {
                        font-size: 50px;
                        line-height: 50px;
                        color:#46701D;
                        font-family: 'Roboto', sans-serif;
                        margin-bottom:0;
                    }

                        .postFigure.smallPost figcaption 

        #homeLoopRight {
            overflow:hidden;
        }

            #homeSmallPosts {
                display:flex;
                flex-direction:column;
                justify-content:space-between;
                height:100%;
            }

                #homeSmallPosts article {
                    grid-template-columns: 35% 65%;
                    grid-template-areas: "left right";
                    display:grid;
                    margin:auto;
                    flex:1;
                    position:relative;
                    padding-bottom:50px;
                }

                    .loopImage {
                        grid-area:left; 
                        margin:0;
                        padding:0;
                        height:100%;
                        width:100%;
                    }

                        .loopImage figure {
                            height:200px;
                        }

                        .loopImage img {
                            object-fit:cover;
                            display:block;
                            height:200px;
                        }

                    .loopText {
                        grid-area:right;
                        margin:0;
                        padding:0 .5em;
                    }

                    #homeSmallPosts .excerpt {
                        font-size:13px;
                        line-height:18px;
                    }

                    #homeSmallPosts article a.button {
                        position:absolute;
                        bottom:0;
                        right:15px;
                        font-size:18px;
                        padding:.4em .75em;
                        border:1px solid #000201;
                        font-weight:800;
                        width:20%;
                    }







/* Blog Posts - Blog Main Page */
/* Blog Page Subtitle & Blog Search Form */
#blogHead {
    margin:2em auto;
    display:block;
}

    

        .titleArea span {
            font-size:80%;
            display:inline-block;
            margin-left:.5em;
        }

.blogSearch {
    grid-column:2;
}

    .blogSearch form {
        float:right;
    }

        .blogSearch .search-field {
            font-size:.9em;
            padding:.15em;
            background-color:#f5f4ff;
            border-radius:5px;
            margin-right:.25em;
            -webkit-transition: all 0.4s ease;
            -moz-transition: all 0.4s ease;
            -o-transition: all 0.4s ease;
            transition: all 0.4s ease;
            width:150px;
            font-family: 'Cormorant Garamond', serif;
        }

            .blogSearch .search-field:focus {
                width:250px;
                -webkit-transition: all 0.4s ease;
                -moz-transition: all 0.4s ease;
                -o-transition: all 0.4s ease;
                transition: all 0.4s ease;
            }

        .blogSearch .search-form .search-submit {
            background-color:inherit;
            border:none;
            color:#000201;
            font-size:1.2em;
            padding-right:0;
        }



/* Blog Posts Loop */
#blogLoop {
    margin:0 auto;
    display:block;
    display:grid;
    grid-template-columns:repeat(3, 1fr);
    grid-gap:5em;
}

    #blogLoop article {
        background:#fcfafa;
        box-shadow:0 0 5px #000201;
        -webkit-transition: all 0.4s ease;
        -moz-transition: all 0.4s ease;
        -o-transition: all 0.4s ease;
        transition: all 0.4s ease;
        position:relative;
        padding-bottom:100px;
    }

        #blogLoop article:hover {
            -webkit-transition: all 0.4s ease;
            -moz-transition: all 0.4s ease;
            -o-transition: all 0.4s ease;
            transition: all 0.4s ease;
            box-shadow:0 0 15px #000201;
        }

        #blogLoop article a.button {
            position:absolute;
            width:50%;
            padding:5px 10px;
            left:0;
            right:0;
            bottom:25px;
        }

            #blogLoop article:hover a.button {
                background:#000201;
                color:#eeeeee;
            }

        #postMeta {
            font-size:15px;
            font-weight:800;
            margin-top:3px;
            text-align:center;
            padding:5px 0;
            background:#000201;
            color:#eeeeee;
            position:absolute;
            bottom:0;
            left:0;
            right:0;
            font-family: 'Roboto', sans-serif;
        }

            #postMeta span {
                font-weight:400;
            }

.entryImage {
    overflow:hidden;
    display:block;
    height:225px;
    position:relative;
}

    .entryImage img {
        object-fit:cover;
        object-position:center;
        min-height:250px;
    }

.entryText {
    padding:1em;
}

    .entryText ul {
        list-style-type: none;
        display:flex;
        flex-direction:row;
        justify-content: flex-start;
        margin-bottom:1em;
        margin-left:0;
        flex-wrap:wrap;   
    }

        .entryText ul li {
            border:1px solid #000201;
            border-radius:5px;
            padding:5px 10px;
            margin-bottom:3px;
            margin-right:10px;
            font-size:13px;
            line-height:13px;
        }

            .entryText ul li a {
                color:#000201;
                font-family: 'Roboto', sans-serif;
            }

    .entryText h2 {
        font-family: 'Roboto', sans-serif;
        font-size:24px;
        line-height:26px;
        margin-bottom:5px;
        font-weight:800;
    }

    .entryText p {
        font-size:14px;
        line-height:24px;
        font-weight:500;
    }

    





/* Blog Posts Pagination */
.pagination {
    font-size:1.25em;
    line-height:1em;
    display:flex;
    flex-direction:row;
    justify-content: center;
    margin:1em auto;
}

    .pagination span, .pagination a {
        border:1px solid #000201;
        padding:5px;
        border-radius:5px;
        margin:1em;
        text-align:center;
        background-image:url(images/homepage/hero/spocom-homepagehero-background.jpg);
        background-attachment:fixed;
        background-repeat: repeat;
    }

    .pagination span:first-child {
        display:block;
        border:none;
        background:transparent;
        font-family: 'Cormorant Garamond', serif;
    }





/* Blog Posts - Individual */
    .blogTitle {
        text-align:center;
        padding:1em 0;
    }

        .blogTitle h1 {
            font-size:6em;
            font-weight:700;
            line-height:1em;
            display:block;
            padding:0 1em;
        }

        .blogTitle p {
            color:#000201;
            margin-bottom:10px;
        }

            .blogTitle p span {
                color:#f05d23;
                font-size:1em;
                font-weight:900;
            }

        

            .blogCategories ul {
                display:flex;
                flex-direction:row;
                justify-content: center;
                list-style-type:none;
                text-align:center;
                margin:0;
            }

                .blogCategories ul li {
                    margin:0 1em;
                }

            .blogCategories a {
                font-style:italic;
                color:#2b490b;
                font-size:21px;
            }

                .blogCategories a:hover {
                    color:#8E6940;
                }

.titleDiv {
    padding:3em 0 5em;
    margin:.5em auto 1em;
    border-top:3px solid #000201;
    border-bottom:3px solid #000201;
    position:relative;
    min-height:250px;
}

.titleDiv h1 {
    color:#EAEAEA;
    text-shadow:2px 2px 0 #000;
    font-weight:700;
    font-size:64px;
    line-height:72px;
    padding:0 2em;
    font-family: 'Roboto', sans-serif;
}

    .titleDiv.noShowcase h1 {
        padding:0;
        margin-top:0;
    }

    .titleDiv h1 span {
        font-weight:300;
    }

    .postIntro {
        font-size:28px;
        font-weight:700;
        color:#EAEAEA;
        display:block;
        width:75%;
        margin:10px auto 0;
        font-family: 'Cormorant Garamond', serif;
    }

        .titleDiv.noShowcase .postIntro {
            color:#E5BE82;
        }

    .blogShowcase {
        display:block;
        overflow:hidden;
        position:absolute;
        top:0;
        left:0;
        right:0;
        bottom:0;
        z-index:-10;
        background:#000201;
    }

        .blogShowcase img {
            object-fit:cover;
            object-position:bottom;
            min-width:100%;
            height:800px;
            opacity:.25;
        }

.introBottom {
    margin-top:100px;
}

.introBottom p, .introBottom .ssbp-wrap {
        color:#eeeeee;
    }






    

            .blogFeaturedImage {
                display:block;
                float:none;
                clear:both;
                width:60%;
                margin:0 auto 1em;
                overflow:hidden;
            }

                .blogFeaturedImage img {
                    height:auto;
                    border-radius:5px;
                }

    .blogText li {
        margin-bottom:20px;
        font-size:24px;
        line-height:36px;
        font-family: 'Merriweather', serif;
    }

.blogtext ul li li {
    font-size:.9rem;
    margin-bottom:10px;
}

.blogText ol li {
    margin-bottom:75px;
}

.blogText ul li ul, .blogText ul li ul li ul, .blogText ul li ul li, .blogText ul li ul li ul li, .blogText ol li ul, .blogText ol li ul li ul, .blogText ol li ul li, .blogText ol li ul li ul li {
    margin-bottom:10px;
    font-weight:500;
}


.wp-caption {
    background:#eeeeee;
    padding:5px;
    width:100%!important;
}

p.wp-caption-text {
    font-size:16px;
    text-align:center;
    color:#162803;
    font-style:italic;
    margin-top:5px;
}

/* Hiding captions on gallery thumbnails */
.rl-gallery .rl-gallery-link .rl-gallery-caption {
    display:none!important;
}


.blogText h2 {
    margin-bottom:20px;
    margin-top:75px;
    font-weight:700;
}

    .postNavigation {
        margin:1em auto;
        border-top:.5px solid #d5d5d5;
        border-bottom:.5px solid #d5d5d5;
        padding-top:2em;
    }

    .prevNext {
        display:grid;
        grid-template-columns:50% 50%;
        font-weight:300;
    }

        .prevNext span {
            font-weight:800;
        }

        .prevButton, .nextButton {
            display:block;
            color:#152704;
            font-weight:bolder;
            text-transform:lowercase;
            font-size:18px;
            -webkit-transition:all .25s ease;  
            -moz-transition:all .25s ease;  
            -o-transition:all .25s ease;  
            transition:all .25s ease;
        }

.prevButton {
    text-align:left;
    grid-column:1;
    padding-right:1em;
}

.nextButton {
    text-align:right;
    grid-column:2;
    padding-left:1em;
}

            .prevButton:hover, .nextButton:hover {
                color:#2B490D;
                -webkit-transition:all .25s ease;  
                -moz-transition:all .25s ease;  
                -o-transition:all .25s ease;  
                transition:all .25s ease;
                cursor: pointer;
            }


    .returnButtons {
        margin:1em auto;
    }

        .returnButtons a {
            background-color:rgba(234,234,234,0.4);
            border:3px solid #000201;
            border-radius:5px;
            padding:.75em 2em;
            display:block;
            margin:1em auto;
            text-align:center;
            color:#000201;
            font-weight:bolder;
            text-transform:lowercase;
            font-size:18px;
            -webkit-transition:all .25s ease;  
            -moz-transition:all .25s ease;  
            -o-transition:all .25s ease;  
            transition:all .25s ease;
        }

            .returnButtons a:hover {
                background-color:rgba(0,2,1,0.8);
                color:#EAEAEA;
                -webkit-transition:all .25s ease;  
                -moz-transition:all .25s ease;  
                -o-transition:all .25s ease;  
                transition:all .25s ease;
            }

        .returnButtons ul {
            list-style-type:none;
            display:flex;
            flex-direction:row;
            justify-content:center;
            width:70%;
            margin:0 auto;
        }

.returnButtons ul li {
    margin:0 1em;
}

/* 
Gallery Pages
*/

.blogGallery {
    margin-top:75px;
    padding:0 50px;
}



.rl-basicgrid-gallery {
    display:flex;
    flex-direction:row;
    flex-wrap:wrap;
    justify-content: space-around;
}

.rl-gallery-item {
    width:31%!important;
    height:225px!important;
    margin-bottom:2em!important;
    -webkit-transition:all .25s ease;  
    -moz-transition:all .25s ease;  
    -o-transition:all .25s ease;  
    transition:all .25s ease;
}

.rl-gallery-item:hover {
    transform: scale(1.1);
    -webkit-transition:all .25s ease;  
    -moz-transition:all .25s ease;  
    -o-transition:all .25s ease;  
    transition:all .25s ease;
}

.rl-gallery-item img {
    object-fit: cover;
    object-position: top center;
    min-height:250px;
    min-width:100%;
}





/* 
---------
---------
FOOTER 
---------
---------
*/
footer {
    background-color:#000201;
    padding:2em;
    text-align:center;
    color:#EAEAEA;
    position:relative;
}

    footer img {
        height:50px;
        width:auto;
        display:block;
        margin:.5em auto;
    }

    #footerMenu ul {
        display:flex;
        flex-direction:row;
        flex-wrap:wrap;
        justify-content: space-around;
        list-style-type: none;
        margin:1em auto 3em;
        width:50%;
    }

        #footerMenu ul li {
            font-size:1.3em;
            font-family: 'Cormorant Garamond', serif;
        }

    footer a {
        color:#E9F7DC;
        font-weight:700;
    }

        footer a:hover {
            color:#F9ECDC;
        }


    footer p {
        color:#EAEAEA;
        font-size:1.2em;
        line-height:1.2em;
        text-align:center;
    }

        footer p.finePrint {
            font-size:.8em;
            color:#EFEDEA;
            display:block;
            width:70%;
            margin:.2em auto;
        }

    footer .menu-primary-menu-container {
        width:auto;
    }







/* 
---------
---------
RESUME PAGE 
---------
---------
*/
.resumeBody {
    display:flex;
    flex-direction:row;
    flex-wrap: nowrap;
}

.resumeBody h2.topPad{
    margin-top:3em;
}

.sideBox {
    width:25%;
    margin-right:1%;
    padding:0;
    overflow:hidden;
}

    .resumePhoto {
        margin-bottom:-5px;
    }


        .resumePhoto img {
            width:100%;
            height:auto;
        }

    .sideBox h1 {
        font-size:48px;
        line-height:35px;
        font-weight:800;
        color:#eaeaea;
        background-color:#000201;
        text-align:left;
        text-transform:uppercase;
        font-family: 'Roboto', sans-serif;
        font-weight:800;
        padding-top:1px;
    }

        .sideBox h1 span.one {
            font-weight:300;
            display:block;
            text-align:center;
        }

        .sideBox h1 span.two {
            font-weight:500;
            display:block;
            text-align:right;
        }

    .sideDetails {
        padding:1em;
        margin-top:0;
        background-color:rgba(251,251,251,0.7);
        border-radius:5px;
    }

        .sideDetails ul {
            margin-left:25px;
            margin-bottom:25px;
        }

            .sideDetails ul li {
                font-size:16px;
                margin:10px auto;
            }

        .sideDetails h2 {
            font-size:28px;
            padding-top:0;
            font-weight:800;
            text-transform:lowercase;
        }

            .sideDetails h2 span {
                display:block;
                clear:both;
                color:#8E6940;
                font-weight:500;
            }

            .sideDetails h2:not(:first-child) {
                margin-top:1em;
            }

.mainBox {
    width:75%;
    margin-left:25px;
    padding:10px;
}

    .mainBox h2 {
        font-size:2.6em;
        font-weight:700;
    }

    .mainBox h3 {
        font-size:28px;
        font-weight:600;
        display:inline-block;
        clear:right;
        padding-right:10px;
        margin-bottom:5px;
        width:93%;
    }

        .mainBox h3.fisher {
            width:91%;
        }

        .mainBox h3 span {
            text-align:right;
            float:right;
            font-size:21px;
            font-weight:800;
            color:#2b490b;
        }

    .mainBox h4 {
        font-size:18px;
        font-weight:300;
        margin-left:44px;
        line-height:12px;
        margin-bottom:40px;
    }

        .mainBox h4 span {
            color:#8E6940;
            font-weight:900;
        }

    .mainBox ul {
        margin:1em 0 1em 2em;
    }

        .mainBox li {
            margin-bottom:1em;
            font-size:18px;
            line-height:28px;
        }

            .job {
                padding:0;
                overflow:hidden;
                margin:1em auto 3em;
            }

ul.specialties, ul.certifications {
    display:flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
    list-style-type:none;
    margin:1em 0 0;
}

ul.specialties li, ul.certifications li {
    flex:0 0 26%;
    text-align:center;
    align-content: center;
    margin:0 auto 2em;
}

ul.specialties li h4 {
    font-size:21px;
    font-family: 'Cormorant Garamond', serif;
    font-weight:800;
    margin-top:5px;
}

ul.specialties li i, ul.certifications li img {
    font-size:24px;
}

.jobTitle {
    padding:0;
}

.jobTitle:not(:first-child) {
    margin-top:4em;
}

    .jobTitle img {
        display:inline-block;
        float:left;
        height:35px;
        width:auto;
        margin:0 10px 0 0;
    }

.jobTitle img.fisher {
    height:52px;
}



.jobDetails {
    border-left:1px dotted #000201;
    padding-left:2em;
    margin-top:1em;
    margin-left:1em;
    font-size:16px;
}

    .jobDetails ul {
        margin-left:0;
    }

.jobDetails ul ul {
    margin-left:2em;
}

.jobDetails ul ul li {
    font-size:16px;
}

ul.twoCol {
    display:flex;
    flex-direction: column;
    flex-wrap: wrap;
    align-items: left;
    height:250px;
}

.jobDetails ul ul.twoCol li {
    width:26%;
    margin:7px auto;
    font-size:16px;
}







/* Case Study Styling */

.blogPostMain h2 {
    font-size:48px;
    line-height:60px;
    font-family:'Roboto', sans-serif;
    font-weight:800;
    text-align:center;
    margin:0 auto 25px;
}
    .caseStudy h2 span {
        font-weight:300;
    }

.caseStudy section {
    margin-bottom:75px;
}

.caseStudy section ul {
    margin-top:10px;
}


    .caseStudy section ul.whatIDid li {
        font-size:14px;
        line-height:20px;
        font-weight:700;
        text-transform:uppercase;
        font-family:'Roboto', sans-serif;
        background:#000201;
        color:#eaeaea;
        border:1px solid #000201;
        border-radius:10px;
        padding:3px 10px;
        margin:10px;
        flex:0 0 22%;
    }

.caseBox {
    width:40%;
    background:#f5f4ff;
    border-radius:20px;
    padding:10px 2em;
    margin:40px auto 0;
    text-align:center;
}

.caseBox h4 span {
    font-weight:300;
}


.overview {
    font-size:21px;
    line-height:32px;
    font-family: 'Cormorant Garamond', serif;
    padding:1em 0 215px;
}

.overview p {
    width:70%;
    text-align:justify;
    margin:0 auto;
}

    .overview p.twoCol {
        column-count:2;
        column-gap:75px;
    }

ul.whatIDid {
    display:flex;
    justify-content: space-around;
    margin-left:0;
    list-style-type:none;
    margin-bottom:10px;
    flex-wrap:wrap;
}






.challenge {
    background: rgb(192,201,201);
    background: linear-gradient(135deg, rgba(192,201,201,1) 0%, rgba(223,230,230,1) 100%); 
    position:relative;
    overflow:visible;
    padding:2em;
    width:85%;
    margin:0 auto;
}

.dividerImage {
    position:relative;
    top:-190px;
    margin-bottom:-125px;
}

.dividerImage img {
    width:95%;
    margin:0 auto;
    box-shadow:0 0 25px #1c1c1c;
    display:block;
}

.challengeText {
    width:70%;
    margin:0 auto;
}

.pullQuote p {
    font-size:28px;
    line-height:32px;
    font-weight:100;
    font-style:italic;
    font-family: 'Roboto', sans-serif;
    text-align:center;
    width:80%;
    margin:0 auto 1em auto;
}



.process {
    width:80%;
    margin:0 auto;
    display:block;
}

.insight, .workflow {
    display:flex;
    justify-content: space-between;
}

.insight {
    margin-bottom:100px;
}

.insightText, .workflowText {
    width:85%;
}

.insightText p, .workflowText p, .workflowText ul li, .insightText ul li {
    text-align: justify;
}

.process ul li ul {margin-bottom:0;}

.insight i, .workflow i {
    font-size:100px;
    text-align:left;
    position: relative;
    top:-25px;
    
}



.results {
    display:grid;
    grid-template-columns:60% 40%;
}

.blogPostMain.caseStudy .results h2 {
    text-align:left;
    margin-top:0;
}

.resultsText {
    grid-column:1;
    padding-left:10px;
}

.results .pullQuote {
    grid-column:2;
    padding:0 0 0 25px;
    border-left:1px solid #d5d5d5;
}

.results .pullQuote p {
    text-align:right;
    width:auto;
}

.results p {
    margin:0 0 50px 0;
    width:90%;
    
}
 
.resultsImage img {
    margin:1em auto;
    display:block;
}











/* Client List Page */
.clientPage {
    overflow:hidden;
    margin:0 auto 125px;
}

.clientPage * {
    max-width:100%;
}

ul.clients {
    display: flex;
    flex-wrap: wrap;
    align-items:stretch;
    justify-content: space-between;
    list-style-type: none;
    margin: 1em 0 0;
}
 

ul.clients li {
    flex: 0 0 350px;
    text-align: center;
    margin:0;
    position:relative;
    padding-bottom:200px;
}

.clientImage {
    height:300px;
    overflow:hidden;
    padding:40px;
    position:relative;
}

ul.clients li img {
    overflow:visible;
    display:block;
    margin:0 auto 1em auto;
    object-fit: fill;
    object-position:center;
}

.clientButtons {
    position:absolute;
    left:0;
    right:0;
    bottom:0;
}









/* Post Embeds */
.postEmbed {
    display:inline;
    float:right;
    margin:1em 0 1em 1em;
    width:30%;
}






/* About Page */


    span.gradient {
        font-size:85px;
        text-align:center;
        font-weight:800;
        letter-spacing: 2px;
        color: #f35626;
        background-image: -webkit-linear-gradient(90deg, rgba(43,73,11,1) 0%, rgba(22,40,3,1) 100%);
        -webkit-background-clip: text;
        -webkit-text-fill-color: transparent;
        -webkit-animation: hue 10s infinite linear;
        font-family: 'Cormorant Garamond', serif;
    }

        span.gradient.small {
            font-size:32px;
            margin-bottom:50px;
            display:block;
        }

@-webkit-keyframes hue {
  from {
    -webkit-filter: hue-rotate(0deg);
  }
  to {
    -webkit-filter: hue-rotate(-360deg);
  }
}


/* Circled Number Lists */
.digitalUmbrella {
    position:relative;
    padding:25px;
    border:5px solid #000201;
    margin-bottom:50px;
    background-image:url(images/homepage/hero/spocom-homepagehero-background.jpg);
    background-attachment:fixed;
    background-repeat: repeat;
    overflow:hidden;
    border-radius:10px;
}

.digitalUmbrella p {
    font-size:14px;
    line-height:24px;
    text-align:center;
    display:block;
    width:75%;
    margin:1em auto 0 auto;
}

.digitalUmbrella h4 {
    text-align:center;
    text-transform:uppercase;
    font-weight:300;
    font-size:32px;
    letter-spacing:2px;
    border-bottom:2px solid #000201;
}

    .digitalUmbrella ul {
        display: flex;
        justify-content: space-between;
        list-style-type:none;
        margin:0 auto 1em;
    }

        .digitalUmbrella ul li { 
            padding:0;
            font-size:14px;
            line-height:21px;
            font-family: 'Roboto', sans-serif;
            flex:0 0 17%;
        }

.digitalUmbrella ul li h3 {
    font-size:16px;
    font-weight:800;
    line-height:18px;
    text-transform:uppercase;
    font-family: 'Roboto', sans-serif;
    display:block;
    margin-top:25px;
}

.digitalUmbrella ul li p {
    font-size:14px;
    line-height:21px;
    font-family: 'Roboto', sans-serif;
    text-align:center;
    margin-bottom:0;
}

.digitalUmbrella ul li ul {
    display:flex;
    flex-direction:column;
    margin:0;
    list-style-type: disc;
}

.digitalUmbrella ul li ul li {
    padding:0;
    margin-left:15px;
}

.animate-opacity {
    opacity: 0;
    -webkit-transition: opacity .5s ease-in-out;
    transition: opacity 1s ease-in-out;
}

    .animate-opacity:nth-child(2) {
        transition-delay: 500ms;
    }

    .animate-opacity:nth-child(3) {
        transition-delay: 1000ms;
    }

    .animate-opacity:nth-child(4) {
        transition-delay: 1500ms;
    }

    .animate-opacity:nth-child(5) {
        transition-delay: 2000ms;
    }

    .animate-opacity.visible {
        opacity: 1;
    }

.numCircle {
    text-align: center;
    text-transform: uppercase;
    text-decoration: none;
    font-size: 56px;
    font-weight: 100;
    font-family: 'Roboto', sans-serif;
    letter-spacing: 1px;
}

    .numCircle:before {
        border-radius: 100px;
        border: 2px solid #2b490b;
        box-shadow: 0 0 45px rgba(0, 255, 204, 0.15), 0 0 15px rgba(0, 255, 204, 0.15) inset;
        content: "";
        display: block;
        position: absolute;
        left: 50%;
        top: 50%;
        height: 80px;
        width: 80px;
        margin-left: -42px;
        margin-top: -42px;    
        transform: scale(1);
        transition: all 300ms;
    }

        .numCircle.circle{
            background: #162803;
            border: none;
            border-radius: 900px;
            color: #eaeaea;
            display: block;
            width: 70px;
            height: 70px;  
            line-height: 70px;  
            position: relative;
            margin: auto;
            margin-top: 25px;
            transition: 0.5s;
        }

.animate-opacity.visible * {
    opacity:.7;
    -webkit-transition:all .4s ease;  
    -moz-transition:all .4s ease;  
    -o-transition:all .4s ease;  
    transition:all .4s ease;
}

.animate-opacity.visible:hover * {
    opacity: 1;
    -webkit-transition:all .4s ease;  
    -moz-transition:all .4s ease;  
    -o-transition:all .4s ease;  
    transition:all .4s ease;
}

.animate-opacity.visible:hover .numCircle:before {
    transform: scale(1.05);
}

.animate-opacity.visible:hover .numCircle {
    background: #2b490b;
    padding: -2px;
}





/* WEBSITE SHOWCASE */



.showcaseLogo img {
    height:150px;
    width:auto;
}



.keyFeatures ul {
    display:flex;
    flex-wrap:wrap;
    list-style-type:none;
    justify-content: space-around;
    text-align:center;
    margin-left:0;
}

.keyFeatures ul li {
    flex:0 0 12%;
    border:1px solid #000201;
    background:#f5f4ff;
    border-radius:10px;
    align-self: stretch;
    padding:15px 5px;
    margin-bottom:25px;
}

.keyFeatures ul li span {
    font-family: 'Cormorant Garamond', serif;
    font-size:12px;
    font-weight:800;
}

.statIcon {
    font-size:48px;
    line-height:36px;
    margin-bottom:5px;
    font-family: 'Roboto', sans-serif;
    text-align:center;
}

.keyFeatures p {
    font-size:8px;
    text-align:center;
    font-style:italic;
    text-shadow:none;
    margin-bottom:0;
}

.keyFeatures h4 {
    font-size:18px;
    line-height:21px;
}

.keyFeatures 

.rationaleBody {
    display:flex;
}

.rationale 

.rationaleImg {
    flex:0 0 50%;
}





.siteDetails {
    /* Permalink - use to edit and share this gradient: https://colorzilla.com/gradient-editor/#eaeaea+0,f5f4ff+10,f5f4ff+75,eaeaea+100 */
    background: rgb(234,234,234); /* Old browsers */
    background: -moz-linear-gradient(top,  rgba(234,234,234,1) 0%, rgba(245,244,255,1) 10%, rgba(245,244,255,1) 75%, rgba(234,234,234,1) 100%); /* FF3.6-15 */
    background: -webkit-linear-gradient(top,  rgba(234,234,234,1) 0%,rgba(245,244,255,1) 10%,rgba(245,244,255,1) 75%,rgba(234,234,234,1) 100%); /* Chrome10-25,Safari5.1-6 */
    background: linear-gradient(to bottom,  rgba(234,234,234,1) 0%,rgba(245,244,255,1) 10%,rgba(245,244,255,1) 75%,rgba(234,234,234,1) 100%); /* W3C, IE10+, FF16+, Chrome26+, Opera12+, Safari7+ */
    filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#eaeaea', endColorstr='#eaeaea',GradientType=0 ); /* IE6-9 */
    padding:50px 2em 0;
}

.siteDescription p {
    font-size:21px;
    line-height:28px;
    text-align:center;
    margin-bottom:50px;
}



.siteMockups img {
    margin:0 auto;
    display:block;
}



.siteFeatures h4 {
    font-size:21px;
    line-height:24px;
    margin-bottom:10px;
}

.siteFeatures p {
    font-size:14px;
    line-height:21px;
    display:block;
    width:80%;
    margin:0 auto;
}

.siteFeatures ul {
    display:flex;
    flex-wrap:wrap;
    list-style-type:none;
    justify-content: space-around;
    text-align:center;
    margin-left:0;
}

.siteFeatures ul li {
    flex:0 0 31%;
    border:1px solid #000201;
    background:#fafafa;
    border-radius:10px;
    padding:20px 5px;
    margin:15px auto;
}

.siteFeatures i {
    font-size:36px;
    font-size:36px;
}



.websiteGallery .rl-basicgrid-gallery {
    justify-content: space-around;
}

.rl-basicgrid-gallery::after {
    content:none!important;
    flex-grow:none!important;
    min-width:0!important;
    height:0!important;
}

.resultsList ul {
    list-style-type: none;
    margin-left:0;
}

.resultsList li {
    padding:25px 25px 0;
    text-align:center;
}

.resultsQuote p {
    font-size:28px;
    line-height:32px;
    font-weight:300;
    font-style:italic;
    font-family: 'Roboto', sans-serif;
    text-align:center;
    width:80%;
    margin:0 auto 1em auto;
    color:#162803;
}

    .resultsQuote p span {
        font-weight:800;
        color:#8e6940;
        display:block;
        clear:both;
    }





















            .cloud-container {
            width: 100%;
            height: 100%;
            position: relative;
            /* Increased color contrast for visibility */
            background: linear-gradient(
                135deg, 
                #ffffff 0%, 
                #e2eee9 20%, 
                #97b9b1 50%, 
                #6d8d85 80%, 
                #4e635e 100%
            );
            background-size: 200% 200%;
            animation: drift 12s ease-in-out infinite;
        }

        @keyframes drift {
            0% { background-position: 0% 0%; }
            50% { background-position: 100% 100%; }
            100% { background-position: 0% 0%; }
        }

        .cloud-container::after {
            content: "";
            position: absolute;
            top: -50%; /* Larger than screen to prevent edges showing during scale */
            left: -50%;
            width: 200%;
            height: 200%;
            filter: url(#cloudTexture);
            opacity: 0.6;
            mix-blend-mode: overlay;
            pointer-events: none;
            animation: morph 20s linear infinite;
        }

        /* Slowly rotates and scales the texture for a "churning" look */
        @keyframes morph {
            0% { transform: rotate(0deg) scale(1); }
            50% { transform: rotate(3deg) scale(1.1); }
            100% { transform: rotate(0deg) scale(1); }
        }

        .highlight {
            position: absolute;
            top: -10%;
            right: -10%;
            width: 80%;
            height: 80%;
            background: radial-gradient(circle, rgba(255,255,255,0.9) 0%, rgba(255,255,255,0) 60%);
            filter: blur(80px);
            animation: sunGlow 8s ease-in-out infinite;
        }

        @keyframes sunGlow {
            0%, 100% { opacity: 0.4; transform: translate(0, 0); }
            50% { opacity: 0.8; transform: translate(-20px, 20px); }
        }




.services-section {
  padding: 60px 0;
  font-family: 'Inter', sans-serif; /* Using a clean professional font */
  background-color: #fff;
}

.container {
  max-width: 1200px;
  margin: 0 auto;
  display: flex;
  justify-content: space-between;
  align-items: stretch;
}

.service-item {
  flex: 1;
  display: flex;
  align-items: center; /* Vertically centers the icon next to text */
  padding: 0 30px;
  border-right: 1px solid #e0e0e0; /* The thin line */
}

/* Removes the line from the very last column */
.service-item:last-child {
  border-right: none;
}

.icon {
  margin-right: 20px;
  color: #4a5d4e; /* Muted professional green from your mockup */
  flex-shrink: 0;
  display: flex;
  align-items: center;
}

.content h3 {
  margin: 0 0 8px 0;
  font-size: 1.25rem;
  font-weight: 700;
  color: #333;
}

.content p {
  margin: 0;
  font-size: 0.95rem;
  color: #666;
  line-height: 1.5;
}

/* Responsive adjustment for mobile */
@media (max-width: 768px) {
  .container {
    flex-direction: column;
  }
  .service-item {
    border-right: none;
    border-bottom: 1px solid #e0e0e0;
    padding: 20px 0;
  }
  .service-item:last-child {
    border-bottom: none;
  }
}




























    /* ── Variables ── */
    .aboutPage-root {
      --ap-bg:        #f2f0eb;
      --ap-surface:   #ffffff;
      --ap-accent:    #6b8f71;
      --ap-accent2:   #a8b89e;
      --ap-text:      #2c2c2c;
      --ap-muted:     #6a6a6a;
      --ap-btn-dark:  #3a4f3d;
      --ap-wave1:     rgba(168,184,158,0.35);
      --ap-wave2:     rgba(168,184,158,0.2);

      font-family: 'Jost', sans-serif;
      background: var(--ap-bg);
      color: var(--ap-text);
    }

    /* ═══════════════════════════════
       HERO
    ═══════════════════════════════ */
    .aboutPage-hero {
      position: relative;
      text-align: center;
      padding: 9rem 0rem 0;
      overflow: hidden;
    }

    /* layered wave background */
    .aboutPage-hero::after {
      content: '';
      display: block;
      width: 100%;
      height: 120px;
      margin-top: 2.5rem;
      background: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 1200 120' preserveAspectRatio='none'%3E%3Cpath d='M0 60 Q300 0 600 50 Q900 100 1200 30 L1200 120 L0 120 Z' fill='%23a8b89e' opacity='0.28'/%3E%3Cpath d='M0 75 Q300 20 600 65 Q900 110 1200 45 L1200 120 L0 120 Z' fill='%23a8b89e' opacity='0.18'/%3E%3Cpath d='M0 90 Q300 40 600 80 Q900 120 1200 60 L1200 120 L0 120 Z' fill='%23a8b89e' opacity='0.12'/%3E%3C/svg%3E") center/cover no-repeat;
    }

    .aboutPage-hero-name {
      font-family: 'Cormorant Garamond', serif;
      font-weight: 400;
      font-size: clamp(2.8rem, 7vw, 5rem);
      letter-spacing: 0.01em;
      line-height: 1.1;
      opacity: 0;
      transform: translateY(20px);
      animation: ap-fadeUp 0.75s 0.05s ease forwards;
    }

    .aboutPage-hero-tagline {
      font-size: clamp(0.8rem, 2vw, 1rem);
      font-weight: 300;
      letter-spacing: 0.12em;
      text-transform: uppercase;
      color: var(--ap-muted);
      margin-top: 0.6rem;
      opacity: 0;
      transform: translateY(14px);
      animation: ap-fadeUp 0.7s 0.18s ease forwards;
    }

    .aboutPage-hero-bio {
      max-width: 640px;
      margin: 1.4rem auto 0;
      font-size: 0.92rem;
      font-weight: 300;
      color: var(--ap-muted);
      line-height: 1.75;
      opacity: 0;
      transform: translateY(12px);
      animation: ap-fadeUp 0.7s 0.3s ease forwards;
    }

    .aboutPage-hero-actions {
      display: flex;
      align-items: center;
      justify-content: center;
      gap: 0.75rem;
      margin-top: 1.8rem;
      flex-wrap: wrap;
      opacity: 0;
      transform: translateY(12px);
      animation: ap-fadeUp 0.7s 0.42s ease forwards;
    }

    .aboutPage-btn-primary {
      background: var(--ap-btn-dark);
      color: #fff;
      border: none;
      border-radius: 6px;
      padding: 0.7rem 1.5rem;
      font-family: 'Jost', sans-serif;
      font-size: 0.88rem;
      font-weight: 400;
      letter-spacing: 0.04em;
      cursor: pointer;
      transition: background 0.2s ease, transform 0.2s ease;
      text-decoration: none;
      display: inline-block;
    }
    .aboutPage-btn-primary:hover { background: #2e3f31; transform: translateY(-2px); }

    .aboutPage-btn-secondary {
      background: transparent;
      color: var(--ap-text);
      border: 1.5px solid #b0b8a8;
      border-radius: 6px;
      padding: 0.68rem 1.4rem;
      font-family: 'Jost', sans-serif;
      font-size: 0.88rem;
      font-weight: 400;
      letter-spacing: 0.04em;
      cursor: pointer;
      transition: border-color 0.2s ease, transform 0.2s ease;
      text-decoration: none;
      display: inline-flex;
      align-items: center;
      gap: 0.4rem;
    }
    .aboutPage-btn-secondary:hover { border-color: var(--ap-accent); transform: translateY(-2px); }

    .aboutPage-btn-icon {
      width: 36px;
      height: 36px;
      border: 1.5px solid #b0b8a8;
      border-radius: 6px;
      display: inline-flex;
      align-items: center;
      justify-content: center;
      font-size: 0.95rem;
      cursor: pointer;
      transition: border-color 0.2s ease;
      text-decoration: none;
      color: var(--ap-text);
    }
    .aboutPage-btn-icon:hover { border-color: var(--ap-accent); }

    .aboutPage-hero-location {
      font-size: 0.8rem;
      font-weight: 300;
      color: var(--ap-muted);
      margin-top: 1rem;
      letter-spacing: 0.02em;
      opacity: 0;
      animation: ap-fadeUp 0.7s 0.54s ease forwards;
    }

    /* ═══════════════════════════════
       CORE FOCUS SECTION
    ═══════════════════════════════ */
    .aboutPage-focus {
      padding: 4rem 1.5rem 3rem;
      max-width: 980px;
      margin: 0 auto;
    }

    .aboutPage-focus-inner {
      display: grid;
      grid-template-columns: 280px 1fr;
      gap: 3rem;
      align-items: start;
    }

    .aboutPage-headshot {
      width: 100%;
      aspect-ratio: 3/4;
      object-fit: cover;
      border-radius: 14px;
      box-shadow: 0 8px 30px rgba(107,143,113,0.18);
      display: block;
    }

    .aboutPage-headshot-placeholder {
      width: 100%;
      aspect-ratio: 3/4;
      border-radius: 14px;
      background: linear-gradient(160deg, #dce6dc 0%, #b8ccb8 100%);
      display: flex;
      align-items: center;
      justify-content: center;
      font-size: 4rem;
      box-shadow: 0 8px 30px rgba(107,143,113,0.18);
    }

    

    .aboutPage-focus-title {
      font-family: 'Cormorant Garamond', serif;
      font-weight: 400;
      font-size: clamp(1.7rem, 3.5vw, 2.4rem);
      line-height: 1.15;
      margin-bottom: 0.4rem;
    }

    .aboutPage-focus-subtitle {
      font-size: 0.88rem;
      font-weight: 300;
      color: var(--ap-muted);
      margin-bottom: 1.75rem;
      letter-spacing: 0.02em;
    }

    /* focus card */
    .aboutPage-focus-card {
      background: var(--ap-surface);
      border-radius: 14px;
      padding: 1.75rem 1.75rem 1.5rem;
      box-shadow: 0 2px 16px rgba(107,143,113,0.07);
    }

    .aboutPage-focus-item {
      display: flex;
      gap: 1rem;
      padding: 1.1rem 0;
      border-bottom: 1px solid #eaede8;
    }
    .aboutPage-focus-item:first-child { padding-top: 0; }
    .aboutPage-focus-item:last-child { border-bottom: none; padding-bottom: 0; }

    .aboutPage-focus-num {
      flex-shrink: 0;
      width: 28px;
      height: 28px;
      border-radius: 50%;
      background: var(--ap-accent);
      color: #fff;
      font-size: 0.8rem;
      font-weight: 500;
      display: flex;
      align-items: center;
      justify-content: center;
      margin-top: 2px;
    }

    

    .aboutPage-focus-item-title {
      font-family: 'Cormorant Garamond', serif;
      font-weight: 400;
      font-size: 1.15rem;
      margin-bottom: 0.35rem;
    }

    .aboutPage-focus-bullets {
      list-style: none;
      display: flex;
      flex-direction: column;
      gap: 0.25rem;
    }

    .aboutPage-focus-bullets li {
      font-size: 0.83rem;
      font-weight: 300;
      color: var(--ap-muted);
      line-height: 1.55;
      display: flex;
      gap: 0.45rem;
    }

    .aboutPage-focus-bullets li::before {
      content: '·';
      color: var(--ap-accent);
      font-size: 1.2rem;
      line-height: 1.3;
      flex-shrink: 0;
    }

    /* ═══════════════════════════════
       JOURNEY SECTION
    ═══════════════════════════════ */
    .aboutPage-journey {
      background: var(--ap-bg);
      padding: 1rem 1.5rem 4rem;
      max-width: 980px;
      margin: 0 auto;
    }

    .aboutPage-journey-title {
      font-family: 'Cormorant Garamond', serif;
      font-weight: 300;
      font-size: clamp(1.8rem, 4vw, 2.6rem);
      letter-spacing: 0.01em;
      margin-bottom: 2rem;
    }

    .aboutPage-journey-grid {
      display: grid;
      grid-template-columns: 1fr 280px;
      gap: 2.5rem;
      align-items: start;
    }

    .aboutPage-journey-steps {
      display: flex;
      flex-direction: column;
      gap: 2rem;
    }

    

    .aboutPage-step-header {
      display: flex;
      align-items: center;
      gap: 0.75rem;
      margin-bottom: 0.7rem;
    }

    .aboutPage-step-num {
      flex-shrink: 0;
      width: 28px;
      height: 28px;
      border-radius: 50%;
      background: var(--ap-accent);
      color: #fff;
      font-size: 0.8rem;
      font-weight: 500;
      display: flex;
      align-items: center;
      justify-content: center;
    }

    .aboutPage-step-title {
      font-family: 'Cormorant Garamond', serif;
      font-weight: 400;
      font-size: clamp(1.1rem, 2.5vw, 1.4rem);
    }

    .aboutPage-step-list {
      list-style: none;
      padding-left: 2.1rem;
      display: flex;
      flex-direction: column;
      gap: 0.35rem;
    }

    .aboutPage-step-list li {
      font-size: 0.85rem;
      font-weight: 300;
      color: var(--ap-muted);
      line-height: 1.6;
      display: flex;
      gap: 0.45rem;
    }

    .aboutPage-step-list li::before {
      content: '·';
      color: var(--ap-accent);
      font-size: 1.2rem;
      line-height: 1.3;
      flex-shrink: 0;
    }

    /* stacked photos */
    .aboutPage-journey-photos {
      display: flex;
      flex-direction: column;
      gap: 1.2rem;
    }

    .aboutPage-journey-photo {
      width: 100%;
      aspect-ratio: 4/3;
      object-fit: cover;
      border-radius: 12px;
      box-shadow: 0 6px 20px rgba(107,143,113,0.15);
      display: block;
    }

    .aboutPage-journey-photo-placeholder {
      width: 100%;
      aspect-ratio: 4/3;
      border-radius: 12px;
      background: linear-gradient(135deg, #dce6dc 0%, #c4d4c4 100%);
      display: flex;
      align-items: center;
      justify-content: center;
      font-size: 2rem;
      box-shadow: 0 6px 20px rgba(107,143,113,0.15);
    }

    /* ═══════════════════════════════
       FOOTER CTA
    ═══════════════════════════════ */
    .aboutPage-cta {
      position: relative;
      overflow: hidden;
      padding: 3rem 1.5rem 4rem;
      text-align: center;
    }

    .aboutPage-cta-text {
      max-width: 560px;
      margin: 2rem auto 0;
      font-size: 0.92rem;
      font-weight: 300;
      color: var(--ap-muted);
      line-height: 1.75;
    }

    /* ═══════════════════════════════
       ANIMATIONS
    ═══════════════════════════════ */
    @keyframes ap-fadeUp {
      to { opacity: 1; transform: translateY(0); }
    }

    /* ═══════════════════════════════
       RESPONSIVE
    ═══════════════════════════════ */
    @media (max-width: 700px) {
      .aboutPage-focus-inner {
        grid-template-columns: 1fr;
      }
      .aboutPage-headshot,
      .aboutPage-headshot-placeholder {
        aspect-ratio: 1/1;
        max-width: 220px;
      }
      .aboutPage-journey-grid {
        grid-template-columns: 1fr;
      }
      .aboutPage-journey-photos {
        flex-direction: row;
        overflow-x: auto;
      }
      .aboutPage-journey-photo,
      .aboutPage-journey-photo-placeholder {
        min-width: 200px;
      }
    }
























    .resumePage-root {
      --rp-bg:      #f4f2ee;
      --rp-surface: #ffffff;
      --rp-accent:  #6b8f71;
      --rp-accent2: #a8b89e;
      --rp-text:    #2c2c2c;
      --rp-muted:   #6e6e6e;
      --rp-num-bg:  #6b8f71;
      --rp-num-fg:  #ffffff;

      font-family: 'Jost', sans-serif;
      background: var(--rp-bg);
      color: var(--rp-text);
      min-height: 100vh;
      padding: 3rem 1.25rem 5rem;
    }

    .resumePage-container {
      max-width: 900px;
      margin: 0 auto;
    }

    .resumePage-title {
      font-family: 'Cormorant Garamond', serif;
      font-weight: 300;
      font-size: clamp(2rem, 5vw, 3.2rem);
      letter-spacing: 0.01em;
      color: var(--rp-text);
      margin-bottom: 3rem;
      opacity: 0;
      transform: translateY(18px);
      animation: rp-fadeUp 0.7s ease forwards;
    }

    .resumePage-section {
      position: relative;
      background: var(--rp-surface);
      border-radius: 18px;
      padding: 2.25rem 2rem 2.5rem;
      margin-bottom: 2.5rem;
      box-shadow: 0 2px 18px rgba(107,143,113,0.07);
      overflow: hidden;
      opacity: 0;
      transform: translateY(24px);
      transition: box-shadow 0.3s ease, transform 0.3s ease;
    }

    .resumePage-section:nth-child(2) { animation: rp-fadeUp 0.65s 0.15s ease forwards; }
    .resumePage-section:nth-child(3) { animation: rp-fadeUp 0.65s 0.30s ease forwards; }
    .resumePage-section:nth-child(4) { animation: rp-fadeUp 0.65s 0.45s ease forwards; }

    .resumePage-section::after {
      content: '';
      position: absolute;
      bottom: -1px;
      left: 0; right: 0;
      height: 56px;
      background: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 900 56' preserveAspectRatio='none'%3E%3Cpath d='M0 30 Q225 0 450 28 Q675 56 900 20 L900 56 L0 56 Z' fill='%23d6dfd6' opacity='0.45'/%3E%3Cpath d='M0 40 Q225 14 450 38 Q675 62 900 32 L900 56 L0 56 Z' fill='%23c8d4c8' opacity='0.35'/%3E%3C/svg%3E") center/cover no-repeat;
      pointer-events: none;
    }

    .resumePage-section:hover {
      transform: translateY(-3px);
      box-shadow: 0 8px 30px rgba(107,143,113,0.13);
    }

    .resumePage-inner {
      display: grid;
      grid-template-columns: 1fr 260px;
      gap: 2rem;
      align-items: start;
    }

    .resumePage-header {
      display: flex;
      align-items: center;
      gap: 0.85rem;
      margin-bottom: 1.1rem;
    }

    .resumePage-num {
      flex-shrink: 0;
      width: 34px;
      height: 34px;
      border-radius: 50%;
      background: var(--rp-num-bg);
      color: var(--rp-num-fg);
      font-family: 'Jost', sans-serif;
      font-weight: 500;
      font-size: 0.95rem;
      display: flex;
      align-items: center;
      justify-content: center;
    }

    .resumePage-heading {
      font-family: 'Cormorant Garamond', serif;
      font-weight: 400;
      font-size: clamp(1.35rem, 3vw, 1.85rem);
      letter-spacing: 0.01em;
      color: var(--rp-text);
      line-height: 1.2;
    }

    .resumePage-list {
      list-style: none;
      padding: 0;
      display: flex;
      flex-direction: column;
      gap: 0.6rem;
    }

    .resumePage-list li {
      display: flex;
      gap: 0.55rem;
      font-size: 0.9rem;
      font-weight: 300;
      color: var(--rp-muted);
      line-height: 1.6;
    }

    .resumePage-list li::before {
      content: '·';
      color: var(--rp-accent);
      font-size: 1.3rem;
      line-height: 1.35;
      flex-shrink: 0;
    }

    .resumePage-photo {
      width: 100%;
      aspect-ratio: 4/3;
      object-fit: cover;
      border-radius: 12px;
      box-shadow: 0 6px 22px rgba(107,143,113,0.15);
      display: block;
    }

    .resumePage-photo-placeholder {
      width: 100%;
      aspect-ratio: 4/3;
      border-radius: 12px;
      background: linear-gradient(135deg, #dce6dc 0%, #c8d4c8 100%);
      display: flex;
      align-items: center;
      justify-content: center;
      color: var(--rp-accent);
      font-size: 2.2rem;
      box-shadow: 0 6px 22px rgba(107,143,113,0.15);
    }

    @media (max-width: 680px) {
      .resumePage-inner {
        grid-template-columns: 1fr;
      }
      .resumePage-photo,
      .resumePage-photo-placeholder {
        order: -1;
        aspect-ratio: 16/9;
      }
      .resumePage-section {
        padding: 1.75rem 1.25rem 2rem;
      }
    }

    @keyframes rp-fadeUp {
      to { opacity: 1; transform: translateY(0); }
    }
























































        .homepage-root {
      --hp-bg:        #f2f0eb;
      --hp-surface:   #ffffff;
      --hp-accent:    #3a4f3d;
      --hp-accent2:   #6b8f71;
      --hp-accent3:   #a8b89e;
      --hp-text:      #2c2c2c;
      --hp-muted:     #6a6a6a;
      --hp-footer-bg: #3a4f3d;
      --hp-footer-fg: #ffffff;

      font-family: 'Jost', sans-serif;
      background: var(--hp-bg);
      color: var(--hp-text);
    }

    /* ═══════════════════════════════
       HERO
    ═══════════════════════════════ */
    .homepage-hero {
      position: relative;
      padding: 10rem 2rem 8rem;
      max-width: 1200px;
      margin: 0 auto;
      overflow: visible;
    }

    .homepage-hero-greeting {
      font-family: 'Jost', sans-serif;
      font-size: 1.4rem;
      font-weight: 400;
      color: var(--hp-accent2);
      letter-spacing: 0.03em;
      margin-bottom: 0.75rem;
      opacity: 0;
      transform: translateY(14px);
      animation: hp-fadeUp 0.6s 0.05s ease forwards;
    }

    .homepage-hero-headline {
      font-family: 'Cormorant Garamond', serif;
      font-weight: 400;
      font-size: clamp(2.2rem, 5.5vw, 3.8rem);
      line-height: 1.12;
      color: var(--hp-text);
      opacity: 0;
      transform: translateY(18px);
      animation: hp-fadeUp 0.7s 0.15s ease forwards;
      text-align:left;
      max-width:800px;
    }

    .homepage-hero-sub {
      margin-top: 1.25rem;
      font-size: 1.75rem;
      font-weight: 300;
      color: var(--hp-muted);
      line-height: 1.7;
      opacity: 0;
      transform: translateY(14px);
      animation: hp-fadeUp 0.65s 0.28s ease forwards;
      max-width:800px;
    }

    .homepage-hero-actions {
      display: flex;
      flex-wrap: wrap;
      gap: 0.75rem;
      margin-top: 2rem;
      opacity: 0;
      transform: translateY(12px);
      animation: hp-fadeUp 0.65s 0.4s ease forwards;
    }

    .homepage-btn-primary {
      background: var(--hp-accent);
      color: #fff;
      border: none;
      border-radius: 6px;
      padding: 0.72rem 1.5rem;
      font-family: 'Jost', sans-serif;
      font-size: 0.88rem;
      font-weight: 400;
      letter-spacing: 0.03em;
      cursor: pointer;
      text-decoration: none;
      display: inline-block;
      transition: background 0.2s, transform 0.2s;
    }
    .homepage-btn-primary:hover { background: #2c3d2f; transform: translateY(-2px); }

    .homepage-btn-outline {
      background: transparent;
      color: var(--hp-text);
      border: 1.5px solid #b5bfad;
      border-radius: 6px;
      padding: 0.7rem 1.4rem;
      font-family: 'Jost', sans-serif;
      font-size: 0.88rem;
      font-weight: 400;
      letter-spacing: 0.03em;
      cursor: pointer;
      text-decoration: none;
      display: inline-block;
      transition: border-color 0.2s, transform 0.2s;
    }
    .homepage-btn-outline:hover { border-color: var(--hp-accent2); transform: translateY(-2px); }

    .homepage-btn-outline-sm {
      font-size: 0.8rem;
      padding: 0.68rem 1.2rem;
    }

    /* wave spacer below hero */
    .homepage-hero-wave {
      width: 100%;
      display: block;
      margin-top: 3.5rem;
      line-height: 0;
    }

    /* ═══════════════════════════════
       STATS BAR
    ═══════════════════════════════ */
    .homepage-stats {
      background: #ced5c5;
      padding: 2.5rem 2rem;
    }

    .homepage-stats-inner {
      max-width: 1280px;
      margin: 0 auto;
      display: grid;
      grid-template-columns: repeat(4, 1fr);
      gap: 0;
    }

    .homepage-stat {
      padding: 0 1.75rem;
      border-left: 1px solid #dde3d8;
    }
    .homepage-stat:first-child { border-left: none; padding-left: 0; }

    .homepage-stat-title {
      font-family: 'Jost', sans-serif;
      font-weight: 500;
      font-size: 1.75rem;
      color: var(--hp-text);
      margin-bottom: 0.45rem;
    }

    .homepage-stat-body {
      font-size: 1rem;
      font-weight: 300;
      color: var(--hp-muted);
      line-height: 1.55;
    }

    .homepage-stat-body strong {
      font-weight: 500;
      color: var(--hp-text);
    }

    /* ═══════════════════════════════
       WHAT I DO
    ═══════════════════════════════ */
    .homepage-services {
      padding: 4rem 2rem;
      max-width: 980px;
      margin: 0 auto;
    }

    .homepage-section-title {
      font-family: 'Cormorant Garamond', serif;
      font-weight: 400;
      font-size: clamp(1.8rem, 4vw, 2.5rem);
      text-align: center;
      margin-bottom: 2.25rem;
      position: relative;
    }

    .homepage-section-title::before,
    .homepage-section-title::after {
      content: '';
      position: absolute;
      top: 50%;
      width: 28%;
      height: 1px;
      background: #d0d8cc;
    }
    .homepage-section-title::before { left: 0; }
    .homepage-section-title::after  { right: 0; }

    .homepage-services-grid {
      display: grid;
      grid-template-columns: repeat(3, 1fr);
      gap: 1.25rem;
    }

    .homepage-service-card {
      background: var(--hp-surface);
      border-radius: 12px;
      overflow: hidden;
      box-shadow: 0 2px 14px rgba(107,143,113,0.07);
      transition: transform 0.25s, box-shadow 0.25s;
    }
    .homepage-service-card:hover {
      transform: translateY(-4px);
      box-shadow: 0 8px 28px rgba(107,143,113,0.14);
    }

    .homepage-service-header {
      background: linear-gradient(
        135deg,
        #3a4f3d 0%,
        #2f4232 100%
    ); 
      color:#fff;
      padding: 1.1rem 1.3rem;
      font-family: 'Jost', sans-serif;
      font-weight: 500;
      font-size: 0.95rem;
      line-height: 1.35;
      min-height: 72px;
      display: flex;
      align-items: center;
    }

    .homepage-service-body {
      padding: 1.25rem 1.3rem 1.5rem;
      font-size: 0.85rem;
      font-weight: 300;
      color: var(--hp-muted);
      line-height: 1.65;
    }

    /* ═══════════════════════════════
       FEATURED WORK
    ═══════════════════════════════ */
    .homepage-work {
      padding: 0 2rem 4rem;
      max-width: 980px;
      margin: 0 auto;
    }

    .homepage-work-grid {
      display: grid;
      grid-template-columns: 1fr 1fr;
      gap: 1.25rem;
      margin-bottom: 0;
    }

    .homepage-work-card {
      background: var(--hp-surface);
      border-radius: 12px;
      padding: 1.6rem 1.75rem 1.75rem;
      box-shadow: 0 2px 14px rgba(107,143,113,0.07);
      transition: transform 0.25s, box-shadow 0.25s;
    }
    .homepage-work-card:hover {
      transform: translateY(-3px);
      box-shadow: 0 8px 28px rgba(107,143,113,0.12);
    }

    .homepage-work-card-title {
      font-family: 'Cormorant Garamond', serif;
      font-weight: 400;
      font-size: 1.3rem;
      margin-bottom: 1.1rem;
      color: var(--hp-text);
    }

    .homepage-work-item {
      margin-bottom: 0.9rem;
    }
    .homepage-work-item:last-of-type { margin-bottom: 0; }

    .homepage-work-item-label {
      font-size: 0.8rem;
      font-weight: 500;
      color: var(--hp-text);
      margin-bottom: 0.2rem;
      letter-spacing: 0.02em;
    }

    .homepage-work-item-text {
      font-size: 0.85rem;
      font-weight: 300;
      color: var(--hp-muted);
      line-height: 1.6;
    }

    .homepage-work-card-footer {
      margin-top: 1.4rem;
      padding-top: 1.1rem;
      border-top: 1px solid #eaede8;
      display: flex;
      justify-content: flex-end;
    }

    /* ═══════════════════════════════
       BLOG / ARTICLES
    ═══════════════════════════════ */
    .homepage-blog {
      background: var(--hp-bg);
      padding: 0 2rem 4rem;
      max-width: 980px;
      margin: 0 auto;
    }

    .homepage-blog-grid {
      display: grid;
      grid-template-columns: repeat(3, 1fr);
      gap: 1.25rem;
    }

    .homepage-blog-card {
      background: var(--hp-surface);
      border-radius: 12px;
      padding: 1.4rem 1.4rem 1.5rem;
      box-shadow: 0 2px 14px rgba(107,143,113,0.06);
      display: grid;
      grid-template-columns: 1fr 72px;
      gap: 1rem;
      align-items: start;
      transition: transform 0.25s, box-shadow 0.25s;
    }
    .homepage-blog-card:hover {
      transform: translateY(-3px);
      box-shadow: 0 8px 26px rgba(107,143,113,0.12);
    }

    .homepage-blog-card-title {
      font-family: 'Cormorant Garamond', serif;
      font-weight: 400;
      font-size: 1.05rem;
      line-height: 1.3;
      margin-bottom: 0.4rem;
      color: var(--hp-text);
    }

    .homepage-blog-meta {
      font-size: 0.75rem;
      font-weight: 300;
      color: var(--hp-muted);
      margin-bottom: 0.55rem;
      letter-spacing: 0.01em;
    }

    .homepage-blog-excerpt {
      font-size: 0.82rem;
      font-weight: 300;
      color: var(--hp-muted);
      line-height: 1.6;
    }

    .homepage-blog-thumb {
      width: 72px;
      height: 72px;
      border-radius: 8px;
      object-fit: cover;
      display: block;
    }

    /* Ensure the image container stays the correct size */
    .homepage-blog-thumb-placeholder {
        width: 80px;  /* Adjust based on your original design */
        height: 80px; /* Adjust based on your original design */
        display: flex;
        align-items: center;
        justify-content: center;
        overflow: hidden;
        flex-shrink: 0; /* Prevents the image box from squishing */
    }

    /* Force the WP image to fill the box without breaking layout */
    .homepage-blog-img {
        width: 100%;
        height: 100%;
        object-fit: cover;
        display: block;
    }

    /* ═══════════════════════════════
       FOOTER CTA BAND
    ═══════════════════════════════ */
    .homepage-cta-band {
      position: relative;
      background: var(--hp-footer-bg);
      color: var(--hp-footer-fg);
      text-align: center;
      padding: 4.5rem 2rem 4rem;
      overflow: hidden;
      margin-top: 2rem;
    }

    .homepage-cta-band::before {
      content: '';
      position: absolute;
      top: 0; left: 0; right: 0;
      height: 70px;
      background: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 1200 70' preserveAspectRatio='none'%3E%3Cpath d='M0 35 Q300 70 600 25 Q900 0 1200 40 L1200 0 L0 0 Z' fill='%23f2f0eb'/%3E%3C/svg%3E") center/cover no-repeat;
      pointer-events: none;
    }

    .homepage-cta-band-text {
      max-width: 580px;
      margin: 0 auto 2rem;
      font-size: 1rem;
      font-weight: 300;
      line-height: 1.75;
      color: rgba(255,255,255,0.88);
    }

    .homepage-cta-band-text em {
      font-style: italic;
      color: #fff;
      font-family: 'Cormorant Garamond', serif;
      font-size: 1.1em;
    }

    .homepage-cta-band-actions {
      display: flex;
      justify-content: center;
      gap: 0.85rem;
      flex-wrap: wrap;
    }

    .homepage-btn-light {
      background: #fff;
      color: var(--hp-accent);
      border: none;
      border-radius: 6px;
      padding: 0.72rem 1.5rem;
      font-family: 'Jost', sans-serif;
      font-size: 0.88rem;
      font-weight: 500;
      letter-spacing: 0.03em;
      cursor: pointer;
      text-decoration: none;
      display: inline-block;
      transition: background 0.2s, transform 0.2s;
    }
    .homepage-btn-light:hover { background: #eef2ed; transform: translateY(-2px); }

    .homepage-btn-outline-light {
      background: transparent;
      color: #fff;
      border: 1.5px solid rgba(255,255,255,0.45);
      border-radius: 6px;
      padding: 0.7rem 1.4rem;
      font-family: 'Jost', sans-serif;
      font-size: 0.88rem;
      font-weight: 400;
      letter-spacing: 0.03em;
      cursor: pointer;
      text-decoration: none;
      display: inline-flex;
      align-items: center;
      gap: 0.35rem;
      transition: border-color 0.2s, transform 0.2s;
    }
    .homepage-btn-outline-light:hover { border-color: rgba(255,255,255,0.8); transform: translateY(-2px); }

    /* ═══════════════════════════════
       FOOTER NAV
    ═══════════════════════════════ */
    .homepage-footer-nav {
      background: var(--hp-footer-bg);
      border-top: 1px solid rgba(255,255,255,0.1);
      padding: 1.25rem 2rem;
      display: flex;
      justify-content: center;
      gap: 0.5rem;
      flex-wrap: wrap;
    }

    .homepage-footer-nav a {
      color: rgba(255,255,255,0.6);
      text-decoration: none;
      font-size: 0.78rem;
      font-weight: 300;
      letter-spacing: 0.03em;
      padding: 0 0.6rem;
      border-right: 1px solid rgba(255,255,255,0.2);
      transition: color 0.2s;
    }
    .homepage-footer-nav a:last-child { border-right: none; }
    .homepage-footer-nav a:hover { color: rgba(255,255,255,0.9); }

    /* ═══════════════════════════════
       WAVE DIVIDER UTILITY
    ═══════════════════════════════ */
    .homepage-wave-divider {
      display: block;
      width: 100%;
      line-height: 0;
      overflow: hidden;
    }

    /* ═══════════════════════════════
       ANIMATIONS
    ═══════════════════════════════ */
    @keyframes hp-fadeUp {
      to { opacity: 1; transform: translateY(0); }
    }

    /* ═══════════════════════════════
       RESPONSIVE
    ═══════════════════════════════ */
    @media (max-width: 800px) {
      .homepage-stats-inner { grid-template-columns: repeat(2, 1fr); gap: 1.5rem; }
      .homepage-stat { border-left: none; padding-left: 0; border-top: 1px solid #dde3d8; padding-top: 1rem; }
      .homepage-stat:first-child, .homepage-stat:nth-child(2) { border-top: none; padding-top: 0; }
      .homepage-services-grid { grid-template-columns: 1fr; }
      .homepage-work-grid { grid-template-columns: 1fr; }
      .homepage-blog-grid { grid-template-columns: 1fr; }
      .homepage-section-title::before,
      .homepage-section-title::after { width: 15%; }
    }

    @media (max-width: 520px) {
      .homepage-stats-inner { grid-template-columns: 1fr; }
      .homepage-stat { border-top: 1px solid #dde3d8; padding-top: 1rem; }
      .homepage-stat:first-child { border-top: none; padding-top: 0; }
    }




















    .portfolioPage-root {
      --pp-bg:        #f2f0eb;
      --pp-surface:   #ffffff;
      --pp-accent:    #3a4f3d;
      --pp-accent2:   #6b8f71;
      --pp-accent3:   #a8b89e;
      --pp-text:      #2c2c2c;
      --pp-muted:     #6a6a6a;
      --pp-border:    #e2e8de;

      font-family: 'Jost', sans-serif;
      background: var(--pp-bg);
      color: var(--pp-text);
      padding-top:7rem;
    }

    /* ═══════════════════════════════
       PAGE TITLE
    ═══════════════════════════════ */
    .portfolioPage-header {
      padding: 3.5rem 2rem 0;
      max-width: 980px;
      margin: 0 auto;
    }

    .portfolioPage-title {
      font-family: 'Cormorant Garamond', serif;
      font-weight: 300;
      font-size: clamp(2.8rem, 7vw, 4.5rem);
      letter-spacing: 0.01em;
      opacity: 0;
      transform: translateY(16px);
      animation: pp-fadeUp 0.7s 0.05s ease forwards;
    }

    /* ═══════════════════════════════
       METHODOLOGY CARD
    ═══════════════════════════════ */
    .portfolioPage-method {
      max-width: 980px;
      margin: 2.5rem auto 0;
      padding: 0 2rem;
      opacity: 0;
      transform: translateY(20px);
      animation: pp-fadeUp 0.7s 0.2s ease forwards;
    }

    .portfolioPage-method-card {
      background: var(--pp-surface);
      border-radius: 16px;
      padding: 2.5rem 2.5rem 2.25rem;
      box-shadow: 0 2px 20px rgba(107,143,113,0.08);
      text-align: center;
    }

    .portfolioPage-method-title {
      font-family: 'Jost', sans-serif;
      font-weight: 600;
      font-size: clamp(1rem, 2.5vw, 1.25rem);
      letter-spacing: 0.12em;
      text-transform: uppercase;
      color: var(--pp-text);
      margin-bottom: 0.35rem;
    }

    .portfolioPage-method-subtitle {
      font-size: 0.88rem;
      font-weight: 300;
      color: var(--pp-muted);
      margin-bottom: 2.25rem;
    }

    /* step flow */
    .portfolioPage-steps {
      display: grid;
      grid-template-columns: repeat(4, 1fr);
      gap: 0;
      position: relative;
    }

    /* arrow connectors between steps */
    .portfolioPage-steps::before {
      content: '';
      position: absolute;
      top: 36px;
      left: calc(12.5% + 36px);
      right: calc(12.5% + 36px);
      height: 2px;
      background: repeating-linear-gradient(90deg, var(--pp-accent3) 0, var(--pp-accent3) 8px, transparent 8px, transparent 16px);
      pointer-events: none;
    }

    .portfolioPage-step {
      display: flex;
      flex-direction: column;
      align-items: center;
      text-align: center;
      padding: 0 0.75rem;
      position: relative;
    }

    .portfolioPage-step-icon {
      width: 72px;
      height: 72px;
      border-radius: 50%;
      border: 2px solid var(--pp-accent3);
      background: #f7faf7;
      display: flex;
      align-items: center;
      justify-content: center;
      font-size: 1.6rem;
      margin-bottom: 1rem;
      position: relative;
      z-index: 1;
    }

    .portfolioPage-step-num {
      position: absolute;
      top: -4px;
      left: -4px;
      width: 22px;
      height: 22px;
      border-radius: 50%;
      background: var(--pp-accent);
      color: #fff;
      font-size: 0.7rem;
      font-weight: 600;
      display: flex;
      align-items: center;
      justify-content: center;
    }

    .portfolioPage-step-title {
      font-family: 'Jost', sans-serif;
      font-weight: 600;
      font-size: 0.78rem;
      letter-spacing: 0.08em;
      text-transform: uppercase;
      color: var(--pp-text);
      margin-bottom: 0.4rem;
      line-height: 1.3;
    }

    .portfolioPage-step-desc {
      font-size: 0.78rem;
      font-weight: 300;
      color: var(--pp-muted);
      line-height: 1.55;
    }

    /* ═══════════════════════════════
       PROJECT GRID
    ═══════════════════════════════ */
    .portfolioPage-projects {
      max-width: 980px;
      margin: 3rem auto 0;
      padding: 0 2rem 4rem;
    }

    .portfolioPage-grid {
      display: grid;
      grid-template-columns: repeat(3, 1fr);
      gap: 1.25rem;
    }

    .portfolioPage-card {
      background: var(--pp-surface);
      border-radius: 12px;
      overflow: hidden;
      box-shadow: 0 2px 16px rgba(107,143,113,0.07);
      transition: transform 0.25s ease, box-shadow 0.25s ease;
      opacity: 0;
      transform: translateY(22px);
    }

    .portfolioPage-card:nth-child(1) { animation: pp-fadeUp 0.6s 0.35s ease forwards; }
    .portfolioPage-card:nth-child(2) { animation: pp-fadeUp 0.6s 0.45s ease forwards; }
    .portfolioPage-card:nth-child(3) { animation: pp-fadeUp 0.6s 0.55s ease forwards; }
    .portfolioPage-card:nth-child(4) { animation: pp-fadeUp 0.6s 0.65s ease forwards; }
    .portfolioPage-card:nth-child(5) { animation: pp-fadeUp 0.6s 0.75s ease forwards; }
    .portfolioPage-card:nth-child(6) { animation: pp-fadeUp 0.6s 0.85s ease forwards; }

    .portfolioPage-card:hover {
      transform: translateY(-4px);
      box-shadow: 0 10px 30px rgba(107,143,113,0.15);
    }

    .portfolioPage-card-img {
      width: 100%;
      aspect-ratio: 16/9;
      object-fit: cover;
      display: block;
    }

    .portfolioPage-card-img-placeholder {
      width: 100%;
      aspect-ratio: 16/9;
      background: linear-gradient(135deg, #dce6dc 0%, #b8ccb8 100%);
      display: flex;
      align-items: center;
      justify-content: center;
      font-size: 2.2rem;
    }

    .portfolioPage-card-body {
      padding: 1.2rem 1.25rem 1.5rem;
    }

    .portfolioPage-card-title {
      font-family: 'Jost', sans-serif;
      font-weight: 500;
      font-size: 0.9rem;
      letter-spacing: 0.04em;
      text-transform: uppercase;
      color: var(--pp-text);
      margin-bottom: 0.2rem;
    }

    .portfolioPage-card-category {
      font-size: 0.75rem;
      font-weight: 300;
      color: var(--pp-accent2);
      margin-bottom: 0.9rem;
    }

    .portfolioPage-card-item {
      margin-bottom: 0.65rem;
    }
    .portfolioPage-card-item:last-child { margin-bottom: 0; }

    .portfolioPage-card-label {
      font-size: 0.78rem;
      font-weight: 500;
      color: var(--pp-text);
      margin-bottom: 0.15rem;
    }

    .portfolioPage-card-text {
      font-size: 0.8rem;
      font-weight: 300;
      color: var(--pp-muted);
      line-height: 1.6;
    }

    /* ═══════════════════════════════
       TESTIMONIAL
    ═══════════════════════════════ */
    .portfolioPage-testimonial {
      position: relative;
      padding: 1rem 2rem 4rem;
      overflow: hidden;
    }

    .portfolioPage-testimonial-card {
      max-width: 760px;
      margin: 2.5rem auto 0;
      background: var(--pp-surface);
      border-radius: 16px;
      padding: 2rem 2.25rem;
      box-shadow: 0 2px 20px rgba(107,143,113,0.08);
      display: grid;
      grid-template-columns: 72px 1fr auto;
      gap: 1.25rem;
      align-items: center;
    }

    .portfolioPage-testimonial-avatar {
      width: 72px;
      height: 72px;
      border-radius: 50%;
      object-fit: cover;
    }

    .portfolioPage-testimonial-avatar-placeholder {
      width: 72px;
      height: 72px;
      border-radius: 50%;
      background: linear-gradient(135deg, #dce6dc, #b8ccb8);
      display: flex;
      align-items: center;
      justify-content: center;
      font-size: 1.8rem;
      flex-shrink: 0;
    }

    

    .portfolioPage-testimonial-name {
      font-family: 'Jost', sans-serif;
      font-weight: 500;
      font-size: 0.92rem;
      margin-bottom: 0.1rem;
    }

    .portfolioPage-testimonial-role {
      font-size: 0.78rem;
      font-weight: 300;
      color: var(--pp-muted);
      margin-bottom: 0.6rem;
    }

    .portfolioPage-testimonial-quote {
      font-family: 'Cormorant Garamond', serif;
      font-style: italic;
      font-size: 1.05rem;
      color: var(--pp-text);
      line-height: 1.6;
    }

    .portfolioPage-testimonial-logo {
      font-size: 0.78rem;
      font-weight: 500;
      color: var(--pp-accent2);
      letter-spacing: 0.06em;
      text-transform: uppercase;
      white-space: nowrap;
      display: flex;
      align-items: center;
      gap: 0.35rem;
    }

    /* ═══════════════════════════════
       WAVE BETWEEN SECTIONS
    ═══════════════════════════════ */
    .portfolioPage-wave {
      display: block;
      width: 100%;
      line-height: 0;
      overflow: hidden;
    }

    /* ═══════════════════════════════
       ANIMATIONS
    ═══════════════════════════════ */
    @keyframes pp-fadeUp {
      to { opacity: 1; transform: translateY(0); }
    }

    /* ═══════════════════════════════
       RESPONSIVE
    ═══════════════════════════════ */
    @media (max-width: 780px) {
      .portfolioPage-grid { grid-template-columns: repeat(2, 1fr); }
      .portfolioPage-steps { grid-template-columns: repeat(2, 1fr); gap: 1.5rem; }
      .portfolioPage-steps::before { display: none; }
      .portfolioPage-testimonial-card { grid-template-columns: 60px 1fr; }
      .portfolioPage-testimonial-logo { grid-column: 1 / -1; justify-self: start; }
    }

    @media (max-width: 520px) {
      .portfolioPage-grid { grid-template-columns: 1fr; }
      .portfolioPage-steps { grid-template-columns: 1fr; }
      .portfolioPage-testimonial-card { grid-template-columns: 1fr; text-align: center; }
      .portfolioPage-testimonial-avatar-placeholder { margin: 0 auto; }
    }




















    .blogHome-root {
      --bh-bg:        #f2f0eb;
      --bh-surface:   #ffffff;
      --bh-accent:    #3a4f3d;
      --bh-accent2:   #6b8f71;
      --bh-accent3:   #a8b89e;
      --bh-text:      #2c2c2c;
      --bh-muted:     #6a6a6a;
      --bh-border:    #e2e8de;
      --bh-dark-card: #1e2e20;

      font-family: 'Jost', sans-serif;
      background: var(--bh-bg);
      color: var(--bh-text);
    }

    /* ═══════════════════════════════
       NAV
    ═══════════════════════════════ */
    .blogHome-nav {
      background: var(--bh-bg);
      padding: 0.9rem 2.5rem;
      display: flex;
      align-items: center;
      justify-content: space-between;
      gap: 1rem;
      border-bottom: 1px solid var(--bh-border);
      flex-wrap: wrap;
    }

    .blogHome-nav-logo {
      display: flex;
      align-items: center;
      gap: 0.5rem;
      text-decoration: none;
      color: var(--bh-text);
    }

    .blogHome-nav-logo-icon { font-size: 1.3rem; }

    .blogHome-nav-logo-text {
      font-family: 'Jost', sans-serif;
      font-weight: 300;
      font-size: 0.85rem;
      letter-spacing: 0.04em;
    }

    .blogHome-nav-center {
      display: flex;
      align-items: center;
      gap: 1.75rem;
    }

    .blogHome-nav-link {
      font-size: 0.8rem;
      font-weight: 400;
      color: var(--bh-muted);
      text-decoration: none;
      letter-spacing: 0.03em;
      transition: color 0.2s;
    }
    .blogHome-nav-link:hover,
    .blogHome-nav-link.blogHome-nav-link--active { color: var(--bh-accent); }
    .blogHome-nav-link--active { font-weight: 500; }

    .blogHome-nav-right {
      display: flex;
      align-items: center;
      gap: 1.1rem;
    }

    .blogHome-nav-icons {
      display: flex;
      gap: 0.5rem;
      font-size: 0.8rem;
      color: var(--bh-muted);
    }

    .blogHome-nav-icons a {
      color: var(--bh-muted);
      text-decoration: none;
      transition: color 0.2s;
      font-size: 0.85rem;
    }
    .blogHome-nav-icons a:hover { color: var(--bh-accent); }

    .blogHome-nav-search {
      display: flex;
      align-items: center;
      background: var(--bh-surface);
      border: 1px solid var(--bh-border);
      border-radius: 5px;
      overflow: hidden;
      height: 28px;
    }

    .blogHome-nav-search input {
      border: none;
      outline: none;
      background: transparent;
      padding: 0 0.6rem;
      font-size: 0.75rem;
      font-family: 'Jost', sans-serif;
      color: var(--bh-text);
      width: 140px;
    }

    .blogHome-nav-search button {
      background: var(--bh-accent);
      border: none;
      color: #fff;
      padding: 0 0.55rem;
      height: 100%;
      cursor: pointer;
      font-size: 0.7rem;
    }

    /* ═══════════════════════════════
       PAGE TITLE + WAVE
    ═══════════════════════════════ */
    .blogHome-hero {
      text-align: center;
      padding: 3rem 2rem 0;
      position: relative;
    }

    .blogHome-hero-title {
      font-family: 'Cormorant Garamond', serif;
      font-weight: 300;
      font-size: clamp(2.5rem, 6vw, 4rem);
      opacity: 0;
      transform: translateY(16px);
      animation: bh-fadeUp 0.7s 0.05s ease forwards;
    }

    .blogHome-hero-wave {
      display: block;
      width: 100%;
      line-height: 0;
      margin-top: 2rem;
    }

    /* ═══════════════════════════════
       INSIGHTS BANNER
    ═══════════════════════════════ */
    .blogHome-insights {
      max-width: 900px;
      margin: 2.5rem auto 0;
      padding: 0 2rem;
      opacity: 0;
      transform: translateY(18px);
      animation: bh-fadeUp 0.65s 0.2s ease forwards;
    }

    .blogHome-insights-label {
      font-size: 0.72rem;
      font-weight: 500;
      letter-spacing: 0.14em;
      text-transform: uppercase;
      color: var(--bh-muted);
      margin-bottom: 1.1rem;
    }

    .blogHome-insights-inner {
      display: grid;
      grid-template-columns: 100px 1fr 1fr;
      gap: 1.75rem;
      align-items: center;
    }

    .blogHome-insights-photo {
      width: 100px;
      height: 100px;
      border-radius: 10px;
      object-fit: cover;
      display: block;
    }

    .blogHome-insights-photo-placeholder {
      width: 100px;
      height: 100px;
      border-radius: 10px;
      background: linear-gradient(135deg, #dce6dc, #b8ccb8);
      display: flex;
      align-items: center;
      justify-content: center;
      font-size: 2.2rem;
      flex-shrink: 0;
    }

    .blogHome-insights-headline {
      font-family: 'Cormorant Garamond', serif;
      font-weight: 400;
      font-size: clamp(1.1rem, 2.5vw, 1.5rem);
      line-height: 1.3;
      color: var(--bh-text);
    }

    .blogHome-insights-list {
      list-style: none;
      display: flex;
      flex-direction: column;
      gap: 0.3rem;
    }

    .blogHome-insights-list li {
      font-size: 0.82rem;
      font-weight: 300;
      color: var(--bh-muted);
      display: flex;
      gap: 0.45rem;
      line-height: 1.5;
    }

    .blogHome-insights-list li::before {
      content: '•';
      color: var(--bh-accent2);
      flex-shrink: 0;
    }

    /* ═══════════════════════════════
       FEATURED POST (dark card)
    ═══════════════════════════════ */
    .blogHome-featured {
      max-width: 900px;
      margin: 2.5rem auto 0;
      padding: 0 2rem;
      opacity: 0;
      transform: translateY(20px);
      animation: bh-fadeUp 0.65s 0.33s ease forwards;
      background:#000;
    }

    .blogHome-featured-card {
      background: var(--bh-dark-card);
      border-radius: 14px;
      overflow: hidden;
      display: grid;
      grid-template-columns: 1fr 1fr;
      min-height: 200px;
      box-shadow: 0 4px 24px rgba(30,46,32,0.18);
      transition: transform 0.25s, box-shadow 0.25s;
    }
    .blogHome-featured-card:hover {
      transform: translateY(-3px);
      box-shadow: 0 10px 32px rgba(30,46,32,0.24);
    }

    .blogHome-featured-img {
      width: 100%;
      height: 100%;
      object-fit: cover;
      display: block;
    }

    .blogHome-featured-img-placeholder {
      width: 100%;
      height: 100%;
      min-height: 200px;
      background: linear-gradient(135deg, #1a2e1c 0%, #2d4a30 100%);
      display: flex;
      align-items: center;
      justify-content: center;
      font-size: 4rem;
    }

    .blogHome-featured-body {
      padding: 1.75rem 2rem;
      color: #fff;
      display: flex;
      flex-direction: column;
      justify-content: center;
      background-color:#2c2c2c;
    }

    .blogHome-featured-title {
      font-family: 'Jost', sans-serif;
      font-weight: 600;
      font-size: clamp(1.2rem, 2vw, 1.7rem);
      text-transform: uppercase;
      line-height: 1.1;
      margin-bottom: 0.5rem;
      color:#f2f0eb;
    }

    .blogHome-featured-meta {
      font-size: 0.75rem;
      font-weight: 300;
      color: rgba(255,255,255,0.55);
      margin-bottom: 0.85rem;
      letter-spacing: 0.03em;
    }

    .blogHome-featured-excerpt {
      font-size: 0.83rem;
      font-weight: 300;
      color: rgba(255,255,255,0.78);
      line-height: 1.65;
    }

    /* ═══════════════════════════════
       POST GRIDS
    ═══════════════════════════════ */
    .blogHome-posts {
      max-width: 900px;
      margin: 1.5rem auto 0;
      padding: 0 2rem;
    }

    .blogHome-grid-3 {
      display: grid;
      grid-template-columns: repeat(3, 1fr);
      gap: 1.1rem;
    }

    /* text-only card */
    .blogHome-post-card {
      background: var(--bh-surface);
      border-radius: 11px;
      overflow: hidden;
      box-shadow: 0 2px 14px rgba(107,143,113,0.07);
      transition: transform 0.22s, box-shadow 0.22s;
      opacity: 0;
      transform: translateY(18px);
    }

    .blogHome-post-card:nth-child(1) { animation: bh-fadeUp 0.55s 0.42s ease forwards; }
    .blogHome-post-card:nth-child(2) { animation: bh-fadeUp 0.55s 0.50s ease forwards; }
    .blogHome-post-card:nth-child(3) { animation: bh-fadeUp 0.55s 0.58s ease forwards; }

    .blogHome-post-card--img:nth-child(1) { animation: bh-fadeUp 0.55s 0.60s ease forwards; }
    .blogHome-post-card--img:nth-child(2) { animation: bh-fadeUp 0.55s 0.68s ease forwards; }
    .blogHome-post-card--img:nth-child(3) { animation: bh-fadeUp 0.55s 0.76s ease forwards; }

    .blogHome-post-card:hover {
      transform: translateY(-3px);
      box-shadow: 0 8px 24px rgba(107,143,113,0.13);
    }

    .blogHome-post-header {
      background: var(--bh-accent);
      color: #fff;
      padding: 0.85rem 1rem;
      font-family: 'Jost', sans-serif;
      font-weight: 500;
      font-size: 0.85rem;
      line-height: 1.3;
    }

    .blogHome-post-body {
      padding: 0.9rem 1rem 1.1rem;
    }

    .blogHome-post-category {
      font-size: 0.72rem;
      font-weight: 300;
      color: var(--bh-muted);
      margin-bottom: 0.35rem;
    }

    .blogHome-post-label {
      font-size: 0.75rem;
      font-weight: 500;
      color: var(--bh-text);
      margin-bottom: 0.15rem;
    }

    .blogHome-post-text {
      font-size: 0.78rem;
      font-weight: 300;
      color: var(--bh-muted);
      line-height: 1.58;
      margin-bottom: 0.55rem;
    }

    /* image card */
    .blogHome-post-card--img .blogHome-post-thumb {
      width: 100%;
      aspect-ratio: 16/9;
      object-fit: cover;
      display: block;
    }

    .blogHome-post-card--img .blogHome-post-thumb-placeholder {
      width: 100%;
      aspect-ratio: 16/9;
      background: linear-gradient(135deg, #dce6dc, #b0c4b0);
      display: flex;
      align-items: center;
      justify-content: center;
      font-size: 2rem;
    }

    .blogHome-post-card--img .blogHome-post-body {
      padding: 0.85rem 1rem 1rem;
    }

    .blogHome-post-card--img .blogHome-post-title {
      font-family: 'Jost', sans-serif;
      font-weight: 500;
      font-size: 0.88rem;
      margin-bottom: 0.2rem;
      line-height: 1.3;
      color: var(--bh-text);
    }

    /* second row spacer */
    .blogHome-posts + .blogHome-posts {
      margin-top: 1.1rem;
    }

    /* ═══════════════════════════════
       DOWNLOAD CTA
    ═══════════════════════════════ */
    .blogHome-download {
      max-width: 900px;
      margin: 2.5rem auto 0;
      padding: 0 2rem 3.5rem;
      opacity: 0;
      transform: translateY(16px);
      animation: bh-fadeUp 0.65s 0.9s ease forwards;
    }

    .blogHome-download-card {
      background: var(--bh-surface);
      border-radius: 14px;
      display: grid;
      grid-template-columns: 220px 1fr;
      overflow: hidden;
      box-shadow: 0 2px 20px rgba(107,143,113,0.08);
      transition: transform 0.25s, box-shadow 0.25s;
    }
    .blogHome-download-card:hover {
      transform: translateY(-3px);
      box-shadow: 0 8px 28px rgba(107,143,113,0.13);
    }

    .blogHome-download-thumb {
      width: 100%;
      height: 100%;
      object-fit: cover;
      display: block;
    }

    .blogHome-download-thumb-placeholder {
      width: 100%;
      min-height: 180px;
      background: linear-gradient(135deg, #dce6dc, #c2d4c2);
      display: flex;
      align-items: center;
      justify-content: center;
      font-size: 3rem;
    }

    .blogHome-download-body {
      padding: 2rem 2.25rem;
      display: flex;
      flex-direction: column;
      justify-content: center;
      gap: 0.75rem;
    }

    .blogHome-download-title {
      font-family: 'Cormorant Garamond', serif;
      font-weight: 400;
      font-size: clamp(1.2rem, 2.5vw, 1.65rem);
      line-height: 1.2;
    }

    .blogHome-download-desc {
      font-size: 0.86rem;
      font-weight: 300;
      color: var(--bh-muted);
      line-height: 1.65;
    }

    .blogHome-btn-primary {
      align-self: flex-start;
      background: var(--bh-accent);
      color: #fff;
      border: none;
      border-radius: 6px;
      padding: 0.68rem 1.4rem;
      font-family: 'Jost', sans-serif;
      font-size: 0.85rem;
      font-weight: 400;
      letter-spacing: 0.03em;
      cursor: pointer;
      text-decoration: none;
      display: inline-block;
      transition: background 0.2s, transform 0.2s;
    }
    .blogHome-btn-primary:hover { background: #2c3d2f; transform: translateY(-2px); }

    /* ═══════════════════════════════
       FOOTER
    ═══════════════════════════════ */
    .blogHome-footer {
      position: relative;
      padding: 1rem 2rem 2.5rem;
      text-align: center;
      overflow: hidden;
    }

    .blogHome-footer::before {
      content: '';
      position: absolute;
      top: 0; left: 0; right: 0;
      height: 70px;
      background: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 1200 70' preserveAspectRatio='none'%3E%3Cpath d='M0 35 Q300 70 600 20 Q900 0 1200 45 L1200 0 L0 0 Z' fill='%23a8b89e' opacity='0.22'/%3E%3C/svg%3E") center/cover no-repeat;
      pointer-events: none;
    }

    .blogHome-footer-inner {
      margin-top: 3rem;
      display: flex;
      align-items: center;
      justify-content: center;
      gap: 0.55rem;
    }

    .blogHome-footer-logo-icon { font-size: 1.4rem; }

    .blogHome-footer-logo-text {
      font-family: 'Jost', sans-serif;
      font-weight: 300;
      font-size: 0.9rem;
      letter-spacing: 0.05em;
      color: var(--bh-text);
    }

    /* ═══════════════════════════════
       WAVE UTILITY
    ═══════════════════════════════ */
    .blogHome-wave {
      display: block;
      width: 100%;
      line-height: 0;
      overflow: hidden;
    }

    /* ═══════════════════════════════
       ANIMATIONS
    ═══════════════════════════════ */
    @keyframes bh-fadeUp {
      to { opacity: 1; transform: translateY(0); }
    }

    /* ═══════════════════════════════
       RESPONSIVE
    ═══════════════════════════════ */
    @media (max-width: 780px) {
      .blogHome-nav-center { display: none; }
      .blogHome-insights-inner { grid-template-columns: 80px 1fr; }
      .blogHome-insights-list { display: none; }
      .blogHome-featured-card { grid-template-columns: 1fr; }
      .blogHome-featured-img-placeholder { min-height: 160px; }
      .blogHome-grid-3 { grid-template-columns: repeat(2, 1fr); }
      .blogHome-download-card { grid-template-columns: 1fr; }
    }

    @media (max-width: 520px) {
      .blogHome-grid-3 { grid-template-columns: 1fr; }
      .blogHome-nav-right { display: none; }
    }

/* Ensure the grid doesn't collapse */
.blogHome-grid-3 {
    display: grid !important;
    grid-template-columns: repeat(3, 1fr);
    gap: 1.5rem;
    margin-bottom: 3rem;
}

/* Fix for animation visibility - ensures all cards show up */
.blogHome-post-card {
    opacity: 1 !important; /* Forces visibility if the animation fails */
    transform: none !important;
    display: flex;
    flex-direction: column;
}

/* Ensure images fit the card correctly */
.blogHome-post-thumb {
    width: 100%;
    height: 200px;
    object-fit: cover;
}

/* Pagination Styling */
.portfolio-pagination {
    text-align: center;
    margin-top: 2rem;
    font-family: 'Jost', sans-serif;
}

.portfolio-pagination .page-numbers {
    padding: 8px 16px;
    margin: 0 4px;
    border: 1px solid var(--bh-border);
    text-decoration: none;
    color: var(--bh-muted);
    border-radius: 4px;
}

.portfolio-pagination .current {
    background: var(--bh-accent);
    color: #fff;
    border-color: var(--bh-accent);
}

/* Ensure the grid container is active */
.blogHome-grid-3 {
    display: grid !important;
    grid-template-columns: repeat(3, 1fr) !important; /* Forces 3 columns */
    gap: 20px !important;
    width: 100%;
    margin: 0 auto;
}

/* Ensure the cards fill the space correctly */
.blogHome-post-card-link {
    text-decoration: none;
    color: inherit;
    display: block;
}

.blogHome-post-card {
    height: 100%; /* Ensures all cards in a row are the same height */
    display: flex;
    flex-direction: column;
    opacity: 1 !important; /* Fixes potential animation issues */
    transform: none !important;
}

.blogHome-post-thumb-wrap {
    width: 100%;
    height: 180px;
    overflow: hidden;
}

.blogHome-post-thumb {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

/* Responsive adjustment: 2 columns on tablets, 1 on mobile */
@media (max-width: 900px) {
    .blogHome-grid-3 {
        grid-template-columns: repeat(2, 1fr) !important;
    }
}

@media (max-width: 600px) {
    .blogHome-grid-3 {
        grid-template-columns: 1fr !important;
    }
}


























    
    .singlePost-root {
      --sp-bg:        #f2f0eb;
      --sp-surface:   #ffffff;
      --sp-accent:    #3a4f3d;
      --sp-accent2:   #6b8f71;
      --sp-accent3:   #a8b89e;
      --sp-text:      #2c2c2c;
      --sp-muted:     #6a6a6a;
      --sp-border:    #e2e8de;
      --sp-toc-active:#3a4f3d;

      font-family: 'Jost', sans-serif;
      background: var(--sp-bg);
      color: var(--sp-text);
    }

    /* ═══════════════════════════════
       NAV
    ═══════════════════════════════ */
    .singlePost-nav {
      background: var(--sp-bg);
      padding: 0.85rem 2.5rem;
      display: flex;
      align-items: center;
      justify-content: space-between;
      gap: 1rem;
      border-bottom: 1px solid var(--sp-border);
      flex-wrap: wrap;
    }

    .singlePost-nav-logo {
      display: flex;
      align-items: center;
      gap: 0.5rem;
      text-decoration: none;
      color: var(--sp-text);
    }
    .singlePost-nav-logo-icon { font-size: 1.25rem; }
    .singlePost-nav-logo-text {
      font-family: 'Jost', sans-serif;
      font-weight: 300;
      font-size: 0.85rem;
      letter-spacing: 0.04em;
    }
    .singlePost-nav-logo-text strong { font-weight: 500; }

    .singlePost-nav-right {
      display: flex;
      align-items: center;
      gap: 1.5rem;
      flex-wrap: wrap;
    }

    .singlePost-nav-links {
      display: flex;
      gap: 1.5rem;
      align-items: center;
    }

    .singlePost-nav-link {
      font-size: 0.8rem;
      font-weight: 400;
      color: var(--sp-muted);
      text-decoration: none;
      letter-spacing: 0.03em;
      transition: color 0.2s;
    }
    .singlePost-nav-link:hover { color: var(--sp-accent); }
    .singlePost-nav-link--active { font-weight: 600; color: var(--sp-text); border-bottom: 2px solid var(--sp-accent2); padding-bottom: 1px; }

    .singlePost-nav-icons {
      display: flex;
      gap: 0.55rem;
      font-size: 0.85rem;
    }
    .singlePost-nav-icons a { color: var(--sp-muted); text-decoration: none; transition: color 0.2s; }
    .singlePost-nav-icons a:hover { color: var(--sp-accent); }

    .singlePost-nav-search {
      display: flex;
      align-items: center;
      background: var(--sp-surface);
      border: 1px solid var(--sp-border);
      border-radius: 5px;
      overflow: hidden;
      height: 28px;
    }
    .singlePost-nav-search input {
      border: none;
      outline: none;
      background: transparent;
      padding: 0 0.6rem;
      font-size: 0.75rem;
      font-family: 'Jost', sans-serif;
      color: var(--sp-text);
      width: 150px;
    }
    .singlePost-nav-search button {
      background: var(--sp-accent);
      border: none;
      color: #fff;
      padding: 0 0.55rem;
      height: 100%;
      cursor: pointer;
      font-size: 0.7rem;
    }

    /* ═══════════════════════════════
       HERO WAVE
    ═══════════════════════════════ */
    .singlePost-hero-wave {
      display: block;
      width: 100%;
      line-height: 0;
      overflow: hidden;
    }

    /* ═══════════════════════════════
       BREADCRUMB
    ═══════════════════════════════ */
    .singlePost-breadcrumb {
      max-width: 1020px;
      margin: 1.5rem auto 0;
      padding: 0 2rem;
      font-size: 0.75rem;
      font-weight: 300;
      color: var(--sp-muted);
      display: flex;
      gap: 0.4rem;
      align-items: center;
      flex-wrap: wrap;
    }
    .singlePost-breadcrumb a {
      color: var(--sp-accent2);
      text-decoration: none;
      transition: color 0.2s;
    }
    .singlePost-breadcrumb a:hover { color: var(--sp-accent); }
    .singlePost-breadcrumb-sep { color: var(--sp-border); }

    /* ═══════════════════════════════
       MAIN LAYOUT
    ═══════════════════════════════ */
    .singlePost-layout {
      max-width: 1020px;
      margin: 1.5rem auto 0;
      padding: 0 2rem 4rem;
      display: grid;
      grid-template-columns: 160px 1fr 220px;
      gap: 2rem;
      align-items: start;
    }

    /* ═══════════════════════════════
       TABLE OF CONTENTS (left)
    ═══════════════════════════════ */
    .singlePost-toc {
      position: sticky;
      top: 1.5rem;
      background: var(--sp-surface);
      border-radius: 10px;
      padding: 1.1rem 1rem 1.25rem;
      box-shadow: 0 2px 14px rgba(107,143,113,0.07);
      font-size: 0.78rem;
    }

    .singlePost-toc-title {
      font-family: 'Jost', sans-serif;
      font-weight: 500;
      font-size: 0.82rem;
      color: var(--sp-text);
      margin-bottom: 0.85rem;
      padding-bottom: 0.5rem;
      border-bottom: 1px solid var(--sp-border);
    }

    .singlePost-toc-section {
      margin-bottom: 0.6rem;
    }

    .singlePost-toc-link {
      display: block;
      font-size: 0.75rem;
      font-weight: 400;
      color: var(--sp-accent2);
      text-decoration: none;
      line-height: 1.4;
      padding: 0.1rem 0;
      transition: color 0.2s;
    }
    .singlePost-toc-link:hover { color: var(--sp-accent); }
    .singlePost-toc-link--active { font-weight: 600; color: var(--sp-toc-active); }

    .singlePost-toc-sublink {
      display: block;
      font-size: 0.72rem;
      font-weight: 300;
      color: var(--sp-muted);
      text-decoration: none;
      padding: 0.1rem 0 0.1rem 0.75rem;
      line-height: 1.4;
      transition: color 0.2s;
    }
    .singlePost-toc-sublink:hover { color: var(--sp-accent2); }

    /* ═══════════════════════════════
       ARTICLE BODY (center)
    ═══════════════════════════════ */
    

    .singlePost-article-title {
      font-family: 'Jost', sans-serif;
      font-weight: 600;
      font-size: clamp(1.3rem, 3vw, 1.75rem);
      letter-spacing: 0.03em;
      text-transform: uppercase;
      line-height: 1.2;
      margin-bottom: 0.75rem;
      color: var(--sp-text);
      opacity: 0;
      transform: translateY(16px);
      animation: sp-fadeUp 0.65s 0.1s ease forwards;
    }

    .singlePost-article-meta {
      font-size: 0.78rem;
      font-weight: 300;
      color: var(--sp-muted);
      margin-bottom: 1.25rem;
      opacity: 0;
      animation: sp-fadeUp 0.6s 0.2s ease forwards;
    }
    .singlePost-article-meta a {
      color: var(--sp-accent2);
      text-decoration: none;
    }

    /* intro block with inline image */
    .singlePost-intro {
      display: grid;
      grid-template-columns: 1fr 200px;
      gap: 1.25rem;
      align-items: start;
      margin-bottom: 1.25rem;
      opacity: 0;
      animation: sp-fadeUp 0.6s 0.28s ease forwards;
    }

    .singlePost-intro-text {
      font-size: 0.88rem;
      font-weight: 300;
      color: var(--sp-text);
      line-height: 1.7;
    }
    .singlePost-intro-text strong { font-weight: 500; }

    
    .singlePost-intro-img {
      width: 100%;
      aspect-ratio: 4/3;
      object-fit: cover;
      border-radius: 10px;
      display: block;
    }
    .singlePost-intro-img-placeholder {
      width: 100%;
      aspect-ratio: 4/3;
      border-radius: 10px;
      background: linear-gradient(135deg, #dce6dc, #b8ccb8);
      display: flex;
      align-items: center;
      justify-content: center;
      font-size: 2.5rem;
    }
    .singlePost-intro-caption {
      font-size: 0.7rem;
      font-weight: 300;
      color: var(--sp-muted);
      text-align: center;
      margin-top: 0.3rem;
      font-style: italic;
    }

    /* stat pill */
    .singlePost-stat-pill {
      display: inline-flex;
      align-items: center;
      gap: 0.4rem;
      border: 1.5px solid var(--sp-border);
      border-radius: 8px;
      padding: 0.55rem 1rem;
      font-size: 0.88rem;
      font-weight: 500;
      color: var(--sp-text);
      margin-bottom: 1.25rem;
      opacity: 0;
      animation: sp-fadeUp 0.6s 0.34s ease forwards;
    }

    /* body prose */
    .singlePost-prose {
      font-size: 0.87rem;
      font-weight: 300;
      color: var(--sp-muted);
      line-height: 1.75;
      margin-bottom: 1.75rem;
      opacity: 0;
      animation: sp-fadeUp 0.6s 0.4s ease forwards;
    }

    /* numbered sections */
    .singlePost-section {
      margin-bottom: 2rem;
      opacity: 0;
      transform: translateY(14px);
    }
    .singlePost-section:nth-of-type(1) { animation: sp-fadeUp 0.6s 0.48s ease forwards; }
    .singlePost-section:nth-of-type(2) { animation: sp-fadeUp 0.6s 0.56s ease forwards; }
    .singlePost-section:nth-of-type(3) { animation: sp-fadeUp 0.6s 0.64s ease forwards; }

    .singlePost-section-header {
      display: flex;
      align-items: center;
      gap: 0.65rem;
      margin-bottom: 0.75rem;
    }

    .singlePost-section-num {
      width: 28px;
      height: 28px;
      border-radius: 50%;
      background: var(--sp-accent);
      color: #fff;
      font-size: 0.8rem;
      font-weight: 500;
      display: flex;
      align-items: center;
      justify-content: center;
      flex-shrink: 0;
    }

    .singlePost-section-title {
      font-family: 'Cormorant Garamond', serif;
      font-weight: 400;
      font-size: clamp(1.1rem, 2.5vw, 1.45rem);
      color: var(--sp-text);
    }

    .singlePost-section-list {
      list-style: none;
      padding-left: 2.4rem;
      display: flex;
      flex-direction: column;
      gap: 0.35rem;
    }
    .singlePost-section-list li {
      font-size: 0.84rem;
      font-weight: 300;
      color: var(--sp-muted);
      line-height: 1.65;
      display: flex;
      gap: 0.5rem;
    }
    .singlePost-section-list li::before {
      content: '•';
      color: var(--sp-accent2);
      flex-shrink: 0;
    }

    /* section with side image */
    .singlePost-section-split {
      display: grid;
      grid-template-columns: 1fr 180px;
      gap: 1.25rem;
      align-items: start;
    }

    
    .singlePost-section-side-img {
      width: 100%;
      border-radius: 10px;
      display: block;
      aspect-ratio: 4/3;
      object-fit: cover;
    }
    .singlePost-section-side-img-placeholder {
      width: 100%;
      border-radius: 10px;
      aspect-ratio: 4/3;
      background: linear-gradient(135deg, #dce6dc, #b0c4b0);
      display: flex;
      align-items: center;
      justify-content: center;
      font-size: 2rem;
    }
    .singlePost-section-side-caption {
      font-size: 0.68rem;
      color: var(--sp-muted);
      font-style: italic;
      text-align: center;
      margin-top: 0.3rem;
    }

    /* highlight badge */
    .singlePost-highlight {
      background: var(--sp-surface);
      border-radius: 10px;
      padding: 0.9rem 1.25rem;
      font-size: 1rem;
      font-weight: 500;
      color: var(--sp-text);
      text-align: center;
      box-shadow: 0 2px 12px rgba(107,143,113,0.09);
      margin-top: 1rem;
    }

    /* ═══════════════════════════════
       RIGHT SIDEBAR
    ═══════════════════════════════ */
    .singlePost-sidebar {
      display: flex;
      flex-direction: column;
      gap: 1.25rem;
      position: sticky;
      top: 1.5rem;
    }

    /* author card */
    .singlePost-author {
      background: var(--sp-surface);
      border-radius: 12px;
      overflow: hidden;
      box-shadow: 0 2px 14px rgba(107,143,113,0.07);
    }

    .singlePost-author-photo {
      width: 100%;
      aspect-ratio: 4/3;
      object-fit: cover;
      display: block;
    }
    .singlePost-author-photo-placeholder {
      width: 100%;
      aspect-ratio: 4/3;
      background: linear-gradient(160deg, #c8d8c8, #a0b8a0);
      display: flex;
      align-items: center;
      justify-content: center;
      font-size: 3rem;
    }

    .singlePost-author-body {
      padding: 0.9rem 1rem 1rem;
    }
    .singlePost-author-name {
      font-family: 'Jost', sans-serif;
      font-weight: 500;
      font-size: 0.85rem;
      margin-bottom: 0.2rem;
    }
    .singlePost-author-bio {
      font-size: 0.75rem;
      font-weight: 300;
      color: var(--sp-muted);
      line-height: 1.55;
    }

    /* CTA card */
    .singlePost-cta-card {
      background: var(--sp-accent);
      border-radius: 12px;
      padding: 1.4rem 1.25rem;
      box-shadow: 0 2px 14px rgba(58,79,61,0.18);
      text-align: center;
    }
    .singlePost-cta-card-title {
      font-family: 'Jost', sans-serif;
      font-weight: 700;
      font-size: 0.88rem;
      letter-spacing: 0.1em;
      text-transform: uppercase;
      color: #fff;
      line-height: 1.3;
      margin-bottom: 1rem;
    }
    .singlePost-btn-light {
      display: inline-block;
      background: #fff;
      color: var(--sp-accent);
      border: none;
      border-radius: 6px;
      padding: 0.6rem 1.2rem;
      font-family: 'Jost', sans-serif;
      font-size: 0.8rem;
      font-weight: 500;
      letter-spacing: 0.03em;
      cursor: pointer;
      text-decoration: none;
      transition: background 0.2s, transform 0.2s;
    }
    .singlePost-btn-light:hover { background: #eef2ed; transform: translateY(-2px); }

    /* social share links */
    .singlePost-share {
      display: flex;
      gap: 0.6rem;
      align-items: center;
    }
    .singlePost-share a {
      width: 30px;
      height: 30px;
      border-radius: 50%;
      border: 1px solid var(--sp-border);
      display: flex;
      align-items: center;
      justify-content: center;
      font-size: 0.75rem;
      color: var(--sp-muted);
      text-decoration: none;
      transition: border-color 0.2s, color 0.2s;
    }
    .singlePost-share a:hover { border-color: var(--sp-accent2); color: var(--sp-accent); }
    .singlePost-share-label {
      font-size: 0.72rem;
      font-weight: 300;
      color: var(--sp-muted);
    }

    /* ═══════════════════════════════
       UP NEXT
    ═══════════════════════════════ */
    .singlePost-upnext {
      max-width: 1020px;
      margin: 0 auto;
      padding: 0 2rem 4rem;
    }

    .singlePost-upnext-title {
      font-family: 'Cormorant Garamond', serif;
      font-weight: 400;
      font-size: clamp(1.5rem, 3.5vw, 2.2rem);
      margin-bottom: 1.25rem;
    }

    .singlePost-upnext-grid {
      display: grid;
      grid-template-columns: repeat(3, 1fr);
      gap: 1.1rem;
    }

    .singlePost-upnext-card {
      background: var(--sp-surface);
      border-radius: 11px;
      overflow: hidden;
      box-shadow: 0 2px 14px rgba(107,143,113,0.07);
      text-decoration: none;
      color: var(--sp-text);
      transition: transform 0.22s, box-shadow 0.22s;
      display: block;
    }
    .singlePost-upnext-card:hover {
      transform: translateY(-3px);
      box-shadow: 0 8px 24px rgba(107,143,113,0.13);
    }

    .singlePost-upnext-img {
      width: 100%;
      aspect-ratio: 16/9;
      object-fit: cover;
      display: block;
    }
    .singlePost-upnext-img-placeholder {
      width: 100%;
      aspect-ratio: 16/9;
      background: linear-gradient(135deg, #dce6dc, #b8ccb8);
      display: flex;
      align-items: center;
      justify-content: center;
      font-size: 2rem;
    }

    .singlePost-upnext-body {
      padding: 0.9rem 1rem 1.1rem;
    }
    .singlePost-upnext-card-title {
      font-family: 'Jost', sans-serif;
      font-weight: 500;
      font-size: 0.88rem;
      line-height: 1.35;
      color: var(--sp-text);
    }

    /* ═══════════════════════════════
       FOOTER WAVE + LOGO
    ═══════════════════════════════ */
    .singlePost-footer {
      position: relative;
      padding: 1rem 2rem 3rem;
      text-align: center;
      overflow: hidden;
    }

    .singlePost-footer::before {
      content: '';
      position: absolute;
      top: 0; left: 0; right: 0;
      height: 70px;
      background: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 1200 70' preserveAspectRatio='none'%3E%3Cpath d='M0 35 Q300 70 600 20 Q900 0 1200 45 L1200 0 L0 0 Z' fill='%23a8b89e' opacity='0.22'/%3E%3C/svg%3E") center/cover no-repeat;
      pointer-events: none;
    }

    .singlePost-footer-inner {
      margin-top: 3rem;
      display: flex;
      align-items: center;
      justify-content: center;
      gap: 0.5rem;
    }
    .singlePost-footer-icon { font-size: 1.4rem; }
    .singlePost-footer-name {
      font-family: 'Jost', sans-serif;
      font-weight: 300;
      font-size: 0.9rem;
      letter-spacing: 0.05em;
    }

    /* ═══════════════════════════════
       ANIMATIONS
    ═══════════════════════════════ */
    @keyframes sp-fadeUp {
      to { opacity: 1; transform: translateY(0); }
    }

    /* ═══════════════════════════════
       RESPONSIVE
    ═══════════════════════════════ */
    @media (max-width: 860px) {
      .singlePost-layout {
        grid-template-columns: 1fr;
      }
      .singlePost-toc {
        position: static;
        display: flex;
        flex-wrap: wrap;
        gap: 0.5rem 1.5rem;
      }
      .singlePost-toc-title { width: 100%; margin-bottom: 0.25rem; }
      .singlePost-sidebar { position: static; flex-direction: row; flex-wrap: wrap; }
      .singlePost-author, .singlePost-cta-card { flex: 1 1 200px; }
      .singlePost-upnext-grid { grid-template-columns: repeat(2, 1fr); }
      .singlePost-intro { grid-template-columns: 1fr; }
      .singlePost-section-split { grid-template-columns: 1fr; }
    }

    @media (max-width: 520px) {
      .singlePost-nav-links { display: none; }
      .singlePost-upnext-grid { grid-template-columns: 1fr; }
    }


    























    .resumeNew {
  max-width: 860px;
  margin: 0 auto;
  padding: 3rem 1.5rem 4rem;
  position: relative;
}

.resumeNew::before,
.resumeNew::after {
  content: '';
  position: fixed;
  border-radius: 50%;
  pointer-events: none;
  z-index: 0;
}
.resumeNew::before {
  width: 500px; height: 400px;
  background: radial-gradient(ellipse, rgba(122,158,120,0.18) 0%, transparent 68%);
  top: -60px; left: -120px;
}
.resumeNew::after {
  width: 420px; height: 340px;
  background: radial-gradient(ellipse, rgba(122,158,120,0.14) 0%, transparent 68%);
  bottom: 100px; right: -100px;
}

.rn-header {
  position: relative;
  z-index: 1;
  text-align: center;
  margin-bottom: 3.5rem;
  animation: fadeDown 0.6s ease both;
}

.rn-header .shamrock {
  font-size: 2rem;
  margin-bottom: 0.5rem;
  display: block;
  animation: spin 8s linear infinite;
}

@keyframes spin {
  from { transform: rotate(0deg); }
  to   { transform: rotate(360deg); }
}

.rn-header h1 {
  font-family: 'Playfair Display', serif;
  font-size: clamp(1.8rem, 5vw, 2.8rem);
  font-weight: 700;
  letter-spacing: -0.03em;
  color: var(--ink);
  line-height: 1.1;
}

.rn-timeline {
  position: relative;
  z-index: 1;
}

.rn-timeline::before {
  content: '';
  position: absolute;
  left: 50%;
  top: 0; bottom: 0;
  width: 2px;
  background: linear-gradient(to bottom, var(--sage-light), var(--border));
  transform: translateX(-50%);
  z-index: 0;
}

.rn-entry {
  display: grid;
  grid-template-columns: 1fr 60px 1fr;
  gap: 0 1rem;
  margin-bottom: 4rem;
  position: relative;
  z-index: 1;
  animation: fadeUp 0.6s ease both;
}

.rn-entry:nth-child(1) { animation-delay: 0.1s; }
.rn-entry:nth-child(2) { animation-delay: 0.22s; }
.rn-entry:nth-child(3) { animation-delay: 0.34s; }

.rn-node {
  display: flex;
  align-items: flex-start;
  justify-content: center;
  padding-top: 0.2rem;
  position: relative;
  z-index: 2;
}

.rn-num {
  width: 38px; height: 38px;
  background: var(--num-bg);
  color: var(--white);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 0.85rem;
  font-weight: 500;
  flex-shrink: 0;
  box-shadow: 0 2px 12px rgba(0,0,0,0.18);
  border: 3px solid var(--cream);
}

.rn-media {
  display: flex;
  justify-content: flex-end;
  align-items: flex-start;
}

.rn-content {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
}

.rn-entry:nth-child(even) .rn-media   { order: 3; justify-content: flex-start; }
.rn-entry:nth-child(even) .rn-node    { order: 2; }
.rn-entry:nth-child(even) .rn-content { order: 1; align-items: flex-end; text-align: right; }
.rn-entry:nth-child(even) .rn-content ul li { padding-left: 0; padding-right: 0.9rem; }
.rn-entry:nth-child(even) .rn-content ul li::before { left: auto; right: 0; }
.rn-entry:nth-child(even) .rn-meta  { align-items: flex-end; }
.rn-entry:nth-child(even) .rn-tags  { justify-content: flex-end; }

.rn-img-card {
  width: 100%;
  max-width: 320px;
  border-radius: 12px;
  overflow: hidden;
  box-shadow: 0 4px 24px rgba(0,0,0,0.12), 0 1px 4px rgba(0,0,0,0.06);
  background: #c8cfd8;
  transition: transform 0.25s ease, box-shadow 0.25s ease;
}
.rn-img-card:hover {
  transform: translateY(-4px) rotate(0.5deg);
  box-shadow: 0 10px 36px rgba(0,0,0,0.16);
}
.rn-img-card img { width: 100%; display: block; height: auto; }

.rn-img-placeholder {
  width: 100%;
  aspect-ratio: 4/3;
  display: flex;
  align-items: center;
  justify-content: center;
  background: linear-gradient(135deg, #c8cfd8 0%, #b0bcc8 100%);
}
.rn-img-placeholder.green { background: linear-gradient(135deg, #b8ccb4 0%, #9ab898 100%); }
.rn-img-placeholder.warm  { background: linear-gradient(135deg, #ccc4b8 0%, #b8b0a4 100%); }
.rn-img-placeholder svg   { width: 55%; height: 55%; opacity: 0.3; }

.rn-eyebrow {
  font-size: 0.7rem;
  font-weight: 500;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--sage);
  margin-bottom: 0.3rem;
}

.rn-content h2 {
  font-family: 'Playfair Display', serif;
  font-size: clamp(1rem, 2.5vw, 1.35rem);
  font-weight: 700;
  color: var(--ink);
  line-height: 1.2;
  margin-bottom: 0.15rem;
  letter-spacing: -0.01em;
}

.rn-content h2 em {
  display: block;
  font-style: italic;
  font-weight: 400;
  color: var(--muted);
  font-size: 0.88em;
}

.rn-meta {
  display: flex;
  flex-direction: column;
  gap: 0.1rem;
  margin: 0.7rem 0 0.9rem;
}

.rn-role     { font-size: 0.78rem; font-weight: 500; color: var(--ink); text-transform: uppercase; letter-spacing: 0.06em; }
.rn-date     { font-size: 0.74rem; color: var(--light-muted); font-weight: 300; }
.rn-location { font-size: 0.74rem; color: var(--light-muted); font-weight: 300; font-style: italic; }

.rn-desc {
  font-size: 0.82rem;
  color: var(--muted);
  font-weight: 300;
  line-height: 1.65;
  margin-bottom: 0.8rem;
}

.rn-content ul {
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: 0.28rem;
  margin-bottom: 0.8rem;
}

.rn-content ul li {
  font-size: 0.8rem;
  color: var(--muted);
  font-weight: 300;
  line-height: 1.6;
  padding-left: 0.9rem;
  position: relative;
}

.rn-content ul li::before {
  content: '·';
  position: absolute;
  left: 0;
  color: var(--sage);
  font-size: 1rem;
  line-height: 1.5;
}

.rn-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 0.35rem;
  margin-top: 0.3rem;
}

.rn-tag {
  font-size: 0.68rem;
  font-weight: 400;
  background: var(--sage-pale);
  color: var(--sage);
  border-radius: 100px;
  padding: 0.2rem 0.65rem;
  letter-spacing: 0.04em;
  border: 1px solid var(--sage-light);
}

.rn-award {
  font-size: 0.74rem;
  color: var(--gold);
  font-style: italic;
  margin-top: 0.5rem;
}

.rn-proof {
  position: relative;
  z-index: 1;
  margin-top: 1rem;
  padding: 2.5rem;
  background: var(--white);
  border-radius: 16px;
  box-shadow: 0 4px 32px rgba(0,0,0,0.07);
  border: 1px solid var(--border);
  animation: fadeUp 0.6s 0.45s ease both;
}

.rn-proof-title {
  font-family: 'Playfair Display', serif;
  font-size: clamp(1rem, 3vw, 1.4rem);
  font-weight: 700;
  text-align: center;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: var(--ink);
  margin-bottom: 2rem;
}
.rn-proof-title::after {
  content: '';
  display: block;
  width: 50px; height: 2px;
  background: var(--sage);
  margin: 0.5rem auto 0;
  border-radius: 2px;
}

.rn-proof-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 2rem;
}

.rn-impact h3,
.rn-competencies h3 {
  font-family: 'Playfair Display', serif;
  font-size: 1rem;
  font-weight: 600;
  color: var(--ink);
  margin-bottom: 0.9rem;
}

.rn-table { width: 100%; border-collapse: collapse; font-size: 0.8rem; }
.rn-table tr { border-bottom: 1px solid var(--border); }
.rn-table tr:last-child { border-bottom: none; }
.rn-table td { padding: 0.5rem 0.4rem; vertical-align: top; }
.rn-table td:first-child { font-weight: 500; color: var(--ink); white-space: nowrap; padding-right: 1rem; width: 110px; }
.rn-table td:last-child  { color: var(--muted); font-weight: 300; }

.rn-comp-list { list-style: none; display: flex; flex-direction: column; gap: 0.35rem; }
.rn-comp-list li { font-size: 0.82rem; color: var(--muted); font-weight: 300; padding-left: 1rem; position: relative; }
.rn-comp-list li::before { content: '▸'; position: absolute; left: 0; color: var(--sage); font-size: 0.65rem; top: 0.15rem; }

@keyframes fadeUp   { from { opacity: 0; transform: translateY(18px); } to { opacity: 1; transform: translateY(0); } }
@keyframes fadeDown { from { opacity: 0; transform: translateY(-14px); } to { opacity: 1; transform: translateY(0); } }

@media (max-width: 640px) {
  .rn-timeline::before { left: 20px; }

  .rn-entry {
    grid-template-columns: 40px 1fr;
    grid-template-rows: auto auto;
    gap: 0.5rem 0.8rem;
  }

  .rn-node { padding-top: 0; }
  .rn-num  { width: 32px; height: 32px; font-size: 0.75rem; }

  .rn-media {
    grid-column: 1 / -1;
    justify-content: flex-start;
    order: 99 !important;
  }

  .rn-content {
    align-items: flex-start !important;
    text-align: left !important;
    order: 1 !important;
  }

  .rn-entry:nth-child(even) .rn-node { order: 1; }
  .rn-entry:nth-child(even) .rn-content ul li { padding-left: 0.9rem; padding-right: 0; }
  .rn-entry:nth-child(even) .rn-content ul li::before { left: 0; right: auto; }

  .rn-img-card { max-width: 100%; }
  .rn-proof { padding: 1.5rem 1.25rem; }
  .rn-proof-grid { grid-template-columns: 1fr; gap: 1.5rem; }
}

@media (max-width: 400px) {
  .resumeNew { padding: 2rem 1rem 3rem; }
}







/* --- Final Blog Grid Fix --- */

/* 1. Force the inner wrapper to be the grid */
.blogHome-grid-3 {
    display: grid !important;
    grid-template-columns: repeat(3, 1fr) !important;
    gap: 30px !important;
    margin-top: 40px;
    width: 100%;
}

/* 2. Fix the link item so it doesn't break the grid */
.blogHome-card-link {
    text-decoration: none !important;
    color: inherit !important;
    display: flex !important;
    flex-direction: column;
    height: 100%;
    background: #fff;
    border-radius: 12px;
    overflow: hidden;
    box-shadow: 0 4px 15px rgba(0,0,0,0.05);
    transition: transform 0.2s ease;
}

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

/* 3. Image Handling */
.blogHome-post-card .entryImage img {
    width: 100%;
    height: 180px;
    object-fit: cover;
    display: block;
}

/* 4. Text & Footer Layout */
.blogHome-post-card .entryText {
    padding: 20px;
    flex-grow: 1; /* Pushes footer to the bottom */
}

.blogHome-post-card .title {
    font-family: 'Jost', sans-serif;
    font-size: 1.1rem !important;
    font-weight: 500;
    margin: 10px 0;
    line-height: 1.3;
}

.blogHome-post-footer {
    padding: 0 20px 20px;
    display: flex;
    justify-content: space-between;
    align-items: center;
    font-size: 0.75rem;
    color: #6a6a6a;
}

.read-more-btn {
    color: #3a4f3d; /* Your Sage Green Accent */
    font-weight: 600;
    text-transform: uppercase;
}

/* Responsive */
@media (max-width: 900px) {
    .blogHome-grid-3 { grid-template-columns: repeat(2, 1fr) !important; }
}
@media (max-width: 600px) {
    .blogHome-grid-3 { grid-template-columns: 1fr !important; }
}


/* --- BLOG GRID SANDBOX --- */

/* Force the container to behave */
#spo-blog-sandbox {
    padding: 40px 0 !important;
    display: block !important;
    width: 1220px !important; /* Matches your site's container width */
}

/* The Grid Wrapper */
.blog-grid-container {
    display: grid !important;
    grid-template-columns: repeat(3, 1fr) !important;
    gap: 30px !important;
    width: 100% !important;
}

/* Individual Card Styling */
.blog-card-item {
    background: #fff !important;
    border-radius: 12px !important;
    overflow: hidden !important;
    box-shadow: 0 4px 20px rgba(0,0,0,0.08) !important;
    display: flex !important;
    flex-direction: column !important;
    width: auto !important; /* Prevents stretching */
    margin-bottom: 0 !important; /* Removes legacy article margins */
}

.blog-card-link {
    text-decoration: none !important;
    color: inherit !important;
    display: flex !important;
    flex-direction: column !important;
    height: 100% !important;
}

.blog-card-image img {
    width: 100% !important;
    height: 190px !important;
    object-fit: cover !important;
    display: block !important;
}

.blog-card-content {
    padding: 22px !important;
    display: flex !important;
    flex-direction: column !important;
    flex-grow: 1 !important;
}

.blog-card-cat {
    font-size: 11px !important;
    text-transform: uppercase !important;
    color: #6b8f71 !important; /* Sage green */
    letter-spacing: 1px !important;
    font-weight: 600 !important;
}

.blog-card-title {
    font-family: 'Jost', sans-serif !important;
    font-size: 19px !important;
    margin: 10px 0 !important;
    line-height: 1.3 !important;
    color: #2c2c2c !important;
}

.blog-card-excerpt {
    font-size: 14px !important;
    color: #6a6a6a !important;
    line-height: 1.6 !important;
    margin-bottom: 20px !important;
}

.blog-card-footer {
    margin-top: auto !important;
    display: flex !important;
    justify-content: space-between !important;
    align-items: center !important;
    font-size: 12px !important;
}

.blog-card-more {
    font-weight: 600 !important;
    color: #3a4f3d !important;
}

/* Responsive Fixes */
@media (max-width: 1200px) {
    #spo-blog-sandbox { width: 95% !important; }
}

@media (max-width: 900px) {
    .blog-grid-container { grid-template-columns: repeat(2, 1fr) !important; }
}

@media (max-width: 600px) {
    .blog-grid-container { grid-template-columns: 1fr !important; }
}























    /* ============================================================
       BLOG POST — CONCEPT 3: MINIMAL EDITORIAL
       All classes prefixed with .blogPostNew to avoid CSS conflicts
       ============================================================ */
 
    /* ── Variables ──────────────────────────────────────────────── */
    .blogPostNew,
    .blogPostNew * {
      box-sizing: border-box;
    }
 
    .blogPostNew {
      --bpn-green:        #2d4a2d;
      --bpn-green-mid:    #3d5c3a;
      --bpn-green-light:  #c8d8c0;
      --bpn-green-pale:   #e8efe4;
      --bpn-linen:        #f0ede6;
      --bpn-linen-dark:   #e2ddd4;
      --bpn-linen-mid:    #d4cfc6;
      --bpn-text:         #1a1a18;
      --bpn-muted:        #5a5852;
      --bpn-accent:       #6b8f4e;
      --bpn-white:        #ffffff;
 
      --bpn-font-serif:   'Lora', Georgia, serif;
      --bpn-font-sans:    'DM Sans', system-ui, sans-serif;
 
      --bpn-max-width:    680px;
      --bpn-wide-width:   860px;
 
      background-color: var(--bpn-linen);
      color: var(--bpn-text);
      font-family: var(--bpn-font-sans);
      font-size: 16px;
      line-height: 1.6;
      -webkit-font-smoothing: antialiased;
    }
 
 
    /* ── Top Meta Bar (breadcrumbs + reading time) ──────────────── */
    .blogPostNew__topBar {
      display: flex;
      justify-content: space-between;
      align-items: center;
      padding: 10px 24px;
      border-bottom: 1px solid var(--bpn-linen-dark);
      background: var(--bpn-linen);
    }
 
    .blogPostNew__breadcrumb {
      display: flex;
      align-items: center;
      gap: 6px;
      font-size: 12px;
      color: var(--bpn-muted);
      flex-wrap: wrap;
    }
 
    .blogPostNew__breadcrumb a {
      color: var(--bpn-muted);
      text-decoration: none;
      transition: color 0.15s;
    }
 
    .blogPostNew__breadcrumb a:hover {
      color: var(--bpn-green);
    }
 
    .blogPostNew__breadcrumb-sep {
      color: var(--bpn-green-light);
      font-size: 11px;
    }
 
    .blogPostNew__breadcrumb-current {
      color: var(--bpn-green);
      font-weight: 500;
    }
 
    .blogPostNew__readingTime {
      font-size: 12px;
      color: var(--bpn-accent);
      font-weight: 500;
      white-space: nowrap;
      display: flex;
      align-items: center;
      gap: 5px;
    }
 
    .blogPostNew__readingTime svg {
      width: 13px;
      height: 13px;
      opacity: 0.75;
    }
 
 
    /* ── Hero / Post Header ─────────────────────────────────────── */
    .blogPostNew__hero {
      max-width: var(--bpn-max-width);
      margin: 0 auto;
      padding: 52px 24px 0;
      text-align: center;
    }
 
    .blogPostNew__categories {
      display: flex;
      gap: 0;
      justify-content: center;
      flex-wrap: wrap;
      margin-bottom: 18px;
    }
 
    .blogPostNew__category {
      font-size: 11px;
      text-transform: uppercase;
      letter-spacing: 0.08em;
      color: var(--bpn-accent);
      font-weight: 500;
      font-family: var(--bpn-font-sans);
      text-decoration: none;
      transition: color 0.15s;
    }
 
    .blogPostNew__category:hover {
      color: var(--bpn-green);
    }
 
    .blogPostNew__category + .blogPostNew__category::before {
      content: '·';
      margin: 0 10px;
      color: var(--bpn-green-light);
      font-weight: 400;
    }
 
    .blogPostNew__title {
      font-family: var(--bpn-font-serif);
      font-size: clamp(26px, 4vw, 36px);
      font-weight: 500;
      color: var(--bpn-text);
      line-height: 1.2;
      margin: 0 0 20px;
      letter-spacing: -0.01em;
    }
 
    .blogPostNew__byline {
      font-size: 13px;
      color: var(--bpn-muted);
      display: flex;
      align-items: center;
      justify-content: center;
      gap: 8px;
      flex-wrap: wrap;
    }
 
    .blogPostNew__byline-sep {
      color: var(--bpn-green-light);
    }
 
    .blogPostNew__byline a {
      color: var(--bpn-green);
      text-decoration: none;
      font-weight: 500;
    }
 
    .blogPostNew__byline a:hover {
      text-decoration: underline;
    }
 
 
    /* ── Ornament Divider ───────────────────────────────────────── */
    .blogPostNew__ornament {
      text-align: center;
      padding: 28px 0 16px;
      color: var(--bpn-green-light);
      letter-spacing: 10px;
      font-size: 14px;
      user-select: none;
    }
 
 
    /* ── Body Content ───────────────────────────────────────────── */
    .blogPostNew__body {
      max-width: var(--bpn-max-width);
      margin: 0 auto;
      padding: 0 24px 48px;
    }
 
    .blogPostNew__p {
      font-size: 16px;
      line-height: 1.85;
      color: var(--bpn-text);
      margin: 0 0 24px;
      font-weight: 300;
    }
 
    /* Drop cap on first paragraph */
    .blogPostNew__p--dropCap::first-letter {
      font-family: var(--bpn-font-serif);
      font-size: 62px;
      font-weight: 500;
      float: left;
      line-height: 0.78;
      margin: 8px 6px 0 0;
      color: var(--bpn-green);
    }
 
 
    /* ── Pull Quote ─────────────────────────────────────────────── */
    .blogPostNew__pullquote {
      text-align: center;
      padding: 8px 24px;
      margin: 36px 0;
      position: relative;
    }
 
    .blogPostNew__pullquote::before,
    .blogPostNew__pullquote::after {
      content: '';
      display: block;
      height: 1px;
      background: var(--bpn-green-light);
      margin: 16px 0;
    }
 
    .blogPostNew__pullquote p {
      font-family: var(--bpn-font-serif);
      font-size: 20px;
      font-style: italic;
      color: var(--bpn-green);
      line-height: 1.5;
      margin: 0;
    }
 
    .blogPostNew__pullquote cite {
      display: block;
      margin-top: 10px;
      font-size: 12px;
      font-style: normal;
      color: var(--bpn-accent);
      font-weight: 500;
      letter-spacing: 0.03em;
    }
 
 
    /* ── Tip / Note / Warning Boxes ─────────────────────────────── */
    .blogPostNew__callout {
      display: flex;
      gap: 16px;
      background: var(--bpn-white);
      border-radius: 8px;
      padding: 16px 20px;
      margin: 28px 0;
      border: 1px solid var(--bpn-linen-dark);
      align-items: flex-start;
    }
 
    .blogPostNew__callout--tip {
      border-left: 3px solid var(--bpn-accent);
    }
 
    .blogPostNew__callout--warning {
      border-left: 3px solid #c8893a;
      background: #fdf8f2;
    }
 
    .blogPostNew__callout--note {
      border-left: 3px solid var(--bpn-green);
      background: var(--bpn-green-pale);
    }
 
    .blogPostNew__callout-icon {
      width: 30px;
      height: 30px;
      border-radius: 6px;
      display: flex;
      align-items: center;
      justify-content: center;
      font-size: 14px;
      flex-shrink: 0;
      margin-top: 1px;
    }
 
    .blogPostNew__callout--tip .blogPostNew__callout-icon {
      background: var(--bpn-green-pale);
    }
 
    .blogPostNew__callout--warning .blogPostNew__callout-icon {
      background: #faebd6;
    }
 
    .blogPostNew__callout--note .blogPostNew__callout-icon {
      background: var(--bpn-green-light);
    }
 
    .blogPostNew__callout-content {
      flex: 1;
    }
 
    .blogPostNew__callout-label {
      font-size: 11px;
      font-weight: 500;
      text-transform: uppercase;
      letter-spacing: 0.07em;
      margin-bottom: 5px;
    }
 
    .blogPostNew__callout--tip .blogPostNew__callout-label    { color: var(--bpn-accent); }
    .blogPostNew__callout--warning .blogPostNew__callout-label { color: #a06828; }
    .blogPostNew__callout--note .blogPostNew__callout-label   { color: var(--bpn-green); }
 
    .blogPostNew__callout-content p {
      font-size: 14px;
      color: var(--bpn-text);
      line-height: 1.65;
      margin: 0;
      font-weight: 300;
    }
 
 
    /* ── Inline Boxes (left / right / full) ─────────────────────── */
    .blogPostNew__box {
      background: var(--bpn-linen-dark);
      border: 1px solid var(--bpn-linen-mid);
      border-radius: 8px;
      padding: 16px 20px;
      margin: 24px 0;
    }
 
    .blogPostNew__box--left {
      float: left;
      width: 45%;
      margin: 4px 24px 16px 0;
    }
 
    .blogPostNew__box--right {
      float: right;
      width: 45%;
      margin: 4px 0 16px 24px;
    }
 
    .blogPostNew__box--full {
      background: var(--bpn-green);
      border-color: transparent;
      float: none;
      width: 100%;
      margin: 32px 0;
    }
 
    .blogPostNew__box h4 {
      font-family: var(--bpn-font-sans);
      font-size: 13px;
      font-weight: 500;
      margin: 0 0 8px;
      color: var(--bpn-text);
    }
 
    .blogPostNew__box--full h4 {
      color: #fff;
    }
 
    .blogPostNew__box p {
      font-size: 13px;
      color: var(--bpn-muted);
      line-height: 1.6;
      margin: 0;
      font-weight: 300;
    }
 
    .blogPostNew__box--full p {
      color: rgba(255, 255, 255, 0.78);
    }
 
    .blogPostNew__clearfix::after {
      content: '';
      display: table;
      clear: both;
    }
 
 
    /* ── Tutorial Step Boxes ────────────────────────────────────── */
    .blogPostNew__step {
      margin: 28px 0 4px;
    }
 
    .blogPostNew__step-header {
      background: var(--bpn-green);
      color: #e8efe4;
      border-radius: 8px 8px 0 0;
      padding: 12px 18px;
      display: flex;
      align-items: center;
      gap: 12px;
    }
 
    .blogPostNew__step-num {
      background: rgba(255, 255, 255, 0.2);
      color: #fff;
      font-size: 13px;
      font-weight: 500;
      width: 28px;
      height: 28px;
      border-radius: 50%;
      display: flex;
      align-items: center;
      justify-content: center;
      flex-shrink: 0;
      font-family: var(--bpn-font-sans);
    }
 
    .blogPostNew__step-title {
      font-size: 15px;
      font-weight: 500;
      font-family: var(--bpn-font-sans);
    }
 
    .blogPostNew__step-body {
      background: var(--bpn-white);
      border: 1px solid var(--bpn-green-light);
      border-top: none;
      border-radius: 0 0 8px 8px;
      padding: 16px 18px;
    }
 
    .blogPostNew__step-body p {
      font-size: 14px;
      line-height: 1.7;
      color: var(--bpn-text);
      margin: 0;
      font-weight: 300;
    }
 
 
    /* ── Photo Gallery ──────────────────────────────────────────── */
    .blogPostNew__gallery {
      margin: 32px 0;
    }
 
    .blogPostNew__gallery-grid {
      display: grid;
      grid-template-columns: 2fr 1fr;
      gap: 6px;
    }
 
    .blogPostNew__gallery-grid--3up {
      grid-template-columns: repeat(3, 1fr);
    }
 
    .blogPostNew__gallery-col {
      display: flex;
      flex-direction: column;
      gap: 6px;
    }
 
    .blogPostNew__gallery-thumb {
      background: var(--bpn-linen-dark);
      border-radius: 6px;
      overflow: hidden;
      position: relative;
      cursor: pointer;
      display: block;
    }
 
    /* Placeholder aspect ratios — replace with actual <img> tags */
    .blogPostNew__gallery-thumb--large  { aspect-ratio: 16/10; }
    .blogPostNew__gallery-thumb--medium { aspect-ratio: 4/3; }
    .blogPostNew__gallery-thumb--square { aspect-ratio: 1/1; }
 
    .blogPostNew__gallery-thumb img {
      width: 100%;
      height: 100%;
      object-fit: cover;
      display: block;
      transition: transform 0.3s ease;
    }
 
    /* Placeholder swatch when no image is present */
    .blogPostNew__gallery-thumb:not(:has(img))::before {
      content: '';
      display: block;
      width: 100%;
      height: 100%;
      min-height: 120px;
      background: var(--bpn-green-pale);
    }
 
    .blogPostNew__gallery-thumb:hover img {
      transform: scale(1.03);
    }
 
    .blogPostNew__gallery-overlay {
      position: absolute;
      inset: 0;
      background: rgba(45, 74, 45, 0.45);
      display: flex;
      align-items: center;
      justify-content: center;
      opacity: 0;
      transition: opacity 0.2s ease;
    }
 
    .blogPostNew__gallery-thumb:hover .blogPostNew__gallery-overlay {
      opacity: 1;
    }
 
    .blogPostNew__gallery-overlay-icon {
      width: 36px;
      height: 36px;
      border: 1.5px solid rgba(255, 255, 255, 0.85);
      border-radius: 50%;
      display: flex;
      align-items: center;
      justify-content: center;
      color: #fff;
      font-size: 18px;
      line-height: 1;
    }
 
    .blogPostNew__gallery-caption {
      font-size: 12px;
      color: var(--bpn-muted);
      text-align: center;
      margin-top: 10px;
      font-style: italic;
    }
 
    /* ── Lightbox ───────────────────────────────────────────────── */
    .blogPostNew__lightbox {
      position: fixed;
      inset: 0;
      background: rgba(18, 18, 16, 0.92);
      z-index: 9999;
      display: flex;
      align-items: center;
      justify-content: center;
      padding: 24px;
      opacity: 0;
      pointer-events: none;
      transition: opacity 0.2s ease;
    }
 
    .blogPostNew__lightbox.is-open {
      opacity: 1;
      pointer-events: all;
    }
 
    .blogPostNew__lightbox-inner {
      position: relative;
      max-width: 900px;
      width: 100%;
    }
 
    .blogPostNew__lightbox-inner img {
      width: 100%;
      border-radius: 4px;
      display: block;
    }
 
    /* Placeholder for lightbox when no real image */
    .blogPostNew__lightbox-inner .blogPostNew__lightbox-placeholder {
      width: 100%;
      aspect-ratio: 16/9;
      background: var(--bpn-green-pale);
      border-radius: 4px;
      display: flex;
      align-items: center;
      justify-content: center;
      color: var(--bpn-green);
      font-size: 14px;
    }
 
    .blogPostNew__lightbox-caption {
      color: rgba(255, 255, 255, 0.65);
      font-size: 13px;
      text-align: center;
      margin-top: 12px;
    }
 
    .blogPostNew__lightbox-close {
      position: absolute;
      top: -16px;
      right: -16px;
      width: 32px;
      height: 32px;
      background: rgba(255, 255, 255, 0.15);
      border: 1px solid rgba(255, 255, 255, 0.25);
      border-radius: 50%;
      color: #fff;
      font-size: 16px;
      cursor: pointer;
      display: flex;
      align-items: center;
      justify-content: center;
      line-height: 1;
      transition: background 0.15s;
    }
 
    .blogPostNew__lightbox-close:hover {
      background: rgba(255, 255, 255, 0.28);
    }
 
    .blogPostNew__lightbox-nav {
      position: absolute;
      top: 50%;
      transform: translateY(-50%);
      width: 36px;
      height: 36px;
      background: rgba(255, 255, 255, 0.12);
      border: 1px solid rgba(255, 255, 255, 0.2);
      border-radius: 50%;
      color: #fff;
      font-size: 16px;
      cursor: pointer;
      display: flex;
      align-items: center;
      justify-content: center;
      transition: background 0.15s;
    }
 
    .blogPostNew__lightbox-nav:hover {
      background: rgba(255, 255, 255, 0.25);
    }
 
    .blogPostNew__lightbox-nav--prev { left: -52px; }
    .blogPostNew__lightbox-nav--next { right: -52px; }
 
 
    /* ── Pagination ─────────────────────────────────────────────── */
    .blogPostNew__pagination {
      display: flex;
      justify-content: center;
      align-items: center;
      gap: 4px;
      padding: 28px 0 8px;
      border-top: 1px solid var(--bpn-linen-dark);
      margin-top: 32px;
    }
 
    .blogPostNew__page-btn {
      display: flex;
      align-items: center;
      justify-content: center;
      min-width: 34px;
      height: 34px;
      padding: 0 8px;
      border-radius: 5px;
      border: 1px solid var(--bpn-linen-mid);
      background: var(--bpn-white);
      color: var(--bpn-muted);
      font-size: 13px;
      font-family: var(--bpn-font-sans);
      cursor: pointer;
      text-decoration: none;
      transition: background 0.15s, border-color 0.15s, color 0.15s;
    }
 
    .blogPostNew__page-btn:hover:not(.is-active) {
      background: var(--bpn-green-pale);
      border-color: var(--bpn-green-light);
      color: var(--bpn-green);
    }
 
    .blogPostNew__page-btn.is-active {
      background: var(--bpn-green);
      border-color: var(--bpn-green);
      color: #e8efe4;
      font-weight: 500;
    }
 
    .blogPostNew__page-btn--arrow {
      font-size: 15px;
      color: var(--bpn-green);
      border-color: var(--bpn-green-light);
    }
 
    .blogPostNew__page-btn--arrow:hover {
      background: var(--bpn-green-pale);
    }
 
    .blogPostNew__page-ellipsis {
      font-size: 13px;
      color: var(--bpn-muted);
      padding: 0 4px;
    }
 
 
    /* ── Responsive ─────────────────────────────────────────────── */
    @media (max-width: 600px) {
      .blogPostNew__topBar {
        flex-direction: column;
        align-items: flex-start;
        gap: 6px;
        padding: 10px 16px;
      }
 
      .blogPostNew__hero {
        padding: 36px 16px 0;
      }
 
      .blogPostNew__body {
        padding: 0 16px 40px;
      }
 
      .blogPostNew__box--left,
      .blogPostNew__box--right {
        float: none;
        width: 100%;
        margin: 0 0 16px;
      }
 
      .blogPostNew__gallery-grid {
        grid-template-columns: 1fr;
      }
 
      .blogPostNew__gallery-col {
        flex-direction: row;
      }
 
      .blogPostNew__lightbox-nav--prev { left: -8px; }
      .blogPostNew__lightbox-nav--next { right: -8px; }
    }



    /* ============================================================
   BLOG POST NEW — SCOPED RESETS
   Neutralises theme globals inside .blogPostNew only.
   Does NOT affect any other part of the site.
   ============================================================ */

.blogPostNew p {
  font-family: 'DM Sans', system-ui, sans-serif;
  font-size: 15.5px;
  line-height: 1.85;
  margin-bottom: 22px;
  font-weight: 300;
  color: #1a1a18;
}

.blogPostNew h1,
.blogPostNew h2,
.blogPostNew h3,
.blogPostNew h4,
.blogPostNew h5,
.blogPostNew h6 {
  font-family: 'DM Sans', system-ui, sans-serif;
  font-weight: 500;
  line-height: 1.2;
  margin-bottom: 0;
  text-align: left;
}

.blogPostNew a {
  color: #5a5852;
  font-weight: 400;
  text-decoration: none;
  transition: color 0.15s;
}

.blogPostNew a:hover {
  color: #2d4a2d;
  transition: color 0.15s;
}

.blogPostNew aside {
  background: none;
  border: 1px solid #d4cfc6;
  border-radius: 8px;
  padding: 16px 18px;
  font-size: inherit;
  line-height: inherit;
  font-family: 'DM Sans', system-ui, sans-serif;
  margin: 22px 0;
  width: auto;
}

.blogPostNew aside h3 {
  text-align: left;
  font-size: 13px;
  font-weight: 500;
  margin-bottom: 7px;
  border-bottom: none;
}

.blogPostNew aside.blogPostNew__box--left,
.blogPostNew aside.blogPostNew__box--right {
  box-shadow: none;
}

.blogPostNew strong,
.blogPostNew b {
  font-weight: 600;
}

.blogPostNew hr {
  margin: 0;
  border: none;
  width: 100%;
}

.blogPostNew ul,
.blogPostNew ol {
  margin-left: 0;
  font-size: inherit;
  font-family: 'DM Sans', system-ui, sans-serif;
}

.blogPostNew blockquote {
  margin: 0;
  padding: 0;
  border: none;
  background: none;
}

.blogPostNew__category {
  color: #6b8f4e !important;
  font-weight: 500 !important;
}

.blogPostNew__breadcrumb a {
  color: #5a5852 !important;
  font-weight: 400 !important;
}

.blogPostNew__breadcrumb-current {
  color: #2d4a2d !important;
}

.blogPostNew__byline a {
  color: #2d4a2d !important;
  font-weight: 500 !important;
}

.blogPostNew__title {
  font-family: 'Lora', Georgia, serif !important;
  font-size: clamp(24px, 4vw, 34px) !important;
  font-weight: 500 !important;
  text-align: center !important;
  line-height: 1.22 !important;
  color: #1a1a18 !important;
}

.blogPostNew__pullquote p {
  font-family: 'Lora', Georgia, serif !important;
  font-size: 19px !important;
  font-style: italic !important;
  font-weight: 400 !important;
  color: #2d4a2d !important;
  line-height: 1.5 !important;
  margin: 0 !important;
  text-align: center !important;
}

.blogPostNew__callout-content p {
  font-size: 14px !important;
  line-height: 1.65 !important;
  font-weight: 300 !important;
  margin: 0 !important;
}

.blogPostNew__box h4 {
  font-size: 13px !important;
  font-weight: 500 !important;
  color: #1a1a18 !important;
  margin: 0 0 7px !important;
  font-family: 'DM Sans', system-ui, sans-serif !important;
}

.blogPostNew__box--full h4 {
  color: #ffffff !important;
}

.blogPostNew__box p {
  font-size: 13px !important;
  color: #5a5852 !important;
  line-height: 1.6 !important;
  margin: 0 !important;
  font-weight: 300 !important;
}

.blogPostNew__box--full p {
  color: rgba(255,255,255,0.78) !important;
}

.blogPostNew__step-body p {
  font-size: 14px !important;
  line-height: 1.7 !important;
  font-weight: 300 !important;
  margin: 0 !important;
  color: #1a1a18 !important;
}























/* ============================================================
   WEBSITE SHOWCASE — Single Post Template Styles  v2
   seanpatrickoleary.com — paste at bottom of style.css
   ============================================================
   All rules scoped to #blogPost so nothing leaks to rest of site.

   Palette:
   --sc-cream:       #f0ece3   page background
   --sc-green-dark:  #2b3d2b   hero, siteDetails band, headings
   --sc-green-mid:   #4a6741   accents, borders, hover
   --sc-green-pale:  #e8efe6   icon badge bg, tinted surfaces
   --sc-text:        #1e1e1e   body copy (dark-on-light)
   --sc-muted:       #5a5a5a   secondary copy
   --sc-rule:        #d4cfc6   divider lines
   --sc-cream-light: #f0ece3   hero text / light-on-dark copy
   ============================================================ */


/* ─────────────────────────────────────────────────────────────
   0. SCOPED RESET — neutralise theme globals inside #blogPost
───────────────────────────────────────────────────────────── */

#blogPost *,
#blogPost *::before,
#blogPost *::after {
    box-sizing: border-box;
}

#blogPost h1,
#blogPost h2,
#blogPost h3,
#blogPost h4 {
    font-weight: 400;
    margin: 0;
    padding: 0;
    line-height: 1.2;
}

/* Body-copy p reset */
#blogPost p {
    margin: 0 0 1.1em;
    line-height: 1.75;
    font-weight: 400;
    font-size: 1rem;
}

/* Link reset */
#blogPost a {
    text-decoration: underline;
    text-underline-offset: 3px;
}

#blogPost ul,
#blogPost ol {
    list-style: none;
    margin: 0;
    padding: 0;
}

#blogPost hr {
    border: none;
    border-top: 1px solid #d4cfc6;
    margin: 1.5rem 0;
}

/* Prevent theme 'aside' rules bleeding in */
#blogPost aside {
    all: unset;
}


/* ─────────────────────────────────────────────────────────────
   1. PAGE SHELL
───────────────────────────────────────────────────────────── */

.sidePage {
    background-color: #f0ece3;
}

#blogPost {
    background-color: #f0ece3;
    max-width: 100%;
    overflow-x: hidden;
    font-family: inherit;
}


/* ─────────────────────────────────────────────────────────────
   2. BREADCRUMBS
───────────────────────────────────────────────────────────── */

#blogPost .breadcrumbs {
    max-width: 860px;
    margin: 0 auto;
    padding: 1.25rem 2rem 0;
    font-size: 0.75rem;
    letter-spacing: 0.04em;
    color: #5a5a5a;
}

#blogPost .breadcrumbs a {
    color: #4a6741;
    text-decoration: none;
    font-weight: 600;
}

#blogPost .breadcrumbs a:hover {
    text-decoration: underline;
}

/* Yoast / BCN separator */
#blogPost .breadcrumbs span[typeof="li"]::after,
#blogPost .breadcrumbs .breadcrumb_last {
    color: #5a5a5a;
}


/* ─────────────────────────────────────────────────────────────
   3. HERO — dark green band
───────────────────────────────────────────────────────────── */

#blogPost .blogTitle {
    background-color: #2b3d2b;
    padding-bottom: 3.5rem;
    position: relative;
}

/* Category pill(s) */
#blogPost .blogCategories {
    max-width: 860px;
    margin: 0 auto;
    padding: 2rem 2rem 0;
}

#blogPost .blogCategories a {
    display: inline-block;
    font-size: 0.68rem;
    font-weight: 700;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: #c8d8c4;
    text-decoration: none;
    border: 1px solid rgba(200,216,196,0.35);
    padding: 0.28em 0.9em;
    border-radius: 2px;
    margin: 0 0.35rem 0.35rem 0;
    transition: background 0.2s, color 0.2s;
}

#blogPost .blogCategories a:hover {
    background: rgba(200,216,196,0.12);
    color: #e8efe6;
}

/* Inner title wrapper */
#blogPost .titleDiv {
    max-width: 860px;
    margin: 0 auto;
    padding: 1.5rem 2rem 0;
}

/* Hero showcase graphic */
#blogPost .blogShowcase {
    width: 100%;
    margin-bottom: 2rem;
    border-radius: 5px;
    overflow: hidden;
    box-shadow: 0 10px 40px rgba(0,0,0,0.45);
}

#blogPost .blogShowcase img {
    width: 100%;
    height: auto;
    display: block;
    vertical-align: bottom;
}

/* Client logo */
#blogPost .showcaseLogo {
    margin-bottom: 1.1rem;
}

#blogPost .showcaseLogo img {
    max-height: 56px;
    width: auto;
    display: block;
    filter: brightness(0) invert(1);
    opacity: 0.8;
}

/* H1 */
#blogPost .blogTitle h1 {
    font-family: Georgia, 'Times New Roman', serif;
    font-size: clamp(1.75rem, 3.5vw, 2.6rem);
    font-weight: 400;
    color: #f0ece3;
    line-height: 1.2;
    letter-spacing: -0.01em;
    margin-bottom: 0.9rem;
}

/* Intro text */
#blogPost .postIntro {
    margin-bottom: 1.4rem;
}

#blogPost .postIntro p,
#blogPost .postIntro {
    font-size: 1rem;
    line-height: 1.72;
    color: rgba(232,239,230,0.82);
    margin: 0;
}

/* Date + share bar */
#blogPost .introBottom {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 1.25rem;
    margin-top: 1.5rem;
    padding-top: 1.1rem;
    border-top: 1px solid rgba(200,216,196,0.2);
}

#blogPost .introBottom p {
    font-size: 0.75rem;
    letter-spacing: 0.07em;
    text-transform: uppercase;
    color: rgba(232,239,230,0.5);
    margin: 0;
}

#blogPost .introBottom p span {
    color: rgba(232,239,230,0.35);
    font-weight: 700;
}

#blogPost .shareButtons {
    margin-left: auto;
}

/* Share button icon colour fix on dark bg */
#blogPost .shareButtons a,
#blogPost .shareButtons svg {
    color: rgba(232,239,230,0.6) !important;
    fill: rgba(232,239,230,0.6) !important;
}


/* ─────────────────────────────────────────────────────────────
   4. MAIN CONTENT AREA
───────────────────────────────────────────────────────────── */

#blogPost .blogPostMain {
    background-color: #f0ece3;
}

/* Generic inner container used for overview + after-launch */
#blogPost .blogPostMain .container {
    max-width: 860px;
    margin: 0 auto;
    padding: 3.5rem 2rem;
}


/* ─────────────────────────────────────────────────────────────
   5. SECTION HEADING — shared style (light sections)
───────────────────────────────────────────────────────────── */

/* Used in webShowIntro and after-launch */
#blogPost .webShowIntro h2,
#blogPost .blogPostMain .container section > h2,
#blogPost .siteDescription h2 {
    font-family: Georgia, 'Times New Roman', serif;
    font-size: 1.6rem;
    font-weight: 400;
    color: #2b3d2b;
    text-align: center;
    letter-spacing: -0.01em;
    margin-bottom: 0;
}

/* Green rule under each heading */
#blogPost .webShowIntro h2::after,
#blogPost .blogPostMain .container section > h2::after,
#blogPost .siteDescription h2::after {
    content: '';
    display: block;
    width: 44px;
    height: 2px;
    background-color: #4a6741;
    margin: 0.7rem auto 0;
}


/* ─────────────────────────────────────────────────────────────
   6. WEBSITE OVERVIEW
───────────────────────────────────────────────────────────── */

#blogPost .webShowIntro {
    padding: 3.5rem 2rem 2rem;
    max-width: 860px;
    margin: 0 auto;
    text-align: center;
}

/* Icon badge grid */
#blogPost .keyFeatures {
    margin: 2.25rem 0 2rem;
}

#blogPost .keyFeatures ul {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 1rem 1.1rem;
}

#blogPost .keyFeatures ul li {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 0.45rem;
    width: 88px;
    text-align: center;
}

#blogPost .keyFeatures .statIcon {
    width: 54px;
    height: 54px;
    border-radius: 50%;
    background-color: #e8efe6;
    border: 1px solid #c8d8c4;
    display: flex;
    align-items: center;
    justify-content: center;
    color: #2b3d2b;
    font-size: 1.15rem;
    transition: background 0.2s, color 0.2s, transform 0.2s;
}

#blogPost .keyFeatures ul li:hover .statIcon {
    background-color: #2b3d2b;
    color: #e8efe6;
    transform: translateY(-2px);
}

#blogPost .keyFeatures h4 {
    font-size: 0.64rem;
    font-weight: 700;
    letter-spacing: 0.05em;
    text-transform: uppercase;
    color: #5a5a5a;
    line-height: 1.3;
}

/* Overview body text */
#blogPost .webShowIntro > div:last-of-type {
    text-align: left;
    max-width: 680px;
    margin: 0 auto;
}

#blogPost .webShowIntro > div:last-of-type p {
    color: #1e1e1e;
    font-size: 1rem;
    line-height: 1.75;
}


/* ─────────────────────────────────────────────────────────────
   7. SITE DETAILS — dark green band
   Wraps: .rationale  |  .siteDescription  |  .siteFeatures  |  .siteMockups
───────────────────────────────────────────────────────────── */

#blogPost .siteDetails {
    background-color: #2b3d2b;
    padding: 4rem 2rem;
}

/* Inner max-width centering for each sub-section */
#blogPost .rationale,
#blogPost .siteDescription,
#blogPost .siteFeatures,
#blogPost .siteMockups {
    max-width: 860px;
    margin-left: auto;
    margin-right: auto;
}

/* Bottom margin between sub-sections */
#blogPost .rationale    { margin-bottom: 3rem; }
#blogPost .siteDescription { margin-bottom: 2.5rem; }
#blogPost .siteFeatures { margin-bottom: 3rem; }

/* ── Headings inside dark band */
#blogPost .siteDetails h2 {
    font-family: Georgia, 'Times New Roman', serif;
    font-size: 1.6rem;
    font-weight: 400;
    color: #e8efe6;
    text-align: center;
    letter-spacing: -0.01em;
    margin-bottom: 0;
}

#blogPost .siteDetails h2::after {
    content: '';
    display: block;
    width: 44px;
    height: 2px;
    background-color: #c8d8c4;
    margin: 0.7rem auto 1.75rem;
}

/* ── All p / a inside dark band */
#blogPost .siteDetails p {
    color: rgba(232,239,230,0.8);
    font-size: 1rem;
    line-height: 1.75;
}

#blogPost .siteDetails a {
    color: #c8d8c4;
}

/* ── Rationale section */
#blogPost .rationale {
    overflow: hidden; /* clearfix for float */
}

#blogPost .rationale img.alignright {
    float: right;
    max-width: 42%;
    margin: 0 0 1.5rem 2rem;
    border-radius: 4px;
    box-shadow: 0 6px 28px rgba(0,0,0,0.5);
}

/* Bold labels inside rationale body (e.g. "Sophisticated, Clean Design") */
#blogPost .rationale strong,
#blogPost .rationale b {
    display: block;
    font-size: 0.95rem;
    font-weight: 700;
    color: #e8efe6;
    margin: 1.4rem 0 0.3rem;
    letter-spacing: 0.01em;
}

/* ── Site Description (centred) */
#blogPost .siteDescription {
    text-align: center;
}

#blogPost .siteDescription p {
    max-width: 640px;
    margin-left: auto;
    margin-right: auto;
}

/* ── Site Features card grid */
#blogPost .siteFeatures ul {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(230px, 1fr));
    gap: 1rem;
}

#blogPost .siteFeatures ul li {
    display: flex;
    gap: 1rem;
    align-items: flex-start;
    background: rgba(255,255,255,0.06);
    border: 1px solid rgba(200,216,196,0.18);
    border-radius: 4px;
    padding: 1.25rem 1.1rem;
    transition: background 0.2s;
}

#blogPost .siteFeatures ul li:hover {
    background: rgba(255,255,255,0.1);
}

#blogPost .siteFeatureIcon {
    flex-shrink: 0;
    width: 38px;
    height: 38px;
    border-radius: 50%;
    background: rgba(200,216,196,0.14);
    border: 1px solid rgba(200,216,196,0.25);
    display: flex;
    align-items: center;
    justify-content: center;
    color: #c8d8c4;
    font-size: 0.95rem;
}

#blogPost .siteFeatures .itemHeading h4 {
    font-size: 0.8rem;
    font-weight: 700;
    letter-spacing: 0.05em;
    text-transform: uppercase;
    color: #e8efe6;
    margin-bottom: 0.35rem;
}

#blogPost .siteFeatures .itemHeading p {
    font-size: 0.875rem;
    color: rgba(200,216,196,0.72);
    line-height: 1.55;
    margin: 0;
}

/* ── Site Mockup + Gallery */
#blogPost .siteMockups > img {
    width: 100%;
    height: auto;
    display: block;
    border-radius: 4px;
    box-shadow: 0 10px 40px rgba(0,0,0,0.5);
    margin-bottom: 1.5rem;
}

#blogPost .websiteGallery {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(250px, 1fr));
    gap: 0.9rem;
}

#blogPost .websiteGallery img {
    width: 100%;
    height: auto;
    display: block;
    border-radius: 3px;
    box-shadow: 0 4px 18px rgba(0,0,0,0.4);
    transition: transform 0.25s, box-shadow 0.25s;
}

#blogPost .websiteGallery img:hover {
    transform: translateY(-3px);
    box-shadow: 0 8px 30px rgba(0,0,0,0.55);
}


/* ─────────────────────────────────────────────────────────────
   8. AFTER THE LAUNCH — light cream section
───────────────────────────────────────────────────────────── */

/* The outer .container wraps the whole section */
#blogPost .blogPostMain > .container section {
    text-align: center;
}

/* Results list */
#blogPost .resultsList {
    margin: 2rem 0;
    text-align: left;
}

#blogPost .resultsList ul {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(210px, 1fr));
    border-top: 1px solid #d4cfc6;
}

#blogPost .resultsList ul li {
    padding: 1.4rem 1rem 1.2rem;
    border-bottom: 1px solid #d4cfc6;
}

/* Hide PHP-generated <hr> inside li — we use border-bottom */
#blogPost .resultsList ul li hr {
    display: none;
}

#blogPost .resultsList h4 {
    font-size: 0.78rem;
    font-weight: 700;
    letter-spacing: 0.07em;
    text-transform: uppercase;
    color: #2b3d2b;
    margin-bottom: 0.45rem;
}

#blogPost .resultsList p {
    font-size: 0.88rem;
    color: #5a5a5a;
    line-height: 1.6;
    margin: 0;
}

/* Results pull quote */
#blogPost .resultsQuote {
    max-width: 600px;
    margin: 1.5rem auto 0;
    text-align: center;
}

#blogPost .resultsQuote p {
    font-family: Georgia, 'Times New Roman', serif;
    font-size: 1.2rem;
    font-style: italic;
    color: #2b3d2b;
    line-height: 1.65;
    padding: 0 1.25rem;
    margin: 0;
    position: relative;
}

#blogPost .resultsQuote p::before {
    content: '\201C';
    font-size: 2.8rem;
    line-height: 0;
    vertical-align: -0.45em;
    color: #4a6741;
    margin-right: 0.12em;
    font-style: normal;
}

#blogPost .resultsQuote hr {
    width: 44px;
    margin: 1.25rem auto;
    border-top-color: #4a6741;
}


/* ─────────────────────────────────────────────────────────────
   9. CTA BUTTON — "Visit the website"
───────────────────────────────────────────────────────────── */

/* The button is a direct child <a> of .blogPostMain */
#blogPost .blogPostMain > a.button,
#blogPost .blogPostMain a.button.medium {
    display: block;
    width: fit-content;
    margin: 2.5rem auto 3rem;
    padding: 0.8rem 2.5rem;
    background-color: transparent;
    border: 2px solid #2b3d2b;
    border-radius: 2px;
    color: #2b3d2b;
    font-size: 0.75rem;
    font-weight: 700;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    text-decoration: none;
    transition: background 0.2s, color 0.2s;
}

#blogPost .blogPostMain > a.button:hover,
#blogPost .blogPostMain a.button.medium:hover {
    background-color: #2b3d2b;
    color: #f0ece3;
}


/* ─────────────────────────────────────────────────────────────
   10. POST NAVIGATION
───────────────────────────────────────────────────────────── */

#blogPost .postNavigation {
    max-width: 860px;
    margin: 0 auto;
    padding: 2.5rem 2rem 4rem;
    border-top: 1px solid #d4cfc6;
}

/* Prev / Next */
#blogPost .prevNext {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 2rem;
    margin-bottom: 2.25rem;
    flex-wrap: wrap;
}

#blogPost .prevButton { flex: 1; }
#blogPost .nextButton { flex: 1; text-align: right; }

#blogPost .prevButton a,
#blogPost .nextButton a {
    display: inline-flex;
    align-items: baseline;
    gap: 0.45rem;
    color: #2b3d2b;
    text-decoration: none;
    font-size: 0.8rem;
    font-weight: 700;
    letter-spacing: 0.05em;
    text-transform: uppercase;
    transition: color 0.2s;
    line-height: 1.4;
}

#blogPost .prevButton a:hover,
#blogPost .nextButton a:hover {
    color: #4a6741;
}

/* "Previous Post:" / "Next Post:" label */
#blogPost .prevButton a span,
#blogPost .nextButton a span {
    font-weight: 400;
    font-size: 0.75rem;
    color: #5a5a5a;
    text-transform: none;
    letter-spacing: 0;
}

/* Chevron icon */
#blogPost .prevButton a i,
#blogPost .nextButton a i {
    font-size: 0.65rem;
    color: #4a6741;
}

/* Return buttons */
#blogPost .returnButtons ul {
    display: flex;
    justify-content: center;
    gap: 0.85rem;
    flex-wrap: wrap;
}

#blogPost .returnButtons a.button {
    display: inline-block;
    padding: 0.6rem 1.6rem;
    border: 1px solid #2b3d2b;
    border-radius: 2px;
    color: #2b3d2b;
    background: transparent;
    font-size: 0.72rem;
    font-weight: 700;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    text-decoration: none;
    transition: background 0.2s, color 0.2s;
}

#blogPost .returnButtons a.button:hover {
    background-color: #2b3d2b;
    color: #f0ece3;
}


/* ─────────────────────────────────────────────────────────────
   11. ACCESSIBILITY FIXES — ensure contrast on all bg/fg combos
───────────────────────────────────────────────────────────── */

/* Dark band: force all text nodes to readable colour */
#blogPost .siteDetails,
#blogPost .blogTitle {
    color: #e8efe6;
}

/* Any stray p in hero that theme might colour dark */
#blogPost .blogTitle p {
    color: rgba(232,239,230,0.75);
}

/* rationale h3/h4 that might come through from theme */
#blogPost .rationale h3,
#blogPost .rationale h4 {
    color: #e8efe6;
    font-size: 1rem;
    font-weight: 700;
    margin: 1.25rem 0 0.3rem;
}

/* Light band: ensure body text is never washed out */
#blogPost .webShowIntro,
#blogPost .blogPostMain .container {
    color: #1e1e1e;
}


/* ─────────────────────────────────────────────────────────────
   12. RESPONSIVE
───────────────────────────────────────────────────────────── */

@media (max-width: 820px) {

    #blogPost .blogTitle { padding-bottom: 2.75rem; }

    #blogPost .blogCategories,
    #blogPost .titleDiv,
    #blogPost .webShowIntro,
    #blogPost .siteDetails,
    #blogPost .blogPostMain .container,
    #blogPost .postNavigation {
        padding-left: 1.25rem;
        padding-right: 1.25rem;
    }

    #blogPost .blogTitle h1 { font-size: 1.65rem; }

    #blogPost .rationale img.alignright {
        float: none;
        max-width: 100%;
        margin: 0 0 1.5rem;
    }

    #blogPost .siteFeatures ul {
        grid-template-columns: 1fr;
    }

    #blogPost .resultsList ul {
        grid-template-columns: 1fr;
    }

    #blogPost .keyFeatures ul li { width: 72px; }

    #blogPost .keyFeatures .statIcon {
        width: 46px;
        height: 46px;
        font-size: 1rem;
    }
}

@media (max-width: 540px) {

    #blogPost .blogTitle h1 { font-size: 1.45rem; }

    #blogPost .keyFeatures ul li { width: 62px; }
    #blogPost .keyFeatures h4   { font-size: 0.58rem; }

    #blogPost .prevNext {
        flex-direction: column;
        gap: 1.25rem;
    }

    #blogPost .nextButton { text-align: left; }

    #blogPost .returnButtons ul {
        flex-direction: column;
        align-items: center;
    }

    #blogPost .webShowIntro {
        padding-top: 2.25rem;
        padding-bottom: 1.5rem;
    }

    #blogPost .siteDetails {
        padding-top: 2.75rem;
        padding-bottom: 2.75rem;
    }
}




.cag-wrap {
  background-color: #eceae4;          /* matches --rp-bg / your cream bg */
  padding: 2rem 3rem 1.75rem;
  margin: 0;
}
 
/* Section label — matches your existing muted uppercase labels */
.cag-label {
  font-family: 'Roboto', sans-serif;
  font-size: 0.72rem;
  font-weight: 500;
  letter-spacing: 0.13em;
  text-transform: uppercase;
  color: #6e6e6e;                     /* --rp-muted */
  text-align: center;
  margin: 0 0 1rem;
}
 
/* Horizontal rules — thin, subtle */
.cag-rule {
  border: none;
  border-top: 1px solid #d4d0c8;     /* close to your site's --color-border */
  margin: 0.6rem 0;
  width: 100%;
}
 
/* ── Role list ─────────────────────────────────────────── */
.cag-list {
  list-style: none;
  margin: 0.5rem 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 0;
}
 
.cag-item {
  display: flex;
  align-items: baseline;
  gap: 0.5rem;
  padding: 0.42rem 0;
  border-bottom: 1px solid rgba(180, 175, 165, 0.3);
  flex-wrap: wrap;
}
 
.cag-item:last-child {
  border-bottom: none;
}
 
/* Company name — bold, sage green accent to match your palette */
.cag-company {
  font-family: 'Roboto', sans-serif;
  font-size: 0.82rem;
  font-weight: 700;
  color: #6b8f71;                     /* --rp-accent / --hp-accent2 */
  white-space: nowrap;
  flex-shrink: 0;
}
 
/* Separator dot */
.cag-dot {
  color: #b0aba2;
  font-size: 0.9rem;
  flex-shrink: 0;
  user-select: none;
}
 
/* Role title — takes up remaining space */
.cag-role {
  font-family: 'Merriweather', serif;
  font-size: 0.78rem;
  font-weight: 400;
  color: #2c2c2c;                     /* --rp-text */
  flex: 1;
  min-width: 180px;
}
 
/* Dates — right-aligned, muted */
.cag-dates {
  font-family: 'Roboto', sans-serif;
  font-size: 0.75rem;
  font-weight: 300;
  color: #6e6e6e;                     /* --rp-muted */
  white-space: nowrap;
  margin-left: auto;
  flex-shrink: 0;
}
 
/* ── Education + Certifications ────────────────────────── */
.cag-meta-list {
  list-style: none;
  margin: 0.75rem 0 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 0.3rem;
}
 
.cag-meta-item {
  display: flex;
  align-items: baseline;
  flex-wrap: wrap;
  gap: 0.4rem;
}
 
.cag-meta-label {
  font-family: 'Roboto', sans-serif;
  font-size: 0.75rem;
  font-weight: 700;
  color: #2c2c2c;
  white-space: nowrap;
  flex-shrink: 0;
}
 
.cag-meta-value {
  font-family: 'Roboto', sans-serif;
  font-size: 0.75rem;
  font-weight: 300;
  color: #2c2c2c;
}
 
/* Inner separator dots in education/cert rows */
.cag-sep {
  color: #b0aba2;
  margin: 0 0.1rem;
  font-size: 0.85rem;
}
 
/* ── Responsive ─────────────────────────────────────────── */
@media (max-width: 680px) {
  .cag-wrap {
    padding: 1.5rem 1.25rem 1.25rem;
  }
 
  /* Stack role + dates on mobile */
  .cag-item {
    flex-wrap: wrap;
    gap: 0.25rem 0.5rem;
  }
 
  .cag-dates {
    margin-left: 0;
    width: 100%;
    padding-left: calc(0.82rem + 1rem + 0.5rem); /* indent under company */
  }
 
  .cag-role {
    min-width: 0;
  }
}
 
@media (max-width: 420px) {
  .cag-label {
    font-size: 0.65rem;
  }
 
  .cag-company,
  .cag-role,
  .cag-dates {
    font-size: 0.72rem;
  }
}



/* Color Palette & Base Styles */
.resumeProof-container {
    background-color: #f4f6f0; /* The light sage/cream background */
    font-family: 'Segoe UI', Tahoma, Geneva, Verdana, sans-serif;
    color: #334e44; /* Darker forest green/grey text */
    padding: 40px;
    max-width: 1000px;
    margin: 0 auto;
}

.resumeProof-section {
    margin-bottom: 40px;
    text-align: center;
}

.resumeProof-title {
    font-family: 'Georgia', serif;
    font-size: 2rem;
    font-weight: 700;
    margin-bottom: 25px;
    color: #2c3e37;
}

/* Proof of Impact Grid */
.resumeProof-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 15px;
}

.resumeProof-card {
    background: transparent;
    border: 1px solid #c9d1c1;
    border-radius: 6px;
    border-left: 5px solid #4a6d5f; /* The thick left accent */
    text-align: left;
    padding: 12px 15px;
    display: flex;
    align-items: center;
}

.resumeProof-card-heading {
    margin: 0;
    font-size: 1.05rem;
    font-weight: 700;
    color: #3d5a4e;
}

.resumeProof-card-subtext {
    margin: 3px 0 0 0;
    font-size: 0.85rem;
    color: #667c73;
}

/* Core Competencies Tags */
.resumeProof-tag-container {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 8px;
}

.resumeProof-tag {
    background-color: #e2e8db;
    border: 1px solid #bdc7b5;
    padding: 6px 14px;
    border-radius: 20px;
    font-size: 0.85rem;
    color: #3d5a4e;
}

/* Education Section */
.resumeProof-divider {
    border: 0;
    border-top: 1px solid #c9d1c1;
    margin: 30px 0;
}

.resumeProof-education {
    text-align: left;
}

.resumeProof-edu-main-title {
    font-family: 'Georgia', serif;
    font-size: 1.8rem;
    margin-bottom: 10px;
}

.resumeProof-edu-header {
    display: flex;
    gap: 10px;
    align-items: baseline;
    margin-bottom: 5px;
}

.resumeProof-college {
    font-weight: 700;
    color: #3d5a4e;
    font-size: 1.1rem;
}

.resumeProof-edu-details {
    font-size: 0.95rem;
    color: #667c73;
}

.resumeProof-edu-desc {
    margin: 2px 0;
    font-size: 0.9rem;
    color: #555;
}

/* Certifications */
.resumeProof-certs {
    margin-top: 20px;
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 10px;
}

.resumeProof-cert-label {
    font-weight: 700;
    margin-right: 10px;
}

.resumeProof-cert-tag {
    background-color: #eef3eb;
    padding: 4px 12px;
    border-radius: 4px;
    font-size: 0.85rem;
    border: 1px solid transparent; /* Keeps sizing consistent */
}

/* Responsive adjustment for mobile */
@media (max-width: 768px) {
    .resumeProof-grid {
        grid-template-columns: 1fr;
    }
    .resumeProof-edu-header {
        flex-direction: column;
        gap: 2px;
    }
}


/* Ensure linked certs look like the non-linked ones */
a.resumeProof-cert-tag {
    text-decoration: none;
    display: inline-block;
    transition: background-color 0.2s ease, border-color 0.2s ease;
}

/* Add a subtle hover effect for clickable certs */
a.resumeProof-cert-tag:hover {
    background-color: #e2e8db;
    border-color: #adb9a4;
}


















/* ==========================================================
   Resume Page Refresh
   Add at end of style.css
   ========================================================== */

/* Button fix: make primary buttons light green by default */
.resumePage-root .aboutPage-btn-primary,
.resumePage-root a.aboutPage-btn-primary {
    background: #dfe8d8;
    color: #2c2c2c;
    border: 1px solid #b9c8b0;
    box-shadow: 0 1px 0 rgba(0, 0, 0, 0.04);
}

.resumePage-root .aboutPage-btn-primary:hover,
.resumePage-root a.aboutPage-btn-primary:hover {
    background: #cfdcc6;
    color: #1f2a21;
    border-color: #a6b79d;
    transform: translateY(-2px);
}

.resumePage-root .aboutPage-btn-secondary,
.resumePage-root a.aboutPage-btn-secondary {
    background: transparent;
    color: #2c2c2c;
    border: 1px solid #b9c8b0;
}

.resumePage-root .aboutPage-btn-secondary:hover,
.resumePage-root a.aboutPage-btn-secondary:hover {
    background: rgba(223, 232, 216, 0.45);
    border-color: #a6b79d;
}

/* Hero spacing refinement for resume page */
.resumePage-root .resumeHero {
    padding-top: 8.5rem;
}

.resumePage-root .resumeHero-inner {
    max-width: 860px;
    margin: 0 auto;
    padding: 0 1.5rem;
}

.resumePage-root .resumeHero-actions {
    gap: 0.9rem;
}

/* Timeline section header */
.resumePage-root .rn-sectionHeader {
    text-align: center;
    margin-bottom: 2.5rem;
}

.resumePage-root .rn-sectionLabel {
    margin: 0;
    font-family: 'Roboto', sans-serif;
    font-size: 0.72rem;
    font-weight: 500;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: #6e6e6e;
}

/* Timeline wrapper */
.resumePage-root .resumeNew {
    max-width: 1100px;
    margin: 0 auto;
    padding: 3.5rem 1.5rem 4rem;
    position: relative;
    overflow: visible;
}

.resumePage-root .rn-timeline {
    position: relative;
    padding: 0.5rem 0 0;
}

.resumePage-root .rn-timeline::before {
    content: '';
    position: absolute;
    left: 50%;
    top: 0;
    bottom: 0;
    width: 2px;
    transform: translateX(-50%);
    background: linear-gradient(to bottom, rgba(168, 184, 158, 0.15), rgba(168, 184, 158, 0.65), rgba(168, 184, 158, 0.15));
    z-index: 0;
}

/* Each timeline entry */
.resumePage-root .rn-entry {
    position: relative;
    display: grid;
    grid-template-columns: 1fr 72px 1fr;
    align-items: center;
    gap: 0 2rem;
    margin-bottom: 4.5rem;
    z-index: 1;
}

.resumePage-root .rn-entry:last-child {
    margin-bottom: 0;
}

.resumePage-root .rn-mediaCol,
.resumePage-root .rn-contentCol {
    min-width: 0;
}

.resumePage-root .rn-mediaCol {
    display: flex;
    justify-content: flex-end;
}

.resumePage-root .rn-contentCol {
    display: flex;
    justify-content: flex-start;
}

.resumePage-root .rn-reverse .rn-mediaCol {
    justify-content: flex-start;
}

.resumePage-root .rn-reverse .rn-contentCol {
    justify-content: flex-end;
}

.resumePage-root .rn-rail {
    position: relative;
    display: flex;
    justify-content: center;
    align-items: center;
    min-height: 100%;
    z-index: 3;
}

.resumePage-root .rn-node {
    width: 44px;
    height: 44px;
    border-radius: 999px;
    background: #ffffff;
    border: 2px solid #a8b89e;
    box-shadow: 0 6px 18px rgba(44, 44, 44, 0.08);
    display: flex;
    align-items: center;
    justify-content: center;
}

.resumePage-root .rn-num {
    font-family: 'Roboto', sans-serif;
    font-size: 0.82rem;
    font-weight: 700;
    color: #6b8f71;
    line-height: 1;
}

/* Media card */
.resumePage-root .rn-img-card {
    width: min(100%, 340px);
    background: #ffffff;
    border-radius: 16px;
    overflow: hidden;
    border: 1px solid rgba(168, 184, 158, 0.35);
    box-shadow: 0 14px 36px rgba(44, 44, 44, 0.08);
}

.resumePage-root .rn-img-card img {
    display: block;
    width: 100%;
    height: auto;
}

/* Content card */
.resumePage-root .rn-card {
    width: min(100%, 430px);
    background: #ffffff;
    border: 1px solid rgba(168, 184, 158, 0.35);
    border-radius: 18px;
    padding: 1.65rem 1.55rem 1.5rem;
    box-shadow: 0 12px 34px rgba(44, 44, 44, 0.07);
}

.resumePage-root .rn-eyebrow {
    margin: 0 0 0.45rem;
    font-family: 'Roboto', sans-serif;
    font-size: 0.7rem;
    font-weight: 600;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: #6b8f71;
}

.resumePage-root .rn-title {
    margin: 0 0 0.65rem;
    font-family: 'Cormorant Garamond', serif;
    font-size: clamp(1.6rem, 2vw, 2rem);
    line-height: 1.08;
    color: #2c2c2c;
}

.resumePage-root .rn-meta {
    display: flex;
    flex-wrap: wrap;
    gap: 0.45rem 0.8rem;
    margin: 0 0 1rem;
}

.resumePage-root .rn-role,
.resumePage-root .rn-date {
    display: inline-flex;
    align-items: center;
    font-family: 'Roboto', sans-serif;
    font-size: 0.78rem;
    line-height: 1.35;
}

.resumePage-root .rn-role {
    font-weight: 700;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    color: #2c2c2c;
}

.resumePage-root .rn-date {
    color: #6e6e6e;
    font-weight: 400;
}

.resumePage-root .rn-desc {
    margin-bottom: 1rem;
}

.resumePage-root .rn-desc p {
    margin: 0 0 0.8rem;
    font-size: 0.92rem;
    line-height: 1.75;
    color: #555d57;
}

.resumePage-root .rn-desc p:last-child {
    margin-bottom: 0;
}

.resumePage-root .rn-bullets {
    list-style: none;
    margin: 0 0 1rem;
    padding: 0;
    display: grid;
    gap: 0.55rem;
}

.resumePage-root .rn-bullets li {
    position: relative;
    margin: 0;
    padding-left: 1rem;
    font-size: 0.9rem;
    line-height: 1.65;
    color: #555d57;
}

.resumePage-root .rn-bullets li::before {
    content: '•';
    position: absolute;
    left: 0;
    top: 0;
    color: #6b8f71;
    font-size: 1rem;
    line-height: 1.5;
}

.resumePage-root .rn-tags {
    display: flex;
    flex-wrap: wrap;
    gap: 0.45rem;
}

.resumePage-root .rn-tag {
    display: inline-flex;
    align-items: center;
    padding: 0.38rem 0.72rem;
    background: #edf3e8;
    border: 1px solid #d8e3d1;
    border-radius: 999px;
    font-family: 'Roboto', sans-serif;
    font-size: 0.72rem;
    font-weight: 500;
    line-height: 1;
    color: #48624d;
    margin: 0;
}

/* Better spacing into proof section */
.resumePage-root .resumeProof-container {
    margin-top: 0.5rem;
}

/* Tablet */
@media (max-width: 980px) {
    .resumePage-root .rn-entry {
        grid-template-columns: 1fr 56px 1fr;
        gap: 0 1.2rem;
    }

    .resumePage-root .rn-card {
        width: 100%;
    }

    .resumePage-root .rn-img-card {
        width: 100%;
        max-width: 300px;
    }
}

/* Mobile timeline becomes single-column */
@media (max-width: 760px) {
    .resumePage-root .resumeNew {
        padding: 2.75rem 1rem 3rem;
    }

    .resumePage-root .rn-timeline::before {
        left: 20px;
        transform: none;
    }

    .resumePage-root .rn-entry,
    .resumePage-root .rn-reverse {
        display: grid;
        grid-template-columns: 40px 1fr;
        gap: 0.9rem 1rem;
        margin-bottom: 2.5rem;
    }

    .resumePage-root .rn-rail,
    .resumePage-root .rn-reverse .rn-rail {
        order: 1;
        justify-content: flex-start;
        align-items: flex-start;
    }

    .resumePage-root .rn-node {
        width: 36px;
        height: 36px;
    }

    .resumePage-root .rn-mediaCol,
    .resumePage-root .rn-contentCol,
    .resumePage-root .rn-reverse .rn-mediaCol,
    .resumePage-root .rn-reverse .rn-contentCol {
        order: initial;
        justify-content: flex-start;
    }

    .resumePage-root .rn-contentCol,
    .resumePage-root .rn-reverse .rn-contentCol {
        grid-column: 2;
    }

    .resumePage-root .rn-mediaCol,
    .resumePage-root .rn-reverse .rn-mediaCol {
        grid-column: 2;
    }

    .resumePage-root .rn-card,
    .resumePage-root .rn-img-card {
        width: 100%;
        max-width: 100%;
    }

    .resumePage-root .rn-card {
        padding: 1.3rem 1.15rem 1.2rem;
    }

    .resumePage-root .rn-title {
        font-size: 1.5rem;
    }
}



/* ==========================================================
   Blog Post Template - offset below fixed main nav
   Add at end of style.css
   ========================================================== */

/* Push the entire blog post template below the fixed site header */
.blogPostNew {
    padding-top: 110px;
}

/* Keep the top bar visually attached to the article, not the viewport */
.blogPostNew__topBar {
    position: relative;
    z-index: 1;
}

/* Slightly tighter desktop spacing if needed once offset is applied */
.blogPostNew__hero {
    padding-top: 40px;
}

/* Logged-in WordPress admin bar adjustment */
body.admin-bar .blogPostNew {
    padding-top: 142px;
}

/* Tablet */
@media (max-width: 980px) {
    .blogPostNew {
        padding-top: 100px;
    }

    body.admin-bar .blogPostNew {
        padding-top: 132px;
    }
}

/* Mobile */
@media (max-width: 760px) {
    .blogPostNew {
        padding-top: 90px;
    }

    body.admin-bar .blogPostNew {
        padding-top: 122px;
    }

    .blogPostNew__hero {
        padding-top: 28px;
    }
}










/* ==========================================================
   RESUME TIMELINE - CLEAN FINAL OVERRIDE
   Matches current resume.php structure
   ========================================================== */

.resumePage-root .resumeNew {
    max-width: 1100px;
    margin: 0 auto;
    padding: 3.5rem 1.5rem 4rem;
    position: relative;
    overflow: visible;
}

.resumePage-root .rn-sectionHeader {
    text-align: center;
    margin-bottom: 2.5rem;
}

.resumePage-root .rn-sectionLabel {
    margin: 0;
    font-family: 'Roboto', sans-serif;
    font-size: 0.72rem;
    font-weight: 500;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: #6e6e6e;
}

.resumePage-root .rn-timeline {
    position: relative;
    padding-top: 0.5rem;
}

.resumePage-root .rn-timeline::before {
    content: '';
    position: absolute;
    left: 50%;
    top: 0;
    bottom: 0;
    width: 2px;
    transform: translateX(-50%);
    background: linear-gradient(
        to bottom,
        rgba(168, 184, 158, 0.15),
        rgba(168, 184, 158, 0.65),
        rgba(168, 184, 158, 0.15)
    );
    z-index: 0;
}

.resumePage-root .rn-entry {
    position: relative;
    display: grid;
    grid-template-columns: 1fr 72px 1fr;
    align-items: center;
    gap: 0 2rem;
    margin-bottom: 4.5rem;
    z-index: 1;
}

.resumePage-root .rn-entry:last-child {
    margin-bottom: 0;
}

.resumePage-root .rn-mediaCol,
.resumePage-root .rn-contentCol {
    min-width: 0;
}

.resumePage-root .rn-mediaCol {
    display: flex;
    justify-content: flex-end;
}

.resumePage-root .rn-contentCol {
    display: flex;
    justify-content: flex-start;
}

.resumePage-root .rn-reverse .rn-mediaCol {
    order: 3;
    justify-content: flex-start;
}

.resumePage-root .rn-reverse .rn-rail {
    order: 2;
}

.resumePage-root .rn-reverse .rn-contentCol {
    order: 1;
    justify-content: flex-end;
}

.resumePage-root .rn-rail {
    position: relative;
    display: flex;
    justify-content: center;
    align-items: center;
    min-height: 100%;
    z-index: 3;
}

.resumePage-root .rn-node {
    width: 44px;
    height: 44px;
    border-radius: 999px;
    background: #ffffff;
    border: 2px solid #a8b89e;
    box-shadow: 0 6px 18px rgba(44, 44, 44, 0.08);
    display: flex;
    align-items: center;
    justify-content: center;
}

.resumePage-root .rn-num {
    font-family: 'Roboto', sans-serif;
    font-size: 0.82rem;
    font-weight: 700;
    color: #6b8f71;
    line-height: 1;
}

.resumePage-root .rn-img-card {
    width: min(100%, 340px);
    background: #ffffff;
    border-radius: 16px;
    overflow: hidden;
    border: 1px solid rgba(168, 184, 158, 0.35);
    box-shadow: 0 14px 36px rgba(44, 44, 44, 0.08);
}

.resumePage-root .rn-img-card img {
    display: block;
    width: 100%;
    height: auto;
}

.resumePage-root .rn-card {
    width: min(100%, 430px);
    background: #ffffff;
    border: 1px solid rgba(168, 184, 158, 0.35);
    border-radius: 18px;
    padding: 1.65rem 1.55rem 1.5rem;
    box-shadow: 0 12px 34px rgba(44, 44, 44, 0.07);
}

.resumePage-root .rn-eyebrow {
    margin: 0 0 0.45rem;
    font-family: 'Roboto', sans-serif;
    font-size: 0.7rem;
    font-weight: 600;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: #6b8f71;
}

.resumePage-root .rn-title {
    margin: 0 0 0.65rem;
    font-family: 'Cormorant Garamond', serif;
    font-size: clamp(1.6rem, 2vw, 2rem);
    line-height: 1.08;
    color: #2c2c2c;
}

.resumePage-root .rn-meta {
    display: flex;
    flex-wrap: wrap;
    gap: 0.45rem 0.8rem;
    margin: 0 0 1rem;
}

.resumePage-root .rn-role,
.resumePage-root .rn-date {
    display: inline-flex;
    align-items: center;
    font-family: 'Roboto', sans-serif;
    font-size: 0.78rem;
    line-height: 1.35;
}

.resumePage-root .rn-role {
    font-weight: 700;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    color: #2c2c2c;
}

.resumePage-root .rn-date {
    color: #6e6e6e;
    font-weight: 400;
}

.resumePage-root .rn-desc {
    margin-bottom: 1rem;
}

.resumePage-root .rn-desc p {
    margin: 0 0 0.8rem;
    font-size: 0.92rem;
    line-height: 1.75;
    color: #555d57;
}

.resumePage-root .rn-desc p:last-child {
    margin-bottom: 0;
}

.resumePage-root .rn-bullets {
    list-style: none;
    margin: 0 0 1rem;
    padding: 0;
    display: grid;
    gap: 0.55rem;
}

.resumePage-root .rn-bullets li {
    position: relative;
    margin: 0;
    padding-left: 1rem;
    font-size: 0.9rem;
    line-height: 1.65;
    color: #555d57;
}

.resumePage-root .rn-bullets li::before {
    content: '•';
    position: absolute;
    left: 0;
    top: 0;
    color: #6b8f71;
    font-size: 1rem;
    line-height: 1.5;
}

.resumePage-root .rn-tags {
    display: flex;
    flex-wrap: wrap;
    gap: 0.45rem;
}

.resumePage-root .rn-tag {
    display: inline-flex;
    align-items: center;
    padding: 0.38rem 0.72rem;
    background: #edf3e8;
    border: 1px solid #d8e3d1;
    border-radius: 999px;
    font-family: 'Roboto', sans-serif;
    font-size: 0.72rem;
    font-weight: 500;
    line-height: 1;
    color: #48624d;
    margin: 0;
}

@media (max-width: 980px) {
    .resumePage-root .rn-entry {
        grid-template-columns: 1fr 56px 1fr;
        gap: 0 1.2rem;
    }

    .resumePage-root .rn-card {
        width: 100%;
    }

    .resumePage-root .rn-img-card {
        width: 100%;
        max-width: 300px;
    }
}

@media (max-width: 760px) {
    .resumePage-root .resumeNew {
        padding: 2.75rem 1rem 3rem;
    }

    .resumePage-root .rn-timeline::before {
        left: 20px;
        transform: none;
    }

    .resumePage-root .rn-entry,
    .resumePage-root .rn-reverse {
        display: grid;
        grid-template-columns: 40px 1fr;
        gap: 0.9rem 1rem;
        margin-bottom: 2.5rem;
    }

    .resumePage-root .rn-rail,
    .resumePage-root .rn-reverse .rn-rail {
        order: 1;
        justify-content: flex-start;
        align-items: flex-start;
    }

    .resumePage-root .rn-node {
        width: 36px;
        height: 36px;
    }

    .resumePage-root .rn-contentCol,
    .resumePage-root .rn-reverse .rn-contentCol {
        grid-column: 2;
        justify-content: flex-start;
    }

    .resumePage-root .rn-mediaCol,
    .resumePage-root .rn-reverse .rn-mediaCol {
        grid-column: 2;
        justify-content: flex-start;
    }

    .resumePage-root .rn-card,
    .resumePage-root .rn-img-card {
        width: 100%;
        max-width: 100%;
    }

    .resumePage-root .rn-card {
        padding: 1.3rem 1.15rem 1.2rem;
    }

    .resumePage-root .rn-title {
        font-size: 1.5rem;
    }
}



/* ==========================================================
   SPO EXPERIENCE TIMELINE
   Fully scoped to avoid conflicts with existing resume styles
   ========================================================== */

#spo-expTimeline,
.spo-expTimeline {
    max-width: 1100px;
    margin: 0 auto;
    padding: 3.5rem 1.5rem 4rem;
    position: relative;
    overflow: visible;
}

#spo-expTimeline .spo-expTimeline__header,
.spo-expTimeline .spo-expTimeline__header {
    text-align: center;
    margin-bottom: 2.5rem;
}

#spo-expTimeline .spo-expTimeline__label,
.spo-expTimeline .spo-expTimeline__label {
    margin: 0;
    font-family: 'Roboto', sans-serif;
    font-size: 0.72rem;
    font-weight: 500;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: #6e6e6e;
}

#spo-expTimeline .spo-expTimeline__list,
.spo-expTimeline .spo-expTimeline__list {
    position: relative;
    padding-top: 0.5rem;
}

#spo-expTimeline .spo-expTimeline__list::before,
.spo-expTimeline .spo-expTimeline__list::before {
    content: '';
    position: absolute;
    left: 50%;
    top: 0;
    bottom: 0;
    width: 2px;
    transform: translateX(-50%);
    background: linear-gradient(
        to bottom,
        rgba(168, 184, 158, 0.15),
        rgba(168, 184, 158, 0.65),
        rgba(168, 184, 158, 0.15)
    );
    z-index: 0;
}

#spo-expTimeline .spo-expTimeline__item,
.spo-expTimeline .spo-expTimeline__item {
    position: relative;
    display: grid;
    grid-template-columns: 1fr 72px 1fr;
    align-items: center;
    gap: 0 2rem;
    margin-bottom: 4.5rem;
    z-index: 1;
}

#spo-expTimeline .spo-expTimeline__item:last-child,
.spo-expTimeline .spo-expTimeline__item:last-child {
    margin-bottom: 0;
}

#spo-expTimeline .spo-expTimeline__mediaCol,
#spo-expTimeline .spo-expTimeline__contentCol,
.spo-expTimeline .spo-expTimeline__mediaCol,
.spo-expTimeline .spo-expTimeline__contentCol {
    min-width: 0;
}

#spo-expTimeline .spo-expTimeline__mediaCol,
.spo-expTimeline .spo-expTimeline__mediaCol {
    display: flex;
    justify-content: flex-end;
}

#spo-expTimeline .spo-expTimeline__contentCol,
.spo-expTimeline .spo-expTimeline__contentCol {
    display: flex;
    justify-content: flex-start;
}

#spo-expTimeline .spo-expTimeline__item--reverse .spo-expTimeline__mediaCol,
.spo-expTimeline .spo-expTimeline__item--reverse .spo-expTimeline__mediaCol {
    order: 3;
    justify-content: flex-start;
}

#spo-expTimeline .spo-expTimeline__item--reverse .spo-expTimeline__rail,
.spo-expTimeline .spo-expTimeline__item--reverse .spo-expTimeline__rail {
    order: 2;
}

#spo-expTimeline .spo-expTimeline__item--reverse .spo-expTimeline__contentCol,
.spo-expTimeline .spo-expTimeline__item--reverse .spo-expTimeline__contentCol {
    order: 1;
    justify-content: flex-end;
}

#spo-expTimeline .spo-expTimeline__rail,
.spo-expTimeline .spo-expTimeline__rail {
    position: relative;
    display: flex;
    justify-content: center;
    align-items: center;
    min-height: 100%;
    z-index: 3;
}

#spo-expTimeline .spo-expTimeline__node,
.spo-expTimeline .spo-expTimeline__node {
    width: 44px;
    height: 44px;
    border-radius: 999px;
    background: #ffffff;
    border: 2px solid #a8b89e;
    box-shadow: 0 6px 18px rgba(44, 44, 44, 0.08);
    display: flex;
    align-items: center;
    justify-content: center;
}

#spo-expTimeline .spo-expTimeline__num,
.spo-expTimeline .spo-expTimeline__num {
    font-family: 'Roboto', sans-serif;
    font-size: 0.82rem;
    font-weight: 700;
    color: #6b8f71;
    line-height: 1;
}

#spo-expTimeline .spo-expTimeline__imageCard,
.spo-expTimeline .spo-expTimeline__imageCard {
    width: min(100%, 340px);
    background: #ffffff;
    border-radius: 16px;
    overflow: hidden;
    border: 1px solid rgba(168, 184, 158, 0.35);
    box-shadow: 0 14px 36px rgba(44, 44, 44, 0.08);
    margin: 0;
}

#spo-expTimeline .spo-expTimeline__imageCard img,
.spo-expTimeline .spo-expTimeline__imageCard img {
    display: block;
    width: 100%;
    height: auto;
}

#spo-expTimeline .spo-expTimeline__card,
.spo-expTimeline .spo-expTimeline__card {
    width: min(100%, 430px);
    background: #ffffff;
    border: 1px solid rgba(168, 184, 158, 0.35);
    border-radius: 18px;
    padding: 1.65rem 1.55rem 1.5rem;
    box-shadow: 0 12px 34px rgba(44, 44, 44, 0.07);
}

#spo-expTimeline .spo-expTimeline__eyebrow,
.spo-expTimeline .spo-expTimeline__eyebrow {
    margin: 0 0 0.45rem;
    font-family: 'Roboto', sans-serif;
    font-size: 0.7rem;
    font-weight: 600;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: #6b8f71;
}

#spo-expTimeline .spo-expTimeline__title,
.spo-expTimeline .spo-expTimeline__title {
    margin: 0 0 0.65rem;
    font-family: 'Cormorant Garamond', serif;
    font-size: clamp(1.6rem, 2vw, 2rem);
    line-height: 1.08;
    color: #2c2c2c;
}

#spo-expTimeline .spo-expTimeline__meta,
.spo-expTimeline .spo-expTimeline__meta {
    display: flex;
    flex-wrap: wrap;
    gap: 0.45rem 0.8rem;
    margin: 0 0 1rem;
}

#spo-expTimeline .spo-expTimeline__role,
#spo-expTimeline .spo-expTimeline__date,
.spo-expTimeline .spo-expTimeline__role,
.spo-expTimeline .spo-expTimeline__date {
    display: inline-flex;
    align-items: center;
    font-family: 'Roboto', sans-serif;
    font-size: 0.78rem;
    line-height: 1.35;
}

#spo-expTimeline .spo-expTimeline__role,
.spo-expTimeline .spo-expTimeline__role {
    font-weight: 700;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    color: #2c2c2c;
}

#spo-expTimeline .spo-expTimeline__date,
.spo-expTimeline .spo-expTimeline__date {
    color: #6e6e6e;
    font-weight: 400;
}

#spo-expTimeline .spo-expTimeline__desc,
.spo-expTimeline .spo-expTimeline__desc {
    margin-bottom: 1rem;
}

#spo-expTimeline .spo-expTimeline__desc p,
.spo-expTimeline .spo-expTimeline__desc p {
    margin: 0 0 0.8rem;
    font-size: 0.92rem;
    line-height: 1.75;
    color: #555d57;
    font-family: 'Merriweather', serif;
}

#spo-expTimeline .spo-expTimeline__desc p:last-child,
.spo-expTimeline .spo-expTimeline__desc p:last-child {
    margin-bottom: 0;
}

#spo-expTimeline .spo-expTimeline__bullets,
.spo-expTimeline .spo-expTimeline__bullets {
    list-style: none;
    margin: 0 0 1rem;
    padding: 0;
    display: grid;
    gap: 0.55rem;
}

#spo-expTimeline .spo-expTimeline__bullets li,
.spo-expTimeline .spo-expTimeline__bullets li {
    position: relative;
    margin: 0;
    padding-left: 1rem;
    font-size: 0.9rem;
    line-height: 1.65;
    color: #555d57;
    font-family: 'Merriweather', serif;
}

#spo-expTimeline .spo-expTimeline__bullets li::before,
.spo-expTimeline .spo-expTimeline__bullets li::before {
    content: '•';
    position: absolute;
    left: 0;
    top: 0;
    color: #6b8f71;
    font-size: 1rem;
    line-height: 1.5;
}

#spo-expTimeline .spo-expTimeline__tags,
.spo-expTimeline .spo-expTimeline__tags {
    display: flex;
    flex-wrap: wrap;
    gap: 0.45rem;
}

#spo-expTimeline .spo-expTimeline__tag,
.spo-expTimeline .spo-expTimeline__tag {
    display: inline-flex;
    align-items: center;
    padding: 0.38rem 0.72rem;
    background: #edf3e8;
    border: 1px solid #d8e3d1;
    border-radius: 999px;
    font-family: 'Roboto', sans-serif;
    font-size: 0.72rem;
    font-weight: 500;
    line-height: 1;
    color: #48624d;
    margin: 0;
}

@media (max-width: 980px) {
    #spo-expTimeline .spo-expTimeline__item,
    .spo-expTimeline .spo-expTimeline__item {
        grid-template-columns: 1fr 56px 1fr;
        gap: 0 1.2rem;
    }

    #spo-expTimeline .spo-expTimeline__card,
    .spo-expTimeline .spo-expTimeline__card {
        width: 100%;
    }

    #spo-expTimeline .spo-expTimeline__imageCard,
    .spo-expTimeline .spo-expTimeline__imageCard {
        width: 100%;
        max-width: 300px;
    }
}

@media (max-width: 760px) {
    #spo-expTimeline,
    .spo-expTimeline {
        padding: 2.75rem 1rem 3rem;
    }

    #spo-expTimeline .spo-expTimeline__list::before,
    .spo-expTimeline .spo-expTimeline__list::before {
        left: 20px;
        transform: none;
    }

    #spo-expTimeline .spo-expTimeline__item,
    #spo-expTimeline .spo-expTimeline__item--reverse,
    .spo-expTimeline .spo-expTimeline__item,
    .spo-expTimeline .spo-expTimeline__item--reverse {
        display: grid;
        grid-template-columns: 40px 1fr;
        gap: 0.9rem 1rem;
        margin-bottom: 2.5rem;
    }

    #spo-expTimeline .spo-expTimeline__rail,
    #spo-expTimeline .spo-expTimeline__item--reverse .spo-expTimeline__rail,
    .spo-expTimeline .spo-expTimeline__rail,
    .spo-expTimeline .spo-expTimeline__item--reverse .spo-expTimeline__rail {
        order: 1;
        justify-content: flex-start;
        align-items: flex-start;
    }

    #spo-expTimeline .spo-expTimeline__node,
    .spo-expTimeline .spo-expTimeline__node {
        width: 36px;
        height: 36px;
    }

    #spo-expTimeline .spo-expTimeline__contentCol,
    #spo-expTimeline .spo-expTimeline__item--reverse .spo-expTimeline__contentCol,
    .spo-expTimeline .spo-expTimeline__contentCol,
    .spo-expTimeline .spo-expTimeline__item--reverse .spo-expTimeline__contentCol {
        grid-column: 2;
        justify-content: flex-start;
    }

    #spo-expTimeline .spo-expTimeline__mediaCol,
    #spo-expTimeline .spo-expTimeline__item--reverse .spo-expTimeline__mediaCol,
    .spo-expTimeline .spo-expTimeline__mediaCol,
    .spo-expTimeline .spo-expTimeline__item--reverse .spo-expTimeline__mediaCol {
        grid-column: 2;
        justify-content: flex-start;
        order: initial;
    }

    #spo-expTimeline .spo-expTimeline__card,
    #spo-expTimeline .spo-expTimeline__imageCard,
    .spo-expTimeline .spo-expTimeline__card,
    .spo-expTimeline .spo-expTimeline__imageCard {
        width: 100%;
        max-width: 100%;
    }

    #spo-expTimeline .spo-expTimeline__card,
    .spo-expTimeline .spo-expTimeline__card {
        padding: 1.3rem 1.15rem 1.2rem;
    }

    #spo-expTimeline .spo-expTimeline__title,
    .spo-expTimeline .spo-expTimeline__title {
        font-size: 1.5rem;
    }
}






/* ==========================================================
   About Page - Outside of Work horizontal gallery
   Add this near the end of style.css so it overrides older gallery defaults.
   ========================================================== */

.aboutPage-personality {
    background: var(--ap-bg);
    padding: 3.5rem 1.5rem 5rem;
}

.aboutPage-personality-inner {
    max-width: 1180px;
    margin: 0 auto;
    display: grid;
    grid-template-columns: minmax(220px, 0.9fr) minmax(0, 2.1fr);
    gap: 2.25rem;
    align-items: start;
}

.aboutPage-personality-copy .aboutPage-focus-title {
    margin-bottom: 1rem;
}

.aboutPage-personality-intro {
    max-width: 320px;
    margin: 0;
    font-family: 'Jost', sans-serif;
    font-size: 0.95rem;
    font-weight: 300;
    line-height: 1.8;
    color: var(--ap-muted);
}

.personality-grid {
    display: grid;
    grid-template-columns: repeat(5, minmax(120px, 1fr));
    gap: 1rem;
    align-items: stretch;
}

.personality-item {
    margin: 0;
    min-width: 0;
}

.personality-item img {
    display: block;
    width: 100%;
    aspect-ratio: 4 / 3;
    height: auto;
    object-fit: cover;
    object-position: center;
    border-radius: 12px;
    box-shadow: 0 6px 20px rgba(107, 143, 113, 0.14);
}

.personality-caption {
    margin: 0.55rem 0 0;
    font-family: 'Jost', sans-serif;
    font-size: 0.74rem;
    font-weight: 300;
    line-height: 1.5;
    color: var(--ap-muted);
}

@media (max-width: 980px) {
    .aboutPage-personality-inner {
        grid-template-columns: 1fr;
    }

    .aboutPage-personality-intro {
        max-width: 620px;
    }

    .personality-grid {
        grid-template-columns: repeat(3, minmax(140px, 1fr));
    }
}

@media (max-width: 620px) {
    .personality-grid {
        display: flex;
        gap: 0.85rem;
        overflow-x: auto;
        scroll-snap-type: x proximity;
        padding-bottom: 0.75rem;
    }

    .personality-item {
        flex: 0 0 72%;
        scroll-snap-align: start;
    }
}




/* ==========================================================
   Single Blog Post Refinements
   Scoped to .blogPostNew to avoid conflicts
   ========================================================== */

@import url('https://fonts.googleapis.com/css2?family=Atkinson+Hyperlegible:wght@400;700&family=Lora:wght@400;500;600&display=swap');

.blogPostNew {
    --bpn-font-sans: 'Atkinson Hyperlegible', system-ui, sans-serif;
    --bpn-font-serif: 'Lora', Georgia, serif;
}

/* Stronger post readability */
.blogPostNew p,
.blogPostNew li {
    font-family: var(--bpn-font-sans) !important;
    font-size: 17px !important;
    line-height: 1.85 !important;
    color: #1f211e !important;
}

.blogPostNew__title {
    font-family: var(--bpn-font-serif) !important;
    font-size: clamp(34px, 5vw, 48px) !important;
    line-height: 1.18 !important;
}

/* Featured image below title */
.blogPostNew__heroImage {
    width: min(80%, 760px);
    margin: 32px auto 0;
    border-radius: 14px;
    overflow: hidden;
}

.blogPostNew__heroImage img {
    display: block;
    width: 100%;
    height: auto;
}

/* Better bullet and ordered list spacing */
.blogPostNew__body ul,
.blogPostNew__body ol {
    margin: 0 0 28px 1.6rem !important;
    padding-left: 1.1rem !important;
}

.blogPostNew__body ul {
    list-style: disc !important;
}

.blogPostNew__body ol {
    list-style: decimal !important;
}

.blogPostNew__body li {
    display: list-item !important;
    margin-bottom: 12px !important;
    padding-left: 0.35rem !important;
    font-weight:300 !important;
}

.blogPostNew__body li::before {
    content: none !important;
}

/* Larger centered in-body images */
.blogPostNew__inlineImage,
.blogPostNew .wp-caption,
.blogPostNew__body figure {
    width: min(80%, 760px) !important;
    margin: 36px auto !important;
}

.blogPostNew__inlineImage img,
.blogPostNew__body figure img,
.blogPostNew .wp-caption img {
    width: 100% !important;
    height: auto !important;
    display: block;
}

/* Further Reading: horizontal polished cards */
.blogPostNew__furtherReading {
    max-width: 1020px;
    margin: 48px auto 72px;
    padding: 0 24px;
}

.blogPostNew__furtherReading-heading {
    font-family: var(--bpn-font-serif) !important;
    font-size: 32px !important;
    text-align: left !important;
    margin-bottom: 20px !important;
    color: #1f211e !important;
}

.blogPostNew__furtherReading-list {
    display: grid !important;
    grid-template-columns: repeat(3, 1fr);
    gap: 22px;
    list-style: none !important;
    margin: 0 !important;
    padding: 0 !important;
}

.blogPostNew__furtherReading-item {
    margin: 0 !important;
}

.blogPostNew__furtherReading-link {
    display: block;
    height: 100%;
    background: #ffffff;
    border: 1px solid #d8d5cc;
    border-radius: 14px;
    overflow: hidden;
    box-shadow: 0 8px 22px rgba(45, 74, 45, 0.08);
    text-decoration: none !important;
}

.blogPostNew__furtherReading-thumb img {
    width: 100%;
    aspect-ratio: 16 / 9;
    object-fit: cover;
    display: block;
}

.blogPostNew__furtherReading-meta {
    display: grid;
    gap: 6px;
    padding: 16px;
}

.blogPostNew__furtherReading-cat {
    font-size: 11px;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    color: #6b8f4e;
    font-weight: 700;
}

.blogPostNew__furtherReading-title {
    font-family: var(--bpn-font-serif);
    font-size: 18px;
    line-height: 1.35;
    color: #1f211e;
}

.blogPostNew__furtherReading-date {
    font-size: 13px;
    color: #6e736e;
}

@media (max-width: 760px) {
    .blogPostNew__furtherReading-list {
        grid-template-columns: 1fr;
    }

    .blogPostNew__heroImage,
    .blogPostNew__inlineImage,
    .blogPostNew .wp-caption,
    .blogPostNew__body figure {
        width: 100% !important;
    }
}


/* ==========================================================
   Further Reading Centering Fix
   Add at very bottom of style.css
   ========================================================== */

.blogPostNew > .blogPostNew__furtherReading {
    display: block !important;
    width: min(1020px, calc(100% - 48px)) !important;
    max-width: 1020px !important;
    margin: 56px auto 72px !important;
    padding: 24px !important;
    float: none !important;
    clear: both !important;
    box-sizing: border-box !important;
    background: #f7f6f2;
    border: 1px solid #d8d5cc;
    border-radius: 8px;
}

.blogPostNew__furtherReading-heading {
    margin: 0 0 22px !important;
}

.blogPostNew__furtherReading-list {
    display: grid !important;
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
    gap: 22px !important;
    width: 100% !important;
    margin: 0 !important;
    padding: 0 !important;
    list-style: none !important;
}

.blogPostNew__furtherReading-item {
    margin: 0 !important;
    padding: 0 !important;
    list-style: none !important;
}

@media (max-width: 760px) {
    .blogPostNew > .blogPostNew__furtherReading {
        width: calc(100% - 32px) !important;
        padding: 18px !important;
    }

    .blogPostNew__furtherReading-list {
        grid-template-columns: 1fr !important;
    }
}

/* ==========================================================
   Featured Blog Post Image Height Fix
   ========================================================== */

.blogHome-featured-card {
    align-items: stretch !important;
}

.blogHome-featured-img {
    height: 100% !important;
    min-height: 100% !important;
    display: flex !important;
}

.blogHome-featured-img img {
    width: 100% !important;
    height: 100% !important;
    object-fit: cover !important;
    display: block !important;
}


/* ==========================================================
   Homepage Service Icons
   Add at very bottom of style.css
   ========================================================== */

.homepage-service-header {
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    gap: 14px;
    text-align: center;
    min-height: 180px;
    padding: 24px 20px;
}

.homepage-service-header span {
    display: block;
    font-size: 1rem;
    line-height: 1.35;
    font-weight: 500;
    max-width: 220px;
}

.homepage-service-icon {
    width: 78px;
    height: 78px;
    border: 2px solid rgba(255,255,255,0.35);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    transition: all .25s ease;
}

.homepage-service-icon svg {
    width: 40px;
    height: 40px;
    stroke: #ffffff;
    stroke-width: 2;
    stroke-linecap: round;
    stroke-linejoin: round;
    fill: none;
}

.homepage-service-card:hover .homepage-service-icon {
    transform: translateY(-2px);
    border-color: rgba(255,255,255,0.75);
}

.homepage-service-card:hover .homepage-service-icon svg {
    transform: scale(1.05);
}

/* Mobile */

@media (max-width: 800px) {

    .homepage-service-header {
        min-height: auto;
        padding: 28px 20px;
    }

    .homepage-service-icon {
        width: 70px;
        height: 70px;
    }

    .homepage-service-icon svg {
        width: 36px;
        height: 36px;
    }
}


.homepage-blog-featured,
.homepage-recent-posts {
    max-width: 900px;
    margin: 0 auto;
    padding: 0 2rem 4rem;
}

.homepage-featured-post-link,
.homepage-featured-post-link:hover {
    text-decoration: none;
    color: inherit;
}

.homepage-featured-post-card {
    margin: 0 auto;
}

.homepage-featured-post-meta {
    font-size: 0.75rem;
    font-weight: 300;
    color: rgba(255,255,255,0.6);
    margin: 0.75rem 0 1rem;
    line-height: 1.4;
}

.homepage-recent-posts-grid {
    margin-top: 2rem;
}

.homepage-recent-post-card .blog-card-title {
    font-size: 1rem !important;
}

@media (max-width: 780px) {
    .homepage-blog-featured,
    .homepage-recent-posts {
        padding-left: 1.25rem;
        padding-right: 1.25rem;
    }

    .homepage-featured-post-card {
        grid-template-columns: 1fr;
    }
}


/* ==========================================
   About Page CTA Centering Fix
   ========================================== */

.aboutPage-cta {
    text-align: center;
}

.aboutPage-cta > * {
    max-width: 760px;
    margin-left: auto;
    margin-right: auto;
}

.aboutPage-cta-text {
    max-width: 760px;
    margin: 1.5rem auto 0;
    text-align: center;
}

.aboutPage-cta .aboutPage-hero-actions,
.aboutPage-cta .aboutPage-cta-actions {
    justify-content: center;
}

/* ==========================================================================
   New Digital Humanist Pagination Styling
   ========================================================================== */
.portfolio-pagination {
    text-align: center;
    margin: 50px auto;
    padding: 20px 0;
    clear: both;
}

.portfolio-pagination .page-numbers {
    display: inline-block;
    font-family: "Garamond", "Georgia", serif; /* Matches your humanist editorial font stack */
    font-size: 1.1rem;
    color: #2c4c38; /* Your brand forest green */
    padding: 8px 16px;
    margin: 0 4px;
    text-decoration: none;
    border: 1px solid #e1e6e3; /* Soft, subtle border */
    border-radius: 4px;
    transition: all 0.3s ease;
}

/* Hover State */
.portfolio-pagination a.page-numbers:hover {
    background-color: #2c4c38;
    color: #fcfbf9; /* Off-white/cream background color */
    border-color: #2c4c38;
}

/* Active/Current Page State */
.portfolio-pagination .page-numbers.current {
    background-color: #2c4c38;
    color: #fcfbf9;
    border-color: #2c4c38;
    font-weight: bold;
}

/* Disabled or Dots State (...) */
.portfolio-pagination .page-numbers.dots {
    border: none;
    color: #8a9a90;
}