/*
Theme Name: Rachel Fuhrer Music
Theme URI: https://rachelfuhrermusic.com/
Description: A custom Wordpress theme developed for Rachel Fuhrer.
Version: 1.0
Author: Mathew Smith
Author URI: https://mathewsmithstudio.com/
Tags: black, gray, white, two-columns, fixed-width
*/

@font-face {
	font-family: 'Veneer Three';
	src: url('assets/fonts/VeneerThree.woff2') format('woff2'),
		 url('assets/fonts/VeneerThree.woff') format('woff');
	font-weight: normal;
	font-style: normal;
}

:root {
	--red: #b32025;
	--red-dark: #8f171b;
	--black: #101010;
	--charcoal: #181818;
	--gray: #f2f2f2;
	--white: #ffffff;
	--body: 'Space Grotesk', sans-serif;
	--headline: 'Veneer Three', sans-serif;
}

body {
	color: var(--black);
	background-color: var(--white);
	font-family: var(--body);
	line-height: 1.6;
}

.h1, .h2, .h3, .h4, .h5, .h6, h1, h2, h3, h4, h5, h6, .navbar-brand, .footer-brand {
	font-family: var(--headline);
	font-weight: normal;
	line-height: 1;
	text-transform: uppercase;
	/*letter-spacing: -0.03em;*/
}

h1 {
	font-size: clamp(2.5rem, 5vw, 5rem);
}

h2 {
	font-size: clamp(2rem, 4vw, 4rem);
}

h3 {
	font-size: 1.35rem;
}

a {
	color: var(--red);
	text-decoration: none;
}

a:hover {
	color: var(--red-dark);
}

.site-header {
	background-color: var(--black);
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	z-index: 20;
}

.navbar {
	padding: 1.25rem 0;
}

.navbar-brand {
	color: var(--white);
	font-size: 3rem;
}

.navbar-brand span, .footer-brand span {
	color: var(--red);
}

.navbar-nav {
	gap: 1.5rem;
}

.navbar-nav .menu-item a {
	color: var(--white);
	font-size: 0.8rem;
	font-weight: 800;
	letter-spacing: 0.05em;
	text-transform: uppercase;
}

.navbar-nav .menu-item a:hover {
	color: var(--red);
}

.hero-section {
	background-image: linear-gradient(90deg, rgba(0, 0, 0, 0.9), rgba(0, 0, 0, 0.25)), url('https://placehold.co/1800x950/111111/ffffff?text=Rachel+Drumming');
	background-position: center;
	background-size: cover;
	color: var(--white);
	min-height: 760px;
	padding: 9rem 0 5rem;
}

.min-vh-75 {
	min-height: 75vh;
}

.hero-card {
	background-color: var(--red);
	box-shadow: -18px 18px 0 rgba(0, 0, 0, 0.35);
	padding: clamp(2rem, 4vw, 4rem);
	transform: skew(4deg);
}

.hero-card > * {
	transform: skew(-4deg);
}

.hero-card p {
	max-width: 420px;
}

.section-dark {
	background-color: var(--charcoal);
	color: var(--white);
}

.section-image {
	min-height: 560px;
	object-fit: cover;
}

.content-block {
	max-width: 620px;
	padding: clamp(3rem, 6vw, 6rem);
}

.eyebrow {
	color: var(--red);
	font-size: 0.85rem;
	font-weight: 900;
	letter-spacing: 0.08em;
	margin-bottom: 0.75rem;
	text-transform: uppercase;
}

.check-list {
	list-style: none;
	margin: 1.5rem 0 2rem;
	padding: 0;
}

.check-list li {
	margin-bottom: 0.65rem;
	padding-left: 1.75rem;
	position: relative;
}

.check-list li::before {
	color: var(--red);
	content: "✓";
	font-weight: 900;
	left: 0;
	position: absolute;
	top: 0;
}

.btn {
	border: 0;
	border-radius: 0;
	font-size: 0.8rem;
	font-weight: 900;
	letter-spacing: 0.04em;
	padding: 1rem 1.75rem;
	text-transform: uppercase;
}

.btn-red {
	background-color: var(--red);
	color: var(--white);
}

.btn-red:hover {
	background-color: var(--red-dark);
	color: var(--white);
}

.btn-dark-red {
	background-color: var(--black);
	color: var(--white);
}

.btn-dark-red:hover {
	background-color: var(--red-dark);
	color: var(--white);
}

.lessons-section {
	background-color: var(--gray);
	padding: 5rem 0;
}

.lesson-card {
	align-items: flex-end;
	background-position: center;
	background-size: cover;
	color: var(--white);
	display: flex;
	min-height: 360px;
	padding: 2rem;
	position: relative;
}

.lesson-card::before {
	background: linear-gradient(180deg, rgba(0, 0, 0, 0.05), rgba(0, 0, 0, 0.85));
	content: "";
	inset: 0;
	position: absolute;
}

.lesson-card::after {
	background-color: var(--red);
	bottom: 0;
	content: "";
	height: 5px;
	left: 0;
	position: absolute;
	width: 100%;
}

.lesson-card > div {
	position: relative;
	z-index: 2;
}

.lesson-card h3 {
	color: var(--white);
	margin-bottom: 0.5rem;
}

.lesson-card p {
	margin-bottom: 0;
}

.experience-section {
	padding: 5rem 0;
}

.experience-section img {
	min-height: 420px;
	object-fit: cover;
	width: 100%;
}

.testimonial-section {
	background-color: var(--black);
	color: var(--white);
	padding: 4rem 0;
}

.testimonial-section blockquote {
	font-size: clamp(1.3rem, 2vw, 2rem);
	font-style: italic;
	line-height: 1.4;
	margin-bottom: 1rem;
}

.testimonial-name {
	color: var(--red);
	font-weight: 900;
	margin-bottom: 0;
	text-transform: uppercase;
}

.features-section {
	background-color: var(--white);
	padding: 4rem 0;
}

.feature-item {
	border-right: 1px solid rgba(0, 0, 0, 0.18);
}

.feature-item:last-child {
	border-right: 0;
}

.features-section h3 {
	margin-bottom: 1rem;
}

.features-section p {
	font-size: 0.95rem;
	margin: 0 auto;
	max-width: 230px;
}

.cta-section {
	background-color: var(--red);
	color: var(--white);
	overflow: hidden;
	padding: 3rem 0;
}

.cta-section h2 {
	margin-bottom: 0.75rem;
}

.cta-section p {
	margin-bottom: 1.5rem;
}

.cta-image {
	max-height: 300px;
	object-fit: contain;
}

.cta-content {
	max-width: 620px;
}

.site-footer {
	background-color: var(--black);
	color: var(--white);
	padding: 2.5rem 0;
}

.site-footer h3 {
	color: var(--red);
	font-size: 1rem;
	margin-bottom: 0.75rem;
}

.site-footer p {
	font-size: 0.9rem;
	margin-bottom: 0;
}

.site-footer a {
	color: var(--white);
}

.footer-brand {
	color: var(--white);
	font-size: 1.75rem;
}

// Small devices (landscape phones, 576px and up)
@media (min-width: 576px) {
}

// Medium devices (tablets, 768px and up)
@media (min-width: 768px) {
}

// Large devices (desktops, 992px and up)
@media (min-width: 992px) {
}

// X-Large devices (large desktops, 1200px and up)
@media (min-width: 1200px) {
}

// XX-Large devices (larger desktops, 1400px and up)
@media (min-width: 1400px) {
}