/**
 * Custom Card Ubud — Card Detail CSS
 *
 * Clean, premium detail page matching reference design.
 *
 * @package CustomCardUbud
 * @version 1.2.0
 */

.ccu-card-detail a,
.ccu-card-detail a:hover,
.ccu-card-detail a:focus,
.ccu-card-detail a:visited {
	text-decoration: none !important;
	box-shadow: none !important;
}

.ccu-card-detail *,
.ccu-card-detail *::before,
.ccu-card-detail *::after {
	box-sizing: border-box;
}

.ccu-card-detail {
	font-family: 'Inter', -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;
	background: #fff;
	padding-top: 80px;
	padding-bottom: 80px;
}

@media screen and (max-width: 768px) {
	.ccu-card-detail {
		padding-top: 60px;
	}
}

.ccu-detail-container {
	max-width: 1120px;
	margin: 0 auto;
	padding: 0 24px;
}

/* =========================================================
   BREADCRUMB
   ========================================================= */
.ccu-detail-breadcrumb {
	display: flex;
	align-items: center;
	gap: 8px;
	padding: 24px 0 16px;
	font-size: 14px;
	color: #6b7280;
}

.ccu-detail-breadcrumb a {
	color: #6b7280;
	transition: color .2s;
}

.ccu-detail-breadcrumb a:hover {
	color: var(--ccu-detail-accent, #ff7a00);
}

.ccu-detail-breadcrumb-sep {
	color: #d1d5db;
	font-size: 12px;
}

.ccu-detail-breadcrumb > span:last-child {
	color: #111827;
	font-weight: 500;
	min-width: 0;
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
}

/* =========================================================
   HEADER — title + rating
   ========================================================= */
.ccu-detail-header {
	display: flex;
	justify-content: space-between;
	align-items: flex-start;
	gap: 20px;
	margin-bottom: 24px;
}

.ccu-detail-header-left {
	display: flex;
	flex-direction: column;
	gap: 8px;
}

.ccu-detail-title {
	font-size: 28px;
	font-weight: 700;
	color: #111827;
	margin: 0;
	line-height: 1.25;
}

.ccu-detail-location {
	display: flex;
	align-items: center;
	gap: 6px;
	font-size: 15px;
	color: #4b5563;
}

.ccu-detail-header-rating {
	display: flex;
	align-items: center;
	gap: 6px;
	padding: 8px 16px;
	background: color-mix(in srgb, var(--ccu-detail-accent, #ff7a00) 8%, transparent);
	border-radius: 8px;
	flex-shrink: 0;
}

.ccu-detail-stars {
	display: flex;
	gap: 2px;
	color: #f99f1b;
	font-size: 14px;
}

.ccu-detail-rating-num {
	font-size: 15px;
	font-weight: 700;
	color: #111827;
}

/* =========================================================
   IMAGE GRID
   ========================================================= */
.ccu-detail-image-grid {
	display: grid;
	gap: 8px;
	border-radius: 12px;
	overflow: hidden;
	margin-bottom: 28px;
}

.ccu-grid-count-1 {
	grid-template-columns: 1fr;
}

.ccu-grid-count-2 {
	grid-template-columns: 1fr 1fr;
	grid-template-rows: 320px;
}

.ccu-grid-count-3 {
	grid-template-columns: 2fr 1fr;
	grid-template-rows: 160px 160px;
}

.ccu-grid-count-3 .ccu-grid-primary {
	grid-row: 1 / -1;
}

.ccu-grid-count-4 {
	grid-template-columns: 2fr 1fr;
	grid-template-rows: 106px 106px 106px;
}

.ccu-grid-count-4 .ccu-grid-primary {
	grid-row: 1 / -1;
}

.ccu-detail-grid-item {
	position: relative;
	overflow: hidden;
	background: linear-gradient(135deg, #fff7ed 0%, #ffedd5 100%);
	border-radius: 8px;
	cursor: pointer;
	height: 100%;
}

.ccu-detail-grid-item img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
	transition: transform .4s ease;
}

.ccu-detail-grid-item:hover img {
	transform: scale(1.04);
}

.ccu-grid-count-1 .ccu-detail-grid-item {
	height: 420px;
}

.ccu-grid-more-overlay {
	position: absolute;
	inset: 0;
	background: rgba(0,0,0,0.45);
	display: flex;
	align-items: center;
	justify-content: center;
	color: #fff;
	font-size: 20px;
	font-weight: 700;
	letter-spacing: 0.5px;
	border-radius: 8px;
}

.ccu-detail-hero-placeholder {
	width: 100%;
	height: 420px;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 80px;
	color: var(--ccu-detail-accent, #ff7a00);
}

.ccu-detail-hero-placeholder svg {
	width: 80px;
	height: 80px;
	fill: currentColor;
}

/* =========================================================
   FEATURES ROW
   ========================================================= */
.ccu-detail-features {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 16px;
	margin-bottom: 36px;
}

.ccu-detail-feature-item {
	display: flex;
	align-items: center;
	gap: 14px;
	padding: 16px;
	background: #f9fafb;
	border-radius: 12px;
}

.ccu-detail-feature-icon {
	width: 44px;
	height: 44px;
	border-radius: 10px;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 18px;
	flex-shrink: 0;
}

.ccu-detail-feature-text {
	display: flex;
	flex-direction: column;
	gap: 2px;
}

.ccu-detail-feature-label {
	font-size: 12px;
	font-weight: 500;
	color: #9ca3af;
	text-transform: uppercase;
	letter-spacing: 0.5px;
}

.ccu-detail-feature-value {
	font-size: 15px;
	font-weight: 600;
	color: #111827;
}

/* =========================================================
   BODY LAYOUT
   ========================================================= */
.ccu-detail-layout {
	display: grid;
	grid-template-columns: 1fr 340px;
	gap: 40px;
	align-items: start;
}

.ccu-detail-main {
	display: flex;
	flex-direction: column;
	gap: 36px;
}

/* =========================================================
   SECTION
   ========================================================= */
.ccu-detail-section {
	display: flex;
	flex-direction: column;
	gap: 14px;
}

.ccu-detail-section-title {
	font-size: 22px;
	font-weight: 600;
	color: #111827;
	margin: 0;
	line-height: 1.3;
}

.ccu-detail-description {
	font-size: 16px;
	color: #4b5563;
	line-height: 1.7;
	margin: 0;
}

/* =========================================================
   OFFER BLOCKS — vertical layout (replaces old tabs)
   ========================================================= */
.ccu-detail-offer-block {
	background: #f9fafb;
	border-radius: 12px;
	padding: 20px 24px;
}

.ccu-detail-offer-block + .ccu-detail-offer-block {
	margin-top: 12px;
}

.ccu-offer-title {
	font-size: 16px;
	font-weight: 600;
	margin: 0 0 14px;
	display: flex;
	align-items: center;
	gap: 8px;
	font-family: 'Inter', -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;
}

.ccu-offer-title i,
.ccu-offer-title svg {
	font-size: 18px;
}

.ccu-offer-includes {
	color: #16a34a;
}

.ccu-offer-excludes {
	color: #dc2626;
}

.ccu-offer-itinerary {
	color: var(--ccu-detail-accent, #ff7a00);
}

.ccu-detail-checklist {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	flex-direction: column;
	gap: 10px;
}

.ccu-detail-checklist li {
	display: flex;
	align-items: flex-start;
	gap: 10px;
	font-size: 15px;
	color: #374151;
	line-height: 1.5;
}

.ccu-detail-checklist li i,
.ccu-detail-checklist li svg {
	flex-shrink: 0;
	margin-top: 4px;
}

/* =========================================================
   ITINERARY ACCORDION
   ========================================================= */
.ccu-detail-timeline {
	display: flex;
	flex-direction: column;
	gap: 12px;
}

.ccu-timeline-item {
	border: 1px solid #e5e7eb;
	border-radius: 10px;
	overflow: hidden;
	background: #fff;
}

.ccu-timeline-title {
	font-size: 16px;
	font-weight: 600;
	color: #fff;
	margin: 0;
	line-height: 1.4;
	padding: 14px 18px;
	background: var(--ccu-detail-accent, #ff7a00);
	border: none;
	border-radius: 0;
	cursor: pointer;
	display: flex;
	align-items: center;
	justify-content: space-between;
	width: 100%;
	gap: 8px;
	font-family: 'Inter', -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;
	transition: background .2s;
}

.ccu-timeline-title:hover {
	background: color-mix(in srgb, var(--ccu-detail-accent, #ff7a00) 85%, #000);
}

.ccu-timeline-arrow {
	font-size: 13px;
	color: #fff;
	transition: transform .2s;
	flex-shrink: 0;
}

.is-open .ccu-timeline-arrow {
	transform: rotate(180deg);
}

.ccu-timeline-desc-wrap {
	padding: 18px;
}

.ccu-timeline-desc {
	font-size: 15px;
	color: #6b7280;
	line-height: 1.6;
	margin: 6px 0 0;
}

.ccu-timeline-sub {
	margin: 0;
	padding: 10px 0 0;
	border-top: 1px dashed #e5e7eb;
	display: flex;
	flex-direction: column;
	gap: 2px;
}

.ccu-timeline-sub:first-child {
	border-top: none;
	padding-top: 0;
}

.ccu-timeline-sub strong {
	color: #374151;
	font-size: 15px;
}

/* =========================================================
   SIDEBAR
   ========================================================= */
.ccu-detail-sidebar-card {
	background: #fff;
	border: 1px solid #e5e7eb;
	border-radius: 12px;
	padding: 24px;
	position: sticky;
	top: 24px;
	display: flex;
	flex-direction: column;
	gap: 20px;
}

.ccu-detail-rating {
	display: flex;
	align-items: center;
	gap: 10px;
}

.ccu-detail-rating-text {
	font-size: 15px;
	font-weight: 600;
	color: #111827;
}

.ccu-detail-pricing {
	display: flex;
	flex-wrap: wrap;
	align-items: baseline;
	gap: 4px 6px;
}

.ccu-detail-price-old {
	font-size: 15px;
	font-weight: 500;
	color: #9ca3af;
	text-decoration: line-through;
	text-decoration-thickness: 1.5px;
	flex: 0 0 100%;
}

.ccu-detail-price-new {
	font-size: 28px;
	font-weight: 700;
	color: var(--ccu-detail-accent, #ff7a00);
	line-height: 1.1;
}

.ccu-detail-price-per {
	font-size: 14px;
	color: #6b7280;
	font-weight: 400;
	align-self: flex-end;
	padding-bottom: 2px;
}

.ccu-detail-sidebar-divider {
	height: 1px;
	background: #e5e7eb;
}

.ccu-detail-sidebar-form {
	display: flex;
	flex-direction: column;
	gap: 14px;
}

.ccu-detail-form-title {
	font-size: 16px;
	font-weight: 600;
	color: #111827;
	margin: 0;
	font-family: 'Inter', -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;
}

.ccu-booking-form {
	display: flex;
	flex-direction: column;
	gap: 12px;
}

.ccu-form-group {
	display: flex;
	flex-direction: column;
	gap: 4px;
}

.ccu-form-group label {
	font-size: 13px;
	font-weight: 500;
	color: #4b5563;
}

.ccu-form-input {
	width: 100%;
	padding: 10px 14px;
	border: 1px solid #d1d5db;
	border-radius: 8px;
	font-size: 14px;
	font-family: 'Inter', -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;
	color: #111827;
	background: #fff;
	transition: border-color .2s, box-shadow .2s;
	outline: none;
}

.ccu-form-input:focus {
	border-color: var(--ccu-detail-accent, #ff7a00);
	box-shadow: 0 0 0 3px color-mix(in srgb, var(--ccu-detail-accent, #ff7a00) 15%, transparent);
}

.ccu-form-textarea {
	resize: vertical;
	min-height: 60px;
	line-height: 1.5;
}

.ccu-detail-wa-btn {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 10px;
	background: #25d366;
	color: #fff;
	font-size: 15px;
	font-weight: 600;
	padding: 14px 24px;
	border: none;
	border-radius: 10px;
	cursor: pointer;
	transition: background .2s, transform .15s;
	width: 100%;
	font-family: 'Inter', -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;
}

.ccu-detail-wa-btn:hover {
	background: #1da851;
	color: #fff;
	transform: translateY(-1px);
}

.ccu-detail-wa-btn svg {
	width: 20px;
	height: 20px;
	fill: currentColor;
}

/* =========================================================
   LIGHTBOX
   ========================================================= */
.ccu-lightbox {
	position: fixed;
	inset: 0;
	z-index: 99999;
	background: rgba(0,0,0,0.92);
	display: none;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	padding: 20px;
}

.ccu-lightbox--open {
	display: flex;
}

.ccu-lightbox-close {
	position: absolute;
	top: 16px;
	right: 20px;
	font-size: 36px;
	color: #fff;
	background: none;
	border: none;
	cursor: pointer;
	line-height: 1;
	z-index: 2;
	padding: 4px 8px;
	opacity: .7;
	transition: opacity .2s;
}

.ccu-lightbox-close:hover { opacity: 1; }

.ccu-lightbox-nav {
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
	font-size: 48px;
	color: #fff;
	background: none;
	border: none;
	cursor: pointer;
	padding: 8px 16px;
	opacity: .6;
	transition: opacity .2s;
	z-index: 2;
	line-height: 1;
}

.ccu-lightbox-nav:hover { opacity: 1; }
.ccu-lightbox-prev { left: 12px; }
.ccu-lightbox-next { right: 12px; }

.ccu-lightbox-body {
	display: flex;
	align-items: center;
	justify-content: center;
	flex: 1;
	min-height: 0;
	max-width: 95vw;
	max-height: 70vh;
}

.ccu-lightbox-img {
	max-width: 100%;
	max-height: 100%;
	object-fit: contain;
	display: block;
	border-radius: 4px;
	user-select: none;
	-webkit-user-drag: none;
}

.ccu-lightbox-thumbs {
	display: flex;
	gap: 8px;
	padding: 16px 0 8px;
	overflow-x: auto;
	max-width: 100%;
	flex-shrink: 0;
}

.ccu-lightbox-thumb {
	width: 72px;
	height: 54px;
	border-radius: 4px;
	overflow: hidden;
	cursor: pointer;
	opacity: .5;
	border: 2px solid transparent;
	transition: opacity .2s, border-color .2s;
	flex-shrink: 0;
}

.ccu-lightbox-thumb:hover { opacity: .8; }
.ccu-lightbox-thumb.is-active { opacity: 1; border-color: #fff; }

.ccu-lightbox-thumb img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}

@media screen and (max-width: 540px) {
	.ccu-lightbox { padding: 12px; }
	.ccu-lightbox-body { max-height: 60vh; }
	.ccu-lightbox-thumb { width: 56px; height: 42px; }
	.ccu-lightbox-nav { font-size: 32px; }
}

/* =========================================================
   OTHER ACTIVITIES
   ========================================================= */
.ccu-detail-other {
	padding-top: 48px;
	margin-top: 48px;
	border-top: 1px solid #e5e7eb;
}

.ccu-detail-other-title {
	font-size: 22px;
	font-weight: 600;
	color: #111827;
	margin: 0 0 24px;
	line-height: 1.3;
}

.ccu-detail-other .ccu-card-builder-grid {
	gap: 16px;
}

/* =========================================================
   RESPONSIVE
   ========================================================= */
@media screen and (max-width: 1024px) {
	.ccu-detail-layout { grid-template-columns: 1fr 300px; gap: 28px; }
	.ccu-detail-title { font-size: 26px; }
	.ccu-grid-count-3 { grid-template-rows: 130px 130px; }
	.ccu-grid-count-4 { grid-template-rows: 86px 86px 86px; }
}

@media screen and (max-width: 768px) {
	.ccu-detail-title { font-size: 24px; }
	.ccu-detail-layout { grid-template-columns: 1fr; }
	.ccu-detail-sidebar { order: -1; }
	.ccu-detail-sidebar-card { position: static; }

	.ccu-detail-header { flex-direction: column; }
	.ccu-detail-features { grid-template-columns: 1fr; }
	.ccu-grid-count-2,
	.ccu-grid-count-3,
	.ccu-grid-count-4 { grid-template-columns: 1fr; grid-template-rows: auto; }
	.ccu-grid-count-3 .ccu-grid-primary,
	.ccu-grid-count-4 .ccu-grid-primary { grid-row: auto; }
	.ccu-detail-grid-item { height: 220px; }
	.ccu-detail-hero-placeholder { height: 280px; }
	.ccu-detail-offer-block { padding: 16px 20px; }
}

@media screen and (max-width: 540px) {
	.ccu-detail-container { padding: 0 16px; }
	.ccu-detail-title { font-size: 22px; }
	.ccu-detail-breadcrumb { padding: 16px 0 12px; font-size: 13px; overflow: hidden; }
	.ccu-detail-breadcrumb > span:last-child { min-width: 0; max-width: 160px; }
	.ccu-detail-section-title { font-size: 18px; }
	.ccu-detail-price-new { font-size: 24px; }
	.ccu-detail-grid-item { height: 180px; }
	.ccu-grid-count-1 .ccu-detail-grid-item { height: 220px; }
	.ccu-detail-hero-placeholder { height: 220px; font-size: 56px; }
	.ccu-detail-feature-item { padding: 12px; }
	.ccu-detail-offer-block { padding: 14px 16px; }
	.ccu-detail-other { padding-top: 32px; margin-top: 32px; }
	.ccu-detail-other-title { font-size: 18px; margin-bottom: 16px; }
	.ccu-detail-other .ccu-card-builder-grid { gap: 8px; }
}