/* magic style */
@media (max-width: 768px) {html {scroll-padding-top: 2em; /* mobile nav height - helps with anchors */}}
@media (max-width: 768px) {.site-header {border: 10px solid black;}}
@media (max-width: 768px) {.nav-links {flex-direction: column; align-items: center; gap: 0.5em;}}
@media (max-width: 900px) {.services {grid-template-columns: 1fr;}}
@media (max-width: 768px) {.testimonial-container .quote{font-size: 2rem; min-height: unset;}}
@media (max-width: 768px) {.greviews{font-size: .7rem;}}
@media (max-width: 768px) {.keyshot{text-align: center; width: 100%;}}
@media (min-width: 769px) {input[type="submit"], button[type="submit"]
	{background-color: #007aff; color: #fff; border: none; border-radius: .5em; margin: 0em 0em 2em 0em;}}
	
html{overflow-x: visible; scroll-behavior: smooth;}
body {background-color: #000; color: #fff; font-family: Georgia; margin: 0em; padding: 3em 0em 0em 0em; overflow-x: visible; width: 100%;}

a:link {color: #fff;} /* unvisited link */
a:visited {color: #fff;}/* visited link */
a:hover {color: blue;}/* mouse over link */
a:active {color: #fff;}/* selected link */
	
.site-header {margin: 0em 0em 0em 0em; width: 100%;} /* Top navigation bar */
.top-nav {background: #30c4cb; box-shadow: 0 2px 6px rgba(0, 0, 0, 0.12);position: fixed; top: 0; left: 0; width: 100%; z-index: 1000;}

/* Nav list */
.nav-links {list-style: none;margin: 0;padding: 1em 1em;/* controls bar height */ display: flex;gap: 1.5em;justify-content: space-between; align-items: center;}

/* Links */
.nav-links a {text-decoration: underline;color: #fff;font-size: 1.5rem;/* keeps it thin */}

/* Hover/focus */
.nav-links a:hover,
.nav-links a:focus {text-decoration: underline;}
	
#contact{padding: 2em 0em 0em 0em;}
	
ul {list-style-type: none; margin: 1em; padding: 0;}
li{display: inline; line-height: 0em; margin: .2em; padding: 0em;}
	
section{margin: 0em 0em 2em 0em; padding: 0em;}

h1{font-size: 5em; font-weight: bold; line-height: 1.5em; margin: 0em; padding: 0em; text-align:center;} 
h2{font-size: 4em; font-weight: bold; line-height: 1.5em; margin: 0em; padding: 0em; text-align:center; margin: 0em; padding: 0em;} 
h3{margin: 0em; padding: 0em;}

.keyname{display: block; max-width: 100%; height: auto; margin: 1em auto 1em auto;}
	
figure{margin: 0em 0em 6em .5em; text-align: center; width: 100%;}
.keyshot{margin: 0em 0em 4em 0em; text-align: center; width: 100%;}
figcaption{font-size: 2em;}
.portrait{max-width: 100%; height: auto;}
.google{max-width: 100%; height: auto;}
.vimeo{border: 10px solid #30c4cb; display: block; max-width: 100%; height: auto; margin: 0em auto; padding: 0em auto; text-align: center;}
.logos{border: 10px solid #30c4cb; display: block; max-width: 100%; height: auto; margin: 0em auto; padding: 0em auto; text-align: center;}
	
p{border: none; font-size: 2.5em; line-height: 2.5em; text-align: center;}
	
/* services */
.services {border: none; max-width: 1600px; margin: 0 auto; padding: 0rem 5vw 15rem 5vw; display: grid; 
 grid-template-columns: repeat(auto-fit, minmax(300px, 1fr)); gap: 2rem;}
.serviceheader{border: none; font-size: 2.5em; line-height: 1.5em; text-align: center;}
.service {text-align: center;}
.service img {width: 100%; aspect-ratio: 1 / 1; object-fit: cover; border-radius: 24px; display: block; transition: transform 0.3s ease;}
.service h3 {margin-top: 1rem; font-size: 2rem;}
.service:hover img {transform: scale(1.03);}

.testimonial-container {height: 650px; /* set this to the height of your tallest quote */ margin: 0em 0em 3em 0em;
display: flex; align-items: center; /* vertically center the text */
justify-content: center; /* horizontally center text if needed */ text-align: center;}
	
.quote{border: none; font-size: 3em; font-style: italic; width: 100%; max-width: 800px; min-height: 180px; 
line-height: 1.5em; position: relative; overflow: hidden;}

.person{font-size: 1em; line-height: 1.2em; margin: 1em 0em 0em 0em;}
.greviews{margin: 0em 0em 16em 0em;}
	
.gifanimation{display: block; max-width: 100%; height: auto; margin: 0em auto 1em auto; padding: 0em auto; text-align: center;}
.theatershow{display: block; max-width: 100%; height: auto; margin: 0em auto .5em auto; padding: 0em auto; text-align: center;}
	
.denise{font-size: 2em; line-height: 1.5em; margin: 0em 0em 5em 0em;}
.affiliations{margin: 10em 0em 0em 0em; text-align: center;}
.social{margin: 0em; text-align: center;}
.insta{width: 10%; height: 10%;}
	
article {margin: 3em 0em 10em 0em; padding: 0em; width: 100%; text-align: center;}
article p{line-height: 1.5em; margin: 0em auto; padding: 0em auto; width: 80%; text-align: center;}
	
.bookwrap{border: none; margin: 10em 0em 10em 0em; padding: 0em;}
.reactions{font-size: 2em; line-height: 1.5em; margin: 3em 0em 0em 0em;}

.formintro{font-size: 1.5em; line-height: 1em; margin: 0em 0em 1em 0em;}
form{background-color: #1c1c1c; /*border: 10px solid #30c4cb;*/ margin: 0em auto; padding: 0em auto; text-align: center; width: 100%;}
textarea {box-sizing: border-box;width: 100%;max-width: 600px;/* limits desktop size */min-height: 140px; /* good mobile size */}
	
label[for="ent-type"] {font-size: 1.5em;}
.radiotext{font-size: 1.5em; line-height: 1.5em;}
input[type="submit"] {border-radius: 3em; font-size: 1.5em; padding: 14px 30px;}
	
footer{font-size: .7em; margin: 2em .5em 5em .5em; padding: 0em; text-align: center;}
footer p{line-height: 1.9em;}
.official{font-size: 1.5em;}
.date{font-size: 1.5em;}