/* ==========================================================================
   Components — bottoni, card, badge, form, alert.
   ========================================================================== */

/* Buttons */
.btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: var(--space-2);
	padding: 14px 28px;
	font-family: var(--font-sans);
	font-size: var(--font-size-base);
	font-weight: 600;
	line-height: 1;
	color: var(--color-text-inverse);
	background: var(--color-primary);
	border: 2px solid var(--color-primary);
	border-radius: var(--radius-md);
	cursor: pointer;
	transition: all var(--dur-fast) var(--ease);
	text-decoration: none;
	white-space: nowrap;
}
.btn:hover, .btn:focus-visible {
	background: var(--color-primary-hover);
	border-color: var(--color-primary-hover);
	color: var(--color-text-inverse);
	transform: translateY(-1px);
	box-shadow: var(--shadow-md);
}
.btn:active { transform: translateY(0); }

.btn--accent {
	background: var(--color-accent);
	border-color: var(--color-accent);
	color: var(--color-text-inverse);
}
.btn--accent:hover, .btn--accent:focus-visible {
	background: var(--color-accent-hover);
	border-color: var(--color-accent-hover);
	color: var(--color-text-inverse);
}

.btn--outline {
	background: transparent;
	color: var(--color-primary);
}
.btn--outline:hover, .btn--outline:focus-visible {
	background: var(--color-primary);
	color: var(--color-text-inverse);
}

.btn--ghost {
	background: transparent;
	color: var(--color-text-inverse);
	border-color: rgba(255, 255, 255, .35);
}
.btn--ghost:hover, .btn--ghost:focus-visible {
	background: rgba(255, 255, 255, .12);
	border-color: var(--color-text-inverse);
	color: var(--color-text-inverse);
}

.btn--lg { padding: 18px 36px; font-size: var(--font-size-md); }
.btn--sm { padding: 10px 18px; font-size: var(--font-size-sm); }

.btn__icon { display: inline-flex; }

/* Icons */
.dcp-icon {
	display: inline-block;
	vertical-align: middle;
	flex-shrink: 0;
}

/* Card */
.card {
	background: var(--color-bg);
	border: 1px solid var(--color-border);
	border-radius: var(--radius-lg);
	padding: var(--space-6);
	transition: transform var(--dur-base) var(--ease), box-shadow var(--dur-base) var(--ease), border-color var(--dur-base) var(--ease);
	height: 100%;
	display: flex;
	flex-direction: column;
}
.card:hover {
	transform: translateY(-4px);
	box-shadow: var(--shadow-lg);
	border-color: var(--color-border-strong);
}

.card__icon {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 56px;
	height: 56px;
	margin-bottom: var(--space-4);
	background: var(--color-primary-soft);
	color: var(--color-primary);
	border-radius: var(--radius-md);
}

.card__title {
	font-size: var(--font-size-lg);
	margin-bottom: var(--space-3);
}

.card__text {
	color: var(--color-text-muted);
	margin: 0;
}

.card__link {
	margin-top: var(--space-4);
	font-weight: 600;
	display: inline-flex;
	align-items: center;
	gap: var(--space-2);
}
.card__link:hover .dcp-icon { transform: translateX(3px); }
.card__link .dcp-icon { transition: transform var(--dur-fast) var(--ease); }

/* Badge */
.badge {
	display: inline-flex;
	align-items: center;
	gap: var(--space-2);
	padding: 6px 14px;
	background: var(--color-primary-soft);
	color: var(--color-primary);
	border-radius: var(--radius-pill);
	font-size: var(--font-size-sm);
	font-weight: 600;
	letter-spacing: 0.02em;
}

.badge--accent {
	background: rgba(200, 155, 60, .12);
	color: var(--color-accent-hover);
}

/* Forms */
.form { display: flex; flex-direction: column; gap: var(--space-5); }

.form__row {
	display: grid;
	gap: var(--space-5);
}
.form__row--2 { grid-template-columns: 1fr 1fr; }
@media (max-width: 640px) {
	.form__row--2 { grid-template-columns: 1fr; }
}

.form__field { display: flex; flex-direction: column; gap: var(--space-2); }

.form__label {
	font-size: var(--font-size-sm);
	font-weight: 600;
	color: var(--color-text);
}
.form__label .required { color: var(--color-error); margin-left: 2px; }

.form__input,
.form__textarea,
.form__select {
	width: 100%;
	padding: 14px 16px;
	font-family: var(--font-sans);
	font-size: var(--font-size-base);
	color: var(--color-text);
	background: var(--color-bg);
	border: 1px solid var(--color-border-strong);
	border-radius: var(--radius-md);
	transition: border-color var(--dur-fast) var(--ease), box-shadow var(--dur-fast) var(--ease);
}
.form__textarea {
	min-height: 160px;
	resize: vertical;
	font-family: var(--font-sans);
}
.form__input:focus,
.form__textarea:focus,
.form__select:focus {
	outline: 0;
	border-color: var(--color-primary);
	box-shadow: 0 0 0 4px var(--color-primary-soft);
}

.form__input[aria-invalid="true"],
.form__textarea[aria-invalid="true"] {
	border-color: var(--color-error);
	box-shadow: 0 0 0 4px var(--color-error-bg);
}

.form__checkbox {
	display: flex;
	align-items: flex-start;
	gap: var(--space-3);
	font-size: var(--font-size-sm);
	color: var(--color-text-muted);
	cursor: pointer;
	line-height: 1.5;
}
.form__checkbox input {
	margin-top: 3px;
	accent-color: var(--color-primary);
	width: 18px;
	height: 18px;
	flex-shrink: 0;
}
.form__checkbox a { font-weight: 600; }

.form__help {
	font-size: var(--font-size-xs);
	color: var(--color-text-muted);
}

.form__notice {
	margin: 0;
	font-size: var(--font-size-sm);
	color: var(--color-text-muted);
	line-height: 1.55;
}

.map_custom_notify {
	margin-bottom: var(--space-5);
}
.form__notice a {
	color: var(--color-primary);
	font-weight: 600;
	text-decoration: underline;
	text-underline-offset: 2px;
}
.form__notice a:hover,
.form__notice a:focus-visible {
	color: var(--color-primary-hover);
}

.form__honeypot {
	position: absolute;
	left: -9999px;
	width: 1px;
	height: 1px;
	overflow: hidden;
}

.form__error-msg {
	font-size: var(--font-size-sm);
	color: var(--color-error);
	display: none;
}
.form__field[data-invalid="true"] .form__error-msg { display: block; }

/* Alerts */
.alert {
	padding: var(--space-4) var(--space-5);
	border-radius: var(--radius-md);
	border-left: 4px solid;
	margin-bottom: var(--space-5);
	font-size: var(--font-size-base);
}
.alert--success {
	background: var(--color-success-bg);
	border-color: var(--color-success);
	color: #14532d;
}
.alert--error {
	background: var(--color-error-bg);
	border-color: var(--color-error);
	color: #7f1d1d;
}

/* Grid helpers */
.grid {
	display: grid;
	gap: var(--space-6);
}
.grid--2 { grid-template-columns: repeat(2, 1fr); }
.grid--3 { grid-template-columns: repeat(3, 1fr); }
.grid--4 { grid-template-columns: repeat(4, 1fr); }
@media (max-width: 1024px) {
	.grid--3, .grid--4 { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 640px) {
	.grid--2, .grid--3, .grid--4 { grid-template-columns: 1fr; }
}

/* Flex helpers */
.cta-group {
	display: flex;
	gap: var(--space-4);
	flex-wrap: wrap;
	align-items: center;
}

/* Stat */
.stat {
	text-align: center;
}
.stat__num {
	font-family: var(--font-serif);
	font-size: var(--font-size-4xl);
	font-weight: 700;
	color: var(--color-primary);
	line-height: 1;
	display: block;
	margin-bottom: var(--space-2);
}
.stat__label {
	font-size: var(--font-size-sm);
	color: var(--color-text-muted);
	text-transform: uppercase;
	letter-spacing: 0.08em;
	font-weight: 600;
}

/* Pagination */
.nav-links {
	display: flex;
	gap: var(--space-2);
	justify-content: center;
	flex-wrap: wrap;
	margin: var(--space-6) 0;
}
.nav-links .page-numbers {
	padding: 10px 16px;
	border: 1px solid var(--color-border);
	border-radius: var(--radius-md);
	font-weight: 600;
	color: var(--color-text);
}
.nav-links .page-numbers.current,
.nav-links .page-numbers:hover {
	background: var(--color-primary);
	border-color: var(--color-primary);
	color: var(--color-text-inverse);
}
