/* ========================================
   GRACIA Field Custom Styles
   Color: Green #2d8f5e + Amber #f59e0b
   Tone: 地域密着 × 実行力 × BtoB
   ======================================== */

/* --- Sticky Header --- */
.site-header {
	position: sticky;
	top: 0;
	z-index: 999;
	transition: box-shadow 0.3s ease;
}

.site-header.is-scrolled {
	box-shadow: 0 2px 20px rgba(0, 0, 0, 0.08);
}

/* --- Hero --- */
.gf-hero {
	margin-top: 0 !important;
}

.gf-hero .wp-block-cover__inner-container {
	animation: heroFadeIn 1s ease-out;
}

@keyframes heroFadeIn {
	from {
		opacity: 0;
		transform: translateY(20px);
	}
	to {
		opacity: 1;
		transform: translateY(0);
	}
}

/* --- Scroll Fade-in Animation --- */
.fade-in-up {
	opacity: 0;
	transform: translateY(30px);
	transition: opacity 0.6s ease-out, transform 0.6s ease-out;
}

.fade-in-up.is-visible {
	opacity: 1;
	transform: translateY(0);
}

/* Stagger delay for service cards */
.fade-in-up.delay-1 { transition-delay: 0.1s; }
.fade-in-up.delay-2 { transition-delay: 0.2s; }
.fade-in-up.delay-3 { transition-delay: 0.3s; }

/* --- Service Card Hover --- */
.service-card {
	transition: transform 0.3s ease, box-shadow 0.3s ease;
	border-radius: 12px;
	overflow: hidden;
}

.service-card:hover {
	transform: translateY(-4px);
	box-shadow: 0 12px 40px rgba(45, 143, 94, 0.15);
}

/* --- Number Counter --- */
.counter-number {
	font-size: clamp(2.5rem, 5vw, 4rem);
	font-weight: 800;
	color: var(--wp--preset--color--primary);
	line-height: 1.2;
}

.counter-label {
	font-size: 0.9rem;
	color: var(--wp--preset--color--mid-gray);
	margin-top: 0.3em;
}

/* --- Section Heading with Left Accent --- */
.section-heading {
	position: relative;
	padding-left: 1em;
}

.section-heading::before {
	content: '';
	position: absolute;
	left: 0;
	top: 0.15em;
	bottom: 0.15em;
	width: 4px;
	background: var(--wp--preset--color--primary);
	border-radius: 2px;
}

/* --- Image hover --- */
.wp-block-image img {
	transition: transform 0.3s ease;
}

.wp-block-image:hover img {
	transform: scale(1.03);
}

/* --- Button hover transition --- */
.wp-block-button__link {
	transition: background-color 0.3s ease, color 0.3s ease, transform 0.2s ease;
}

.wp-block-button__link:hover {
	transform: translateY(-2px);
}

/* --- Contact Form 7 --- */
.wpcf7 {
	max-width: 100%;
}

.wpcf7 input[type="text"],
.wpcf7 input[type="email"],
.wpcf7 input[type="tel"],
.wpcf7 input[type="url"],
.wpcf7 select,
.wpcf7 textarea {
	width: 100%;
	padding: 0.8em 1em;
	border: 1px solid #d1d5db;
	border-radius: 8px;
	font-size: 1rem;
	font-family: inherit;
	background: #fff;
	transition: border-color 0.3s ease, box-shadow 0.3s ease;
}

.wpcf7 input:focus,
.wpcf7 select:focus,
.wpcf7 textarea:focus {
	outline: none;
	border-color: var(--wp--preset--color--primary);
	box-shadow: 0 0 0 3px var(--wp--preset--color--primary-tint);
}

.wpcf7 textarea {
	min-height: 160px;
	resize: vertical;
}

.wpcf7 input[type="submit"] {
	display: inline-block;
	padding: 0.9em 2.5em;
	background: var(--wp--preset--color--primary);
	color: #fff;
	border: none;
	border-radius: 8px;
	font-size: 1rem;
	font-weight: 600;
	cursor: pointer;
	transition: background-color 0.3s ease, transform 0.2s ease;
}

.wpcf7 input[type="submit"]:hover {
	background: var(--wp--preset--color--primary-dark);
	transform: translateY(-2px);
}

.wpcf7-form p {
	margin-bottom: 1.2em;
}

.wpcf7-form label {
	display: block;
	margin-bottom: 0.4em;
	font-weight: 500;
	font-size: 0.9rem;
}

/* --- Table styles --- */
.wp-block-table table {
	border-collapse: collapse;
	width: 100%;
}

.wp-block-table td,
.wp-block-table th {
	padding: 0.8em 1em;
	border: 1px solid #e5e7eb;
}

.wp-block-table th {
	background: var(--wp--preset--color--primary);
	color: #fff;
	font-weight: 600;
}

.wp-block-table tr:nth-child(even) td {
	background: var(--wp--preset--color--light-gray);
}

/* --- Separator short style --- */
.wp-block-separator:not(.is-style-wide):not(.is-style-dots) {
	width: 60px;
	height: 3px;
	border: none;
}

/* --- Footer logo: invert for dark background --- */
.site-footer .footer-logo img {
	filter: brightness(0) invert(1);
	pointer-events: auto;
}

/* --- Footer links override --- */
.site-footer a {
	color: inherit;
	text-decoration: none;
}

.site-footer a:hover {
	color: var(--wp--preset--color--accent);
}

/* --- Image protection --- */
img {
	-webkit-user-drag: none;
	user-select: none;
	pointer-events: none;
}

a img {
	pointer-events: auto;
}

/* --- Strength Point Icons --- */
.strength-icon {
	width: 64px;
	height: 64px;
	border-radius: 50%;
	background: var(--wp--preset--color--primary-tint);
	display: flex;
	align-items: center;
	justify-content: center;
	margin: 0 auto 1em;
	font-size: 1.8rem;
}

/* --- CTA Section --- */
.cta-section {
	background: linear-gradient(135deg, #2d8f5e 0%, #1e6b42 100%);
	border-radius: 16px;
}

/* --- Mobile --- */
@media (max-width: 768px) {
	.site-header {
		padding-left: 1rem !important;
		padding-right: 1rem !important;
	}

	.counter-number {
		font-size: 2.2rem;
	}
}
