/* ------------------------------------------------------------------------- */
/* INITIAL SETUP */

@font-face {
    font-family: 'SansCulottes';
    src: url('../_fonts/SansCulottes.eot');
    src: url('../_fonts/SansCulottes.eot') format('embedded-opentype'),
         url('../_fonts/SansCulottes.woff') format('woff'),
         url('../_fonts/SansCulottes.ttf') format('truetype'),
         url('../_fonts/SansCulottes.svg') format('svg');
    font-weight: normal;
    font-style: normal;
}

html, body, table, th, tr, td, p, img, hr, ul, li, h1, h2, h3, h4, h5, div, form, fieldset {padding:0; margin:0; border:none;}

@media screen and (-webkit-min-device-pixel-ratio:0) {
    html, body, table, th, tr, td, p, img, hr, ul, li, h1, h2, h3, h4, h5, div, form, fieldset {padding:0; margin:0; border:none;}
    h1 {font-weight:normal;}
}

:root {
    font-size:16px;
    --basic_font_size: 16px;
    --accent_color:#c7b29b;
    --woody_brown:#a75e34;
    --light_beige:#fef4cd;
}


body {
    font-family:'Noto Serif', serif;
    font-weight:400;
    color:#FFFFFF;
}

div, video {
    position: relative;
}    

table { 
    border-spacing: 0;
    border-collapse: collapse;
}

div#vax_overlay {
    width:10vw;
    height:10vw;
    background-image: url('../_img/vaccination_overlay.png');
    background-repeat: no-repeat;
    background-size:contain;
    position:absolute;
    bottom:30%;
    left:10%;
    z-index: 10000;
}

/* ------------------------------------------------------------------------- */
/* TYPOGRAPHY */

.sp_after_3 { margin-bottom: 3px; }
.sp_after_6 { margin-bottom: 6px; }
.sp_after_9 { margin-bottom: 9px; }
.sp_after_12 { margin-bottom: 12px; }
.sp_after_18 { margin-bottom: 18px; }
.sp_after_24 { margin-bottom: 24px; }
.sp_before_3 { margin-top: 3px; }
.sp_before_6 { margin-top: 6px; }
.sp_before_9 { margin-top: 9px; }
.sp_before_12 { margin-top: 12px; }
.sp_before_18 { margin-top: 18px; }
.sp_before_24 { margin-top: 24px; }
.align_r { text-align:right; }

h1 {
    font-family:'Oswald', sans-serif;
    font-size:1.7rem;
    line-height:1.8rem;
    font-weight:500;
    color:var(--accent_color);
    margin-bottom:.35rem;
}

p {
    font-size:1.2rem;
    font-weight:400;
    color:#FFFFFF;
    margin-bottom:1rem;
}

.medium-sz { font-size:1.6rem; }
.large-sz { font-size:2.4rem; }

ul {
    list-style: inside url('../_img/leaf_bull.png');
    font-weight:700;
    font-style:italic;
    font-size:1.3rem;
}

li {
    margin:.2rem 0 .7rem 3rem;
    text-indent: -3rem;
    line-height:1.4rem;
    
}

span.artist {
    font-weight:500;
    font-size:1rem;
    font-style:normal;
    color:var(--accent_color);
}

span.quote {
    font-size:1.5rem;
    line-height:1.8rem;
    color:var(--accent_color);
    font-style:italic;
    display:block;
    border-top:3px double var(--accent_color);
    border-bottom:3px double var(--accent_color);
    padding:.6rem 0;
    margin: .7rem 0;
    -webkit-column-break-inside: avoid; /* Chrome, Safari */
    page-break-inside: avoid;           /* Theoretically FF 20+ */
    break-inside: avoid-column;         /* IE 11 */
}

a, a:active, a:hover, a:visited {
    text-decoration:underline;
    color:inherit;
}

a:hover {
    color:var(--accent_color);
}

/* ------------------------------------------------------------------------- */
/* GENERAL */

html {
    height:100%; width:100vw; 
}

body {
    width:100vw;
    height:100%;
    background-image:url('../_img/steel_bg_3.jpg');
    background-size:cover;
    background-repeat:repeat-y;
}

div#guitarneck {
    width:15%;
    max-width:200px;
    height:100%;
    position:absolute;
    z-index:20000;
    top:0;
    right:5%;
    background-image:url('../_img/gtr_neck_tile_2.jpg');
    background-size:contain;
    background-repeat:repeat-y;
    -webkit-box-shadow: -38px 0px 25px -1px rgba(0,0,0,0.67);
    -moz-box-shadow: -38px 0px 25px -1px rgba(0,0,0,0.67);
    box-shadow: -38px 0px 25px -1px rgba(0,0,0,0.67);
}

div#main_wrap {
    width:100%;
    height:auto;
}

#navbar {
    background-image:url('../_img/wood_divider_alt.jpg');
    background-repeat:repeat-x;
    background-position:left bottom;    
    height:30px;
    padding:15px 25vw 15px 5vw;
    position:fixed;
    z-index:19000;
    width:70vw;
    top:0;
    left:0;
    overflow:hidden;
    -webkit-box-shadow: 0px 0px 48px 9px rgba(0,0,0,0.75);
    -moz-box-shadow: 0px 0px 48px 9px rgba(0,0,0,0.75);
    box-shadow: 0px 0px 48px 9px rgba(0,0,0,0.75);
    
}

.navhead {
    height:30px;
    float:right;
    cursor:pointer;
}

div.burger_dropdown {
    position:fixed;
    top:-400px;
    right:25%;
    z-index:9000;
    background-image:url('../_img/nav_dd_bg.png');
    background-position:bottom;
    width:246px;
    height:373px;
    display:none;
}

.navhead_dd {
    cursor:pointer;
}

.navhead_dd:first-of-type {
    margin-top:2.5em;
}

.navhead_dd:last-of-type {
    margin-bottom:1em;
}

div#nav_spacer {
    width:100%;
    height:60px;
}

.divider {
    width:77%;
    margin:0 0 5rem 0;
}

.divider img {
    height:6rem;
    position:absolute;
    top:0;
    right:0;
}

footer {
    width:100%;
    margin:0;
    height:25vh;
    max-height:500px;
    background-image:url('../_img/wood_divider_alt.jpg');
    background-size:cover;
    background-repeat:repeat-x;
    z-index:500;
    -webkit-box-shadow: 0px 0px 48px 9px rgba(0,0,0,0.75);
    -moz-box-shadow: 0px 0px 48px 9px rgba(0,0,0,0.75);
    box-shadow: 0px 0px 48px 9px rgba(0,0,0,0.75);
}

footer img {
    position:absolute;
    left:6vw;
    bottom:6vh;
    height:5rem;
}

/* ------------------------------------------------------------------------- */
/* PAGE BUILDING BLOCKS */

section {
    width:95%;
    margin:0;
    padding:5vh 0 10vh 5%;
}

.sect_inner_wrap {
    width:70%;
    display:flex;
    flex-wrap:wrap;
}

.sect_hd {
    margin-bottom: 2rem;
    margin-right:4vw;
}

.sect_hd img {
    height:3.5rem;
    max-height:60px;
}

.column {
    height:100%;
    margin-right:3vw; 
}

.column:last-of-type {
    margin-right:0;
}

.two_col {
    -webkit-column-count: 2; /* Chrome, Safari, Opera */
    -moz-column-count: 2; /* Firefox */
    column-count: 2;
    -webkit-column-gap: 3vw; /* Chrome, Safari, Opera */
    -moz-column-gap: 3vw; /* Firefox */
    column-gap: 3vw;
    
}

.v_flex, .h_flex {
    display: flex;
    flex-direction: column;
    flex-wrap: wrap;
    align-items: flex-start;
    height: 70vh;
}

.h_flex {
    flex-direction: row;
    height:auto;
}

.testblock {
    width:100px;
    height:100px;
    background-color:green;
    margin:0 20px 20px 0;
}

.para_A {
    width:45%;
    order:1;
}

.para_B {
    width:45%;
    order:3;
}

.flex_auto {
    flex-basis:auto;
}

.flex_1 {
    flex:1 1;
}

.flex_2 {
    flex:2 2;
}

.flex_justify {
    display:flex;
    justify-content:space-between;
    flex-wrap:wrap;
}

.break, .hard_break {
    flex-basis: 100%;
    width: 0px; 
    height: 0px; 
    overflow: hidden;
    display: inline-block; 
}

.rule_top {
	padding:1vh 0;
	border-top:1px solid var(--accent_color);
}

/* ------------------------------------------------------------------------- */
/* FORM */


form {
    overflow:hidden;
    margin:2rem 0 2.5rem 0;
    padding-top:1rem;
    border-top:1px solid var(--accent_color);
}

form p {
    font-size:.9rem;
    color:var(--accent_color);
    font-style:italic;
}

label {
    width:100%;
    font-size:1rem;
    margin:8px 10px 0 0;
}

input.text, textarea {
    width:calc(100% - 2rem);
    font-family:'Noto Serif',serif;
    font-size:1rem;
    background-color:#fef4cd;
    border:1px solid #666666;
    border-radius:.7rem;
    padding:1rem;
    -webkit-box-shadow: inset 0px 0px 10px 5px rgba(0,0,0,0.35);
    -moz-box-shadow: inset 0px 0px 10px 5px rgba(0,0,0,0.35);
    box-shadow: inset 0px 0px 10px 5px rgba(0,0,0,0.35);
}

textarea {
    min-height:5rem;
    resize:vertical;
    margin-top:.3rem;
}

.button {
    float:right;
    clear:left;
    min-width:100px;
    font-family:'Noto Serif',serif;
    font-size:1.2rem;
    text-align:center;
    color:#FFFFFF;
    background-color:#666666;
    border:2px solid var(--accent_color);
    border-radius:26px;
    padding:10px 30px;
    margin:20px 0 0 0;
}

.button:hover {
    background-color: var(--woody_brown);
    color:#FFFFFF;
    cursor:pointer;
}



/* ------------------------------------------------------------------------- */
/* SPECIFIC ELEMENTS */

.home_portrait {
    width:50vw;
    height:100%;
    margin:-5vh 0 0 -3vw;
    z-index:10;
}

.home_logo {
    position:absolute;
    top:7vh;
    right:2vw;
    width:30vw;
    z-index:100;
}

.home_text_wrap {
    display:flex;
}

.overlay {
    background-image:url('../_img/overlay_bg_tile.png');
    width:100%;
    height:100%;
    position:absolute;
    top:0;
    left:0;
    z-index:99999;
}

.overlay p {
    text-align:center;
    font-size:1.5rem;
    font-weight:700;
    color:#000000;
    width:35vw;
    text-shadow: 0px 0px 12px #FFFFFF;
    padding:2rem;
    background-color:#fef4cd;
    -webkit-box-shadow: 0 0 20px 10px rgba(254,254,205,1);
    -moz-box-shadow: 0 0 20px 10px rgba(254,254,205,1);
    box-shadow: 0 0 20px 10px rgba(254,254,205,1);
}

span.close_msg {
    font-size:.65rem;
    font-family:'Helvetica',sans-serif;
    color:#666666;
    margin-top:2rem;
    text-align:center;
    display:inline-block;
    letter-spacing:1px;
}

/* ------------------------------------------------------------------------- */
/* VIDEO */

.vid_home_thumb {
    width:100%;
    display:inline-block;
    cursor:pointer;
}

.blocker, .vid_blocker {
    width:100%; height:100%;
    position:absolute;
    top:0; left:0;
    z-index:500;
}

.vid_blocker {
    background-color:#000000;
    opacity:0.8;
    z-index:800000;
    overflow:hidden;
}

div.video_wrap {
    width:80%;
    position: absolute;
    top:15%;
    left:10%;
    z-index:900000;
    border:1px solid #666666;
    -webkit-box-shadow: 10px 10px 23px 0px rgba(0,0,0,0.75);
    -moz-box-shadow: 10px 10px 23px 0px rgba(0,0,0,0.75);
    box-shadow: 10px 10px 23px 0px rgba(0,0,0,0.75);        
}
video {
    width:100%;
}

div.close_but {
    width:30px;
    height:30px;
    cursor:pointer;
    position:absolute;
    top:-15px;
    right:-15px;
    z-index:10;
    overflow:hidden;
}

div.close_but:hover img {
    margin-top:-30px;
}

.video_thumb_wrap {
    width:30%;
    cursor:pointer;
}

.video_thumb_wrap img {
    width:100%;
}

.video_thumb_wrap p {
    text-align:center;
    font-style:italic;
    font-size:.9rem;
    margin:-2px 0 6px 0;
}

/* ------------------------------------------------------------------------- */
/* DEVICE-SPECIFIC */

/* SMARTPHONES */
@media only screen and (max-width: 600px) {
    :root {
        font-size: 12px;
        --basic_font_size: 12px;
    }
    
    div#guitarneck {
        -webkit-box-shadow: -24px 0px 16px -1px rgba(0,0,0,0.40);
        -moz-box-shadow: -24px 0px 16px -1px rgba(0,0,0,0.40);
        box-shadow: -24px 0px 16px -1px rgba(0,0,0,0.40);
    }    
    
    #navbar {
        height: 24px;
        padding: 10px 30% 10px 5%;
    }
    
    #nav_burger { height:100% }
    #nav_burger img { height:100%; } 
    section { padding:3vh 0 3vh 5%; }
    .sect_inner_wrap, .home_text_wrap { display:inline-block; }
    .home_portrait { width:70vw; }
    
    .home_logo {
        position:relative;
        width:50vw;
        margin:-18vw auto 0 9vw;
        top:0;
        left:0;
    }
    
    .video_thumb_wrap { width:45%; }
    .medium-sz { font-size:1.3rem; }
    .large-sz { font-size:2.0rem; }

    
    .two_col {
        -webkit-column-count: 1; /* Chrome, Safari, Opera */
        -moz-column-count: 1; /* Firefox */
        column-count: 1;
    }
        
    footer { height:15vh; }
    footer img { height:auto; width:70%; }
    .overlay p { width:65vw; }      
    
}

/* TABLETS */
@media only screen and (min-width: 601px) and (max-width: 1200px) {
    :root {
        font-size: 14px;
        --basic_font_size: 14px;
    }

    div#guitarneck {
        -webkit-box-shadow: -24px 0px 16px -1px rgba(0,0,0,0.40);
        -moz-box-shadow: -24px 0px 16px -1px rgba(0,0,0,0.40);
        box-shadow: -24px 0px 16px -1px rgba(0,0,0,0.40);
    }    
    
    #navbar {
        height: 24px;
        padding: 12px 30% 17px 5%;
    }
    
    section { padding:3vh 0 3vh 5%; }
    
    img.home_logo {
        top:4vh;
        width:32vw;
    } 
    
    .video_thumb_wrap { width:45%; }
    .medium-sz { font-size:1.5rem; }
    .large-sz { font-size:2.2rem; }

    footer { height:20vh; }

    .overlay p { width:50vw; }      
}


/* DESKTOP */    
@media only screen and (min-width: 1201px) {
    
    .break {
        display: none;
    }
}    
    

