/*Jett Brayman 5/6/26*/
* {
	box-sizing: border-box;
	margin: 0;
	padding: 0;
}

html {
	scroll-behavior: smooth;
}

body {
	font-family: 'DM Serif Display', Georgia, serif;
	background: #f4f7f5;
	color: #1f2421;
	line-height: 1.5;
}

img {
	display: block;
	max-width: 100%;
	height: auto;
}

a {
	color: inherit;
}

#site-nav {
	background: #f4f7f5;
	border-bottom: 2px solid #9cc5a1;
	box-shadow: 0 2px 12px rgba(31,36,33,.07);
}

#site-nav .navbar-brand {
	font-family: 'DM Serif Display', Georgia, serif;
	font-size: 2rem;
	color: #216869;
	text-decoration: none;
}


#site-nav ul {
	list-style: none;
	display: flex;
	gap: .5rem;
	margin: 0;
	padding: 0;
}

#site-nav .d-md-flex a, #site-nav #nav-drawer a {
	display: block;
	padding: .35rem .9rem;
	border-radius: 20px;
	border: 1.5px solid #9cc5a1;
	color: #216869;
	text-decoration: none;
	font-size: 1rem;
	font-weight: 500;
	transition: all .2s;
}

#site-nav a:hover, #site-nav a.active {
	background: #49a078;
	border-color: #49a078;
	color: #fff;
}

#nav-drawer a {
	border-radius: 0;
	border: none;
	border-bottom: 1px solid #dce1de;
	font-size: 1rem;
}

#nav-drawer a:hover {
	color: #49a078;
	background: none;
}

.navbar-toggler {
	border: none;
	padding: 6px;
	background: none;
}

.navbar-toggler:focus {
	box-shadow: none;
}

.toggler-bar {
	display: block;
	width: 24px;
	height: 2px;
	background: #216869;
	margin: 5px 0;
}

footer {
	background: #1f2421;
	color: #9cc5a1;
	padding: 3rem 1.5rem 2rem;
	text-align: center;
	font-family: 'Satisfy', cursive;
	font-size: 2rem;
}

footer a {
	display: inline-block;
	padding: .5rem 1.25rem;
	border: 1.5px solid #216869;
	border-radius: 5px;
	color: #9cc5a1;
	text-decoration: none;
	font-size: 1rem;
	margin: 1rem;
	font-family: 'Trebuchet MS', sans-serif;
}

footer a:hover {
	background: #216869;
	color: #fff;
}

footer p:last-child {
	font-size: .73rem;
	opacity: .4;
}

.page-hero {
	background: linear-gradient(135deg, #1f2421, #216869);
	padding: 3.5rem 1.5rem 2.5rem;
	text-align: center;
	color: #fff;
}

.page-hero span {
	font-family: 'Satisfy', cursive;
	font-size: 1.5rem;
	color: #9cc5a1;
	display: block;
	margin-bottom: .4rem;
}

main {
	max-width: 820px;
	margin: 0 auto;
	padding: 3rem 1.25rem 4rem;
}

main p {
	font-size: 1rem;
	color: #3a4a3f;
	line-height: 2;
	margin-bottom: 1rem;
}

.carousel {
	border-radius: 10px;
	overflow: hidden;
	margin-bottom: 1.75rem;
}

.carousel-item {
	aspect-ratio: 16/9;
}

.carousel-item img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}


.read-more-btn {
	color: #216869;
	font-size: .9rem;
	font-weight: 600;
	padding: .5rem 0;
	display: inline-block;
}

.read-more-btn:hover {
	color: #49a078;
}

.itinerary-box {
	background: #1f2421;
	color: #dce1de;
	border-radius: 10px;
	padding: 1.75rem;
	margin: 1.5rem 0;
}

.itinerary-box h4 {
	font-size: 1rem;
	color: #9cc5a1;
	font-style: italic;
	margin-bottom: 1rem;
}

.itinerary-box ul {
	list-style: none;
	display: grid;
	gap: .5rem;
	padding: 0;
}

.itinerary-box li {
	display: flex;
	gap: .5rem;
	background: rgba(156,197,161,.08);
	padding: 0.5rem 1rem;
	border-radius: 6px;
	border-left: 3px solid #49a078;
	font-size: 1rem;
	align-items: baseline;
}

.itinerary-box li span {
	font-family: 'Satisfy', cursive;
	font-size: 1rem;
	color: #49a078;
	flex-shrink: 0;
	min-width: 45px;
}

.sources-box {
	background: #dce1de;
	border-left: 3px solid #9cc5a1;
	border-radius: 0 10px 10px 0;
	padding: 1rem 1.25rem;
	margin: 1.25rem 0;
	font-size: 1rem;
}

.sources-box p {
	font-family: 'Satisfy', cursive;
	font-size: 1rem;
	color: #216869;
	margin-bottom: .5rem;
}

.sources-box ul {
	list-style: none;
	line-height: 2;
	padding: 0;
}

.coming-soon-note {
	display: inline-flex;
	background: #dce1de;
	border: 1.5px dashed #9cc5a1;
	border-radius: 8px;
	padding: .5rem 1rem;
	font-size: 1rem;
	color: #216869;
	margin-bottom: 1rem;
}

.comment-section {
	margin-top: 2.5rem;
	padding-top: 1.75rem;
	border-top: 2px solid #dce1de;
}

.comment-section h3 {
	font-size: 1.2rem;
	color: #216869;
	margin-bottom: 1rem;
}

.comment-form {
	display: grid;
	gap: .75rem;
}

.form-row {
	display: grid;
	gap: .75rem;
}

.comment-form input, .comment-form textarea {
	width: 100%;
	padding: .5rem 1rem;
	border: 1.5px solid #c5d4c8;
	border-radius: 6px;
	font-family: 'DM Serif Display', Georgia, serif;
	font-size: 1rem;
	background: #fff;
	color: #1f2421;
}

.comment-form button {
	padding: .5rem 1.75rem;
	background: #49a078;
	color: #fff;
	border: none;
	border-radius: 6px;
	font-family: 'DM Serif Display', Georgia, serif;
	font-size: 1rem;
	cursor: pointer;
	width: fit-content;
}

.comment-form button:hover {
	background: #216869;
}



.hero {
	min-height: 40rem;
	display: flex;
	align-items: center;
	justify-content: center;
	overflow: hidden;
	position: relative;
	text-align: center;
	background: linear-gradient(150deg, #1f2421, #216869 55%, #49a078);
}



.hero-content {
	position: relative;
	z-index: 2;
	padding: 2rem 1.5rem;
}

.hero-content > span:first-child {
	font-family: 'Satisfy', cursive;
	font-size: 1.5rem;
	color: #9cc5a1;
	display: block;
	margin-bottom: .5rem;
}

.hero-content h1 {
	font-size: 7rem;
	color: #fff;
	line-height: 1;
	margin-bottom: .5rem;
}

.hero-content em {
	font-style: italic;
	font-size: 2rem;
	color: #9cc5a1;
	display: block;
	margin-bottom: 1rem;
}

.hero-content p {
	color: rgba(220,225,222,.88);
	font-size: 1rem;
	max-width: 460px;
	margin: 0 auto 2rem;
}

.hero-tag {
	padding: 0.5rem 1rem;
	background: rgba(156,197,161,.18);
	border: 1px solid rgba(156,197,161,.5);
	border-radius: 20px;
	color: #dce1de;
	font-size: .8rem;
}

.about-strip {
	background: #dce1de;
	padding: 2.5rem 1.5rem;
}

.about-strip > div {
	max-width: 740px;
	margin: 0 auto;
	background: #fff;
	border-radius: 10px;
	box-shadow: 0 2px 16px rgba(31,36,33,.10);
	padding: 2rem 2rem;
	display: grid;
	align-items: center;
}

.about-strip .avatar {
	width: 82px;
	height: 82px;
	border-radius: 50%;
	background: linear-gradient(135deg, #216869, #49a078);
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 2rem;
	color: #fff;
}

.about-strip h2 {
	font-size: 1.2rem;
	color: #216869;
	margin-bottom: .35rem;
}

.about-strip p {
	font-size: .9rem;
	color: #4a5e50;
}

.categories-section {
	padding: 3.5rem 1.25rem 4rem;
	max-width: 1000px;
	margin: 0 auto;
}

.categories-section h2 {
	font-size: 1.5rem;
	margin-bottom: .25rem;
}

.categories-section p {
	font-family: 'Satisfy', cursive;
	color: #49a078;
	font-size: 1rem;
	margin-bottom: 2rem;
}

.category-grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: 1.5rem;
}

.category-grid a {
	display: flex;
	flex-direction: column;
	background: #fff;
	border-radius: 10px;
	box-shadow: 0 2px 16px rgba(31,36,33,.10);
	overflow: hidden;
	text-decoration: none;
	color: inherit;
  padding: 1rem;
}

.category-grid a:hover {
	transform: translateY(-6px);
	box-shadow: 0 10px 32px rgba(31,36,33,.16);
}

.card-thumb {
	aspect-ratio: 4/3;
	display: flex;
	align-items: center;
	justify-content: center;
	font-family: 'Satisfy', cursive;
	font-size: 1rem;
}

@media (min-width: 500px) {
	.form-row {
		grid-template-columns: 1fr 1fr;
	}
  .hero-content h1 {
	font-size: 5rem;

}

}

@media (min-width: 540px) {
	.itinerary-box ul {
		grid-template-columns: repeat(2, 1fr);
	}

	.about-strip {
		grid-template-columns: 90px 1fr;
	}
}

@media (min-width: 600px) {
	.category-grid {
		grid-template-columns: repeat(3, 1fr);
	}
}