.catm-form {
	display: grid;
	max-width: 760px;
	gap: 1rem;
}

.catm-form h2 {
	margin-bottom: 0.25rem;
}

.catm-form p {
	display: grid;
	gap: 0.4rem;
	margin: 0;
}

.catm-form input:not([type="checkbox"]):not([type="radio"]),
.catm-form textarea,
.catm-form select {
	/* Inherits global input style from theme core.css */
	font-size: var(--text-sm, 14px);
	padding: 0.7rem 0.9rem;
}

.catm-form textarea {
	min-height: auto; /* let rows="" attribute control height, not core.css global min */
}

.catm-password-field {
	position: relative;
	display: block;
}

.catm-password-field input {
	padding-right: 3rem;
}

.catm-password-toggle {
	position: absolute;
	top: 50%;
	right: 0.75rem;
	display: grid;
	width: 1.5rem;
	min-height: 1.5rem;
	height: 1.5rem;
	place-items: center;
	border: 0;
	background: transparent;
	color: var(--wt-ink, #101010);
	padding: 0;
	transform: translateY(-50%);
}

.catm-password-toggle:hover {
	background: transparent;
	color: var(--wt-muted, #747474);
}

.catm-password-toggle span {
	position: relative;
	display: block;
	width: 1.25rem;
	height: 0.8rem;
	border: 1.6px solid currentColor;
	border-radius: 999px / 700px;
}

.catm-password-toggle span::after {
	position: absolute;
	top: 50%;
	left: 50%;
	display: block;
	width: 0.35rem;
	height: 0.35rem;
	border-radius: 50%;
	background: currentColor;
	content: "";
	transform: translate(-50%, -50%);
}

.catm-password-toggle[aria-pressed="true"] span::before {
	position: absolute;
	top: 50%;
	left: 50%;
	width: 1.45rem;
	height: 1.6px;
	background: currentColor;
	content: "";
	transform: translate(-50%, -50%) rotate(-35deg);
}

.catm-notice {
	margin-bottom: 1rem;
	border: 1px solid var(--wt-line, #e4e4e4);
	border-radius: 16px;
	padding: 0.9rem 1rem;
}

.catm-notice-success {
	background: #f4faf3;
	color: #235724;
}

.catm-notice-error {
	background: #fff3f1;
	color: #8a1f17;
}

.catm-dashboard-panel {
	border: 1px solid var(--wt-line, #e4e4e4);
	border-radius: 24px;
	background: var(--wt-white, #fff);
	padding: 1.25rem;
}

.catm-table {
	width: 100%;
	border-collapse: collapse;
}

.catm-table th,
.catm-table td {
	border-bottom: 1px solid var(--wt-line, #e4e4e4);
	padding: 0.85rem;
	text-align: left;
}

.catm-field-grid {
	display: grid;
	gap: 1rem;
	grid-template-columns: repeat(2, minmax(0, 1fr));
}

.catm-media-field,
.catm-itinerary-builder,
.catm-itinerary-list {
	display: grid;
	gap: 1rem;
}

.catm-itinerary-item {
	border: 1px solid var(--wt-line, #e4e4e4);
	border-radius: 18px;
	background: var(--wt-surface, #fafafa);
}

.catm-itinerary-item__summary {
	cursor: pointer;
	padding: 1rem;
	font-weight: 500;
}

.catm-itinerary-item__fields {
	padding: 0 1rem 1rem;
}

@media (max-width: 640px) {
	.catm-field-grid {
		grid-template-columns: 1fr;
	}
}

.catm-notice {
	border-color: var(--c-line);
}

/* ── Media picker buttons ────────────────────────────────────────────── */
.catm-media-field__actions {
	display: flex;
	gap: var(--sp-3, 0.75rem);
	align-items: center;
	flex-wrap: wrap;
}

.catm-media-open {
	padding: 0.5rem 1.1rem;
	border: 1.5px solid var(--c-ink, #121212);
	border-radius: var(--r-pill, 999px);
	background: transparent;
	color: var(--c-ink, #121212);
	font-size: var(--text-sm, 14px);
	font-weight: 600;
	cursor: pointer;
	transition: background 150ms, color 150ms;
}

.catm-media-open:hover {
	background: var(--c-ink, #121212);
	color: #fff;
}

.catm-media-clear {
	padding: 0.5rem 1.1rem;
	border: 1px solid var(--c-line, #ededed);
	border-radius: var(--r-pill, 999px);
	background: transparent;
	color: var(--c-muted, #888);
	font-size: var(--text-sm, 14px);
	font-weight: 500;
	cursor: pointer;
	transition: color 150ms, border-color 150ms;
}

.catm-media-clear:hover:not(:disabled) {
	color: var(--c-ink, #121212);
	border-color: var(--c-ink, #121212);
}

.catm-media-clear:disabled {
	opacity: 0.35;
	cursor: not-allowed;
}

/* ── Choice pills (checkbox / radio inline labels) ───────────────────── */
.catm-choice-pill {
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: var(--text-sm, 14px);
	font-weight: 500;
	color: var(--c-muted, #888);
	padding: 0.5rem 0.75rem;
	background: var(--c-surface-2, #f5f5f5);
	border: 1px solid var(--c-line, #ededed);
	border-radius: var(--r-pill, 999px);
	cursor: pointer;
	text-align: center;
	transition: border-color 120ms, background 120ms, color 120ms;
	user-select: none;
}

/* Hide the native checkbox/radio — label click still toggles it */
.catm-choice-pill input[type="checkbox"],
.catm-choice-pill input[type="radio"] {
	display: none;
}

.catm-choice-pill:hover {
	border-color: var(--c-ink-2, #444);
	color: var(--c-ink, #121212);
}

.catm-choice-pill:has(input:checked) {
	background: var(--c-ink, #121212);
	border-color: var(--c-ink, #121212);
	color: var(--c-white, #fff);
	font-weight: 600;
}
