/* =============================================
   Cebu Campus – Philippine Flag Color Theme
   Blue: #0038A8 / Red: #CE1126 / Gold: #FCD116
   ============================================= */

:root {
	--primary: #0071bc;
	--light: #f0f6fc;
	--dark: #181d38;
}

/* Primary overrides */
.text-primary {
	color: #0071bc !important;
}
.bg-primary {
	background-color: #0071bc !important;
}
.bg-light-primary {
	background: #f0f6fc;
}
.btn-primary {
	background-color: #0071bc;
	border-color: #0071bc;
	color: #fff;
}
.btn-primary:hover {
	background-color: #005fa0;
	border-color: #005fa0;
	color: #fff;
}
.btn-outline-primary {
	border-color: #0071bc;
	color: #0071bc;
}
.btn-outline-primary:hover {
	background-color: #0071bc;
	color: #fff;
}

/* Hero – text color override for dark background */
.hero-section .text-primary {
	color: #fcd116 !important;
}
.hero-section span.text-primary {
	color: #fcd116 !important;
}
.hero-section .text-label-sm {
	color: #181d38 !important;
}


/* Hero */
.hero-section {
	background:
		linear-gradient(to right, rgba(255, 255, 255, 0.9) 0%, rgba(255, 255, 255, 0) 100%),
		linear-gradient(135deg, rgba(24, 29, 56, 0.15) 0%, rgba(6, 50, 80, 0.1) 100%),
		url('../img/hallway-noticeboard.png') center/cover no-repeat;
}

/* Section title underline */
.section-title {
	color: #0038a8;
}

/* Feature cards */
.feature-item:hover {
	background: #0071bc;
}

/* Plan card active border */
.plan-card.active {
	border-color: #0038a8;
	box-shadow: 0 6px 24px rgba(0, 56, 168, 0.22);
}
.plan-price {
	color: #0038a8;
}

/* Schedule labels */
.schedule-label {
	background: #0038a8;
}

/* Step circle */
.step-circle {
	background: #0071bc;
	box-shadow: 0 2px 8px rgba(0, 113, 188, 0.3);
}
.step-circle.plain {
	background: #fff;
	color: #0071bc;
}
.step-circle.final {
	background: #fcd116;
	color: #001a5c;
}
.step-label {
	color: #0071bc;
}

/* Testimonials */
.testimonial-highlight {
	color: #0038a8;
	border-left-color: #0038a8;
}
.testimonial-avatar {
	background: #f0f6fc;
}
.avatar-icon {
	color: #0038a8;
}
.testimonial-plan {
	color: #0038a8;
}
.read-more-link {
	color: #0038a8;
}

/* FAQ */
.faq-item.open {
	border-color: #0038a8;
}
.faq-q span {
	color: #0038a8;
}
.faq-icon {
	color: #0038a8;
}
.faq-a-label {
	color: #0038a8;
}

/* Support cards */
.support-card {
	border-color: #b3c6f0;
}

/* CTA section */
.cta-section {
	background: linear-gradient(135deg, #181d38 0%, #0a4060 100%);
}

/* Light pink from Philippine red */
.bg-ph-pink {
	background: #fdf3f4;
}

/* Accent overrides inside the pink section */
.bg-ph-pink .text-primary {
	color: #b0102a !important;
}
.bg-ph-pink .section-title {
	color: #b0102a;
}
.bg-ph-pink .fa {
	color: #b0102a !important;
}
.bg-ph-pink .support-card {
	border-color: #f2b8c0;
}
.bg-ph-pink .border-primary-left {
	border-left-color: #b0102a;
}
.bg-ph-pink span.text-primary {
	color: #b0102a !important;
}
.bg-ph-pink .faq-a-label {
	color: #b0102a;
}

/* Gold accent – badge, highlights */
.badge-gold {
	background: #fcd116;
	color: #001a5c;
	font-weight: 700;
}

/* Price table */
.price-table thead tr {
	background-color: #0038a8;
}
.price-table tbody tr:hover {
	background: #f0f6fc;
}
.price-table tbody tr.active-row {
	background: #dce6f8;
}

/* Footer links */
.footer a:hover {
	color: #fcd116;
}

/* ── ホテルセクション ──────────────────────────────────── */
.hotel-img-wrap {
	position: relative;
	border-radius: 12px;
	overflow: hidden;
}
.hotel-img-wrap img {
	width: 100%;
	height: 400px;
	object-fit: cover;
	display: block;
}
.hotel-img-badge {
	position: absolute;
	top: 20px;
	left: 20px;
	background: #fff;
	border-radius: 50px;
	padding: 8px 18px;
	font-size: 0.82rem;
	font-weight: 700;
	color: #1a1a2e;
	display: flex;
	align-items: center;
	box-shadow: 0 2px 10px rgba(0, 0, 0, 0.12);
}
.hotel-img-badge i {
	color: #0038a8;
}
.hotel-main-title {
	font-size: 1.8rem;
	font-weight: 700;
	color: #1a1a2e;
}
.hotel-main-body {
	font-size: 0.95rem;
	color: #666;
	line-height: 1.8;
}
.hotel-feature-item {
	display: flex;
	gap: 16px;
	padding: 24px 0;
	border-bottom: 1px solid #eee;
}
.hotel-feature-item:first-child {
	padding-top: 0;
}
.hotel-feature-icon {
	width: 44px;
	height: 44px;
	flex-shrink: 0;
	background: #f0f6fc;
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
}
.hotel-feature-icon i {
	color: #0071bc;
	font-size: 1.05rem;
}
.hotel-feature-title {
	font-size: 1rem;
	font-weight: 700;
	color: #1a1a2e;
	margin: 0 0 6px;
}
.hotel-feature-desc {
	font-size: 0.82rem;
	color: #777;
	line-height: 1.7;
	margin: 0 0 10px;
}
.hotel-feature-link {
	font-size: 0.82rem;
	font-weight: 700;
	color: #0038a8;
}

/* ── レッスンスケジュール タイムライン ────────────────── */
.cebu-timeline {
	max-width: 540px;
	margin: 0 auto;
	position: relative;
}
.cebu-timeline::before {
	content: '';
	position: absolute;
	left: 12px;
	top: 20px;
	bottom: 20px;
	border-left: 1.5px dashed #c0c0c0;
	z-index: 0;
}
.cebu-tl-row {
	display: flex;
	align-items: stretch;
	min-height: 55px;
}
.cebu-tl-row.tall {
	min-height: 75px;
}
.cebu-tl-row.half {
	min-height: 0;
	height: 30px;
	overflow: hidden;
}
.cebu-tl-row.half .cebu-tl-content-col {
	padding-top: 3px;
	padding-bottom: 3px;
}
.cebu-tl-row.half .cebu-tl-block-body {
	padding: 5px 12px;
}
.cebu-tl-row.end {
	min-height: 0;
	align-items: flex-start;
}
.cebu-tl-time-col {
	width: 90px;
	flex-shrink: 0;
	display: flex;
	align-items: flex-start;
	padding-top: 4px;
	position: relative;
	top: -5px;
}
.cebu-tl-row:not(.end) .cebu-tl-time-col::after {
	content: '';
	position: absolute;
	left: 12px;
	right: 0;
	top: 11px;
	border-top: 1.5px dashed #c0c0c0;
}
.cebu-tl-time {
	font-size: 0.82rem;
	font-weight: 700;
	color: #1a1a2e;
	padding-left: 26px;
	position: relative;
	top: -2px;
	z-index: 1;
}
.cebu-tl-content-col {
	flex: 1;
	display: flex;
	flex-direction: column;
	padding: 4px 0 4px 12px;
}
.cebu-tl-block {
	flex: 1;
	display: flex;
	align-items: stretch;
	background: #2283c5;
	border: 1px solid #2283c5;
	border-radius: 4px;
	overflow: hidden;
}
.cebu-tl-bar {
	display: none;
}
.cebu-tl-block.break {
	background: #e8e8e8;
	border-color: #ccc;
}
.cebu-tl-block.feedback {
	background: #d45f51;
	border-color: #d45f51;
}
.cebu-tl-block-body {
	padding: 6px 14px;
	display: flex;
	flex-direction: column;
	justify-content: center;
}
.cebu-tl-name {
	font-size: 0.82rem;
	font-weight: 700;
	color: #fff;
	margin: 0;
}
.cebu-tl-block.break .cebu-tl-name {
	color: #888;
}
.cebu-tl-sub {
	font-size: 0.72rem;
	color: rgba(255, 255, 255, 0.75);
	margin: 2px 0 0;
}
.cebu-tl-block.break .cebu-tl-sub {
	color: #888;
}
.cebu-tl-note {
	font-size: 0.68rem;
}
.cebu-tl-block.orientation {
	background: #d45f51;
	border-color: #d45f51;
}
.cebu-tl-block-join-top {
	border-bottom-left-radius: 0;
	border-bottom-right-radius: 0;
	border-bottom: none;
}
.cebu-tl-block-join-bottom {
	border-top-left-radius: 0;
	border-top-right-radius: 0;
	border-top: none;
}

/* Step labels */
.step-label3 {
	background: #0071bc;
}
.step-label3--blue {
	background: #0a4060;
}

/* Mobile fixed navbar override */
@media (max-width: 991.98px) {
	nav.navbar {
		background: linear-gradient(135deg, #001a5c 0%, #0038a8 100%);
	}
}

@media (max-width: 991.98px) {
	.hero-section {
		padding-top: 120px !important;
	}
}

@media (max-width: 767px) {
	.hero-section .container {
		padding-left: 12px;
		padding-right: 12px;
	}
	.hero-desc {
		font-size: 0.7rem;
	}
}

/* ── cebucampus.html から移動 ── */
.hero-section .btn-primary:hover {
	background-color: #0055cc !important;
	border-color: #0055cc !important;
	transform: translateY(-2px);
	box-shadow: 0 6px 20px rgba(0, 56, 168, 0.4);
}
.hero-section h1,
.hero-section p,
.hero-section .text-primary {
	color: #181d38 !important;
}
.hero-section {
	background:
		linear-gradient(to right, rgba(255, 255, 255, 0.9) 0%, rgba(255, 255, 255, 0) 100%),
		linear-gradient(135deg, rgba(24, 29, 56, 0.15) 0%, rgba(6, 50, 80, 0.1) 100%),
		url('../img/hallway-noticeboard.png') center/cover no-repeat;
	padding: 100px 0 80px;
	color: #fff;
}
.cebu-map-wrap {
	border-radius: 16px;
	overflow: hidden;
}
.cebu-map-wrap img {
	width: 100%;
	height: auto;
}
/* 料金シミュレーター */
.est-rate-note {
	font-size: 0.78rem;
	color: #aaa;
	margin-bottom: 14px;
	padding: 6px 10px;
	background: #f0f6fc;
	border-radius: 6px;
}
.est-row {
	display: grid;
	grid-template-columns: 72px 1fr auto;
	align-items: start;
	gap: 4px 10px;
	padding: 10px 0;
	border-bottom: 1px solid #d4e8f5;
	text-align: left;
}
.est-label {
	font-weight: 600;
	color: #181d38;
}
.est-detail {
	font-size: 0.9rem;
	color: #666;
}
.est-detail small {
	display: block;
	color: #06bbcc;
}
.est-value {
	font-weight: 700;
	color: #06bbcc;
	white-space: nowrap;
}
.ssp-yen-br {
	display: none;
}
@media (max-width: 480px) {
	.est-row {
		grid-template-columns: 64px 1fr;
	}
	.est-value {
		grid-column: 2;
		text-align: right;
	}
	.ssp-yen-br {
		display: block;
	}
}
.est-total {
	display: flex;
	justify-content: space-between;
	align-items: center;
	margin-top: 14px;
	padding: 10px 14px;
	background: #f0f6fc;
	border-top: 2px solid #06bbcc;
	font-size: 1.1rem;
	font-weight: 700;
	color: #181d38;
}
.feature-item--red:hover {
	background: #c0392b !important;
}
@media (max-width: 991.98px) {
	.brighture-original-img {
		width: 100% !important;
		opacity: 0.85 !important;
	}
	.brighture-original-img-wrap {
		background: none;
		border-radius: 0;
		overflow: hidden;
		padding: 0;
		margin-bottom: 8px;
	}
	.step-body3,
	.text-sm-relaxed {
		font-size: 0.9rem;
		line-height: 1.7;
	}
	.step-title {
		font-size: 1rem;
	}
	.step-desc {
		font-size: 0.82rem;
		margin-top: 10px;
	}
	.feature-item h5 {
		font-size: 1rem;
	}
	.feature-item .feature-icon-block {
		font-size: 1.05rem;
	}
	h2 {
		font-size: 1.5rem;
	}
	.text-intro,
	.text-intro-sm,
	.text-body-lg {
		font-size: 0.9rem !important;
		line-height: 1.7 !important;
	}
}
#curriculumAccordion .faq-item {
	background: #fff;
}
