:root {
	--lp-primary: #7d5c3b;
	--lp-accent: #a28365;
	--lp-soft: #ebe1d7;
	--lp-text: #2b3a42;
}

body {
	color: var(--lp-text);
	line-height: 1.8;
	font-size: 17px;
	background: linear-gradient(180deg, #f8fcff 0%, #ffffff 320px);
}

h1,
h2,
h3,
h4 {
	line-height: 1.45;
}

.lp-hero {
	padding: 88px 0 52px;
	background: radial-gradient(circle at 12% 0%, #d9edf5 0%, rgba(217, 237, 245, 0) 52%), linear-gradient(120deg, #ffffff 0%, #f0f8fb 100%);
}

.lp-badge {
	display: inline-block;
	background: var(--lp-soft);
	color: var(--lp-primary);
	border: 1px solid #c9e3ee;
	padding: 6px 12px;
	border-radius: 30px;
	font-size: 14px;
	font-weight: 700;
	margin-bottom: 14px;
}

.lp-title {
	font-size: clamp(28px, 5.2vw, 44px);
	margin-bottom: 12px;
}

.lp-sub {
	font-size: clamp(18px, 3.8vw, 22px);
	font-weight: 500;
	margin-bottom: 18px;
}

.lp-card {
	background: #fff;
	border: 1px solid #dcecf4;
	border-radius: 16px;
	padding: 22px;
	box-shadow: 0 8px 30px rgba(26, 88, 109, 0.06);
}

.lp-section {
	padding: 64px 0;
}

.lp-section.bg-soft {
	background: var(--lp-soft);
}

.lp-section-title {
	font-size: clamp(24px, 4.2vw, 34px);
	margin-bottom: 16px;
}

.notice-list li,
.check-list li {
	margin-bottom: 10px;
}

.step-item {
	display: flex;
	gap: 16px;
	padding: 16px;
	border: 1px solid #dcecf4;
	border-radius: 12px;
	background: #fff;
	height: 100%;
}

.step-number {
	width: 36px;
	height: 36px;
	border-radius: 50%;
	background: var(--lp-primary);
	color: #fff;
	font-weight: 700;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
}

.placeholder-box {
	min-height: 160px;
	border: 2px dashed #bdd9e5;
	border-radius: 14px;
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 20px;
	text-align: center;
	color: #5d7b89;
	background: #f9fdff;
}

.cta-band {
	background: linear-gradient(120deg, var(--lp-primary) 0%, var(--lp-accent) 100%);
	color: #fff;
	padding: 28px;
	border-radius: 16px;
}

.cta-band .btn-light {
	color: var(--lp-primary);
	font-weight: 700;
}

.sticky-call {
	position: fixed;
	bottom: 14px;
	left: 12px;
	right: 12px;
	z-index: 999;
	display: none;
	gap: 10px;
}

.sticky-call a {
	flex: 1;
	text-align: center;
	padding: 13px 10px;
	border-radius: 999px;
	font-weight: 700;
	font-size: 15px;
	box-shadow: 0 8px 18px rgba(21, 68, 86, 0.25);
}

.sticky-call .tel {
	background: var(--lp-primary);
	color: #fff;
}

.sticky-call .form {
	background: #fff;
	color: var(--lp-primary);
	border: 1px solid var(--lp-primary);
}

@media (max-width: 991px) {
	.lp-hero {
		padding-top: 72px;
	}

	.sticky-call {
		display: flex;
	}

	body {
		padding-bottom: 84px;
	}
}

html {
	scroll-behavior: smooth;
}

.site-header.style-2 .header-nav .lp-header-nav > li > a {
	font-size: 14px;
	font-weight: 600;
	padding-left: 14px;
	padding-right: 14px;
}

.site-header.style-2 .extra-nav .btn {
	white-space: nowrap;
}

.hero-intro-box {
	max-width: 820px;
	margin-top: 18px;
	margin-bottom: 40px;
	padding: 18px 22px;
	border-radius: 14px;
	background: rgba(8, 34, 53, 0.64);
	border: 1px solid rgba(255, 255, 255, 0.32);
	backdrop-filter: blur(3px);
	-webkit-backdrop-filter: blur(3px);
	color: #ffffff;
	line-height: 1.9;
	text-shadow: 0 1px 2px rgba(0, 0, 0, 0.22);
}

.hero-intro-box,
.hero-intro-box * {
	color: #ffffff !important;
}

.hero-intro-box p {
	margin: 0;
	font-size: 16px;
}

.hero-intro-box p + p {
	margin-top: 10px;
}

.hero-intro-box .hero-intro-title {
	font-size: 18px;
	font-weight: 700;
	color: #ffffff !important;
	margin-top: 16px !important;
	margin-bottom: 12px;
	padding-bottom: 10px;
	border-bottom: 1px solid rgba(255, 255, 255, 0.28);
}

.hero-intro-box .hero-intro-note {
	margin-top: 12px;
	padding: 10px 12px;
	border-radius: 10px;
	background: rgba(255, 255, 255, 0.13);
	font-weight: 600;
}

@media (max-width: 1199px) {
	.site-header.style-2 .header-nav .lp-header-nav > li > a {
		font-size: 15px;
		padding: 12px 18px;
	}
}

@media (max-width: 767.98px) {
	.hero-intro-box {
		padding: 14px 14px;
		margin-bottom: 28px;
	}

	.hero-intro-box p {
		font-size: 14px;
		line-height: 1.85;
	}

	.hero-intro-box .hero-intro-title {
		font-size: 16px;
		margin-bottom: 10px;
		padding-bottom: 8px;
	}
}

/* MESSAGE */
.pre-consultation-note {
  background: linear-gradient(180deg, #f7fbf8 0%, #eef6f1 100%);
  padding: 56px 0;
}

.pre-consultation-head {
  margin-bottom: 30px;
}

.pre-consultation-label {
  display: inline-block;
  background: #e3f1e8;
  color: #4f7a61;
  font-size: 0.85rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  padding: 6px 14px;
  border-radius: 999px;
  margin-bottom: 14px;
}

.pre-consultation-head h3 {
  font-size: 1.55rem;
  font-weight: 700;
  color: #2f4b3a;
  margin-bottom: 12px;
}

.pre-consultation-head p {
  margin: 0;
  color: #5f6f65;
  font-size: 0.98rem;
  line-height: 1.8;
}

.pre-consultation-card {
  background: #ffffff;
  border: 1px solid #dce9e1;
  border-radius: 16px;
  padding: 28px 20px 24px;
  text-align: center;
  height: 100%;
  box-shadow: 0 10px 24px rgba(58, 92, 70, 0.06);
  transition: transform 0.2s ease, box-shadow 0.2s ease;
}

.pre-consultation-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 16px 32px rgba(58, 92, 70, 0.1);
}

.pre-consultation-icon {
  width: 52px;
  height: 52px;
  margin: 0 auto 16px;
  border-radius: 50%;
  background: linear-gradient(135deg, #b9d9c2 0%, #d9eee0 100%);
  color: #3d6a50;
  font-weight: 700;
  font-size: 0.95rem;
  display: flex;
  align-items: center;
  justify-content: center;
}

.pre-consultation-card p {
  margin: 0;
  color: #34483a;
  font-size: 1rem;
  font-weight: 600;
  line-height: 1.8;
}

@media (max-width: 767.98px) {
  .pre-consultation-note {
    padding: 44px 0;
  }

  .pre-consultation-head h3 {
    font-size: 1.3rem;
  }

  .pre-consultation-card {
    padding: 24px 18px 22px;
  }

  .pre-consultation-card p {
    font-size: 0.96rem;
  }
}


/* Flow */
.flow-section .section-head {
	max-width: 760px;
	margin-left: auto;
	margin-right: auto;
}

.flow-lead {
	color: #6b7280;
	line-height: 1.9;
	margin-bottom: 0;
}

.flow-list {
	max-width: 900px;
	margin: 0 auto;
	position: relative;
}

.flow-step {
	position: relative;
}

.flow-step + .flow-step {
	margin-top: 18px;
}

.flow-card {
	display: flex;
	align-items: flex-start;
	gap: 18px;
	padding: 24px 22px;
	background: #fff;
	border: 1px solid #e4efe8;
	border-radius: 16px;
	box-shadow: 0 10px 30px rgba(31, 61, 45, 0.05);
	width: 100%;
}

.flow-card .step-number {
	flex: 0 0 54px;
	width: 54px;
	height: 54px;
	border-radius: 50%;
	background: linear-gradient(135deg, #dff1e6 0%, #cfe8d8 100%);
	color: #2f6b4f;
	font-size: 18px;
	font-weight: 700;
	display: flex;
	align-items: center;
	justify-content: center;
	line-height: 1;
	margin-top: 2px;
}

.flow-card .step-content {
	flex: 1;
	min-width: 0;
}

.flow-card .step-title {
	font-size: 1.1rem;
	font-weight: 700;
	color: #22352b;
	margin-bottom: 8px;
	line-height: 1.5;
}

.flow-card p {
	color: #58656a;
	line-height: 1.8;
}

.flow-cta {
	border-radius: 18px;
	padding: 28px 30px;
	max-width: 900px;
	margin-left: auto;
	margin-right: auto;
}

/* スクロール表示前 */
.scroll-fade-up {
	opacity: 0;
	transform: translateY(40px);
	transition: opacity 0.8s ease, transform 0.8s ease;
	will-change: opacity, transform;
}

/* 表示時 */
.scroll-fade-up.is-visible {
	opacity: 1;
	transform: translateY(0);
}

@media (max-width: 991.98px) {
	.flow-card {
		padding: 22px 18px;
		gap: 14px;
	}

	.flow-card .step-number {
		width: 48px;
		height: 48px;
		font-size: 16px;
		flex-basis: 48px;
	}

	.flow-card .step-title {
		font-size: 1rem;
	}

	.flow-cta {
		padding: 24px 20px;
	}
}

@media (max-width: 767.98px) {
	.flow-lead br {
		display: none;
	}

	.flow-card {
		border-radius: 14px;
		padding: 18px 16px;
		gap: 12px;
	}

	.flow-card .step-number {
		width: 42px;
		height: 42px;
		font-size: 15px;
		flex-basis: 42px;
	}

	.flow-card .step-title {
		font-size: 0.98rem;
		margin-bottom: 6px;
	}

	.flow-card p {
		font-size: 0.95rem;
		line-height: 1.7;
	}

	.m-b10-sm {
		margin-bottom: 10px;
	}
}



.consultation-section .consultation-note {
	margin: 20px 0 24px;
	padding: 18px 20px;
	border-radius: 12px;
	background: #f4f8fb;
	border-left: 4px solid #2f80c1;
}

.consultation-section .consultation-list li {
	margin-bottom: 10px;
}

.consultation-actions {
	display: flex;
	flex-wrap: wrap;
	gap: 12px;
	margin-top: 28px;
}

.consultation-btn {
	min-width: 220px;
	text-align: center;
}

.consultation-btn-sub {
	background: #fff;
	border: 1px solid #2f80c1;
	color: #2f80c1;
}

.consultation-btn-sub:hover {
	background: #2f80c1;
	color: #fff;
}

.consultation-subtext {
	margin-top: 18px;
	font-size: 0.95rem;
	line-height: 1.8;
	color: #666;
}

.consultation-media img {
	border-radius: 16px;
}

@media (max-width: 767.98px) {
	.consultation-actions {
		flex-direction: column;
	}

	.consultation-btn {
		width: 100%;
		min-width: auto;
	}
}
/* consultation download */
.consultation-download-section .consultation-lead{
	max-width: 760px;
	margin: 15px auto 0;
	line-height: 1.9;
}

.consultation-number{
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 100%;
	height: 100%;
	font-size: 16px;
	font-weight: 700;
	color: #fff;
	position: relative;
	z-index: 2;
}

.consultation-center-image img{
	max-width: 100%;
	height: auto;
}

.consultation-download-bottom{
	margin-top: 20px;
}

.consultation-download-bottom__inner{
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 30px;
	padding: 32px;
	border: 1px solid #e6edf5;
	border-radius: 20px;
	background: #ffffff;
	box-shadow: 0 10px 30px rgba(0,0,0,0.06);
}

.consultation-download-bottom__text{
	flex: 1 1 auto;
}

.consultation-download-bottom__text h3{
	font-size: 28px;
	margin-bottom: 12px;
}

.consultation-download-bottom__text p{
	margin-bottom: 0;
	line-height: 1.9;
}

.consultation-download-bottom__buttons{
	flex: 0 0 280px;
	display: flex;
	flex-direction: column;
	gap: 12px;
}

.btn-download{
	width: 100%;
	text-align: center;
	justify-content: center;
}

.btn-outline-primary{
	background: #fff;
	border: 1px solid var(--primary);
	color: var(--primary);
}

.btn-outline-primary:hover{
	background: var(--primary);
	color: #fff;
}

.consultation-footer-note{
	max-width: 860px;
	margin: 18px auto 0;
	text-align: center;
}

.consultation-footer-note p{
	line-height: 1.9;
	margin-bottom: 0;
	color: #555;
}

/* 追加：ホバー時の数字丸背景をオレンジ固定 */
.consultation-download-section .icon-bx-wraper:hover .icon-bx-sm,
.consultation-download-section .icon-bx-wraper.active .icon-bx-sm{
	background: #f28c28 !important;
	border-color: #f28c28 !important;
}

/* 追加：ホバー時も数字は白で固定 */
.consultation-download-section .icon-bx-wraper:hover .consultation-number,
.consultation-download-section .icon-bx-wraper.active .consultation-number{
	color: #fff !important;
}

/* 念のため、リンクやアイコンの色影響を受けないようにする */
.consultation-download-section .icon-bx-wraper:hover .icon-cell,
.consultation-download-section .icon-bx-wraper.active .icon-cell{
	color: #fff !important;
}

@media only screen and (max-width: 991px){
	.consultation-download-bottom__inner{
		flex-direction: column;
		align-items: stretch;
		padding: 24px;
	}

	.consultation-download-bottom__buttons{
		flex: 1 1 auto;
		width: 100%;
	}

	.consultation-download-bottom__text h3{
		font-size: 24px;
	}
}

@media only screen and (max-width: 767px){
	.consultation-download-bottom{
		margin-top: 10px;
	}

	.consultation-download-bottom__inner{
		padding: 20px 16px;
		border-radius: 16px;
		gap: 20px;
	}

	.consultation-download-bottom__text p{
		font-size: 14px;
		line-height: 1.8;
	}

	.consultation-download-bottom__buttons{
		gap: 10px;
	}
}


/* ⑤ 当日のご案内 */
.same-day-section .same-day-lead{
	max-width: 720px;
	margin: 15px auto 0;
	line-height: 1.9;
}

.same-day-box{
	margin-top: 30px;
	padding: 40px;
	border-radius: 20px;
	background: #ffffff;
	border: 1px solid #e6edf5;
	box-shadow: 0 10px 30px rgba(0,0,0,0.05);
}

.same-day-list{
	list-style: none;
	padding: 0;
	margin: 0;
}

.same-day-list li{
	padding: 20px 0;
	border-bottom: 1px solid #eef2f6;
	line-height: 1.9;
	font-size: 16px;
}

.same-day-list li:last-child{
	border-bottom: none;
}

.same-day-list strong{
	display: block;
	font-size: 18px;
	color: var(--primary);
	margin-bottom: 6px;
}

/* スマホ最適化 */
@media only screen and (max-width: 767px){
	.same-day-box{
		padding: 24px 18px;
		border-radius: 16px;
	}

	.same-day-list li{
		font-size: 14px;
		padding: 16px 0;
	}

	.same-day-list strong{
		font-size: 16px;
	}
}

.same-day-section .same-day-lead{
	max-width: 720px;
	margin: 15px auto 0;
	line-height: 1.9;
}

.same-day-content{
	margin-top: 30px;
	padding: 36px 32px;
	border: 1px solid #e6edf5;
	border-radius: 20px;
	background: #fff;
	box-shadow: 0 10px 30px rgba(0,0,0,0.05);
}

.same-day-content h4{
	margin-bottom: 24px;
	line-height: 1.6;
}

.same-day-content .list-check-1 li{
	line-height: 1.9;
	margin-bottom: 12px;
}

.same-day-content .list-check-1 li strong{
	color: var(--primary);
	font-weight: 700;
}

.same-day-note{
	margin-top: 10px;
	padding-top: 24px;
	border-top: 1px solid #eef2f6;
}

.same-day-note__inner .title{
	margin-bottom: 10px;
}

.same-day-note__inner p{
	line-height: 1.9;
	color: #555;
}

@media only screen and (max-width: 767px){
	.same-day-content{
		padding: 24px 18px;
		border-radius: 16px;
	}

	.same-day-content h4{
		font-size: 20px;
		margin-bottom: 18px;
	}

	.same-day-content .list-check-1 li{
		margin-bottom: 10px;
		font-size: 14px;
	}

	.same-day-note{
		padding-top: 18px;
	}
}


.oita-section{
	background: var(--lp-soft);
	padding-top: 60px;
	padding-bottom: 60px;
}

.oita-lead{
	max-width: 720px;
	margin: 15px auto 0;
	line-height: 1.9;
	color: #5f6b7a;
}

.oita-card{
	background: #fff;
	border-radius: 18px;
	overflow: hidden;
	box-shadow: 0 10px 30px rgba(0,0,0,0.05);
	border: 1px solid #e6edf5;
	height: 100%;
}

.oita-media img{
	width: 100%;
	height: 220px;
	object-fit: cover;
}

.oita-body{
	padding: 24px;
}

.oita-body h4{
	margin-bottom: 12px;
}

.oita-body p{
	line-height: 1.9;
	margin-bottom: 12px;
}

.oita-body ul{
	padding-left: 18px;
	margin: 0;
}

.oita-body ul li{
	margin-bottom: 6px;
	font-size: 14px;
}

.oita-message{
	margin-top: 40px;
	padding: 24px;
	background: #ffffff;
	border-radius: 14px;
	text-align: center;
	border: 1px solid #e6edf5;
	line-height: 1.9;
}

/* スマホ */
@media only screen and (max-width: 767px){
	.oita-section{
		padding-top: 40px;
		padding-bottom: 40px;
	}

	.oita-media img{
		height: 180px;
	}

	.oita-body{
		padding: 18px;
	}

	.oita-message{
		padding: 18px;
	}
}
.oita-body ul{
	padding-left: 20px;
	margin: 0;
	list-style: disc;
}

.oita-body ul li{
	margin-bottom: 6px;
	font-size: 14px;
	list-style: disc;
}


.faq-lead{
	max-width: 760px;
	margin: 15px auto 0;
	line-height: 1.9;
	color: #666;
}

#faq .accordion-item{
	margin-bottom: 16px;
	border: 1px solid #e6edf5;
	border-radius: 12px;
	overflow: hidden;
	background: #fff;
}

#faq .accordion-button{
	font-weight: 700;
	line-height: 1.7;
	padding: 18px 20px;
	background: #fff;
}

#faq .accordion-button:not(.collapsed){
	background: #f8fbff;
	color: var(--primary);
}

#faq .accordion-body{
	padding: 0 20px 20px;
	line-height: 1.9;
	color: #555;
}

@media only screen and (max-width: 767px){
	.faq-lead{
		font-size: 14px;
		line-height: 1.8;
	}

	#faq .accordion-button{
		padding: 16px;
		font-size: 15px;
	}

	#faq .accordion-body{
		padding: 0 16px 16px;
		font-size: 14px;
	}
}

.dialysis-contact-section .section-head{
	margin-bottom: 24px;
}

.dialysis-contact-lead{
	margin-top: 12px;
	line-height: 1.9;
	opacity: 0.95;
}

/* 事前相談窓口 01〜03：スマホ時は数字を左揃えに */
@media only screen and (max-width: 767px) {
	.section-wraper-left .icon-bx-wraper.right {
		text-align: left;
	}
	.section-wraper-left .icon-bx-wraper.right .icon-bx-xl,
	.section-wraper-left .icon-bx-wraper.right .icon-bx-lg,
	.section-wraper-left .icon-bx-wraper.right .icon-bx-md,
	.section-wraper-left .icon-bx-wraper.right .icon-bx-sm,
	.section-wraper-left .icon-bx-wraper.right .icon-bx-xs {
		float: left;
		margin-left: 0;
		margin-right: 20px;
	}
}

.dialysis-phone-btn{
	min-width: 280px;
	padding: 16px 24px;
	text-align: left;
	border-radius: 16px;
}

.dialysis-phone-btn span{
	display: block;
	font-size: 14px;
	line-height: 1.4;
}

.dialysis-phone-btn .title{
	margin: 4px 0 0;
	font-size: 28px;
	line-height: 1.2;
	letter-spacing: 0.02em;
}

.dialysis-contact-info{
	margin-top: 18px;
	padding: 20px 24px;
	border-radius: 16px;
	background: rgba(255, 255, 255, 0.12);
	backdrop-filter: blur(2px);
}

.dialysis-contact-info p{
	margin-bottom: 10px;
	color: #fff;
	line-height: 1.8;
}

.dialysis-contact-info p:last-child{
	margin-bottom: 0;
}

.dialysis-contact-info .hospital-name{
	font-weight: 700;
	font-size: 18px;
}

.dialysis-contact-info .hospital-tel a{
	color: #fff;
	text-decoration: none;
	font-weight: 700;
}

.dialysis-contact-media img{
	max-width: 100%;
	height: auto;
}

@media only screen and (max-width: 991px){
	.dialysis-contact-media{
		text-align: center;
		margin-top: 20px;
	}

	.dialysis-phone-btn{
		min-width: auto;
		width: 100%;
	}
}

@media only screen and (max-width: 767px){
	.dialysis-contact-lead{
		font-size: 14px;
		line-height: 1.8;
	}

	.dialysis-phone-btn{
		padding: 14px 18px;
		border-radius: 14px;
	}

	.dialysis-phone-btn .title{
		font-size: 24px;
	}

	.dialysis-contact-info{
		padding: 16px 18px;
		border-radius: 14px;
	}

	.dialysis-contact-info .hospital-name{
		font-size: 16px;
	}
}

.pre-consultation-note{
	padding: 40px 0 10px;
}

.pre-title-wrap{
	margin-bottom: 20px;
	text-align: center;
}

.pre-title-sub{
	display: inline-block;
	font-size: 14px;
	font-weight: 600;
	letter-spacing: 0.08em;
	color: var(--primary);
	margin-bottom: 8px;
}

.pre-title-wrap .dz-title{
	margin: 0;
	font-size: 32px;
	line-height: 1.5;
	color: #222;
}

.pre-note-body{
	max-width: 900px;
	margin: 0 auto;
}

.pre-note-body p{
	margin: 0 0 16px;
	line-height: 1.95;
	color: #555;
	text-align: center;
}

.pre-note-body p:last-child{
	margin-bottom: 0;
}

@media only screen and (max-width: 767px){
	.pre-consultation-note{
		padding: 30px 0 0;
	}

	.pre-title-wrap{
		text-align: left;
		margin-bottom: 16px;
	}

	.pre-title-wrap .dz-title{
		font-size: 24px;
		line-height: 1.6;
	}

	.pre-note-body p{
		text-align: left;
		font-size: 14px;
		line-height: 1.85;
		margin-bottom: 14px;
	}
}

/* ヒーロー上下中央揃え */
.banner-three {
	display: flex;
	align-items: center;
	padding-top: 0;
}

.banner-three .container.h-100 {
	display: flex;
	align-items: center;
}

.banner-three .banner-inner.h-100 {
	padding: 110px 0 60px;
}

@media only screen and (max-width: 991px) {
	.banner-three .banner-inner.h-100 {
		padding: 80px 0 50px;
	}
}

@media only screen and (max-width: 767px) {
	.banner-three .banner-inner.h-100 {
		padding: 70px 0 40px;
	}
}