/* ============================================
   WP overrides — keep AT THE END of the cascade.
   Only add rules here that fix WP's own injected
   styles. Real design rules belong in global.css.
   ============================================ */

/* WP injects `html { margin-top: 32px !important }` when admin bar is
   visible, which collides with our fixed header. Push the header below
   the admin bar instead. */
.admin-bar .site-header {
	top: 32px;
}
@media (max-width: 782px) {
	.admin-bar .site-header {
		top: 46px;
	}
}

/* ACF flexible-content / repeater output sometimes wraps in <p> tags via
   wpautop, which breaks our flex layouts. The ones we render manually are
   already clean — this catches stragglers in WYSIWYG body fields. */
.detail-body p:empty,
.cms-content p:empty {
	display: none;
}

/* WP gallery / caption defaults — neutralise so they don't bleed into
   ACF-rendered galleries. */
.wp-block-gallery,
.wp-block-image figcaption {
	font-family: var(--font-sans);
}

/* Keep the WP block editor's "alignwide" / "alignfull" from breaking
   our centred layouts on standard pages, in case anyone enables blocks
   on a page later. */
.alignwide,
.alignfull {
	max-width: 100%;
}

/* Comments section — minimal, editorial, matches the rest. */
.comment-list,
.comment-list ol {
	list-style: none;
	padding: 0;
	margin: 0;
}

.comment-list li {
	padding: 24px 0;
	border-top: 1px solid var(--ink-20);
}

.comment-author cite {
	font-family: var(--font-serif);
	font-size: 18px;
	font-style: normal;
	color: var(--ink-100);
}

.comment-meta a {
	font-family: var(--font-mono);
	font-size: 10px;
	letter-spacing: 0.20em;
	text-transform: uppercase;
	color: var(--ink-60);
}

/* Search form — adopt our input style. */
.search-form input[type="search"] {
	font-family: var(--font-sans);
	font-size: 16px;
	padding: 14px 16px;
	border: 1px solid var(--ink-20);
	background: var(--paper);
	color: var(--ink-100);
	border-radius: 0;
}
.search-form input[type="search"]:focus {
	outline: none;
	border-color: var(--accent);
}

/* ============================================
   THEME ADDITIONS — classes used by templates
   that aren't in the original global.css.
   ============================================ */

/* Reveal-on-scroll. main.js adds .is-revealed when in view. */
.reveal {
	opacity: 0;
	transform: translateY(24px);
	transition:
		opacity 1.1s cubic-bezier(.2,.7,.2,1),
		transform 1.1s cubic-bezier(.2,.7,.2,1);
}
.reveal.is-revealed {
	opacity: 1;
	transform: translateY(0);
}
@media (prefers-reduced-motion: reduce) {
	.reveal { opacity: 1; transform: none; transition: none; }
}

/* Visually-hidden honeypot helper. */
.visually-hidden {
	position: absolute !important;
	width: 1px;
	height: 1px;
	padding: 0;
	margin: -1px;
	overflow: hidden;
	clip: rect(0, 0, 0, 0);
	white-space: nowrap;
	border: 0;
}

/* Skip link. */
.skip-link {
	position: absolute;
	left: -9999px;
	top: 0;
	z-index: 9999;
	background: var(--ink-100);
	color: var(--paper);
	padding: 12px 24px;
	font-family: var(--font-mono);
	font-size: 11px;
	letter-spacing: 0.2em;
	text-transform: uppercase;
}
.skip-link:focus {
	left: 16px;
	top: 16px;
}

/* Mobile toggle (hamburger). Hidden on desktop. */
.mobile-toggle {
	display: none;
	background: none;
	border: 0;
	width: 36px;
	height: 36px;
	flex-direction: column;
	justify-content: center;
	align-items: center;
	gap: 5px;
	cursor: pointer;
	padding: 0;
}
.mobile-toggle span {
	display: block;
	width: 22px;
	height: 1.5px;
	background: var(--ink-100);
	transition: background 0.2s;
}
.site-header.scrolled .mobile-toggle span { background: var(--ink-100); }

@media (max-width: 900px) {
	.mobile-toggle { display: inline-flex; }
	.primary-nav, .header-cta, .lang-switcher { display: none !important; }
}

/* Mobile drawer. */
.mobile-nav {
	position: fixed;
	top: 0; left: 0; right: 0; bottom: 0;
	background: var(--paper);
	z-index: 90;
	padding: 100px 32px 32px;
	overflow-y: auto;
}
.mobile-nav-inner {
	display: flex;
	flex-direction: column;
	gap: 24px;
}
.mobile-nav-inner a {
	font-family: var(--font-serif);
	font-size: 28px;
	color: var(--ink-100);
	letter-spacing: -0.01em;
	padding-bottom: 20px;
	border-bottom: 1px solid var(--ink-20);
}
.mobile-nav-inner a.mobile-cta {
	border-bottom: 0;
	color: var(--accent-deep);
	margin-top: 16px;
}
body.mobile-nav-open { overflow: hidden; }

/* SVG fallback image — fills its parent. */
.bimc-fallback-svg {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

/* ----- Procedure detail: pricing card layout adjustments. */
.price-amount {
	margin: 16px 0 24px;
}
.price-amount-idr {
	display: block;
	font-family: var(--font-serif);
	font-size: 38px;
	line-height: 1;
	letter-spacing: -0.01em;
	color: var(--ink-100);
}
.pricing-card.featured .price-amount-idr { color: white; }
.price-amount-aud {
	display: block;
	font-family: var(--font-serif);
	font-style: italic;
	font-size: 17px;
	color: var(--ink-60);
	margin-top: 8px;
}
.pricing-card.featured .price-amount-aud { color: rgba(255, 255, 255, 0.7); }
.price-amount small {
	display: block;
	margin-top: 8px;
	font-family: var(--font-mono);
	font-size: 10px;
	letter-spacing: 0.18em;
	text-transform: uppercase;
	color: var(--ink-60);
}
.pricing-card.featured .price-amount small { color: rgba(255, 255, 255, 0.5); }

/* PriceTag inline (used in procedure-row + treatment listings). */
.price-tag {
	display: inline-flex;
	flex-direction: column;
	gap: 4px;
}
.price-tag--right { align-items: flex-end; }
.price-tag-idr {
	font-family: var(--font-mono);
	font-size: 11px;
	font-weight: 500;
	letter-spacing: 0.18em;
	color: var(--accent-deep);
	white-space: nowrap;
}
.price-tag-aud {
	font-family: var(--font-serif);
	font-style: italic;
	font-size: 13px;
	color: var(--ink-60);
	white-space: nowrap;
}
.price-tag--invert .price-tag-idr { color: white; }
.price-tag--invert .price-tag-aud { color: rgba(255, 255, 255, 0.6); }

/* ----- Single procedure: surgeon mini wrapper layout if not in global. */
/* (global.css has .surgeon-mini, .surgeon-mini-img, etc — leave as-is.) */

/* ----- Single surgeon: bio grid, areas grid, creds table. */
.surgeon-bio-grid {
	display: grid;
	grid-template-columns: 1fr 2fr;
	gap: 80px;
	align-items: start;
	max-width: 1280px;
	margin: 0 auto;
}
.surgeon-bio-cols {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 40px;
	margin-top: 40px;
}
.surgeon-bio-cols p {
	font-size: 16.5px;
	line-height: 1.7;
	color: var(--ink-80);
	margin: 0;
}
@media (max-width: 900px) {
	.surgeon-bio-grid { grid-template-columns: 1fr; gap: 40px; }
	.surgeon-bio-cols { grid-template-columns: 1fr; gap: 24px; }
}

.surgeon-areas-grid {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 24px;
}
.surgeon-area {
	padding: 32px 28px;
	border: 1px solid var(--ink-20);
	background: var(--paper);
	min-height: 180px;
}
.surgeon-area-title {
	font-family: var(--font-serif);
	font-style: italic;
	font-size: 28px;
	font-weight: 400;
	margin: 12px 0 0;
	letter-spacing: -0.01em;
	color: var(--ink-100);
}
@media (max-width: 1100px) {
	.surgeon-areas-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 600px) {
	.surgeon-areas-grid { grid-template-columns: 1fr; }
}

.surgeon-creds-table { /* container only — see row below. */ }
.surgeon-cred-row {
	display: grid;
	grid-template-columns: 240px 1fr 280px;
	gap: 32px;
	padding: 26px 0;
	border-bottom: 1px solid var(--ink-20);
	align-items: baseline;
}
.surgeon-cred-row .cred-mid {
	font-family: var(--font-serif);
	font-size: 20px;
	color: var(--ink-100);
	letter-spacing: -0.005em;
}
.surgeon-cred-row .cred-right {
	font-family: var(--font-serif);
	font-style: italic;
	font-size: 17px;
	color: var(--ink-60);
	text-align: right;
}
@media (max-width: 800px) {
	.surgeon-cred-row {
		grid-template-columns: 1fr;
		gap: 8px;
	}
	.surgeon-cred-row .cred-right { text-align: left; }
}

.surgeons-other-grid {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 24px;
}
@media (max-width: 1100px) { .surgeons-other-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 600px)  { .surgeons-other-grid { grid-template-columns: 1fr; } }

/* ----- Treatment archive procedure table. */
.procedure-table {
	border-top: 1px solid var(--ink-20);
	margin-top: 48px;
}
.procedure-row {
	display: grid;
	grid-template-columns: 60px 1fr auto;
	gap: 32px;
	padding: 28px 0;
	border-bottom: 1px solid var(--ink-20);
	align-items: center;
	color: inherit;
	transition: background 0.2s;
}
.procedure-row:hover {
	background: var(--paper-warm);
	padding-left: 16px;
	padding-right: 16px;
}
.procedure-row-num { color: var(--accent-deep); }
.procedure-row-meta h3,
.procedure-row-meta h4 {
	font-family: var(--font-serif);
	font-size: 26px;
	font-weight: 400;
	margin: 0 0 6px;
	color: var(--ink-100);
	letter-spacing: -0.01em;
}
.procedure-row-meta h4 { font-size: 22px; }
.procedure-row-tagline {
	display: inline-block;
	font-family: var(--font-serif);
	font-style: italic;
	font-size: 16px;
	color: var(--ink-60);
	margin-bottom: 8px;
}
.procedure-row-meta p {
	font-size: 15px;
	color: var(--ink-80);
	margin: 0;
	max-width: 600px;
	line-height: 1.6;
}
.procedure-row-price {
	display: flex;
	align-items: center;
	gap: 24px;
}
.procedure-row-arrow {
	font-family: var(--font-mono);
	font-size: 18px;
	color: var(--accent-deep);
	transition: transform 0.2s;
}
.procedure-row:hover .procedure-row-arrow { transform: translateX(6px); }
.procedure-row--compact { grid-template-columns: 1fr auto; gap: 24px; }

@media (max-width: 800px) {
	.procedure-row {
		grid-template-columns: 1fr;
		gap: 12px;
	}
	.procedure-row-price { justify-content: flex-end; }
}

.pricing-section { margin-top: 80px; }
.pricing-section-title {
	font-family: var(--font-serif);
	font-size: 36px;
	font-weight: 400;
	margin: 0 0 24px;
	letter-spacing: -0.01em;
	color: var(--ink-100);
}

/* ----- Press page: cards + list. */
.press-grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 24px;
	margin-top: 60px;
}
@media (max-width: 900px) { .press-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 600px) { .press-grid { grid-template-columns: 1fr; } }

.press-card {
	padding: 40px 32px;
	border: 1px solid var(--ink-20);
	background: var(--paper);
	min-height: 200px;
	display: flex;
	flex-direction: column;
	justify-content: space-between;
}
.press-card-mark {
	font-family: var(--font-serif);
	font-style: italic;
	font-size: 32px;
	color: var(--accent-deep);
	margin-bottom: 16px;
}
.press-card h4 {
	font-family: var(--font-serif);
	font-size: 22px;
	font-weight: 400;
	margin: 0 0 8px;
	color: var(--ink-100);
	letter-spacing: -0.005em;
	line-height: 1.3;
}

.press-list {
	list-style: none;
	padding: 0;
	margin: 60px 0 0;
	border-top: 1px solid var(--ink-20);
}
.press-list li {
	display: grid;
	grid-template-columns: 80px 1fr auto;
	gap: 32px;
	padding: 24px 0;
	border-bottom: 1px solid var(--ink-20);
	align-items: baseline;
}
.press-year {
	font-family: var(--font-mono);
	font-size: 11px;
	letter-spacing: 0.22em;
	color: var(--accent-deep);
}
.press-title {
	font-family: var(--font-serif);
	font-size: 22px;
	color: var(--ink-100);
	letter-spacing: -0.005em;
}
.press-source {
	font-family: var(--font-serif);
	font-style: italic;
	font-size: 16px;
	color: var(--ink-60);
}
@media (max-width: 700px) {
	.press-list li { grid-template-columns: 1fr; gap: 4px; }
}

/* ----- Pricing page extras. */
.pricing-includes {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 32px;
	margin-top: 60px;
}
.pricing-include {
	padding: 32px 24px;
	border: 1px solid var(--ink-20);
	background: var(--paper);
}
.pricing-include h4 {
	font-family: var(--font-serif);
	font-size: 22px;
	font-weight: 400;
	margin: 12px 0 8px;
	color: var(--ink-100);
}
.pricing-include p {
	font-size: 15px;
	color: var(--ink-80);
	margin: 0;
	line-height: 1.6;
}
@media (max-width: 1000px) { .pricing-includes { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 600px)  { .pricing-includes { grid-template-columns: 1fr; } }

/* ----- Recovery stays. */
.recovery-list {
	margin-top: 60px;
	border-top: 1px solid var(--ink-20);
}
.recovery-row {
	display: grid;
	grid-template-columns: 60px 1fr;
	gap: 32px;
	padding: 28px 0;
	border-bottom: 1px solid var(--ink-20);
	align-items: baseline;
}
.recovery-row h4 {
	font-family: var(--font-serif);
	font-size: 24px;
	font-weight: 400;
	margin: 0 0 6px;
	color: var(--ink-100);
}
.recovery-row p {
	font-size: 15px;
	line-height: 1.65;
	color: var(--ink-80);
	margin: 0;
}

/* ----- Contact page grid. */
.contact-section { padding-top: 0; }
.contact-grid {
	display: grid;
	grid-template-columns: 2fr 1fr;
	gap: 80px;
	max-width: 1280px;
	margin: 0 auto;
	padding: 60px 0;
}
.contact-form-col { max-width: 720px; }
.contact-info-col {
	padding: 32px;
	background: var(--paper-warm);
	border: 1px solid var(--ink-20);
	height: fit-content;
	display: flex;
	flex-direction: column;
	gap: 28px;
}
.contact-info-block { }
.contact-link {
	display: block;
	font-family: var(--font-serif);
	font-size: 24px;
	color: var(--ink-100);
	margin-top: 8px;
	letter-spacing: -0.005em;
}
.contact-link:hover { color: var(--accent-deep); }

@media (max-width: 1000px) {
	.contact-grid { grid-template-columns: 1fr; gap: 48px; }
}

/* ----- Form rows. */
.field-row {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 16px;
}
@media (max-width: 600px) {
	.field-row { grid-template-columns: 1fr; gap: 0; }
}

/* Status messages on forms. */
.form-status {
	margin: 16px 0 0;
	padding: 14px 16px;
	font-family: var(--font-sans);
	font-size: 14px;
	line-height: 1.5;
}
.form-status.success {
	background: rgba(166, 124, 82, 0.10);
	color: var(--accent-deep);
	border-left: 3px solid var(--accent);
}
.form-status.error {
	background: rgba(180, 50, 50, 0.08);
	color: #b43232;
	border-left: 3px solid #b43232;
}

/* ----- Gallery filters. */
.gallery-filters {
	display: flex;
	gap: 8px;
	flex-wrap: wrap;
	margin-bottom: 60px;
	padding-bottom: 24px;
	border-bottom: 1px solid var(--ink-20);
}
.gallery-filter {
	background: transparent;
	border: 1px solid var(--ink-20);
	padding: 10px 20px;
	font-family: var(--font-mono);
	font-size: 11px;
	letter-spacing: 0.18em;
	text-transform: uppercase;
	color: var(--ink-80);
	cursor: pointer;
	transition: all 0.2s;
}
.gallery-filter:hover { border-color: var(--accent); color: var(--accent-deep); }
.gallery-filter.active {
	background: var(--ink-100);
	color: var(--paper);
	border-color: var(--ink-100);
}

/* Archive variants of gallery + stories grids. */
.gallery-grid--archive {
	grid-template-columns: repeat(3, 1fr);
}
@media (max-width: 1000px) { .gallery-grid--archive { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 600px)  { .gallery-grid--archive { grid-template-columns: 1fr; } }

.stories-grid--archive {
	grid-template-columns: repeat(3, 1fr);
	gap: 32px;
}
@media (max-width: 1000px) { .stories-grid--archive { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 600px)  { .stories-grid--archive { grid-template-columns: 1fr; } }

/* Archive list (search results / blog index). */
.archive-list { display: flex; flex-direction: column; gap: 32px; }
.archive-row {
	padding-bottom: 32px;
	border-bottom: 1px solid var(--ink-20);
}
.archive-row h3 {
	font-family: var(--font-serif);
	font-size: 28px;
	font-weight: 400;
	margin: 12px 0 8px;
	letter-spacing: -0.01em;
}
.archive-row h3 a:hover { color: var(--accent-deep); }
.archive-row p {
	font-size: 16px;
	line-height: 1.6;
	color: var(--ink-80);
	margin: 0;
}

/* ----- Journey detail. */
.journey-detail {
	display: flex;
	flex-direction: column;
	gap: 0;
	border-top: 1px solid var(--ink-20);
}
.journey-phase {
	display: grid;
	grid-template-columns: 120px 1fr;
	gap: 40px;
	padding: 40px 0;
	border-bottom: 1px solid var(--ink-20);
	align-items: baseline;
}
.journey-phase-num { padding-top: 4px; }
.journey-phase-body h3 {
	font-family: var(--font-serif);
	font-size: 36px;
	font-weight: 400;
	margin: 0 0 12px;
	letter-spacing: -0.01em;
	color: var(--ink-100);
}
.journey-phase-body p {
	font-size: 17px;
	line-height: 1.65;
	color: var(--ink-80);
	margin: 0;
	max-width: 720px;
}
@media (max-width: 700px) {
	.journey-phase { grid-template-columns: 1fr; gap: 12px; }
}

/* ----- Villa cards page. */
/* (assumes .villa-grid + .villa-card already styled in global.css; if not,
   provide minimal placeholders here.) */
.villa-num {
	font-family: var(--font-serif);
	font-style: italic;
	font-size: 20px;
	color: var(--accent-deep);
}

/* ----- Mobile-bar variant when no admin bar. */
@media (max-width: 782px) {
	.mobile-nav { padding-top: 80px; }
}

/* ----- Body padding so the fixed header doesn't overlap chapter openers. */
.chapter-opener { /* CSS is in global.css; this is just a guard for when it isn't. */ }

/* ----- Pagination styling. */
.archive-pagination .page-numbers,
.gallery-pagination .page-numbers {
	display: inline-block;
	padding: 8px 14px;
	font-family: var(--font-mono);
	font-size: 11px;
	letter-spacing: 0.18em;
	text-transform: uppercase;
	color: var(--ink-80);
	border: 1px solid var(--ink-20);
	margin: 0 4px;
}
.archive-pagination .page-numbers.current,
.gallery-pagination .page-numbers.current {
	background: var(--ink-100);
	color: var(--paper);
	border-color: var(--ink-100);
}
.archive-pagination .page-numbers:hover,
.gallery-pagination .page-numbers:hover {
	border-color: var(--accent);
	color: var(--accent-deep);
}
