/*
 * Hammock Life - Contact Page Styles
 * Page: page-id-1719
 * Scoped to .page-id-1719 to avoid any leakage to other pages.
 */

/* ===== Container ===== */
.page-id-1719 .hl-contact {
	max-width: 720px;
	margin: 0 auto;
	padding: 40px 20px 80px;
	color: #3d3a35;
	font-family: "Noto Sans JP", "Hiragino Sans", sans-serif;
	line-height: 1.9;
}

/* ===== Header ===== */
.page-id-1719 .hl-contact-header {
	text-align: center;
	margin-bottom: 48px;
}
.page-id-1719 .hl-contact-eyebrow {
	font-family: "Cormorant Garamond", serif;
	font-size: 0.85rem;
	letter-spacing: 0.25em;
	color: #8b7355;
	margin: 0 0 10px;
	text-transform: uppercase;
}
.page-id-1719 .hl-contact-title {
	font-family: "Cormorant Garamond", "Noto Serif JP", serif;
	font-size: 2rem;
	font-weight: 400;
	letter-spacing: 0.08em;
	color: #3d3a35;
	margin: 0 0 16px;
	padding: 0;
	line-height: 1.4;
}
.page-id-1719 .hl-contact-subtitle {
	font-size: 0.95rem;
	color: #6b685f;
	margin: 0;
	line-height: 1.9;
}

/* ===== Intro ===== */
.page-id-1719 .hl-contact-intro {
	background: #fafaf6;
	border: 1px solid #ece8dd;
	border-radius: 2px;
	padding: 28px 32px;
	margin-bottom: 40px;
}
.page-id-1719 .hl-contact-intro p {
	margin: 0 0 18px;
	font-size: 0.95rem;
	line-height: 1.9;
	color: #555048;
}
.page-id-1719 .hl-contact-intro p:last-child {
	margin-bottom: 0;
}
.page-id-1719 .hl-contact-meta {
	list-style: none;
	padding: 18px 0 0;
	margin: 18px 0 0;
	border-top: 1px dashed #d4c9b8;
	display: flex;
	flex-wrap: wrap;
	gap: 8px 24px;
}
.page-id-1719 .hl-contact-meta li {
	font-size: 0.88rem;
	color: #6b685f;
}
.page-id-1719 .hl-contact-meta strong {
	color: #4a4a45;
	font-weight: 500;
	margin-right: 6px;
}

/* ===== Form container ===== */
.page-id-1719 .hl-contact-form {
	background: #fff;
	border: 1px solid #ece8dd;
	border-radius: 2px;
	padding: 40px 36px 32px;
}

/* ===== Contact Form 7 overrides (scoped to contact page) ===== */
.page-id-1719 .wpcf7-form p {
	margin: 0 0 22px;
}
.page-id-1719 .wpcf7-form label,
.page-id-1719 .wpcf7-form > p {
	font-size: 0.88rem;
	color: #4a4a45;
	font-weight: 500;
	letter-spacing: 0.04em;
	display: block;
}
.page-id-1719 .wpcf7-form p br {
	display: none;
}
.page-id-1719 .wpcf7-form-control-wrap {
	display: block;
	margin-top: 8px;
}
.page-id-1719 .wpcf7-form input[type="text"],
.page-id-1719 .wpcf7-form input[type="email"],
.page-id-1719 .wpcf7-form input[type="tel"],
.page-id-1719 .wpcf7-form input[type="url"],
.page-id-1719 .wpcf7-form textarea {
	width: 100%;
	padding: 12px 14px;
	font-size: 0.95rem;
	font-family: inherit;
	color: #3d3a35;
	background: #fdfcf8;
	border: 1px solid #d4c9b8;
	border-radius: 2px;
	box-sizing: border-box;
	transition: border-color 0.2s ease, background 0.2s ease, box-shadow 0.2s ease;
	box-shadow: none;
	outline: none;
}
.page-id-1719 .wpcf7-form input[type="text"]:focus,
.page-id-1719 .wpcf7-form input[type="email"]:focus,
.page-id-1719 .wpcf7-form input[type="tel"]:focus,
.page-id-1719 .wpcf7-form input[type="url"]:focus,
.page-id-1719 .wpcf7-form textarea:focus {
	border-color: #8b7355;
	background: #fff;
	box-shadow: 0 0 0 3px rgba(139, 115, 85, 0.1);
}
.page-id-1719 .wpcf7-form textarea {
	min-height: 160px;
	resize: vertical;
	line-height: 1.8;
}
.page-id-1719 .wpcf7-form input[type="submit"] {
	display: block;
	width: 100%;
	max-width: 420px;
	margin: 12px auto 0;
	padding: 18px 32px;
	background: #4a5d3a;
	color: #fff;
	border: 1px solid #4a5d3a;
	font-size: 1rem;
	letter-spacing: 0.1em;
	font-family: inherit;
	font-weight: 500;
	cursor: pointer;
	border-radius: 2px;
	transition: background 0.3s ease, transform 0.3s ease, box-shadow 0.3s ease;
	-webkit-appearance: none;
	appearance: none;
}
.page-id-1719 .wpcf7-form input[type="submit"]:hover {
	background: #3a4b2e;
	transform: translateY(-1px);
	box-shadow: 0 6px 20px rgba(74, 93, 58, 0.22);
}
.page-id-1719 .wpcf7-form input[type="submit"]:active {
	transform: translateY(0);
	box-shadow: none;
}

/* Validation messages */
.page-id-1719 .wpcf7-not-valid-tip {
	color: #c44;
	font-size: 0.82rem;
	margin-top: 6px;
	display: block;
}
.page-id-1719 .wpcf7-response-output {
	margin: 24px 0 0 !important;
	padding: 14px 18px !important;
	border-radius: 2px !important;
	font-size: 0.9rem !important;
	border: 1px solid #d4c9b8 !important;
	background: #fafaf6;
}
.page-id-1719 .wpcf7 form.sent .wpcf7-response-output {
	border-color: #4a5d3a !important;
	background: #f3f6ee;
	color: #3a4b2e;
}
.page-id-1719 .wpcf7 form.invalid .wpcf7-response-output,
.page-id-1719 .wpcf7 form.failed .wpcf7-response-output {
	border-color: #c44 !important;
	background: #fef6f4;
	color: #a33;
}

/* ===== Mobile ===== */
@media (max-width: 768px) {
	.page-id-1719 .hl-contact {
		padding: 28px 16px 56px;
	}
	.page-id-1719 .hl-contact-title {
		font-size: 1.5rem;
	}
	.page-id-1719 .hl-contact-intro {
		padding: 22px 20px;
	}
	.page-id-1719 .hl-contact-meta {
		flex-direction: column;
		gap: 6px;
	}
	.page-id-1719 .hl-contact-form {
		padding: 28px 20px 24px;
	}
	.page-id-1719 .wpcf7-form input[type="submit"] {
		padding: 16px 24px;
	}
}
