/*
Theme Name: Flagship
Author: Andrew Donoghue
Version: 1.0
License: GNU General Public License v2 or later
Text Domain: flagship
*/



html, body, div, span, applet, object, iframe, h1, h2, h3, h4, h5, h6, p, blockquote, pre, a, abbr, acronym, address, big, cite, code,
del, dfn, em, font, ins, kbd, q, s, samp, small, strike, strong, sub, sup, tt, var, dl, dt, dd, ol, ul, li, fieldset, form, label, legend,
table, caption, tbody, tfoot, thead, tr, th, td, figure, figcaption {
	border: 0;
	font-family: inherit;
	font-size: 100%;
	font-style: inherit;
	font-weight: inherit;
	margin: 0;
	outline: 0;
	padding: 0;
	vertical-align: baseline;
}

*,
*:before, 
*:after {  
	-webkit-box-sizing: border-box;  
	-moz-box-sizing: border-box;  
	box-sizing: border-box;
}

html,
body {
	height: 100%;
	width: 100%;
}

html {
	-webkit-text-size-adjust: 100%;  
	-ms-text-size-adjust: 100%;
	overflow-x: hidden;
	overflow-y: scroll;
        scroll-behavior: smooth;
}

@media screen and (prefers-reduced-motion: reduce) {

	html {
		scroll-behavior: auto;
	}

}

body {
        font-size: 16px;
        margin: 0;
        padding: 0;
}

body, 
input, 
select, 
textarea, 
button {
        font-family: "Montserrat", sans-serif; 
	font-weight: 400;
        line-height: 1.5;
}

article,
aside,
figcaption,
figure,
footer,
header,
main,
nav,
section {
	display: block;
}

a {
	text-decoration: none;
}

a:hover,
a:active,
a:focus {
	outline: 0;
        cursor: pointer;
}

embed, 
iframe, 
object, 
video {
	max-width: 100%;
}

strong,
b {
        font-weight: 700;
}

em,
i {
	font-style: italic;
}

small {
        font-size: 0.75em;
}

blockquote {
        padding-bottom: 1em;
}

cite {

}

sub,
sup {
        font-size: 50%;
        line-height: 0;
        position: relative;
        vertical-align: baseline;
}

sup {
        top: -0.75em;
}

sub {
        bottom: -0.25em;
}

.the-title {
        font-weight: 700;
        line-height: 1.1;
        margin-bottom: 0.2em;
        padding-bottom: 0;
}

h1 {
        font-weight: 700;
        line-height: 1.1;
        margin-bottom: 0.5em;
}

h2 {
        font-size: 2em;
        font-weight: 700;
}

h3 {
        font-size: 1.5em;
        font-weight: 700;
        line-height: 1.2;
        margin-bottom: 0.25em;
}

h4 {
        font-size: 2em;
        font-weight: 700;
        margin-bottom: 0.5em;
}

p {
        padding-bottom: 1em;
}

ul {
	list-style: none;
	margin: 0;
        padding: 0;
}

ol {
	list-style: none;
	margin: 0;
        padding: 0;
}

ol li {
        position: relative;
}

ol li h3 i {
        line-height: 1.2;
        margin-left: 10px;
        float: right;
}

img, 
figure {
        display: block;
	max-width: 100%;
        height: auto;
}

a img {
	border: 0;
}

.screen-reader-text {
	clip: rect(1px, 1px, 1px, 1px);
	position: absolute;
	height: 1px;
	width: 1px;
	overflow: hidden;
}

.screen-reader-text:hover,
.screen-reader-text:active,
.screen-reader-text:focus {
	clip: auto;
	display: block;
	height: auto;
	width: auto;
	left: 0;
	top: 0;
	z-index: 100000; 
}

.clear:before,
.clear:after,
.the-content ol:before,
.the-content ol:after, 
#services ol:before,
#services ol:after {
	content: "";
	display: table;
	clear: both;
}



.featured-image-container {
        background-position: center center;
        background-repeat: no-repeat;
        background-size: cover;
}

.featured-image-caption {
        font-size: 0.8em;
        min-height: 30px;
        position: absolute;
        bottom: 0;
        right: 5%;
        z-index: 3;
        text-align: right;
}
        
.featured-image-caption,
.featured-image-caption a {
        color: #ffffff;
}

.fic-icon:hover {
        cursor: pointer;
}

#fic-text,
#fic-toggle {
        display: none;
}

#fic-toggle:checked ~ #fic-text {
        display: inline;
}





.site {
        position: relative;
        overflow: hidden;
}

.site-content {
        position: relative;
        z-index: 2;
}

.page-header,
.the-header {
        position: relative;
}

.page-header {
        margin-bottom: 1.5em;
}





.site-branding div {
        overflow: hidden;
        text-overflow: ellipsis;
        white-space: nowrap;
}

.site-branding a:hover {
        opacity: 0.75
}

.site-logo {
        display: inline-block;
}

.logo {
        display: block;
        max-width: 100%;
}

.wp-custom-logo .site-title-header {
        display: none;
}




.action-button {
        display: inline-block;
        margin-left: 1.5em;
}



.the-content {
        margin-bottom: 1em;
}



.above-content-notice {
        margin-bottom: 0.5em;        
}




.underline-link a {
        border-bottom: 1px dotted;
}

.underline-link a:hover,
.underline-link a:active, 
.underline-link a:focus {
        border-bottom: 1px solid;
}




.gallery-item {
        margin-bottom: 1em;
}

.gallery-item img {
        display: block;
}

.gallery-item figcaption {
        margin-top: 0.5em;
}





.site-footer {
        padding-top: 1em;
        padding-bottom: 1em;
}

.footer-branding,
.footer-colophon {
        position: relative;
        z-index: 2;
}

.footer-branding {
        margin-bottom: 1em;
}

.footer-logo img {
        display: block;
}

.footer-colophon {
        font-size: 0.9em;
}

.footer-colophon a {
        margin-right: 1em;
}

.footer-colophon a:hover,
.footer-colophon a:active,
.footer-colophon a:focus {
        opacity: 0.75;
}

.footer-colophon .footer-contact-icon {
        margin-right: 0.25em;
}


.site-footer .social-profiles {
        margin-left: 1em;
}

.back-to-top {
        position: absolute;
        right: 0;
}





