@import url('https://fonts.googleapis.com/css2?family=Open+Sans:ital,wght@0,300..800;1,300..800&display=swap');
@import url("https://use.typekit.net/oak3jny.css"); /* new-spirit, new-spirit-condensed */ /* --font-family: colt, font-weight: 400, 900 */

/*
.open-sans-<uniquifier> {
  font-family: "Open Sans", sans-serif;
  font-optical-sizing: auto;
  font-weight: <weight>;
  font-style: normal;
  font-variation-settings: "wdth" 100;
}
*/

* {
	box-sizing: border-box;
	-moz-box-sizing: border-box;
	-webkit-box-sizing: border-box;
}

:root {
  interpolate-size: allow-keywords;
}

html {
	padding: 0;
	margin: 0;
	border: 0;
	scroll-behavior: smooth;
	width: 100%;
	min-height: 100vh;
}

body {
	padding: 0;
	margin: 0;
	border: 0;

	width: 100%;
	min-height: 100vh;
	
	background-color: rgba(255,255,255,1.00);
	background-image: url('../images/background-crumpled-paper.webp');
	background-repeat: repeat;
	background-position: center;
	background-size: auto;
	
	color: rgba(50,50,50,1);

	font-family: 'Open Sans';
	font-weight: normal;
	font-size: clamp(75%, 1vw, 100%);	
	line-height: 1.6em;
	
	display: flex;
	flex-direction: column;
	justify-content: flex-start;
}

h1, .h1 {
	margin: 0;
	font-family: 'new-spirit-condensed', serif;
	font-size: 250%;
	line-height: 1em;
	font-weight: 400;
	text-align: left;
	color: rgb(69,41,7);
}

h2, .h2 {
	margin: 0;
	font-family: 'new-spirit-condensed', serif;
	font-size: 175%;
	line-height: 1em;
	font-weight: 600;
}

h1 + h2 {
	margin-bottom: 1em;
}

h1:has(+ h2){
	margin-bottom: 0.15em;
}
h2:has(+ h1) {
	margin-bottom: 0.25em;
}

h3 {
	font-weight: 600;
	font-size: 1.8em;
	color: rgba(251,172,30,1.00);
}

a{
	font-weight: 600;
/*	color: rgba(57,51,89,1.00);*/
	text-decoration: none;
}
a:visited {
 color: inherit;
}
p {
	margin: 1em 0;
	font-size: 1em;
	line-height: 1.5em;
	font-weight: 400;
	color: rgba(10,7,0,1.00);
}

img, svg {vertical-align: top;}

section {
	position: relative;
	z-index: 1;
}

input,
textarea,
select,
button{
	appearance: none;
}

svg image{
	width: 100%;
	height: auto;
}

.tbl{display: table}
.tr{display: table-row}
.td{display: table-cell; vertical-align: top;}

ul {
	width: content;
	text-align: left;
	margin: 1em auto;
}


/* --------------------------- SITE HEADER ------------------------------ */

header{
	width: 100%;
	position: fixed;
	top: 0;
	z-index: 10;
	font-size: clamp(71%, 1vw, 100%);
}
header.inner-header{
	position: sticky;
	flex: 0 0 auto;
}

.hero-grid{
	display: grid;
	grid-template-rows: 1fr auto;
	grid-template-columns: 1fr;
	height: 100svh;
}
.hero-grid .btn-link{
	margin: 0 auto;
}
.home-hero-container{
	height: 100%;
}
.home-hero {
	width: 100%;
	height: 145%;
	background-image:url('../images/hero-background.webp');
	background-size: cover;
	background-position: top center;
	filter: brightness(0.5);
}

.title-container {
	display: grid;
	grid-template-rows: 1fr;
	grid-template-columns: 62fr 38fr;
	height: 100%;
}
.title-container .title {
	display: flex;
	align-items: center;
	justify-content: center;
	flex-direction: column;
	gap: 0;
	filter: drop-shadow(0 20pt 20pt black) drop-shadow(0 5pt 5pt black);
}
.title-container .group-name {
	font-family: new-spirit-condensed;
	font-size: 450%;
	line-height: 1.2em;
	color: white;
	font-weight: 700;
}
.title-container .mission {
	font-size: clamp(11px, 1.5cqw, 20.8px);
	color: white;
	margin-top: 1em;
	text-align: center;
}
.title-container .title-image{
/*
	background-image: url('../images/Estudillo, Jose Antonio.webp');
	background-position: top 40px left;
	background-size: 80% auto;
	background-repeat: no-repeat;
*/
	position: relative;
	filter: drop-shadow(0 15pt 15pt black);
}
.title-container .title-image img {
	position: absolute;
	top: 0;
	left: 50%;
	transform: translateX(-50%);
	width: 60%;
	height: 100%;
	object-fit: cover;
	object-position: center 40px;
}
.title-container .title-flourish {
	width: min(85%, 45em);
	margin-top: 1.5em;
}
.title-container .title-logo {
	display: block;
	width: 50em;
	max-width: 90%;
	margin: 1.2em auto;
}
.title-container .TVHS-logo {
	font-size: clamp(6px, 0.9cqw, 15px);
}
nav {
	background-color: transparent;
	position: relative;
	transition: all 0.5s;
	width: 100%;
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 0;
	padding: 5px 2em 5px 2em;
}
nav div{
	transition: inherit;
}
nav > div:nth-of-type(1){
	padding-right: 0;
}
nav div.logo-text {
	font-family: new-spirit-condensed;
	text-align: center;
	line-height: 1em;
	font-size: 0em;
	font-weight: 600;
	opacity: 0;
}
nav ul{
	flex: 1 1 0;
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 1em;
	list-style-type: none;
	padding: 0;
	margin: 0;
	font-size: 1.35em;
}
nav ul li{
	position: relative;
	color: white;
	padding: 5px;
}
li.pub-links li{
	padding: 1px!important;
}
nav a {
	display: flex;
	align-items: center;
	text-decoration: none;
	padding: 0 0.5em;
	height: 2.5em;
	color: rgba(255,255,255,1.00);
	font-weight: 500;
	letter-spacing: 0.05em;
	line-height: 1.2em;
	border-radius: 5px;
	filter: drop-shadow(0 0 20px rgba(0,0,0,1)) drop-shadow(0 0 5px rgba(0,0,0,1));
	box-shadow: 0 0 20px transparent;
	transition: inherit;
/*	white-space: nowrap;*/
	border: 1px solid transparent;
	scroll-margin-top: 1500px;
	text-align: center;
	}
nav a:hover,
nav a:target,
nav a:has(+ ul > li > a:target){
	background-color: rgba(255,255,255,0.2);
	filter: drop-shadow(0 0 20px rgba(0,0,0,0)) drop-shadow(0 0 5px rgba(0,0,0,0));	
	box-shadow: 0 0 20px rgba(0,0,0,0.5);
	border: 1px solid transparent;
	outline: none;
}
nav ul ul {
	background-color: rgba(0,0,0,0.85);
	position: absolute;
	top: 100%;
	left: 50%;
	transform: translateX(-50%);
	display: flex;
	flex-direction: column;
	align-items: stretch;
	justify-content: space-between;
	text-align: center;
	white-space: nowrap;
	border-radius: 5px;
	padding: 0 1em;
	gap: 0;
	overflow: clip;
	height: 0;
	transition: all 0.3s;
	font-size: 80%;
}
nav ul li:hover ul {
	height: auto;
	padding: 1em 1em;
}
nav ul ul a {
	font-weight: 300;
	line-height: 1em;
	padding: 0.7em;
	height: 1em;
	border: 1px solid transparent;
}
nav li > div {
	border-bottom: 1px solid white;
	text-align: left;
}
nav li:not(:has(a)) {
	font-weight: 700;
	padding: 0.1em 0 0.4em 0;
	color: white;
}
nav .TVHS-logo{
	font-size: 0;
	opacity: 0;
	transition: all 0.25s ease-out!important;
	img {
		transition: inherit;
	}
}

nav.standard{
	background-color: rgba(223,198,168,1);
	background-color: black;
	border-bottom: 1px solid rgba(100,100,100,1);
	color: white;
/*	filter: drop-shadow(0 0 20px black);*/
}
nav.standard a{
	filter: none;
}
nav.standard a:hover,
nav.standard a:target,
nav.standard a:has(+ ul > li > a:target){
	box-shadow: 0 0 20px transparent;
	background-color: transparent;	
	border: 1px solid rgba(223, 193, 168,1);
	outline: none;
}
nav.standard > div:nth-of-type(1){
	padding-right: 40px;
}

nav.standard div.logo-text {
	font-size: 1.4em;
	opacity: 1;
}
nav.standard .TVHS-logo{
	font-size: 3px;
	opacity: 1;
	margin: 5px 0;
}



#navcontrol {
	position: fixed;
	top: 0;
	left: -10000px;
}
.mobile-nav-banner{
	display: none;
}
.mobile-logo-container {
	display: none;
}
#header-logo {
	width: 40em;
	max-width: 100%;
	filter: drop-shadow(0 0 30px white);
}

.social-container > a {
	position: relative;
	display: flex;
	align-items: center;
	justify-content: center;
	width: 2.5em;
	height: 2.5em;
	z-index: 1;
	padding: 5px;
	margin: 3px 7px;
	border-radius: 5px;
	background-color: rgba(251,172,30,1.00);
}
.social-container img {
	max-height: 100%;
	max-width: 100%;
	filter: grayscale(1) brightness(1.8);
}


/* --------------------------- SITE FOOTER ------------------------------- */

.footer-contact {
	color: white;
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 2em;
	flex-wrap: wrap;
	padding: 1em 2em;
}
.footer-contact * {
	position: relative;
	z-index: 2;
}
.footer-contact > div {
	flex: 0 1 auto;
}
.footer-contact .address {
	font-size: 120%;
	line-height: 1.2em;
}
.footer-contact .logo {
	text-align: center;
	font-size: 9px;
}
.footer-contact .logo img {
	width: 350px;
	max-width: 100%;
/*	filter: drop-shadow(0 0 20px black) drop-shadow(0 0 50px black);*/
}
.subfooter {
	background-color: black;
	color: white;
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 2em;
	font-size: 80%;
	line-height: 1.3em;
	padding: 1em;
	flex-wrap: wrap;
}
.subfooter > div {
	flex: 0 1 80em;
	max-width: 100%;
}
.subfooter > div:first-of-type{
	flex: 0 0 auto;
}
.subfooter > div:last-of-type {
	text-align: right;
	flex: 0 0 auto;
}
.subfooter a {
	color: rgb(127,121,155);
}

/* -------------------------- DEFAULT PAGE STYLES ------------------------ */

.highlight {
	background-color: yellow;
	font-weight: bold;
}
.not-clickable {
	pointer-events: none;
}
.TVHS-logo {
	position: relative;
	color: white;
	line-height: normal;
	font-size: min(1.1cqw, 7px);	
}
.TVHS-logo img {
	width: 17.7em!important;
	display: block;
	position: relative;
	left: 20.3em!important;
	margin-bottom: 2.3em!important;
	opacity: 1;
}
.TVHS-logo .big-text{
	font-family: colt;
	font-weight: 700;
	text-align: center;
	font-size: 4em!important;
	line-height: 1em!important;
	transform-origin: center;
	transform: scale(0.94,1.4);
	margin-bottom: 0.32em!important;
}
.TVHS-logo .small-text{
	font-family: colt;
	font-weight: 400;
	text-align: center;
	font-size: 2.17em!important;
	transform-origin: center;
	transform: scale(1,1.7);
	letter-spacing: 0.1em!important;
}

a.action {
	position: absolute;
	opacity: 0;
}

.article-container a{
	color: inherit;
	text-decoration: underline;
}
.btn-link{
	display: block;
	margin: 1em auto;
	color: white;
	background-color: rgba(22,51,66,1);
	padding: 5px 1em;
	text-decoration: none;
	border: none;
	border-radius: 3px;
	font-size: 1.2em;
	width: fit-content;
}
.btn-link:visited{
	color: white;
}
.text-link {
	display: block;
	text-align: right;
	margin: 0;
	line-height: 2em;
}

section {
	position: relative;
	width: 100%;
}

.columns {
	display: flex;
	align-items: stretch;
	justify-content: space-between;
	gap: 0;
	flex-wrap: wrap;
	min-height: calc(100svh - 100px); 
}
.columns .column-image {
	flex: 1 1 500px;
	position: relative;
	background-size: cover;
	background-position: center;
	background-color: rgba(238,236,223,1.00);
	aspect-ratio: 1.75;
	max-width: 100%;
}
.columns .column-image img,
.columns .column-image iframe{
	position: absolute;
	width: 100%;
	height: 100%;
	object-fit: cover;
	object-position: center;
}
.columns .column-text {
	flex: 1 1 500px;
	padding: clamp(3em, 6vw, 5em) 3em;
	display: flex;
	flex-direction: column;
	justify-content: center;
	position: relative;
	z-index: 1;
	background-image: url('../images/background-crumpled-paper.webp');
	background-repeat: repeat;
	background-position: center;
	background-size: auto;
/*	background-blend-mode: color-burn;*/
}
.columns .column-text * {
	position: relative;
	z-index: 2;
}
/*
.columns .column-text:before {
	content: "";
	display: block;
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background-image: url('../images/mudwagon-sihouette-white.webp');
	background-repeat: no-repeat;
	background-position: bottom 1em right 1em;
	background-size: 33% auto;
	filter: drop-shadow(0 0 4em rgba(40,40,0,0.5));
	opacity: 0.8;
	z-index: 1;
	mix-blend-mode: multiply;
}
*/
.columns .column-text p:first-of-type:first-line,
.full-width-column p:first-of-type:first-line {
	font-weight: bold;
}
.columns .column-text p:first-of-type:first-letter,
.full-width-column p:first-of-type:first-letter {
	font-family: new-spirit, serif;
	font-size: 3em;
	line-height: 1em;
	display: block;
	vertical-align: baseline;
	padding-right: 0.03em;
}
.columns .column-text strong {
	font-size: 1.1em;
	line-height: 0.9em;
}

.columns.thirds .column-image {
	flex: 1 1 400px;
}
.columns.thirds .column-text {
	flex: 2 1 600px;
}


section {
}
section:has(.blue-gradient) {
	background-image: linear-gradient(180deg, rgba(127, 121, 200, 0.4), white 70%);
}
.full-width-column {
	min-height: 700px;
	padding: 5em 2em;
	max-width: 1600px;
	width: 100%;
	margin: 0 auto;
}
.full-width-column h2,
.full-width-column h1{
/*	text-align: center;*/
}
.full-width-column > img {
	width: 100%;
	max-width: 1000px;
	margin: 2em auto;
	filter: drop-shadow(0 0 3em rgba(0,0,0,0.2));
	display: block;
}
.full-width-column hr {
	width: 100%;
/*	max-width: 1000px;*/
	margin: 2em auto;
}
.full-width-column img.right {
	float: right;
	margin: 0 0 1em 2em;
	width: 60%;
	max-width: 600px;
}
.full-width-column .vail-container{
	display: flex;
	align-items: stretch;
	justify-content: center;
	gap: 2em;
}
.full-width-column .vail-container.left{
	float: left;
	width: 50%;
	max-width: 1000px;
	margin: 0 2em 1em 0;
}
.full-width-column .vail-container figure {
	flex: 1 1 250px;
	height: auto;
	display: table;
	margin: 0;
	background-color: rgba(238,236,223,1.00);
	filter: drop-shadow(0 0 3em rgba(0,0,0,0.2));
}
.full-width-column .vail-container figcaption {
	caption-side: bottom;
	line-height: 1.3em;
	font-weight: bold;
	padding: 0.5em;
}
.full-width-column .vail-container img {
	width: 100%;
	height: auto;
}

.divider {
	width: 100%;
	display: flex;
	align-items: stretch;
	position: relative;
	border-style: solid;
	border-width: 1px 0;
}
.divider:before{
	content: "";
	display: block;
	position: absolute;
	z-index: 1;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background-position: center;
	background-blend-mode: color-dodge;
}
.divider .image {
	z-index: 2;
	mix-blend-mode: luminosity;
	flex: 1 1 0;
	position: relative;
}
.divider .image img {
	position: absolute;
	left: 0;
	top: 0;
	width: 100%;
	height: 100%;
	object-fit: cover;
}
.divider .text {
	z-index: 2;
	color: white;
	text-align: center;
	flex: 2 1 0;
	font-size: clamp(100%, 3vw, 120%);
	font-weight: 400;
	filter: drop-shadow(0 0 5px black);
	padding:1em;
}
.divider .text > div:not(.location-info) {
	color: rgb(223,198,168);
}


.divider .location-info{
	padding: 1em;
}
.divider .tvhs {
	font-family: new-spirit-condensed, serif;
	font-size: 140%;
	font-weight: 700;
	line-height: 1em;
	padding: 0;
}
.divider .store {
	font-family: new-spirit, serif;
	font-size: 280%;
	font-weight: 900;
	line-height: 1.2em;
	padding: 0;
}
.divider .address {
	font-family: new-spirit, serif;
	font-size: 100%;
	font-weight: 500;
	line-height: 1em;
	padding: 0;
}
.divider .location-info {
	font-size: 90%;
	line-height: 1.2em;
}
.divider .features {
	font-size: 115%;
	font-family: new-spirit;
	line-height: 1.6em;
}

.divider.right-pic .image img{
	mask-image: linear-gradient(90deg, rgba(0,0,0,0), rgba(0,0,0,1) 40%);
}
.divider.left-pic .image img{
	mask-image: linear-gradient(90deg, rgba(0,0,0,1) 70%, rgba(0,0,0,0));
}


.brown {
	background-image: linear-gradient(90deg, rgba(191, 149, 112, 1), rgba(25,25,0, 1));
	border-color: rgba(69, 41, 7, 1);
}
.brown:before{
	background-image: url('../images/tooled-leather-pattern-brown.webp');
	background-size: auto 200%;
	mix-blend-mode: multiply;
	opacity: 0.4;
}
/*
.brown + section .column-text{
	background-image: linear-gradient(0, rgba(109, 130, 142, 0.6), rgba(235,235,235,1) 75%);
}
*/

.black {
	background-image: linear-gradient(90deg, rgba(50,50,50, 1), rgba(0,0,0, 1));
	border-color: rgba(0,0,0, 1);	
}
.black:before{
	background-image: url('../images/tooled-leather-black-2.webp');
	background-size: auto 150%;
	mix-blend-mode: multiply;
	opacity: 0.6;
}
/*
.black + section .column-text {
	background-image: linear-gradient(0deg, rgb(127, 127, 155, 0.5),  rgba(240,240,240,1)  75%);
}
*/


hr {
	margin: 2em 0;
}
hr.narrow {
	margin: 0;
	height: 1px;
	background-color: rgba(150,150,150,1);
	border: none;
}
hr.fancy {
	border: none;
	background-color: transparent;
	background-image: url('../images/flourish-horizontal.svg');
	background-size: 100% auto;
	background-position: center;
	background-repeat: no-repeat;
	height: 10px;
	margin: 1em auto;
	
}

.overlay {
	transition: all 1s;
}

.image-board-container {
	display: flex;
	align-items: flex-start;
	justify-content: space-between;
	gap: 2em;
	flex-wrap: wrap;
	text-align: center;
}
.image-board-container figure {
		flex: 1 1 450px;
		margin: 0;
		padding: 0;
		display: table;
	}
.image-board-container figcaption {
		font-weight: bold;
		text-align: center;
		display: table-caption;
		caption-side: bottom;
	}
.image-board-container img {
		width: 100%;
		height: auto;
		max-width: 650px;
}


.small-text {
	font-size: 70%;
}
.large-text {
	font-size: 130%;
}
.simple-text-divider {
	display: block;
	width: 90%!important;
	max-width: 600px!important;
	filter: brightness(0)!important;
	padding: 2em 0;
	margin: 0 auto!important;
	clear: both;
}

/* --------------------------- HOME PAGE ----------------------------- */

a.nav-activate {
	top: 20%;
}
a.reveal-overlay{
	top: calc(50% + (100svh / 2));
}
.home-welcome * {
	position: relative;
}
/*
.home-welcome .column-text:before {
	content: "";
	display: block;
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background-image: url("../images/mudwagon-sihouette-white.webp");
	background-position: center 125%;
	background-size: 130% auto;
	background-repeat: no-repeat;
	opacity: 0.3;
}
*/
.home-welcome .column-text p {
	font-size: 140%;
	margin: 1em 0 0 0;
	line-height: 1.5em;
}
.home-welcome .column-image{
	background-image: url("../images/wolf-store-vintage.webp");
}


.column-text.events{
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	font-size: 90%;
	overflow: hidden;
}
.column-text.events * {
	position: relative;
}
.column-text.events h1 {
	margin-bottom: 0.5em;
}

/* MembershipWorks override styles on home page */

.column-text.events #SFctr{
	margin-top: 0em;
}
.column-text.events #SFctr #SFevtinfmnu {
		display: none;
}
.column-text.events #SFctr #SFevtlst .SFevtimg,
.column-text.events #SFctr #SFevtlsttop {
	display: none;
}
.column-text.events #SFctr #SFevtinfttl {
	margin-top: 0.5em!important;
}
.column-text.events #SFctr #SFevtinfimg {
	max-height: 300px;
	display: block;
	margin: 0 auto;
}
.column-text.events #SFctr #SFevtpaybtn {
	max-height: 300px;
	display: block;
	width: fit-content;
	margin: 1em auto;
}
.column-text.events #SFctr #SFevtlst {
	border-bottom: var(--SF-border-light);
}
.column-text.events #SFctr #SFevtlst a.SFevt {
	padding: 1em 0 0 0;
}
.column-text.events #SFctr #SFevtlst #SFevtlstbtm {
	display: none;
}
.column-text.events #SFctr #SFevtlst a.SFevt:nth-of-type(n + 6) {
	display: none;	
}
.column-text.events #SFctr #SFevtlst a.SFevt:hover{
	background-color: rgba(0,0,0,0.1);
}
.column-text.events .spcl-evt-link {
	position: absolute;
	left: 0;
	bottom: 0;
	width: 100%;
	text-align: center;
	padding: 0.5em;
	font-size: 140%;
	color: white;
	background-color: black;
}

.mem-info-container #SFctr #SFevtcal .SFevtcal, 
.mem-info-container #SFctr[data-evi] #SFevtcal .SFevtcal {
	padding-bottom: 10%!important;
}
.mem-info-container #SFctr #SFevtcal .SFevtcal.SFevtcaltop{
	padding-bottom: 1em!important;
}
.mem-info-container #SFctr #SFevtinfimg {
	max-height: 300px;
	max-width: 300px;
	margin: 0 1em 1em 0;
	float: left;
}
.mem-info-container #SSevtinftop{
	margin-top: 0!important;
}
.mem-info-container #SFctr #SFevtinfimg~#SFevtinfttl.SFevtcol3{
	margin-top: 1em!important;
}
.mem-info-container #SFctr #SFevtinf {
	overflow: hidden;
}
.mem-info-container #SFctr #SFevtinfmap {
/*	float: left;*/
	overflow: hidden;
}
.mem-info-container #SFctr #SFevtinfbtm {
	clear: both;
}

/*
.column-text.events:before{
	content: "";
	display: block;
	position: absolute;
	width: 100%;
	height: 100%;
	top: 34%;
	left: 25%;
	background-image: url('../images/vail-tank-silhouette-white.webp');
	background-repeat: no-repeat;
	background-size: auto 100%;
	background-position: center;
	mix-blend-mode: luminosity;
	opacity: 0.5;
}
*/
.event-container {
	position: relative;
	width: calc(100% - 4em);
	margin: 1em auto;
	background-color: rgba(238,236,223,1.00);
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 0;
	
}
.event-date-container {
	background-color: white;
	text-align: center;
	padding: 10px;
	border-radius: 5px;
	margin: 1em;
	min-width: 11em;
}
.event-day{
	font-weight: 700;
	line-height: 1.8em;
}
.event-date{
	font-family: new-spirit;
	color: rgb(24,27,72);
	font-size: 4em;
	font-weight: bold;
	line-height: 0.8em;
}
.event-month{
	font-weight: 900;
	line-height: 1em;
	font-size: 120%;
}
.event-desc-container {
	flex: 1 1 0;
	padding: 1em 1em 1em 0;
}
.event-headline {
	line-height: 1em;
	font-size: 150%;
	font-weight: 700;
	margin-bottom: 0.5em;
	color: rgb(22,51,66);
}
.event-description {
	font-weight: 500;
	line-height: 1.2em;
}

.meetings * {
	position: relative;
}
.meetings p{
	font-size: 1em!important;
	margin-bottom: 1em!important;
}

/*
.meetings .column-text:before {
	content: "";
	display: block;
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background-image: url("../images/windmill-silhouette-white.webp");
	background-position: -200% -40%;
	background-size:  90% auto;
	background-repeat: no-repeat;
	opacity: 0.3;
}
*/

.nlsignup-form-container{
	display: flex;
	align-items: stretch;
	justify-content: center;
	column-gap: 0;
	margin: 0 auto;
	filter: drop-shadow(0 0 3em rgba(0, 0, 0, 0.2));
}
.nlsignup-form-container > div,
.nlsignup-form-container > form {
	flex: 0 1 350px;
	position: relative;
}
.signup-image {
	
}
.signup-image img {
	width: 100%;
	max-width: 350px;
	height: auto;
}
.signup-image > div {
	position: absolute;
	bottom: 0.2em;
	left: 0;
	width: 100%;
	font-family: new-spirit-condensed;
	color: white;
	font-size: 3em;
	font-weight: 900;
	filter: drop-shadow(0 0 20px black) drop-shadow(0 0 20px black);
	text-align: center;
	line-height: 1.1em;
}
.signup-form {
	padding: 1em;
	background-color: white;
	margin: 0!important;
	display: flex!important;
	flex-direction: column;
	justify-content: center;
}
.signup-form input[type='submit'] {
	margin-bottom: 0!important;
}
.signup-review {
	display:none;
}

/* --------------------------- GENERAL INFO PAGE ------------------- */

.table-Officer{
	margin: 1em auto;
	display: inline-table;
	background-color: white;
	padding: 1em;
	filter: drop-shadow(0 0 2em rgba(0,0,0,0.1));
}
.table-Officer .head td {
	margin: 0;
	font-family: 'new-spirit-condensed', serif;
	font-size: 250%;
	line-height: 1em;
	font-weight: 400;
	text-align: center;
	color: rgb(69,41,7);
	position: relative;
}
.table-Officer .head td:after {
	content: '';
	display: block;
	height: 5px;
	background-image: url('../images/flourish-black.svg');
	background-position: center;
	background-size: contain;
	background-repeat: no-repeat;
	margin: 0.5em;
}
.table-Officer td:first-of-type {
	font-weight: 700;
}
.table-Officer td:last-of-type {
	text-align: right;
}
.table-Officer tbody {
	font-size: 120%;
}

.table-Director {
	display: block;
	margin: 1em auto;
	background-color: white;
	padding: 1em;
	width: 100%;
	max-width: 1000px;
	filter: drop-shadow(0 0 2em rgba(0,0,0,0.1));
}
.table-Director thead, .table-Director thead tr{
	display: block;
}
.table-Director .head td:after {
	content: '';
	display: block;
	height: 5px;
	background-image: url('../images/flourish-black.svg');
	background-position: center;
	background-size: contain;
	background-repeat: no-repeat;
	margin: 0.5em;
}

.table-Director thead tr td{
	display: block;
	margin: 0;
	font-family: 'new-spirit-condensed', serif;
	font-size: 175%;
	line-height: 1em;
	font-weight: 600;
	text-align: center;
}
.table-Director tbody {
	display: flex;
	flex-wrap: wrap;
	gap: 1em 2em;
	align-items: center;
	justify-content: center;
}
.table-Director tbody tr {
	display: contents;
}
.table-Director tbody td:empty {
	display: none;
}
.table-Director td {
	display: block;
	white-space: nowrap;
	font-size: 110%;
	font-weight: 600;
}
.table-Director tbody td:before{
	content: '\2022';
	font-size: 150%;
	display: inline-block;
	padding-right: 0.3em;
	vertical-align: middle;
}

/* -------------------------- ABOUT PROJECTS PAGE ----------------- */

.about-projects.full-width-column {
	display: flex;
	flex-direction: column;
	justify-content: center;
}
.about-projects .mission {
	font-size: 130%;
	margin: 2em;
	line-height: normal;
}

.flex-container {
	display: flex;
	align-items: stretch;
	justify-content: space-between;
	flex-wrap: wrap;
	gap: 2em;
	padding: 3em;
	max-width: 1400px;
	margin: 0 auto;
}
.flex-container .text{
	flex: 1 1 0;
	min-width: 370px;
	padding: 2em;
	display: flex;
	flex-direction: column;
	justify-content: center;
}
.flex-container .image {
	flex: 0 1 0;
	align-self: stretch;
	margin: 0 auto;
}
.flex-container .image img {
/*	height: 100%;*/
	object-fit: cover;
	max-width: 100vw;
}

.flex-container.wrapped .text {
	order: 2;
}
.flex-container.wrapped .image {
	padding-top: 2em;
}

.notable-container, .notable-container *{
	text-align: center;
	width: 100%;
	max-width: 800px;
	margin: 0 auto;
}
.notable-description{
	font-size: 1.2em;
	font-weight: 400;
	width: 100%;
}

/* ------------------------- LITTLE HISTORY MUSEUM ----------------- */

.museum-map {
	width: 100%;
	max-width: 1000px;
	aspect-ratio: 2.5;
	min-height: 300px;
	margin: 2em auto;
	filter: drop-shadow(0 0 3em rgba(0, 0, 0, 0.2));
	border: none;
	display: block;
}


/* ------------------------ MEMBERSHIP PAGES ----------------------- */

.mem-container {
    min-height: 700px;
    width: 100%;
    margin: 0 auto;
	display: flex;
	align-items: stretch;
	flex-wrap: wrap;
}
.mem-info-container {
	flex: 2 1 450px;
	padding: 5em 2em;
}
.mem-info-container > img {
    width: 100%;
    max-width: 1000px;
    margin: 2em auto;
    filter: drop-shadow(0 0 3em rgba(0, 0, 0, 0.2));
    display: block;
}
.mem-reg-container {
	flex: 1 1 225px;
	padding: 0 2em;
	min-width: 33.33%;
	background-color: white;
}
.mem-reg-container .divider {
	margin: 0 -2em;
	width: calc(100% + 4em);
}
.mem-reg-container h1{
	text-align: center;
	color: white;
}
.mem-reg-container h2 {
	margin-bottom: 0.5em!important;
}

/* ---------------------- RESOURCE DIRECTORY ------------------------- */

.links-container{
	display: flex;
	align-items: flex-start;
	justify-content: space-between;
	gap: 2em;
	margin-top: 2em;
}
.links-container hr {
	margin: 1em 0;
}
.link-column {
	flex: 1 1 auto; 
}
.link a{
	padding: 0.2em 0.5em;
	color: rgba(98,74,44,1.00);
	background-color: transparent;
	transition: all 0.5s;
}
.link a:hover {
	color: white;
	background-color: rgba(98,74,44,1.00);
}

/* ------------------------- HISTORY PAGES ------------------------- */

.history-grid {
	display: grid;
	grid-template-rows: 1fr;
	grid-template-columns: 20em 1fr;
	width: 100%;
	flex: 1 1 auto;
}
.history-grid .toc-column {
	grid-row: 1;
	grid-column: 1; 
	margin: 0;
	border: 2px solid black;
	border-width: 0 1px 0 0;
	background-color: white;
	background-image: linear-gradient(30deg, rgba(100,100,50,0.2), rgba(255,255,255,0.4));
}	
.history-grid .toc-column>div {
	position: sticky;
	top: 5em;
	padding-bottom: 3em;
}
.toc-column .all-black * {
	color: black!important;
}
.toc-column a{
	display: block;
	position: relative;
	transition: all 0.5s;
}
a.selected-cat::before{
	content: '\2794';
	font-weight: 900;
	font-size: 105%;
	position: absolute;
	right: calc(100% + 3px);
	color: rgba(150,117,88,1.00)!important;
}
.toc-column a:hover {
	background-color: rgba(69,41,7,0.1);
}
.toc-column a.selected::before {
	content: '\2794';
	font-weight: 900;
	font-size: 105%;
	position: absolute;
	left: 1.8em;
	color: rgba(150,117,88,1.00)!important;
}
.toc-header-container{
	padding: 2em 1em 1em 1em;
	color: white!important;
	position: relative;
}
.toc-header-container * {
	position: relative;
	z-index: 2;
}
.toc-header-container:before {
    content: "";
    display: block;
    position: absolute;
    z-index: 1;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-position: center;
    background-blend-mode: color-dodge;
}
.toc-header{
	display: block;
	font-family: new-spirit-condensed;
	text-align: center;
	font-size: 2em;
	font-weight: 800;
	color: white!important;
	position: relative;
}
.toc-cat-header{
	display: block;
	font-family: new-spirit-condensed;
	font-size: 1.5em;
	font-weight: 600;
	display: flex;
	align-items: baseline;
	padding: 0.5em 1.2em;
}
a.item-link {
	padding-left: 3.5em;
	padding-right: 1em;
	text-indent: -1em;
}
.toc-cat-header::after{
	content: '';
	margin-left: 0.25em;
	overflow: hidden;
	flex: 1;
	height: 1em;
	border-bottom: 2px solid black;
}
.history-grid .full-width-column {
	grid-row: 1;
	grid-column: 2;
/*	overflow-y: scroll;*/
	min-height: 0;
}

.categories-container {
	display: flex;
	align-items: stretch;
	justify-content: space-between;
	gap: 2em;
	flex-wrap: wrap;
}

div.cat-card {
	position: relative;
	width: clamp(200px, 50vw, 300px);
	background-color: white;
	border: 1em solid white;
	filter: drop-shadow(0 0 2em rgba(0,0,0,0.3));
	margin: 0 auto;
	container-type: inline-size;
}
div.cat-card .image img{
	width: 100%;
	height: auto;
}
div.cat-card .caption{
	width: 100%;
	padding: 1em 0 0 0;
	font-size: 90%;
}
div.cat-card .caption a{
	display: block;
	text-align: left;
	color: inherit;
	line-height: 1.2em;
}
div.cat-card .category-name{
	font-family: new-spirit;
	font-weight: bold;
	position: absolute;
	top: 0.5em;
	left: 0;
	width: 100%;
	text-align: center;
	font-size: 16cqw;
	color:white;
	filter: drop-shadow(0 0 0.5em rgba(0,0,0,1));
	pointer-events: none;
}

.article-info-container {
	width: 100%;
	text-align: left;
	border: 1px solid rgb(175,175,175);
	border-width: 1p;
	margin: 2em 0;
	background-color: white;
	filter: drop-shadow(0 0 3em rgba(0,0,0,0.2));
	border-collapse: collapse;
}
.article-info-container tr:nth-of-type(odd) {
	background-color: rgb(230,230,230);
}
.article-info-container td {
	vertical-align: middle;
	padding: 0.5em;
	text-align: center;
	min-width: 150px;
}
.article-info-container td:nth-of-type(4n + 2) {
	text-align: left;
	width: 100%;
}
.article-info-container img{
	max-height: 75px;
}
.article-info-container .header{
	font-weight: bold;
	font-size: 120%;
	background-color: rgb(69,41,7)!important;
	color: white;
}
.article-info-container .title {
	display: flex;
	align-items: center;
}
.article-info-container .title img {
	float: left;
	margin-right: 0.5em;
}

.articles-index-container {
	display: flex;
	align-items: stretch;
	justify-content: space-between;
	gap: 1em;
	flex-wrap: wrap;
}
.articles-index-container figure {
	margin: 0 auto;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: space-between;
	flex: 0 1 250px;
	background-color: white;
	border: 0.7em solid white;
	filter: drop-shadow(0 0 2em rgba(0, 0, 0, 0.3));
}
.articles-index-container figure > div {
	flex: 1 1 0;
	display: flex;
	align-items: center;
	background-color: rgba(0,0,0,0.1);
	background-image: linear-gradient(30deg, rgba(0,0,0,0.2), white);
	width: 100%;
	border: 1px solid rgb(220,220,220);
	text-align: center;
}
.articles-index-container figure > div > a{
	display: block;
	width: 100%;
	color: rgba(68,41,7,1.00);
}
.articles-index-container figure > figcaption {
	font-family: new-spirit;
	font-size: 1.2em;
	flex: 0 1 0;
	text-align: center;
	padding-bottom: 0.5em;
}
.articles-index-container figure > figcaption > a {
	color: rgb(68,41,7);
}
.articles-index-container figure > figcaption > a:visited{
	color: rgba(217,214,210,1.00)!important;
}
.articles-index-container figure img{
	width: 100%;
}
.articles-index-container .nophoto {
	width: 120px;
	margin: auto;
}


.article-container {
	text-align: left;
	max-width: 100%;
	width: 1500px;
	padding: 2em min(5vw, 4em);
	background-color: white;
	margin: 0 auto;
	overflow: hidden;
	border-radius: 7px;
	filter: drop-shadow(0 0 5em rgba(0,0,0,0.2));
	margin: -3em 0;
}
.article-container > div,
.article-container > blockquote > div{
	margin: 1em 0;
}
.article-container h1{
	width: 100%;
	text-align: center;
	margin: 0 auto 0.8em auto;
}
.article-container h1:has(+ h2){
	margin-bottom: 0.2em;
}
.article-container h2{
	width: 100%;
	text-align: center;
	margin: 0 auto 1em auto;
}
.article-container .a {
	float: none;
	display: block;
	margin: 2em auto;
	text-align: center;
}
.article-container .l {
	float: left;
	margin: 0 2em 1em 0;
}
.article-container .l img {
	width: auto;
	height: auto;
	max-width: min(500px, 50vw);
	max-height: 60lvh;
}
.article-container .r {
	float: right;
	clear: right;
	margin: 0 1em 0 2em;
}
.article-container .r img {
	width: auto;
	height: auto;
	max-width: min(500px, 50vw);
	max-height: 60lvh;
}
.article-container .c {
	float: none;
	clear: both;
	margin: 2em auto;
	text-align: center;
}
.article-container .c img {
	width: auto;
	height: auto;
	max-width: min(700px, 100vw);
	max-height: 80lvh;
}
.article-container figure {
	display: table;
}
.article-container figcaption {
	display: table-caption;
	caption-side: bottom;
	font-size: 80%;
	line-height: 1.2em;
	font-style: italic;
	padding: 0.5em;
	text-align: center;
}
.article-container table {
	margin: 1em auto;
}

.article-container div figure.c,
.article-container table figure {
	margin: 0 auto!important;
}
.article-container div:has(>figure) {
	display: flex;
	align-items: flex-start;
	justify-content: center;
	gap: 3em;
	flex-wrap: wrap;
/*	text-align: center;*/
}
.article-container div figure {
	margin: 0;
}
.article-container div figure img {
/*	max-width: 100%;*/
	height: 300px;
}


/* ------------------- INDEX PAGES -------------------------------- */



.index-table {
	border: 1px solid rgba(0,0,0,1);
	width: 100%;
	border-collapse: collapse;
}
.index-header td {
	white-space: nowrap;
	color: white;
	font-weight: 700;
	background-color: black!important;
	font-size: 1.2em;
}
.index-header label {
	cursor: pointer;
}
.index-table tr {
	background-color: white;
}
.index-table tr:nth-of-type(odd) {
	background-color: rgba(240, 240, 240, 1);
}
.index-table tr:not(.index-header,.category-head):hover{
	background-color: rgb(230,230,230);
	position: relative;
	outline: 1px solid black;
}
.index-table .category-head {
	background-color: rgba(200,200,200,1.00)!important;
	font-weight: 600;
}
.index-table .index-row .description {
	font-size: 80%;
	line-height: normal;
	padding: 0.8em;
}
.index-table .index-header td{
	padding: 5px 10px!important;
}
.index-table .index-header form {
	margin: 0;
	padding: 0;
}
.index-table .index-header button {
	border: none;
	background-color: transparent;
	font-family: inherit;
	color: inherit;
	font-size: inherit;
	font-weight: inherit;
	cursor: pointer;
}
.index-table td {
	padding: 2px 10px;
}
.index-table input[type='radio'] {
	display: none;
}
.index-table td.sorted{
	font-weight: 550;
	background-color: rgba(220,220,220,0.5);
}
label.sorted-ASC:after,
.sorted-ASC label:after{
	content: '';
	position: relative;
	display: inline-block;
	width: 10px;
	height: 13px;
	vertical-align: middle;
   background-color: currentColor; 
	-webkit-mask: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 10 12.3'><polygon points='0.6,6.9 9.4,6.9 5,11.9' fill='black'/><path d='M8.7,7.2L5,11.4L1.3,7.2H8.7 M10,6.7H0l5,5.7L10,6.7L10,6.7z' fill='black'/><rect x='2.7' y='0.3' width='4.7' height='6.1' fill='black'/><path d='M7.1,0.6v5.5H2.9V0.6H7.1 M7.6,0H2.4v6.7h5.3V0L7.6,0z' fill='black'/></svg>") no-repeat center / contain;
	mask: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 10 12.3'><polygon points='0.6,6.9 9.4,6.9 5,11.9' fill='black'/><path d='M8.7,7.2L5,11.4L1.3,7.2H8.7 M10,6.7H0l5,5.7L10,6.7L10,6.7z' fill='black'/><rect x='2.7' y='0.3' width='4.7' height='6.1' fill='black'/><path d='M7.1,0.6v5.5H2.9V0.6H7.1 M7.6,0H2.4v6.7h5.3V0L7.6,0z' fill='black'/></svg>") no-repeat center / contain;
}
label.sorted-DESC:after,
.sorted-DESC label:after {
	content: '';
	position: relative;
	display: inline-block;
	width: 10px;
	height: 13px;
	vertical-align: middle;
   background-color: currentColor; 
	-webkit-mask: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 10 12.3'><polygon points='0.6,5.4 5,0.4 9.4,5.4' fill='black'/><path d='M5,0.9l3.7,4.2H1.3L5,0.9 M5,0L0,5.7h10L5,0L5,0z' fill='black'/><rect x='2.7' y='5.9' width='4.7' height='6.1' fill='black'/><path d='M7.1,6.2v5.5H2.9V6.2H7.1 M7.6,5.7H2.4v6.7h5.3V5.7L7.6,5.7z' fill='black'/></svg>") no-repeat center / contain;
	mask: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 10 12.3'><polygon points='0.6,5.4 5,0.4 9.4,5.4' fill='black'/><path d='M5,0.9l3.7,4.2H1.3L5,0.9 M5,0L0,5.7h10L5,0L5,0z' fill='black'/><rect x='2.7' y='5.9' width='4.7' height='6.1' fill='black'/><path d='M7.1,6.2v5.5H2.9V6.2H7.1 M7.6,5.7H2.4v6.7h5.3V5.7L7.6,5.7z' fill='black'/></svg>") no-repeat center / contain;
}

.index-table td:first-of-type {
	background-color: rgba(200,200,200,1);
	font-size: 80%;
	text-align: center;
}




.publications-container {
	display: flex;
	align-items: stretch;
	justify-content: space-between;
	flex-wrap: wrap;
	gap: 2em;
	margin-top: 1em;
}
.pub-container {
	flex: 1 1 450px;
	background-color: rgba(255,255,255,0.6);
	padding: 2em;
	cursor: pointer;
}
.pub-container:hover {
	background-color: rgba(255,255,255,1);
	outline: 3px solid black;
}
.pub-container .date{
	font-size: 120%;
	font-weight: 600;
	order: 0;
	text-align: right;
}
.pub-container .title{
	font-weight: 600;
	line-height: 1.3em;
}
.pub-container .author {
	font-size: 80%;
	padding-left: 2em;
	line-height: 1.3em;
}
.pub-container .subject{
	font-size: 80%;
	line-height: 1.3em;
	padding: 0 0 1em 0;
	padding-left: 2em;
}
.pub-container hr{
	margin: 0.5em 0;;
}
.publications-container .pub-name{
	display: block;
	width: 100%;
}
.pub-articles {
	max-height: 450px;
	overflow-x: auto;
	scrollbar-color: rgba(0,0,0,0.2) transparent;
	scrollbar-width: thin;
	scrollbar-gutter: stable both-edges;
}




.reading-table {
	display: block;
	text-align: center;
}
.reading-table tbody {
	display: flex;
	align-items: stretch;
	justify-content: space-between;
	flex-wrap: wrap;
	gap: 2em;
	margin-top: 1em;
}
.reading-table a {
	font-weight: inherit!important;
}

.reading-table .category-head{
	width: 100%;
	display: block;
	align-items: baseline;
	text-align: center;
}
.reading-table .category-head td{
	display: block;
	flex: 0;
	white-space: nowrap;
	font-size: 1.6em;
	width: 100%;
	text-align: center;
}
.reading-table .divider-cell{
	order: 3;
}
.reading-table .divider-cell hr{
	margin: 1em 0;;
}

.reading-table .reading-row {
	flex: 1 1 425px;
	display: flex;
	flex-direction: column;
	text-align: left;
	position: relative;
	padding: 1em 2em 2em 2em;
	background-color: rgba(255,255,255,0.6);
	filter: drop-shadow(0 0 2em rgba(0, 0, 0, 0.1));
	cursor: pointer;
	max-width: 700px;
	margin-left: auto;
	margin-right: auto;
}
.reading-table .reading-row:hover {
	outline: 3px solid black;
	background-color: rgba(255,255,255,1);
}

.reading-table .author,
.reading-table .title {
	text-align: center;
	padding: 0.2em 0;
	line-height: 100%;
	order: 2;
}
.reading-table .title.sorted{
	order: 1;
	font-weight: 700;
	font-size: 120%;
}
.reading-table .author.sorted{
	order: 1;
	font-weight: 700;
	font-size: 120%;
}

.reading-table .reading-row .description {
	font-size: 80%;
	line-height: normal;
	padding: 0.8em;
	order: 3;
}

.reading-table .row-count {
	position: absolute;
	bottom: 0.2em;
	left: 50%;
	transform: translateX(-50%);
	font-size: 80%;
}
.reading-table .row-count::before{
	content: "(";
}
.reading-table .row-count::after{
	content: ")";
}

.reading-table .cover-image {
	max-width: 200px;
	max-height: 200px;
	width: auto;
	height: auto;
	float: left;
	margin: 0 1em 1em 0;
}
.reading-table .cover-image:only-child {
	float: none;
	display: block;
	margin: 0 auto;
}
.reading-table .index-header td {
	white-space: nowrap;
	color: white;
	font-weight: 700;
	background-color: black!important;
	font-size: 1.2em;
}



.sort-row {
	text-align: center;
	margin-top: 2em;
}
.sort-row input {
	display: none;
}
.sort-row:before {
	content: "Sort By:";
	margin-right: 1em;
	font-weight: bold;
}

.sort-row label {
	padding-left: 0.5em;
	padding-right: 0.5em;
	border-radius: 0.2em;
}
.sort-row label:has(:checked) {
	background-color: rgba(0,0,0,0.2);
}



.row-range {
	text-align: right;
	font-size: 80%;
}
.row-range.top {
	border-bottom: 1px solid black;
	margin-bottom: 1em;
}
.row-range.bottom {
	border-top: 1px solid black;
	margin-top: 3em;
}
.row-range .max-rows {
	margin: 0;
	float: left;
}
.row-range .max-rows select {
	text-align: center;
	border-color: black;
	color: black;
}
.row-range .prevnext-container {
	display: inline-flex;
	gap: 4px;
}
.row-range .prevnext-container div{
	display: inline-flex;
	align-items: center;
	gap: 5px;
	height: 2em;
	pointer-events: none;
}
.row-range [type="radio"]{
	display: none;
}


#searchForm {
	width: calc(100% - 2em);
	background-color: white;
	border: 1px solid rgba(200,200,200,1);
	outline: 1em solid white;
	margin: 1em;
	padding: 1.5em 1em 1em 1em;
	position: relative;
}
.btn-skip{
	border: none;
	background-color: transparent;
	display: inline-block;
	padding: 0;	
	cursor: pointer;
	font-size: 1.2em;
	height: 10px;
	pointer-events: auto;
}
.btn-skip img {
	height: 100%;
	width: auto;
}
#skipForm input[type="radio"],
#searchForm input[type="radio"] {
	display: none;
}
#searchForm button {
	padding: 5px;
	box-sizing: border-box;
  	height: 2em; /* explicitly set the same height */
}
#searchForm .row-range {
	margin-bottom: 2em;
}
.form-title {
	position: absolute;
	background-color: white;
	top: -0.5em;
	line-height: 1em;
	left: 1em;
	padding: 0 0.5em;
	font-size: 1.1em;
	color: rgba(150,150,150,1);
}
.all-input-container {
	display: flex;
	flex-direction: column;
	justify-content: space-between;
	gap: 1em;
	padding-bottom: 1em;
}
.all-input-container > div {
	display: inline-block;
	position: relative;
	flex: 1 1 0;
}
.all-input-container > div > label {
	position: absolute;
	bottom: 100%;
	left: 0;
	font-family: inherit;
	font-size: 80%;
	padding: 0;
	line-height: 1em;
	width: 100%;
}
.all-input-container > div > select,
.all-input-container > div > input,
.all-input-container button {
	font-family: inherit;
	font-size: 90%;
	padding: 3px 5px;
	width: 100%;
	background-color: white;
	border: 1px solid rgb(150,150,150);
  	height: 2em; 
	line-height: 1em;
	border-radius: 3px;
	color: black;
}
.all-input-container button {
	background-color: rgb(200,200,200);
	color: black;
}

#tabletop{
	position: relative;
	top: -7em;
}

/* ---------------------PRIVACY POLICY ---------------------------- */


.privacy{
	font-size: 90%;
	line-height: 1.4em;
}
.privacy h1{
	text-align: left;
	font-size: 2em;
	font-weight: 600;
}.privacy h2{
	font-size: 1.6em;
	text-align: left;
}
.privacy ul{
	max-width: none;
}


/* --------------------------- BGM DEFAULT OVERRIDES ------------------ */

#BGM_contactMap {
	height: 100%;
}
.BGM-gallery-alt2-group-container{
	display: flex;
	align-items: flex-end;
	justify-content: center;
	flex-wrap: wrap;
	gap: 2em;
	overflow: visible!important;
}
.BGM-gallery-alt2-image{
	flex: 0 1 400px;
	aspect-ratio: 1;
	margin: auto;
	position: relative;
	overflow: visible!important;
}
.BGM-gallery-alt2-image::before{
	content: '';
	display: block;
	position: absolute;
	top:  -0.13em;
	left: 50%;
	transform: translateX(-50%);
	width: calc(100% - 5.4em);
	height: 0px;
	border-width: 0 3em 3em 3em;
	border-color: transparent  rgba(255,255,245,0.9);
	border-style: solid;
	z-index: 2;
	padding-bottom: 0!important;
	filter: drop-shadow(0 0 0.2em rgba(0,0,0,0.5));
	border-radius: 0.5em;
}
.BGM-gallery-alt2-image::after{
	content: '';
	display: block;
	position: absolute;
	bottom: -0.13em;
	left: 50%;
	transform: translateX(-50%);
	width: calc(100% - 5.4em);
	height: 0px;
	border-width: 3em 3em 0 3em;
	border-color: transparent rgba(255,255,245,0.9);
	border-style: solid;
	z-index: 2;
	padding-bottom: 0!important;
	filter: drop-shadow(0 0 0.2em rgba(0,0,0,0.5));
	border-radius: 0.5em;
}
.BGM-gallery-alt2-image>div:first-of-type {
	background-position: top center!important;
	background-repeat: no-repeat!important;
}
.BGM-gallery-alt2-image>div:first-of-type:hover{
	transform: translate(-50%, -50%) scale(1)!important;
}
.BGM-gallery-alt2-image>div:first-of-type:hover + figcaption{
	background-color: black;
}
.BGM-editor-codeEnabled * {
	color: white!important;
}
.BGM-gallery-alt2-image>div:first-of-type{
	transition: none;
}
.BGM-parallax2-container {
	min-height: 0!important;
}

/* ---------------------- CONTENT EDITOR OVERRIDES ------------------------- */

#board label:has(select[name="category"] option[value="Director"]:checked) + label {
	display: none;
}

/* ----------------------- MEMBERSHIPWORKS OVERRIDES ------------------ */

#SFctr{
	font-size: inherit!important;
}
#SFctr input[type=file], #SFctr input[type=password], #SFctr input[type=text], #SFctr select {
	width: 100%!important;
}

/* -------------------------- MEDIA QUERIES --------------------------- */


@media screen and (max-aspect-ratio: 1), 
screen and (orientation: portrait),
screen and (max-width: 800px){
	
	.mobile-nav-banner {
		display: flex;
		align-items: center;
		justify-content: space-between;
		position: sticky;
		top: 0;
		background-color: black;
		color: white;
		font-size: 1.2em;
		font-family: new-spirit, serif;
		height: 35px;
		z-index: 11;
		padding: 0 10px;
	}
	.mobile-nav-banner > div {
		flex: 0 0 auto;
	}
	
	.mobile-nav-button{
		width: 25px;
		height: 18px;
		position: relative;
		display: flex;
		flex-direction: column;
		justify-content: space-between;
		cursor: pointer;
		background-image: linear-gradient(0deg, transparent calc(50% - 1px), white calc(50% - 1px), white calc(50% + 1px), transparent calc(50% + 1px));
		pointer-events: all;
		transition: all 0.5s;
	}
	.mobile-nav-button:before {
		content: '';
		display: block;
		border: none;
		width: 100%;
		height: 2px;
		background-color: white;
		transition: all 0.5s;
	}
	.mobile-nav-button:after {
		content: '';
		display: block;
		border: none;
		width: 100%;
		height: 2px;
		background-color: white;
		transition: all 0.5s;
	}
	.mobile-logo-container {
		padding: 2em 0;
		display: block;
	}
	.mobile-logo-container .TVHS-logo {
		font-size: 0.25em;
	}
	
	nav a br{
		display: none;
	}
	nav a div:has(br)::before {
		content: '\00a0';
	}
	nav.standard{
		background-color: transparent;
		filter: none;
	}
	nav.standard a:hover,
	nav.standard a:target,
	nav.standard a:has(+ ul > li > a:target){
		background-color: rgba(255,255,255,0.2);
		border: none;
		}
	
	
	#navcontrol:checked + label + header{
		transform: translateX(0%)
	}
	#navcontrol:checked + label .mobile-nav-button {
		background-image: none;
		pointer-events: none;
	}
	#navcontrol:checked + label .mobile-nav-button:before {
		transform: translateY(8px) rotate(45deg);
		background-color: red;
	}
	#navcontrol:checked + label .mobile-nav-button:after {
		transform: translateY(-8px) rotate(-45deg);
		background-color: red;
	}
	#navcontrol:checked + label + header {
		transform: translateX(0);
	}
	
	header {
		position: fixed!important;
		height: 100dvh;
		width: 210px;
		background-color: rgba(38,38,1,1.00);
		padding-top: 45px;
		filter: drop-shadow(0 0 8px rgba(0,0,0,1));
		transform: translateX(-105%);
		transition: all 0.5s;
		display: flex;
		flex-direction: column;
		align-items: center;
		justify-content: space-between;
	}
	nav {
		filter: none!important;
	}
	nav div:nth-of-type(1) {
		display: none;
	}
	nav ul{
		flex-wrap: wrap;
	}
	nav ul li {
		flex: 1 1 100%;
	}
	nav ul ul {
		left: 100%;
		transform: translateX(0);
	}

	.home-hero-container {
		min-height: 380px!important;
		height: auto;
/*		aspect-ratio: 1.22;*/
		width: 100%;
	}
	.hero-grid{
		height: calc(100svh - 35px);
	}

	.title-container {
		grid-template-columns: 75fr 25fr;
	}
	.title-container .title-image img {
		object-fit: contain;
		object-position: center;
	}
	
	.footer-contact {
		flex-direction: column;
		align-items: center;
		padding: 2em;		
	}
	.footer-contact .logo {
		font-size: clamp(6px, 1vw, 9px);
	}
	.footer-contact .contact {
		text-align: center;
		font-size: 1.5em;
		order: 2;
	}
	.footer-contact h1 {
		display: none;
	}
	.footer-contact .address {
		line-height: 1.2em;
	}
	.subfooter {
		flex-direction: column;
	}
	.subfooter > div {
		text-align: center!important;
	}
	
	.columns {
		flex-direction: column;
	}

	.column-image{
		order: 1;
		aspect-ratio: 1.5;
		min-height: 300px;
		flex: 1 1 auto!important;
		min-height: 66vw;
	}
	.column-text {
		order: 2;
		flex: 1 1 auto!important;
	}
	.nlsignup-form-container {
		flex-direction: column;
		width: 100%;
		max-width: 350px;
	}
	.history-grid .toc-column>div {
		top: 2.9em;
	}
}

@media screen and (max-width: 800px){
	.title-container {
		grid-template-rows: auto 1fr;
		grid-template-columns: 1fr;
	}
	.title-container > div {
		padding: 1em;
	}
}

/* ----------------------------- PRINT STYLES ------------------------------- */


@media print {
	html, body{margin: 0; padding: 0;}
	.noPrint{display: none;}
}
