/*
 Theme Name:   OriMap
 Theme URI:    https://orimap.fr
 Description:  Child theme for GeneratePress — interactive map of French vocational training.
 Author:       OriMap
 Author URI:   https://orimap.fr
 Template:     generatepress
 Version:      1.0.0
 Text Domain:  orimap
*/

/* ==========================================================================
   Design Tokens (from DESIGN.md)
   ========================================================================== */

:root {
	/* Primary */
	--color-primary: #7C3AED;
	--color-primary-dark: #5B21B6;
	--color-primary-light: #EDE9FE;
	--color-accent: #F97316;
	--color-accent-light: #FFF7ED;

	/* Semantic */
	--color-success: #34D399;
	--color-success-light: #D1FAE5;
	--color-warning: #FBBF24;
	--color-warning-light: #FEF3C7;
	--color-error: #FB7185;
	--color-error-light: #FCE7F3;

	/* Neutrals */
	--color-ink: #1C1917;
	--color-body: #78716C;
	--color-muted: #A8A29E;
	--color-border: #E7E5E4;
	--color-surface: #FEFCE8;
	--color-surface-alt: #FDF9F0;
	--color-white: #FFFFFF;

	/* Typography */
	--font-display: 'DM Sans', system-ui, sans-serif;
	--font-body: 'Plus Jakarta Sans', system-ui, sans-serif;

	--text-hero: 700 36px/1.2 var(--font-display);
	--text-h1: 700 28px/1.25 var(--font-display);
	--text-h2: 700 22px/1.3 var(--font-display);
	--text-h3: 700 18px/1.35 var(--font-display);
	--text-body: 400 15px/1.6 var(--font-body);
	--text-body-strong: 600 15px/1.6 var(--font-body);
	--text-small: 500 13px/1.5 var(--font-body);
	--text-caption: 600 11px/1.4 var(--font-body);
	--text-data: 700 22px/1.2 var(--font-body);

	/* Spacing (8px grid) */
	--space-1: 4px;
	--space-2: 8px;
	--space-3: 12px;
	--space-4: 16px;
	--space-5: 20px;
	--space-6: 24px;
	--space-8: 32px;
	--space-10: 40px;
	--space-12: 48px;
	--space-16: 64px;

	/* Radius */
	--radius-sm: 8px;
	--radius-md: 12px;
	--radius-lg: 16px;
	--radius-xl: 20px;
	--radius-full: 9999px;

	/* Shadows */
	--shadow-sm: 0 1px 4px rgba(0, 0, 0, 0.06);
	--shadow-md: 0 4px 16px rgba(124, 58, 237, 0.1);
	--shadow-lg: 0 8px 32px rgba(124, 58, 237, 0.12);
	--shadow-pin: 0 3px 8px rgba(124, 58, 237, 0.3);
}

/* ==========================================================================
   Base Overrides (GeneratePress)
   ========================================================================== */

body {
	font: var(--text-body);
	color: var(--color-ink);
	background-color: var(--color-surface);
}

h1, h2, h3, h4, h5, h6 {
	font-family: var(--font-display);
	color: var(--color-ink);
}

h1 { font: var(--text-h1); }
h2 { font: var(--text-h2); }
h3 { font: var(--text-h3); }

a {
	color: var(--color-primary);
	text-decoration: none;
	transition: color 0.2s ease;
}

a:hover {
	color: var(--color-primary-dark);
}

/* Focus ring for accessibility */
:focus-visible {
	outline: 3px solid var(--color-primary);
	outline-offset: 2px;
}

/* ==========================================================================
   Buttons
   ========================================================================== */

.orimap-btn {
	display: inline-flex;
	align-items: center;
	gap: var(--space-2);
	padding: 10px 20px;
	border: none;
	border-radius: var(--radius-md);
	font: var(--text-body-strong);
	font-size: 14px;
	cursor: pointer;
	transition: all 0.2s ease;
	text-decoration: none;
}

.orimap-btn--primary {
	background: var(--color-primary);
	color: var(--color-white);
}

.orimap-btn--primary:hover {
	background: var(--color-primary-dark);
	color: var(--color-white);
}

.orimap-btn--accent {
	background: var(--color-accent);
	color: var(--color-white);
}

.orimap-btn--accent:hover {
	background: #EA580C;
	color: var(--color-white);
}

.orimap-btn--outline {
	background: transparent;
	border: 2px solid var(--color-primary);
	color: var(--color-primary);
}

.orimap-btn--outline:hover {
	background: var(--color-primary-light);
}

.orimap-btn--ghost {
	background: transparent;
	color: var(--color-primary);
}

.orimap-btn--ghost:hover {
	background: var(--color-primary-light);
}

/* ==========================================================================
   Badges
   ========================================================================== */

.orimap-badge {
	display: inline-flex;
	align-items: center;
	gap: var(--space-1);
	padding: 4px 10px;
	border-radius: var(--radius-md);
	font: var(--text-small);
	font-size: 12px;
	font-weight: 600;
}

.orimap-badge--default {
	background: var(--color-primary-light);
	color: var(--color-primary-dark);
}

.orimap-badge--success {
	background: var(--color-success-light);
	color: #065F46;
}

.orimap-badge--warning {
	background: var(--color-warning-light);
	color: #92400E;
}

.orimap-badge--error {
	background: var(--color-error-light);
	color: #9D174D;
}

.orimap-badge--premium {
	background: var(--color-accent-light);
	color: #C2410C;
}

/* ==========================================================================
   Cards
   ========================================================================== */

.orimap-card {
	background: var(--color-white);
	border: 2px solid var(--color-primary-light);
	border-radius: var(--radius-lg);
	padding: var(--space-5);
	transition: box-shadow 0.2s ease, border-color 0.2s ease;
}

.orimap-card:hover {
	box-shadow: var(--shadow-md);
	border-color: #D8B4FE;
}

/* ==========================================================================
   GeneratePress Layout Overrides
   ========================================================================== */

/* Fiche: expand article to fill the content area */
.single-etablissement .site-content {
	flex-direction: column;
}

.single-etablissement .orimap-fiche {
	width: 100%;
	max-width: 720px;
	margin: 0 auto;
	flex: 1;
}

/* Carte: break out of GP container for full-bleed */
.page-template-page-carte-php .grid-container {
	max-width: 100%;
	padding: 0;
}

.page-template-page-carte-php .site-content {
	display: block;  /* override GP's flex row — map handles its own layout */
	padding: 0;
	margin: 0;
}

.page-template-page-carte-php .orimap-map-page {
	width: 100%;
}

.page-template-page-carte-php .inside-article,
.page-template-page-carte-php .entry-content {
	padding: 0;
	margin: 0;
}

/* Dashboard: center the form */
.page-template-page-dashboard-php .site-content {
	flex-direction: column;
}

.page-template-page-dashboard-php .orimap-dashboard {
	width: 100%;
	max-width: 720px;
	margin: 0 auto;
	flex: 1;
}

/* ==========================================================================
   Fiche Etablissement
   ========================================================================== */

.orimap-fiche__header {
	background: linear-gradient(135deg, var(--color-surface), var(--color-primary-light));
	padding: var(--space-6);
	border-radius: var(--radius-lg) var(--radius-lg) 0 0;
}

.orimap-fiche__logo {
	width: 56px;
	height: 56px;
	background: var(--color-white);
	border: 2px solid var(--color-primary-light);
	border-radius: var(--radius-lg);
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 28px;
	margin-bottom: var(--space-3);
}

.orimap-fiche__title {
	font: var(--text-h3);
	color: var(--color-ink);
	margin: 0 0 var(--space-1) 0;
}

.orimap-fiche__subtitle {
	font: var(--text-small);
	color: var(--color-body);
	margin: 0;
}

/* Stats bar */
.orimap-fiche__stats {
	display: flex;
	border-top: 1px solid var(--color-primary-light);
	background: var(--color-white);
}

.orimap-fiche__stat {
	flex: 1;
	text-align: center;
	padding: var(--space-4) var(--space-2);
	border-right: 1px solid var(--color-border);
}

.orimap-fiche__stat:last-child {
	border-right: none;
}

.orimap-fiche__stat-value {
	font: var(--text-data);
	font-variant-numeric: tabular-nums;
}

.orimap-fiche__stat-value--primary { color: var(--color-primary); }
.orimap-fiche__stat-value--success { color: var(--color-success); }
.orimap-fiche__stat-value--accent  { color: var(--color-accent); }

.orimap-fiche__stat-label {
	font: var(--text-caption);
	color: var(--color-body);
	text-transform: uppercase;
	letter-spacing: 0.05em;
	margin-top: var(--space-1);
}

/* Sections */
.orimap-fiche__section {
	padding: var(--space-6);
	border-top: 1px solid var(--color-border);
}

.orimap-fiche__section-title {
	font: var(--text-h2);
	color: var(--color-ink);
	margin: 0 0 var(--space-4) 0;
}

/* Contact info rows */
.orimap-fiche__contact-row {
	display: flex;
	align-items: center;
	gap: var(--space-3);
	padding: var(--space-3) 0;
	border-bottom: 1px solid var(--color-border);
	font: var(--text-body);
	color: var(--color-body);
}

.orimap-fiche__contact-row:last-child {
	border-bottom: none;
}

.orimap-fiche__contact-icon {
	width: 20px;
	color: var(--color-muted);
	flex-shrink: 0;
}

/* JPO card */
.orimap-fiche__jpo {
	display: flex;
	gap: var(--space-4);
	align-items: flex-start;
	padding: var(--space-4);
	background: var(--color-accent-light);
	border-radius: var(--radius-md);
	margin-bottom: var(--space-3);
}

.orimap-fiche__jpo-date {
	background: var(--color-accent);
	color: var(--color-white);
	border-radius: var(--radius-sm);
	padding: var(--space-2) var(--space-3);
	font: var(--text-body-strong);
	font-size: 13px;
	text-align: center;
	white-space: nowrap;
}

/* Gallery */
.orimap-fiche__gallery {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: var(--space-3);
}

@media (min-width: 640px) {
	.orimap-fiche__gallery {
		grid-template-columns: repeat(3, 1fr);
	}
}

.orimap-fiche__gallery img {
	width: 100%;
	aspect-ratio: 4/3;
	object-fit: cover;
	border-radius: var(--radius-md);
}

/* ==========================================================================
   Dashboard (ACF frontend forms)
   ========================================================================== */

.orimap-dashboard {
	max-width: 800px;
	margin: var(--space-8) auto;
	padding: 0 var(--space-4);
}

.orimap-dashboard__title {
	font: var(--text-h1);
	margin-bottom: var(--space-6);
}

/* Style ACF frontend form fields */
.orimap-dashboard .acf-field {
	margin-bottom: var(--space-5);
}

.orimap-dashboard .acf-label label {
	font: var(--text-body-strong);
	color: var(--color-ink);
	margin-bottom: var(--space-2);
}

.orimap-dashboard .acf-input input[type="text"],
.orimap-dashboard .acf-input input[type="email"],
.orimap-dashboard .acf-input input[type="url"],
.orimap-dashboard .acf-input input[type="tel"],
.orimap-dashboard .acf-input textarea,
.orimap-dashboard .acf-input select {
	width: 100%;
	padding: var(--space-3) var(--space-4);
	border: 2px solid var(--color-border);
	border-radius: var(--radius-md);
	font: var(--text-body);
	color: var(--color-ink);
	background: var(--color-white);
	transition: border-color 0.2s ease, box-shadow 0.2s ease;
}

.orimap-dashboard .acf-input input:focus,
.orimap-dashboard .acf-input textarea:focus,
.orimap-dashboard .acf-input select:focus {
	border-color: var(--color-primary);
	box-shadow: 0 0 0 3px rgba(124, 58, 237, 0.15);
	outline: none;
}

.orimap-dashboard .acf-input input::placeholder {
	color: var(--color-muted);
}

/* ACF form submit button */
.orimap-dashboard .acf-form-submit input[type="submit"] {
	background: var(--color-primary);
	color: var(--color-white);
	border: none;
	padding: 12px 28px;
	border-radius: var(--radius-md);
	font: var(--text-body-strong);
	cursor: pointer;
	transition: background 0.2s ease;
}

.orimap-dashboard .acf-form-submit input[type="submit"]:hover {
	background: var(--color-primary-dark);
}

/* ACF image/gallery upload */
.orimap-dashboard .acf-image-uploader,
.orimap-dashboard .acf-gallery {
	border: 2px dashed var(--color-border);
	border-radius: var(--radius-md);
	padding: var(--space-4);
	transition: border-color 0.2s ease;
}

.orimap-dashboard .acf-image-uploader:hover,
.orimap-dashboard .acf-gallery:hover {
	border-color: var(--color-primary);
}

/* Success/error messages for form submission */
.orimap-dashboard .acf-notice.-success {
	background: var(--color-success-light);
	border-left: 4px solid var(--color-success);
	color: #065F46;
	padding: var(--space-4);
	border-radius: var(--radius-md);
	margin-bottom: var(--space-4);
}

.orimap-dashboard .acf-notice.-error {
	background: var(--color-error-light);
	border-left: 4px solid var(--color-error);
	color: #9D174D;
	padding: var(--space-4);
	border-radius: var(--radius-md);
	margin-bottom: var(--space-4);
}

/* ==========================================================================
   Alerts
   ========================================================================== */

.orimap-alert {
	padding: var(--space-4);
	border-radius: var(--radius-md);
	border-left: 4px solid;
	font: var(--text-body);
}

.orimap-alert--info {
	background: var(--color-primary-light);
	border-color: var(--color-primary);
	color: var(--color-primary-dark);
}

.orimap-alert--success {
	background: var(--color-success-light);
	border-color: var(--color-success);
	color: #065F46;
}

.orimap-alert--warning {
	background: var(--color-warning-light);
	border-color: var(--color-warning);
	color: #92400E;
}

.orimap-alert--error {
	background: var(--color-error-light);
	border-color: var(--color-error);
	color: #9D174D;
}

/* ==========================================================================
   Map Page
   ========================================================================== */

.orimap-map-page {
	display: flex;
	height: calc(100vh - 60px); /* subtract header height */
}

.orimap-map-container {
	flex: 1;
	position: relative;
	background: var(--color-surface-alt);
}

.orimap-map-container #orimap-map {
	width: 100%;
	height: 100%;
}

/* Search overlay on map */
.orimap-map-search {
	position: absolute;
	top: var(--space-3);
	left: var(--space-3);
	right: var(--space-3);
	z-index: 1000;
}

.orimap-map-search__input {
	width: 100%;
	padding: var(--space-3) var(--space-4);
	padding-left: 44px;
	border: 2px solid var(--color-primary-light);
	border-radius: 14px;
	font: var(--text-body);
	background: var(--color-white);
	box-shadow: var(--shadow-md);
	transition: border-color 0.2s ease;
}

.orimap-map-search__input:focus {
	border-color: var(--color-primary);
	box-shadow: var(--shadow-md), 0 0 0 3px rgba(124, 58, 237, 0.15);
	outline: none;
}

.orimap-map-search__icon {
	position: absolute;
	left: var(--space-4);
	top: 50%;
	transform: translateY(-50%);
	color: var(--color-muted);
	pointer-events: none;
}

/* Filter chips row */
.orimap-map-chips {
	display: flex;
	gap: var(--space-2);
	padding: var(--space-2) 0;
	overflow-x: auto;
	-webkit-overflow-scrolling: touch;
}

.orimap-chip {
	display: inline-flex;
	align-items: center;
	gap: var(--space-1);
	padding: 6px 14px;
	border-radius: var(--radius-full);
	font: var(--text-small);
	white-space: nowrap;
	cursor: pointer;
	transition: all 0.2s ease;
	border: 1px solid var(--color-border);
	background: var(--color-white);
	color: var(--color-body);
}

.orimap-chip:hover {
	border-color: var(--color-primary);
	color: var(--color-primary);
}

.orimap-chip.is-active {
	background: var(--color-primary);
	color: var(--color-white);
	border-color: var(--color-primary);
}

/* Side panel */
.orimap-panel {
	width: 35%;
	min-width: 340px;
	max-width: 440px;
	overflow-y: auto;
	background: var(--color-white);
	border-left: 1px solid var(--color-border);
	padding: var(--space-4);
}

.orimap-panel__header {
	font: var(--text-h2);
	margin-bottom: var(--space-4);
}

.orimap-panel__count {
	font: var(--text-small);
	color: var(--color-body);
	margin-bottom: var(--space-4);
}

/* Result cards in panel */
.orimap-result {
	padding: var(--space-4);
	border: 1px solid var(--color-border);
	border-radius: var(--radius-md);
	margin-bottom: var(--space-3);
	cursor: pointer;
	transition: all 0.2s ease;
}

.orimap-result:hover {
	border-color: var(--color-primary);
	box-shadow: var(--shadow-sm);
}

.orimap-result__name {
	font: var(--text-body-strong);
	color: var(--color-ink);
	margin-bottom: var(--space-1);
}

.orimap-result__location {
	font: var(--text-small);
	color: var(--color-body);
}

.orimap-result__badges {
	display: flex;
	gap: var(--space-2);
	flex-wrap: wrap;
	margin-top: var(--space-2);
}

/* ==========================================================================
   Mobile — Bottom Sheet & Tab Bar
   ========================================================================== */

@media (max-width: 639px) {
	.orimap-map-page {
		flex-direction: column;
		height: calc(100vh - 56px); /* subtract tab bar */
	}

	.orimap-map-container {
		height: 60vh;
	}

	.orimap-panel {
		width: 100%;
		min-width: unset;
		max-width: unset;
		border-left: none;
		border-top: 1px solid var(--color-border);
		height: 40vh;
	}

	/* Bottom tab bar */
	.orimap-tab-bar {
		display: flex;
		position: fixed;
		bottom: 0;
		left: 0;
		right: 0;
		height: 56px;
		padding-bottom: env(safe-area-inset-bottom, 0px);
		background: var(--color-white);
		border-top: 1px solid var(--color-border);
		box-shadow: 0 -2px 8px rgba(0, 0, 0, 0.06);
		z-index: 9999;
	}

	.orimap-tab-bar__item {
		flex: 1;
		display: flex;
		flex-direction: column;
		align-items: center;
		justify-content: center;
		gap: 2px;
		color: var(--color-muted);
		font: var(--text-caption);
		font-size: 11px;
		text-decoration: none;
		transition: color 0.2s ease;
	}

	.orimap-tab-bar__item.is-active {
		color: var(--color-primary);
	}

	.orimap-tab-bar__icon {
		width: 24px;
		height: 24px;
	}
}

/* Tablet */
@media (min-width: 640px) and (max-width: 1024px) {
	.orimap-panel {
		width: 40%;
		min-width: 300px;
	}
}

/* Hide tab bar on desktop */
@media (min-width: 640px) {
	.orimap-tab-bar {
		display: none;
	}
}

/* ==========================================================================
   Reduced Motion
   ========================================================================== */

@media (prefers-reduced-motion: reduce) {
	*,
	*::before,
	*::after {
		animation-duration: 0.01ms !important;
		animation-iteration-count: 1 !important;
		transition-duration: 0.01ms !important;
	}
}
