@charset "UTF-8";

/*=========================================
 CSS INFO
 Description : free-transportation css
========================================= */

/* common
========================================= */
#contents {
	width: 100% !important;
}
#pankuzu {
	width: 1004px;
	margin: 0 auto;
}
#ui-datepicker-div{
	z-index: 9999!important;
}
@media (max-width: 767px) {
	#pankuzu{
		width: 100%;
	}
}
@media (min-width: 768px) {
	.totop{
		width: 1004px;
		margin: 0 auto;
	}
}


/* =========================================
 Reset & Base Styles
 ========================================= */
*, *::before, *::after {
	box-sizing: border-box;
	margin: 0;
	padding: 0;
}

:root {
	/* Colors based on Tailwind palette */
	--sky-50: #f0f9ff;
	--sky-100: #e0f2fe;
	--sky-300: #7dd3fc;
	--sky-400: #38bdf8;
	--sky-500: #0ea5e9;
	--sky-600: #0284c7;
	--sky-700: #0369a1;
	--sky-800: #075985;

	--orange-50: #fff7ed;
	--orange-100: #ffedd5;
	--orange-200: #fed7aa;
	--orange-400: #fb923c;
	--orange-500: #f97316;
	--orange-600: #ea580c;

	--amber-50: #fffbeb;

	--emerald-50: #ecfdf5;
	--emerald-100: #d1fae5;
	--emerald-600: #059669;

	--slate-50: #f8fafc;
	--slate-100: #f1f5f9;
	--slate-200: #e2e8f0;
	--slate-300: #cbd5e1;
	--slate-400: #94a3b8;
	--slate-500: #64748b;
	--slate-600: #475569;
	--slate-700: #334155;
	--slate-800: #1e293b;
	--slate-900: #0f172a;

	--red-100: #fee2e2;
	--red-200: #fecaca;
	--red-400: #f87171;
	--red-500: #ef4444;
	--red-600: #dc2626;

	--yellow-50: #fefce8;
	--yellow-400: #facc15;
	--yellow-500: #eab308;

	--white: #ffffff;
}

/*html {
	scroll-behavior: smooth;
	font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
	line-height: 1.6;
	color: var(--slate-800);
	background-color: var(--slate-50);
}

body {
	font-size: 16px;
}

a {
	text-decoration: none;
	color: inherit;
}*/

ul {
	list-style: none;
}

img {
	max-width: 100%;
	height: auto;
}

/* =========================================
 Layout & Utility Classes
 ========================================= */
.container {
	width: 100%;
	margin-right: auto;
	margin-left: auto;
	padding-right: 1rem;
	padding-left: 1rem;
}
@media (max-width: 767px) {
	.container{
		padding-right: 1.5rem;
		padding-left: 1.5rem;
	}
}
.max-w-3xl { max-width: 48rem; } /* 768px */
.max-w-4xl { max-width: 56rem; } /* 896px */
.max-w-5xl { max-width: 64rem; } /* 1024px */
.max-w-6xl { max-width: 72rem; } /* 1152px */

.text-center { text-align: center; }
.font-bold { font-weight: 700; }
.font-extrabold { font-weight: 800; }

.section-padding { padding: 4rem 0; }

.section-header {
	text-align: center;
	margin-bottom: 3rem;
}
.section-title {
	font-size: 1.5rem;
	font-weight: 700;
	color: var(--slate-800);
	margin-bottom: 1rem;
	display: inline-block;
}
.section-title.border-bottom {
	border-bottom: 4px solid var(--sky-400);
	padding-bottom: 0.5rem;
}
.section-desc {
	color: var(--slate-600);
	font-size: 1rem;
}
@media (max-width: 767px) {
	.section-title{
		font-size: 1.8rem;
	}
	.section-desc{
		font-size: 1.4rem;
	}
}

/* Responsive Display Utilities */
.hidden { display: none !important; }
@media (min-width: 768px) {
	.md-block { display: block !important; }
	.md-hidden { display: none !important; }
	.md-flex { display: flex !important; }
	.section-title { font-size: 1.875rem; }
}

/* =========================================
 Components
 ========================================= */
/* Header */
/*.header {
	background-color: var(--white);
	box-shadow: 0 1px 2px 0 rgba(0, 0, 0, 0.05);
	position: sticky;
	top: 0;
	z-index: 50;
}
.header-inner {
	height: 4rem;
	display: flex;
	align-items: center;
	justify-content: space-between;
}
.header-logo {
	font-size: 1.25rem;
	font-weight: 700;
	color: var(--sky-600);
}
.header-nav {
	display: none;
	gap: 1.5rem;
	font-size: 0.875rem;
	font-weight: 500;
	color: var(--slate-600);
}
.header-nav a:hover {
	color: var(--sky-600);
	transition: color 0.3s;
}
@media (min-width: 768px) {
	.header-nav { display: flex; }
}*/

/* Hero Section */
.hero {
	position: relative;
	overflow: hidden;
	background: url("/img/site/free-transportation/free-transportation_mv.jpg") no-repeat center center;
}
.hero:before{
	content: "";
	display: block;
	width: 100%;
	height: 100%;
	background-color: rgba(224, 242, 254, 0.5);
	backdrop-filter: blur(10px);
	position: absolute;
	left: 0;
	top: 0;
}
.hero-bg {
	position: absolute;
	inset: 0;
	opacity: 0.2;
	pointer-events: none;
}
.hero-bg-circle-1 {
	position: absolute;
	top: -6rem;
	right: -6rem;
	width: 24rem;
	height: 24rem;
	background-color: var(--sky-300);
	border-radius: 50%;
	filter: blur(60px);
	mix-blend-mode: multiply;
}
.hero-bg-circle-2 {
	position: absolute;
	top: 8rem;
	left: -6rem;
	width: 18rem;
	height: 18rem;
	background-color: var(--sky-400); /* Adjusted for visual effect */
	border-radius: 50%;
	filter: blur(60px);
	mix-blend-mode: multiply;
}
.hero-content {
	position: relative;
	padding: 3rem 1rem 5rem;
	text-align: center;
}
@media (min-width: 768px) {
	.hero-content { padding: 6rem 1rem 8rem; }
}
.hero-badge {
	display: inline-block;
	padding: 0.25rem 0.75rem;
	border-radius: 9999px;
	background-color: var(--orange-500);
	color: var(--white);
	font-size: 0.875rem;
	font-weight: 700;
	/*border: 1px solid var(--orange-200);*/
	margin-bottom: 1rem;
}
.hero-title {
	font-size: 1.875rem;
	font-weight: 800;
	color: var(--slate-900);
	line-height: 1.2;
	letter-spacing: -0.025em;
	margin-bottom: 1.5rem;
}
.hero-title .highlight { color: var(--sky-600); }
.hero-title .sub {
	display: block;
	font-size: 1.5rem;
	margin-top: 0.5rem;
}
@media (min-width: 768px) {
	.hero-title { font-size: 3rem; }
	.hero-title .sub { font-size: 2.25rem; }
}
.hero-text {
	font-size: 1rem;
	color: var(--slate-600);
	margin-bottom: 2rem;
	max-width: 42rem;
	margin-left: auto;
	margin-right: auto;
}
@media (max-width: 767px) {
	.hero-badge,.hero-text{
		font-size: 1.2rem;
	}
	.hero{
		background-size: contain;
	}
}

/* Search Section */
.search-section {
	position: relative;
	z-index: 20;
	margin-top: -4rem;
	margin-bottom: 3rem;
}
@media (min-width: 768px) {
	.search-section { margin-top: -5rem; }
}
.search-box {
	background-color: var(--white);
	border-radius: 1rem;
	box-shadow: 0 20px 25px -5px rgba(0, 0, 0, 0.1), 0 10px 10px -5px rgba(0, 0, 0, 0.04);
	border: 1px solid var(--slate-100);
	padding: 1.5rem;
}
@media (min-width: 768px) {
	.search-box { padding: 2rem; }
}
.search-box-title {
	font-size: 1.25rem;
	font-weight: 700;
	color: var(--slate-800);
	margin-bottom: 1.5rem;
	border-bottom: 1px solid var(--slate-200);
	padding-bottom: 0.5rem;
}
.search-box-title i { color: var(--sky-500); margin-right: 0.5rem; }
@media (max-width: 767px) {
	.search-box-title{
		font-size: 1.4rem;
	}
}
.search-grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: 1rem;
	margin-bottom: 1.5rem;
}
@media (min-width: 768px) { .search-grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1024px) { .search-grid { grid-template-columns: repeat(4, 1fr); } }
.form-group {
	display: flex;
	flex-direction: column;
}
.form-label {
	font-size: 0.875rem;
	font-weight: 500;
	color: var(--slate-700);
	margin-bottom: 0.25rem;
}
.form-control,
.form-control.dep_datepicker,.form-control.arv_datepicker{
	border: 1px solid var(--slate-300);
	border-radius: 0.5rem;
	padding: 0.625rem;
	color: var(--slate-700);
	background-color: var(--slate-50)!important;
	font-family: inherit;
	font-size: 1rem;
	cursor: pointer;
}
@media (max-width: 767px) {
	.form-group{
		margin-bottom: 3px;
	}
	.form-label{
		font-size: 1.2rem;
	}
	.form-control,.form-control.dep_datepicker,.form-control.arv_datepicker{
		font-size: 1.4rem;
	}
	.form-control.dep_datepicker,.form-control.arv_datepicker{
		background-image: url(/img/rentacar/icon/icon-calendar.png);
		background-position: right center;
		background-repeat: no-repeat;
	}
}
.form-control:focus {
	outline: none;
	border-color: var(--sky-500);
	box-shadow: 0 0 0 2px rgba(14, 165, 233, 0.2);
}
.form-control.dep_datepicker,.form-control.arv_datepicker{
	background-color: var(--slate-50)!important;
}
.search-footer {
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: space-between;
	border-top: 1px solid var(--slate-100);
	padding-top: 1.5rem;
}
@media (min-width: 768px) {
	.search-footer { flex-direction: row; }
}
.checkbox-group {
	display: flex;
	align-items: center;
	margin-bottom: 1rem;
	cursor: pointer;
}
@media (min-width: 768px) { .checkbox-group { margin-bottom: 0; } }
.checkbox-input {
	width: 1.25rem;
	height: 1.25rem;
	accent-color: var(--sky-600);
	cursor: pointer;
}
.checkbox-label {
	margin-left: 0.5rem;
	font-size: 0.875rem;
	font-weight: 700;
	color: var(--slate-700);
	cursor: pointer;
}
.btn-search {
	width: 100%;
	background-color: var(--sky-600);
	color: var(--white);
	font-weight: 700;
	padding: 0.75rem 2.5rem;
	border-radius: 0.5rem;
	border: none;
	box-shadow: 0 4px 6px -1px rgba(0, 0, 0, 0.1);
	cursor: pointer;
	transition: background-color 0.3s;
	font-size: 1rem;
}
@media (max-width: 767px) {
	.checkbox-label{
		font-size: 1.4rem;
		margin-bottom: 0;
	}
	.btn-search{
		font-size: 1.6rem;
	}
}
.btn-search:hover { background-color: var(--sky-700); }
@media (min-width: 768px) { .btn-search { width: auto; } }

/* Flow Section */
.flow-section { background-color: var(--white); }
.flow-grid {
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	gap: 1.5rem;
	position: relative;
}
@media (min-width: 768px) {
	.flow-grid { flex-direction: row; gap: 1rem; }
}
.flow-step {
	width: 100%;
	background-color: var(--slate-50);
	border-radius: 0.75rem;
	padding: 1.5rem;
	text-align: center;
	border: 1px solid var(--slate-100);
	z-index: 10;
}
.flow-step.highlight {
	background-color: var(--sky-50);
	border-color: var(--sky-100);
}
@media (min-width: 768px) { .flow-step { width: 33.333%; } }
.flow-icon {
	width: 4rem;
	height: 4rem;
	background-color: var(--sky-100);
	color: var(--sky-600);
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	margin: 0 auto 1rem;
	font-size: 1.5rem;
}
.flow-step.highlight .flow-icon {
	background-color: var(--sky-600);
	color: var(--white);
}
.flow-image{
	margin-bottom: 20px;
}
.flow-image img{
	max-width: 100%;
}
.flow-step-title {
	font-weight: 700;
	font-size: 1.125rem;
	margin-bottom: 0.5rem;
}
.flow-step.highlight .flow-step-title { color: var(--sky-800); }
.flow-step-desc {
	font-size: 0.875rem;
	color: var(--slate-600);
}
.flow-arrow {
	color: var(--sky-300);
	font-size: 1.875rem;
	z-index: 0;
	display: none;
}
.flow-arrow.mobile {
	display: block;
	transform: rotate(90deg);
	margin: -0.625rem 0;
}
@media (min-width: 768px) {
	.flow-arrow { display: block; }
	.flow-arrow.mobile { display: none; }
}
.flow-note {
	font-size: 0.875rem;
	color: var(--slate-500);
	margin-top: 2rem;
	text-align: center;
}
@media (max-width: 767px) {
	.flow-step-title{
		font-size: 1.6rem;
	}
	.flow-step-desc{
		font-size: 1.4rem;
	}
	.flow-note{
		font-size: 1.2rem;
	}
}

/* Merit/Demerit Section */
.merit-section { background-color: var(--slate-50); }
.merit-grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: 2rem;
}
@media (min-width: 768px) { .merit-grid { grid-template-columns: repeat(2, 1fr); } }

.feature-box {
	background-color: var(--white);
	border-radius: 1rem;
	padding: 2rem;
	box-shadow: 0 1px 2px 0 rgba(0, 0, 0, 0.05);
}
.box-merit { border: 4px solid var(--sky-400); }
.box-demerit { border: 4px solid var(--red-400); }

.box-header {
	display: flex;
	align-items: center;
	margin-bottom: 1.5rem;
}
.box-icon {
	width: 3rem;
	height: 3rem;
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 1.25rem;
	margin-right: 1rem;
}
.box-merit .box-icon { background-color: var(--sky-100); color: var(--sky-600); }
.box-demerit .box-icon { background-color: var(--red-100); color: var(--red-600); }
.box-title {
	font-size: 1.25rem;
	font-weight: 700;
	color: var(--slate-800);
}
.feature-list{
	font-size: 1rem;
}
.feature-list li {
	display: flex;
	align-items: flex-start;
	margin-bottom: 1rem;
}
.feature-list li:last-child { margin-bottom: 0; }
.feature-list i { margin-top: 0.25rem; margin-right: 0.75rem; }
.box-merit .feature-list i { color: var(--sky-500); }
.box-demerit .feature-list i { color: var(--red-500); }
.feature-list span { color: var(--slate-700); }
.text-underline-red { text-decoration: underline; text-decoration-color: var(--red-200); text-decoration-thickness: 2px;}
@media (max-width: 767px) {
	.box-title{
		font-size: 1.6rem;
	}
	.feature-list{
		font-size: 1.4rem;
	}
}

/* Private Transfer Section */
.private-section {
	padding: 3rem 0;
	background: linear-gradient(to right, var(--orange-50), var(--amber-50));
	border-top: 1px solid var(--orange-100);
	border-bottom: 1px solid var(--orange-100);
	text-align: center;
}
.private-title {
	font-size: 1.5rem;
	font-weight: 700;
	color: var(--slate-800);
	margin-bottom: 1rem;
}
.private-desc {
	color: var(--slate-700);
	margin-bottom: 1.5rem;
	line-height: 1.8;
}

/* Points Section */
.points-section {
	background-color: var(--sky-50);
	border-top: 1px solid var(--sky-100);
	border-bottom: 1px solid var(--sky-100);
}
.points-grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: 1.5rem;
}
@media (min-width: 768px) {
	.points-grid { grid-template-columns: repeat(2, 1fr); }
}
.point-card {
	background-color: var(--white);
	border-radius: 1rem;
	padding: 1.5rem;
	box-shadow: 0 4px 6px -1px rgba(0, 0, 0, 0.05);
	border: 1px solid var(--sky-100);
	display: flex;
	flex-direction: column;
	height: 100%;
}
.point-card-header {
	display: flex;
	align-items: center;
	margin-bottom: 1rem;
	padding-bottom: 1rem;
	border-bottom: 1px dashed var(--slate-200);
}
.point-num {
	background-color: var(--sky-500);
	color: var(--white);
	font-weight: 800;
	font-size: 1.25rem;
	width: 2.5rem;
	height: 2.5rem;
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	margin-right: 1rem;
	flex-shrink: 0;
}
.point-title {
	font-size: 1.125rem;
	font-weight: 700;
	color: var(--slate-800);
	line-height: 1.4;
}
.point-img {
	width: 100%;
	aspect-ratio: 21 / 9;
	background-color: var(--slate-200);
	border-radius: 0.5rem;
	overflow: hidden;
	margin-bottom: 1rem;
}
.point-img img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
	transition: transform 0.3s ease;
}
.point-card:hover .point-img img {
	/*transform: scale(1.05);*/
}
.point-desc {
	font-size: 0.875rem;
	color: var(--slate-600);
	line-height: 1.6;
}
@media (max-width: 767px) {
	.point-title{
		font-size: 1.6rem;
	}
	.point-desc{
		font-size: 1.4rem;
	}
}

/* Bus Stop Guide Section */
.bus-stop-section { background-color: var(--white); }
.bus-stop-card {
	background-color: var(--slate-100);
	border-radius: 1rem;
	padding: 1.5rem;
	display: flex;
	flex-direction: column;
	gap: 1.5rem;
}
.bus-stop-card .leaflet-container{
	background: #eef2f2;
}
@media (min-width: 768px) {
	.bus-stop-card { padding: 2rem; gap: 2rem; }
}
/* Leaflet Map Container Style */
.bus-stop-map {
	width: 100%;
	height: 300px; /* スマホ用高さ */
	background-color: var(--slate-200);
	border-radius: 0.5rem;
	border: 2px solid var(--slate-300);
	z-index: 1; /* ヘッダー等との重なりを防ぐ */
}
.bus-stop-map.leaflet-touch .leaflet-bar a{
	width: 42px;
	height: 42px;
	line-height: 42px;
}
@media (min-width: 768px) { 
	.bus-stop-map { height: 450px; } /* PC用高さ */
}
/* Leafletのコントロールを少しカスタマイズ */
.leaflet-container {
	font-family: inherit;
}
/*.bus-stop-img {
	width: 100%;
	aspect-ratio: 16 / 9;
	background-color: var(--slate-200);
	border-radius: 0.5rem;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	color: var(--slate-500);
	border: 2px dashed var(--slate-300);
	text-align: center;
	min-height: 300px;
}
@media (min-width: 768px) { .bus-stop-img { aspect-ratio: 21 / 9; } }*/
.bus-stop-info { width: 100%; }

.bus-stop-info h3 {
	font-size: 1.125rem;
	font-weight: 700;
	margin-bottom: 0.75rem;
	color: var(--sky-700);
}
.bus-stop-info p {
	color: var(--slate-600);
	font-size: 0.875rem;
	margin-bottom: 1rem;
	line-height: 1.8;
}
.alert-box {
	background-color: var(--yellow-50);
	border-left: 4px solid var(--yellow-400);
	padding: 1rem;
	border-radius: 0.25rem;
	font-size: 0.875rem;
	color: var(--slate-700);
}
@media (max-width: 767px) {
	.bus-stop-info h3{
		font-size: 1.6rem;
	}
	.bus-stop-info p,.alert-box{
		font-size: 1.4rem;
	}
}

/* Companies Section */
.companies-section { background-color: var(--slate-50); }
.companies-wrap { display: flex; flex-direction: column; gap: 2rem; }

.company-card {
	background-color: var(--white);
	border-radius: 0.75rem;
	box-shadow: 0 1px 2px 0 rgba(0, 0, 0, 0.05);
	border: 1px solid var(--slate-200);
	overflow: hidden;
	display: flex;
	flex-direction: column;
}
@media (min-width: 768px) {
	.company-card { flex-direction: row; }
}
.company-category {
	width: 100%;
	padding: 1.5rem;
	display: flex;
	flex-direction: column;
	justify-content: center;
	border-bottom: 1px solid var(--slate-200);
}
@media (min-width: 768px) {
	.company-category { width: 33.333%; border-bottom: none; border-right: 1px solid var(--slate-200); }
}
.cat-sky { background-color: var(--sky-50); }
.cat-orange { background-color: var(--orange-50); }
.cat-emerald { background-color: var(--emerald-50); }

.cat-badge {
	font-size: 0.75rem;
	font-weight: 700;
	padding: 0.25rem 0.5rem;
	border-radius: 0.25rem;
	display: inline-block;
	width: max-content;
	margin-bottom: 0.5rem;
}
.cat-sky .cat-badge { color: var(--sky-600); background-color: var(--sky-100); }
.cat-orange .cat-badge { color: var(--orange-600); background-color: var(--orange-100); }
.cat-emerald .cat-badge { color: var(--emerald-600); background-color: var(--emerald-100); }

.company-category h3 {
	font-size: 1.25rem;
	font-weight: 700;
	color: var(--slate-800);
}
.company-category p {
	font-size: 0.875rem;
	color: var(--slate-600);
	margin-top: 0.5rem;
}

.company-list-wrap {
	width: 100%;
	padding: 1.5rem;
}
@media (min-width: 768px) { .company-list-wrap { width: 66.666%; } }
@media (max-width: 767px) {
	.cat-badge{
		font-size: 1.2rem;
	}
	.company-category h3{
		font-size: 1.6rem;
	}
	.company-category p{
		font-size: 1.4rem;
	}
}

.company-item {
	display: flex;
	align-items: flex-start;
	gap: 1rem;
	border-bottom: 1px solid var(--slate-100);
	padding-bottom: 1.25rem;
	margin-bottom: 1.25rem;
}
.company-item:last-child {
	border-bottom: none;
	padding-bottom: 0;
	margin-bottom: 0;
}
/* 店舗画像 */
.company-thumb {
	width: 80px;
	flex-shrink: 0;
	border-radius: 0.5rem;
	overflow: hidden;
	background-color: var(--slate-200);
	border: 1px solid var(--slate-200);
}
@media (min-width: 640px) {
	.company-thumb { width: 100px; }
}
.company-thumb img {
	width: 100%;
	height: auto;
	display: block;
	aspect-ratio: 4 / 3;
	object-fit: cover;
}
/* 詳細情報エリア */
.company-details {
	flex-grow: 1;
	display: flex;
	flex-direction: column;
	gap: 0.75rem;
}
@media (min-width: 640px) {
	.company-details {
		flex-direction: row;
		align-items: center;
		justify-content: space-between;
	}
}
.company-info {
	display: flex;
	flex-direction: column;
}
/* 店舗名とロゴ */
.company-info .name {
	font-weight: 700;
	font-size: 1.125rem;
	color: var(--slate-800);
	display: flex;
	align-items: center;
	gap: 0.5rem;
	flex-wrap: wrap;
	margin-bottom: 0.25rem;
}
.company-logo {
	height: 1.25rem;
	width: auto;
	object-fit: contain;
}
@media (min-width: 640px) {
	.company-logo { height: 1.5rem; }
}
.company-info .address {
	font-size: 0.8125rem;
	color: var(--slate-500);
}
.company-info .address i { margin-right: 0.25rem; color: var(--slate-400); }
.company-info .desc {
	font-size: 0.875rem;
	color: var(--slate-500);
	margin-top: 0.25rem;
}
.company-info .desc i { margin-right: 0.25rem; }
.company-info .desc .strong { font-weight: 700; color: var(--slate-700); }
@media (max-width: 767px) {
	.company-info .name, .company-info .address, .company-info .desc{
		font-size: 1.4rem;
	}
}

.btn-detail {
	font-size: 0.875rem;
	background-color: var(--white);
	border: 1px solid var(--sky-500);
	color: var(--sky-600);
	font-weight: 500;
	padding: 0.5rem 1rem;
	border-radius: 0.25rem;
	white-space: nowrap;
	transition: background-color 0.3s;
}
.btn-detail:hover { background-color: var(--sky-50); }
@media (max-width: 767px) {
	.btn-detail{
		font-size: 1.4rem;
		text-align: center;
	}
}

/* Bottom Search Section */
.bottom-search-section {
	background-color: var(--sky-100);
	padding: 4rem 0;
	border-top: 1px solid var(--sky-200);
}

/* Yui Rail Section */
.yuirail-section { background-color: var(--white); }
.yuirail-card {
	background-color: var(--sky-50);
	border: 1px solid var(--sky-100);
	border-radius: 1rem;
	padding: 1.5rem;
	display: flex;
	flex-direction: column;
	gap: 1.5rem;
	align-items: center;
	box-shadow: 0 1px 2px 0 rgba(0, 0, 0, 0.05);
}
@media (min-width: 768px) {
	.yuirail-card { padding: 2.5rem; flex-direction: row; gap: 2rem; }
}
.yuirail-img {
	width: 100%;
	border-radius: 0.75rem;
	overflow: hidden;
	flex-shrink: 0;
}
@media (min-width: 768px) { .yuirail-img { width: 33.333%; } }
.yuirail-img img {
	width: 100%;
	height: auto;
	aspect-ratio: 4 / 3;
	object-fit: cover;
	display: block;
}
.yuirail-info { width: 100%; }
@media (min-width: 768px) { .yuirail-info { width: 66.666%; } }

.yuirail-title {
	font-size: 1.25rem;
	font-weight: 700;
	color: var(--slate-800);
	margin-bottom: 1rem;
}
@media (min-width: 768px) { .yuirail-title { font-size: 1.5rem; } }
.yuirail-desc {
	color: var(--slate-600);
	font-size: 0.875rem;
	line-height: 1.8;
	margin-bottom: 1.5rem;
}
@media (min-width: 768px) { .yuirail-desc { font-size: 1rem; } }
.yuirail-desc strong { color: var(--slate-700); }
@media (max-width: 767px) {
	.yuirail-title{
		font-size: 1.6rem;
	}
	.yuirail-desc{
		font-size: 1.4rem;
	}
}

#yuirail a.btn-yuirail {
	display: inline-block;
	background-color: var(--orange-500);
	color: var(--white);
	font-weight: 700;
	font-size: 1rem;
	padding: 0.75rem 2rem;
	border-radius: 0.5rem;
	text-align: center;
	transition: background-color 0.3s, transform 0.3s;
	/*width: 100%;*/
	box-shadow: 0 4px 6px -1px rgba(0, 0, 0, 0.1);
}
@media (min-width: 768px) { .btn-yuirail { width: auto; } }
#yuirail a.btn-yuirail:hover {
	background-color: var(--orange-600);
	transform: translateY(-2px);
	text-decoration: none;
}
@media (max-width: 767px) {
	#yuirail a.btn-yuirail{
		font-size: 1.6rem;
	}
}

/* FAQ Section */
.faq-section { background-color: var(--white); }
.faq-list { display: flex; flex-direction: column; gap: 1rem;font-size: 1rem}
.faq-item {
	border: 1px solid var(--slate-200);
	border-radius: 0.5rem;
	padding: 1.25rem;
}
.faq-q {
	font-weight: 700;
	color: var(--slate-800);
	display: flex;
	align-items: flex-start;
}
.faq-q .icon { color: var(--sky-500); margin-right: 0.5rem; }
.faq-a {
	color: var(--slate-600);
	margin-top: 0.5rem;
	font-size: 0.875rem;
	margin-left: 1.5rem;
}
.faq-a .icon { color: var(--slate-400); font-weight: 700; margin-right: 0.25rem; }
@media (max-width: 767px) {
	.faq-list{
		font-size: 1.6rem
	}
	.faq-a{
		font-size: 1.6rem;
	}
}
/* Footer */
/*.footer {
	background-color: var(--slate-800);
	color: var(--slate-400);
	padding: 2rem 0;
	text-align: center;
	font-size: 0.875rem;
}
.footer p { margin-bottom: 0.5rem; }*/