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,hr,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,main,menu,nav,output,ruby,section,summary,time,mark,audio,video{font:inherit;font-size:100%;vertical-align:baseline;padding:0;border:0;margin:0}input,textarea,select,button{font:inherit;font-size:100%;outline:none}*,*:before,*:after{box-sizing:inherit}html{box-sizing:border-box}html{-webkit-text-size-adjust:100%;-ms-text-size-adjust:100%;text-size-adjust:100%}ol,ul{list-style:none}blockquote,q{quotes:none}blockquote::before,blockquote::after,q::before,q::after{content:none}table{border-collapse:collapse;border-spacing:0}img,svg{max-width:100%;max-height:100%}pre{max-width:100%;overflow:hidden}em{font-style:italic}strong{font-weight:bold}del{opacity:0.8;text-decoration:line-through}sub{font-size:0.875em;vertical-align:sub}sup{font-size:0.875em;vertical-align:super}


@font-face {
  font-family: 'Poppins';
  src: url('./fonts/Poppins-Regular.ttf') format('truetype');
  font-weight: normal;
  font-style: normal;
}

@font-face {
  font-family: 'Poppins';
  src: url('./fonts/Poppins-Bold.ttf') format('truetype');
  font-weight: bold;
  font-style: normal;
}

@font-face {
  font-family: 'Poppins';
  src: url('./fonts/Poppins-Italic.ttf') format('truetype');
  font-weight: normal;
  font-style: italic;
}

@font-face {
  font-family: 'Poppins';
  src: url('./fonts/Poppins-BoldItalic.ttf') format('truetype');
  font-weight: bold;
  font-style: italic;
}

@font-face {
  font-family: 'Poppins';
  src: url('./fonts/Poppins-Light.ttf') format('truetype');
  font-weight: 300;
  font-style: normal;
}

@font-face {
  font-family: 'Poppins';
  src: url('./fonts/Poppins-Medium.ttf') format('truetype');
  font-weight: 500;
  font-style: normal;
}


@font-face {
  font-family: 'fontello';
  src: url('./fonts/fontello.eot');
  src: url('./fonts/fontello.eot') format('embedded-opentype'),
       url('./fonts/fontello.woff2') format('woff2'),
       url('./fonts/fontello.woff') format('woff'),
       url('./fonts/fontello.ttf') format('truetype'),
       url('./fonts/fontello.svg') format('svg');
  font-weight: normal;
  font-style: normal;
}

 [class^="icon-"]:before, [class*=" icon-"]:before {
  font-family: "fontello";
  color: #27add3;
  font-style: normal;
  font-weight: normal;
  speak: none;

  display: inline-block;
  text-decoration: inherit;
  width: 1em;
  margin-right: .2em;
  text-align: center;
  /* opacity: .8; */

  /* For safety - reset parent styles, that can break glyph codes*/
  font-variant: normal;
  text-transform: none;

  /* fix buttons height, for twitter bootstrap */
  line-height: 1em;

  /* Animation center compensation - margins should be symmetric */
  /* remove if not needed */
  margin-left: .2em;

  /* you can be more comfortable with increased icons size */
  /* font-size: 120%; */

  /* Font smoothing. That was taken from TWBS */
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;

  /* Uncomment for 3D effect */
  /* text-shadow: 1px 1px 1px rgba(127, 127, 127, 0.3); */
}

.icon-picture:before { content: '\e800'; }
.icon-videocam:before { content: '\e801'; }
.icon-ok:before { content: '\e803'; }
.icon-apple:before { content: '\f179'; }
.icon-google:before { content: '\f1a0'; }
.icon-envelope-open:before { content: '\f2b6'; }
.icon-link-ext-alt:before{     content: '\f14c';  }
.icon-mobile:before {     font-size: 1.5em;   margin: 0;content: '\f10b'; }
.icon-link-ext-alt:before, .icon-apple:before, .icon-picture:before, .icon-google:before,
.icon-videocam:before {
    transition: color 0.4s ease;
    color: #aaa;
}

.fas:hover:before {
    color: #27add3;
}

body {
    font-family: "Poppins", "Open Sans", Helvetica, Arial, sans-serif;
    font-weight: 300;
    line-height: 1.45em;
    background-color: #11273c;
    color: #333;
}

section {
    padding: 1.5em 1.5em 1.5em 35px;
    border-bottom: 1px solid #dddddd;
    background-color: #ffffff;
}

section.highlights {
    padding: 0;
}

section.highlights > h1 {
    padding: 1.0em 0 1.0em 35px;
}

/* Filter navigation styling */
.filter-nav {
    padding: 0 35px 30px 35px;
    display: flex;
    gap: 4px;
    flex-wrap: wrap;
}

.filter-btn {
    padding: 0px 8px;
    border: 2px solid #27add3;
    border-radius: 20px;
    color: #27add3;
    text-decoration: none;
    font-size: 0.8em;
    font-weight: 500;
    transition: all 0.3s ease;
    background: transparent;
    border-radius: 0;
}

.filter-btn:hover,
.filter-btn.active {
    background: #27add3;
    color: white;
}

.project.hidden {
    display: none;
}


section.highlights>div.project>* {
    padding: 0 0 0 35px;
}
section.highlights>div.project>h3 {
    padding-bottom: 5px;
}
section.highlights>div.project>img {
    padding: 0;
}
h1 {
    font-size: 1.3em;
    font-weight: 600;
    padding: 0 0 0.3em 0;
    text-transform: uppercase;
}

h2 {
    font-size: 1.2em;
    font-weight: 500;
}

h3 {
    padding: 1em 0 1em 0;
    font-weight: 500;
    font-size: 0.8em;
    color: #000;
    margin-bottom: 4px;
}

h1 > span, h2 > span {
    display: block;
    color: #939393;
    font-size: 0.575em;
    line-height: 1.3em;
    margin-top: 5px;
    margin-bottom: 5px;
}

p {
    font-size: 0.9em;
    font-weight: 300;
}

strong {
    color: #27add3;
    text-transform: uppercase;
    font-weight: 500;
}

section img {
    width: 100%;
}

a {
    text-decoration: none;
    color: #27add3;
    font-weight: 500;
    transition: color 0.4s ease;
}

a:hover {
    color: #b74343;
}

span.light {
    font-weight: 200;
    text-transform: none;
}


div.more, details.more {
    font-size: 0.8em;
}

details.more {
    cursor: pointer;
    margin-top: 6px;
}

details.more summary:hover {
    text-decoration: underline
}

span.sub-project {
    text-transform: uppercase;
    font-weight: 500;
}

span.sub-project > span.small {
    font-weight: 200;
    color: #999;
    text-transform: initial;
}

span.tech {
    display: block;
    color: #939393;
    line-height: 1.3em;
    font-weight: 500;
    padding: 0 0 0.5em 0;
}

section.header {
    background: #efeeee;
    border-bottom: 4px solid #27add3;
    border-radius: 0;
    margin-top: 0;
}

section.footer {
    background: #efeeee;
    border-top: 4px solid #27add3;
}

section.header h1,
section.footer h1 {
    color: #27add3;
}

section.footer {
    border-radius: 0;
    margin-bottom: 0;
}

section.header p,
section.footer p,
section.introduction p,
section.info p {
    padding: 0 0 0.9em 0;
}

section.introduction p:last-of-type,
section.info p:last-of-type {
    padding: 0;
}

section.introduction > img {
    border-radius: 15px;
    width: 50%;
    max-width: 265px;
    margin: 0 0 1em 0;
}

section.skills > p {
    padding: 0 0 1em 0;
    font-weight: 500;
    color: #aaa;
}

section.skills > p:last-of-type {
    padding: 0;
}

section.languages > p > img {
    width: 50%;
    max-width: 200px;
}

div.address {
    padding: 0;
    font-size: 0.9em;
}

div.address > h2 {
    font-weight: 500;
}

div.address > p {
    line-height: 1.3em;
    font-weight: 200;
}

div.address > p.contact {
    font-size: 0.9em;
}


div.availability {
    font-size: 0.75em;
    line-height: 1.3em;
}

div.availability label {
    display: inline-block;
    min-width: 7em;
    color: #aaa;
}

div.project {
    border-bottom: 1px solid #dddddd;
    margin-bottom: 2.0em;
    padding-bottom: 1.5em;
}

div:last-of-type.project {
    border-bottom: 0;
    margin-bottom: 0;
    padding-bottom: 0;
}
div.project > h2 {
    color: #27add3;
}

div.project > h3 {
    color: #aaa;
    line-height: 1.3em;
}

div.project span.client {
    color: #b9b9b9;
    font-size: 1.0em;
    display: block;
    padding-right: 10px;
    float: right;
}

div.project div.spacing {
    margin: 10px 0 0 0;
    border-top: 1px solid #eee;
    padding-top: 20px;
}

div.project > img {
    padding: 0 0;
}

/* Image Modal */

.modal-image {
    cursor: pointer;
}

.modal {
    display: none;
    position: fixed;
    z-index: 1;
    padding-top: 3em;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    overflow: auto;
    background-color: rgb(0,0,0);
    background-color: rgba(0,0,0,0.8);
    overflow: hidden;
}

.modal-content {
    margin: auto;
    display: block;
    width: 90%;
    border-radius: 10px;
    max-width: 1024px;
    max-height: inherit;

    -webkit-animation-name: zoom;
    -webkit-animation-duration: 0.6s;
    animation-name: zoom;
    animation-duration: 0.6s;
}

@-webkit-keyframes zoom {
    from {-webkit-transform:scale(0)}
    to {-webkit-transform:scale(1)}
}

@keyframes zoom {
    from {transform:scale(0)}
    to {transform:scale(1)}
}

#modal-close {
    position: absolute;
    top: 15px;
    right: 35px;
    color: #bbb;
    font-size: 40px;
    font-weight: bold;
    transition: 0.3s;
}

#modal-close:hover,
#modal-close:focus {
    color: #f1f1f1;
    text-decoration: none;
    cursor: pointer;
}

/* Widescreen */

@media (min-width: 480px)
{
    body {
        font-size: 1.25em;
    }
}

@supports (display: grid) {
    @media (min-width: 720px)
    {
        body {

            max-width: 1100px;
            margin: auto;

            display: grid;
            grid-template-columns: auto 15em;
            grid-template-areas:
                "header header"
                "intro intro"
                "services services"
                "projects skills"
                "projects awards"
                "projects languages"
                "projects misc"
                "projects customers"
                "info info"
                "footer footer";
            grid-template-rows: .0fr .0fr .0fr .0fr .0fr .0fr .0fr 1fr .0fr .0fr;
        }

        .filter-btn {
            padding: 4px 16px;
            border: 2px solid #27add3;
            border-radius: 20px;
            color: #27add3;
            text-decoration: none;
            font-size: 0.9em;
            font-weight: 500;
            transition: all 0.3s ease;
            background: transparent;
            border-radius: 0;
        }

        section.skills, section.awards, section.languages, section.misc,
        section.customers {
            background: #eeeeee;
        }

        section.skills p,
        section.awards p,
        section.languages p,
        section.misc div {
            font-size: 0.75em;
            line-height: 1.3em;    }

        section.customers p {
            font-size: 0.65em;
            line-height: 1.3em;
        }

        section.customers h1 > span {
            font-size: 0.40em;
        }

        section.header {
            grid-area: header;
            display: grid;
            grid-template-columns: auto 8em;
        }

        section.header h1 {
            grid-column: span 2
        }

        div.availability {
            align-self: end;
        }

        div.address > p.contact {
            padding: 0;
        }

        section.introduction {
            grid-area: intro;
            display: block;
        }

        section.introduction img {
            width: 10em;
            margin: 0.25em 1em 1em 0;
            display: block;
            max-height: inherit;
            float: left;
        }

        section.services {
            grid-area: services;
            display: block;
        }

        section.highlights {
            grid-area: projects;
            display: block;
        }

        section.skills {
            grid-area: skills;
        }

        section.awards {
            grid-area: awards;
        }

        section.awards img {
            border-radius: 5px;
            padding: 5px;
            background: #fff;
        }

        section.languages {
            grid-area: languages;
        }

        section.misc {
            grid-area: misc;
        }

        section.customers {
            grid-area: customers;
        }

        section.info {
            grid-area: info;
        }

        section.footer {
            grid-area: footer;
        }
    }
}

section.services ul {
    padding-left: 0em;
    list-style-type: none;
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
    gap: 1em;
}

section.services li {
    font-size: 0.9em;
    line-height: 1.3em;
    color: #333333;
    position: relative;
    margin-bottom: 0.5em;
    display: flex;
    flex-direction: column;
}

section.services li {
    margin-bottom: 1em;
}

@media (min-width: 720px) {
    section.services ul {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media print {
    section {
        border: 0;
        padding: 0.5em;
    }

    section.footer {
        display: none;
    }

    section.header {
        margin-top: 0;
        padding-top: 0;
        padding-bottom: 0.5em;
    }

    section.introduction>img {
        border-radius: 15px;
        width: 50%;
        max-width: 105px;
        margin: 0.2em 1em 0 0;
        float: left;
    }

    section.customers,
    section.awards,
    section.misc {
        display: none;
    }

    /* Hide filter navigation when printing */
    .filter-nav {
        display: none !important;
    }

    /* Ensure hidden projects don't print */
    .project.hidden {
        display: none !important;
    }

    /* Reset project transitions for print */
    .project {
        opacity: 1 !important;
        transform: none !important;
    }
}
