/* ===== Custom Properties ===== */
:root {
	--color-primary:   #1a3a28;
	--color-secondary: #2e7d54;
	--color-accent:    #52b788;
	--color-text:      #333;
	--color-muted:     #3d4a41;
	--color-bg:        #fff;
	--color-bg-light:  #f2f7f4;
	--color-bg-navy:   #0e2418;
	--color-border:    #c5d9cc;
	--color-icon-bg:   #e0f0e8;

	--font-base: 'Noto Sans JP', 'Hiragino Kaku Gothic ProN', 'Hiragino Sans', sans-serif;

	--container-max: 1280px;
	--container-pad: clamp(16px, 4vw, 32px);

	--radius:    8px;
	--radius-lg: 16px;

	--shadow:    0 2px 12px rgba(0, 0, 0, 0.08);
	--shadow-lg: 0 6px 28px rgba(0, 0, 0, 0.13);

	--transition: 0.25s ease;
	--header-h:   70px;
}

/* ===== Reset ===== */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; font-size: 16px; }
body {
	font-family: var(--font-base);
	color: var(--color-text);
	background: var(--color-bg);
	line-height: 1.75;
	-webkit-font-smoothing: antialiased;
}
img { max-width: 100%; height: auto; display: block; }
a { color: inherit; text-decoration: none; }
ul, ol { list-style: none; }
button { font-family: inherit; }
h2, h3 { font-weight: 900; }

/* ===== Accessibility ===== */
.sr-only {
	position: absolute;
	width: 1px; height: 1px;
	padding: 0; margin: -1px;
	overflow: hidden;
	clip: rect(0, 0, 0, 0);
	white-space: nowrap;
	border: 0;
}

/* ===== Layout ===== */
.container {
	max-width: var(--container-max);
	margin: 0 auto;
	padding: 0 var(--container-pad);
}

.section {
	padding: 120px 0;
}
.section--light    { background: var(--color-bg-light); }
.section--navy     { background: var(--color-primary); color: #fff; }
.section--dark-navy { background: var(--color-bg-navy); color: #fff; }

/* ===== Section Header ===== */
.section-header {
	text-align: center;
	margin-bottom: 56px;
}

.section-label {
	display: inline-block;
	font-size: 0.78rem;
	font-weight: 700;
	letter-spacing: 0.18em;
	color: var(--color-secondary);
	text-transform: uppercase;
	margin-bottom: 12px;
}
.section-label--light { color: rgba(255,255,255,0.6); }

.section-title {
	font-size: clamp(1.5rem, 3vw, 2.2rem);
	font-weight: 900;
	line-height: 1.5;
	color: var(--color-primary);
}
.section-title--light { color: #fff; }

.section-divider {
	width: 48px;
	height: 3px;
	background: var(--color-accent);
	margin: 20px auto 0;
	border-radius: 2px;
}
.section-divider--light { background: rgba(255,255,255,0.35); }

/* ===== Buttons ===== */
.btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: 16px 36px;
	font-size: 0.95rem;
	font-weight: 700;
	border-radius: 50px;
	transition: background var(--transition), border-color var(--transition), opacity var(--transition), transform var(--transition);
	cursor: pointer;
	border: 2px solid transparent;
	letter-spacing: 0.04em;
	white-space: nowrap;
}
.btn:hover { opacity: 0.88; transform: translateY(-1px); }
.btn:active { transform: translateY(0); }

.btn--lg { padding: 20px 48px; font-size: 1.05rem; }

.btn--gold {
	background: #f5c200;
	color: var(--color-primary);
	border-color: #f5c200;
}

.btn--outline {
	background: transparent;
	color: #fff;
	border-color: rgba(255,255,255,0.65);
}
.btn--outline:hover { background: rgba(255,255,255,0.12); opacity: 1; }

.btn--navy {
	background: var(--color-primary);
	color: #fff;
	border-color: var(--color-primary);
}

/* ===== Site Header ===== */
.site-header {
	position: fixed;
	top: 0; left: 0; right: 0;
	z-index: 1000;
	height: var(--header-h);
	transition: background var(--transition), box-shadow var(--transition);
}
.site-header.is-scrolled {
	background: #fff;
	box-shadow: 0 2px 16px rgba(0, 0, 0, 0.09);
}

.header__inner {
	display: flex;
	align-items: center;
	justify-content: space-between;
	height: var(--header-h);
}

.header__logo a {
	display: flex;
	align-items: center;
}
.custom-logo-link {
	display: flex;
	align-items: center;
	max-width: min(260px, 48vw);
}
.custom-logo {
	display: block;
	width: auto;
	max-width: 100%;
	height: auto;
	max-height: 52px;
	object-fit: contain;
}
.logo-text {
	font-size: 0.88rem;
	font-weight: 700;
	line-height: 1.4;
	color: #fff;
	transition: color var(--transition);
}
.site-header.is-scrolled .logo-text { color: var(--color-primary); }
.site-header.is-scrolled .header__logo img { filter: none; }

/* ===== Navigation ===== */
.nav-menu {
	display: flex;
	align-items: center;
	gap: 28px;
}
.nav-menu li a {
	font-size: 0.88rem;
	font-weight: 600;
	color: #333;
	transition: color var(--transition);
	position: relative;
	padding-bottom: 3px;
}
.nav-menu li a::after {
	content: '';
	position: absolute;
	bottom: 0; left: 0; right: 0;
	height: 2px;
	background: var(--color-accent);
	transform: scaleX(0);
	transform-origin: left;
	transition: transform var(--transition);
}
.nav-menu li a:hover::after { transform: scaleX(1); }
.site-header.is-scrolled .nav-menu li a { color: var(--color-text); }

.nav-menu > li:last-child > a {
	background: #f5c200;
	color: var(--color-primary);
	padding: 10px 24px;
	border-radius: 50px;
	border: none;
}
.nav-menu > li:last-child > a::after { display: none; }
.nav-menu > li:last-child > a:hover { opacity: 0.85; }

/* ===== Mobile Menu Toggle ===== */
.menu-toggle {
	display: none;
	flex-direction: column;
	justify-content: space-between;
	width: 28px;
	height: 20px;
	background: none;
	border: none;
	cursor: pointer;
	padding: 0;
	z-index: 1001;
	position: relative;
}
.menu-toggle__bar {
	display: block;
	height: 2px;
	background: #fff;
	border-radius: 2px;
	transition: transform var(--transition), opacity var(--transition), background var(--transition);
}
.site-header.is-scrolled .menu-toggle__bar { background: var(--color-primary); }
.menu-toggle.is-active .menu-toggle__bar:nth-child(1) { transform: translateY(9px) rotate(45deg); }
.menu-toggle.is-active .menu-toggle__bar:nth-child(2) { opacity: 0; }
.menu-toggle.is-active .menu-toggle__bar:nth-child(3) { transform: translateY(-9px) rotate(-45deg); }

/* ===== FV ===== */
.fv {
	position: relative;
	height: 100dvh;
	min-height: 580px;
	display: flex;
	align-items: center;
	background-image: none;
	background-size: cover;
	background-position: center;
	background-repeat: no-repeat;
	background-color: var(--color-primary);
}
.fv .container { position: relative; z-index: 1; }

.fv__label {
	font-size: 0.82rem;
	font-weight: 700;
	color: var(--color-accent);
	letter-spacing: 0.14em;
	text-transform: uppercase;
	margin-bottom: 20px;
}

.fv__title {
	font-size: clamp(1.75rem, 4vw, 2.75rem);
	font-weight: 700;
	color: #fff;
	line-height: 1.55;
	margin-bottom: 24px;
	text-shadow: 0 2px 10px rgba(0, 0, 0, 0.35);
}

.fv__sub {
	font-size: clamp(0.88rem, 1.6vw, 1rem);
	color: rgba(255, 255, 255, 0.88);
	line-height: 1.9;
	margin-bottom: 40px;
}

.fv__cta {
	display: flex;
	gap: 16px;
	flex-wrap: wrap;
}

.fv__scroll {
	position: absolute;
	bottom: 28px;
	left: 50%;
	transform: translateX(-50%);
	z-index: 1;
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 8px;
}
.fv__scroll-text {
	font-size: 0.65rem;
	letter-spacing: 0.22em;
	color: rgba(255,255,255,0.55);
}
.fv__scroll-bar {
	width: 1px;
	height: 44px;
	background: rgba(255,255,255,0.25);
	position: relative;
	overflow: hidden;
}
.fv__scroll-bar::after {
	content: '';
	position: absolute;
	top: -100%; left: 0;
	width: 100%; height: 100%;
	background: rgba(255,255,255,0.8);
	animation: scroll-down 2s ease-in-out infinite;
}
@keyframes scroll-down {
	0%   { top: -100%; }
	100% { top: 100%; }
}

/* ===== Trust Badges ===== */
.trust { background: var(--color-bg-light); padding: 28px 0; }

.trust__list {
	display: flex;
	justify-content: center;
	flex-wrap: wrap;
}
.trust__item {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 8px;
	padding: 14px 28px;
	text-align: center;
	position: relative;
}
.trust__item + .trust__item::before {
	content: '';
	position: absolute;
	left: 0;
	top: 50%;
	transform: translateY(-50%);
	height: 36px;
	width: 1px;
	background: var(--color-border);
}
.trust__icon {
	width: 44px; height: 44px;
	display: flex;
	align-items: center;
	justify-content: center;
	background: var(--color-primary);
	border-radius: 50%;
	color: #fff;
	flex-shrink: 0;
}
.trust__icon svg { width: 22px; height: 22px; }
.trust__text {
	font-size: 0.8rem;
	font-weight: 700;
	color: var(--color-primary);
	line-height: 1.4;
}

/* ===== Pain Points ===== */
.pain {
	background: #f0f0f0;
	padding-top: calc(120px + 4rem);
	padding-bottom: 0;
}

.pain__heading {
	text-align: center;
	font-size: clamp(1.5rem, 3vw, 2.2rem);
	font-weight: 900;
	color: var(--color-primary);
	line-height: 1.65;
	margin-bottom: 52px;
}

.pain__em {
	font-style: normal;
	color: var(--color-secondary);
}

.pain__cards {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 20px;
	max-width: 860px;
	margin: 0 auto;
}

.pain__card-media {
	width: 100%;
	max-width: 200px;
	aspect-ratio: 1 / 1;
	overflow: hidden;
	display: flex;
	align-items: center;
	justify-content: center;
	margin: 0 auto 16px;
}

.pain__card-media svg {
	width: 72px;
	height: 72px;
	color: #aaa;
}

.pain__card-media img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.pain__card-text {
	font-size: 1.05rem;
	font-weight: 700;
	color: var(--color-primary);
	line-height: 1.9;
	text-align: center;
}
.pain__card-text::before {
	content: '✓';
	display: inline-block;
	width: 24px;
	height: 24px;
	line-height: 24px;
	background: var(--color-accent);
	color: #fff;
	border-radius: 50%;
	font-size: 0.75rem;
	font-weight: 700;
	text-align: center;
	margin-right: 8px;
	vertical-align: middle;
}

.pain__resolve {
	background: #3db87a;
	margin-top: calc(120px + 4rem);
	padding: 4rem var(--container-pad);
	text-align: center;
}

.pain__resolve p {
	font-size: clamp(1.2rem, 2.5vw, 2rem);
	font-weight: 700;
	color: #fff;
	letter-spacing: 0.06em;
}

.pain__resolve p::before {
	content: '＼';
	color: #f5c200;
	font-weight: 900;
	margin-right: 20px;
}

.pain__resolve p::after {
	content: '／';
	color: #f5c200;
	font-weight: 900;
	margin-left: 20px;
}

/* ===== About ===== */
.about__grid {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 64px;
	align-items: center;
}
.about__grid + .about__grid { margin-top: 64px; }

.about__map {
	border-radius: var(--radius-lg);
	overflow: hidden;
	box-shadow: var(--shadow-lg);
	aspect-ratio: 4 / 3;
	max-width: 560px;
	width: 100%;
}
.about__body .section-label { display: block; margin-bottom: 12px; }
.about__title { text-align: left; }
.about__divider { margin: 20px 0 28px; }
.about__text {
	font-size: 1rem;
	line-height: 2;
	color: var(--color-text);
}

.about__info {
	display: flex;
	flex-direction: column;
	gap: 24px;
}

.about__info-item {
	display: flex;
	align-items: flex-start;
	gap: 14px;
}

.about__info-icon {
	flex-shrink: 0;
	width: 36px;
	height: 36px;
	background: var(--color-icon-bg);
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	color: var(--color-secondary);
	margin-top: 2px;
}

.about__info-icon svg {
	width: 18px;
	height: 18px;
}

.about__info-body {
	display: flex;
	flex-direction: column;
	gap: 4px;
}

.about__info-main {
	font-size: 0.95rem;
	font-weight: 600;
	color: var(--color-primary);
	line-height: 1.6;
}

.about__info-sub {
	font-size: 0.82rem;
	color: var(--color-muted);
	line-height: 1.6;
}
.about__cta {
	display: inline-block;
	margin-top: 32px;
}
.about__image {
	border-radius: var(--radius-lg);
	overflow: hidden;
	box-shadow: var(--shadow-lg);
	aspect-ratio: 4 / 3;
	max-width: 560px;
	width: 100%;
}
.about__image img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}
.about__image-placeholder {
	width: 100%;
	height: 100%;
	display: flex;
	align-items: center;
	justify-content: center;
	background: var(--color-icon-bg);
	color: var(--color-secondary);
}
.about__image-placeholder svg {
	width: 76px;
	height: 76px;
}

/* ===== Reasons ===== */
.reasons {
	position: relative;
}

.reasons__watermark {
	position: absolute;
	top: 0;
	left: calc((100vw - var(--container-max)) / 2 + var(--container-pad));
	transform: translateY(-50%);
	font-size: clamp(5rem, 12vw, 10rem);
	font-weight: 900;
	color: rgba(0, 0, 0, 0.045);
	line-height: 1;
	pointer-events: none;
	user-select: none;
	letter-spacing: -0.02em;
	z-index: 10;
}

.reasons__grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 28px;
}

.reason-card {
	position: relative;
	background: #fff;
	border-radius: var(--radius-lg);
	padding: 52px 28px 36px;
	box-shadow: var(--shadow);
	display: flex;
	flex-direction: column;
	align-items: center;
	text-align: center;
	gap: 24px;
	transition: transform var(--transition), box-shadow var(--transition);
}
.reason-card:hover {
	transform: translateY(-4px);
	box-shadow: var(--shadow-lg);
}
.reason-card__num {
	position: absolute;
	top: 0;
	left: 24px;
	transform: translateY(-50%);
	font-size: 3.5rem;
	font-weight: 900;
	color: var(--color-accent);
	opacity: 0.6;
	line-height: 1;
	letter-spacing: -0.02em;
}
.reason-card__title {
	font-size: 1.15rem;
	font-weight: 700;
	color: var(--color-primary);
	line-height: 1.6;
}
.reason-card__icon {
	width: 100%;
	aspect-ratio: 4 / 3;
	display: flex;
	align-items: center;
	justify-content: center;
	background: var(--color-icon-bg);
	border-radius: var(--radius);
	color: var(--color-secondary);
	flex-shrink: 0;
	overflow: hidden;
}
.reason-card__icon svg {
	width: 64px;
	height: 64px;
}
.reason-card__icon img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}
.reason-card__text {
	font-size: 0.95rem;
	color: var(--color-text);
	line-height: 2;
}

/* ===== Services ===== */
.services {
	position: relative;
}

.services__watermark {
	position: absolute;
	top: 0;
	left: calc((100vw - var(--container-max)) / 2 + var(--container-pad));
	transform: translateY(-50%);
	font-size: clamp(5rem, 12vw, 10rem);
	font-weight: 900;
	color: rgba(0, 0, 0, 0.045);
	line-height: 1;
	pointer-events: none;
	user-select: none;
	letter-spacing: -0.02em;
	z-index: 10;
}

.services__list {
	display: flex;
	flex-direction: column;
	gap: 24px;
	max-width: 900px;
	margin: 0 auto;
}

.service-item {
	display: grid;
	grid-template-columns: 2fr 3fr auto;
	align-items: center;
	background: #fff;
	border-radius: var(--radius-lg);
	overflow: hidden;
	box-shadow: var(--shadow);
	transition: box-shadow var(--transition), transform var(--transition);
}

.service-item:hover {
	box-shadow: var(--shadow-lg);
	transform: translateY(-2px);
}

.service-item__image {
	background: var(--color-bg-light);
	display: flex;
	align-items: center;
	justify-content: center;
	color: var(--color-secondary);
	height: 200px;
	overflow: hidden;
}

.service-item__image img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}

.service-item__image svg {
	width: 64px;
	height: 64px;
}

.service-item__body {
	padding: 32px 36px;
}

.service-item__label {
	font-size: 0.75rem;
	font-weight: 700;
	color: var(--color-secondary);
	letter-spacing: 0.1em;
	margin-bottom: 8px;
}

.service-item__title {
	font-size: clamp(1.3rem, 2.5vw, 1.75rem);
	font-weight: 900;
	color: var(--color-primary);
	line-height: 1.4;
	margin-bottom: 12px;
}

.service-item__text {
	font-size: 0.88rem;
	color: var(--color-muted);
	line-height: 1.9;
}

.service-item__btn {
	flex-shrink: 0;
	width: 48px;
	height: 48px;
	margin-right: 32px;
	background: var(--color-secondary);
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	color: #fff;
	transition: background var(--transition), transform var(--transition);
}

.service-item__btn:hover {
	background: var(--color-primary);
	transform: translateX(3px);
}

.service-item__btn svg {
	width: 18px;
	height: 18px;
}

/* ===== Pricing ===== */
.pricing {
	background: #3db87a;
	position: relative;
}

.pricing__watermark {
	position: absolute;
	top: 0;
	right: calc((100vw - var(--container-max)) / 2 + var(--container-pad));
	transform: translateY(-50%);
	font-size: clamp(5rem, 12vw, 10rem);
	font-weight: 900;
	color: rgba(255, 255, 255, 0.15);
	line-height: 1;
	pointer-events: none;
	user-select: none;
	letter-spacing: -0.02em;
	z-index: 10;
}

.pricing__grid {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 32px;
	max-width: 860px;
	margin: 0 auto;
}

.plan-card {
	background: #fff;
	border-radius: var(--radius-lg);
	padding: 48px 36px 36px;
	box-shadow: 0 8px 36px rgba(0, 0, 0, 0.22);
	position: relative;
	display: flex;
	flex-direction: column;
	margin-top: 22px;
}

.plan-card--popular {
	box-shadow: 0 10px 40px rgba(0, 0, 0, 0.28);
}

.plan-badge {
	position: absolute;
	top: 0;
	left: 50%;
	transform: translate(-50%, -50%);
	background: #f5c200;
	color: var(--color-primary);
	font-size: 0.82rem;
	font-weight: 700;
	padding: 7px 22px;
	border-radius: 6px;
	white-space: nowrap;
	letter-spacing: 0.04em;
}

.plan-badge--popular {
	background: #f5c200;
}

.plan-name {
	font-size: 1rem;
	font-weight: 700;
	color: var(--color-primary);
	text-align: center;
	margin-bottom: 16px;
}

.plan-price {
	text-align: center;
	margin-bottom: 8px;
	padding-top: 4px;
}

.plan-price__label {
	font-size: 0.88rem;
	font-weight: 700;
	color: var(--color-primary);
	padding-bottom: 8px;
	align-self: flex-end;
	margin-right: 2px;
}

.plan-price__row {
	display: flex;
	align-items: flex-end;
	justify-content: center;
	gap: 3px;
	line-height: 1;
}

.plan-price__amount {
	font-size: clamp(3rem, 5vw, 4rem);
	font-weight: 900;
	color: var(--color-secondary);
	line-height: 1;
	letter-spacing: -0.02em;
}

.plan-price__unit {
	font-size: 1.1rem;
	color: var(--color-muted);
	padding-bottom: 6px;
}

.plan-price__tax {
	font-size: 0.78rem;
	color: var(--color-muted);
	margin-top: 6px;
}

.plan-price__sub {
	font-size: 0.82rem;
	font-weight: 700;
	color: var(--color-muted);
	text-align: center;
	line-height: 1.7;
	border-bottom: 1px solid var(--color-border);
	padding-bottom: 20px;
	margin-bottom: 20px;
}

.plan-features {
	margin-bottom: 28px;
	flex-grow: 1;
}

.plan-feature {
	display: flex;
	align-items: center;
	gap: 10px;
	padding: 10px 0;
	border-bottom: 1px solid var(--color-border);
	font-size: 0.92rem;
	color: var(--color-text);
}

.plan-feature:last-child { border-bottom: none; }

.plan-feature__check {
	flex-shrink: 0;
	width: 22px;
	height: 22px;
	background: var(--color-icon-bg);
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	color: var(--color-secondary);
}

.plan-feature__check svg { width: 13px; height: 13px; }

.plan-btn { width: 100%; margin-top: auto; }

/* Payment method row */
.pricing__payment {
	max-width: 860px;
	margin: 40px auto 0;
	background: rgba(255,255,255,0.08);
	border: 1px solid rgba(255,255,255,0.14);
	border-radius: var(--radius-lg);
	padding: 24px 32px;
}

.pricing__payment-inner {
	display: flex;
	justify-content: space-between;
	align-items: center;
	gap: 24px;
	flex-wrap: wrap;
}

.pricing__payment-label {
	font-size: 0.72rem;
	font-weight: 700;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	color: rgba(255,255,255,0.5);
	margin-bottom: 6px;
}

.pricing__payment-method {
	font-size: 0.92rem;
	font-weight: 600;
	color: rgba(255,255,255,0.88);
}

.pricing__payment-cards {
	display: flex;
	gap: 10px;
	align-items: center;
	flex-wrap: wrap;
}

.pricing__card-logo {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	background: #fff;
	border-radius: 4px;
	padding: 5px 12px;
	font-size: 0.75rem;
	font-weight: 700;
	color: var(--color-primary);
	letter-spacing: 0.03em;
	min-width: 52px;
}

/* ===== Flow ===== */
.flow {
	position: relative;
}

.flow__watermark {
	position: absolute;
	top: 0;
	right: calc((100vw - var(--container-max)) / 2 + var(--container-pad));
	transform: translateY(-50%);
	font-size: clamp(5rem, 12vw, 10rem);
	font-weight: 900;
	color: rgba(0, 0, 0, 0.045);
	line-height: 1;
	pointer-events: none;
	user-select: none;
	letter-spacing: -0.02em;
	z-index: 10;
}

.flow__steps {
	display: flex;
	flex-direction: column;
	max-width: 760px;
	margin: 0 auto;
}

.flow-step {
	display: flex;
	align-items: center;
	gap: 20px;
	padding: 22px 36px;
	background: #fff;
	border: 2px solid #f5c200;
	border-radius: 50px;
}

.flow-step__num {
	font-size: 0.88rem;
	font-weight: 700;
	color: var(--color-primary);
	white-space: nowrap;
	letter-spacing: 0.02em;
	flex-shrink: 0;
}

.flow-step__num strong {
	font-size: 1.5rem;
	font-weight: 900;
	letter-spacing: -0.02em;
	display: inline-block;
	margin-left: 1px;
}

.flow-step__sep {
	color: rgba(0,0,0,0.2);
	font-size: 1.1rem;
	flex-shrink: 0;
}

.flow-step__text {
	font-size: 0.95rem;
	color: var(--color-text);
	line-height: 1.7;
}

.flow-arrow {
	display: flex;
	justify-content: center;
	padding: 4px 0;
	color: #f5c200;
}

.flow-arrow svg { width: 28px; height: 28px; }

/* ===== FAQ ===== */
.faq {
	position: relative;
}

.faq__watermark {
	position: absolute;
	top: 0;
	left: calc((100vw - var(--container-max)) / 2 + var(--container-pad));
	transform: translateY(-50%);
	font-size: clamp(5rem, 12vw, 10rem);
	font-weight: 900;
	color: rgba(0, 0, 0, 0.045);
	line-height: 1;
	pointer-events: none;
	user-select: none;
	letter-spacing: -0.02em;
	z-index: 10;
}

.faq__list {
	max-width: 760px;
	margin: 0 auto;
}
.faq__item {
	border-bottom: 1px solid var(--color-border);
}
.faq__item:first-child { border-top: 1px solid var(--color-border); }
.faq__question {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 16px;
	width: 100%;
	padding: 20px 4px;
	background: none;
	border: none;
	cursor: pointer;
	text-align: left;
	font-size: 0.95rem;
	font-weight: 600;
	color: var(--color-primary);
	transition: color var(--transition);
}
.faq__question:hover { color: var(--color-secondary); }
.faq__icon {
	flex-shrink: 0;
	width: 26px; height: 26px;
	background: var(--color-secondary);
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	color: #fff;
	transition: transform var(--transition), background var(--transition);
}
.faq__icon svg { width: 14px; height: 14px; }
.faq__item.is-open .faq__icon {
	transform: rotate(45deg);
	background: var(--color-primary);
}
.faq__answer {
	max-height: 0;
	overflow: hidden;
	transition: max-height 0.35s ease;
}
.faq__item.is-open .faq__answer { max-height: 240px; }
.faq__answer-inner {
	padding: 0 4px 20px;
	font-size: 0.9rem;
	color: var(--color-muted);
	line-height: 1.9;
}

/* ===== Contact ===== */
.contact {
	background: #3db87a;
	position: relative;
}

.contact__watermark {
	position: absolute;
	top: 0;
	left: 50%;
	transform: translateX(-50%) translateY(-50%);
	font-size: clamp(5rem, 12vw, 10rem);
	font-weight: 900;
	color: rgba(255, 255, 255, 0.15);
	line-height: 1;
	pointer-events: none;
	user-select: none;
	letter-spacing: -0.02em;
	white-space: nowrap;
	z-index: 0;
}

.contact .container {
	position: relative;
	z-index: 1;
}

.contact__sub {
	text-align: center;
	color: rgba(255,255,255,0.85);
	font-size: 0.9rem;
	margin-top: 16px;
	margin-bottom: 40px;
}
.contact-notice {
	max-width: 660px;
	margin: 0 auto 28px;
	padding: 16px 20px;
	border-radius: var(--radius);
	font-size: 0.9rem;
	font-weight: 600;
	text-align: center;
}
.contact-notice--success {
	background: rgba(56,161,105,0.15);
	color: #68d391;
	border: 1px solid rgba(56,161,105,0.35);
}
.contact-notice--error {
	background: rgba(229,62,62,0.12);
	color: #fc8181;
	border: 1px solid rgba(229,62,62,0.3);
}
.contact-form {
	max-width: 660px;
	margin: 0 auto;
	background: #fff;
	border-radius: var(--radius-lg);
	padding: 40px 48px;
}
.form-row {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 20px;
}
.form-group { margin-bottom: 20px; }
.form-group label {
	display: block;
	font-size: 0.88rem;
	font-weight: 600;
	color: var(--color-primary);
	margin-bottom: 8px;
}
.form-required {
	font-size: 0.72rem;
	color: #e53e3e;
	font-weight: 700;
	margin-left: 6px;
	vertical-align: middle;
}
.form-optional {
	font-size: 0.72rem;
	color: var(--color-muted);
	font-weight: 400;
	margin-left: 6px;
}
.contact-form input,
.contact-form textarea {
	width: 100%;
	padding: 12px 16px;
	background: var(--color-bg-light);
	border: 1.5px solid var(--color-border);
	border-radius: var(--radius);
	font-size: 0.95rem;
	font-family: var(--font-base);
	color: var(--color-text);
	transition: border-color var(--transition), box-shadow var(--transition);
	outline: none;
	-webkit-appearance: none;
	appearance: none;
}
.contact-form input::placeholder,
.contact-form textarea::placeholder { color: var(--color-border); }
.contact-form input:focus,
.contact-form textarea:focus {
	border-color: var(--color-secondary);
	box-shadow: 0 0 0 3px rgba(46,125,84,0.12);
	background: #fff;
}
.contact-form textarea { resize: vertical; min-height: 140px; }
.form-submit { text-align: center; margin-top: 32px; }

/* ===== Company ===== */
.company__inner {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 56px;
	align-items: center;
}
.company__message .section-label { display: block; margin-bottom: 12px; }
.company__title {
	font-size: clamp(1.3rem, 2.5vw, 1.8rem);
	font-weight: 700;
	color: var(--color-primary);
	line-height: 1.6;
	margin-bottom: 20px;
}
.company__text {
	font-size: 0.9rem;
	color: var(--color-muted);
	line-height: 2;
}
.company__info {
	background: #fff;
	border: 1px solid rgba(0,0,0,0.07);
	border-radius: var(--radius-lg);
	padding: 32px;
}
.company__info-title {
	font-size: 1rem;
	font-weight: 700;
	color: var(--color-secondary);
	margin-bottom: 20px;
	padding-bottom: 12px;
	border-bottom: 1px solid rgba(0,0,0,0.08);
}
.company__dl { display: flex; flex-direction: column; gap: 0; }
.company__row {
	display: grid;
	grid-template-columns: 80px 1fr;
	gap: 12px;
	padding: 12px 0;
	border-bottom: 1px solid rgba(0,0,0,0.06);
}
.company__row:last-child { border-bottom: none; }
.company__row dt {
	font-size: 0.8rem;
	font-weight: 700;
	color: var(--color-muted);
}
.company__row dd {
	font-size: 0.88rem;
	color: var(--color-primary);
	line-height: 1.7;
}

/* ===== Site Footer ===== */
.site-footer {
	background: #3db87a;
	color: rgba(255,255,255,0.65);
	padding: 72px 0 0;
}

.footer__inner {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 64px;
	padding-bottom: 56px;
	border-bottom: 1px solid rgba(255,255,255,0.08);
}

.footer__logo {
	display: flex;
	align-items: center;
	font-size: 1.15rem;
	font-weight: 700;
	color: #fff;
	margin-bottom: 16px;
	letter-spacing: 0.02em;
}

.footer__logo a {
	display: inline-flex;
	align-items: center;
	color: #fff;
}

.footer__logo .custom-logo-link {
	max-width: min(260px, 100%);
}

.footer__logo .custom-logo {
	max-height: 56px;
}

.footer__tagline {
	font-size: 0.85rem;
	line-height: 1.9;
	color: rgba(255,255,255,0.5);
	margin-bottom: 32px;
}

.footer__cta {
	display: inline-flex;
	padding: 14px 32px;
	font-size: 0.88rem;
}

.footer__links-heading {
	font-size: 0.7rem;
	font-weight: 700;
	letter-spacing: 0.2em;
	color: rgba(255,255,255,0.35);
	margin-bottom: 20px;
	text-transform: uppercase;
}

.footer-menu {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 4px 24px;
}

.footer-menu li a {
	display: block;
	font-size: 0.88rem;
	color: rgba(255,255,255,0.65);
	padding: 8px 0;
	border-bottom: 1px solid rgba(255,255,255,0.06);
	transition: color var(--transition);
}

.footer-menu li a:hover { color: #f5c200; }

.footer__bottom {
	display: flex;
	justify-content: space-between;
	align-items: center;
	padding: 24px 0;
	gap: 16px;
}

.footer__copy {
	font-size: 0.78rem;
	color: rgba(255,255,255,0.3);
}

.footer__privacy {
	font-size: 0.78rem;
	color: rgba(255,255,255,0.4);
	transition: color var(--transition);
}

.footer__privacy:hover { color: var(--color-accent); }

/* ===== Responsive ===== */
@media (max-width: 768px) {
	:root { --header-h: 60px; }

	.section { padding: 110px 0; }
	.section-header { margin-bottom: 40px; }

	/* Ghost watermarks — fix off-screen calc on narrow viewports */
	.reasons__watermark,
	.services__watermark,
	.faq__watermark { left: var(--container-pad); }

	.pricing__watermark,
	.flow__watermark { right: var(--container-pad); }

	.contact__watermark {
		left: 50%;
		transform: translateX(-50%) translateY(-50%);
	}

	.reasons__watermark { font-size: 4rem; }

	/* Header */
	.menu-toggle { display: flex; }
	.custom-logo-link { max-width: min(220px, 58vw); }
	.custom-logo { max-height: 42px; }
	.nav-menu {
		position: fixed;
		inset: 0;
		background: var(--color-primary);
		flex-direction: column;
		justify-content: center;
		align-items: center;
		gap: 36px;
		transform: translateX(100%);
		transition: transform 0.32s ease;
		z-index: 999;
	}
	.nav-menu.is-open { transform: translateX(0); }
	.nav-menu li a {
		font-size: 1.1rem;
		color: rgba(255,255,255,0.9);
	}
	.nav-menu > li:last-child > a {
		padding: 12px 32px;
		font-size: 1.1rem;
	}
	body.menu-open { overflow: hidden; }

	/* FV */
	.fv {
		height: 100vh;
		height: 100svh;
		min-height: 100svh;
		background-position: center;
		background-size: cover;
	}
	.fv__content { max-width: 100%; }
	.fv__title { font-size: 1.6rem; }
	.fv__cta { flex-direction: column; }
	.fv__cta .btn { width: 100%; justify-content: center; }

	/* Trust */
	.trust__list { gap: 0; justify-content: flex-start; }
	.trust__item {
		width: 33.33%;
		padding: 12px 8px;
	}
	.trust__item + .trust__item::before { display: none; }

	/* Pain */
	.pain { padding-top: 64px; }
	.pain__heading { font-size: 1.05rem; white-space: normal; }
	.pain__heading-tail { display: block; }
	.pain__cards { grid-template-columns: 1fr; gap: 24px; }
	.pain__card-media { aspect-ratio: 1 / 1; max-width: 160px; }
	.pain__resolve {
		margin-top: 48px;
		padding-top: 2.5rem;
		padding-bottom: 2.5rem;
	}
	.pain__resolve p {
		display: inline-flex;
		align-items: center;
		justify-content: center;
		gap: 8px;
		max-width: 100%;
		font-size: clamp(1.02rem, 4.5vw, 1.55rem);
		line-height: 1.55;
		letter-spacing: 0.01em;
	}
	.pain__resolve-copy { display: block; white-space: nowrap; }
	.pain__resolve-break { display: block; }
	.pain__resolve p::before,
	.pain__resolve p::after {
		content: '';
		display: block;
		width: 2px;
		height: 3.7em;
		margin: 0;
		background: #f5c200;
		border-radius: 2px;
		flex: 0 0 auto;
	}
	.pain__resolve p::before { transform: rotate(-18deg); }
	.pain__resolve p::after { transform: rotate(18deg); }

	/* About */
	.about__grid { grid-template-columns: 1fr; gap: 36px; }
	.about__title { text-align: center; }
	.about__title--nowrap {
		font-size: clamp(1.14rem, 5.2vw, 1.5rem);
		letter-spacing: 0;
		white-space: nowrap;
	}
	.about__divider { margin: 16px auto 24px; }

	/* Reasons */
	.reasons__grid { grid-template-columns: 1fr; }
	.reasons__watermark { font-size: 4rem; }

	/* Services */
	.service-item { grid-template-columns: 1fr; }
	.service-item__image { min-height: 120px; }
	.service-item__body { padding: 24px; }
	.service-item__btn { margin: 0 24px 24px auto; }

	/* Pricing */
	.pricing__grid { grid-template-columns: 1fr; max-width: 440px; }
	.plan-price__sub { text-align: center; }
	.plan-price__sub-break { display: block; }
	.pricing__payment-inner { flex-direction: column; align-items: flex-start; }

	/* Flow */
	.flow-step { padding: 18px 24px; gap: 14px; border-radius: 40px; }
	.flow-step__num strong { font-size: 1.2rem; }

	/* FAQ */
	.faq__question { font-size: 0.9rem; }

	/* Contact */
	.form-row { grid-template-columns: 1fr; }
	.contact__title {
		font-size: clamp(1.05rem, 5.5vw, 1.6rem);
		line-height: 1.55;
		letter-spacing: 0;
		white-space: nowrap;
	}
	.contact__sub { margin-top: 12px; }
	.contact-form { padding: 28px 24px; }

	/* Company */
	.company__inner { grid-template-columns: 1fr; gap: 32px; }

	/* Footer */
	.footer__inner { grid-template-columns: 1fr; gap: 40px; }
	.footer-menu { grid-template-columns: 1fr 1fr; }
	.footer__bottom { flex-direction: column; text-align: center; gap: 10px; }
}

@media (max-width: 480px) {
	.trust__item { width: 50%; }
	.trust__item:nth-child(5) { width: 100%; }
}
