html {
	scroll-behavior: smooth;
}

body {
	font-family: "Inter", sans-serif;
	background:
		linear-gradient(90deg, rgba(15, 133, 128, 0.08) 1px, transparent 1px),
		linear-gradient(180deg, rgba(15, 133, 128, 0.08) 1px, transparent 1px),
		#fffdf8;
	background-size: 42px 42px;
	color: #222222;
}

.font-display {
	font-family: "Sora", "Inter", sans-serif;
}

.entry-content > * {
	margin-bottom: 1.25rem;
}

.entry-content h2,
.entry-content h3 {
	font-family: "Sora", "Inter", sans-serif;
	font-weight: 700;
	line-height: 1.05;
}

.codepop-search-form {
	display: grid;
	gap: 0.75rem;
}

.codepop-search-form-main {
	align-items: stretch;
	background: #fffdf8;
	border: 1px solid rgba(255, 253, 248, 0.26);
	display: flex;
	overflow: hidden;
}

.codepop-search-form input,
.codepop-search-form select {
	background: #fffdf8;
	border: 0;
	color: #222222;
	font: inherit;
	font-weight: 750;
	min-width: 0;
	outline: none;
	padding: 1rem;
	width: 100%;
}

.codepop-search-form select {
	border-top: 1px solid rgba(34, 34, 34, 0.12);
}

.codepop-search-form button {
	background: #0f8580;
	color: #fffdf8;
	font-weight: 900;
	padding: 1rem 1.25rem;
	white-space: nowrap;
}

.codepop-search-form button:hover {
	background: #222222;
}

@media (min-width: 720px) {
	.codepop-search-form {
		grid-template-columns: minmax(0, 1fr) 16rem;
	}

	.codepop-search-form select {
		border-left: 1px solid rgba(34, 34, 34, 0.12);
		border-top: 0;
	}
}

.entry-content h2 {
	font-size: clamp(2rem, 1.44rem + 2.78vw, 4rem);
}

.entry-content h3 {
	font-size: clamp(1.4rem, 1.12rem + 1.39vw, 2.4rem);
}

.entry-content a {
	color: #0f8580;
	font-weight: 700;
	text-decoration: underline;
	text-underline-offset: 0.2em;
}

.entry-content ul,
.entry-content ol {
	padding-left: 1.25rem;
}

.entry-content ul {
	list-style: disc;
}

.entry-content ol {
	list-style: decimal;
}

.codepop-card {
	background: rgba(255, 255, 255, 0.76);
	border: 1px solid rgba(15, 133, 128, 0.18);
	border-radius: 0.5rem;
	box-shadow: 0 24px 70px rgba(34, 34, 34, 0.08);
}

.codepop-hero {
	background:
		radial-gradient(circle at 14% 24%, rgba(18, 143, 137, 0.45), transparent 30%),
		radial-gradient(circle at 84% 18%, rgba(255, 253, 248, 0.18), transparent 24%),
		radial-gradient(circle at 70% 82%, rgba(10, 111, 107, 0.42), transparent 26%),
		#222222;
}

.codepop-site-header {
	transition: background-color 180ms ease, border-color 180ms ease, box-shadow 180ms ease;
}

.codepop-site-header.is-scrolled {
	background: rgba(15, 133, 128, 0.96);
	border-color: rgba(255, 253, 248, 0.18);
	box-shadow: 0 12px 36px rgba(34, 34, 34, 0.14);
}

.codepop-site-header.is-scrolled a,
.codepop-site-header.is-scrolled .menu-item a {
	color: #fffdf8;
}

.codepop-site-header.is-scrolled a:hover,
.codepop-site-header.is-scrolled .menu-item a:hover {
	color: #e4f2ef;
}

.codepop-site-header.is-scrolled .text-coral {
	color: #fffdf8;
}

.codepop-custom-logo {
	width: var(--codepop-logo-width, 176px);
}

.codepop-custom-logo img {
	display: block;
	height: auto;
	max-width: 100%;
	width: 100%;
}

.codepop-custom-logo.codepop-logo-shape-rounded img {
	border-radius: 0.75rem;
}

.codepop-custom-logo.codepop-logo-shape-circle {
	aspect-ratio: 1;
	overflow: hidden;
}

.codepop-custom-logo.codepop-logo-shape-circle img {
	aspect-ratio: 1;
	border-radius: 999px;
	height: 100%;
	object-fit: cover;
}

.codepop-contact-form form {
	display: grid;
	gap: 1.1rem;
}

.codepop-contact-form label {
	color: rgba(34, 34, 34, 0.78);
	display: grid;
	font-size: 0.875rem;
	font-weight: 800;
	gap: 0.45rem;
	letter-spacing: 0;
}

.codepop-contact-form input,
.codepop-contact-form select,
.codepop-contact-form textarea {
	background: #fffdf8;
	border: 1px solid rgba(34, 34, 34, 0.13);
	border-radius: 0;
	color: #222222;
	font: inherit;
	font-weight: 650;
	padding: 1rem;
	width: 100%;
}

.codepop-contact-form textarea {
	min-height: 9rem;
	resize: vertical;
}

.codepop-contact-form input:focus,
.codepop-contact-form select:focus,
.codepop-contact-form textarea:focus {
	border-color: #0f8580;
	box-shadow: 0 0 0 3px rgba(15, 133, 128, 0.16);
	outline: none;
}

.codepop-contact-form input[type="submit"] {
	background: #222222;
	border-color: #222222;
	border-radius: 999px;
	color: #fffdf8;
	cursor: pointer;
	font-weight: 900;
	padding-inline: 1.4rem;
	width: auto;
}

.codepop-contact-form input[type="submit"]:hover {
	background: #0f8580;
	border-color: #0f8580;
}

.codepop-contact-form .wpcf7-not-valid-tip {
	color: #0a6f6b;
	font-size: 0.85rem;
	font-weight: 800;
	margin-top: 0.25rem;
}

.codepop-contact-form .wpcf7-response-output {
	border-radius: 0;
	margin: 1rem 0 0;
	padding: 1rem;
}

.codepop-site-edit-button {
	align-items: center;
	background: #222222;
	border: 1px solid rgba(255, 253, 248, 0.24);
	border-radius: 999px;
	bottom: 1.25rem;
	box-shadow: 0 18px 48px rgba(34, 34, 34, 0.22);
	color: #fffdf8;
	display: inline-flex;
	font-size: 0.875rem;
	font-weight: 900;
	gap: 0.45rem;
	line-height: 1;
	padding: 0.9rem 1.1rem;
	position: fixed;
	right: 1.25rem;
	text-decoration: none;
	z-index: 60;
}

.codepop-site-edit-button:hover,
.codepop-site-edit-button:focus {
	background: #0f8580;
	color: #fffdf8;
}

.codepop-cf7-grid {
	display: grid;
	gap: 1rem;
	grid-template-columns: repeat(2, minmax(0, 1fr));
}

.codepop-cf7-panel {
	display: grid;
	gap: 1rem;
}

@media (max-width: 720px) {
	.codepop-cf7-grid {
		grid-template-columns: 1fr;
	}
}

.screen-reader-text {
	clip: rect(1px, 1px, 1px, 1px);
	height: 1px;
	overflow: hidden;
	position: absolute;
	width: 1px;
}
