
html {
	height: 100%;
}

body {
	color:#727272;
	font-size: 13px;
	line-height: 1.2;
	margin:0;
	padding:0;
	/*min-width: 320px;
	min-width: 1148px;*/
	width: 100%;
}
body#page_day {
	height: 100%;
}
body#page_day,
body#page_basket {	
	padding: .5rem;
}

body,
input,
select,
#quotes span,
textarea{
	font-family: "Nunito", Sans-serif;
	color: #525e66;
	font-weight: 300;
}

textarea{
	width: 500px;
	height: 100px;
}

h2 {
	margin: 0 0 1em;
    line-height: 130%;
    text-align: center;
    font-size: 1.75rem;
    font-family: "Source Serif Pro", Sans-serif;
    font-weight: 500;
    color: #4795c7;
}

h3{
	font-size: 1.231em;
	font-weight: 800;
	margin: 0 0 1em 0;
	/*text-transform: uppercase;*/
	text-align: left;
	line-height: 130%;
}

p{
	margin: 0 0 0.8em;
}

table p{
	margin: 0;
}

form textarea,
form select,
form input{
	font-size: 1em;
	padding: 3px;
	border: 1px solid #bbb;
	border-radius: 5px;
	line-height: 1.2em;
	width: 300px;
	float:left;
	margin-bottom: 10px;
}

form button{
	float:left;
	margin-bottom: 10px;
}

form label{
	font-size: 1.077em;
	padding: 3px;
	line-height: 18px;
	width: 200px;
	float:left;
	clear:both;
}

form label span.required_flag{
	float:right;
	color:#a00;
	margin-right: 10px;
}

hr{
	height: 35px;
	background: transparent url(/images/home-seperator.png) repeat-x center top;
	border:0;
	clear: both;
	margin: 10px 0;
	background-size: cover;
}

table{
	border-spacing: 1px;
   	background: #ddd;
	border-collapse: separate;
}

table td{
	background: #fff;
	padding: 5px;
}

button,
input.button,
input[type=button],
a.button:link,
a.button:visited{
    background: #4795c7;
    color: #fff;
    border: 0;
    vertical-align: middle;
    box-sizing: content-box;
    -moz-box-sizing: content-box;
    -webkit-box-sizing: content-box;
    cursor: pointer;
    display: inline-block;
    border-radius: 20px;
    font-weight: 500;
    font-size: 14px;
	padding: 8px 16px;
	font-family: "Nunito", Sans-serif;
    font-weight: 500;
}

th button,
th input.button,
th a.button:link,
th a.button:visited{
	color: #338ec3;
	background:#fff;
}

button:hover,
input[type=button]:hover,
input.button:hover,
a.button:hover{
	background: #888888;
	color:#fff;
	cursor: pointer;
}

button.button-outline,
input.button.button-outline,
input[type=button].button-outline,
a.button.button-outline:link,
a.button.button-outline:visited {
    border: 1px solid #4795c7;
    background: #fff;
    color: #4795c7;
}
button.button-outline:hover,
input[type=button].button-outline:hover,
input.button.button-outline:hover,
a.button.button-outline:hover {
	background-color: #888888;
    color: #fff;
    border-color: #888888;
}

#wrap{
	/*min-height: 100%;*/
	position: relative;
	z-index:2;
	/*width: 94%;*/
	margin: 0 auto;
}
@media screen and (min-width: 350px) {
	#wrap {
		width: 100%;
	}
}

#main{
	/*padding-bottom: 150px;*/
	z-index:3;
}

.step_nav div a,
.pu h3,
#home_panels p.large,
footer h4,
#quotes,
#check_story{
	font-family: "Nunito", Sans-serif;
    font-weight: 600;
    font-size: .7rem;
}
@media (min-width: 1000px) {
	.step_nav div a,
	.pu h3,
	#home_panels p.large,
	footer h4,
	#quotes,
	#check_story{
	    font-size: .8rem;
	}
}

a:link,
a:visited{
	color:#4192C7;
	text-decoration:none;
	outline:none;
}
a:hover{
	color:#83b9db;
}

.centered{
	max-width: 1148px;
	padding: 0 5px;
	margin: 0 auto;
	position: relative;
}

h1{
	margin: 0;
	font-size: 3.538em;
	font-weight: 900;
	line-height: 56px;
	/*text-transform: uppercase;*/
}


header{
	color: #fff;
	position: relative;
	text-shadow: 0.1em 0.1em 0.4em rgba(0,0,0,0.2);
}
body#page_checkout #wrap > header {
    display: none;
}

#page_index header{
	height: 500px;
}

#backgrounds{
	height: 100%;
}

#main_nav a:link,
#main_nav a:visited,
header a:link,
header a:visited{
	color:#fff;
}
header a:hover{
	color:#83b9db;
}

#main_nav{
	height: 60px;
	line-height: 60px;
	float:left !important;
	margin-left: 190px !important;
}

#main_nav ul{
	list-style-type: none;
	padding:0;
	margin:0;
	float:left;
}

#main_nav li{
	display: inline;
	margin-left: 10px;
}

#main_nav .first{
	font-size: 1.2em;
	font-weight: 800;
}

#blog_nav_link{
	float:left;
	margin-left: 10px;
}

#backgrounds{
	width: 100%;
	overflow: hidden;
	position: absolute;
	top:0px;
	left:0px;
	z-index: 1;
}

#backgrounds div{
	position: absolute;
	top:0px;
	left:0px;
	height: 100%;
	width: 100%;
	background-repeat: no-repeat;
	background-size: cover;
}


#top_bar{
	height: 60px;
	line-height: 60px;
	background-color:rgba(52,143,196,0.2);
	position: relative;
	z-index: 3;
}

#header_main{
	position: absolute;
	top:0px;
	left: 0px;
	width: 100%;
	z-index: 2;
	height: 100%;
}

#header_main > div{
	position: relative;
	height: 100%;
}

#top_bar > .centered > *{
	float: right;
	margin-left: 3%;
}

#header_basket{
	text-align: right;
}

#header_social{
	text-align: right;
	min-width: 80px;
}

#top_bar > .centered img{
	vertical-align: middle;
	margin-left: 10px;
}

#top_bar a:hover{
	color:#333333;
}

#header_social img{
	
}

#header_phone{
	font-size: 1.2em;
	font-weight: 800;
	text-align: center;
}


#mob_phone{
	display:none;
	position: absolute;
	top: 10px;
	right: 50px;
	font-size: 1.2em;
	font-weight: 800;
	z-index: 3;
}


#mob_menu{
	display:none;
	position: absolute;
	top: 10px;
	right: 10px;
	z-index: 10;
}

#logo{
	position: absolute;
	top: 20px;
	left: -40px;
}

#home_titles p.strapline,
header h1{
	margin: 0;
	font-size: 3.538em;
	font-weight: 900;
	line-height: 90%;
	/*text-transform: uppercase;*/
	max-height: 56px;
}

#page_title{
	position: absolute;
	bottom: 10px;
	left: 2%;
	width: 76%
}

#page_title .subtitle{
	margin:0;
}

#page_index p.strapline,
#page_index header h1{
	font-size: 4.846em;
	max-height: 168px;
}

#home_titles{
	position: absolute;
	bottom: 0px;
	left: 2%;
	width: 96%;
	height: 47%;
}

sup{
	font-size: 50%;
	position: relative;
	top: -0.7em;
}

p.subtitle{
	font-size: 1.923em;
	font-weight: normal;
	line-height: 100%;
}

#quotes{
	position: absolute;
	right:5px;
	top:80px;
	text-align: right;
	font-size: 2.308em;
	line-height: 100%;
	width: 66%;
	display:none;
	height: 15%;
}

#quotes p{
	width: 100%;
}

#quotes span{
	display:block;
	font-size: 0.5em;
	font-weight: 800;
	/*text-transform: uppercase;*/
}

footer{
	padding: 10px 0;
	font-size: 10px;
	/*height: 130px;
	margin: -150px auto 0 !important;*/
	margin: 0 auto !important;
	position: relative;
	z-index:1;
	text-align: left;
}

footer h4{
	font-size: 1.846em;
	line-height: 32px;
	margin: 20px 0 10px;
}

footer #n9{
	float:right;
	padding-top: 85px;
}
footer #n9 > div{
	background-color: #737373;
	padding: 3px;
	border-radius: 50%;
	width: 30px;
	margin: 0 auto;
}
footer #n9 p{
	line-height: 30px;
	text-align: center;
}
footer #n9 p img{
	vertical-align: middle;
}

footer #links{
	float:left;
	width: 35%;
}

footer p{
	margin: 0;
}

#copy{
	float: right;
	margin-top: 50px;
}

footer #links ul{
	list-style-type: none;
	padding-left: 0;
}

footer #links li{
	float:left;
	width: 33%;
}

#footer-logos{
	margin: 20px 0;
	display: block;
	width: 900px;
	max-width: 100%;
}

footer #signup{
	float:left;
	width: 40%;
}

footer #signup form{
	margin: 5px 0;
}

footer #signup form input{
	float:none;
	margin:0 10px 10px 0;
}

footer #signup form input.text{
	border: 1px solid #DDDDDD;
	background-color: transparent;
	width: 30%;
	font-size: 12px;
	padding:0;
	line-height: 23px;
}

footer #signup form input.submit{
	border: 0;
	background-color: #737373;
	color:#fff;
	font-weight: 900;
	line-height: 25px;
	font-size: 1.077em;
	width: 25%;
	/*text-transform: uppercase;*/
	cursor: pointer;
	padding:0;
}

footer #signup form input.submit:hover{
	background-color:#DDDDDD;
	color: #737373;
}


#check_story{
	top: 370px;
	left: 460px;
	position: absolute;
	font-size: 2.462em;
	height: 36px;
	line-height: 36px;
}

#check_story a img{
	vertical-align: middle;
}

#choose{
	position: absolute;
	bottom: 0px;
	height: 47%;
	margin:0;
	right: 22%;
	font-size: 1.462em;
	text-align: right;
	line-height: 120%;
	font-weight: 800;
	/*text-transform: uppercase;*/
}


#areas{
	text-align: center;
}

#areas .five_cols{
	padding: 10px 0;
}

#areas .area > p{
	font-size: 0.846em;
	margin-bottom: 0px;
	z-index:2;
	position: relative;
	font-weight: bold;
}

#areas .area > p.large{
	font-size: 1.615em;
	line-height: 21px;
	z-index: 2;
	position: relative;
	margin: 0;
	font-weight: 800;
	/*text-transform: uppercase;*/
}

#home_col_births{
	border-top: 5px solid #4d8c81;
}
#home_col_births.show_pu p.large,
#home_col_births:hover p.large{
	color:#4d8c81;
}

#home_col_anniv{
	border-top: 5px solid #df775e;
}
#home_col_anniv.show_pu p.large,
#home_col_anniv:hover p.large{
	color:#df775e;
}

#home_col_weddings{
	border-top: 5px solid #9f5c65 ;
}
#home_col_weddings.show_pu p.large,
#home_col_weddings:hover p.large{
	color:#9f5c65;
}

#home_col_christ{
	border-top: 5px solid #d0a942;
} 
#home_col_christ.show_pu p.large,
#home_col_christ:hover p.large{
	color:#d0a942;
}

#home_col_calendar{
	border-top: 5px solid #338ec3;
}
#home_col_calendar.show_pu p.large,
#home_col_calendar:hover p.large{
	color:#338ec3;
}

#home_col_calendar .pu_body *{
	float: none;
}

#home_col_calendar form textarea, 
#home_col_calendar form select, 
#home_col_calendar form input{
	max-width: 100%;
	box-sizing: border-box;
}

#home_col_calendar .date_picker .date_select_container{
	float: none;
	margin: 0;
}

#home_col_calendar form{
	padding: 20px 0;
}

.area{
	position: relative;
}

.area .pu{
	position: absolute;
	bottom: 10%;
	left: 2%;
	z-index:1;
	display:none;
	width: 96%;
	color:#4192c7;
	overflow: hidden;
	box-shadow: 2px 2px 5px rgba(0,0,0,0.2);
	border-radius: 0 0 1em 1em;
}

.area .pu .pu_head{
	height: 22px;
}

.area .pu .pu_head .left_corner{
	height: 22px;
	width: 10%;
	float:left;
	border-radius: 10px 0 0 0;
	background: #fff;
}
.area .pu .pu_head .right_corner{
	height: 22px;
	width: 10%;
	float: right;
	border-radius: 0 10px 0 0;
	background: #fff;
}
.area .pu .pu_head .pu_center{
	position: absolute;
	top: 0px;
	left: 50%;
	margin-left: -45%;
	height: 22px;
	background: transparent url(/images/pu-top-white.png) no-repeat center top;
	width: 90%;
}

.pu_body{
	background: #fff;
	border-radius: 0 0 10px 10px;
	padding: 0 10px 40px;
}

.area.show_pu .pu{
	display: block;
}


.area .pu .bg{
	width: 100%;
}

.pu #calendarWrap{
	height: 230px;
}

.pu_close{
	position: absolute;
	right: 10%;
	top: 8%;
	font-weight: 800 !important;
	font-size: 1.077em !important;
	padding: 0px !important;
	background-color: transparent !important;
	text-transform: none !important;
	color:#888;
	margin: 0 !important;
}

table.calendar{
	border-spacing: 0px;
    border-collapse: separate;
	width: 100%;
	height: 100%;
}

table.calendar a:link,
table.calendar a:visited{
	color:#4192c7;
}

table.calendar th,
table.calendar td{
	width: 14.28%;
	text-align: center;
	vertical-align: middle;
	font-weight: 800;
	line-height: 100%;
	/*height: 24px;*/
	padding: 0px;
	background: #fff;
}

table.calendar tr.year_row th{
	padding-bottom: 5px;
	border-bottom: 4px solid #4192c7;
}

table.calendar tr.month_row th{
	padding: 5px 0;
}

table.calendar th{
}

table.calendar td{
	color: #90c0dd;
}
/*
table.calendar td.today{
	background: #888888;
	color:#fff;
	border: 1px solid #FFF;
}
*/
table.calendar td.selected{
	background: #4192C7;
	color:#fff;
}
/*
table.calendar td.today a:link,
table.calendar td.today a:visited,
*/
table.calendar td.selected a:link,
table.calendar td.selected a:visited{
	color:#fff;
}

table.calendar .year_name,
table.calendar .month_name{
	font-size: 1.846em;
	font-weight: 800;
	/*text-transform: uppercase;*/
}

table.calendar thead a{
	display: block;
	font-size: 1.692em;
}

#cal_loading{
	background-color: rgba(221, 221, 221, 0.5);
	width: 100%;
	height: 100%;
	position: absolute;
	top: 0px;
	left: 0px;
	border-radius: 10px;
	z-index: 5;
	display: none;
}

#cal_loading_inner{
	background: transparent url(/images/logo-loading.png) no-repeat center center;
	-webkit-animation: rotating 0.5s linear infinite;
	position: absolute;
	left: 50%;
	top: 50%;
	margin: -19px 0 0 -20px;
	width: 40px;
	height: 38px;
}

h2.home_sep{
	padding-top: 45px;
	background: transparent url(/images/home-seperator.png) repeat-x center top;
	background-size: auto 45px;
	font-size: 2em;
	text-align: center;
	height: 36px;
	line-height: 130%;
	margin: 10px 0;
	color: #4192C7;
}

h2.blog_sep{
	padding-top: 25px;
	background: transparent url(/images/home-seperator.png) repeat-x center top;
	background-size: auto 25px;
	font-size: 1.3em;
	text-align: center;
	height: 36px;
	line-height: 130%;
	margin: 10px 0;
	color: #4192C7;
}

#home_panels{
	text-align: center;
}

.home_panel{
	float: left;
	width: 23.8%;
	margin-left: 1.6%;
	position: relative;
}

.home_panel:first-child,
#home_social .home_panel:first-child,
#home_blog .home_panel:first-child{
	margin-left: 0%;
}

.hp_image{
	display: block;
	width: 100%;
	padding-bottom: 53%;
	border-radius: 8px;
	-webkit-border-radius: 8px;
	-moz-border-radius: 8px;
	-ms-border-radius: 8px;
	overflow: hidden;
	background-size: cover;
	background-position: center center;
	margin: 0 0 10px;
}


#home_panels p{
	font-size: 0.846em;
	margin: 10px 0 5px;
}

#home_panels p.large{
	font-size: 1.846em;
	line-height: 24px;
	margin:0;
}

#home_blog{
	float:left;
	width: 49%;
}

#home_social .home_panel,
#home_blog .home_panel{
	width: 49%;
	margin-left: 2%;
}

#home_blog h4{
	color:rgb(52,143,196);
	margin: 15px 0 8px;
	font-weight: bold;
}

#home_blog p{
	margin: 0 0 10px;
}

#home_blog p.date{
	position: absolute;
	top:0px;
	left: 20px;
}

p.date{
	margin: 0;
	background: transparent url(/images/home-date-bg.png) no-repeat center center;
	text-align: center;
	font-size: 1.231em;
	line-height: 16px;
	color: #737373;
	width: 40px;
	height: 33px;
	font-weight: 900;
	padding-top: 10px;
	padding-right: 3px;
}

p.date span{
	font-weight: normal;
	font-size: 9px;
	display: block;
	line-height: 10px;
}

#home_blog .hp_image{
	margin-top: 20px;
}

#home_social{
	float: right;
	width: 49%;
	position: relative;
}

article.tweet{
	position: relative;
	margin-bottom: 15px;
	min-height: 42px;
}

article.tweet p.date{
	position: absolute;
	top:0px;
	left: 0px;
}

article.tweet p.tweet_text{
	margin-left: 50px;
	line-height: 14px;
}

#home_facebook article.tweet p.date{
	right: 0px;
	left: auto;
}

#home_facebook article.tweet p.tweet_text{
	margin-left: 0px;
	margin-right: 50px;
	min-height: 30px;
	overflow: hidden;
}

article.tweet p.tweet_text.fb_text span.hellip{
	display: inline;
}
article.tweet p.tweet_text.fb_text span.part2{
	display: none;
}

article.tweet p.tweet_text.fb_text:hover span.hellip{
	display: none;
}
article.tweet p.tweet_text.fb_text:hover span.part2{
	display: inline;
}


.fb_text img{
	width: 50px;
	float:left;
	margin: 0 5px 5px 0;
	border-radius: 5px;
}

article.tweet p.tweet_text.fb_text:hover img{
	width: auto;
}

#hs_tw{
	position: absolute;
	top: -40px;
	left: 10px;
	height: 30px;
}
#hs_fb{
	position: absolute;
	top: -40px;
	right: 10px;
	height: 30px;
}

.three_cols{
	float:left;
	margin-left: 2%;
}

.four_cols{
	float:left;
	margin-left: 1.6%;
}

.six_cols{
	float:left;
	margin-left: 16px;
}

.eight_cols{
	float:left;
	/*margin-left: 12px;*/
	margin-left: 0.8%
}

.three_cols:first-child,
.four_cols:first-child,
.eight_cols:first-child,
.six_cols:first-child{
	margin-left: 0px !important; 
}

.three_cols.width1{
	width: 32%;
}

.three_cols.width2{
	width: 66%;
}

.four_cols.width1{
	width: 23.8%;
}

.four_cols.width2{
	width: 49.2%;
}

.four_cols.width3{
	width: 74.6%;
}

.four_cols.width4{
	width: 100%;
}

.four_cols.width3 .four_cols{
	margin-left: 2.1447%
}

.four_cols.width3 .four_cols.width1{
	width: 31.892%;
}

.four_cols.width3 .four_cols.width2{
	width: 65.9287%;
}

.five_cols{
	float: left;
	min-height: 1px;
}
.five_cols.width1{
	width: 20%;
}
.five_cols.width2{
	width: 40%;
}
.five_cols.width3{
	width: 60%;
}
.five_cols.width4{
	width: 80%;
}


.six_cols.width1{
	width: 178px;
}
.six_cols.width2,
.six_cols.width4 .six_cols.width1{
	width: 372px;
}
.six_cols.width3{
	width: 566px;
}
.six_cols.width4{
	width: 760px;
}
.six_cols.width5{
	width: 954px;
}

.eight_cols.width1{
	width: 11.8%;
}
.eight_cols.width2,
.eight_cols.width4 .eight_cols.width1{
	width: 24.4%;
}
.eight_cols.width3{
	width: 37%;
}
.eight_cols.width4,
.eight_cols.width4 .eight_cols.width2{
	width: 49.6%;
}
.eight_cols.width5{
	width: 62.2%;
}
.eight_cols.width6{
	width: 74.8%;
}
.eight_cols.width7{
	width: 87.4%;
}

p.day_description{
	margin: 1.5em 0;
	line-height: 150%;
	font-size: 1rem;
}

#preview_wrap{
	position: relative;
	margin: 10px 0;
}

#preview_wrap p{
	margin:0;
}

#preview_image{
	display: block;
	width: 100%;
	height: 100%;
	background-repeat: no-repeat;
	background-position: center center;
	
}

#product_preview.landscape #preview_image{
	background-size: 95% auto;
}
#product_preview.portrait #preview_image{
	background-size: auto 95% ;
}

.option_title_wrap{
	display: table;
	width: 100%;
}

.option_title{
	display: table-cell;
	/*text-transform: uppercase;*/
	text-align: center;
	font-weight: 800;
	font-size: 1.692em;
	line-height: 100%;
	height:100%;
	vertical-align: middle;
}

#preview_panel{
	position: relative;
	overflow: hidden;
	height: 100%;
}

#preview_options{
	height: 100%;
}

#preview_option_wrap{
	height: 600px;
}

#preview_option_wrap section{
	height: 100%;
}

#preview_wrap .spacer{
	overflow: hidden;
	margin:0;
	padding:0;
}

.loading{
	position: absolute;
	top: 0px;
	left: 0px;
	width: 100%;
	height: 100%;
	/*background-color: rgba(221,221,221,0.5)*/ /*url(/images/admin/loading.gif) no-repeat center center*/;
	z-index:2;
	display: none;
}

.loading img{
	position: absolute;
	left: 50%;
	top: 50%;
	margin-left: -20px;
	margin-top: -19px;
}

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

.rotating {
    -webkit-animation: rotating 0.5s linear infinite;
}

.product_preview{
	background-color: #dddddd;
	text-align: center;
	cursor: pointer;
	font-weight: 900;
	display: table;
	width: 100%;
	/*text-transform: uppercase;*/
	font-size: 1.231em;
}

.product_preview.selected{
	background-color: #4192C7;
	color:#fff;
}

#day_pics_wrap{
	height: 130px;
	margin-bottom: 0.5%;
	overflow-x: scroll;
	overflow-y: hidden;
	position: relative;
}

#day_pics{
	height: 100%;
	white-space: nowrap;
}

#day_pics article{
	height: 100%;
}


.photo_preview{
	cursor: pointer;
	height: 100%;
	position: relative;
	margin-left: 5px;
	display: inline-block;
}

.photo_preview:first-child{
	margin-left: 0;
}

.photo_preview img{
	height: 100%;
}

.photo_preview span{
	position: absolute;
	color: rgba(255,255,255,0.3);
	bottom: 10%;
	right: 10%;
	font-size: 2.308em;
	font-weight: 800;
	line-height: 100%;
}

.photo_preview.selected span{
	color:rgba(255,255,255,0.8);
}

#product_preview{
	background-color: #dddddd;
	position: relative;
	overflow: hidden;
	height: 650px;
}

.option_size_preview{
	background-color: #dddddd;
	text-align: center;
	cursor: pointer;
	font-weight: 900;
	display: table;
	width: 100%;
	font-size: 1.231em;
}

.photo_preview > div,
.product_preview > div,
.option_frame_preview > div,
.option_size_preview > div{
	display: table-cell;
	vertical-align: middle;
	width: 100%;
}

.option_size_preview.selected{
	background-color: #4192C7;
	color:#fff;
}

.option_frame_preview{
	background-color: #dddddd;
	text-align: center;
	cursor: pointer;
	font-weight: 900;
	/*text-transform: uppercase;*/
	display: table;
	width: 100%;
	font-size: 1.231em;
}

.option_frame_preview.selected{
	background-color: #4192C7;
	color:#fff;
}

#preview_frame{
	background-color: transparent;
	background-repeat: no-repeat;
	background-position: center center;
	background-size: cover;
	position: absolute;
	left: 50%;
	top: 50%;
	z-index:1;
}

#preview_photo{
	background-color: transparent;
	background-repeat: no-repeat;
	background-position: center center;
	background-size: cover;
	position: absolute;
	left: 50%;
	top: 50%;
	z-index:2;
}

#message_wrap{
	margin-top: 5px;
}

#message_label{
	background-color: #4192C7;
	color:#fff;
	text-align: left;
	font-weight: 900;
	/*text-transform: uppercase;*/
	height: 45px;
	font-size: 1.077em;
	line-height: 45px;
}

#message_label label{
	padding: 0 10px;
	display: block;
}

#message_text{
	background-color: #dddddd;
	height: 45px;
}

#message_text div{
	margin:2px;
}

#message_text textarea{
	border:0;
	background-color: #fff;
	margin: 0px;
	width: 100%;
	height: 41px;
	display: block;
	font-size: 1.077em;
	padding:0;
}

#message_text.selected{
	background-color: #4192C7;
	color:#fff;
}

#message_text.selected textarea{
	
}

#message_preview{
	font-family: 'Marck Script', cursive;
	font-size: 1.385em;
	z-index:3;
	position: absolute;
	top: 50%;
	left: 50%;
}

.date_picker{
	background: #338ec3;
	color:#fff;
	text-align: center;
	padding: 3px;
	display: none;
}

.date_picker a.button:link,
.date_picker a.button:visited{
	background:#fff;
	color: #338ec3;
}
.date_picker a.button:hover{
	background:#888;
	color: #fff;
}

.date_picker h2{
	color: #fff;
}


#dp_close{
	position: absolute;
	right: 5px;
	top: 5px;
	font-weight: 800 !important;
	font-size: 1.077em !important;
	padding: 0px !important;
	background-color: transparent !important;
	text-transform: none !important;
	color:#fff;
	margin: 0 !important;
}

#checkout_now{
	font-size: 1.385em;
	float:right;
}

#basket{
	width: 100%;
	border-spacing:0;
    border-collapse:collapse;
	box-shadow: 0 0 10px 1px rgba(0,0,0,0.3);
    border-radius: 10px;
}

#basket th {
	font-size: 1.25em;
	font-weight: 800;
	padding: 1.5rem;
	/*text-transform: uppercase;*/
	vertical-align: middle;
	border: 1px solid #e4e4e4;
	background: #fff;
}
#basket thead th {
	background: #4795c7;
	color: #fff;
	font-family: "Source Serif Pro", Sans-serif;
    font-weight: 500;
    font-size: 1.75em;
}

#basket td {
	padding: .5rem;
	vertical-align: middle;
	background: #fff;
}
#basket tbody > tr:first-child > td {
    padding-top: 2rem;
}
#basket tbody > tr:last-child > td {
    padding-bottom: 2rem;
}
@media (min-width: 768px) {
	#basket td {
		padding: 1rem;
	}
}

#basket .price{
	font-size: 1.538em;
	font-weight: 800;
}

#basket img{
	vertical-align: middle;
	max-width: 100%;
	max-height: 100%;
}

#delivery_description{
	font-size: 0.7em;
	text-transform: none;
	margin: 10px 0 0;
	font-weight: normal;
	line-height: 120%;
}

#voucher_text,
#basket_delivery{
	vertical-align: middle;
	max-width: 350px;
	width: 100%;
	margin-top: 10px;
}

#customer_checkout .three_cols{
	text-align: center;
}

#customer_checkout{
	padding-top: 20px;
	margin-bottom: 20px;
}

#customer_checkout h2{
	margin: 0;
	float:left;
	font-size: 1rem;
}

#customer_checkout input:not([type=submit]) {
	width: 90%;
	text-align: left;
	padding: 5px;
	margin:0 auto;
	display: block;
}
#customer_checkout label{
	width: 90%;
	text-align: left;
	margin: 10px auto 0;
	line-height: 20px;
	display: block;
	font-size: 1.077em;
}
@media (max-width: 1000px) {	
	#customer_checkout input:not([type=submit]) {
		width: 97%;
	}
	#customer_checkout label{
		width: 100%;
	}
}

#use_billing{
	float:right;
	width: auto;
	text-align: right;
}

#use_billing label,
#use_billing input{
	float:none;
	width: auto;
	margin:0;
	vertical-align: middle;
	display: inline;
	font-size: 0.846em;
}
#use_billing label > * {
    display: inline-block !important;
}
#use_billing label > input {
    width: auto !important;
    margin: .25rem !important;
}

#customer_checkout .button{
	margin: 20px 0;
	width: auto;
}

#card_details{
	width: 520px;
    margin: 0 auto;
    background: #f9f9f9;
    border: 1px solid #dcdcdc;
    border-radius: 5px;
    padding: 1rem;
}

#errors{
	background:#a00;
	color:#fff;
	padding: 20px;
	font-size: 1.231em;
	margin-bottom: 20px;
}

#errors ul{
	list-style-type: disc;
	padding-left: 25px;
	margin-top: 10px;
}

.add_basket{
	position: absolute;
	right: 10px;
	bottom: 10px;
}

#voucher_text{
	width: 180px;
	float:none;
	margin: 10px 0 0;
	font-size: .9em;
	vertical-align: middle;
}

#voucher_submit{
	width: auto;
    float: none;
    margin: 10px 0 0;
    padding: 5px 12px;
}

#page_wrap{
	margin-top: 1em;
}

#page_left{
	min-height: 100px;
}

#page_banner,
#page_right img,
#page_left img{
	width: 100%;
	margin-bottom: 10px;
}

#day_pics_preview_wrap{
	position: relative;
}

#photo_preview_pu{
	position: absolute;
	width: 100%;
	text-align: center;
	z-index:5;
}

#photo_preview_pu img{
	height: 100%;
	border: 5px solid #fff;
	box-shadow: 0px 0px 10px #888;
}

form.page_contact_form{
	max-width: 500px;
	margin: 0 auto;
}

form.page_contact_form label{
	width: 90%;
	float: none;
}

form.page_contact_form input{
	float: none;
	width: 90%;
	
}

form.page_contact_form select{
	float: none;
	width: auto;
	
}

#digi-download-form > *{
	width: 100%;
}

#get_download{
	display:none;
}

#digi-download-form .date_select_container{
	width: auto;
}

#digi-download-form .date_select_container select{
	margin:0;
}

#digi-download-date-search > *{
	display: inline;
}

#search-digi-download-date{
	width: auto;
	margin: 0;
}

.ddf-step2{
	text-align: center;
}

.step,
.info_box,
#info_box,
#preview_box,
#step_box{
	border-radius: 15px;
	padding: 0;
	box-sizing: border-box;
	-moz-box-sizing: border-box;
	-webkit-box-sizing: border-box;
	float:left;
	height: 650px;
	overflow: auto;
	margin-bottom: 20px;
}

#step1, #step2, #step3, #step4, #step5{
	height: 100%;
}

#preview_box{
	width: 75%;
	margin: 0;
	position: absolute;
	top: 0px;
	left: 24%;
}

#preview_box .box_body{
	width: 90%;
	margin: 0 auto;
	background-size: contain;
	background-position: center center;
	background-repeat: no-repeat;
	background-color: transparent;
}

.step,
.info_box,
#info_box,
#step_box{
	width: 23%;
}

#info_box .box_footer{
	text-align: center;
	font-size: 1.385em;
	font-weight: 800;
}

#choose_photos{
	padding: 0 20px;
	overflow: auto;	
}

.choose_photo{
	position: relative;
	margin: 0 auto 10px;
}
.choose_photo.portrait{
	width: 50%;
}
.choose_photo img{
	width: 100%;
	cursor: pointer;
}
.choose_photo img{
	display: block;
}

.choose_photo span{
	position: absolute;
	bottom: 5px;
	right: 5px;
	color: rgba(255,255,255,0.5);
	font-weight: 800;
	padding: 5px;
	font-size: 1.538em;
}

.choose_photo.selected span{
	background: #3791CF;
	color: rgba(255,255,255,1);
}

.box_header,
.box_footer{
	height: 12%;
	margin:0;
	overflow: hidden;
}
#preview_box .box_header {
    height: 8%;
}

.box_body{
	height: 76%;
}

.step .box_header,
.step .box_footer,
.info_box .box_header,
.info_box .box_footer,
#info_box .box_header,
#step_box .box_header,
#step_box .box_footer,
#preview_box .box_header,
#preview_box .box_footer{
	text-align: center;
    padding: 0;
    box-sizing: border-box;
    -moz-box-sizing: border-box;
    -webkit-box-sizing: border-box;
    position: relative;
    font-weight: 600;
    font-size: 1.1rem;
}

#step_box .box_footer{
	font-size: 1.154em;
}

#info2{
	padding: 0 20px;
	text-align: center;
	color: #3791cf;
	font-size: 1.385em;
	font-weight: 800;	
	line-height: 21px;
}

#info3{
	padding: 0 20px;
	text-align: center;
	color: #3791cf;
	font-size: 1.385em;
	font-weight: 800;	
	line-height: 21px;
}

#info4{
	padding: 0 20px;
}

#info5{
	padding: 1.25rem 1rem;
    text-align: center;
    color: #3791cf;
    font-size: 1.385em;
    font-weight: 800;
    line-height: 21px;
    border: 1px solid #4795c7;
    margin-top: 1rem;
}
#info5 h2 {
    font-size: 1rem;
    font-family: Nunito, sans-serif;
    color: #525e66;
    font-weight: 600;
    margin-bottom: .75rem;
}

.info p{
	font-size: 11px;
}

.info p span{
	line-height: 120%;
}

.vidlink{
	font-size: 0.8em;
}

#steps_nav{
	padding: 1.5rem;
	border-bottom: 1px solid #d4d4d4;
}

.step{
	position: absolute;
	top: 0px;
	height: 650px;
	left: 0px;
	border-right: 1px solid #d4d4d4;
	border-radius: 0;
}

.info_box{
	position: absolute;
	top: 0px;
	height: 650px;
	right: 0px;
}


.step .cell_layout{
	padding: 0 20px;
}
.box_body .cell_layout {
	vertical-align: top;
}

.step_nav{
	width: 18.8%;
	float:left;
	margin-left: 1.5%;
	cursor: pointer;
}

.step_nav.inactive{
	opacity: 0.4;
}

.step_nav a{
	display: block;
	visibility: hidden;
	text-transform: none;
	font-weight: normal;
}

.step_nav.done a{
	visibility: visible;
}


.step_nav:first-child{
	margin-left: 0%;
}

.step_nav > span{
	float:left;
	background: transparent url(/images/logo-loading.png) no-repeat center top;
	background-size: 100% auto;
	width: 15%;
	height: 30px;
	line-height: 30px;
	margin-top: 2%;
	font-weight: 800;
	text-align: center;
	font-size: 1.615em;
	color:#fff;
	
}

.step_nav > div.step_nav_title {
	float: right;
    width: 80%;
    border-radius: 5px;
    padding: 5px;
	font-size: .75rem;
    box-sizing: border-box;
    -moz-box-sizing: border-box;
    -webkit-box-sizing: border-box;
    font-family: "Source Serif Pro", Sans-serif;
    font-weight: 500;
    line-height: 1;
}
@media (min-width: 768px) {
	.step_nav > div.step_nav_title {
		font-size: 1.3rem;
	}
}
@media (min-width: 1000px) {
	.step_nav a{
		margin-top: 10px;
	}	
}


#choose_message{
	width: 100%;
	padding: 5px;
	border: 1px solid #3791cf;
	height: 50px;
	box-sizing: border-box; 
	-moz-sizing: border-box; 
	-webkit-sizing: border-box; 
}

#choose_confirm dl{
	font-size: 1.077em;
	overflow: auto;
}

#choose_confirm dl dt{
	font-weight: bold;
	float: left;
	clear: both;
}
#choose_confirm dl dd{
	font-weight: bold;
	margin-bottom: 5px;
	text-align: right;
	color:#bbb;
	float: right;
	clear: right;
}

#choose_sizes li{
	display:none;
}

#extra_title{
	display: none;
}

.extratype{
	display: none;
}

.extra input{
	float:left;
	width: auto;
}

.extra p{
	float:right;
	width: 85%;
	text-align: left;
	font-weight: normal;
    font-size: .8rem;
    line-height: 1.3;
}
.extra label {
	width: auto;
	padding: 0;
	font-size: 1em;
}

.extra p strong{
	font-weight: 800;
}

#choose_types ul{
	list-style-type:none;
	padding-left: 0px;
}

#choose_types ul li{
	/*line-height: 190%;*/
}

#choose_types ul ul{
	padding-left: 20px;
	/*display: none;*/
}

span.type_icon{
	/*cursor: pointer;*/
}

#choose_types span.type_icon{
	width: 25px;
	display: block;
	float: left;
	text-align: center;
}

#choose_types span.type_icon img{
	vertical-align: sub;
}

/*#choose_types .frame_type_label,*/
#choose_types label{
	cursor: pointer;
	color: #4192C7;
}

#choose_sizes ul{
	list-style-type:none;
	padding-left: 0px;
}

#choose_sizes ul ul{
	padding-left: 20px;
}

#choose_sizes label{
	cursor: pointer;
	color: #4192C7;
}

#social_wrap{
	position: relative;
}

#video_close{
	position: absolute;
	bottom: 0px;
	right: 5%;
	cursor: pointer;
	font-size: 0.769em;
	display: none;
}

.type_from_price{
	font-size: .85em;
    float: right;
    padding-top: .15em;
    color: #525e66;
}

#size_images{
	position: relative;
	text-align: center;
}

#size_images img{
	max-width: 90%;
}

.size_image{
	display: none;
}

#page_left ul{
	padding:0;
	margin: 0 0 20px;
	list-style-type:none;
}

#page_left ul li{
	font-size: 1.231em;
	line-height: 1.5em;
	font-weight: 800;
	margin: 0.5em;
}

#sub_nav h3{
	margin:0 0 5px;
	text-transform: none;
}

#sub_nav ul li{
	font-size: 1.077em;
	line-height: 18px;
	font-weight: normal;
}

#sub_nav ul li.current a:link,
#sub_nav ul li.current a:visited{
	color: #333333;
}

#addToBasket{
	margin-bottom: 15px;
	float: none;
	width: 100%;
	display: block;
	box-sizing: border-box;
	-moz-box-sizing: border-box;
	-webkit-box-sizing: border-box;
	font-size: 1.25rem;
	line-height: 100%;
	margin-top: 30px;
}

.template1 .image1 img,
.template1 .image2 img,
.template1 #page_right img{
	width: 100%;
	margin-bottom: 15px;
	display: block;
}

.template2 #page_images{
	margin-bottom: 20px;
}

.template2 #page_images img{
	width: 32%;
	margin-left: 2%;
	display: block;
	float:left;
}

.template3 #page_images img{
	width: 100%;
	margin-bottom: 5%;
	display: block;
}

.template2 #page_images a:first-child img{
	margin-left: 0;
}

#page_main{
	box-sizing: border-box;
	-moz-box-sizing: border-box;
	-webkit-box-sizing: border-box;
	padding: 0 2%;
}

#cookie,
#custom_message{
	position: fixed;
	bottom: 40px;
	right: 40px;
	border: 4px solid #3F91CF;
	border-radius: 10px;
	padding: 10px 20px;
	background-color: #fff;
	width: 286px;
	box-shadow: 2px 2px 10px rgba(0,0,0,0.5);
	display:none;
	z-index: 10;
}

#cookie{
	right:0;
	left: 40px;
}

#cookie .close:link,
#cookie .close:visited,
#custom_message .close:link,
#custom_message .close:visited{
	display: block;
	width: 40px;
	height: 38px;
	line-height: 38px;
	background: transparent url(/images/logo-loading.png) no-repeat center center;
	position: absolute;
	top: -30px;
	right: 10px;
	text-align: center;
	color:#fff;
	font-size: 14px;
	font-weight: bold;
}

#cookie .close:link,
#cookie .close:visited{
	right:0;
	left: 10px;
}


#cookie p,
#custom_message p{
	margin:0;
}

div.video_wrap{
	position: relative;
}
div.video_wrap img{
	width: 100%;
	
}

div.video_wrap a::before {
	color: #FFF;
	content: "\25B6";
	opacity: 0.8;
	position: absolute;
	text-shadow: 0 3px #555;
	z-index: 10;
	font-size: 3.846em;
	position: absolute;
	left: 50%;
	top: 50%;
	margin-left: -20px;
	margin-top: -10px;
}

div.video_pu{
	position: fixed;
	background: rgba(0,0,0,0.5);
	width: 100%;
	height: 100%;
	display: none;
	left: 0px;
	top: 0px;
	z-index: 100;
}

div.video_pu iframe{
	display: block;
	position: absolute;
	top: 50%;
	left: 50%;
	margin-left: -400px;
	margin-top: -225px;
	width: 800px; 
	height: 450px;
}

div.video_pu a{
	position: absolute;
	top: 20px;
	right: 20px;
	color:#fff;
	font-size: 2.308em;
	font-weight: 800;
}

#examples{
	font-size: 0.846em;
}

#examples dt{
	font-weight: bold;
	
}

#examples dd{
	font-style: italic;	
}

.size_inch{
	display: none;
}

#compare_overlay {
    display: none;
    background: rgba(255, 255, 255, 0.95);
    position: fixed;
    top: 12px;
    left: 0px;
    width: 90%;
    height: 25%;
    z-index: 200;
    left: 5%;
    border-radius: 20px;
    box-shadow: 0 0 10px 1px rgba(0,0,0,0.3);
}
@media (min-width: 768px) {
	#compare_overlay {
	    height: 45%;
	}
}
@media (min-width: 992px) {
	#compare_overlay {
	    width: 80%;
	    left: 10%;
	}
}

.compare_half{
	position: absolute;
	top: 10%;
	height: 80%;
	width: 40%;
	box-sizing: border-box;
	-moz-box-sizing: border-box;
	-webkit-box-sizing: border-box;
	padding: 30px;
	background-position: center center;
	background-repeat: no-repeat;
	background-size: contain;
}

#compare_left{
	left: 5%;
}
#compare_right{
	right: 5%;
}

#compare_close {
    position: absolute;
    right: 1rem;
    top: 1rem;
    font-size: 1.75rem;
    color: #4795c7;
    font-weight: bold;
    cursor: pointer;
}

.compare_half .controls{
	position: absolute;
	bottom: 5px;
	left: 0px;
	width: 100%;
	text-align: center;
}
.compare_half .controls > * {
    vertical-align: middle;
    line-height: 1.2;
    font-weight: 600;
}
.compare_half .controls .button {
	padding: 0.375em 0.625em;
	background: none !important;
	font-size: 1.25em;
}
.compare_half .controls .button:hover {
	background-color: #888888 !important;
}

.compare_half span.number {
	font-weight: 600;
	font-size: 1.75em;
    padding: 0 .25rem;
}

#other_sizes{
	margin-top: 10px;
	font-weight: bold;
}

#comments{
	margin-top: 20px;
}
	
#basket_checks{
	font-size: 1.077em;
	margin-bottom: 1em;
    font-weight: 800;
	color: #000;
    padding: 1em 0;
}
#basket_checks label {
    line-height: 1.2;
    margin-bottom: 0;
    display: block;
}
#basket_checks label > * {
    display: inline-block;
    vertical-align: middle;
}
#basket_checks label > span {
    width: 80%;
    width: calc(100% - 32px);
}
#basket_checks label > input {
    width: 18px;
}
#basket_checks input{
	margin:0 0 0 10px;
	vertical-align: middle;
}

.voucher_size{
	float:left;
	width: 18%;
	margin-left: 2.5%;
}

.voucher_size:nth-child(5n+1){
	margin-left: 0;
}

#payment_amount{
	font-size: 3em;
	text-align: center;
	font-weight: 800;
}

#confirm_payment{
	margin: 0 auto;
	display: block;
	float: none;
}

#confirm_payment:disabled{
	background: #888;
	color: #aaa;
}

.blog_image_panel{
	float: right;
	text-align: right;
	margin: 0 0 1em 1em;
	width: 50%;
}

.blog_image_panel img{
	max-width: 100%;
}

.collection{
	display: inline-block;
	width: 250px;
	padding: 10px;
	text-align: center;
	background: #ddd;
	margin: 5px;
}

.collection .image{
	height: 250px;
	line-height: 250px;
}

.collection img{
	max-width: 250px;
	max-height: 250px;
	vertical-align: middle;
}

.collection p{
	margin: 5px 0;
}

.collection .button{
	font-size: 0.9em;
	display: block;
	
}

img.collection_detail_image{
	max-width: 90%;
	max-height: 400px;
}

#widget_wrap{
	float:left;
	margin-right: 10px;
	min-width: 500px;
	text-align: center;
}

#widget_form{
	float:left;
}


#widget_form label{
	width: auto;
	clear: none;
}

#widget_form input{
	width: auto;
	clear: left;
}

#steps_area{
	position: relative;
	margin-bottom: 20px;
}
@media screen and (min-width: 1001px) {
	#steps_area{
		min-height: 650px;
	}
}

#envelope{
	max-width: 500px;
	width: 49%;
	position: relative;
	z-index: 1;
	float:left;
}

#envelope_front{
	width: 100%;
	height: 100%;
	position: absolute;
	z-index: 3;
	top: 0px;
	left: 0px;
}

#voucher{
	width: 80%;
	position: absolute;
	top: 35%;
	left: 10%;
	z-index: 2;
	
	border-radius: 0.5em;
	-webkit-border-radius: 0.5em;
	-moz-border-radius: 0.5em;
	-ms-border-radius: 0.5em;
	overflow: hidden;
	
	-webkit-transition: all 0.3s ease-in-out;
	-moz-transition: all 0.3s ease-in-out;
	-o-transition: all 0.3s ease-in-out;
	transition: all 0.3s ease-in-out;
}

#envelope.popped_up #voucher{
	top: 10%;
	-webkit-transform: rotate(13deg);
	
	-webkit-transition: all 0.3s ease-in-out;
	-moz-transition: all 0.3s ease-in-out;
	-o-transition: all 0.3s ease-in-out;
	transition: all 0.3s ease-in-out;
}

#envelope img,
#envelope_front img,
#voucher img{
	width: 100%;
}

#envelope_details{
	float:right;
	width: 49%;
	margin: 30px 0;
}

#envelope_details p{
	margin: 30px 0;
	
}

#envelope_details .button{
	width: auto;
}

#errors *{
	color:#fff;
}

.ex_large{
	font-size: 2em;
	line-height: 150%;
}

.syv_email{
	float: left;
	width: 45%;
}

.syv_link{
	float: right;
	width: 45%;
}


.blog_pages{
	line-height: 30px;
	margin-bottom: 20px;
}

.blog_pages span{
	float:left;
	margin-right: 30px;
}
.blog_pages ol{
	float:left;
	list-style-type:none;
	padding:0;
	margin:0;
}

.blog_pages ol li{
	float:left;
	font-size: 14px;
	padding: 0 10px;
}

.blog_pages ol li.current{
	background: #4192C7;
	color:#fff;
}

#new_blog .nb_category{
	display: block;
	float: left;
	background-repeat: no-repeat;
	background-position: center center;
	background-size: cover;
	position: relative;
	margin-bottom: 20px;
	box-shadow: inset 0px -60px 80px rgba(0,0,0,0.6);
}

#new_blog .nb_category.height1{
	height: 190px;
}

#new_blog .nb_category.height2{
	height: 400px;
}

#new_blog .nb_category .nb_category_details{
	color:#fff;
	text-align: center;
	position: absolute;
	bottom: 20px;
	left: 0px;
	width:100%;
	text-shadow: 0px 0px 20px rgba(0,0,0,1);
}

#new_blog .nb_category .nb_category_details p{
	margin:0;
}

#new_blog .nb_category .nb_category_details p:nth-child(1){
	font-size: 16px;
	margin-bottom: 6px;
	font-weight: 800;
	/*text-transform: uppercase;*/
}

#new_blog .nb_category.width2 .nb_category_details p:nth-child(1){
	font-size: 20px;
}

#new_blog .nb_category .nb_category_details p:nth-child(2){
	font-size: 18px;
}

#new_blog .nb_category.width2 .nb_category_details p:nth-child(2){
	font-size: 22px;
}



#nb_categories.cats6 .nb_category:nth-child(3),
#nb_categories.cats7 .nb_category:nth-child(4),
#nb_categories.cats8 .nb_category:nth-child(5){
	margin-left: 0;
}

.article_summary .article_summary_image{
	background-color: #dddddd;
	background-position: center center;
	background-size: cover;
	height: 200px;
	display: block;
}
.article_summary h3{
	margin: 0.6em 0;
}

.article_summary p.date{
	float: right;
	margin: 10px 0 0 10px;
}

p.article_summary_comments{
	color: #ccc;
	font-size: 0.8em;
}

.article_snippet{
	font-size: 0.9em;
	line-height: 120%;
}

.article_snippet .article_snippet_image{
	background-color: #dddddd;
	background-position: center center;
	background-size: cover;
	height: 80px;
	display: block;
	width: 40%;
	float:left;
	margin: 0 0.6em 0.6em 0;
}
.article_snippet h3{
	margin: 0.6em 0;
}

.article_snippet p.date{
	float: right;
	margin: 0 0 0 0.6em;
}

.article_snippet p.snippet_content{
	
}

#nb_article_images{
	margin-bottom: 10px;
}

#new_blog_article .nb_article_image{
	background-color: #dddddd;
	background-position: center center;
	background-size: cover;
}

#new_blog_article .nb_article_image.height1{
	height: 145px;
	margin-bottom: 10px;
}

#new_blog_article .nb_article_image.height2{
	height: 300px;
}

#beau_prods td{
	font-size:14px;
	font-weight: bold;
}

#blog_search{
	float: right;
	
}
#blog_search input,
#blog_search button{
	vertical-align: middle;
	float:none;
}

#blog_search input{
	width: 100px;
}

#blog_search button img{
	margin-left:0 !important;
}

#share_bar{
	background: #338EC3;
	color: #fff;
	padding: 5px 20px;
}

#share_bar h2{
	color: #fff;
	float:left;
}

#share_bar p{
	margin-left: 20px;
	float:left;
}

#share_bar p img{
	margin: 0 10px;
	vertical-align: middle;
}

#share_bar > *{
	margin-bottom: 0;
}

#blog_back{
	margin: 20px 0;
}

#lower_page_cta{
	text-align: center;
}

.date_picker *,
#lower_page_cta *{
	width: auto;
	vertical-align: middle;
	margin: 0 3px;
	float: none;
	display: inline-block;
}

.date_picker option,
#lower_page_cta option{
	display: block;
}

.date_picker > *,
#lower_page_cta > *{
	margin: 5px 3px;
}

#cardlogos{
	text-align: center;
	margin-top: 30px;
}

#cardlogos img{
	vertical-align: middle;
}

#signup_pu{
	position: fixed;
	width: 100%;
	height: 100%;
	background-color: rgba(255,255,255,0.7);
	top: 0px;
	left: 0px;
	z-index: 100;
	display: none;
}

#signup_pu form{
	position: absolute;
	background-color: #fff;
	padding: 20px;
	box-shadow: 5px 5px 10px rgba(0,0,0,0.5);
	top: 50%;
	left: 50%;
	transform: translateX(-50%) translateY(-50%);
	-webkit-transform: translateX(-50%) translateY(-50%);
	-moz-transform: translateX(-50%) translateY(-50%);
	-ms-transform: translateX(-50%) translateY(-50%);
	border-radius: 10px;
	-webkit-border-radius: 10px;
	width: 308px;
	text-align: center;
}

#signup_pu form h3{
	text-align: center;
}

#signup_pu input{
	float: none;
	display: block;
	margin: 10px auto;
}

#signup_pu p{
	margin:0;
}

#summary_message{
	color: #000 !important;
}

#summary_message_notice{
	display:none;
	font-weight: bold;
	clear: both;
	text-align: center;
	margin: 1em 0 0;
}

#order-processed-message{
	font-weight: 800;
	/*text-transform: uppercase;*/
	display: none;
	clear: left;
	margin: 20px auto;
}

#digi-download-form{
	max-width: none;
}

.ddf-step1{
	width: 500px !important;
	margin: 0 auto;
}

#digi-download-date-results .div{
	position: relative;
}

#digi-download-date-results img{	
	cursor: pointer;
}

#digi-message{
	display: block;
	width: 500px;
	margin: 10px auto;
	max-width: 98%;
}

#digi-download-confirm{
	position: fixed;
	top: 20%;
	left: 20%;
	width: 60%;
	padding: 20px;
	background: #fff;
	box-shadow: 0 0 10px 0px;
	z-index: 999;
	display: none;
}

#digi-download-confirm-close{
	position: absolute;
	top: 10px;
	right: 10px;
	font-size: 20px;
	font-weight: 800;
}

#digi-download-confirm > *{
	display: block;
	margin: 0 auto;
}

#digi-download-confirm img{
	margin-bottom: 20px;
	max-height: 50vh;
}

#download-page{
	text-align: center;
}

#downloaded-image{
	margin-bottom: 20px;
}

#share-facebook{
	background-color: #3B5998;
}

#share-twitter{
	background-color: #1DA1F2;
}

#share-googleplus{
	background-color: #DB4437;
}

#share-pinterest{
	background-color: #B3081B;
}

#download-share-buttons a{
	margin: 0 5px;
}

#download-share-buttons a:hover{
	background: #888888;
}

#digi-personalisation{
	display: none;
}

/*Stripe*/

/**
 * The CSS shown here will not be introduced in the Quickstart guide, but shows
 * how you can use CSS to style your Element's container.
 */
.StripeElement {
	background-color: white;
	height: 20px;
	padding: 10px 12px;
	border-radius: 1px;
	border: 1px solid #ccc;
	margin-bottom: 18px;
}

.StripeElement--focus {
	box-shadow: 0 1px 3px 0 #cfd7df;
}

.StripeElement--invalid {
	border-color: #fa755a;
}

.StripeElement--webkit-autofill {
	background-color: #fefde5 !important;
}
#card-errors{ margin-bottom: 15px;}
#confirm_stripe{ display: block; margin: auto; float: none; }




/*--------------------- Instagram ---------------------------------*/
.instagram__list {
	display: flex;
	flex-wrap: wrap;
}
.instagram__item {
	width: 33.3333%;
}
.instagram__item > div {
	padding: 5px;
}

.instagram__list .image {
	width: 100%;
	background-size: cover !important;
	height: 177px;
	border-radius: 10px;
}
.instagram__item .box{
	position: relative;
	overflow: hidden;
}

.instagram__item .count {
	font-size: 10px;
	padding-left: 4px;
}

.instagram__item .like {
	position: absolute;
	display: flex;
    align-items: center;
	top: 7px;
	right: 7px;
	background: rgba(0,0,0, 0.5);
	padding: 0 3px;
	color: #ffffff;
	opacity: 0;
	transition: all .3s linear;
	transform: translateY(-200%);

}
.instagram__item:hover .like {
	opacity: 1;
	transform: translateY(0);
}
.instagram__item .like .heart {
	width: 10px;
	height: 10px;
}
.instagram__item .caption {
    font-size: 10px;
    line-height: 1.1;
    position: absolute;
    bottom: 0;
    padding: 10px;
    background: rgba(0,0,0,0.5);
    color: #fff;
    transform: translateX(100%);
    opacity: 0;
    transition: all .3s linear;
    border-bottom-left-radius: 10px;
    border-bottom-right-radius: 10px;
}
.instagram__item:hover .caption {
	opacity: 1;
	transform: translateX(0);
}
.inst_logo {
	position: absolute;
    top: -40px;
    right: 10px;
    height: 30px;
}
.instagram__item .video {
	position: absolute;top: 7px; left: 7px;
}
#social_wrap { display: flex; flex-wrap: wrap;}

#social_wrap .instagram-feed {
	width: 100%;
}
@media (min-width: 601px) and (max-width: 767px){
	.instagram__item {
    	width: 50%;
	}
}
@media (max-width: 425px){
	.instagram__item {
    	width: 50%;
	}
	.instagram__list .image {
		height: 190px;
	}
	.instagram__item .like {
		padding: 2px 3px;
	}
}

/* Font Awesome */
.fa, .far, .fas {
	font-family: "Font Awesome 5 Free Solid", "Font Awesome 5 Free" !important;
}

/* About this day */
#about_this_day {
    margin-top: 1.5rem;
	line-height: 1.5;
}
#about_this_day .right {
	margin-top: 3rem;
}
#about_this_day h2 {
    font-size: 1.5rem;
}
#about_this_day #photographers {
	float: right;
}
#about_this_day .photographerImage {
    width: 125px;
    height: 125px;
    margin: 0 0 1rem 1rem;
    border-radius: 50%;
    background-size: cover;
    background-position: center;
}
#about_this_day .day_description {
	color: #525e66;
    font-family: "Nunito", Sans-serif;
    font-weight: 300;
}
@media screen and (min-width: 768px) {
	#about_this_day .right {
		margin-top: 0;
	}
}

/* Accordion */
.accordion .accordion-item,
#choose_types > .cell_layout > ul > li {
    border: 1px solid #d4d4d4;
	margin-bottom: -1px;
}
.accordion .accordion-item .tab-title,
#choose_types > .cell_layout > ul > li .type_label {
    margin: 0;
    font-weight: 700;
    line-height: 1;
    cursor: pointer;
    outline: none;
    font-size: 1rem;
    color: #4795c7;
    font-weight: 500;
}
.accordion .accordion-item .tab-title {
    padding: 15px 20px;
}
#choose_types > .cell_layout > ul > li .type_label {
	padding: 10px 15px;
}
.accordion .accordion-item .tab-title.active,
#choose_types > .cell_layout > ul > li .type_label.active {
    color: #6ec1e4;
}
#choose_types .type_label:before {
    -moz-osx-font-smoothing: grayscale;
    -webkit-font-smoothing: antialiased;
    display: inline-block;
    font-style: normal;
    font-variant: normal;
    text-rendering: auto;
    line-height: 1;
    font-family: "Font Awesome 5 Free Solid", "Font Awesome 5 Free" !important;
    content: '\f107';
    font-weight: 900;
    margin-right: .25rem;
}
#choose_types .type_label.active:before {
    content: '\f106';
}
.accordion .accordion-item .tab-title .accordion-icon {
    display: inline-block;
    width: 1.5em;
}
.accordion .accordion-item .tab-title .accordion-icon-opened,
.accordion .accordion-item .tab-title.active .accordion-icon-closed {
	display: none;
}
.accordion .accordion-item .tab-title .accordion-icon-closed,
.accordion .accordion-item .tab-title.active .accordion-icon-opened {
	display: inline;
}
.accordion .accordion-item .tab-content,
#choose_types > .cell_layout > ul > li > ul {
    padding: 15px 20px;
    border-top: 1px solid #d4d4d4;
    color: #525e66;
    font-family: "Nunito", Sans-serif;
    font-weight: 300;
}
.accordion .accordion-item .tab-content {
    font-size: 1rem;
    padding: 15px 20px;
}
#choose_types > .cell_layout > ul > li > ul {
	padding: 10px 15px;
}
#choose_types > .cell_layout > ul > li > ul.active{
	display: block;
}
#choose_types label {
	color: #525e66;
	vertical-align: middle;
}


.configuratorArea {
	box-shadow: 0 0 10px 1px rgba(0,0,0,0.3);
	border-radius: 10px;
}


/* Lightbox */
.lightboxOverlay {
    background-color: #fff !important;
}
.lb-dataContainer {
    position: absolute;
    top: .75rem;
    z-index: 500;
}
.lightbox .lb-image {
    box-shadow: 0 0 10px 1px rgba(0,0,0,0.3);
    border-radius: 10px;
}


/* Empty Basket */
.emptyBasket h2,
.emptyBasket p {
    color: #4795c7;
    font-family: "Source Serif Pro", sans-serif;
    font-size: 1.5rem;
    text-align: center;
    font-weight: 500 !important;
    margin-bottom: 1rem;
    line-height: 1.2;
}
.emptyBasket .btnWrapper {
	margin-top: 2rem;
}
.emptyBasket .btnWrapper .button {
	font-size: 15px;
}
@media (min-width: 992px) {
	.emptyBasket h2,
	.emptyBasket p {
	    font-size: 2rem;
	    margin-bottom: 1.25rem;
	}
	.emptyBasket .btnWrapper {
		margin-top: 3rem;
	}
}



/* Basket */
.remove-item .fa-times {
    color: #dc3545;
}
.remove-item:hover .fa-times {
    opacity: 0.8;
}



/* Checkout */
.paymentAmountWrapper {
    padding: 1rem 0 2rem;
}
.paymentAmountWrapper > *:last-child {
    margin-bottom: 0;
}
.paymentAmountWrapper h2 {
	margin-bottom: .25em;
	font-size: 1rem;
}



/* Checkout - Confirmation */
.confirmation_wrapper img {
	margin: 0 auto 2rem;
    display: block;
}
.confirmation_wrapper p {
	font-size: 1.25em;
    text-align: center;
}


/* Images not available yet */
.inProcess-text p {
    font-size: 1rem;
}