body{margin:0;padding:0;}
img{border:0;}
.fl_menu{list-style:none;margin:0;padding:0;}
.cms_imgleft{margin:3px 5px 5px 0;float:left;border:1px solid #000;}
.cms_imgright{margin:3px 0 5px 5px;float:right;border:1px solid #000;}
h1{margin:0;font-size:28pt;line-height:30pt;}
h2{font-size:20pt;line-height:24pt;}
h2, h3{margin:0 0 5px 0;}
.clear{clear:both;}
.gallthumbnail{float:left;border:2px solid #666;margin-right:5px;margin-bottom:5px;}
.fl_blogpostavatar{float:right;border:2px solid #666;margin:0 0 5px 5px;}
.fl_commentavatar{float:left;border:2px solid #666;margin:0 5px 0 0;}
.fl_commentname{display:block;margin-left:80px;text-transform:uppercase;margin-bottom:5px;font-size:8pt;}
.fl_commentmessage{display:block;margin-left:80px;}
.fl_gtname{display:block;text-transform:uppercase;margin-bottom:5px;font-size:8pt;}
.fl_gtmessage{display:block;}
.fl_blogpost1, .fl_blogpost2{border-bottom:1px dashed #f8422d;padding-bottom:5px;margin-bottom:5px;}
.fl_postinfo{text-transform:uppercase;margin-bottom:5px;font-size:8pt;}
.fl_blogfooter{clear:both;}
.fl_comment1{display:block;padding:5px;margin-top:5px;}
.fl_comment2{display:block;padding:5px;background-color:#eee;margin-top:5px;}
.fl_commclear{display:block;clear:both;}
#fl_commsbox, #fl_tracksbox{clear:both;padding-top:15px;}
.fl_bigpic{border:2px solid #666;}
.fl_bigcaption{margin-top:10px;}
.fl_rssentry{clear:both;}
.fl_rssimg{float:right;display:block;border:2px solid #666;margin:0 0 5px 5px;}
.fl_rsstitle{font-size:18pt;line-height:24pt;font-weight:bold;}
.fl_rssby{text-transform:uppercase;margin-bottom:5px;font-size:8pt;}
.fl_gallpreview1{margin-bottom:10px;padding:5px;clear:both;}
.fl_gallpreview2{margin-bottom:10px;background-color:#eee;padding:5px;clear:both;}
.fl_gallpreview1 img, .fl_gallpreview2 img{float:left;border:2px solid #666;}
.fl_galllink, .fl_galltext{display:block;margin-left:110px;}
td.fl_label{display:block;width:100px;}
.fl_mailform textarea{width:400px;height:200px;}
.fl_votebar{background-color:#fff;height:10px;}
input.fl_regform{width:100px;}
.fl_postingform{display:none;}
.fl_postingform textarea{height:100px;}
.fl_rsslinks{padding-top:10px;clear:both;text-align:right;}
.fl_rsslinks a{text-transform:uppercase;font-size:8pt;text-decoration:none;margin-left:10px;}
.fl_rsslinks:empty{display:none;}
.fl_rating{float:right;text-align:right;}
#msgwrap{position:fixed;top:150px;left:50%;text-align:center;z-index:99;}
#msgbar{position:relative;color:#fff;border-width:3px;border-style:solid;padding:15px;font-size:28px;line-height:40px;width:300px;left:-168px;display:none;font-family:"Lucida Sans","Lucida Grande", Lucida, Tahoma, Verdana, Arial, Helvetica, sans-serif;cursor:default;}
#msgbar a{color:#fff;}
#topbar{display:none;position:fixed;z-index:99;background-color:#4ad;color:#fff;top:0;left:0;width:100%;font-size:12px;border-bottom:3px solid #079;text-align:center;}
#topbar a{color:#fff;}
#topcont{padding:10px;}
input, textarea{border:1px solid;padding:3px;background-color:#fff;border-color:#000;font-family:Verdana, Arial, Helvetica, sans-serif;font-size:12px;}
textarea{width:300px;height:150px;}
input:hover, input:focus, textarea:hover, textarea:focus{background-color:#eee;}
.fl_later{float:left;}
.fl_earlier{float:right;}
.flmsg_alert{background-color:#4ad;border-color:#079;}
.flmsg_error{background-color:#900;border-color:#600;}
.flmsg_success{background-color:#096;border-color:#066;}
.flmsg_generic{background-color:#666;border-color:#999;}
#fl_commsbox{margin:5px;padding:5px;border:1px dotted #333;background-color:#eee;}
#fl_gallwrap{position:fixed;top:0;left:0;margin:0;padding:0;width:100%;height:100%;display:none;font:11px Arial, Helvetica, sans-serif;line-height:20px;color:#333;text-align:left;}
#fl_gallcover{position:fixed;width:100%;height:100%;top:0;left:0;margin:0;padding:0;background-color:#000;opacity:0.8;filter:alpha(opacity=80);}
#fl_gallbox{position:relative;top:5%;margin:0 auto;background-color:#fff;padding:10px;width:100px;height:100px;}
#fl_gallpic{display:block;margin:0 auto;position:relative;top:35%;}
#fl_gallbelowpic{clear:both;display:none;padding:5px 10px 10px;margin:0 -10px;background-color:#fff;overflow:hidden;}
#fl_gallwrap a{color:#666;text-decoration:none;}
#fl_gallwrap a:hover{color:#444;}
#fl_gallprevnext{background:url('../scripting/blank.gif');position:relative;}
#fl_gallprev{position:absolute;z-index:50;}
#fl_gallnext{text-align:right;position:absolute;z-index:50;right:0;}
#fl_gallclose, #fl_gallslide{clear:right;float:right;}
a#fl_gallprev:hover, a#fl_gallnext:hover, a#fl_gallclose:hover{border-width:0;}
#fl_gallprev img, #fl_gallnext img{visibility:hidden;padding-top:50px;}
#fl_gallprev:hover img, #fl_gallnext:hover img{visibility:visible;}

* { margin: 0; padding: 0; border: 0; }
html, body { min-height: 100%; color: #1d1c1b; font: 16px/23px proxima-nova, sans-serif; }
p { margin: 15px 0; }
ul, ol { margin: 15px 30px; }
a { color: #24246c; }
a:hover { text-decoration: none; color: #80b4de; }
img { max-width: 100%; height: auto!important; }
b, strong  { font-weight: 600; }

h1, h2, h3, h4 { margin: 25px 0; color: #24246c; font-weight: 600; }
h1 { font-size: 32px; line-height: 36px; margin-top: 0; }
h2 { font-size: 28px; line-height: 32px; }
h3 { font-size: 24px; line-height: 28px; }
h4 { font-size: 20px; line-height: 24px; }
h1 b, h2 b, h3 b, h4 b, h1 strong, h2 strong, h3 strong, h4 strong { font-weight: 600; }
.textlabel { position: absolute; margin-left: -9999px; }
h1:empty { display: none; }

.skipto a { position: absolute; margin-left: -9999px; top: auto; width: 1px; height: 1px; overflow: hidden; color: #fff!important; padding: 10px; background: #fc0; }
.skipto a:focus { margin-left: 0; width: auto; height: auto; }

.wrapper { max-width: 1200px; margin: 0 auto; padding: 0 25px; position: relative; }


header { display: block; padding: 25px 0; }
.logo { width: 340px; height: 125px; display: inline-block; vertical-align: top; }
.logo img { display: block; }
.headertr { position: absolute; top: 0; right: 25px; text-align: right; color: #24246c; font-size: 18px; line-height: 18px; }
.headertr .helplinetel { font-size: 24px; line-height: 24px; margin-bottom: 5px; padding-left: 34px; background: url('../gfx/tel.svg') no-repeat left; background-size: auto 24px; }

.search { position: absolute; bottom: 0; right: 25px; width: 200px; }
input.searchtext { width: 165px; height: 35px; font-size: 12px; box-sizing: border-box; background: #f8f7f9!important; padding: 0 10px; border-radius: 5px 0 0 5px; }
input.gosearch { position: absolute; top: 0; right: 0; width: 35px; height: 35px; box-sizing: border-box; cursor: pointer; background: #80b4de url('../gfx/magnify.svg') no-repeat 9px 9px!important; background-size: 16px 16px!important; text-indent: -9999px; border-radius: 0 5px 5px 0; }
input.gosearch:hover { transform: scale3d(1.1,1.1,1); }
#menu_c_search { display: none!important; }

a.buttondonatetop { text-align: left!important; line-height: 18px!important; position: absolute!important; bottom: 0; right: 240px; padding: 8px 20px 8px 61px!important; }
a.buttondonatetop:active { top: auto!important; bottom: -2px; }

div.menuwrap { background: #e2e1e7; position: sticky; top: 0; z-index: 20; }
#menu, .smwrap { margin: 0 auto; max-width: 1200px; padding: 0 25px; }
.smwrap { position: relative; top: -42px; }
.fl_menu { list-style: none; }
.fl_menu li, .fl_menu a { display: inline-block; vertical-align: top; position: relative; font-size: 16px; line-height: 40px; text-decoration: none; font-weight: 600; }
.fl_menu>li:after { content: '\2022'; margin: 0 20px; color: #80b4de; }
.fl_menu>li#menu_c_contact:after { display: none; }

.fl_menu>li.current>a, .fl_menu>li.curparent>a, .fl_menu>li.curhighparent>a { border-bottom: 2px solid #24246c; }

.fl_menu>li.hassubmenu>a { transition: all 0.25s; }
.fl_menu>li.hassubmenu:hover>a { border: 2px solid #80b4de; border-bottom: 0; background: #f0f0f3; border-radius: 5px 5px 0 0; padding: 3px 25px 2px; margin: -5px -27px 0; box-sizing: border-box; }
.fl_menu>li.current.hassubmenu:hover>a, .fl_menu>li.curparent.hassubmenu:hover>a, .fl_menu>li.curhighparent.hassubmenu:hover>a { border-bottom: 2px solid #e2e1e7; }
.fl_menu ul { position: absolute; background: #f0f0f3; margin: 0; z-index: 20; top: 42px; max-height: 0; left: -27px; width: 200px; overflow: hidden; transition-duration: 0.25s; transition-property: max-height; text-align: left; box-sizing: border-box; border-left: 2px solid #80b4de; }
.fl_menu ul li, .fl_menu ul a { display: block; margin: 0; padding: 0; }
.fl_menu ul a { font-size: 14px; line-height: 20px; padding: 5px 10px; }
.fl_menu ul.size { -webkit-transition: none; transition: none; opacity: 0; }
.fl_menu li:hover ul { max-height: 500px; }
.fl_menu ul ul { display: none!important; }
.fl_menu>ul>li:first-child { padding-top: 10px; }

.hasjs .fl_menu #menu_c_support { position: static; }
.hasjs .fl_menu #menu_c_support>ul { position: absolute; left: 0; right: 0; width: auto; background: #f0f0f3; border-left: 0; }
.hasjs .fl_menu #menu_c_support>ul>li { border-top: 2px solid #80b4d3; }
.fl_menu ul ul.submenuwrap { display: block!important; max-height: none; border-left: 0; width: auto; max-width: 1200px; margin: 0 auto; padding: 0 25px; position: relative; top: 0; left: 0!important; }
.submenuwrap>li { width: 33.33333%; padding: 0 20px 0 0!important; display: inline-block!important; vertical-align: top; box-sizing: border-box; }
.submenuwrap>li:last-child { padding-right: 0!important; }
.submenuwrap>li>a { color: #fff; height: 100px; background: #eee; position: relative; margin-top: 20px; background-size: cover; background-position: center; }
.submenuwrap>li>a>span { position: absolute; bottom: 0; left: 0; right: 0; padding: 30px 5px 5px; background: linear-gradient(rgba(0,0,0,0),rgba(0,0,0,0.75)); font-size: 16px; }
.submenuwrap>li>a:hover { opacity: 0.75; }
.fl_menu ul.submenuwrap ul { display: block!important; position: static; max-height: none!important; border-left: 0; margin-top: 10px; margin-bottom: 15px; }
.fl_menu ul.submenuwrap ul a { padding: 5px 0; text-decoration: underline; }
.fl_menu ul.submenuwrap ul a:hover { text-decoration: none; }
.hasjs #menu_c_support-parent_1>a { background-image: url('../siteimages/boxes-front/bereaved-parent.jpg'); }
.hasjs #menu_c_support-sibling_1>a { background-image: url('../siteimages/boxes-front/bereaved-sibling.jpg'); }
.hasjs #menu_c_support-more_1>a { background-image: url('../siteimages/boxes-front/information.jpg'); }

.fl_menu ul.submenuwrap ul { width: auto; }
.fl_menu ul.submenuwrap ul ul { display: none!important; }

.socmed { position: absolute; right: 0; top: 5px; }
.socmed a { width: 30px; height: 30px; margin-left: 5px; display: inline-block; vertical-align: top; background: #80b4de; border-radius: 5px; background-repeat: no-repeat; }
.socmed a:hover { transform: scale3d(1.1,1.1,1); }
.socmed a.fb { background-image: url('../gfx/icon-fb.svg'); background-size: auto 24px; background-position: 12px bottom; }
.socmed a.tw { background-image: url('../gfx/icon-tw.svg'); background-size: auto 12px; background-position: center; }
.socmed a.yt { background-image: url('../gfx/icon-yt.svg'); background-size: auto 12px; background-position: center; }
.socmed a.ig { background-image: url('../gfx/icon-ig.svg'); background-size: auto 16px; background-position: center; }

#imgfade { height: 300px; max-height: calc(100vh - 300px); min-height: 200px; position: relative; background: #80b4de; overflow: hidden; }
.imgwrap { max-width: 1600px; margin: 0 auto; position: relative; height: 300px; max-height: calc(100vh - 300px); min-height: 200px; }
.fadeimg { position: absolute; top: 0; left: 0; right: 0; bottom: 0; background-size: cover; background-position: center; display: none; }
.fadeimg:first-child { display: block; }
.page-front #imgfade { display: none; }

main { display: block; }
.lhscol { width: calc(100% - 250px); display: inline-block; vertical-align: top; background: #fff; margin-left: -25px; padding: 10px 0 35px 25px; position: relative; margin-top: -55px; z-index: 14; }
.rhscol { width: 200px; padding-left: 50px; display: inline-block; vertical-align: top; padding-bottom: 50px; font-size: 14px; line-height: 20px; color: #666; }
.page-front .rhscol, .rhscol:empty { display: none; padding-bottom: 50px; }
.lhscol h2, .lhscol h3, .lhscol h4 { margin-top: 40px; }
.lhscol .breadcrumbs, .lhscol h1 { padding-right: 25px; }
.onecol .lhscol { width: 100%; }
.onecol .rhscol { display: none; }
.breadcrumbs { font-size: 12px; line-height: 16px; color: #ccc; margin-bottom: 5px; }
.breadcrumbs a { color: #999; display: inline-block; vertical-align: top; margin: 0 10px; }
.breadcrumbs a.noleft { margin-left: 0; }

.lhscol li { margin-top: 3px; }
.lhscol ul { list-style: none; }
.lhscol ul li:before { color: #24246c; content: "\25cf"; position: absolute; font-size: 10px; line-height: 18px; margin: 2px 0 0 -18px; }
.lhscol>*:first-child, .lhscol>div>*:first-child, #searchresults h2 { margin-top: 0; }
.lhscol>*:last-child { margin-bottom: 0; }

.cms_imgleft { max-width: 250px; border: 0; margin: 3px 10px 10px 0; float: left; }
.cms_imgright { max-width: 250px; border: 0; margin: 3px 0 10px 10px; float: right; clear: right; }
.leftcol li { margin-top: 3px; }
.leftcol ul { list-style: none; }
.leftcol ul li:before { color: #fc0; content: "\2022"; position: absolute; font-size: 18px; line-height: 18px; margin: 3px 0 0 -18px; }

.rhscol h4 { margin-bottom: 10px; }
.rhscol ul { margin: 0; list-style: none; }
.rhscol li { display: block; margin: 5px 0 0; }
.rhscol a { color: #80b4de; }
.rhscol li.current a { cursor: default; color: #999; text-decoration: none; }
.rhscol ul ul { margin: 10px; }

blockquote { margin: 30px; background: #f5ba49; padding: 15px 30px; border-radius: 5px; color: #24246c; font-weight: 600; }

.page-front .lhscol { width: 100%; padding: 25px 0 50px; margin: 0; }
.page-front h1, .page-front .breadcrumbs { display: none; }
#scroller { position: relative; height: 0; padding-bottom: 40%; }
.fadeimg { position: absolute; top: 0; left: 0; right: 0; bottom: 0; background-size: cover; background-position: center; }
#scrollleft, #scrollright { position: absolute; bottom: 20px; right: 20px; cursor: pointer; background: url('../gfx/arrow-right.svg') no-repeat center; background-size: auto 12px; width: 30px; height: 30px; background-color: #80b4de; border-radius: 15px; z-index: 10; transition: 0.25s all; background-position: 11px center; }
#scrollleft { right: 55px; background-image: url('../gfx/arrow-left.svg'); background-position: 9px center; }
#scrollleft:hover, #scrollright:hover { transform: scale3d(1.1,1.1,1); }
#scrollbar { position: absolute; bottom: 0; left: 0; background: #80b4de; height: 3px; width: 0; z-index: 6;  transition-duration: 0.25s; transition-property: background; }
#scrollbar.paused { background: #24246c; }
#slider { z-index: 3; position: absolute; left: 0; right: 0; top: 0; bottom: 0; overflow: hidden; }
.slide { position: absolute; top: 0; left: 0; bottom: 0; width: 100%; display: none; z-index: 4; color: #fff!important; text-decoration: none; background: #f6f6f6; background-size: cover; background-position: center; transition-property: color, background-color, opacity; }
.slidewrap { top: 0; bottom: 0; left: 0; width: 50%; position: absolute; padding: 20px 220px 20px 20px; background: linear-gradient(to left, rgba(0,0,0,0),rgba(0,0,0,0.8)); text-align: left; z-index: 5; }
.slidewraptext { position: absolute; bottom: 20px; left: 20px; right: 20px; }
.notext { display: none; }
.slide h2 { font-size: 32px; line-height: 36px; margin: 0; color: inherit; }
.slide p { font-size: 18px; line-height: 22px; font-weight: 500; margin: 10px 0 0; max-width: 600px; }
.slide:hover .slidewrap { opacity: 0.6; }
#slide_0 { display: block; }
a.transition, div.transition { -webkit-transition: all 1s; transition: all 1s; }
a.transitionfast, div.transitionfast { -webkit-transition: all 0.2s; transition: all 0.2s; }
a.sliding .slideside { display: block; }

.frontbar { margin-top: 25px; }
.frontbar h2 { display: inline; color: #f5ba49; border-right: 1px solid #e2e1e7; padding-right: 20px; margin: 0 20px 0 0; }
.frontbar h4 { display: inline-block; vertical-align: top; margin: 0; padding-top: 10px; width: calc(100% - 130px); }

.subpages, .accountoptions, .newsitems { margin: 0 0 0 -25px; }
.accountoptions li:before { display: none; }
.accountoptions li, .subpages a { display: inline-block; width: calc((100% / 3) - 25px); margin: 25px 0 0 25px!important; vertical-align: top; height: 0; padding-bottom: 20%; background: #e2e1e7; position: relative; background-size: cover; background-position: center; overflow: hidden; }

.subpages a.linkboximg { height: auto; }
.subpages a.linkboximg .boximg { position: relative; padding-bottom: 100%; background-position: center; background-size: cover; }

.subpages a .boxtitle { position: absolute; bottom: 0; left: 0; right: 0; padding-top: 100px; background: linear-gradient(rgba(0,0,0,0),rgba(0,0,0,0.6)); }
.subpages a h4 { margin: 0; padding: 20px; font-size: 18px; line-height: 22px; color: #fff; }
.subpages a:hover, .accountoptions li:hover { transform: scale3d(1.05,1.05,1); }

.subpages a.linkboximg .boxtitle { transform: none; top: auto; bottom: 0; left: 0; right: 0; padding: 50px 10px 10px; background: linear-gradient(to bottom, rgba(36,36,108,0),rgba(36,36,108,0.75)); }
.subpages a.linkboximg .boxtitle h4 { color: #fff; }

.newsitem { width: calc(33.333333333% - 25px); display: inline-block; vertical-align: top; margin: 20px 0 0 20px; position: relative; text-decoration: none; }
.newsitem h4 { color: inherit; }
.newsitem .newsimagewrap { height: 0; padding-bottom: 66%; background: #f5ba49; position: relative; }
.newsitem .pcimagewrap { height: auto; padding: 5px; }
.newsitem:hover { transform: scale3d(1.05,1.05,1); }
.newsitem div.newsimage { position: absolute; top: 5px; left: 5px; right: 5px; bottom: 5px; background-color: #fff; background-size: cover; background-position: center; background-repeat: no-repeat; }
.newsitem img.newsimage { display: block; }
.newsitem .newshead { margin: 10px 0 5px; }
.newsitem .newstext { color: #1d1c1b; margin: 0; }
.genericimage .newsimage { background: #80b4de url('../gfx/tcf-circle.png') no-repeat center; background-size: auto 60%; } 
.insidesubpages, .accountoptions { margin-top: -25px!important; }
.accountoptions li, .insidesubpages a { padding-bottom: 0!important; height: 80px; border-top: 3px solid #80b4de; border-bottom: 3px solid #80b4de; box-sizing: border-box; }
.insidesubpages a .boxtitle { bottom: auto; top: 50%; padding: 0; background: none; transform: translateY(-50%); text-align: center; left: 10px; right: 10px; }
.insidesubpages a h4 { padding: 0; color: #24246c; }
.resourcesubcats { margin-bottom: 20px; }

.accountoptions li { position: relative; overflow: hidden; }
.accountoptions a { top: 50%; display: block; font-weight: 600; text-align: center; left: 10px; right: 10px; position: absolute; transform: translateY(-50%); text-decoration: none; font-size: 18px; line-height: 22px; }
.accountoptions a:after { position: absolute; top: -100px; left: -10px; right: -10px; bottom: -100px; content: ''; }
.accountoptions a:hover { color: #24246c; }

.fl_blogintro, .fl_blogpost1, .fl_blogpost2 { margin-top: 30px; border-bottom: 1px solid #eee; padding-bottom: 30px; }
.fl_blogintro { margin-top: 0; }
#fl_commsbox { clear: both; margin: 0; padding: 0; border: 0; background: transparent; }
.fl_commentname, .fl_commentmessage { margin-left: 0; }
.fl_blogentrytitle, .fl_newspreview h2 { margin-bottom: 10px; }
.fl_postinfo { font-size: 12px; line-height: 16px; margin-bottom: 20px; color: #999; }
.fl_comment1, .fl_comment2 { padding: 20px; font-size: 16px; line-height: 20px; }
.fl_comment1 { background: #efede6; }
.fl_comment2 { background: transparent; }
.fl_commentname { font-size: 12px; line-height: 16px; }
.fl_blogfooter { color: #999; margin-top: 20px; }
h2.fl_blogentrytitle { margin-top: -30px!important; }
.fl_newspreview h2.fl_blogentrytitle { margin-top: -30px; }
.fl_rsslinks, #fl_tracksbox, .accountnewslet { display: none; }
.page-blogs .fl_rsslinks { display: block; margin-bottom: 10px; }
.fl_commform { margin-bottom: 20px; }
.fl_tags { font-size: 12px; text-transform: uppercase; }

form label, .eventconfirm label { display: block; font-weight: 600; font-size: 12px; line-height: 17px; text-transform: uppercase; margin: 10px 0 2px; }
input, textarea { -webkit-appearance: none; border-radius: 0; }
input.checkbox, input.button { border: 0; width: auto; display: inline; background: transparent!important; -webkit-appearance: checkbox; height: auto; margin-right: 5px; }
input[type=radio] { -webkit-appearance: radio; }
label .reqd { margin-left: 5px; }
input, textarea, .fl_mailform textarea, select { background: #f0f0f0; border: 0; font: 14px/20px proxima-nova, sans-serif; color: #072d3e; width: 100%; display: block; padding: 10px; -moz-box-sizing: border-box; box-sizing: border-box; }
input, select { height: 40px; }
input:hover, textarea:hover, select:hover { background: #f0f0f0; color: #072d3e; }
input:focus, textarea:focus, select:focus { background: #f0f0f0; color: #072d3e; }
select#usertitle { display: inline-block; width: 150px; }
.daterow select { display: inline-block; width: auto; }

input.emailsub, input.passsub, input.commentsub, input.formsub, input.shopbutton, a.button { display: block; width: auto; height: auto; font-weight: 600; font-size: 16px; line-height: 24px; margin: 10px 0; padding: 13px 20px; color: #24246c!important; border: 0; background: #f5ba49; border-radius: 5px; cursor: pointer; text-decoration: none; position: relative; text-transform: uppercase; text-align: center; }
input.emailsub:hover, input.passsub:hover, input.commentsub:hover, input.formsub:hover, input.shopbutton:hover, a.button:hover { transform: scale3d(1.1,1.1,1); }
input.emailsub:active, input.passsub:active, input.commentsub:active, input.formsub:active, input.shopbutton:active, a.button:active { top: 2px; }
a.button { width: auto; display: inline-block; vertical-align: top; margin: 0; }

.signuptcs { max-width: 508px; font-size: 12px; line-height: 16px; border: 1px solid #eee; padding: 10px; overflow: auto; height: 150px; -webkit-overflow-scrolling: touch; position: relative; }

a.buttondonate { background-image: url('../gfx/heart.svg'); background-size: auto 20px; background-position: 20px center; padding-left: 61px; background-repeat: no-repeat; }
a.buttondonatemenu { display: none; }

.event { margin-top: 20px; border-top: 1px solid #eee; border-bottom: 1px solid #eee; margin-bottom: -21px; padding: 0 10px 20px; background: transparent; clear: left; display: block; text-decoration: none; }
.event:hover { background: #f9f8f3; position: relative; opacity: 1; }
.event, .event:hover { color: #333!important; }
.event h3 { margin-bottom: 10px; } 
.event img { float: right; margin: 0 0 10px 10px; width: 100px; }
.event:last-child { margin-bottom: 0; }

.eventcat, .eventdate { margin: 0 0 10px; }
.err { font-weight: 600; color: #c00; }

div.eventinfo { float: right; background: #f9f8f3; width: 250px; margin: 0 0 10px 10px; }
div.eventinfo .eventimg { max-width: 100%; display: block; }
#map_canvas { height: 250px; }
div.eventinfo p { padding: 0 15px 15px; }

#mapscroll { position: absolute; margin-top: -50px; }
#map_canvas>div { -webkit-transition-duration: 0.5s; transition-duration: 0.5s; -webkit-transition-property:opacity; transition-property:opacity; }
#map_canvas.hidden>div { opacity: 0; }
#map_canvas.supportmap { height: 600px; margin: 20px 0; }
a#findnearest { display: block; text-align: center; margin: 20px 0 -20px; padding: 10px; text-transform: uppercase; color: #24246c; background: #f5ba49; font-weight: 600; font-size: 18px; text-decoration: none; }
a#findnearest:hover { transform: scale3d(1.02,1.02,1); }
form#shownearest { margin: 0 160px 20px 0; }
input#townpostcode { width: 100%; -moz-box-sizing: border-box; box-sizing: border-box; }
.belowmap { position: relative; }
#maplegend { position: absolute; right: 0; top: 0; width: 160px; text-align: right; }
.legendtype img { width: 15px; height: 21px; display: inline-block; vertical-align: middle; }
.legendtype label { margin: 0; }
.legendtype span { width: 120px; display: inline-block; text-align: left; vertical-align: middle; font-size: 14px; text-transform: none; color: #000; font-weight: normal; }
#map_canvas h4 { margin: 10px 0; }
#map_canvas h4:first-child { margin-top: 5px; }
.pagecol-green a#findnearest { background: #76ba99; }

table.leaflets { margin-top: 10px; }

#fl_loading { display: none; position: fixed; top: 10px; right: 10px; background: #fff; padding: 3px; border: 1px solid #ccc; z-index: 150; width: 32px; z-index: 99; }
#cookiebar { font-size: 12px; line-height: 16px; }
#cookiebar a { display: inline-block; }
#msgbar { font-family: proxima-nova, sans-serif; font-weight: 600; }
.err, .reqd { font-weight: 600; color: #c00; }

footer { display: block; background: #e2e1e7; background-size: contain; color: #666; font-size: 12px; line-height: 16px; padding: 45px 25px; text-align: center; }
footer a { color: #666; }
footer p { margin: 5px 0; }

#_chat_link_1215 { position: fixed; bottom: -2px; right: 25px; border-radius: 5px 5px 0 0; cursor: pointer; transition: 0.2s bottom; width: auto!important; max-height: 42px; z-index: 50; display: none; }
#_chat_link_1215:hover { bottom: 0 }

a, input, #menubutton, .slidewrap, .accountoptions li { transition-duration: 0.25s; transition-property: transform, color, background-color, opacity; }

/* store styles */

html.nomin, html.nomin body { min-width: 200px; }
option { padding-right: 10px; }
.sfprodname, .accountheader, .orderheader { font-weight: 600; }
.loginfail { color: #c00; font-weight: 600; }
input#address2, input#address3 { margin-top: 1px; }
.instrucleft { font-size: 14px; }
.instrucright { float: right; font-size: 14px; }
input.shopbutton.gosort { margin-top: 0; }
.storepage .divider { border-top: 1px solid #eee; }
textarea#delinst { width: 100%; -moz-box-sizing: border-box; box-sizing: border-box; height: 80px!important; }

.productsubcats, #productswrap, .productlinks { margin: 0 -0.6666666%; }
.productsubcats .clear, #productswrap .clear, .productlinks .clear { display: none; }
.productlinks h3 { margin-left: 0.6666666%; }

.rrpline, .priceline, .salepriceline {
	display: block;
	text-decoration: line-through;
	color: #ccc;
}
.curprice { text-decoration: none; color: inherit; }
#pricebox .priceline.curprice { color: #24246c; }

.productpricing { clear: left; font-size: 16px; line-height: 24px; font-weight: 600; border-bottom: 1px solid #e2e1e7; padding-bottom: 10px; background: #fff; }

.productimg { float: right; margin: 0 0 10px 0; padding-left: 20px; background: #fff; }
.productimg, #productimg { width: 420px!important; display: block; }
.productimgthumbs { width: 425px; margin-top: 10px; }
.productdescription { margin: 20px 0 0; border-bottom: 1px solid #e2e1e7; padding-bottom: 20px; }

.basketadd { display: block; margin: 20px 0; }
.addtobasket .productoption { display: block; margin-bottom: 10px; }
.addtobasket .lab { display: inline-block; width: 100px; }
.addtobasket #outstock { margin-bottom: 20px; display: block; }

.accountfooter a { display: inline-block; }
.prodbox { width: 32%; display: inline-block; vertical-align: top; margin: 0 0.666666666% 1.3333333333%; text-decoration: none; position: relative; color: #7c878e; overflow: hidden; outline: 1px solid #eee; }

.prodbox:hover { opacity: 1; outline: 1px solid #24246c; }
.prodbox img, .tabbox .prodviewedbox img { width: 100%; height: auto; display: block; }
.prodbox .rrpline, .prodbox .priceline, .prodbox .saveline, .prodbox .curprice, .tabbox .prodviewedbox .curprice, .tabbox .prodviewedbox .rrpline, .tabbox .prodviewedbox .saveline { display: block; }
.prodbox .proddesc, .catinfo { padding: 10px; text-align: center; display: block; font-size: 14px; font-weight: normal; position: absolute; bottom: 0; left: 0; right: 0; background: #24246c; color: #fff!important; }
.prodbox .prodtitle { font-size: 18px; line-height: 24px; font-weight: 600; }
.prodbox .rrpline, .prodbox .priceline, .prodbox .saveline { display: none; }
.prodbox .curprice { display: block; }
#pricebox .salepriceline, #pricebox .saveline { color: #c00; }
.cattitle { font-weight: 600; font-size: 18px; line-height: 24px; display: block; }
.catproducts { font-size: 10px; line-height: 14px; text-transform: uppercase; display: block; margin-top: 5px; font-weight: normal; }
.saleicon { display: none; }

.sortorder { margin: 10px 0; font-size: 14px; }
.sortorder select { width: auto; margin: 0 2px; display: inline; }
input.gosort { display: inline; }
.storepage .subpages { margin-top: 5px; }
.storepage .subpages a { margin-right: 5px; }
.storepage .subpages a.currentprodpage { color: #ccc; }

label.listaddress { text-transform: none; font-size: 14px; line-height: 20px; }
.signinform label.checkbox { padding: 3px 0; }
.signinform input { display: block; }
input.checkbox { margin-right: 5px; width: auto; padding: 0; border: 0; display: inline; }
#titleother { visibility: hidden; width: 150px; display: inline; }
table.storebasket { border-collapse:collapse; width: 100%; font-size: 14px; }
.storebasket td { padding: 3px; }
tr.problemrow { background: #c99; }
.vartypes { text-transform: uppercase; font-size: 10px; }
tr.basketbuttons { text-align: right; }
.storeheader {
	position: absolute;
	width: 645px;
	top: 170px;
	text-align: right;
}
tr.basketbuttons input { margin-left: 8px; margin-right: -3px; }
input#disccode { width: 100px; }
.returneditems { margin-left: 10px; padding-left: 10px; border-left: 1px dotted #a3c727; }
.ratingbar { margin: 5px 0; }
form.addreview { margin-top: 5px; }

.productimgthumbs a { display: block; float: left; outline: 1px solid transparent; margin: 0 5px 5px 0; }
.productimgthumbs a:hover { outline-color: #c19b9d; }
.productimgthumbs img { display: block; }
.productsendfriend { padding-top: 10px; }
.pagesendfriend { padding: 10px; background: #fff; }
.pagesendfriend h3 { margin-top: 0; }
.productsendfriend, .shopsharebar, .currencies { color: #666; font-size: 13px; }

.storebasket tr, .orderlist tr, .orderdetails tr { border-bottom: 1px solid #eee; -webkit-transition-duration: 0.2s; transition-duration: 0.2s; }
.storebasket tr.basketbuttons { border-bottom: 0; }
.storebasket tr:hover, .orderlist tr:hover, .orderdetails tr:hover { background: #eee; }
.storebasket tr.basketbuttons:hover { background: transparent; }
tr.headerrow { font-weight: 600; font-size: 13px; text-transform: uppercase; }
tr.headerrow, tr.headerrow:hover { background: #f2f2f3; }
tr.overalltot { font-weight: 600; text-transform: uppercase; }
table select { width: auto; }
table input.shopbutton { float: none; display: inline; }
input.gosignin, input.gocreateaccount, input.gosavedetails, input.gosaveaddress, input.gochangepass { float: none; }

table.orderdetails, table.orderlist { width: 100%; border-collapse: collapse; margin-top: 10px; }
table.orderdetails td, table.orderlist td { padding: 5px 4px; font-size: 13px; }
table.orderdetails tr.ordereven, table.orderlist tr.ordereven { background: #f6f6f6; }
.giftwrapcol { width: 80px; }

.shopsharebar { padding-top: 5px; }
.shopsharebar a { padding-left: 20px; background-repeat: no-repeat; margin-right: 8px; background-size: 16px auto; }
.shopsharebar .facebook { background-image: url('../gfx/share/facebook-sm.png'); }
.shopsharebar .twitter { background-image: url('../gfx/share/twitter-sm.png'); }
.shopsharebar .pinterest { background-image: url('../gfx/share/pinterest-sm.png'); }

.prodbox .prodviewbutton, .prodbox .prodlongdesc, .prodbox .catdesc, .descprice { display: none; }
.stocknotify a { display: inline-block; }

.addtobasket { clear: left; padding: 10px 0 0; font-weight: 600; margin: 10px 0; border-bottom: 1px solid #e2e1e7; }
.addtobasket select { width: 120px; display: inline; }
.downloadinfo .addtobasket { padding-top: 1px; }

a.shareto { float: left; background-position: left; }
.currencies { clear: left; padding-top: 5px; }
.currencies a { display: inline-block; }

a.noprods { display: inline; }
a.shoplink { display: none; }
.descprice { display: none!important; }

#popupcover { position: fixed; top: 0; left: 0; right: 0; bottom: 0; z-index: 90; background: rgba(0,0,0,0.5); -webkit-transition-property: opacity; transition-property: opacity; -webkit-transition-duration: 0.5s; transition-duration: 0.5s; opacity: 0; }
#popupcover.hidden { display: none; }
#popupcover.isshown { display: block; opacity: 1; }
#popupwrap { position: fixed; top: 10%; left: 20%; right: 20%; bottom: 10%; overflow: auto; -webkit-overflow-scrolling: touch; }
#popupinfo { background: #fff;  padding: 10px 20px 20px; }
#popuptext h3 { margin-top: 10px; }
.popupclosewrap { float: right; margin: -10px -20px 20px 20px; width: 30px; height: 30px; }
#popupclose { width: 20px; height: 30px; position: fixed; background: #666; color: #fff; cursor: pointer; padding: 0 3px 0 7px; font-size: 30px; line-height: 32px; overflow: hidden; }

#formname, #formemail, #formsubject, #formmessage { width: 100%; -moz-box-sizing: border-box; box-sizing: border-box; }
#CAFDonateSlimWidgetContainer { display: none; margin-top: 10px; }

.pagefile-candle-remembrance .fl_comment1, .pagefile-candle-remembrance .fl_comment2 { padding: 20px 0 20px 120px; border-top: 1px solid #ddd; background: url("../siteimages/content/candle.jpg") no-repeat left 20px; background-size: 100px 100px; min-height: 100px; margin: 0; }

.pagefile-remembrance .lhs { margin-right: 0; padding-right: 0; }
.pagefile-remembrance .rhs, .remempage #pagetop { display: none; }
#remem { background: #2c76bf url('../gfx/clouds.jpg') no-repeat bottom; background-size: 100% auto; margin-top: 60px; box-sizing: border-box; padding: 20px; }
.remementry { width: 31.3333333%; display: inline-block; vertical-align: top; background: rgba(255,255,255,0.9); margin-top: 20px; margin-right: 3%; box-sizing: border-box; border: 2px solid rgba(255,255,255,0.9); border-radius: 5px; overflow: hidden; color: #5ca2d2; }
.rimg { display: block; margin: 0 auto; overflow: hidden; }
.rmsg { padding: 5px; word-wrap: break-word; }
.rname { padding: 5px 5px 0; font-size: 14px; font-weight: 600; }
.remementry:nth-of-type(3n+0) { margin-right: 0; }
.rememboxes a.linkbox { padding-bottom: 40%; border-radius: 2px 5px 5px 2px; background-image: url('../gfx/bg-book-wide.png'); background-repeat: no-repeat; background-size: contain; background-position: top center; box-shadow: 5px 2px 10px rgba(0,0,0,0.25); }
.rememboxes .linktext { background: transparent; text-transform: none; font-size: 24px; line-height: 28px; padding: 0 20px 20%; }
.remintro { background: rgba(255,255,255,0.9); padding: 10px; box-sizing: border-box; border-radius: 5px; }
#remem h1 { margin: 0 0 20px; text-align: center; padding: 0 20px; color: #fff!important; text-transform: uppercase; }

.uploader { position: relative; width: 100%; height: 150px; background: #f0f0f0; cursor: pointer; overflow: hidden; box-sizing: border-box; border: 1px solid #eee; }
.uploaderfile { position: absolute; left: -1000px; width: 1px; }
.uploadertext { position: absolute; left: 20px; right: 20px; text-align: center; font-weight: 600; top: 50%; transform: translateY(-50%); font-size: 16px; line-height: 22px; }
.uploader:active, .uploader.active { opacity: 0.6; }
.uploaderprogress { position: absolute; top: 0; bottom: 0; left: 0; right: 0; text-align: center; background: #f0f0f0; cursor: wait; transition: 1s all; }
.uploaderprogress span { position: absolute; left: 20px; right: 20px; top: 50%; transform: translateY(-50%); font-weight: 600; }
.uploaderprogress:empty { display: none; }
.uploadstart .uploaderprogress { background: #f5ba49; }
.uploaddone .uploaderprogress { opacity: 0; }

.handle { cursor: move; }
table#currentimages { width: 100%; border-collapse: collapse; }
table#currentimages thead { background: #24246c; color: #fff; font-weight: 600; }
table#currentimages td { padding: 3px; }

#fl_gallwrap { z-index: 60; }
.imimages { float: right; margin: 3px 0 5px 5px; width: 214px; }
.imimages a { display: block; float: left; width: 102px; box-sizing: border-box; height: 102px; border: 1px solid #24246c; margin: 0 0 5px 5px; transition: border 0.2s; }
.imimages a:hover { border-color: #f5ba49; }
.imimages a img { display: block; }

.donation { border-bottom: 1px solid #eee; padding: 20px 0; }
.donation:first-of-type { border-top: 1px solid #eee; }
.donationdetails { font-weight: 600; }
.donationdate { font-size: 0.8em; color: #666; }
.donationmessage { padding: 10px 40px 0; position: relative; min-height: 50px; box-sizing: border-box; }
.donationmessage:before { content: '“'; position: absolute; top: 20px; left: 0; font-size: 72px; font-weight: 600; color: #f5ba49; }
.donationmessage:after { content: '”'; position: absolute; bottom: 0; right: 0; font-size: 72px; font-weight: 600; color: #f5ba49; }

.impages { margin: -15px 0 20px -20px; }
.resourceswrap { margin: -20px 0 0 -20px; }
a.impage, a.resource { display: inline-block; vertical-align: top; margin: 20px 0 0 20px; width: calc(25% - 20px); word-wrap: break-word; }
.imimgwrap, .resimgwrap { height: 0; padding-bottom: 100%; background: #80b4de url('../gfx/inmem-generic.png') no-repeat center; background-size: 50%; position: relative; }
.imimg, .resimg { position: absolute; top: 2px; bottom: 2px; left: 2px; right: 2px; background: #fff; background-size: contain; border: 2px solid #fff; background-repeat: no-repeat; background-position: center; }
.resimg.genericicon { background-size: 25%; }
a.impage h4, a.resource h4 { margin: 10px 0 0; }
a.impage:hover, a.resource:hover { transform: scale3d(1.02,1.02,1); }

#paymentmethods { display: flex; flex-direction: column; }

#paymentmethods>p { order: 1; }
#paymentmethods>form#sagepay { order: 2; }
#paymentmethods>form:nth-of-type(1) { order: 3; opacity: 0.75; }
#paymentmethods>form:nth-of-type(2) { order: 4; opacity: 0.75; }

button.paymentmethod { display: block; width: 100%; box-sizing: border-box; color: #fff!important; text-transform: none; padding: 10px; font-size: 16px; line-height: 23px; text-align: left; text-decoration: none; font-weight: normal!important; background: #5ca2d2; border: 0; cursor: pointer; border-radius: 0; margin-top: 10px; position: relative; }
button.paymentmethod:hover { opacity: 0.6; background: #5ca2d2; }
button.paymentmethod:active { top: 2px; }
button.paymentmethod span.paymenttitle { font-size: 20px; line-height: 24px; display: block; text-transform: uppercase; margin-bottom: 5px; font-weight: 600; }

@media all and (max-width: 1179px) {
	.accountoptions li, .insidesubpages a { height: 120px; }
}

@media all and (max-width: 1079px) {
	.fl_menu ul { left: -17px; }
	.fl_menu>li:before, .fl_menu>li:after { margin: 0 12px; }
	.fl_menu>li.hassubmenu:hover>a { padding: 3px 15px 2px; margin: -5px -17px 0; }

}
@media all and (max-width: 929px) {
	.fl_menu a { font-size: 14px; }
}
@media all and (max-width: 879px) {

	button.paymentmethod { width: 100%; -moz-box-sizing: border-box; box-sizing: border-box; }
	
	.productsubcats, #productswrap, .productlinks { margin: 0 -1%; }
	.productlinks h3 { margin-left: 1%; }
	.prodbox { width: 48%; margin: 0 1% 2%; }
	.sortbar { display: inline-block; margin: 0 5px 5px 0; }

	.productimg, #productimg { width: 250px!important; max-width: 250px; }
	.productimgthumbs { width: 250px; }
	.productpricing, .addtobasket { padding-right: 270px; }

	.fl_menu a { font-size: 12px; }
	.fl_menu ul { left: -17px; }
	.fl_menu>li:before, .fl_menu>li:after { margin: 0 8px; }
	.fl_menu>li.hassubmenu:hover>a { padding: 3px 15px 2px; margin: -5px -17px 0; }

}
@media all and (max-width: 859px) {
	html, body { min-width: 320px; -webkit-text-size-adjust: none; }
	.lhscol { width: auto; display: block; padding-right: 0; padding-bottom: 10px; }
	.rhscol { display: block; width: auto; padding-left: 0; }
	.frontbar h4 { padding-top: 0; }
}
@media all and (max-width: 799px) {
	a.buttondonatetop { display: none; }
	#scroller { margin: -25px -25px 0; }

	.remementry { width: 48%; margin-right: 4%; }
	.remementry:nth-of-type(3n+0) { margin-right: 4%; }
	.remementry:nth-of-type(2n+0) { margin-right: 0; }


}
@media all and (max-width: 767px) {

	header { position: sticky; top: 0; z-index: 30; padding: 37px 0 15px; background: #fff; border-bottom: 1px solid #f0f0f3; }
	.logo { width: 170px; height: 62.5px; }
	header .search { display: none; }
	.headertr { position: absolute; top: -37px; left: 0; right: 0; background: #f0f0f3; text-align: center; font-size: 14px; line-height: 20px; padding-top: 2px; }
	.headertr .helplinetel { display: inline-block; font-size: 14px; line-height: 20px; background-size: auto 16px; padding-left: 20px; margin-right: 20px; }

	#menubutton { position: absolute; top: 12.5px; right: 25px; width: 40px; height: 40px; background: #f5ba49; border-radius: 5px; cursor: pointer; }
	#menubutton .rowbar { position: absolute; top: 19px; left: 11px; width: 18px; height: 3px; background: #fff; border-radius: 2px; }
	#menubutton .rowtop { top: 13px; }
	#menubutton .rowbottom { top: 25px; }
	div.menuwrap { position: static; }
	
	#menu { position: fixed; top: 0; left: 0; bottom: 0; width: 243px; z-index: 42; height: auto; right: auto; overflow: auto; padding: 0; -webkit-overflow-scrolling: touch; background: rgba(226,225,231,0.95); -webkit-transform: translate3d(-100%, 0, 0); -ms-transform: translate3d(-100%, 0, 0); transform: translate3d(-100%, 0, 0); max-width: none; text-align: center; }
	#menu.menublock { -webkit-transform: translate3d(0, 0, 0); -ms-transform: translate3d(0, 0, 0); transform: translate3d(0, 0, 0); border-right: 1px solid #e5e5e5; }
	#menubg { -webkit-transition-duration: 0.2s; transition-duration: 0.2s; -webkit-transition-property: background; transition-property: background; }
	body.menublock #menubg { position: fixed; top: 0; left: 0; right: 0; bottom: -70px; z-index: 41; background: rgba(255,255,255,0.9); }
	.fl_menu { margin-left: 0; float: none; padding: 30px 0 0; position: static; }
	.fl_menu li, .fl_menu a { display: block!important; width: auto!important; float: none; }
	.fl_menu>li { border-bottom: 1px solid #80b4de; }
	.fl_menu>li:first-child { border-top: 1px solid #80b4de; }
	.fl_menu>li:before { display: none; }
	.fl_menu>li>a { padding: 12px 0!important; margin: 0!important; text-align: center!important; line-height: 24px!important; border: 0!important; background: transparent!important; }
	.fl_menu>li { margin: 0 10px; }
	#menu.menutrans { -webkit-transition-duration: 0.5s; transition-duration: 0.5s; -webkit-transition-property: -webkit-transform, -ms-transform, transform; transition-property: -webkit-transform, -ms-transform, transform; }

    .fl_menu ul { position: relative; width: auto; margin: -5px 0 5px; padding: 0!important; background: none; top: 0!important; max-height: 2000px!important; width: auto!important; left: 0; right: 0; border: 0; text-align: left; transform: none; }
    .fl_menu ul, .fl_menu li:hover ul, .fl_menu li.hovered ul { display: none!important; }
	.fl_menu ul li { background: transparent; border: 0!important; }
	.fl_menu ul a { text-align: center; }
	.fl_menu li.hassubmenu>a:before { content: "\25BC"; }
	.fl_menu li.expanded>a:before { content: "\25B2"; }
	.fl_menu ul.tapped, .fl_menu li:hover ul.tapped, .fl_menu li.hovered ul.tapped { display: block!important; }
	

	.fl_menu>li a:before { position: absolute; right: 10px; color: #80b4de; font-size: 0.5em; margin: 0; }
	.submenuwrap ul, .fl_menu>li:after { display: none; }
	.fl_menu ul.tapped ul.submenuwrap { display: block!important; }
	
	.hasjs .fl_menu #menu_c_support>ul { position: static; background: transparent; }
	.submenuwrap>li { padding-right: 0!important; }
	
	#menu_c_search { display: block!important; }
	div.smwrap, .socmed { position: static; padding: 0; margin: 0 auto; text-align: center; }
	.socmed a { margin: 10px 5px 0; display: inline-block; vertical-align: top; }

	.productsubcats, #productswrap, .productlinks { margin: 0 -0.6666666%; }
	.productlinks h3 { margin-left: 0.6666666%; }
	.prodbox { width: 32%; margin: 0 0.666666666% 1.3333333333%; }

	#popupwrap { left: 10%; right: 10%; }
	#remem { margin-top: 10px; }

	a.impage, a.resource { width: calc(100% / 3 - 20px); }
	
	a.buttondonatemenu { display: inline-block; margin: 10px auto; text-align: left; }
	

}
@media all and (max-width: 699px) {
	.cms_imgleft, .cms_imgright { max-width: 200px; }
	.frontbar h2 { display: block; margin-right: 0; padding-right: 0; border-right: 0; }
	.frontbar h4 { width: auto; display: block; margin-top: 10px; }
	#scroller { padding-bottom: 50%; }
	
	.imimages a { width: 82px; height: 82px; }
	.imimages { width: 174px; }
}

@media all and (max-width: 679px) {
	.productsubcats, #productswrap, .productlinks { margin: 0 -1%; }
	.productlinks h3 { margin-left: 1%; }
	.prodbox { width: 48%; margin: 0 1% 2%; }
	.storepage table { table-layout: fixed; display: block; } .storepage tbody { overflow: scroll; }
	.rememboxes .linktext { padding-bottom: 15%; font-size: 18px; line-height: 22px; }
	.slidewrap { box-sizing: border-box; width: calc(100% - 80px); padding-right: 20px; }
}

@media all and (max-width: 599px) {
	html, body { font-size: 14px; line-height: 22px; }
	h1 { font-size: 28px; line-height: 32px; }
	h2, .slide h2 { font-size: 24px; line-height: 28px; }
	h3 { font-size: 20px; line-height: 24px; }
	h4 { font-size: 18px; line-height: 22px; }
	.subpages a h4, .accountoptions li a { font-size: 14px; line-height: 18px; padding: 10px; }
	.cms_imgleft, .cms_imgright { max-width: 100%; display: block; margin: 0 auto; float: none; }
	.slide p { font-size: 16px; line-height: 22px; margin-top: 5px; }
	div.eventinfo { float: none; width: auto; margin: 0 0 10px; }
	.eventinfo img { margin: 0 auto; }
	
	.subpages a, .accountoptions li, .newsitem { width: calc(50% - 25px); padding-bottom: 30%; }
	.newsitem { padding-bottom: 0; }
	#scroller { padding-bottom: 60%; }

	table.storebasket img { display: none!important; }

	.productimg, #productimg { width: 240px!important; max-width: 240px; }
	.productimgthumbs { width: 240px; }
	.productpricing, .addtobasket { padding-right: 260px; }

	form#shownearest { margin-right: 0; }
	#maplegend { position: static; width: auto; margin-bottom: 10px; text-align: left; }
	.legendtype { display: inline-block; margin-right: 10px; }
	.legendtype span { width: auto; }

	#popupwrap { left: 5%; right: 5%; }
	.lhs>.fl_blogpost1>.fl_blogentrytitle { margin-top: 30px!important; }

}
@media all and (max-width: 499px) {
	#scroller { padding-bottom: 75%; }
	.wrapper { padding: 0 15px; }
	#scroller { margin-left: -15px; margin-right: -15px; }
	#_chat_link_1215 { right: 15px; }
	
	.imimages { float: left; width: 100%; margin-left: -5px; }
	a.impage, a.resource { width: calc(50% - 20px); }
}
@media all and (max-width: 470px) {
	.productimg, #productimg { width: 140px!important; max-width: 140px; }
	.productimgthumbs { width: 140px; }
	.productpricing, .addtobasket { padding-right: 160px; }
}
@media all and (max-width: 449px) {
	.helpwrap { display: none; }
	.rememboxes .linktext { font-size: 16px; line-height: 20px; }

	.prodbox .prodtitle { font-size: 16px; line-height: 20px; }
	.prodbox .prodprice { font-size: 12px; }

	.productimg, #productimg { width: 100%!important; max-width: 400px; padding-left: 0; }
	.productimgthumbs { width: 100%; }
	.productpricing, .addtobasket { padding-right: 0; }

	.pagefile-candle-remembrance .fl_comment1, .pagefile-candle-remembrance .fl_comment2 { padding-left: 80px; background-size: 60px 60px; min-height: 60px; }
	.subpages a h4, .accountoptions li a { line-height: 16px; }

}

@media all and (max-height: 700px) {
	#map_canvas.supportmap { max-height: 450px; }
}
@media all and (max-height: 599px) {
	#popupwrap { top: 5%; bottom: 5%; }
}

.imglarge { height: 0; padding-bottom: 100%; background-size: contain; background-position: center; background-repeat: no-repeat; }

.pf-inmemory header a.buttondonate { display:none!important; }
#card-element { background: #f0f0f0; padding: 10px; }

div#cardtype { position: absolute; background: url('../gfx/cards@2x.png') no-repeat left top; left: 9px; bottom: 9px; width: 37px; height: 22px; background-size: 37px auto; }
.cardlabel { border-top: 1px solid #eee; border-bottom: 1px solid #eee; margin-top: -1px; padding: 8px 5px 5px; margin: 0 0 -1px!important; }
.cardlabel:first-of-type { margin-top: 10px!important; }
span.cardgraphic { display: inline-block; background: url('../gfx/cards@2x.png') no-repeat left top; width: 37px; height: 22px; vertical-align: middle; position: relative; top: -2px; background-size: 37px auto; }
div#cardtype.applepay, span.cardgraphic.applepay { background-position: left bottom; }
div#cardtype.amex, span.cardgraphic.amex { background-position: left -66px; }
div#cardtype.mastercard, span.cardgraphic.mastercard { background-position: left -44px; }
div#cardtype.visa, span.cardgraphic.visa { background-position: left -22px; }
div#cvcwrap, div#expirywrap { display: inline-block; vertical-align: top; margin-right: 10px; }
input#cardnumber, input#cvc, select#expirymonth, select#expiryyear { border-bottom: 2px solid transparent; }
input#cvc { width: 120px; }
select#expirymonth { width: 120px; margin-right: 5px; display: inline-block; }
select#expiryyear { width: 80px; display: inline-block; }
.valid { border-color: #0c0!important; }
.error { border-color: #c00!important; }
.err { color: #c00; font-weight: 600; }
input.disabled { opacity: 0.5; cursor: not-allowed; }
.textlabel { position: absolute; left: -9999px; }
.cardlabel.expired .details { text-decoration: line-through; }

#paymentrequest { display: none; }
#payment-request-button { margin-top: 10px; }
#payment-request-button, #card-element { max-width: 400px; }

@keyframes fadein {
    from { opacity: 0.5; }
    to { opacity: 1; }
}

#lightwrap { position: relative; pointer-events: none; }
#lightwrap img { width: 100%; display: block; }
#lightfgwrap { position: absolute; }
#lightfg { background-size: contain; background-position: center; background-repeat: no-repeat; }
.light { position: absolute; }
.lighttap { cursor: pointer; pointer-events: auto; position: absolute; top: 0; left: 0; right: 0; bottom: 0; width: 10px; height: 10px; margin: -5px 0 0 -5px; }
.lightdot { margin: -3px 0 0 -3px; border-radius: 50%; background: #fae9b4; cursor: pointer; pointer-events: auto; width: 6px; height: 6px; box-sizing: border-box; box-shadow: 0 0 10px 10px rgba(208,127,93,0.8); transition: all 0.3s ease-in-out; border: 1px solid #d07f5d; }
.light:hover .lightdot, .lightshown .lightdot { width: 10px; height: 10px; margin: -5px 0 0 -5px; }
.light .lightdot::after { box-shadow: 0 0 25px 10px rgba(208,127,93,0.5); opacity: 0; transition: opacity 0.3s ease-in-out; content: ''; }
.light:hover .lightdot::after, .lightshown .lightdot:after { opacity: 1; }
.lightinfo { opacity: 0; pointer-events: none; transition: opacity 1s ease-in-out; background: rgba(255,255,255,0.9); border: 1px solid rgba(245,186,73,0.5); position: absolute; top: 0; left: 5px; transform: translate3d(0, -50%, 0); width: 250px; box-sizing: border-box; padding: 10px; border-radius: 5px; font-size: 14px; line-height: 20px; z-index: 20; }
.lightshown .lightinfo { opacity: 1; pointer-events: auto; }
.lightinfo h4 { margin: 0 0 5px; }
.lightinfo .lightmsg { white-space: pre-wrap; }
.lightinfo .lightfrom { font-size: 0.9em; font-weight: 600; font-style: italic; color: #24246c; margin-top: 5px; text-align: right; }
.lightinfo.infobelow { top: 20px; left: 0; transform: translate3d(-50%, 0, 0); }
.lightinfo.infoleft { top: 0; left: auto; right: 20px; transform: translate3d(0, -50%, 0); }
.lightinfo.infobottomleft { top: 0; left: auto; right: 20px; transform: translate3d(0, -100%, 0); }
.lightinfo.infobottomright { top: 0; left: 20px; right: auto; transform: translate3d(0, -100%, 0); }
.light .lightdot::before { box-shadow: 0 0 25px 10px #5ca2d2; animation: fadein 2s ease-in alternate infinite; content: ''; }
.lightgeneric { width: 75px; height: 75px; background-size: auto 250%; background-position: center; background-repeat: no-repeat; background-color: #222; float: right; margin: 3px 0 10px 10px; }
.lightgeneric5 { background-image: url('../gfx/snowflake-generic@2x.png')!important; background-size: contain!important; }

.lightspot { background-size: contain; background-repeat: no-repeat; background-position: center; pointer-events: none; transition: all 0.3s ease-in-out; transform: scale3d(4,4,1); }
.light:hover .lightspot { transform: scale3d(5,5,1); }
.ln1 { width: 34px; height: 34px; margin: -17px 0 0 -17px; background-image: url('../lights/star-1.png'); }
.ln2 { width: 34px; height: 34px; margin: -17px 0 0 -17px; background-image: url('../lights/star-2.png');}
.ln3 { width: 20px; height: 20px; margin: -10px 0 0 -10px; background-image: url('../lights/star-3.png');}
.ln4 { width: 32px; height: 32px; margin: -16px 0 0 -16px; background-image: url('../lights/star-4.png');}
.ln5 { width: 34px; height: 34px; margin: -17px 0 0 -17px; background-image: url('../lights/star-5.png');}
.ln6 { width: 54px; height: 54px; margin: -27px 0 0 -27px; background-image: url('../lights/star-6.png');}
.ln7 { width: 50px; height: 50px; margin: -25px 0 0 -25px; background-image: url('../lights/star-7.png');}
.ln8 { width: 38px; height: 38px; margin: -19px 0 0 -19px; background-image: url('../lights/star-8.png');}
.ln9 { width: 46px; height: 46px; margin: -23px 0 0 -23px; background-image: url('../lights/star-9.png');}
.ln10 { width: 40px; height: 40px; margin: -20px 0 0 -20px; background-image: url('../lights/star-10.png');}
.ln11 { width: 26px; height: 26px; margin: -13px 0 0 -13px; background-image: url('../lights/star-11.png');}
.ln12 { width: 38px; height: 38px; margin: -19px 0 0 -19px; background-image: url('../lights/star-12.png');}

.lightspot5 { background: url('../gfx/snowflake-circle@2x.png') no-repeat center/10% 10%!important; }

#lightlist { position: absolute; top: 50px; right: 50px; bottom: 50px; overflow: auto; -webkit-overflow-scrolling: touch; pointer-events: auto; }
#lightlist table { width: 100%; border-collapse: collapse; background: rgba(255,255,255,0.9); text-align: left; font-size: 0.8em; }
#lightlist th, #lightlist td { padding: 3px 5px; }
#lightlist tr:first-child th { position: sticky; top: 0; background: #24246c; color: #fff; }
#lightlist tbody td { border-bottom: 1px solid #eee; vertical-align: top; }
#lightlist tbody tr { cursor: pointer; transition: background 0.3s; }
#lightlist tbody tr:hover { background: #80b4de; }
#lightlist th:last-child, #lightlist td:last-child { text-align: right; }
#lightlist input { height: 30px; padding: 5px; }

#lightfg img { width: 75px; }
#lightlist img { width: 50px; display: block; float: left; margin: 0 5px 0 0; }
#llbutton { display: none; }

.llsa #lightlist { position: static; max-height: 500px; }

.lightspagewrap { overflow: hidden; }

@media all and (max-width: 929px) {

	#llbutton { display: block; position: absolute; top: 10px; right: 10px; background: #f5ba49; color: #fff; font-weight: 600; padding: 10px; border-radius: 5px; cursor: pointer; pointer-events: auto; opacity: 1; transition: opacity 0.3s ease-in-out; }
	#llbutton:active { opacity: 0.6; }
	#lightwrap.showtable #llbutton { opacity: 0; pointer-events: none; }
	#lightlist { opacity: 0; pointer-events: none; transition: opacity 0.3s ease-in-out; display: block; z-index: 25; }
	#lightwrap.showtable #lightlist { pointer-events: auto; opacity: 1; }
	
	.llsa #llbutton { display: nonne; }
	.llsa #lightlist { opacity: 1; pointer-events: auto; }
	

	#lightwrap { max-width: 750px; margin: 0 auto; }
	#lightwrap>img { display: none; }
	#lightlist { top: 10px; bottom: 10px; left: 10px; right: 10px; width: auto!important; }
	#lightfgwrap { width: auto!important; position: relative; top: 0!important; left: 0!important; }
}
@media all and (max-width: 699px) {
	.lightspagewrap { margin: 0 -25px; padding: 0 25px; }
	#lightwrap { margin: 0 -25px; }
	.lightinfo { width: 200px; }
}
@media all and (max-width: 499px) {
	.lightspagewrap { margin: 0 -15px; padding: 0 15px; }
	#lightwrap { margin: 0 -15px; }
	.lightinfo { width: 180px; } 
	#lightfg img { width: 50px; }

	.lightspot { transform: scale3d(2.5,2.5,1); }
	.light:hover .lightspot { transform: scale3d(3.5,3.5,1); }


}


.form-37 p.sectionlabel { font-size: 1.2em; color: #24246c; font-weight: 600; }
#formstart { padding-top: 100px; margin-top: -100px; pointer-events: none; }

.faqsect { margin: 20px 0; }
h3.questiontitle { background: #f5ba49; padding: 10px 40px 10px 10px; margin: 0; font-size: 18px; line-height: 22px; position: relative; cursor: pointer; text-align: left; margin-top: 5px; transition: background 0.2s; }
.faqjs .questiontitle:after { content: '\25bc'; position: absolute; right: 10px; font-size: 0.6em; top: 50%; margin-top: -12px; color: #fff; transform: rotate(-90deg); transition: transform 0.25s; }
.faqjs.faqshown .questiontitle:after { transform: rotate(0); }
.questiontitle:hover { background: #80b4de; }
.questionanswer { padding: 0 20px; background: #f6f6f6; box-sizing: border-box; position: relative; }
.questionanswer h2, .questionanswer h3, .questionanswer h4 { text-align: left; margin: 10px 0; }
.questionanswer>*:first-child { margin-top: 0; padding-top: 20px; }
.questionanswer>p:first-of-type { margin-top: 0; }
.questionanswer>*:last-child { margin-bottom: 0; padding-bottom: 20px; }
.questionanswer { transition: 0.25s max-height; overflow: hidden; }
.faq .questionanswer { max-height: 0!important; }
.faqshown .faqa { max-height: 1000px; }
.questionanswer.notrans { transition:none; }
.questionanswer.answershown { max-height: 4000px!important; }
.questionanswer iframe { width: 100%!important; height: 300px!important; }

.bannerpages { text-align: center; background: #24246c; color: #fff; padding: 10px 20px; }
.bannerpages p { margin: 0; }
.bannerpages a { color: inherit; }