/**********************************
* Default stylesheet for Frish.nl
* By Rogier Strobbe
**********************************/



/**********************************
* Large Screens (Default)
**********************************/

body {
    width: 100%;
    margin: 0;
    padding: 0;
}

.blobs-container {
    display: flex;
    margin-top:80px;
    margin-bottom:10px;
}

.availability {
    color: rgba(33, 84, 132, 1);
    font-family: 'Poppins', sans-serif;
    font-weight:300;
    font-size:14px;
    margin:-5px 0 0 5px;
}

.blob {
    background: black;
    border-radius: 50%;
    box-shadow: 0 0 0 0 rgba(0, 0, 0, 1);
    margin: 0px;
    height: 10px;
    width: 10px;
    transform: scale(1);
    animation: pulse-black 2s infinite;
    display:inline-block;
}

.blob.blue {
    background: rgba(33, 84, 132, 1);
    box-shadow: 0 0 0 0 rgba(33, 84, 132, 1);
    animation: pulse-blue 2s infinite;
}

@keyframes pulse-blue {
    0% {
        transform: scale(0.95);
        box-shadow: 0 0 0 0 rgba(33, 84, 132, 0.7);
    }
    
    70% {
        transform: scale(1);
        box-shadow: 0 0 0 10px rgba(33, 84, 132, 0);
    }
    
    100% {
        transform: scale(0.95);
        box-shadow: 0 0 0 0 rgba(33, 84, 132, 0);
    }
}

.column {
    display:block;
    width:100%;
    height:1px;
}

.logo {
    display:block;
    width:50px;
    float:left;
}

.logo a {
    text-decoration:none;
}

.logo span {
    display:block;
    text-align:center;
    color:#000;
    font-family: 'Playfair Display', serif;
    font-size:11px;
    line-height:10pt;
    font-weight:400;
    margin:-7px auto 0 auto;
    width:50px;
}

.header .main {
    padding-top:50px;
}

.header nav {
    float:right;
}

.mainnav {
    list-style-type: none;
    margin: 0;
    padding: 0;
}

a {
    color:#215484;
}

.mainnav li {
    float:left;
    font-family: 'Playfair Display', serif;
    font-size:14px;
    line-height:14pt;
    font-weight:700;
    margin-right:20px;
}

.mainnav li a {
    display:block;
    padding:7px;
    color:#000;
    text-decoration:none;
    border-bottom:3px solid transparent;
    transition: linear 0.2s;
}

.mainnav li a:hover {
    border-bottom:3px solid #000;
}

.color-blue header {
    background:#B6DBFA;
}

.color-blue hr {
    border-top: 1px solid #215484;
}

.color-purple header {
    background:#d5c2ef;
}

.color-purple hr {
    border-top: 1px solid #431583;
}

.color-yellow header {
    background:#fbeba6;
}

.color-yellow hr {
    border-top: 1px solid #7e6a14;
}

.color-salmon header {
    background:#fac5b6;
}

.color-salmon hr {
    border-top: 1px solid #8a5545;
}

.color-green header {
    background:#b5eecd;
}

.color-green hr {
    border-top: 1px solid #206a3f;
}

.header {
    display:block;
    height:500px;
}

.header .row {
    margin-top:0px;
}

.header h1 {
    font-family: 'Playfair Display', serif;
    font-size:48px;
    line-height:42pt;
    font-weight:400;
    margin:100px 0 0 0;
    letter-spacing:-0.2px;
}

.home .header h1 {
    margin:0;
}

.header h1 em {
    font-weight:700;
    font-style:normal;
}

hr {
    width:80px;
    padding:0;
    margin-top:30px 0 0 0;
}

hr.small-line {
    margin:15px 0 30px 0;
}

.portfolio {
    background:#f2f2f3;
    padding:100px 0;
}

.wrap h2 {
    font-family: 'Playfair Display', serif;
    font-size:32px;
    line-height:26pt;
    font-weight:700;
    color:#1c1c1c;
    letter-spacing:-0.2px;
}

.introtext {
    font-family: 'Poppins', sans-serif;
    font-weight:300;
    font-size:16px;
    line-height:18pt;
    color:#1c1c1c;
    padding-bottom:10px;
}

.home-portfolio-item {
    background:#fff;
    -webkit-border-radius: 20px;
    -moz-border-radius: 20px;
    border-radius: 20px;
    -webkit-box-shadow: 0px 0px 10px 0px rgba(0,0,0,0.1);
    -moz-box-shadow: 0px 0px 10px 0px rgba(0,0,0,0.1);
    box-shadow: 0px 0px 10px 0px rgba(0,0,0,0.1);
    width:100%;
    transition: linear 0.2s;
}
.home-portfolio-item:hover {
    -webkit-box-shadow: 0px 0px 12px 0px rgba(0,0,0,0.1);
    -moz-box-shadow: 0px 0px 12px 0px rgba(0,0,0,0.1);
    box-shadow: 0px 0px 10px 2px rgba(0,0,0,0.1);
}

.home-portfolio-img {
    width:100%;
    -webkit-border-top-left-radius: 20px;
    -webkit-border-top-right-radius: 20px;
    -moz-border-radius-topleft: 20px;
    -moz-border-radius-topright: 20px;
    border-top-left-radius: 20px;
    border-top-right-radius: 20px;
    transition: linear 0.2s;
}

.home-portfolio-item:hover .home-portfolio-img {
    opacity:90%;
}

.home-portfolio-meta {
    width:100%;
    padding:30px 20px;
}

.home-portfolio-meta h3 {
    font-family: 'Poppins', sans-serif;
    font-weight:600;
    font-size:16px;
    line-height:18pt;
}

.home-portfolio-meta p {
    font-family: 'Poppins', sans-serif;
    font-weight:300;
    font-size:16px;
    line-height:18pt;
}

.home-portfolio {
    color:#1c1c1c;
    text-decoration:none;
    display:block;
}

.odd-item {
    margin-bottom:23px;
}

.about {
    background:#fff;
    padding:100px 0;
}

.about h2 em {
    font-weight:400;
    font-style:normal;
}

.about2 {
    padding-top:50px;
}

.about2 h3 {
    font-family: 'Poppins', sans-serif;
    font-weight:600;
    font-size:16px;
    line-height:18pt;
}

.about2 p {
    padding-bottom:10px;
}

.about2 .introlink {
    margin-top:30px;
}

.introlink {
    font-family: 'Poppins', sans-serif;
    font-weight:600;
    text-decoration:none;
    padding-right:25px;
    background: url(../img/arrow_small_blue.svg);
    background-repeat: no-repeat;
    background-size: 15px auto;
    background-position:right 11px;
    display:inline-block;
}

.introlink:hover {
    text-decoration:underline;
}

.contact {
    background:#f2f2f3;
    padding:100px 0;
}

.contact label {
    display:none;
}

.contact .notifications {
    background:#ebbab4;
    -webkit-border-radius: 20px;
    -moz-border-radius: 20px;
    border-radius: 20px;
    font-family: 'Poppins', sans-serif;
    font-weight:300;
    font-size:16px;
    line-height:18pt;
    margin-bottom:10px;
}

.contact .notifications .error {
    padding:5px 20px;
    display:block;
}

.contact .tick {
    background:#ace8dc;
    -webkit-border-radius: 20px;
    -moz-border-radius: 20px;
    border-radius: 20px;
    font-family: 'Poppins', sans-serif;
    font-weight:300;
    font-size:16px;
    line-height:18pt;
    margin-bottom:10px;
    padding:20px;
}

.formcontactemail {
    margin-bottom:30px;
    display:block;
}

.formcomments {
    clear:both;
}

.formcontactemail p {
    width:50%;
    float:left;
    display:inline-block;
}

.contactfield {
    padding-right:10px;
}
.emailfield {
    padding-left:10px;
}

::-webkit-input-placeholder {
   color:#909090;
}

:-moz-placeholder { /* Firefox 18- */
   color:#909090;  
   opacity: 1
}

::-moz-placeholder {  /* Firefox 19+ */
   color:#909090;
   opacity: 1
}

:-ms-input-placeholder {  
   color:#909090;  
}

input[type=text], input[type=email], textarea {
    background:#fff;
    -webkit-border-radius: 20px;
    -moz-border-radius: 20px;
    border-radius: 20px;
    -webkit-box-shadow: 0px 0px 10px 0px rgba(0,0,0,0.1);
    -moz-box-shadow: 0px 0px 10px 0px rgba(0,0,0,0.1);
    box-shadow: 0px 0px 10px 0px rgba(0,0,0,0.1);
    border:0;
    padding:20px;
    width:100%;
    font-family: 'Poppins', sans-serif;
    font-weight:300;
    font-size:16px;
    line-height:18pt;
    color:#1c1c1c;
    transition: linear 0.2s;
}

input[type=text]:hover, input[type=email]:hover, textarea:hover {
    -webkit-box-shadow: 0px 0px 12px 0px rgba(0,0,0,0.1);
    -moz-box-shadow: 0px 0px 12px 0px rgba(0,0,0,0.1);
    box-shadow: 0px 0px 12px 0px rgba(0,0,0,0.1);
}

input[type=text]:focus, input[type=email]:focus, textarea:focus {
    -webkit-box-shadow: 0px 0px 12px 0px rgba(182,219,250,1.0);
    -moz-box-shadow: 0px 0px 12px 0px rgba(182,219,250,1.0);
    box-shadow: 0px 0px 12px 0px rgba(182,219,250,1.0);
}

textarea {
    min-height:150px;
    margin-bottom:30px;
    resize: none;
}

input[type=submit] {
    background:transparent;
    border:0;
    color:#215484;
    font-size: 16px;
    line-height: 18pt;
    font-family: 'Poppins', sans-serif;
    font-weight:600;
    text-decoration:none;
    padding-right:25px;
    background: url(../img/arrow_small_blue.svg);
    background-repeat: no-repeat;
    background-size: 15px auto;
    background-position:right 11px;
    display:inline-block;
}

.site-footer {
    background:#fff;
    padding:50px 0;
    font-family: 'Poppins', sans-serif;
    font-weight:300;
    font-size:16px;
    line-height:18pt;
    color:#1c1c1c;
}

.portfolio-detail {
    background:#fff;
    padding:100px 0;
    font-family: 'Poppins', sans-serif;
    font-weight:300;
    font-size:16px;
    line-height:18pt;
}

.portfolio-detail .row {
    margin-bottom:100px;
}

.portfolio-detail .extra-row-flip {
    margin-bottom:100px;
}

.portfolio-detail .row:last-child {
    margin-bottom:0px;
}

.portfolio-detail .no-margin {
    margin-bottom:0px;
}

.portfolio-detail img, .styleguide img {
    max-width:100%;
}

.portfolio-detail dl {
  display: block;
  margin-top:75px;
}

.portfolio-detail dt {
  float:left;
  margin-right:3px;
  display:inline-block;
  color:#adadad;
}

.portfolio-detail dd {
    margin-bottom:5px;
    color:#6c6c6c;
}

.styleguide {
    padding:100px 0;
    background:#2d2d2d;
}

.styleguide-content {
    text-align:center;
}

.styleguide-content h2, .styleguide-content .introtext {
    color:#fff;
}

.color-purple .styleguide-content hr.small-line {
    margin:15px auto 30px auto;
    border-top: 1px solid #d5c2ef;
    text-align:left;
}

.color-yellow .styleguide-content hr.small-line {
    margin:15px auto 30px auto;
    border-top: 1px solid #fbeba6;
}

.color-salmon .styleguide-content hr.small-line {
    margin:15px auto 30px auto;
    border-top: 1px solid #fac5b6;
}

.color-green .styleguide-content hr.small-line {
    margin:15px auto 30px auto;
    border-top: 1px solid #b5eecd;
}

.styleguide-content .introtext {
    margin-bottom:50px;
}

.typography img {
    margin-bottom:25px;
}

.typography img:last-child {
    margin-bottom:0px;
}







.wrap {
    width: 1180px;
    margin: 0 auto;
}
.flexbox {
    display: -webkit-flex;
    display: flex;
}

.row {
/*    margin: 20px 0; */
}
    .row:after {
        content: "";
        display: table;
        clear: both;
    }

/* Sets default values on all columns */
[class*="span"] {
    margin-right: 2%;
    float: left;
    -webkit-box-sizing: border-box;
       -moz-box-sizing: border-box;
        -ms-box-sizing: border-box;
            box-sizing: border-box;
}
    [class*="span"]:last-child {
        margin-right: 0;
    }

    .prototype [class*="span"] {
        background: #ececec;
        border-radius: 4px;
        padding: 15px;
        text-align: center;
    }

.span1 {
    width: 6.5%;
}
.span2 {
    width: 15%;
}
.span3 {
    width: 23.5%;
}
.span4 {
    width: 32%;
}
.span5 {
    width: 40.5%;
}
.span6 {
    width: 49%;
}
.col7 {
    width: 57.5%;
}
.span8 {
    width: 66%;
}
.span9 {
    width: 74.5%;
}
.span10 {
    width: 83%;
}
.span11 {
    width: 91.5%;
}
.span12 {
    width: 100%;
    float: none;
}



/**********************************
* Smaller Screens
**********************************/
@media only screen and (max-width: 1200px) {
    .wrap {
        width: 960px;
    }
}

/**********************************
* Tablets
**********************************/
@media only screen and (max-width: 1024px) {
    .wrap {
        width: 760px;
    }
}

/**********************************
* Mobile Devices
* - All columns are full width
**********************************/
@media only screen and (max-width: 767px) {
    .wrap {
        width: 90%;
    }
    .row {
        margin: 0;
    }
    [class*="span"] {
        margin: 15px 0;
        float: none;
        width: 100%;
    }
    .row-flip {
        display:flex;
        flex-flow:column-reverse;
    }
    .extra-row-flip {
        display:flex;
        flex-flow:column-reverse;
    }
    .header .main {
        padding-top:25px;
    }
    .header nav {
        display:none;
    }
    .header h1 {
        font-family: 'Playfair Display', serif;
        font-size:28px;
        line-height:25pt;
        font-weight:400;
        margin:100px 0 0 0;
        letter-spacing:-0.2px;
    }
    .mainnav li {
        float:none;
        margin-right:0px;
    }
    .mainnav li a {
        padding:5px 0px 5px 0px;
        text-align:right;
    }
    .mainnav li a, .mainnav li a:hover {
        border-bottom:none;
    }
    .wrap h2 {
        font-family: 'Playfair Display', serif;
        font-size:24px;
        line-height:18pt;
        letter-spacing:-0.1px;
    }
    hr.small-line {
        margin:15px 0 20px 0;
    }
    .color-purple .styleguide-content hr.small-line {
        margin:15px 0 30px 0;
        border-top: 1px solid #d5c2ef;
        text-align:left;
    }

    .color-yellow .styleguide-content hr.small-line {
        margin:15px 0 30px 0;
        border-top: 1px solid #fbeba6;
    }

    .color-salmon .styleguide-content hr.small-line {
        margin:15px 0 30px 0;
        border-top: 1px solid #fac5b6;
    }

    .color-green .styleguide-content hr.small-line {
        margin:15px 0 30px 0;
        border-top: 1px solid #b5eecd;
    }
    .portfolio {
        padding:25px 0;
    }
    .home-portfolio {
        margin-bottom:30px;
    }
    .odd-item {
        margin-bottom:30px;
    }
    .about {
        padding:25px 0;
    }
    .about2 {
        padding-top:0px;
    }
    .about2 .introlink {
        margin-top:15px;
    }
    .contact {
        padding:25px 0;
    }
    .formcontactemail p {
        width:100%;
    }
    .contactfield {
        padding-right:0px;
        margin-bottom:30px;
    }
    .emailfield {
        padding-left:0px;
    }
    .site-footer {
        padding:25px 0;
        font-family: 'Poppins', sans-serif;
        font-weight:300;
        font-size:14px;
        line-height:17pt;
    }
    .portfolio-detail {
        padding:25px 0;
    }
    .portfolio-detail .row {
        margin-bottom:25px;
    }
    .portfolio-detail .extra-row-flip {
        margin-bottom:0px;
    }
    .portfolio-detail dl {
      margin:25px 0 35px 0;
    }
    .styleguide {
        padding:25px 0;
    }
    .portfolio-detail img, .styleguide img {
        display:block;
    }
    .styleguide-content .introtext {
        margin-bottom:25px;
    }
    .styleguide-content {
        text-align:left;
    }
    .styleguide-content hr.small-line {
        margin:15px 0 20px 0;
    }
    .typography img {
        margin-bottom:25px;
        width:80%;
    }
    .typography img:last-child {
        margin-bottom:50px;
    }
    .colours img {
        width:80%;
    }
    .column {
        display:none;
    }
}
