/*
 * SPDX-License-Identifier: Apache-2.0
 * Copyright Blazebit
 */

/*
 * HTML5 Boilerplate
 *
 * What follows is the result of much research on cross-browser styling.
 * Credit left inline and big thanks to Nicolas Gallagher, Jonathan Neal,
 * Kroc Camen, and the H5BP dev community and team.
 */


/* =============================================================================
   HTML5 element display
   ========================================================================== */

article, aside, details, figcaption, figure, footer, header, hgroup, nav, section { display: block; }
audio[controls], canvas, video { display: inline-block; *display: inline; *zoom: 1; }


/* =============================================================================
   Base
   ========================================================================== */

/*
 * 1. Correct text resizing oddly in IE6/7 when body font-size is set using em units
 *    http://clagnut.com/blog/348/#c790
 * 2. Force vertical scrollbar in non-IE
 * 3. Remove Android and iOS tap highlight color to prevent entire container being highlighted
 *    www.yuiblog.com/blog/2010/10/01/quick-tip-customizing-the-mobile-safari-tap-highlight-color/
 * 4. Prevent iOS text size adjust on device orientation change, without disabling user zoom
 *    www.456bereastreet.com/archive/201012/controlling_text_size_in_safari_for_ios_without_disabling_user_zoom/
 */

html { font-size: 100%; -webkit-overflow-scrolling: touch; -webkit-tap-highlight-color: rgba(0,0,0,0); -webkit-text-size-adjust: 100%; -ms-text-size-adjust: 100%; }

body { background-color: #fff; margin: 0; font-size: 13px; line-height: 1.231; }

body, button, input, select, textarea { font-family:"proxima", Verdana, sans-serif; font-weight:200; font-style:normal; color: #000; }

/* 
 * These selection declarations have to be separate
 * No text-shadow: twitter.com/miketaylr/status/12228805301
 * Also: hot pink!
 */

::-moz-selection { background: #0999c7; color: #fff; text-shadow: none; }
::selection { background: #0999c7; color: #fff; text-shadow: none; }


/* =============================================================================
   Links
   ========================================================================== */

a { color: #3299B8; text-decoration: none; }
a:hover, a:focus { color: #2985a0;  }

a:focus { outline: thin dotted; }

/* Improve readability when focused and hovered in all browsers: people.opera.com/patrickl/experiments/keyboard/test */
a:hover, a:active { outline: 0; }


/* =============================================================================
   Typography
   ========================================================================== */

abbr[title] { border-bottom: 1px dotted; }

b, strong { font-weight: bold; }

blockquote { margin: 1em 40px; }

dfn { font-style: italic; }

hr { display: block; height: 1px; border: 0; border-top: 1px solid #ccc; margin: 1em 0; padding: 0; }

ins { background: #ff9; color: #000; text-decoration: none; }

mark { background: #ff0; color: #000; font-style: italic; font-weight: bold; }

/* Redeclare monospace font family: en.wikipedia.org/wiki/User:Davidgothberg/Test59 */
pre, code, kbd, samp { font-family: monospace, monospace; _font-family: 'courier new', monospace; font-size: 1em; }

/* Improve readability of pre-formatted text in all browsers */
pre { white-space: pre; white-space: pre-wrap; word-wrap: break-word; }

q { quotes: none; }
q:before, q:after { content: ""; content: none; }

small { font-size: 85%; }

/* Position subscript and superscript content without affecting line-height: gist.github.com/413930 */
sub, sup { font-size: 75%; line-height: 0; position: relative; vertical-align: baseline; }
sup { top: -0.5em; }
sub { bottom: -0.25em; }


/* =============================================================================
   Lists
   ========================================================================== */

ul, ol { margin: 1em 0; padding: 0 0 0 40px; }
dd { margin: 0 0 0 40px; }
nav ul, nav ol { list-style: none; margin: 0; padding: 0; }


/* =============================================================================
   Embedded content
   ========================================================================== */

/*
 * Improve image quality when scaled in IE7
 * code.flickr.com/blog/2008/11/12/on-ui-quality-the-little-things-client-side-image-resizing/
 */

img { border: 0; -ms-interpolation-mode: bicubic; }

/*
 * Correct overflow displayed oddly in IE9 
 */

svg:not(:root) {
    overflow: hidden;
}


/* =============================================================================
   Figures
   ========================================================================== */

figure { margin: 0; }


/* =============================================================================
   Forms
   ========================================================================== */

form { margin: 0; }
fieldset { border: 0; margin: 0; padding: 0; }

/* 
 * 1. Correct color not inheriting in IE6/7/8/9 
 * 2. Correct alignment displayed oddly in IE6/7 
 */

legend { border: 0; *margin-left: -7px; padding: 0; }

/* Indicate that 'label' will shift focus to the associated form element */
label { cursor: pointer; }

/*
 * 1. Correct font-size not inheriting in all browsers
 * 2. Remove margins in FF3/4 S5 Chrome
 * 3. Define consistent vertical alignment display in all browsers
 */

button, input, select, textarea { font-size: 100%; margin: 0; vertical-align: baseline; *vertical-align: middle; }

/*
 * 1. Define line-height as normal to match FF3/4 (set using !important in the UA stylesheet)
 * 2. Correct inner spacing displayed oddly in IE6/7
 */

button, input { line-height: normal; *overflow: visible; }

/*
 * 1. Display hand cursor for clickable form elements
 * 2. Allow styling of clickable form elements in iOS
 */

button, input[type="button"], input[type="reset"], input[type="submit"] { cursor: pointer; -webkit-appearance: button; }

/*
 * Consistent box sizing and appearance
 */

input[type="checkbox"], input[type="radio"] { box-sizing: border-box; }
input[type="search"] { -moz-box-sizing: content-box; -webkit-box-sizing: content-box; box-sizing: content-box; }

/* 
 * Remove inner padding and border in FF3/4
 * www.sitepen.com/blog/2008/05/14/the-devils-in-the-details-fixing-dojos-toolbar-buttons/ 
 */

button::-moz-focus-inner, input::-moz-focus-inner { border: 0; padding: 0; }

/* Remove default vertical scrollbar in IE6/7/8/9 */
textarea { overflow: auto; vertical-align: top; }

/* Colors for form validity */
input:valid, textarea:valid {  }
input:invalid, textarea:invalid { background-color: #f0dddd; }


/* =============================================================================
   Tables
   ========================================================================== */

table { border-collapse: collapse; border-spacing: 0; }


/* =============================================================================
   Primary styles
   Author: 
   ========================================================================== */




small, .small {
  font-size: inherit !important
}



/* =============================================================================
   Non-semantic helper classes
   Please define your styles before this section.
   ========================================================================== */

/* For image replacement */
.ir { display: block; text-indent: -999em; overflow: hidden; background-repeat: no-repeat; text-align: left; direction: ltr; }
.ir br { display: none; }

/* Hide for both screenreaders and browsers:
   css-discuss.incutio.com/wiki/Screenreader_Visibility */
.hidden { display: none; visibility: hidden; }

/* Hide only visually, but have it available for screenreaders: by Jon Neal.
  www.webaim.org/techniques/css/invisiblecontent/  &  j.mp/visuallyhidden */
.visuallyhidden { border: 0; clip: rect(0 0 0 0); height: 1px; margin: -1px; overflow: hidden; padding: 0; position: absolute; width: 1px; }

/* Extends the .visuallyhidden class to allow the element to be focusable when navigated to via the keyboard: drupal.org/node/897638 */
.visuallyhidden.focusable:active, .visuallyhidden.focusable:focus { clip: auto; height: auto; margin: 0; overflow: visible; position: static; width: auto; }

/* Hide visually and from screenreaders, but maintain layout */
.invisible { visibility: hidden; }

/* Contain floats: nicolasgallagher.com/micro-clearfix-hack/ */ 
.clearfix:before, .clearfix:after { content: ""; display: table; }
.clearfix:after { clear: both; }
.clearfix { zoom: 1; }



/* =============================================================================
   PLACEHOLDER Media Queries for Responsive Design.
   These override the primary ('mobile first') styles
   Modify as content requires.
   ========================================================================== */

@media only screen and (min-width: 480px) {
  /* Style adjustments for viewports 480px and over go here */

}

@media only screen and (min-width: 768px) {
  /* Style adjustments for viewports 768px and over go here */

}

* { text-rendering: optimizeLegibility; }

h1, h2, h3 { margin: 0; }


.fl { float: left; display: inline; }
.fr { float: right; }

.icon { -webkit-transition: background .2s ease-in; }
.icon.location { background: url(../images/icon_location.v202509040933070451.png) no-repeat; }
.icon.phone { background: url(../images/icon_phone.v202509040933070451.png) no-repeat; }
.icon.mail { background: url(../images/icon_mail.v202509040933070451.png) no-repeat; }
.icon.googleplus { background: url(../images/icon_google.v202509040933070451.png) no-repeat; }
    .icon.googleplus:hover { background: url(../images/icon_google_blue.v202509040933070451.png) no-repeat; }
.icon.facebook { background: url(../images/icon_facebook.v202509040933070451.png) no-repeat; }
    .icon.facebook:hover { background: url(../images/icon_facebook_blue.v202509040933070451.png) no-repeat; }
.icon.flickr { background: url(../images/icon_flickr.v202509040933070451.png) no-repeat; }
    .icon.flickr:hover { background: url(../images/icon_flickr_blue.v202509040933070451.png) no-repeat; }
.icon.delicious { background: url(../images/icon_delicious.v202509040933070451.png) no-repeat; }
    .icon.delicious:hover { background: url(../images/icon_delicious_blue.v202509040933070451.png) no-repeat; }


.sprite { background: url(../images/sprite.v202509040933070451.png) no-repeat top left; }

.sprite-bouncing-preview-icon{ background-position: 0 0; width: 41px; height: 41px; } 
.sprite-icon_delicious{ background-position: 0 -46px; width: 30px; height: 30px; } 
.sprite-icon_delicious_blue{ background-position: 0 -81px; width: 30px; height: 30px; } 
.sprite-icon_facebook{ background-position: 0 -116px; width: 30px; height: 30px; } 
.sprite-icon_facebook:hover { background-position: 0 -151px; width: 30px; height: 30px; } 
.sprite-icon_flickr{ background-position: 0 -186px; width: 30px; height: 30px; } 
.sprite-icon_flickr:hover { background-position: 0 -221px; width: 30px; height: 30px; } 
.sprite-icon_geomarker{ background-position: 0 -256px; width: 19px; height: 24px; } 
.sprite-icon_google{ background-position: 0 -285px; width: 30px; height: 30px; } 
.sprite-icon_google_blue{ background-position: 0 -320px; width: 30px; height: 30px; } 
.sprite-icon_location{ background-position: 0 -355px; width: 16px; height: 12px; } 
.sprite-icon_macos{ background-position: 0 -372px; width: 30px; height: 30px; } 
.sprite-icon_mail{ background-position: 0 -407px; width: 19px; height: 24px; } 
.sprite-icon_mobile{ background-position: 0 -436px; width: 19px; height: 24px; } 
.sprite-icon_next_project{ background-position: 0 -465px; width: 112px; height: 56px; } 
.sprite-icon_next_project_hover{ background-position: 0 -526px; width: 56px; height: 56px; } 
.sprite-icon_phone{ background-position: 0 -587px; width: 16px; height: 12px; } 
.sprite-icon_prev_project{ background-position: 0 -604px; width: 112px; height: 56px; } 
.sprite-icon_services_branding{ background-position: 0 -665px; width: 56px; height: 35px; } 
.sprite-icon_services_developing{ background-position: 0 -705px; width: 56px; height: 35px; } 
.sprite-icon_services_facebook{ background-position: 0 -745px; width: 37px; height: 37px; } 
.sprite-icon_services_seo{ background-position: 0 -787px; width: 41px; height: 37px; } 
.sprite-icon_services_smartphone{ background-position: 0 -829px; width: 37px; height: 37px; } 
.sprite-icon_services_webdesign{ background-position: 0 -871px; width: 56px; height: 35px; } 
.sprite-icon_services_wordpress{ background-position: 0 -911px; width: 37px; height: 37px; } 
.sprite-icon_skype{ background-position: 0 -953px; width: 30px; height: 30px; } 
.sprite-icon_testimonial{ background-position: 0 -988px; width: 31px; height: 25px; } 
.sprite-icon_windows{ background-position: 0 -1018px; width: 30px; height: 30px; } 
.sprite-icon_xing{ background-position: 0 -1053px; width: 30px; height: 30px; } 
.sprite-logo{ background-position: 0 -1088px; width: 402px; height: 113px; } 
.sprite-project_thumb_bg{ background-position: 0 -1206px; width: 360px; height: 250px; } 
.sprite-service_icon{ background-position: 0 -1461px; width: 67px; height: 63px; } 




/* =============================================================================
   Print styles.
   Inlined to avoid required HTTP connection: www.phpied.com/delay-loading-your-print-css/
   ========================================================================== */
 
@media print {
  * { background: transparent !important; color: black !important; text-shadow: none !important; filter:none !important; -ms-filter: none !important; } /* Black prints faster: sanbeiji.com/archives/953 */
  a, a:visited { color: #444 !important; text-decoration: underline; }
  a[href]:after { content: " (" attr(href) ")"; }
  abbr[title]:after { content: " (" attr(title) ")"; }
  .ir a:after, a[href^="javascript:"]:after, a[href^="#"]:after { content: ""; }  /* Don't show links for images, or javascript/internal links */
  pre, blockquote { border: 1px solid #999; page-break-inside: avoid; }
  thead { display: table-header-group; } /* css-discuss.incutio.com/wiki/Printing_Tables */
  tr, img { page-break-inside: avoid; }
  img { max-width: 100% !important; }
  @page { margin: 0.5cm; }
  p, h2, h3 { orphans: 3; widows: 3; }
  h2, h3{ page-break-after: avoid; }
}

p { color: #555; font-size: 1.1em; line-height: 24px; margin: 0 0 20px 0; }
.clearfix:after {
    content: ".";
    display: block;
    clear: both;
    visibility: hidden;
    line-height: 0;
    height: 0;
}

@keyframes fadein {
    0% {
        opacity: 0;
    }
    100% {
        opacity: 1;
    }
}
 
@-webkit-keyframes fadein {
    0% {
        opacity: 0;
    }
    100% {
        opacity: 1;
    }
}

@-moz-keyframes fadein {
    0% {
        opacity: 0;
    }
    100% {
        opacity: 1;
    }
}

#content-wrapper {
    animation: fadein .5s ease-in 1;
    -moz-animation: fadein .5s ease-in 1;
    -webkit-animation: fadein .5s ease-in 1;
    -o-animation: fadein .5s ease-in 1;
}

dl dd {
  margin-left: 0;
}

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

.show-mobile { display: none; }

.slicknav_menu { display: none; visibility: hidden; }



#header-wrapper {
    background: #0994c4 url(../images/bg_header.v202509040933070451.jpg) repeat-x;
    background-attachment: fixed;
    background-size: auto;
    background-position: center top;
    height: 500px;;
}
    #header-wrapper.small { height: 90px; }

    #top-wrapper { background: rgba(0,0,0,.0); width: 100%; float: left; display: inline; }
        #top-wrapper .inner { width: 1080px; margin: 0 auto; }
    #content-wrapper, footer { margin: 0 auto; width: 1080px;}
        #logo { float: left; margin: 17px auto; text-align: left; width: 90px; }
    #header-wrapper nav { float: right; margin-top: 34px;}
    #header-wrapper nav li { float: left; display: inline; margin-left: 40px; position: relative; }
    #header-wrapper nav li:first-child { margin-left: 0; }
        #header-wrapper nav a { font-weight: 100; color: #fff; font: normal normal 1.1em "Montserrat"; font-size: 1em; letter-spacing: .1em; text-transform: uppercase; }
        #header-wrapper nav .current a { font-family: "Montserrat"; border-bottom: 2px solid rgba(255,255,255,.85); padding-bottom: 7px; text-decoration: none; }
    
    #header-wrapper #headline { 
        font-size: 7.8em; 
        color: rgba(255,255,255,1); 
        text-transform: uppercase; 
        float: left; 
        display: inline; 
        width: 100%; 
        margin-top: 80px;
        letter-spacing: -1px;
        text-shadow: 4px 4px 0px rgba(2, 67, 88, 0.45);
    }
        #headline .first-word, #headline .last-word { display: block; font-family: "Jura", Georgia, serif; font-size: 0.5em; text-transform: none; letter-spacing: 1px; }
        #headline .last-word { font-size: 0.7em; }
        #headline .keyword-placeholder { display: inline-block; text-align: left; visibility: hidden; }
        #headline .keyword { font-family: Nevis; position: relative; font-size: 1.05em; text-shadow: 7px 7px 0px rgba(2, 67, 88, 0.45); letter-spacing: 0.03em; }
        #headline .links { display: block; top: 20px; position: relative; font-size: 0.1em; text-shadow: none; letter-spacing: 0.03em; }
        #headline .button {
            border-radius: 0px;
            -webkit-border-radius: 0px;
            -moz-border-radius: 0px;

            padding: 15px 15px;
                font-weight: bold;
    font-size: 1.2em;
    letter-spacing: 0.1em;
            background: rgba(16, 62, 76, 0.84);
            color: #fff;
        }
        #headline-cursor { 
            width: 4px;
            background: rgba(255, 255, 255, 0.48);
            height: 110px;
            display: inline-block;
            position: relative;
            top: 13px;
            right: -2px;
        }
h1, h2, h3 { font: normal normal 2.6em "Montserrat"; }
h1 { font-size: 3em; color: #1F93B8; margin-bottom: 30px; text-align: center; }
h2 { color: #1F93B8; font-size: 2.4em; text-transform: uppercase; margin-bottom: 20px; text-align: center; font-weight: bold; letter-spacing: 1px; }
h3 { font: normal normal 1.5em "Montserrat"; color: #0E87AD; letter-spacing: .05em; margin-bottom: 25px; padding-bottom: 15px; border-bottom: 1px dotted #ccc; text-transform: uppercase; font-weight: bold; }
.tCenter { text-align: center; }
.tJustify { text-align: justify; }
    .tCenter a.more { margin-left: 10px; }
.tLeft { text-align: left; }
ul.no-style { margin: 0; padding: 0; }
    ul.no-style li { list-style-type: none; list-style-image: none; }
ul.features { margin: 0; padding: 0; }
    ul.features li { list-style-type: initial; list-style-image: initial; margin-left: 14px; }
a.more { background: url(../images/icon_more.v202509040933070451.png) no-repeat right; padding: 8px 22px 5px 0; -webkit-transition: all .2s ease-in; }
    a.more:hover, a.more:focus {  }
.skype { background: url(../images/icon_skype.v202509040933070451.png) no-repeat center; }
.macos { background: url(../images/icon_macos.v202509040933070451.png) no-repeat center; }
.windows { background: url(../images/icon_windows.v202509040933070451.png) no-repeat center; }
.xing { background: url(../images/icon_xing.v202509040933070451.png) no-repeat center; }


/* Infinite pulsating border */

.pulsating-border, .pulsating-border-hover:hover {
    box-shadow: 0px 0px 0px 2px rgba(21,168,205, 0);
    
    border-radius: 50px;
    -webkit-border-radius: 50px;
    -moz-border-radius: 50px;
                    
    -webkit-animation-name: pulsate;
    -webkit-animation-duration: 1.5s;
    -webkit-animation-timing-function: ease-out;
    -webkit-animation-iteration-count: infinite;
}
            
@-webkit-keyframes pulsate {
    0% { box-shadow: 0px 0px 0px 2px rgba(21,168,205, .0); }
    50% { box-shadow: 0px 0px 0px 5px rgba(21,168,205, .4); }
    100% { box-shadow: 0px 0px 0px 2px rgba(21,168,205, .0); }
}

/* END - Infinite pulsating border */

.news-post {
    float: left;
    width: 100%;
    margin-bottom: 50px;
}

.news-post .head-image {
    display: block;
    float: left;
    padding-right: 20px;
    padding-bottom: 10px;
    width: 8%;
    min-width: 64px;
}

.news-post .head-image img {
  border-radius: 100px;
}

.post-title {
  float: left;
  width: 92%;
}

@media only screen and (min-width : 320px) and (max-width : 1000px) {
    .post-title {
        /* Firefox */
        width: -moz-calc(99% - 64px);
        /* WebKit */
        width: -webkit-calc(99% - 64px);
        /* Opera */
        width: -o-calc(99% - 64px);
        /* Standard */
        width: calc(99% - 64px);
    }
}

.post-title:after {
    content: "\A";
    white-space: pre;
}

.post-title h3 {
    margin-bottom: 5px;
    border-bottom: none;
    padding-bottom: 0px;
}

.icon-workaround {
  background: url(../images/workaround_icon.v202509040933070451.png) no-repeat center center;
  width: 102px !important;
  height: 38px !important;
  margin-top: 0px !important;
  background-size: contain;
}

.icon-comfortable {
  background: url(../images/comfortable_icon.v202509040933070451.png) no-repeat center center;
  width: 102px !important;
  height: 38px !important;
  margin-top: 0px !important;
  background-size: contain;
}

.icon-sql {
  background: url(../images/sql_icon.v202509040933070451.png) no-repeat center center;
  width: 102px !important;
  height: 38px !important;
  margin-top: 0px !important;
  background-size: contain;
}

.icon-dto-mapping {
    background: url(../images/dto_mapping_icon.v202509040933070451.png) no-repeat center center;
    width: 102px !important;
    height: 38px !important;
    margin-top: 0px !important;
    background-size: contain;
}

.icon-efficiency {
    background: url(../images/efficiency_icon.v202509040933070451.png) no-repeat center center;
    width: 102px !important;
    height: 38px !important;
    margin-top: 0px !important;
    background-size: contain;
}

.news-post .post-content {
  clear: left; 
  margin-top: 40px;
}

#teaser { margin-top: 45px; }
#page-title { clear: both; margin-top: 20px; float: left; display: inline; }
    #page-title h1, #page-title h2 { color: #fff; text-transform: uppercase; letter-spacing: 1px; font-size: 2.6em; margin: 30px 0; text-shadow: 1px 1px 1px rgba(0,0,0,.1); font-weight: normal; }
    #page-title a { color: #fff; font-style: normal; }
    #page-title a:hover { border-bottom: 2px solid #fff; } 
    #page-title.single-project-title h1 { background: url(../images/project_title_slash.v202509040933070451.png) no-repeat left; padding-left: 40px; margin: 30px 0 30px 30px !important; }
    #page-title.single-project-title h1, #page-title.single-project-title h2 { float: left; display: inline; }
    
    #team-intro { margin: 50px 0 0 0; }
        #team-intro .single-person { float: left; display: inline; width: 510px; }
        #team-intro .single-person:first-child { margin-right: 60px; }
            #team-intro .single-person .left-column, #team-intro .single-person .right-column { display: block; text-align: center; }
                #team-intro .head-image { border-radius: 50px; display: inline-block; height: 95px; position: relative; width: 95px; margin-bottom: 20px; }
                #team-intro .head-image::after{
                    border-radius: 50px;
                    position: absolute;
                    top: 0;
                    bottom: 0;
                    left: 0;
                    right: 0;
                    content: "";
                    z-index: 2;
                    pointer-events: none; /* "all" disables mouse access to image */
                    box-shadow: inset 0 1px 3px rgba(0, 0, 0,.3);
                    -moz-box-shadow: inset 0 1px 3px rgba(0, 0, 0,.3);
                    -webkit-box-shadow: inset 0 1px 3px rgba(0, 0, 0,.3);
                }
                    #team-intro .head-image img { border-radius: 50px; }
                #team-intro .social-icons { margin: 0 auto; width: 110px; }
                    #team-intro .social-icons li { float: left; display: inline; margin-left: 10px; }
                    #team-intro .social-icons li:first-child { margin-left: 0; }
                        #team-intro .icon { display: block; height: 30px; width: 30px; }
            #team-intro h3 { }
                #team-intro .responsibilities { color: #0E87AD; font-family: "Montserrat", sans-serif; letter-spacing: 0.05em; text-transform: uppercase; }

    .contactpage-wrapper .content { display: inline-block; width: 100%; }
        .contactpage-wrapper .content .h { display: inline-block; }
            .contactpage-wrapper p { margin: 0; }
            .contactpage-wrapper p.intro { margin-bottom: 25px; }
#contactpage-infos, #contactpage-social { float: left; display: inline; padding: 5px 0 30px 0px; width: 505px; }
#contactpage-infos { margin-right: 70px; }
    .our-services { margin-top: -25px; display: inline-block; }
    .our-services-short ul { margin-top: 10px; display: inline-block; float: left; }
        .our-services-short li, .our-services li { float: left; width: 320px; margin-right: 60px; }
        .our-services-short li:nth-child(3n), .our-services li:nth-child(3n) { margin-right: 0; }
            .our-services-short li a, .our-services li { padding-top: 20px; display: block; font-style: normal; }
            .our-services li { margin-bottom: 20px; }
            .our-services-short h3, .our-services h3 { margin-bottom: 25px; }
            .our-services-short .sprite, .our-services .sprite { display: block; margin: 0px auto 17px auto; text-indent: -9999px; height: 38px; width: 56px; }
    .our-services-commercial ul { margin-top: 10px; display: inline-block; float: left; }
        .our-services-commercial li, .our-services li { float: left; width: 230px; margin-right: 40px; }
        .our-services-commercial li:nth-child(4n), .our-services li:nth-child(4n) { margin-right: 0; }
            .our-services-commercial li a, .our-services li { padding-top: 20px; display: block; font-style: normal; }
            .our-services-commercial h3, .our-services h3 { margin-bottom: 25px; }
            .our-services-commercial .sprite, .our-services .sprite { display: block; margin: 0px auto 17px auto; text-indent: -9999px; height: 38px; width: 56px; }

.contactpage-wrapper form { display: inline-block; margin-top: 30px; width: 100%; }

.contactpage-wrapper .success { display: inline-block; float: left; width: 100%; color: #0E87AD; font: normal normal 1.5em "Montserrat"; text-transform: uppercase; font-weight: bold; letter-spacing: .05em; padding: 60px 0; text-align: center; }

#social-networks { display: inline-block; width: 75px; }
    #contactpage-social #social-networks li { margin-left: 15px; }
.title h2 { float: left; display: inline; }
.title .more { background: url(../images/icon_more.v202509040933070451.png) no-repeat right 4px; float: right; padding: 5px 22px 5px 0; }

#content { padding: 40px 0; }
    #content h2 { margin-bottom: 10px; }            
#contactpage-intro, #page-intro { margin-top: 40px; float: left; display: inline; width: 100%; }
    #page-intro p { width: 80%; margin: 0 auto; }
    .project-wrapper { margin-top: 50px; }
    .project-wrapper .project-single-wrapper { 
        float: left; 
        display: inline; 
        height: 250px; 
        width: 360px;
        -webkit-perspective: 640px; 
        -moz-perspective: 640px;
        perspective: 640px;
        
        -webkit-perspective-origin: 50% 50%; 
        -moz-perspective-origin: 50% 50%; 
        perspective-origin: 50% 50%; 
        
        -webkit-transform-style: preserve-3d; 
        -moz-transform-style: preserve-3d; 
        transform-style: preserve-3d; 
    }
        .project-single {  
            height: 250px; 
            width: 360px;
            position: relative;
            -webkit-transition: all .2s linear;
            -moz-transition: all .2s linear;
            -transition: all .2s linear;
            
            -webkit-transform-style: preserve-3d;
            -moz-transform-style: preserve-3d;
            transform-style: preserve-3d;
            
            -webkit-transform: matrix3d(1, 0, 0, 0, 0, 1, 0, 0, 0, 0, -1, 0, 0, 0, -125, 1);
            -moz-transform: matrix3d(1, 0, 0, 0, 0, 1, 0, 0, 0, 0, -1, 0, 0, 0, -125px, 1);
            transform: matrix3d(1, 0, 0, 0, 0, 1, 0, 0, 0, 0, -1, 0, 0, 0, -125, 1);
        }
        .cssmatrix3dtransformation .project-single-wrapper a:hover .project-single { 
            -webkit-transform: matrix3d(1, 0, 0, 0, 0, 0, -1, 0, 0, -1, 0, 0, 0, 0, -125, 1); 
            -moz-transform: matrix3d(1, 0, 0, 0, 0, 0, -1, 0, 0, -1, 0, 0, 0, 0, -125px, 1); 
            transform: matrix3d(1, 0, 0, 0, 0, 0, -1, 0, 0, -1, 0, 0, 0, 0, -125px, 1); 
        }
            .project-single .side { height: 250px; position: absolute; width: 360px; }
            .project-single .front  { 
                left: 0px; 
                top: 0px; 
                -webkit-transform: rotateX(90deg) rotateY(-180deg) rotateZ(-180deg) translate3d(0px, 0px, -125px); 
                -moz-transform: rotateX(90deg) rotateY(-180deg) rotateZ(-180deg) translate3d(0px, 0px, -125px); 
                transform: rotateX(90deg) rotateY(-180deg) rotateZ(-180deg) translate3d(0px, 0px, -125px); 
            }
                .project-single .pulsating-preview-icon {
                    position: absolute;
                    left: 10px;
                    bottom: 10px;
                    height: 39px;
                    width: 39px;
                }
            .project-single .back { 
                -webkit-transform: translate3d(0px, 0px, -125px); top: 0px; left: 0px; 
                -moz-transform: translate3d(0px, 0px, -125px); top: 0px; left: 0px; 
                transform: translate3d(0px, 0px, -125px); top: 0px; left: 0px; 
            }
                .project-single .back img { margin: 0; display: block; }
    .project-page .project-wrapper { margin-bottom: 50px; margin-top: 0; }

#project-meta { width: 320px; margin-right: 40px; }    
    #project-meta .bTop { float: none; display: block; }    
    #project-navigation { margin: 0 0 -1px 0; }
        #project-navigation .prev, #project-navigation .next { width: 56px; height: 56px; display: block; margin-right: 10px; }
        #project-navigation .prev { background: url(../images/icon_prev_project.v202509040933070451.png) no-repeat top left; -webkit-transition: background-position .1s ease; -moz-transition: background-position .1s ease; transition: background-position .1s ease; }
            #project-navigation .prev:hover { background-position: top right; }
        #project-navigation .next { background: url(../images/icon_next_project.v202509040933070451.png) no-repeat top right; -webkit-transition: background-position .1s ease; -moz-transition: background-position .1s ease; transition: background-position .1s ease; }
            #project-navigation .next:hover { background-position: top left; }
        #project-navigation .middle { height: 54px; width: 208px; text-align: center; }
            #project-navigation .current-project-number { font-size: 3em; color: #0999c7; margin-top: -5px; display: inline-block; }
            #project-navigation .slash { background: url(../images/icon_grey_slash.v202509040933070451.png) no-repeat center; width: 14px; height: 43px; display: inline-block; margin-top: 5px; }
            #project-navigation .project-number { font-size: 2em; color: #ddd; }
    #project-meta .project-description { margin-top: 25px; }
        #project-meta .project-description p:last-child { margin-bottom: 0; }
        #project-meta section h2 { text-align: left; font-size: 2em; }
    div.testimonial { margin-top: 10px; position: relative; }
        .testimonial blockquote { margin: 0; }
            .testimonial blockquote span { background-color: #0999c7; color: #fff; font-style: italic; font-size: 1.1em; padding: 0px 4px; line-height: 1.6em; margin-bottom: 3px; display: inline-block; }
        .testimonial .author { color: #555; display: block; margin-top: 10px; }
        div.testimonial .icon.testimonial { background: url(../images/icon_testimonial.v202509040933070451.png) no-repeat; position: absolute; top: 75px; right: 2px; width: 31px; height: 25px; }
    #project-meta .project-meta-list { margin-bottom: 20px; }
        .project-meta-list li { margin-top: 15px; }
        .project-meta-list li:first-child { margin-top: 0; }
            .project-meta-list .attribute-name { text-transform: uppercase; color: #0E87AD; display: block; font-weight: bold; font-size: 1.2em; font-family: "Montserrat"; margin-bottom: 8px; }
            .project-meta-list .attribute-value { color: #555; }
            
    #project-meta .services ul { padding: 0 0 0 0; margin: 0; }
        #project-meta .services li { color: #555; list-style-image: url(../images/icon_list_icon.v202509040933070451.png); list-style-position: inside; margin-bottom: 10px; }
        
#project-main { width: 720px; margin-bottom: 40px; float: right; }    
    #project-main img { margin-bottom: 50px; }
    
.bTop { border-top: 1px dotted #ddd; float: left; width: 100%; display: inline; margin-bottom: 50px; padding-top: 50px; }    
.col3 { float: left; display: inline; width: 340px; margin-right: 30px; margin-top: 40px; }
.col3:last-child { margin-right: 0; }

section.projects, section.our-services-short { margin-bottom: 90px; }
section.projects, section.our-services-commercial { margin-bottom: 90px; }

.sect2 {
  margin-bottom: 50px;
}

#contactpage-form { margin-bottom: 40px; }
    form #name-input { margin-right: 10px; }
    form #name-input, form #email-input { float: left; display: inline; width: 535px; }
    form input[type='text'], form textarea, form input[type='email'] { 
        background:#f5f5f5; 
        box-shadow: 0px 1px 0px #e2e2e2; 
        border: none; 
        padding: 18px; 
        -webkit-transition: box-shadow .3s ease; 
        -moz-transition: box-shadow .3s ease;
        transition: box-shadow .3s ease;
    }
    form input[type='text'], form input[type='email'] { margin-bottom: 20px; width: 499px; }
    form textarea { height: 200px; margin-bottom: 20px; width: 1044px; }
    form input[type='text']:focus, form textarea:focus, form input[type='email']:focus { outline: none; box-shadow: 0px 3px 0px #1F93B8; }
    form input[type='submit'] { border: none; background: #1F93B8; color: #fff; padding: 18px 0; width: 1080px; -webkit-transition: background .3s ease; -moz-transition: background .3s ease;transition: background .3s ease; }
    
    form input[type='submit'].error {background: #cf0e37; }
    form input[type='text'].error, form textarea.error, form input[type='email'].error { box-shadow: 0px 3px 0px #cf0e37; color: #cf0e37; }
    
    
footer { padding-top: 0 !important; margin-top: 20px; margin-bottom: 25px !important; }
    footer p, footer p a { font-family: "Jura", Georgia, serif; color: #999 !important; margin-bottom: 0; }
    footer section { display: block; width: 250px; text-align: center; margin: 0 auto; padding-top: 30px; }
    footer .contact-infos { padding-right: 0; }
    footer .copyright img { display: block; width: 104px; margin: 0 auto 10px; }
    footer .socialize ul { display: inline-block; margin: 0 auto; }
        footer .socialize li, #contactpage-social li { float: left; display: inline; margin-left: 10px; }
        footer .socialize li:first-child, #contactpage-social #social-networks li:first-child { margin-left: 0; }    
            footer .socialize a, #contactpage-social li a { transition: none; -webkit-transition: none; -moz-transition: none; display: block; height: 30px; width: 30px; text-indent: -9999px; font-size: 0; }
    p.adress, p.tel, p.email { position: relative; padding-left: 30px; }
    #contactpage-infos p i { position: absolute; left: 0; top: 0; float: left; display: inline-block; }
        footer .adress p { margin-bottom: 0; }
        footer .tel p { margin-bottom: 10px; }
        footer .copyright a, footer .contact-infos a { color: #888; font-style: normal; border-bottom: 1px solid #ddd; padding-bottom: 2px; }
        
        
        
#text-content h2 { text-align: left; }
#text-content h3 { border-bottom: none; padding-bottom: 0; margin-bottom: 15px; margin-top: 10px; display: inline-block; }
        
        
.slick-dots li.slick-active button:before,
.slick-dots li button:hover:before, 
.slick-dots li button:focus:before { color: #1283A7 !important; }
        
        
        
/* =============================================================================
   Media Queries
   ========================================================================== */


@media only screen and (min-width : 320px) and (max-width : 1095px) {
    #content-wrapper, footer, #top-wrapper .inner { box-sizing: border-box; padding: 0 5%; width: 100%; }
    
    #header-wrapper { background-attachment: scroll; }
    #header-wrapper #headline { font-size: 6.5em; }

    #header-wrapper nav li {
        margin-left: 16px;
    }
    
    .our-services-short li, .our-services li { width: 33.33%; box-sizing: border-box; margin-right: 0; }
    .our-services-short li:first-child { padding-right: 4%; }
    .our-services-short li:last-child { padding-left: 4%; }
    .our-services-short li:nth-child(2n) { padding-left: 2%; padding-right: 2%; }

    .our-services-commercial li, .our-services li { width: 33.33%; box-sizing: border-box; margin-right: 0; }
    .our-services-commercial li:first-child { padding-right: 4%; }
    .our-services-commercial li:last-child { padding-left: 4%; }
    .our-services-commercial li:nth-child(2n) { padding-left: 2%; padding-right: 2%; }
    
    .our-services { margin-top: 0; }
        .our-services li { padding: 0 3%; height: 270px; }
            .our-services li h3 { white-space: nowrap; }
        
    #contactpage-infos, #contactpage-social { width: 50%; box-sizing: border-box; padding: 30px 3%; margin: 0; }
        #contactpage-infos .adress, #contactpage-infos .tel, #contactpage-infos .email { float: none; display: block; margin-bottom: 15px; box-sizing: border-box; width: 100%; }
        
    form #name-input, form #email-input { width: 50%; margin: 0; }
        form input[type='text'], form textarea, form input[type='submit'], form input[type='email'] { width: 100%; box-sizing: border-box; }
        
    #team-intro .single-person { width: 50%; box-sizing: border-box; margin-right: 0 !important; }
    #team-intro .single-person:first-child { padding-right: 2%; }
    #team-intro .single-person:last-child { padding-left: 2%; }
    
    #project-meta { width: 30%; margin-right: 5%; }
    #project-main { width: 65%; margin-bottom: 0; }
        #project-main img { width: 100%; }
    
    .project-wrapper .project-single-wrapper {
        -webkit-perspective: 0;
        -moz-perspective: 0;
        perspective: 0;
        width: 33.33%;
        height: auto;
    }
        .project-single-wrapper .project-single, .project-single-wrapper .project-single .back, .project-single-wrapper .project-single img {
            width: 100%; 
            height: 100%; 
        }
        .project-single-wrapper .project-single,
        .cssmatrix3dtransformation .project-single-wrapper a:hover .project-single {
            -webkit-transform: none; /* Safari and Chrome */
            -moz-transform: none; /* Firefox */
            -ms-transform: none; /* IE 9 */
            -o-transform: none; /* Opera */
            transform: none;
        }
        .project-single .side { position: relative; transform: none; }
        .project-single-wrapper .front { display: none; visibility: hidden; }
            .project-single-wrapper .project-single img { display: block; max-width: 100%; height: auto; }
}

@media only screen and (min-width : 945px) and (max-width : 1095px) {
    #content-wrapper, footer, #top-wrapper .inner { padding-right: 2% !important; }
}

@media only screen and (min-width : 910px) and (max-width : 945px) {
    #content-wrapper, footer, #top-wrapper .inner { padding-right: 1% !important; }
}

@media only screen and (min-width : 660px) and (max-width : 910px) {
    #content-wrapper, footer, #top-wrapper .inner { padding-right: 1% !important; }
    #header-wrapper .fa { display: none; }
}

@media only screen and (min-width : 660px) and (max-width : 920px) {
    #header-wrapper #headline { font-size: 5.5em; margin-top: 110px; text-shadow: .1em .1em 0px rgba(2, 67, 88, 0.45); }
        #header-wrapper #headline .first-word { margin-bottom: -5px; }
        #header-wrapper #headline .first-word, #header-wrapper #headline .last-word { text-shadow: .07em .07em 0px rgba(2, 67, 88, 0.45); }
        #header-wrapper #headline .links { font-size: 0.15em; }
        #header-wrapper #headline-cursor { height: 88px; }
}

@media only screen and (max-width : 880px) {
    #header-wrapper { height: 445px; }
    #header-wrapper nav { display: none; }
    .slicknav_menu { display: block; visibility: visible; }
    
    #header-wrapper.small { height: 210px; }
    
    #header-wrapper #headline { font-size: 4.5em; margin-top: 55px; }
    
    .our-services li { width: 50%; height: 270px; }
    .our-services li:nth-child(2n) { padding-left: 3% !important; padding-right: 0; }
    .our-services li:first-child, .our-services li:nth-child(1n) { padding-left: 0; }
        .our-services li h3 { white-space: nowrap; }
    
    #logo { float: none; width: 260px; }
        #logo img { width: 100% !important; height: auto !important; }
    #header-wrapper.small #logo { margin: 40px auto 0; }
    
    #project-navigation { display: none; }
    #project-main { width: 100%; float: none; display: block; }
    #project-meta { width: 100%; }
        #project-meta .project-description { margin-top: 15px; }
            #project-meta .project-meta-list { float: right; width: 35%; }
            #project-meta .project-description p { float: left; width: 60%; margin-right: 5%; }
    
    .show-mobile { display: block; }
    .hide-mobile { display: none; }
}

@media only screen and (max-width : 660px) {
    #header-wrapper #headline { font-size: 4em; margin-top: 100px; text-shadow: .1em .1em 0px rgba(2, 67, 88, 0.45); }
        #header-wrapper #headline .first-word { margin-bottom: -10px; }
        #header-wrapper #headline .first-word, #header-wrapper #headline .last-word { text-shadow: .07em .07em 0px rgba(2, 67, 88, 0.45); }
        #header-wrapper #headline .links { font-size: 0.2em; }
        #header-wrapper #headline-cursor { height: 64px; }
    
    
    .our-services-short li { width: 100%; padding: 0 !important; }
    .our-services-commercial li { width: 100%; padding: 0 !important; }
    
    #team-intro .single-person { width: 100%; padding: 0 !important; }
    #team-intro .single-person:first-child { margin-bottom: 50px; }
        #team-intro .social-icons { display: none; }
}

@media only screen and (max-width : 610px) {
    #main-content .our-services li { width: 100%; padding: 0 !important; height: auto; margin-bottom: 30px; padding-left: 0 !important; }
    
    #project-meta .project-meta-list { float: none; width: 100%; }
        .project-meta-list li { float: left; display: inline; margin-top: 0 !important; }
        .project-meta-list li:first-child { margin-right: 5%; margin-bottom: 15px; }
            #project-meta .project-description p { float: none; width: 100%; }
    
    section.projects, section.our-services-short { margin-bottom: 40px; }
    section.projects, section.our-services-commercial { margin-bottom: 40px; }
}

@media only screen and (max-width : 510px) {
    #header-wrapper { height: 335px; }
    #header-wrapper #headline { font-size: 2.5em; margin-top: 20px; }
        #header-wrapper #headline .keyword { text-shadow: .1em .1em 0px rgba(2, 67, 88, 0.45); }
        #header-wrapper #headline .first-word { font-size: 0.8em; margin-bottom: -10px; }
        #header-wrapper #headline .last-word { font-size: 1em; margin-top: 5px; }
        #header-wrapper #headline .first-word, #header-wrapper #headline .last-word { text-shadow: .07em .07em 0px rgba(2, 67, 88, 0.45); }
        #header-wrapper #headline-cursor { height: 52px; }
        
    #contactpage-infos, #contactpage-social { width: 100%; padding: 0; margin-bottom: 25px; }
        #contactpage-infos .adress, #contactpage-infos .tel, #contactpage-infos .email { padding-left: 0; padding-top: 30px; background-position: center top; text-align: center; }
            #contactpage-infos p i { left: 50%; margin-left: -10px; }
        
    form #name-input, form #email-input { width: 100%; }
    
    .projects .project-single-wrapper { width: 50%; }
    .projects .project-single-wrapper:last-child {
        display: none; 
        visibility: hidden;
    }
    .project-page .project-single-wrapper { width: 100%; }
}

.background-color {
    background-color: #2985A0;
}

.bg-hover-color:hover {
    background-color: #0994c4;
}

#tags > a {
    color: #fff;
    display: inline-block;
    font-size: 12px;
    margin: 4px 4px 4px 0;
    padding: 3px 4px;
    text-decoration: none;
    white-space: nowrap;
}

#tags > a::before {
    color: #000;
    content: "\f02b";
    font-family: FontAwesome;
    margin-right: 5px;
}

.versions > p > a.development-version {
    background-color: #d67e28;
	border-radius: .28571429rem;
    color: #fff;
    display: inline-block;
    font-size: 12px;
    margin: 4px 4px 4px 0;
    padding: 3px 4px;
    text-decoration: none;
    white-space: nowrap;
}

.versions > p > a.development-version:hover {
   background-color: #d67e28ba;
}

.versions > p > a.stable-version {
    background-color: #15904a;
	border-radius: .28571429rem;
    color: #fff;
    display: inline-block;
    font-size: 12px;
    margin: 4px 4px 4px 0;
    padding: 3px 4px;
    text-decoration: none;
    white-space: nowrap;
}

.versions > p > a.stable-version:hover {
   background-color: #15904aba;
}

pre {
    -moz-tab-size: 4;
    -o-tab-size:   4;
    tab-size:      4;
}
/* Style The Dropdown Button */
.dropbtn {
    color: white;
    padding: 16px;
    font-size: 16px;
    border: none;
    cursor: pointer;
}

.dropbtn a:hover {
    border: none;
}

/* The container <div> - needed to position the dropdown content */
.dropdown {
    position: relative;
    display: inline-block;
}

/* Dropdown Content (Hidden by Default) */
.dropdown-content {
    display: none;
    position: absolute;
    background-color: #2985A0;
    min-width: 160px;
    box-shadow: 0px 8px 16px 0px rgba(0,0,0,0.2);
}

.dropdown-content li {
    margin-left: 0px !important;
}

/* Links inside the dropdown */
.dropdown-content a {
    color: #3299B8;
    padding: 12px 16px;
    text-decoration: none;
    display: block;
}

.dropdown-content .current a {
    font-family: "Montserrat";
    border-bottom: 2px solid rgba(255,255,255,.85);
    padding-bottom: 7px;
}

/* Change color of dropdown links on hover */
.dropdown-content a:hover {
    border-bottom: 2px solid #fff;
}

/* Show the dropdown menu on hover */
.dropdown:hover .dropdown-content {
    display: block;
}

.button {
    padding: 10px;
    background: rgba(16, 62, 76, 0.84);
    color: #fff;
}

.thumb {
    max-height: 171px;
    border: solid 6px rgba(5, 5, 5, 0.8);
}

.lightbox {
    position: fixed;
    z-index: 999;
    height: 0;
    width: 0;
    text-align: center;
    top: 0;
    left: 0;
    background: rgba(0, 0, 0, 0.8);
    opacity: 0;
}

.lightbox img {
    max-width: 90%;
    max-height: 80%;
    margin-top: 2%;
    opacity: 0;
}

.lightbox:target {
    /** Remove default browser outline */
    outline: none;

    width: 100%;
    height: 100%;
    opacity: 1 !important;

}

.lightbox:target img {
    border: solid 17px rgba(77, 77, 77, 0.8);
    opacity: 1;
    webkit-transition: opacity 0.6s;
    transition: opacity 0.6s;
}

.light-btn {
    color: #fafafa;
    background-color: #333;
    border: solid 3px #777;
    padding: 5px 15px;
    border-radius: 1px;
    text-decoration: none;
    cursor: pointer;
    vertical-align: middle;
    position: absolute;
    top: 45%;
    z-index: 99;
}

.light-btn:hover {
    background-color: #111;
}

.btn-prev {
    left: 7%;
}

.btn-next {
    right: 7%;
}

.btn-close {
    position: absolute;
    right: 2%;
    top: 2%;
    color: #fafafa;
    background-color: #92001d;
    border: solid 5px #ef4036;
    padding: 10px 15px;
    border-radius: 1px;
    text-decoration: none;
}

.btn-close:hover {
    background-color: #740404;
}
