/*
Theme Name: Bootstrap 4 Child
Theme URI: 
Description: Bootstrap 4 Child Theme
Author: Eric Steinecke
Author URI: 
Template: bootstrap-four
Version: 2.0.0
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Tags: bootstrap four
*/

/*******************
Table of Contents

1. Imports & Fonts
2. General Styles
3. Header
4. Body
5. Footer
6. Media Queries

*******************/


/***************** 1. Imports & Fonts *****************/

@import url('https://fonts.googleapis.com/css?family=Cinzel|Open+Sans');
@font-face {
    font-family: Armwrestler;
    src: url('fonts/ArmWrestler.ttf');
}
@font-face {
    font-family:Hominis;
    src:url('fonts/HOMINIS.ttf');
}

/***************** 2. General Styles *****************/



/***************** 3. Header *****************/

header {
    position: fixed;
    left: 0;
    right: 0;
    z-index: 1000;
}

#header {
    font-family:'Cinzel','Trajan Pro',serif;
    background:#222;
    box-shadow:0 2px 4px #000;
    margin: 0 -15px;
    margin-bottom:-1px; /*some odd glitch */
    position: relative;
}

#header::before {
    content: '';
    background-image: url(images/floralSwirl.svg);
    background-size: cover;
    height: 100%;
    width: 100%;
    opacity: 0.1;
    position: absolute;
    left: 0;
    top: 0;
    background-position: center;
}

#menu-toggle {
    display:inline-block;
    color:#fff;
    font-size:1.2em;
    cursor:pointer;
}

#menu-toggle div {
    display:inline-block;
    margin:0 0.5em;
}

.icon-bar {background-color:#fff;}


#header-menu {
    background:#222;
    text-align: center;
    color:#fff;
    font-family:'Cinzel','Trajan Pro',serif;
    box-shadow:2px 2px 2px #000;
    padding-bottom:1em;
}

#header-menu::before {
    content: '';
    background-image: url(images/NewGrooveClear.png);
    opacity: 0.05;
    height: 200px;
    background-size: contain;
    background-repeat: no-repeat;
    display: inline-block;
    background-position: center bottom;
    width: 100%;
    margin-bottom: -200px;
}

#logo {
    width:230px;
    position:absolute;
    box-shadow:0 2px 4px #000;
    border-radius: 50%;
    background-color:#222;
    padding:1em;
}

#header-menu section {margin-top:1.5em;}

#header-menu section:nth-child(1) {
    margin-top:0;
    position:relative;
}

nav ul {
    padding:0;
    margin:0;
}

nav li {
    list-style:none;
    display: table;
    margin: 0.3em auto;
}

#header-menu a {
    color:#fff;
    font-size:1.2em;
}

#main-menu {
    display:table;
    margin:0 auto;
    z-index:2;
}

#main-menu a:focus, #main-menu a:hover {
    text-decoration: none;
    color:#fff;
}

#main-menu a::after {
    content:'';
    height:2px;
    background-color:#fff;
    width:0;
    transition: width 0.3s;
    display:block;
    margin:0 auto;
}

#main-menu a:hover::after {
    width:100%;
    transition: width 0.3s;
}

#header-social-media {
    margin:1.2em;
}

#header-social-media ul {
    display:inline-block;
    margin:0;
    padding:0;
}

#header-social-media li {
    display:inline-block;
    list-style:none;
    margin: 0 0.5em;
}

#header-social-media a {
    color:#fff;
}

#header-social-media span {
    font-size:0.85em;
    margin-left:1em;
}

#main-menu > li > ul.submenu > li > a:hover, #main-menu > li > ul.submenu > li > a:focus {
    background-color:transparent;
}

/***************** 4. Body *****************/
html {
    height:100%;
    box-sizing: border-box;
}
body {
    background-color:#000;
    color:#fff;
    font-family:'Open Sans', sans-serif;
    position:relative;
    min-height:100%;
}

#splash-text {
    text-align: center;
    color: #fff;
    font-family:'Cinzel', serif;
    text-shadow: 2px 2px 2px #000;
}

#splash-text h4 {
    font-size:4em;
    margin:0;
}

#splash-text span {
    font-size:0.9em;
    font-style: italic;
    margin:1em 0;
    display:block;
    font-family:'Cinzel', serif;
}

#splash-text span::before, #splash-text span::after {
    content: '';
    border: 1px solid #fff;
    width: 40px;
    background: #fff;
    border-radius: 50%;
    margin: 0 0.3em;
    display: inline-block;
    vertical-align: middle;
}

#splash-text img {
    max-width:100%;
    display: block;
    margin: 12.5em auto 5em;
}

#page-background {
    position: fixed;
    width: 100%;
    z-index: -1;
    filter: brightness(0.5);
    background-size:cover;
}

#page-background.front-splash {filter:none;}

h1.page-title {
    font-family: 'Cinzel','Trajan Pro',sans-serif;
    margin:2em 0 0;
    text-align: center;
}

h1.page-title::before {
    content: '';
    display: block;
    position: absolute;
    height: 12px;
    width: 6px;
    border-radius: 50%;
    background: #fff;
    top: 3.45em;
    left: 50%;
}

h1.page-title::after {
    content:'';
    display:block;
    border-bottom:1px solid #fff;
    width:100%;
    margin:0.5em 0 1em;
}


/***************** 5. Footer *****************/

footer {
    background-color: #222;
    margin-top: 1em;
    box-shadow: 0 -2px 4px #000;
    position: absolute;
    left: 0;
    right: 0;
    bottom: 0;
    font-family:Cinzel,'Trajan Pro',serif;
}

footer::before {
    content: '';
    background-image: url(images/floralSwirl.svg);
    opacity: 0.1;
    max-height: 100%;
    width: 100%;
    height: 100%;
    position: absolute;
    background-size: cover;
    background-repeat: no-repeat;
    background-position: center;
}

#footer-assoc {text-align: center;}

#footer-assoc img {
    display:inline;
    height:6em;
    margin:1em;
}

#sub-footer {
    text-align: center;
    padding: 1em 0;
    background: rgba(255,255,255, 0.05);
    color: #fff;
    font-family: 'Cinzel';
    font-size: 0.9em;
    margin:0 -15px;
}

/***************** 6. Media Queries *****************/

@media (max-width:767px) {
    #header-social-media {text-align: center;}
    #menu-toggle {
        float:none;
        margin:0 auto;
        position:relative;
        left:50%;
        transform:translateX(-50%);
        -ms-transform:translateX(-50%);
        -webkit-transform:translateX(-50%);
        
    }
    #header-menu {max-height:500px;}
    h1.page-title {margin:4em 0 0;}
    h1.page-title::before {top:5.45em;}
}

@media (max-width:991px) {
    /*#splash-text {margin:12em 0 4em;}*/
    footer {position:relative;}
    #footer-meta {padding:1em 0;}
}

@media (min-width:992px) {
    h1.page-title {margin: 2.5em 0 0;}
    h1.page-title::before {top:3.95em;}
    body {padding-bottom:12.5em;}
}