/**
 * Intimacy Insight — Page Templates
 * --------------------------------------------------------------------
 * Covers templates/page.php, templates/page-about.php, and
 * templates/page-contact.php. Registered/enqueued only on is_page()
 * (see inc/enqueue.php), alongside archive.css for the shared
 * .ii-archive-hero page-header component these templates reuse rather
 * than duplicate.
 *
 * 100% design-token driven — zero hardcoded colors.
 */

/* ====================================================================
   1. PAGE CONTENT PROSE
   ------------------------------------------------------------------
   A slim, page-scoped equivalent of single-article.css's
   .ii-article__content — intentionally NOT the same stylesheet (that
   file also bundles the TOC sidebar, reading progress bar, and author
   box, all irrelevant to a generic Page and not worth the extra KB on
   every Page load), but tuned to the same tokens so page content and
   article content read as visually consistent typography.
   ==================================================================== */

.ii-page__inner {
	padding-block: var(--ii-space-8);
}

.ii-page__content {
	max-width: var(--ii-container-article);
	margin-inline: auto;
	font-size: var(--ii-text-lg);
	line-height: var(--ii-leading-relaxed);
	color: var(--ii-color-text-secondary);
}

.ii-page__content--intro {
	margin-bottom: var(--ii-space-8);
}

.ii-page__content > * {
	margin-bottom: var(--ii-space-5);
}

.ii-page__content > *:last-child {
	margin-bottom: 0;
}

.ii-page__content h2 {
	font-size: var(--ii-text-2xl);
	font-weight: var(--ii-weight-bold);
	color: var(--ii-color-text-primary);
	line-height: var(--ii-leading-tight);
	margin-top: var(--ii-space-7);
}

.ii-page__content h3 {
	font-size: var(--ii-text-xl);
	font-weight: var(--ii-weight-semibold);
	color: var(--ii-color-text-primary);
	line-height: var(--ii-leading-tight);
	margin-top: var(--ii-space-6);
}

.ii-page__content p {
	color: var(--ii-color-text-secondary);
}

.ii-page__content a {
	color: var(--ii-color-primary-dark);
	text-decoration: underline;
	text-underline-offset: 2px;
}

.ii-page__content a:hover {
	color: var(--ii-color-text-primary);
}

.ii-page__content ul,
.ii-page__content ol {
	padding-left: var(--ii-space-6);
	color: var(--ii-color-text-secondary);
}

.ii-page__content li {
	margin-bottom: var(--ii-space-2);
}

.ii-page__content blockquote {
	margin: var(--ii-space-6) 0;
	padding: var(--ii-space-4) var(--ii-space-6);
	border-left: 4px solid var(--ii-color-primary);
	background-color: var(--ii-color-bg-alt);
	border-radius: 0 var(--ii-radius-md) var(--ii-radius-md) 0;
	color: var(--ii-color-text-primary);
}

.ii-page__content img {
	border-radius: var(--ii-radius-md);
}

/* ====================================================================
   2. ABOUT PAGE — TEAM GRID
   ==================================================================== */

.ii-team__grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--ii-space-5);
}

@media (min-width: 640px) {
	.ii-team__grid {
		grid-template-columns: repeat(2, 1fr);
	}
}

@media (min-width: 1024px) {
	.ii-team__grid {
		grid-template-columns: repeat(3, 1fr);
	}
}

.ii-team-card {
	display: flex;
	flex-direction: column;
	align-items: center;
	text-align: center;
	padding: var(--ii-space-6);
	background-color: var(--ii-color-bg);
	border: 1px solid var(--ii-color-border);
	border-radius: var(--ii-radius-lg);
	transition: box-shadow var(--ii-transition-base), transform var(--ii-transition-base);
}

.ii-team-card:hover {
	box-shadow: var(--ii-shadow-md);
	transform: translateY(-3px);
}

.ii-team-card__photo {
	width: 96px;
	height: 96px;
	border-radius: var(--ii-radius-full);
	overflow: hidden;
	margin-bottom: var(--ii-space-4);
}

.ii-team-card__photo img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.ii-team-card__name {
	font-family: var(--ii-font-heading);
	font-size: var(--ii-text-lg);
	font-weight: var(--ii-weight-semibold);
	color: var(--ii-color-text-primary);
	margin: 0 0 2px;
}

.ii-team-card__credentials {
	font-size: var(--ii-text-sm);
	font-weight: var(--ii-weight-medium);
	color: var(--ii-color-primary-dark);
	margin: 0 0 var(--ii-space-3);
}

.ii-team-card__bio {
	font-size: var(--ii-text-sm);
	color: var(--ii-color-text-secondary);
	line-height: var(--ii-leading-normal);
	margin: 0 0 var(--ii-space-3);
}

.ii-team-card__social {
	display: flex;
	gap: var(--ii-space-2);
	margin-top: auto;
}

/* ====================================================================
   3. CONTACT PAGE — TWO-COLUMN LAYOUT
   ==================================================================== */

.ii-contact-layout {
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--ii-space-7);
	max-width: var(--ii-container-lg);
	margin-inline: auto;
}

@media (min-width: 1024px) {
	.ii-contact-layout {
		grid-template-columns: 0.9fr 1.1fr;
		gap: var(--ii-space-8);
	}
}

.ii-contact-info__title {
	font-size: var(--ii-text-2xl);
	margin-bottom: var(--ii-space-3);
}

.ii-contact-info__intro {
	color: var(--ii-color-text-secondary);
	line-height: var(--ii-leading-relaxed);
	margin-bottom: var(--ii-space-6);
}

.ii-contact-info__list {
	list-style: none;
	margin: 0 0 var(--ii-space-6);
	padding: 0;
	display: flex;
	flex-direction: column;
	gap: var(--ii-space-4);
}

.ii-contact-info__list li {
	display: flex;
	align-items: flex-start;
	gap: var(--ii-space-3);
	font-size: var(--ii-text-base);
}

.ii-contact-info__icon {
	display: flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
	width: 40px;
	height: 40px;
	border-radius: var(--ii-radius-md);
	color: var(--ii-color-primary-dark);
	background-color: var(--ii-color-primary-light);
}

.ii-contact-info__list a {
	color: var(--ii-color-text-primary);
	text-decoration: none;
	font-weight: var(--ii-weight-medium);
}

.ii-contact-info__list a:hover {
	color: var(--ii-color-primary-dark);
}

.ii-contact-info__social {
	display: flex;
	gap: var(--ii-space-3);
}

/* ---- Contact form ---- */

.ii-contact-form-wrap {
	padding: var(--ii-space-6);
	background-color: var(--ii-color-bg-alt);
	border: 1px solid var(--ii-color-border);
	border-radius: var(--ii-radius-lg);
}

.ii-contact-form__row {
	margin-bottom: var(--ii-space-4);
}

.ii-contact-form__row label {
	display: block;
	font-size: var(--ii-text-sm);
	font-weight: var(--ii-weight-medium);
	color: var(--ii-color-text-primary);
	margin-bottom: var(--ii-space-2);
}

.ii-contact-form__input {
	width: 100%;
	padding: var(--ii-space-3) var(--ii-space-4);
	font-family: var(--ii-font-body);
	font-size: var(--ii-text-base);
	color: var(--ii-color-text-primary);
	background-color: var(--ii-color-bg);
	border: 1px solid var(--ii-color-border);
	border-radius: var(--ii-radius-md);
	transition: border-color var(--ii-transition-fast), box-shadow var(--ii-transition-fast);
}

.ii-contact-form__input:focus-visible {
	outline: none;
	border-color: var(--ii-color-primary);
	box-shadow: 0 0 0 3px rgba(13, 148, 136, 0.12);
}

.ii-contact-form__textarea {
	resize: vertical;
	min-height: 120px;
}

/* Honeypot: visually hidden but NOT display:none/visibility:hidden —
   some spam bots specifically skip filling fields hidden that way, so
   this is off-screen positioning instead, matching the exact pattern
   already established for the newsletter form's honeypot. */
.ii-contact-form__honeypot {
	position: absolute !important;
	left: -9999px;
	width: 1px;
	height: 1px;
	overflow: hidden;
}

.ii-contact-form__submit {
	margin-top: var(--ii-space-2);
}

.ii-contact-form__message {
	margin: var(--ii-space-3) 0 0;
	font-size: var(--ii-text-sm);
	font-weight: var(--ii-weight-medium);
	min-height: 1.2em;
	color: var(--ii-color-text-primary);
}

.ii-contact-form__message.is-success {
	color: var(--ii-color-text-primary);
}

.ii-contact-form__message.is-error {
	color: var(--ii-color-text-primary);
	font-weight: var(--ii-weight-bold);
	text-decoration: underline;
}

.ii-contact-form.is-loading .ii-contact-form__submit {
	opacity: 0.7;
	cursor: wait;
}

/* ====================================================================
   4. DARK MODE
   ==================================================================== */

[data-theme="dark"] .ii-team-card,
[data-theme="dark"] .ii-contact-form-wrap,
[data-theme="dark"] .ii-contact-form__input {
	background-color: var(--ii-color-bg);
	border-color: var(--ii-color-border);
}

[data-theme="dark"] .ii-page__content blockquote {
	background-color: var(--ii-color-bg-alt);
}
