/*
Theme Name: Todd Barry 2023 Custom
Theme URI: https://toddbarry.com/
Description: A custom theme for Todd Barry.
Version: 1.0
Author: Stig Greve
Author URI: http://www.hirestig.com
Tags: comedy, comedian, podcast
License: Copyright 2023 Stig Greve, all rights reserved.
*/

body{
	background: #2c2e30;
	color: #fff;
	font-family: "macha", sans-serif;
	font-weight: 400;
	font-style: normal;
	font-size: clamp(1rem, 1.21vw, 2rem);
	margin: 0;
}
a{
	color: inherit;
	text-decoration: underline;
	text-decoration-color: #cef5e6;
	text-decoration-thickness: 0.125em;
	text-underline-offset: 2px;
	cursor: pointer;
}
strong, b{
	font-weight: 700;
	font-style: normal;
}
em, i{
	font-weight: 400;
	font-style: italic;
}
strong em, strong i, b em, b i, em strong, i strong, em b, i b{
	font-weight: 700;
	font-style: italic;
}
::selection {
	color: #cef5e6;
	background: #2c2e30;
}
::-moz-selection {
	color: #cef5e6;
	background: #2c2e30;
}
p{
	margin: 0 0 1.5em;
}

/* Homepage Header */

div#homesock{
	position: relative;
	width: 100vw;
	min-height: 100vh;
}
header#home{
	width: 68.4vw;
	margin: 4vw auto 0;
}
header#home h1{
	display: block;
	width: 68.4vw;
	height: 19.404vw;
	text-indent: -9999vw;
	overflow: hidden;
	z-index: 1;
}
.webp header#home h1{
	background: url(images/todd_name.webp);
	background-image: url(images/todd_name.svg), none;
	background-size: 68.4vw 19.404vw;
	background-repeat: no-repeat;
	background-position: center top;
}
.no-webp header#home h1,
.no-js header#home h1{
	background: url(images/todd_name.png);
	background-image: url(images/todd_name.svg), none;
	background-size: 68.4vw 19.404vw;
	background-repeat: no-repeat;
	background-position: center top;
}
header#home nav{
	display: block;
	position: absolute;
	top: 11.5vw;
	left: 50%;
	margin-left: -24.708vw;
	width: 49.416vw;
	height: 11.088vw;
	/* background: url(images/nav_home.webp);
	background-image: url(images/nav_home.svg), none;
	background-size: 41.18vw 9.24vw;
	background-repeat: no-repeat;
	background-position: center top; */
	z-index: 10;
}
header#home nav label,
header#home nav select{
	display: none;
}
.webp header#home nav ul.f_nav{
	display: block;
	background: url(images/nav_home.webp);
	background-image: url(images/nav_home.svg), none;
	background-size: 49.416vw 11.088vw;
	background-repeat: no-repeat;
	background-position: center top;
	margin: 0;
	padding: 0;
}
.no-webp header#home nav ul.f_nav,
.no-js header#home nav ul.f_nav{
	display: block;
	background: url(images/nav_home.png);
	background-image: url(images/nav_home.svg), none;
	background-size: 49.416vw 11.088vw;
	background-repeat: no-repeat;
	background-position: center top;
	margin: 0;
	padding: 0;
}
header#home nav ul.f_nav li{
	display: block;
	position: absolute;
	height: 2.88vw;
	text-indent: -9999vw;
	overflow: hidden;
	z-index: 100;
}
header#home nav ul.f_nav li a{
	display: block;
	width: 100%;
	height: 2.88vw;
}
	header#home nav ul.f_nav li.news{
		top: 5.8vw;
		left: -0.25vw;
		width: 6.6vw;
		transform: rotate(-40deg);
	}
	header#home nav ul.f_nav li.shows{
		top: 1.85vw;
		left: 5.5vw;
		width: 8.4vw;
		transform: rotate(-23deg);
	}
	header#home nav ul.f_nav li.bio{
		top: 0;
		left: 13.1vw;
		width: 4.5vw;
		transform: rotate(-11deg);
	}
	header#home nav ul.f_nav li.photos{
		top: -0.4vw;
		left: 17.75vw;
		width: 9.6vw;
		transform: rotate(3deg);
	}
	header#home nav ul.f_nav li.receipt_museum{
		top: 3.2vw;
		left: 26.2vw;
		width: 19.2vw;
		transform: rotate(27deg);
	}
	header#home nav ul.f_nav li.store{
		top: 5.3vw;
		left: 4.5vw;
		width: 7.56vw;
		transform: rotate(-29deg);
	}
	header#home nav ul.f_nav li.media{
		top: 2.7vw;
		left: 11vw;
		width: 8.1vw;
		transform: rotate(-14deg);
	}
	header#home nav ul.f_nav li.podcast{
		top: 2.1vw;
		left: 18.5vw;
		width: 10.8vw;
		transform: rotate(4deg);
	}
	header#home nav ul.f_nav li.contact{
		top: 4.9vw;
		left: 27.9vw;
		width: 10.8vw;
		transform: rotate(26deg);
	}

/* Subpage Header */

header#subpage{
	position: relative;
	width: 84vw;
	height: auto;
	margin: 0 auto;
	z-index: 1000 !important;
}
header#subpage h1{
	display: block;
	width: 53.256vw;
	height: 7.284vw;
	margin: 2.4vw auto 0;
	text-indent: -9999vw;
	overflow: hidden;
	z-index: 1;
}
.webp header#subpage h1{
	background: url(images/todd_sub_name.webp);
	background-image: url(images/todd_sub_name.svg), none;
	background-size: 53.256vw 7.284vw;
	background-repeat: no-repeat;
	background-position: center top;
}
.no-webp header#subpage h1,
.no-js header#subpage h1{
	background: url(images/todd_sub_name.png);
	background-image: url(images/todd_sub_name.svg), none;
	background-size: 53.256vw 7.284vw;
	background-repeat: no-repeat;
	background-position: center top;
}
header#subpage nav{
	display: block;
	position: relative;
	width: 78.204vw;
	height: 3.576vw;
	margin: 1.2vw auto 0;
	overflow: hidden;
}
header#subpage nav div.fallbacknav_t{}
.webp header#subpage nav div.fallbacknav_t{
	background: url(images/nav_top.webp);
	background-image: url(images/nav_top.svg), none;
	background-size: 78.204vw 3.576vw;
	background-repeat: no-repeat;
	background-position: center top;
}
.no-webp header#subpage nav div.fallbacknav_t,
.no-js header#subpage nav div.fallbacknav_t{
	background: url(images/nav_top.png);
	background-image: url(images/nav_top.svg), none;
	background-size: 78.204vw 3.576vw;
	background-repeat: no-repeat;
	background-position: center top;
}
header#subpage nav div.fallbacknav_b{}
.webp header#subpage nav div.fallbacknav_b{
	background: url(images/nav_bottom.webp);
	background-image: url(images/nav_bottom.svg), none;
	background-size: 78.204vw 3.684vw;
	background-repeat: no-repeat;
	background-position: center top;
}
.no-webp header#subpage nav div.fallbacknav_b,
.no-js header#subpage nav div.fallbacknav_b{
	background: url(images/nav_bottom.png);
	background-image: url(images/nav_bottom.svg), none;
	background-size: 78.204vw 3.684vw;
	background-repeat: no-repeat;
	background-position: center top;
}
header#subpage nav ul,
nav.bottomnav ul{display: block; margin: 0; padding: 0;}
header#subpage nav li,
nav.bottomnav li{
	display: block;
	position: relative;
	float: left;
	height: 3.576vw;
	margin: 0 0.9vw 0 0;
	text-indent: -9999vw;
	overflow: hidden;
	z-index: 100;
}
header#subpage nav li a,
nav.bottomnav li a{
	display: block;
	width: 100%;
	height: 3.576vw;
}
	header#subpage nav li.home, nav.bottomnav li.home{width: 5.1vw;}
	header#subpage nav li.news, nav.bottomnav li.news{width: 5.1vw;}
	header#subpage nav li.shows, nav.bottomnav li.shows{width: 6.3vw;}
	header#subpage nav li.store, nav.bottomnav li.store{width: 5.7vw;}
	header#subpage nav li.bio, nav.bottomnav li.bio{width: 3.9vw;}
	header#subpage nav li.photos, nav.bottomnav li.photos{width: 7.2vw;}
	header#subpage nav li.receipt_museum, nav.bottomnav li.receipt_museum{width: 15.6vw;}
	header#subpage nav li.media, nav.bottomnav li.media{width: 5.1vw;}
	header#subpage nav li.podcast, nav.bottomnav li.podcast{width: 8.4vw;}
	header#subpage nav li.contact, nav.bottomnav li.contact{width: 6.6vw; margin: 0;}
	
/* Homepage Content */

section#backsock{
	position: absolute;
	top: 0;
	left: 50%;
	margin-left: -34.2vw;
	width: 68.4vw;
	height: 100vh;
	z-index: 1;
	overflow: hidden;
}
section#backsock div.starburst{
	position: absolute;
	top: 10.8vw;
	left: 0;
	width: 68.4vw;
	height: 68.4vw;
	animation: toddstar 250s linear 0s infinite forwards;
	text-indent: -9999vw;
	overflow: hidden;
}
.webp section#backsock div.starburst{
	background: url(images/starburst.webp);
	background-image: url(images/starburst.svg), none;
	background-size: 68.4vw 68.4vw;
	background-repeat: no-repeat;
	background-position: center top;
}
.no-webp section#backsock div.starburst,
.no-js section#backsock div.starburst{
	background: url(images/starburst.png);
	background-image: url(images/starburst.svg), none;
	background-size: 68.4vw 68.4vw;
	background-repeat: no-repeat;
	background-position: center top;
}
@keyframes toddstar {0% {transform: rotate(0);} 100% {transform: rotate(360deg);}
}
section#backsock div.big_todd{
	position: absolute;
	top: 23.1vw;
	left: 0;
	width: 64.8vw;
	height: 92.088vw;
	text-indent: -9999vw;
	overflow: hidden;
}
.webp section#backsock div.big_todd{
	background: url(images/big_todd2.webp) no-repeat center top;
	background-size: 68.4vw 97.2vw;
}
.no-webp section#backsock div.big_todd,
.no-js section#backsock div.big_todd{
	background: url(images/big_todd2.png) no-repeat center top;
	background-size: 68.4vw 97.2vw;
}

/* Subpage Content */

main#todd_frame{
	position: relative;
	width: 70.8vw;
	height: 49.8vw;
	padding: 5.1vw 6.6vw;
	margin: -1.992vw auto 0;
	z-index: 10;
}
.webp main#todd_frame{
	background: url(images/bg_frame.webp);
	background-image: url(images/bg_frame.svg), none;
	background-size: 84vw 59.916vw;
	background-repeat: no-repeat;
	background-position: center top;
}
.no-webp main#todd_frame,
.no-js main#todd_frame{
	background: url(images/bg_frame.png);
	background-image: url(images/bg_frame.svg), none;
	background-size: 84vw 59.916vw;
	background-repeat: no-repeat;
	background-position: center top;
}
main#todd_frame div#content_sock{
	position: relative;
	width: 70.8vw;
	height: 49.8vw;
	color: #2c2e30;
	overflow: scroll;
}
main#todd_frame div#content_sock iframe{
	display: block;
	margin: 0 auto 2vw;
}
main#todd_frame div#content_sock form,
div.newshead form{display: block;border: none;margin: 0 0 4.8vw;padding: 0;text-align: center;}
main#todd_frame div#content_sock form input,
div.newshead form input{
	display: inline-block;
	font-size: inherit;
	line-height: 1em;
	padding: 1.2vw 1.8vw;
	-webkit-border-radius: 0.6vw;
	-moz-border-radius: 0.6vw;
	border-radius: 0.6vw;
}
main#todd_frame div#content_sock form input.theaddy,
div.newshead form input.theaddy{
	background: #fff;
	color: #2c2e30;
	border: 2px solid #ababac;
}
main#todd_frame div#content_sock form input.thebutton,
div.newshead form input.thebutton{
	background: #2c2e30;
	color: #cef5e6;
	border: 2px solid #2c2e30;
	font-weight: 700;
	text-transform: uppercase;
	margin: 0 0 0 0.6vw;
}
main#todd_frame div#content_sock form input.thebutton:hover,
div.newshead form input.thebutton:hover{
	opacity: 0.8;
}
main#todd_frame div#content_sock hr{
	display: block;
	width: 85%;
	height: 2px;
	background: #cef5e6;
	border: none;
	margin: 0 auto 1.5em;
}
main#todd_frame div#content_sock div.breadcrumbs{
	font-weight: 700;
	text-transform: uppercase;
	margin: 0 0 2.4vw;
}
main#todd_frame div#content_sock div.n_title{
	font-size: 1.125em;
	line-height: 1em;
	font-weight: 700;
	text-transform: uppercase;
	margin: 0 0 0.48vw;
}
main#todd_frame div#content_sock h2,
main#todd_frame div#content_sock h3{
	font-size: 1.25em;
	line-height: 1em;
	font-weight: 700;
	text-transform: uppercase;
	margin: 0 0 1.8vw;
}
main#todd_frame div#content_sock h3,
main#todd_frame div#content_sock .rep_names{
	display: block;
	font-size: 1.1em;
	font-weight: 700;
	text-transform: uppercase;
	margin: 0 0 1.08vw;
}
main#todd_frame div#content_sock a{
	color: inherit;
	text-decoration: underline;
	text-decoration-color: #ababac;
	text-decoration-thickness: 0.125em;
	text-underline-offset: 2px;
	cursor: pointer;
	transition: fill 0.6s ease;
}
main#todd_frame div#content_sock a:hover{
	opacity: 0.6;
}

/* News Page */

div.newshead{text-align: center;}

/* Contact Page */

main#todd_frame div#content_sock .representatives {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	grid-template-rows: 1fr;
	grid-column-gap: 10px;
	grid-row-gap: 0px;
	margin: 0 0 4vw;
}
main#todd_frame div#content_sock ul.smlinks {
	display: grid;
	grid-template-columns: repeat(5, 1fr);
	grid-template-rows: 1fr;
	grid-column-gap: 10px;
	grid-row-gap: 0px;
	text-align: center;
}
main#todd_frame div#content_sock ul.smlinks li{
	display: inline-block;
	width: 5vw;
	height: 5vw;
	margin: 0;
	padding: 0;
	text-indent: -9999vw;
	overflow: hidden;
}
main#todd_frame div#content_sock ul.smlinks li a{
	display: block;
	width: 100%;
	height: 5vw;
}
main#todd_frame div#content_sock ul.smlinks li.smin{
	background: url(images/icon_instagram.webp);
	background-image: url(images/icon_instagram.svg), none;
	background-size: 5vw 5vw;
	background-repeat: no-repeat;
	background-position: center top;
}
main#todd_frame div#content_sock ul.smlinks li.smyt{
	background: url(images/icon_youtube.webp);
	background-image: url(images/icon_youtube.svg), none;
	background-size: 5vw 5vw;
	background-repeat: no-repeat;
	background-position: center top;
}
main#todd_frame div#content_sock ul.smlinks li.smtw{
	background: url(images/icon_twitter.webp);
	background-image: url(images/icon_twitter.svg), none;
	background-size: 5vw 5vw;
	background-repeat: no-repeat;
	background-position: center top;
}
main#todd_frame div#content_sock ul.smlinks li.smfa{
	background: url(images/icon_facebook.webp);
	background-image: url(images/icon_facebook.svg), none;
	background-size: 5vw 5vw;
	background-repeat: no-repeat;
	background-position: center top;
}
main#todd_frame div#content_sock ul.smlinks li.smtm{
	background: url(images/icon_tumblr.webp);
	background-image: url(images/icon_tumblr.svg), none;
	background-size: 5vw 5vw;
	background-repeat: no-repeat;
	background-position: center top;
}

/* Photos Page */

main#todd_frame div#content_sock .gallery {
	display: grid;
	grid-template-columns: repeat(5, 1fr);
	gap: 10px;
	grid-auto-rows: minmax(50px, auto);
}
main#todd_frame div#content_sock .gallery .gallery-item {
	position: relative;
	overflow: hidden;
	width: calc(14.16vw - 10px);
	margin: 0 5px 10px 0;
	text-align: center;
}
main#todd_frame div#content_sock .gallery .gallery-icon img {
	display: block;
	width: calc(14.16vw - 10px);
	height: auto;
	display: block;
	transition: transform 0.3s ease;
	border: none;
}
main#todd_frame div#content_sock .gallery .gallery-item:hover .gallery-icon img {
	transform: scale(1.1);
}
main#todd_frame div#content_sock .gallery .gallery-caption {
	display: none;
}
main#todd_frame div#content_sock .gallery br{
	display: none !important;
}

/* Quotes Page */

div#todd_quotes blockquote{
	display: block;
	font-size: 1.5em;
	line-height: 1.12em;
	margin: 0 6vw 3vw;
}
div#todd_quotes small{
	font-size: 0.55em;
	line-height: 1em;
}

/* Tour Dates Page */

div.todd_tourdates a{
	color: inherit;
	text-decoration: none !important;
	cursor: pointer;
}

/* Store Page */

main#todd_frame div#content_sock ul.storegrid {
	display: grid;
	grid-template-columns: min-content 1fr min-content 1fr;
	grid-column-gap: 15px;
	grid-row-gap: 35px;
	grid-auto-rows: minmax(50px, auto);
	margin: 0;
	padding: 0;
}
main#todd_frame div#content_sock ul.storegrid li{
	display: block;
	margin: 0;
	padding: 0;
}
main#todd_frame div#content_sock ul.storegrid li .attachment-large.size-large{
	display: block;
	width: calc(22vw - 30px) !important;
	height: auto;
	margin: 0 0 1vw;
}
main#todd_frame div#content_sock ul.storegrid li a.buybtn{
	display: block;
	background: #2c2e30;
	color: #cef5e6;
	font-size: inherit;
	font-weight: 700;
	text-transform: uppercase;
	margin: 0 0 0.5vw;
	padding: 1vw 1.5vw;
	-webkit-border-radius: 0.5vw;
	-moz-border-radius: 0.5vw;
	border-radius: 0.5vw;
	text-decoration: none !important;
	text-align: center;
}
main#todd_frame div#content_sock ul.storegrid li a.buybtn:hover{
	opacity: 0.8;
}
main#todd_frame div#content_sock ul.storegrid li strong.buynow{
	display: block;
	font-size: 1.25em;
	font-weight: 700;
	text-align: center;
	margin: 0 0 0.5vw;
}

/* Receipt Museum */

main#todd_frame div#content_sock ul.receiptgrid {
  display: grid;
  grid-template-columns: min-content 1fr; /* First column is min-content, second column is flexible */
  grid-template-rows: auto auto; /* You can adjust row sizes as needed */
  grid-gap: 35px 15px;
  margin: 0;
  padding: 0;
}

main#todd_frame div#content_sock ul.receiptgrid li {
  display: block;
}
main#todd_frame div#content_sock ul.receiptgrid li img{
	display: block;
	width: auto;
	height: auto;
	margin: 0 auto;
}
main#todd_frame div#content_sock ul.receiptgrid li.rcptspan {
  grid-column: span 2;
  text-transform: uppercase;
  font-weight: 700;
  margin: 0 0 -3vw;
}


/* Subpage Layout Elements */

nav.bottomnav{
	display: block;
	position: relative;
	width: 78.204vw;
	height: 3.684vw;
	margin: -1.98vw auto 0;
	overflow: hidden;
	z-index: 100 !important;
}
/* div.small_todd{
	position: absolute;
	top: 4.62vw;
	left: 50%;
	width: 26.4vw;
	height: 37.536vw;
	margin-left: -14.04vw;
	transform: rotate(6deg);
	z-index: 5;
}
.webp div.small_todd{
	background: url(images/small_todd.webp);
	background-size: 26.4vw 37.536vw;
	background-repeat: no-repeat;
	background-position: center top;
}
.no-webp div.small_todd,
.no-js div.small_todd{
	background: url(images/small_todd.png);
	background-size: 26.4vw 37.536vw;
	background-repeat: no-repeat;
	background-position: center top;
} */
div.smallstar01,
div.smallstar02{
	position: fixed;
	top: -1vw;
	left: 50%;
	width: 48vw;
	height: 48vw;
	margin-left: -24vw;
	animation: toddstar 250s linear 0s infinite forwards;
	z-index: 1;
}
.webp div.smallstar01,
.webp div.smallstar02{
	background: url(images/starburst.webp);
	background-image: url(images/starburst.svg), none;
	background-size: 48vw 48vw;
	background-repeat: no-repeat;
	background-position: center top;
}
.no-webp div.smallstar01,
.no-webp div.smallstar02,
.no-js div.smallstar01,
.no-js div.smallstar02{
	background: url(images/starburst.png);
	background-image: url(images/starburst.svg), none;
	background-size: 48vw 48vw;
	background-repeat: no-repeat;
	background-position: center top;
}
div.smallstar02{
	top: 31.2vw;
}

/* Homepage Banners */

section#announcements{
	position: relative;
	background: #000;
	border-bottom: 0.25vw solid #212325;
	margin: 0;
}
section#announcements div#domesticshorthair{
	position: relative;
	width: 100vw;
	height: 4.88vw;
	background: url(images/top_domesticshorthair_desktop.jpg) no-repeat center top;
	background-size: 78vw 4.88vw;
}
section#announcements div#domesticshorthair a{
	display: block;
	position: relative;
	width: 78vw;
	height: 4.88vw;
	margin: 0 auto;
	text-indent: -9999vw;
	overflow: hidden;
}

/* Footers */

footer#homefoot{
	position: sticky;
	bottom: 0.5rem;
	left: 25%;
	margin: 0 0 0.5vh -25vw;
	width: 50vw;
	min-height: 3.5vw;
	text-align: center;
	z-index: 100;
}
footer#subfoot{
	position: relative;
	margin: 1vw auto;
	width: 50vw;
	min-height: 3.5vw;
	text-align: center;
	z-index: 100;
}