/* ==========================================================================
   Clinic Suite — front-end styles
   Refined, calm clinic aesthetic. Override any variable in your theme.
   ========================================================================== */

.clinic-card,
.clinic-form,
.clinic-grid,
.clinic-guides,
.clinic-booking {
	--cs-ink: #2b2622;
	--cs-muted: #7a716a;
	--cs-bg: #fbf8f4;
	--cs-surface: #ffffff;
	--cs-line: #ece5dc;
	--cs-accent: #b08968;        /* warm taupe-rose */
	--cs-accent-deep: #8c6b52;
	--cs-radius: 16px;
	--cs-shadow: 0 1px 2px rgba(43, 38, 34, .04), 0 12px 30px -18px rgba(43, 38, 34, .25);
	--cs-display: "Fraunces", Georgia, "Times New Roman", serif;
	--cs-body: "Manrope", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
}

/* Layout primitives ------------------------------------------------------ */

.clinic-card {
	background: var(--cs-surface);
	border: 1px solid var(--cs-line);
	border-radius: var(--cs-radius);
	padding: 1.75rem;
	box-shadow: var(--cs-shadow);
	font-family: var(--cs-body);
	color: var(--cs-ink);
}

.clinic-grid {
	display: grid;
	gap: 1.5rem;
	margin: 1.5rem 0;
}
.clinic-grid--1 { grid-template-columns: 1fr; }
.clinic-grid--2 { grid-template-columns: repeat(2, 1fr); }
.clinic-grid--3 { grid-template-columns: repeat(3, 1fr); }
.clinic-grid--4 { grid-template-columns: repeat(4, 1fr); }

@media (max-width: 820px) {
	.clinic-grid--3,
	.clinic-grid--4 { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 540px) {
	.clinic-grid { grid-template-columns: 1fr !important; }
}

.clinic-grid__img {
	width: 100%;
	height: 200px;
	object-fit: cover;
	border-radius: calc(var(--cs-radius) - 6px);
	display: block;
}

.clinic-empty {
	font-family: var(--cs-body);
	color: var(--cs-muted);
}

/* Service & post cards --------------------------------------------------- */

.clinic-service,
.clinic-post {
	display: flex;
	flex-direction: column;
	gap: .6rem;
}

.clinic-service__title a,
.clinic-post__title a {
	font-family: var(--cs-display);
	font-weight: 500;
	font-size: 1.35rem;
	line-height: 1.2;
	color: var(--cs-ink);
	text-decoration: none;
}
.clinic-service__title a:hover,
.clinic-post__title a:hover { color: var(--cs-accent-deep); }

.clinic-service__excerpt,
.clinic-post__excerpt { color: var(--cs-muted); line-height: 1.6; margin: 0; }

.clinic-post__date {
	font-size: .8rem;
	letter-spacing: .08em;
	text-transform: uppercase;
	color: var(--cs-accent-deep);
	margin: 0;
}

.clinic-link {
	font-weight: 600;
	color: var(--cs-accent-deep);
	text-decoration: none;
	margin-top: auto;
}
.clinic-link:hover { text-decoration: underline; }

/* Guides list ------------------------------------------------------------ */

.clinic-guides { list-style: none; margin: 1.5rem 0; padding: 0; display: grid; gap: .75rem; }
.clinic-guides__link {
	display: block;
	padding: 1.1rem 1.25rem;
	background: var(--cs-surface);
	border: 1px solid var(--cs-line);
	border-radius: 12px;
	text-decoration: none;
	transition: border-color .2s ease, transform .2s ease;
}
.clinic-guides__link:hover { border-color: var(--cs-accent); transform: translateY(-2px); }
.clinic-guides__title {
	display: block;
	font-family: var(--cs-display);
	font-size: 1.1rem;
	color: var(--cs-ink);
	margin-bottom: .2rem;
}
.clinic-guides__excerpt { display: block; color: var(--cs-muted); font-size: .92rem; }

/* Booking form ----------------------------------------------------------- */

.clinic-booking { max-width: 640px; margin: 2rem auto; background: var(--cs-bg); }
.clinic-booking__title {
	font-family: var(--cs-display);
	font-weight: 500;
	font-size: 2rem;
	line-height: 1.1;
	margin: 0 0 .35rem;
	color: var(--cs-ink);
}
.clinic-booking__tagline { color: var(--cs-muted); margin: 0 0 1.75rem; }

.clinic-form { display: grid; gap: 1.1rem; }
.clinic-field { display: grid; gap: .4rem; }
.clinic-field-row { display: grid; grid-template-columns: 1fr 1fr; gap: 1.1rem; }
@media (max-width: 520px) { .clinic-field-row { grid-template-columns: 1fr; } }

.clinic-form label {
	font-size: .88rem;
	font-weight: 600;
	color: var(--cs-ink);
}
.clinic-form label span[aria-hidden] { color: var(--cs-accent); }

.clinic-form input,
.clinic-form select,
.clinic-form textarea {
	width: 100%;
	box-sizing: border-box;
	padding: .8rem .9rem;
	border: 1px solid var(--cs-line);
	border-radius: 10px;
	background: var(--cs-surface);
	font-family: var(--cs-body);
	font-size: 1rem;
	color: var(--cs-ink);
	transition: border-color .18s ease, box-shadow .18s ease;
}
.clinic-form input:focus,
.clinic-form select:focus,
.clinic-form textarea:focus {
	outline: none;
	border-color: var(--cs-accent);
	box-shadow: 0 0 0 3px rgba(176, 137, 104, .18);
}

.clinic-consent {
	display: flex;
	align-items: flex-start;
	gap: .6rem;
	font-size: .9rem;
	font-weight: 500;
	color: var(--cs-muted);
}
.clinic-consent input { width: auto; margin-top: .15rem; }

.clinic-hp { position: absolute; left: -9999px; height: 0; overflow: hidden; }

.clinic-btn {
	appearance: none;
	border: none;
	cursor: pointer;
	background: var(--cs-accent);
	color: #fff;
	font-family: var(--cs-body);
	font-weight: 600;
	font-size: 1rem;
	padding: .95rem 1.5rem;
	border-radius: 10px;
	transition: background .18s ease, transform .18s ease;
}
.clinic-btn:hover { background: var(--cs-accent-deep); }
.clinic-btn:active { transform: translateY(1px); }
.clinic-btn[disabled] { opacity: .6; cursor: progress; }

.clinic-form__status {
	margin: 0;
	font-size: .95rem;
	min-height: 1.2em;
}
.clinic-form__status.is-error { color: #b32d2e; }
.clinic-form__status.is-success { color: #15803d; font-weight: 600; }
