/*-----
Dark Blue: #253F5B
Light Blue:#016F8E
Orange: #FBAA21

------*/
html{
    scroll-behavior: smooth;
    font-size: var(--rootFontSize);
}
:root{

    /*--Spacing--*/
    --spacing8:8px;
    --spacing16:16px;
    --spacing20:20px;
    --spacing36:36px;
    --spacing48:48px;
    --spacing64:64px;

    /*--Neutrals--*/
    --white-FFFFFF:#ffffff;
    --grey-FCFCFE:#FCFCFE;
    --grey-FEFAFA:#FEFAFA;
    --grey-F4F4F4:#f4f4f4;
    --grey-DEDEDE:#dedede;
    --grey-888888:#888888;
    --grey-666666:#666666;
    --grey-222222:#222222;
    --grey-282828:#282828;
    --grey-121212:#121212;
    --grey-1E201F:#1E201F;
    
    /*--Red--*/
    --red-881B12:#881b12;
    --red-E83525:#e83525;
    --red-EC8E85:#ec8e85;
    --red-FDBDB8:#FDBDB8;
    --red-FFDEDB:#FFDEDB;
    --red-FFEBEA:#FFEBEA;
    
    /*--Blue--*/
    --blue-001C2D:#001c2d;
    --blue-082838:#082838;
    --blue-005694:#005694;
    --blue-0178CE:#0178CE;
    --blue-54ADED:#54aded;
    --blue-71C4FF:#71c4ff;
    --blue-DBF0FF:#DBF0FF;

    /*--Yellow--*/
    --yellow-A67200:#A67200;
    --yellow-FFE7B5:#FFE7B5;

    /*--Font--*/
    --fontFamilyPrimary: "DM Serif Text", serif;
    --fontFamilySecondary: "Nunito Sans", sans-serif;

    --fontWeightPrimaryRegular: 400;
    --fontWeightSecondaryRegular: 300;
    --fontWeightSecondaryBold: 500;
    --fontWeightSecondaryBlack: 700;

    


    /*----Background---*/
    --backgroundLightPrimary: var(--grey-FCFCFE);
    --backgroundLightSecondary: var(--grey-F4F4F4);
    --backgroundLightAccent: var(--blue-DBF0FF);
    --backgroundLightAccent2: var(--red-FFEBEA);
    --backgroundDarkPrimary: var(--grey-1E201F);
    --backgroundDarkSecondary: var(--grey-282828);
    --backgroundDarkAccent: var(--blue-0178CE);
    --backgroundDarkAccent2: var(--red-E83525);

    /*----Border---*/
    --borderLightPrimary: var(--grey-DEDEDE);
    --borderDarkPrimary: var(--grey-666666);

    /*----Text---*/
    --textLightPrimary: var(--white-FFFFFF);
    --textLightSecondary: var(--grey-F4F4F4);
    --textDarkPrimary: var(--grey-1E201F);
    --textDarkSecondary: var(--grey-282828);

    /*----Interactive---*/
    --interactiveDarkPrimaryIdle: var(--red-881B12);
    --interactiveDarkPrimaryHover: var(--red-881B12);
    --interactiveDarkPrimaryActive: var(--red-881B12);
    --interactiveDarkPrimaryDisabled: var(--grey-666666);

    --interactiveDarkSecondaryIdle: var(--blue-001C2D);
    --interactiveDarkSecondaryHover: var(--blue-001C2D);
    --interactiveDarkSecondaryActive: var(--blue-001C2D);
    --interactiveDarkSecondaryDisabled: var(--grey-666666);

    --interactiveLightPrimaryIdle: var(--red-FFDEDB);
    --interactiveLightPrimaryHover: var(--red-FFEBEA);
    --interactiveLightPrimaryActive: var(--red-FFEBEA);
    --interactiveLightPrimaryDisabled: var(--grey-DEDEDE);

    --interactiveLightSecondaryIdle: var(--white-FFFFFF);
    --interactiveLightSecondaryHover: var(--white-FFFFFF);
    --interactiveLightSecondaryActive: var(--white-FFFFFF);
    --interactiveLightSecondaryDisabled: var(--grey-DEDEDE);

    --interactiveLightPrimaryFocus: var(--yellow-FFE7B5);
    --interactiveDarkPrimaryFocus: var(--yellow-A67200);


    /*----Radius---*/
    --border-full: 1000em;
    --border-20: 20px;
    --border-10: 10px;
    --border-8: 8px;
    --border-5: 5px;
    --border-4: 4px;

    /*----Typography---*/
    --TextXXHuge:5.9rem;
    --TextXHuge:4.8rem;
    --TextHuge:3.8rem;
    --TextXXL:3rem;
    --TextXL:2.4rem;
    --TextL:1.9rem;
    --TextM:1.5;
    --TextBase:1rem;
    --TextS:0.8rem;
    --TextXS:0.6rem;

    --TextH1Color:var(--textDarkPrimary);
    --TextH2Color:var(--textDarkPrimary);
    --TextH3Color:var(--textDarkPrimary);
    --TextH4Color:var(--textDarkPrimary);
    --TextH5Color:var(--textDarkPrimary);
    --TextH6Color:var(--textDarkPrimary);
    --TextBodyColor:var(--textDarkSecondary);

    /*----Button---*/
    --buttonPadding:12px 24px;

    /*----Content Card---*/
    --cardContentBackgroundColor:var(--backgroundLightSecondary);
    --cardContentBorderRadius:var(--border-10);
    --cardContentTextHeadline:var(--textDarkPrimary);
    --cardContentTextBody:var(--textDarkSecondary);

    /*----Grid---*/
    --grid1Column: repeat(1 ,1fr);
    --grid2Column: repeat(2 ,1fr);
    --grid3Column: repeat(3 ,1fr);
    --grid4Column: repeat(4 ,1fr);

}

@media screen and (max-width:699px) {
    :root{
        /*----Typography---*/
        --rootFontSize:14px;
        --TextH1Size:var(--TextHuge);
        --TextH2Size:var(--TextXXL);
        --TextH3Size:var(--TextXL);
        --TextH4Size:var(--TextL);
        --TextH5Size:var(--TextM);
        --TextH6Size:var(--TextS);
        --TextBodySize:var(--TextBase);
        
        /*----Spacing---*/
        --spacingS:8px;
        --spacingM:16px;
        --spacingL:20px;
        --spacingXL:24px;
        --spacingXXL:36px;
        --spacingHuge:48px;
        --spacingXHuge:64px;

        /*----Section---*/
        --sectionPaddingSidesY:36px;

        /*----Container---*/
        --containerPaddingSidesX:3vw;

        /*----Grid---*/
        --gridGapX:16px;

        /*----Content Card---*/
        --cardContentPadding:16px 16px;

        /*----Navigation---*/
        --headerPaddingSidesY: 8px;
    }
}

@media screen and (min-width:700px) and (max-width:1199px) {
    :root{
        /*----Typography---*/
        --rootFontSize:14px;
        --TextH1Size:var(--TextHuge);
        --TextH2Size:var(--TextXXL);
        --TextH3Size:var(--TextXL);
        --TextH4Size:var(--TextL);
        --TextH5Size:var(--TextM);
        --TextH6Size:var(--TextS);
        --TextBodySize:var(--TextBase);

        /*----Spacing---*/
        --spacingS:8px;
        --spacingM:16px;
        --spacingL:20px;
        --spacingXL:24px;
        --spacingXXL:36px;
        --spacingHuge:48px;
        --spacingXHuge:64px;

        /*----Section---*/
        --sectionPaddingSidesY:48px;

        /*----Container---*/
        --containerPaddingSidesX:5vw;

        /*----Grid---*/
        --gridGapX:24px;

        /*----Content Card---*/
        --cardContentPadding:16px 16px;

        /*----Navigation---*/
        --headerPaddingSidesY: 8px;
    }
}

@media screen and (min-width:1199px) {
    :root{
        /*----Typography---*/
        --rootFontSize:16px;
        --TextH1Size:var(--TextXHuge);
        --TextH2Size:var(--TextHuge);
        --TextH3Size:var(--TextXL);
        --TextH4Size:var(--TextL);
        --TextH5Size:var(--TextM);
        --TextH6Size:var(--TextS);
        --TextBodySize:var(--TextBase);

        /*----Spacing---*/
        --spacingS:16px;
        --spacingM:20px;
        --spacingL:24px;
        --spacingXL:36px;
        --spacingXXL:48px;
        --spacingHuge:64px;
        --spacingXHuge:80px;

        /*----Section---*/
        --sectionPaddingSidesY:100px;

        /*----Container---*/
        --containerPaddingSidesX:24px;

        /*----Grid---*/
        --gridGapX:36px;

        /*----Content Card---*/
        --cardContentPadding:24px 24px;

        /*----Navigation---*/
        --headerPaddingSidesY: 16px;
    }
}


/*-------------------*/
/*-------------------*/
/*----Start Styles---*/
/*-------------------*/
/*-------------------*/

*{
    box-sizing:border-box;
}
body{
    font-family: var(--fontFamilySecondary);
    font-weight: var(--fontWeightSecondaryRegular);
    margin:0 auto;
    width:100%;
    font-size: var(--rootFontSize);
    font-style: normal;
    font-optical-sizing: auto;
    background-color: var(--backgroundLightPrimary);

}
h1, h2, h3, h4{
    margin:0;
}
h1{
    font-family: var(--fontFamilyPrimary);
    font-weight: var(--fontWeightPrimaryRegular);
    font-size: var(--TextH1Size);
    margin-bottom: .5em;
    color: var(--TextH1Color);
    line-height: 120%;
}
h2{
    font-family: var(--fontFamilyPrimary);
    font-weight: var(--fontWeightPrimaryRegular);
    font-size: var(--TextH2Size);
    margin-bottom: .25em;
    color: var(--TextH2Color);
    line-height: 120%;
}
h3{
    font-family: var(--fontFamilySecondary);
    font-weight: var(--fontWeightSecondaryBlack);
    font-size: var(--TextH3Size);
    margin-bottom: .25em;
    color: var(--TextH3Color);
    line-height: 120%;
}
h4{
    font-family: var(--fontFamilySecondary);
    font-weight: var(--fontWeightSecondaryBold);
    font-size: var(--TextH4Size);
    margin-bottom: .2em;
    color: var(--TextH4Color);
    line-height: 120%;
}
h5{
    font-family: var(--fontFamilySecondary);
    font-weight: var(--fontWeightSecondaryBold);
    font-size: var(--TextH5Size);
    margin-bottom: .2em;
    color: var(--TextH5Color);
    line-height: 120%;
}
h6{
    font-family: var(--fontFamilySecondary);
    font-weight: var(--fontWeightSecondaryBold);
    font-size: var(--TextH6Size);
    margin-bottom: .2em;
    color: var(--TextH6Color);
    line-height: 120%;
}
p{
    font-size: var(--TextBodySize);
    color: var(--TextBodyColor);
    line-height: 150%;
    margin-top:0;
    font-weight: 400;
    margin-bottom: 0.2em;
}

ul, ol{
    font-size: var(--TextBodySize);
    color: var(--TextBodyColor);
    line-height: 150%;
    margin-top:0;
    font-weight: 400;
    margin-bottom: 0.2em;
}

ul li:not(:last-child), ol li:not(:last-child){
    margin-bottom:.4em;
}





a:focus-visible{
    outline: solid 4px var(--interactiveDarkPrimaryFocus);
    outline-offset: 2px;
}
a.inverted:focus-visible{
    outline: solid 4px var(--interactiveLightPrimaryFocus);
}


/*=================================*/
/*=============SPACING==============*/
/*=================================*/

:is(p, ul, ol):has(+ .button){
    margin-bottom: var(--spacingL);
}

p:has(+ p){
    margin-bottom: var(--spacingL);
}
p:has(+ ul, + ol){
    margin-bottom: var(--spacingM);
}

.button + .button{
    margin-bottom: var(--spacingM);
}

/*=================================*/
/*=============LAYOUT==============*/
/*=================================*/

section{
    padding: var(--sectionPaddingSidesY) 0;
}

.container{
    width:100%;
    max-width: 1728px;
    padding: 0 var(--containerPaddingSidesX);
    margin:0 auto;
}

.content-container{
    display: flex;
    flex-direction: column;
    gap:var(--sectionPaddingSidesY);
}


[class*="grid"]{
    width: 100%;
}



/*=============GRID==============*/
.grid{
    display: grid;
    gap: var(--gridGapX);
}

.align-center{
    align-items: center;
}


@media screen and (max-width:699px){

    .grid.m1{
        grid-template-columns: var(--grid1Column);
    }
    .grid.m2{
        grid-template-columns: var(--grid2Column);
    }

    

}

@media screen and (min-width:700px) and (max-width:1199px){

    .grid.t1{
        grid-template-columns: var(--grid1Column);
    }
    .grid.t2{
        grid-template-columns: var(--grid2Column);
    }
    .grid.t3{
        grid-template-columns: var(--grid3Column);
    }
    .grid.t4{
        grid-template-columns: var(--grid4Column);
    }

}
@media screen and (min-width:1200px){

    p{
        max-width: 952px;
    }
    .grid.d1{
        grid-template-columns: var(--grid1Column);
    }
    .grid.d2{
        grid-template-columns: var(--grid2Column);
    }
    .grid.d3{
        grid-template-columns: var(--grid3Column);
    }
    .grid.d4{
        grid-template-columns: var(--grid4Column);
    }

    [class*="grid"].grid-reverse :nth-child(2){
        grid-column: 1;
        grid-row: 1;
    }
    [class*="grid"].grid-reverse :first-child{
        grid-column: 2;
        grid-row: 1;
    }

}

/*=================================*/
/*=============RATIOS==============*/
/*=================================*/


.ratio-1-1{
    aspect-ratio: 1/1;
}
.ratio-5-3{
    aspect-ratio: 5/3;
}
.ratio-16-19{
    aspect-ratio: 16/9;
}
.ratio-21-9{
    aspect-ratio: 21/9;
}


@media screen and (max-width:699px){

    .m-ratio-1-1{
    aspect-ratio: 1/1;
    }
    .m-ratio-5-3{
        aspect-ratio: 5/3;
    }
    .m-ratio-16-19{
        aspect-ratio: 16/9;
    }
    .m-ratio-21-9{
        aspect-ratio: 21/9;
    }

}

@media screen and (min-width:700px) and (max-width:1199px){

    .t-ratio-1-1{
    aspect-ratio: 1/1;
    }
    .t-ratio-5-3{
        aspect-ratio: 5/3;
    }
    .t-ratio-16-19{
        aspect-ratio: 16/9;
    }
    .t-ratio-21-9{
        aspect-ratio: 21/9;
    }

}
@media screen and (min-width:1200px){

    .d-ratio-1-1{
    aspect-ratio: 1/1;
    }
    .d-ratio-5-3{
        aspect-ratio: 5/3;
    }
    .d-ratio-16-19{
        aspect-ratio: 16/9;
    }
    .d-ratio-21-9{
        aspect-ratio: 21/9;
    }

}


/*=================================*/
/*=============BACKGROUND==========*/
/*=================================*/

.bg-dark-primary{
    background-color: var(--backgroundDarkPrimary);
    color:var(--textLightPrimary);
}

.bg-dark-secondary{
    background-color: var(--backgroundDarkSecondary);
    color:var(--textLightPrimary);
}

.bg-dark-accent{
    background-color: var(--backgroundDarkAccent);
    color:var(--textLightPrimary);
}

.bg-light-primary{
    background-color: var(--backgroundLightPrimary);
}

.bg-light-secondary{
    background-color: var(--backgroundLightSecondary);
}

.bg-light-accent{
    background-color: var(--backgroundLightAccent);
}

/*=================================*/
/*=============Text==========*/
/*=================================*/


:is(h1, h2, h3, h4, h5, h6).light {
    color: var(--textLightPrimary);
}

:is(p, ul, ol).light{
    color: var(--textLightSecondary);
}


/*=================================*/
/*=============IMAGES==========*/
/*=================================*/
img{
    width: 100%;
    border-radius: var(--border-10);
}

.cover{
    object-fit: cover;
}
.contain{
    object-fit: contain;
}

.object-position-center{
    object-position: center center;
}


/*=================================*/
/*=============Divider==============*/
/*=================================*/

section.divider{
    padding:0;
}

hr{
    border-color: var(--borderLightPrimary);
    width: 100%;
}

/*=================================*/
/*=============BUTTONS==============*/
/*=================================*/


.button{
    text-align: center;
    display: block;
    transition: all .3s ease;
    -webkit-transition: all .3s ease;
    -moz-transition: all .3s ease;
    -o-transition: all .3s ease;
    font-weight: var(--fontWeightSecondaryBlack);
    text-decoration: none;
    width: fit-content;
    min-height: 44px;
    min-width: 44px;
    letter-spacing: .02em;
}

.button:focus-visible{
    outline: solid 4px var(--interactiveDarkPrimaryFocus);
    outline-offset: 2px;
}


.button.primary{
    background:var(--interactiveDarkPrimaryIdle);
    color:var(--textLightPrimary);
    border-radius: var(--border-full);
    padding:12px 20px;
    border: solid 2px var(--interactiveDarkPrimaryIdle);
}

.button.primary:hover, .button.primary:focus-visible{
    background:var(--interactiveLightSecondaryHover);
    color:var(--interactiveDarkPrimaryHover);
    border-color: var(--interactiveDarkPrimaryHover);
}

.button.primary:active{
    background:var(--interactiveLightSecondaryActive);
    color:var(--interactiveDarkPrimaryActive);
    border-color: var(--interactiveDarkPrimaryActive);
}

.button.primary:disabled{
    background:var(--interactiveDarkPrimaryDisabled);
    color:var(--textLightPrimary);
    border-color: var(--interactiveDarkPrimaryDisabled);
}


.button.primary.light{
    background:var(--interactiveLightSecondaryIdle);
    color:var(--interactiveDarkPrimaryIdle);
    border-color: var(--interactiveLightSecondaryIdle);
}

.button.primary.light:hover, .button.primary:focus-visible{
    background:var(--interactiveDarkPrimaryHover);
    color:var(--textLightPrimary);
    border-color: var(--interactiveLightPrimaryHover);
}

.button.primary.light:focus-visible{
    outline-color: var(--interactiveLightPrimaryFocus);
}

.button.primary.light:active{
    background:var(--interactiveDarkPrimaryActive);
    color:var(--textLightPrimary);
    border-color: var(--interactiveLightPrimaryActive);
}

.button.primary.light:disabled{
    background:var(--interactiveLightPrimaryDisabled);
    color:var(--textDarkPrimary);
    border-color: var(--interactiveLightPrimaryDisabled);
}


/*-----Secondary-----*/


.button.secondary{
    background:transparent;
    color:var(--interactiveDarkPrimaryIdle);
    border-radius: var(--border-full);
    padding:12px 20px;
    border: solid 2px var(--interactiveDarkPrimaryIdle);
}

.button.secondary:hover, .button.secondary:focus-visible{
    background:var(--interactiveDarkPrimaryHover);
    color:var(--interactiveLightSecondaryHover);
    border-color: var(--interactiveDarkPrimaryHover);
}

.button.secondary:active{
    background:var(--interactiveDarkPrimaryActive);
    color:var(--interactiveLightSecondaryActive);
    border-color: var(--interactiveDarkPrimaryActive);
}

.button.secondary:disabled{
    background:transparent;
    color:var(--interactiveDarkPrimaryDisabled);
    border-color: var(--interactiveDarkPrimaryDisabled);
}


.button.secondary.dark{
    color:var(--interactiveDarkSecondaryIdle);
    border-color: var(--interactiveDarkSecondaryIdle);
}

.button.secondary.dark:hover, .button.secondary.dark:focus-visible{
    background:var(--interactiveDarkSecondaryHover);
    color:var(--interactiveLightSecondaryHover);
    border-color: var(--interactiveDarkSecondaryHover);
}

.button.secondary.dark:active{
    background:var(--interactiveDarkSecondaryActive);
    color:var(--interactiveLightSecondaryActive);
    border-color: var(--interactiveDarkSecondaryActive);
}

.button.secondary.dark:disabled{
    background:transparent;
    color:var(--interactiveDarkSecondaryDisabled);
    border-color: var(--interactiveDarkSecondaryDisabled);
}



.button.secondary.light{
    color:var(--interactiveLightSecondaryIdle);
    border-color: var(--interactiveLightSecondaryIdle);
}

.button.secondary.light:hover, .button.secondary.light:focus-visible{
    background:var(--interactiveLightSecondaryHover);
    color:var(--interactiveDarkSecondaryHover);
    border-color: var(--interactiveLightSecondaryHover);
}

.button.secondary.light:active{
    background:var(--interactiveLightSecondaryActive);
    color:var(--interactiveDarkSecondaryActive);
    border-color: var(--interactiveLightSecondaryActive);
}

.button.secondary.light:disabled{
    background:transparent;
    color:var(--interactiveLightSecondaryDisabled);
    border-color: var(--interactiveLightSecondaryDisabled);
}


/*-----Tertiary-----*/


.button.tertiary{
    color:var(--interactiveDarkPrimaryIdle);
    display: flex;
    align-items: center;
    border-bottom: solid 2px transparent;
}

.button.tertiary:hover, .button.tertiary:focus-visible{
    color:var(--interactiveDarkPrimaryHover);
    border-color: var(--interactiveDarkPrimaryHover);
}

.button.tertiary:active{
    color:var(--interactiveDarkPrimaryActive);
    border-color: var(--interactiveDarkPrimaryActive);
}

.button.tertiary:disabled{
    color:var(--interactiveDarkPrimaryDisabled);
    border-color: var(--interactiveDarkPrimaryDisabled);
}



@media screen and (max-width:699px){

   :is(.primary, .secondary).button{
    width:100%;
   }

}


/*=================================*/
/*=============Content Card==============*/
/*=================================*/

/*-----Card layout-----*/

.card.content{
    background: var(--cardContentBackgroundColor);
    border-radius: var(--cardContentBorderRadius);
    text-decoration: none;
    overflow: hidden;
}

.card.content.clickable{
    display:flex;
    flex-direction: column;
}


.card.content.clickable:focus-visible{
    outline: solid 4px var(--interactiveDarkPrimaryFocus);
}

.card.content.clickable .button{
    width:fit-content;
}

.card.content.clickable:hover .tertiary-btn, .card.content.clickable:focus-visible .tertiary-btn{
    color: var(--interactiveDarkPrimaryHover);
}

[class*="grid"] .card.content{
    height:100%;
}

.card.content .text .icon{
    max-width: 64px;
    margin-bottom: 1em;
}

@media screen and (min-width:1199px){

   .card.content.horizontal{
    flex-direction: row;
   }

   .card.content.horizontal :is(.img-container){
        aspect-ratio: 1/1 !important;
   }

   .card.content.horizontal .text{
    display: flex;
    flex-direction: column;
        height:auto;
        justify-content: center;
        align-items: flex-start;
   }
   .card.content.horizontal .text :is(h4, p, span){
        height:auto;
   }

   .card.content.horizontal :is(.img-container, .text){
        width:50%;
        
   }
   .card.content .text .icon{
        max-width: 100px;
    }


}


/*-----Card text-----*/

.card.content .text :is(h3, h4){
    color:var(--cardContentTextHeadline);
    font-size: var(--TextH4Size);
}

.card.content .text :is(p, ol, ul){
    color:var(--cardContentTextBody);
}

.card.content .text{
    padding:var(--cardContentPadding);
    display: grid;
}

.card.content .text :last-child{
    margin-bottom: 0;
}

.card.content .text :is(h3, h4, span){
    width:100%;
}

.card.content .text :is(h3, h4):has(+ span.btn){
    margin-bottom: 1.2em;
}

.card.content.data{
    text-align: center;
}

.card.content.data .text :is(h3, h4){
    font-size: var(--TextXXHuge);
    font-family: var(--fontFamilyPrimary);
    font-weight: var(--fontWeightPrimaryRegular);
}

/*-----Card image-----*/

.card.content .img-container{
    width:100%;
    aspect-ratio: 5/3;
    overflow: hidden;
}

.card.content .img-container img{
    width: 100%;
    height:100%;
    display: block;
    object-fit: cover !important;
    transition: all .2s ease;
    border-radius:0px;
}

/*=================================*/
/*=============About==============*/
/*=================================*/


@media screen and (min-width:700px){
    .about .special{
        grid-column: 1/3;
    }
}


/*=================================*/
/*=============Header==============*/
/*=================================*/


/*=============Header==============*/

header{
    position: sticky;
    padding:var(--headerPaddingSidesY) 0;
    z-index: 100000;
}


.header-grid{
    display: flex;
    align-items: center;
    width: 100%;
}

header .logo{
    width:100%;
}

header .logo img{
    width:100%;
    filter: invert(1);
}

header .nav-icon{
    width:44px;
    height:44px;
    display: flex;
    flex-direction: column;
    align-items: flex-end;
    justify-content: center;
    gap: 6px;
    padding:7px;
    cursor: pointer;
    transition: all .2s ease;
    -webkit-transition: all .2s ease;
    -moz-transition: all .2s ease;
    -o-transition: all .2s ease;
    position: relative;
    border:none;
    background:transparent;
}



header .nav-icon:hover div{
    background-color: var(--interactiveDarkPrimaryHover);
}

header .nav-icon::before{
    content:'MENU';
    display:block;
    position:absolute;
    left:0%;
    text-align: right;
    transition: all .2s ease;
    -webkit-transition: all .2s ease;
    -moz-transition: all .2s ease;
    -o-transition: all .2s ease;
    opacity: 0;
    font-size: var(--TextXS);
    color:var(--interactiveDarkSecondaryIdle);
}


header .nav-icon.close::before{
    content:'CLOSE';
    color: var(--interactiveLightSecondaryIdle);
}

header .nav-icon:hover::before, header .nav-icon:focus-visible::before{
    opacity: 1;
    left:-80%;
    color:var(--interactiveDarkPrimaryHover);
}



header .nav-icon:focus-visible{
    outline: solid 4px var(--interactiveDarkPrimaryFocus);
    outline-offset: 0px;
    border-radius: 5px;
}
header .nav-icon.close:focus-visible{
    outline-color:var(--interactiveLightPrimaryFocus);
}

header .nav-icon div{
    background-color: var(--interactiveDarkSecondaryIdle);
    height:2px;
    border-radius: 20em;
    transition: all .2s ease;
    -webkit-transition: all .2s ease;
    -moz-transition: all .2s ease;
    -o-transition: all .2s ease;
}

header .nav-icon div:first-child{
    width:100%;
}
header .nav-icon div:nth-child(2){
    width:80%;
}
header .nav-icon div:nth-child(3){
    width:60%;
}
header .nav-icon:hover div{
    width:100%;
}


header .nav-icon.close {
    align-items: center;

}

header .nav-icon.close div:nth-child(3){
    width:100%;
    opacity: 0;
}


header .nav-icon.close div:first-child{
    width:28px;
    position: absolute;
    transform: rotate(-45deg);

}
header .nav-icon.close div:nth-child(2){
    width:28px;
    position: absolute;
    transform: rotate(45deg);
}





header .nav-icon.close div{
    background-color: var(--interactiveLightSecondaryIdle);
}

header .nav-icon.close::before{
    content:'CLOSE';
    color: var(--interactiveLightSecondaryIdle);
}

header .nav-icon.close:hover::before, header .nav-icon.close:focus-visible::before{
    color: var(--interactiveLightSecondaryHover);
}

@media screen and (max-width:699px) {
    header .logo img{
        max-width: 200px;
    }
    header .logo {
        width:100%;
        display: flex;
        justify-content: center;
    }
    header .logo::before{
    width:44px;
    content:'';
    display: inline-block;

}
}
@media screen and (min-width:700px) and (max-width:1199px){
    header .logo img{
        max-width: 250px;
    }
}
@media screen and (min-width:1200px) {
    header .logo img{
        max-width: 325px;
    }
}


/*=============Nav==============*/
[data-aos] {
  z-index: 0 !important;
}

nav{
    position: fixed;
    width:100vw;
    height:100vh;
    right: -100vw;
    opacity: 0;
    visibility:hidden;
    opacity: 0;
    top:0;
    transition: all .6s ease;
    -webkit-transition: all .6s ease;
    -moz-transition: all .6s ease;
    -o-transition: all .6s ease;
     z-index: 99999;
    isolation: isolate;
}



nav.active{
    width:100vw;
    visibility: visible;
    right:0;
    opacity: 1;
    
}

nav .overlay{
    background-color: rgba(0,0,0,0.0);
    transition: all .6s ease;
    -webkit-transition: all .6s ease;
    -moz-transition: all .6s ease;
    -o-transition: all .6s ease;
    z-index: -2;
}

nav.active .overlay{
}

nav .container{
    display: flex;
    justify-content: flex-end;
    position: relative;
    
}

.navigation-container{
    background-color:  var(--backgroundDarkPrimary);
    background:  linear-gradient(0deg, var(--backgroundDarkPrimary) 0%, var(--backgroundDarkSecondary) 100%);
    width:100%;
}

.navigation-container .close-container{
    padding-top:var(--headerPaddingSidesY);
    padding-bottom:var(--headerPaddingSidesY);
    display: flex;
    justify-content: flex-end;
    align-items: center;
}

.navigation-container::after{
    content:'';
    display: block;
    height:100vh;
    background-color:  var(--backgroundDarkPrimary);
    background:  linear-gradient(0deg, var(--backgroundDarkPrimary) 0%, var(--backgroundDarkSecondary) 100%);
    position: fixed;
    right:0;
    top:0;
    z-index: -1;
    transition: all .6s ease;
    -webkit-transition: all .6s ease;
    -moz-transition: all .6s ease;
    -o-transition: all .6s ease;
    width:0px;
}



nav .container .link-list{
    height: 100vh;
    width:100%;
    display: flex;
    flex-direction: column;
    gap: var(--spacingXL);
    z-index: 101;
    padding-top: var(--spacingL);
}

nav .container .link-list a{
    color:var(--interactiveLightSecondaryIdle);
    text-decoration: none;
    font-family: var(--fontFamilyPrimary);
    font-weight: var(--fontWeightPrimaryRegular);
    position: relative;
    transition: all .2s ease;
    -webkit-transition: all .2s ease;
    -moz-transition: all .2s ease;
    -o-transition: all .2s ease;
}

nav .container .link-list a:focus-visible{
    outline-color:var(--interactiveLightPrimaryFocus);
}

nav .container .link-list a::before{
    content:'';
    width:8px;
    height:100%;
    position:absolute;
    background-color:transparent;
    transition: all .2s ease;
    -webkit-transition: all .2s ease;
    -moz-transition: all .2s ease;
    -o-transition: all .2s ease;
    border-radius: 0 40px 40px 0;
}

nav .container .link-list a:hover::before, nav .container .link-list a:focus-visible::before{
    background-color:var(--interactiveDarkPrimaryIdle);
}

nav .container .link-list :is(a:hover, a:focus-visible) {
    color:var(--interactiveLightPrimaryHover);
    text-decoration: none;
}

body.no-scroll{
    overflow: hidden;
}

@media screen and (max-width:699px) {
    nav .container .link-list a{
        font-size: var(--TextH4Size);
    }
    nav{
        background-color:  var(--backgroundDarkPrimary);
        background:  linear-gradient(0deg, var(--backgroundDarkPrimary) 0%, var(--backgroundDarkSecondary) 100%);
    }
    nav .container .link-list a::before{
        left:-3vw;
    }
}
@media screen and (min-width:700px) and (max-width:1199px){
    nav .container .link-list a{
        font-size: var(--TextH4Size);
    }
    nav{
        background-color:  var(--backgroundDarkPrimary);
        background:  linear-gradient(0deg, var(--backgroundDarkPrimary) 0%, var(--backgroundDarkSecondary) 100%);
    }
    nav .container .link-list a::before{
        left:-5vw;
    }
}
@media screen and (min-width:1200px) {
    nav .container .link-list a{
        font-size: var(--TextH3Size);
    }
    nav .navigation-container{
        max-width: 600px;
    }
    nav .navigation-container .close-container{
        height:calc(81.81px + var(--headerPaddingSidesY) + var(--headerPaddingSidesY));
    }
    nav .container .link-list{
        padding-left:48px;
        max-width: 600px;
    }
    nav .container .link-list a::before{
        left:-48px;
    }
    nav.active .navigation-container::after{
         width: calc(50vw - 300px);
    }
}


/*=================================*/
/*=============Footer==============*/
/*=================================*/


footer{
    padding: var(--sectionPaddingSidesY) 0;
    background: var(--backgroundDarkSecondary);
    color: var(--textLightPrimary);
}

footer .grid div:first-child img{
    width:100%;
    max-width: 250px;
    margin-bottom: var(--spacingXL);
    display: block;
}

footer .grid p{
    font-size: var(--TextS);
    color: var(--textLightPrimary);
}

footer .title{
    font-family: var(--fontFamilyPrimary);
    font-weight: var(--fontWeightPrimaryRegular);
    font-size: var(--TextH4Size);
    margin-bottom: var(--spacingL);
    display: block;
}
footer .link-list{
    display: flex;
    flex-direction: column;
    gap: var(--spacingL);
}

footer .link-list a{
    text-decoration: none;
    color: var(--interactiveLightSecondaryIdle);
    border-left:solid 0px transparent;
    transition:all .2s ease;
    width: fit-content;
}

footer .link-list a:hover, footer .link-list a:focus-visible{
    color: var(--interactiveLightPrimaryHover);
    border-left:solid 4px var(--interactiveLightPrimaryHover);
    padding-left: 8px;
}

footer .link-list a:focus-visible{
    outline-color: var(--interactiveLightPrimaryFocus);
}

footer .link-list a:active{
    color: var(--interactiveLightPrimaryActive);
    border-left:solid 4px var(--interactiveLightPrimaryActive);
    padding-left: 8px;
}

footer .social{
    display: flex;
    gap: var(--spacingL);
}
footer .social a{
    width:24px;
    height:24px;
    position: relative;
}

footer .social a img{
    width:100%;
    border-radius: 0px;
}

footer .social a:focus-visible{
    outline-color: var(--interactiveLightPrimaryFocus);
    outline-offset: 8px;
}

footer .social a::before{
    content: '';
    width:30px;
    height:30px;
    border-radius: 5px;
    border:solid 3px transparent;
    position: absolute;
    top:50%;
    left:50%;
    transform: translate(-50%, -50%);
    transition:all .2s ease;
    -webkit-transition:all .2s ease;
    -moz-transition:all .2s ease;
    -o-transition:all .2s ease;
}
footer .social a:hover::before, footer .social a:focus-visible::before{
    border-color: var(--interactiveLightPrimaryHover);
}



footer .social a:active::before{
    border-color: var(--interactiveLightPrimaryActive);
}

footer .content-container{
    gap:var(--spacingXL);
}


footer hr{
    opacity: 0.25;
}


@media screen and (max-width:699px){


    footer .grid div:nth-child(2) {
        margin-bottom: var(--spacingXL);

    }

}





.brighten-10{
    filter: saturate(0) brightness(1.1);
    -webkit-filter: saturate(0) brightness(1.1);
}

section.hero{
    z-index: 1;
    
}

.hero .container {
      height:100%;
}

.hero h1 {
    position: relative; /* Keep this if you need positioning context for other elements */
    line-height: 120%;
    margin-bottom: .2em;
}

.hero p {
    font-size: 1.2rem;
    line-height: 150%;
}

@media screen and (min-width:1199px) {
    .hero h1{
        line-height: 130%;
        margin-bottom: .2em;
    }
    .hero p {
    font-size: 1.4rem;
    line-height: 150%;
}
}






.hero h1 span {
    position: relative;
    display: inline-block; /* Ensures the span wraps tightly around the text */
    
}

.hero h1 span.blue::after {
    content: '';
    display: block;
    position: absolute;
    width: 106%; /* Matches the width of the span (text width due to inline-block) */
    height: 90%;
    background-color: var(--backgroundDarkAccent);
    opacity: 0.2;
    left: -3%; /* Aligns with the start of the span */
    bottom: 5%; /* Positions the pseudo-element just below the text */
    z-index: 1;
    border-radius: 10px;
}

.hero h1 span.red::after {
    content: '';
    display: block;
    position: absolute;
    width: 106%;
    height: 90%;
    background-color: var(--backgroundDarkAccent2); /* Adjust color if needed */
    opacity: 0.2;
    left: -3%;
    bottom: 5%;
    z-index: 1;
    border-radius:10px;
}





