/* =========================================================
   Sites Touristiques d'Alsace — styles globaux du thème
   ========================================================= */

:root {
	--sta-green: #22402E;
	--sta-green-dark: #1A3324;
	--sta-orange: #CB6843;
	--sta-orange-dark: #B0512F;
	--sta-cream: #F1ECE1;
	--sta-paper: #FFFFFF;
	--sta-ink: #262521;
	--sta-muted: #6B6A64;
	--sta-line: rgba(38, 37, 33, .10);

	--cat-histoire: #C9A23F;
	--cat-nature: #CB6843;
	--cat-famille: #3E86AC;
	--cat-culture: #6E5499;
	--cat-gastronomie: #BB4F38;

	--sta-font-display: 'Oswald', system-ui, sans-serif;
	--sta-font-body: 'Inter', system-ui, -apple-system, sans-serif;
	--sta-font-script: 'Caveat', cursive;

	--sta-radius: 14px;
	--sta-radius-lg: 22px;
	--sta-shadow: 0 18px 40px -24px rgba(26, 51, 36, .45);
	--sta-wrap: 1280px;
	--sta-gutter: clamp(1rem, 4vw, 2.5rem);
}

*, *::before, *::after { box-sizing: border-box; }

body {
	margin: 0;
	font-family: var(--sta-font-body);
	color: var(--sta-ink);
	background: var(--sta-cream);
	line-height: 1.6;
	-webkit-font-smoothing: antialiased;
}

body.sta-nav-open { overflow: hidden; }

img { max-width: 100%; height: auto; display: block; }
a { color: var(--sta-orange-dark); }

.sta-skip-link {
	position: absolute; left: -9999px; top: 0; z-index: 9999;
	background: var(--sta-green); color: #fff; padding: .75rem 1.25rem; border-radius: 0 0 10px 0;
}
.sta-skip-link:focus { left: 0; }

/* ---------- Primitives partagées ---------- */
.sta-eyebrow {
	display: inline-block;
	font-family: var(--sta-font-display);
	text-transform: uppercase;
	letter-spacing: .22em;
	font-size: .8rem;
	font-weight: 500;
	color: var(--sta-orange);
}

.sta-section__title {
	font-family: var(--sta-font-display);
	text-transform: uppercase;
	letter-spacing: .06em;
	font-weight: 600;
	color: var(--sta-green);
	font-size: clamp(1.5rem, 3vw, 2rem);
	line-height: 1.1;
	margin: 0;
}

/* Titre centré avec petits tirets de part et d'autre */
.sta-section__title--dashed {
	display: flex; align-items: center; justify-content: center; gap: 1rem;
	text-align: center;
}
.sta-section__title--dashed::before,
.sta-section__title--dashed::after {
	content: ""; height: 2px; width: 34px; background: var(--sta-green); opacity: .55;
}

.sta-btn {
	display: inline-flex; align-items: center; gap: .5rem;
	font-family: var(--sta-font-display);
	text-transform: uppercase; letter-spacing: .08em; font-weight: 500;
	font-size: .82rem;
	padding: .85rem 1.5rem;
	border-radius: 999px;
	border: 0; cursor: pointer; text-decoration: none;
	transition: transform .15s ease, background-color .2s ease, box-shadow .2s ease;
	line-height: 1;
}
.sta-btn:hover { transform: translateY(-1px); }
.sta-btn--cta { background: var(--sta-orange); color: #fff; box-shadow: 0 10px 22px -12px var(--sta-orange-dark); }
.sta-btn--cta:hover { background: var(--sta-orange-dark); }
.sta-btn--green { background: var(--sta-green); color: #fff; }
.sta-btn--green:hover { background: var(--sta-green-dark); }
.sta-btn--ghost { background: transparent; color: var(--sta-green); border: 1.5px solid currentColor; }
.sta-btn--ghost:hover { background: var(--sta-green); color: #fff; }
.sta-btn--arrow::after { content: "›"; font-family: var(--sta-font-body); font-size: 1.1em; line-height: 0; }

/* Chips de thème (pastille couleur + label) */
.sta-chip {
	display: inline-flex; align-items: center; gap: .5rem;
	font-family: var(--sta-font-display);
	text-transform: uppercase; letter-spacing: .1em; font-size: .68rem; font-weight: 500;
	padding: .35rem .75rem; border-radius: 999px;
	background: rgba(255,255,255,.92); color: var(--sta-ink);
	border: 0; cursor: pointer;
}
.sta-chip::before { content: ""; width: 8px; height: 8px; border-radius: 50%; background: var(--chip, var(--sta-orange)); }
.sta-chip.is-active { background: var(--sta-green); color: #fff; }
.sta-chip.is-active::before { background: #fff; }

/* =========================================================
   Header
   ========================================================= */
.sta-header {
	position: sticky; top: 0; z-index: 100;
	background: var(--sta-paper);
	border-bottom: 1px solid var(--sta-line);
	transition: box-shadow .25s ease;
}
.sta-header.is-scrolled { box-shadow: 0 8px 24px -18px rgba(0,0,0,.45); }
.sta-header__inner {
	max-width: var(--sta-wrap); margin: 0 auto;
	padding: .85rem var(--sta-gutter);
	display: grid; grid-template-columns: auto 1fr auto; align-items: center; gap: 1.5rem;
}
.sta-header__logo-text { text-decoration: none; line-height: 1; display: grid; }
.sta-header__logo-top { font-family: var(--sta-font-display); text-transform: uppercase; letter-spacing: .25em; font-size: .56rem; font-weight: 500; color: var(--sta-green); }
.sta-header__logo-main { font-family: var(--sta-font-display); text-transform: uppercase; letter-spacing: .08em; font-size: 1.45rem; font-weight: 700; color: var(--sta-green); }
.sta-header .custom-logo-link { display: inline-flex; }

.sta-header__nav { display: flex; justify-content: center; }
.sta-menu { list-style: none; display: flex; gap: clamp(.75rem, 2vw, 1.75rem); margin: 0; padding: 0; }
.sta-menu a {
	font-family: var(--sta-font-display); text-transform: uppercase; letter-spacing: .08em;
	font-size: .82rem; font-weight: 500; color: var(--sta-ink); text-decoration: none;
	padding: .4rem 0; position: relative;
}
.sta-menu a::after { content: ""; position: absolute; left: 0; bottom: -2px; height: 2px; width: 0; background: var(--sta-orange); transition: width .2s ease; }
.sta-menu a:hover::after, .sta-menu .current-menu-item > a::after { width: 100%; }

.sta-header__actions { display: flex; align-items: center; gap: .65rem; }
.sta-iconbtn {
	display: inline-flex; align-items: center; justify-content: center;
	width: 40px; height: 40px; border-radius: 50%;
	background: transparent; border: 0; color: var(--sta-green); cursor: pointer; text-decoration: none;
	transition: background-color .2s ease;
}
.sta-iconbtn:hover { background: var(--sta-cream); }

.sta-header__search { border-top: 1px solid var(--sta-line); background: var(--sta-cream); }
.sta-header__search-inner { max-width: var(--sta-wrap); margin: 0 auto; padding: 1rem var(--sta-gutter); }
.sta-header__search .search-form { display: flex; gap: .5rem; }
.sta-header__search input[type="search"] { flex: 1; padding: .8rem 1rem; border: 1px solid var(--sta-line); border-radius: 999px; font-family: var(--sta-font-body); }
.sta-header__search input[type="submit"] { padding: .8rem 1.4rem; border: 0; border-radius: 999px; background: var(--sta-green); color: #fff; font-family: var(--sta-font-display); text-transform: uppercase; letter-spacing: .08em; cursor: pointer; }

.sta-burger { display: none; flex-direction: column; gap: 5px; width: 42px; height: 42px; align-items: center; justify-content: center; background: transparent; border: 0; cursor: pointer; }
.sta-burger span { width: 22px; height: 2px; background: var(--sta-green); transition: transform .2s ease, opacity .2s ease; }
.sta-burger.is-open span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.sta-burger.is-open span:nth-child(2) { opacity: 0; }
.sta-burger.is-open span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

.sta-mobile-nav { padding: 1rem var(--sta-gutter) 1.5rem; border-top: 1px solid var(--sta-line); }
.sta-mobile-menu { list-style: none; margin: 0 0 1rem; padding: 0; display: grid; gap: .25rem; }
.sta-mobile-menu a { display: block; padding: .65rem 0; font-family: var(--sta-font-display); text-transform: uppercase; letter-spacing: .06em; color: var(--sta-ink); text-decoration: none; border-bottom: 1px solid var(--sta-line); }
.sta-mobile-nav__cta { width: 100%; justify-content: center; }

@media (max-width: 1024px) {
	.sta-header__nav { display: none; }
	.sta-header__inner { grid-template-columns: auto 1fr; }
	.sta-burger { display: flex; }
	.sta-header__actions .sta-btn--cta { display: none; }
}
@media (min-width: 1025px) {
	.sta-mobile-nav { display: none !important; }
}

/* =========================================================
   Gabarits de page / article
   ========================================================= */
.sta-main { display: block; }
.sta-front { display: block; }

/* Largeurs de blocs (utile si les blocs STA sont posés sur une page normale) */
.alignfull { width: 100vw; max-width: 100vw; margin-left: calc(50% - 50vw); margin-right: calc(50% - 50vw); }
.alignwide { width: min(100%, 1100px); margin-left: auto; margin-right: auto; }
.sta-front .alignfull { margin-left: calc(50% - 50vw); }

.sta-page { padding: clamp(2.5rem, 6vw, 5rem) 0; }
.sta-page__inner { max-width: var(--sta-wrap); margin: 0 auto; padding: 0 var(--sta-gutter); }
.sta-page__inner--narrow { max-width: 820px; }

.sta-article__title { font-family: var(--sta-font-display); color: var(--sta-green); text-transform: uppercase; letter-spacing: .03em; font-size: clamp(1.8rem, 4vw, 2.8rem); line-height: 1.1; }
.sta-article__title span { color: var(--sta-orange); }
.sta-article__media { margin: 1.5rem 0; border-radius: var(--sta-radius-lg); overflow: hidden; }
.sta-article__content { font-size: 1.05rem; }
.sta-article__content h2, .sta-article__content h3 { font-family: var(--sta-font-display); color: var(--sta-green); }

/* Grilles d'archive génériques */
.sta-archive-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)); gap: 1.5rem; }
.sta-card-post__link { text-decoration: none; color: inherit; display: grid; background: var(--sta-paper); border-radius: var(--sta-radius); overflow: hidden; box-shadow: var(--sta-shadow); transition: transform .2s ease; }
.sta-card-post__link:hover { transform: translateY(-3px); }
.sta-card-post__media img { aspect-ratio: 16/10; object-fit: cover; width: 100%; }
.sta-card-post__body { padding: 1.1rem 1.2rem 1.4rem; display: grid; gap: .4rem; }
.sta-card-post__title { font-family: var(--sta-font-display); font-size: 1.15rem; color: var(--sta-green); }
.sta-card-post__excerpt { color: var(--sta-muted); font-size: .92rem; }

.sta-pagination { margin-top: 2.5rem; }
.sta-pagination .page-numbers { display: inline-flex; padding: .5rem .85rem; border-radius: 8px; text-decoration: none; color: var(--sta-ink); }
.sta-pagination .page-numbers.current { background: var(--sta-green); color: #fff; }

.sta-noresults { text-align: center; padding: 3rem 0; }
.sta-noresults h2 { font-family: var(--sta-font-display); color: var(--sta-green); }

/* Archive Sites + filtres */
.sta-archive-sites__head { text-align: center; margin-bottom: 1.5rem; }
.sta-filters { display: flex; flex-wrap: wrap; gap: .5rem; justify-content: center; margin-bottom: 2rem; }
.sta-sites-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(250px, 1fr)); gap: 1.25rem; }

/* Fiche site */
.sta-site-single__hero { min-height: 52vh; background-size: cover; background-position: center; display: flex; align-items: flex-end; position: relative; }
.sta-site-single__hero::after { content: ""; position: absolute; inset: 0; background: linear-gradient(to top, rgba(26,51,36,.85), rgba(26,51,36,.1) 55%); }
.sta-site-single__hero-inner { position: relative; z-index: 1; max-width: var(--sta-wrap); margin: 0 auto; width: 100%; padding: 2.5rem var(--sta-gutter); color: #fff; }
.sta-site-single__title { font-family: var(--sta-font-display); text-transform: uppercase; letter-spacing: .03em; font-size: clamp(2rem, 5vw, 3.4rem); margin: .6rem 0 .3rem; line-height: 1; }
.sta-site-single__meta { display: inline-flex; align-items: center; gap: .4rem; font-family: var(--sta-font-display); letter-spacing: .05em; opacity: .92; }
.sta-site-single__lead { font-size: 1.25rem; color: var(--sta-green); font-weight: 500; margin: 2rem 0; }

/* =========================================================
   Footer
   ========================================================= */
.sta-footer { background: var(--sta-cream); border-top: 1px solid var(--sta-line); }
.sta-footer__inner {
	max-width: var(--sta-wrap); margin: 0 auto; padding: clamp(2.5rem, 5vw, 4rem) var(--sta-gutter) 2.5rem;
	display: grid; grid-template-columns: 1.4fr repeat(3, 1fr) 1.4fr; gap: 2rem;
}
.sta-footer__logo { text-decoration: none; display: grid; }
.sta-footer__logo-top { font-family: var(--sta-font-display); text-transform: uppercase; letter-spacing: .25em; font-size: .56rem; color: var(--sta-green); }
.sta-footer__logo-main { font-family: var(--sta-font-display); text-transform: uppercase; letter-spacing: .08em; font-size: 1.45rem; font-weight: 700; color: var(--sta-green); }
.sta-footer__tagline { font-family: var(--sta-font-script); font-size: 1.25rem; color: var(--sta-orange); margin: .35rem 0 0; }
.sta-footer__title { font-family: var(--sta-font-display); text-transform: uppercase; letter-spacing: .1em; font-size: .82rem; color: var(--sta-green); margin: 0 0 .9rem; }
.sta-footer__title--mt { margin-top: 1.6rem; }
.sta-footer__menu { list-style: none; margin: 0; padding: 0; display: grid; gap: .55rem; }
.sta-footer__menu a { text-decoration: none; color: var(--sta-ink); font-size: .92rem; }
.sta-footer__menu a:hover { color: var(--sta-orange-dark); }
.sta-footer__social { display: flex; gap: .6rem; }
.sta-footer__social a { display: inline-flex; align-items: center; justify-content: center; width: 38px; height: 38px; border-radius: 50%; background: var(--sta-paper); color: var(--sta-green); text-decoration: none; transition: transform .15s ease, color .2s; }
.sta-footer__social a:hover { transform: translateY(-2px); color: var(--sta-orange); }

.sta-newsletter { display: flex; gap: .5rem; }
.sta-newsletter input { flex: 1; min-width: 0; padding: .7rem .9rem; border: 1px solid var(--sta-line); border-radius: 8px; background: var(--sta-paper); }
.sta-newsletter .sta-btn { padding: .7rem 1.2rem; }
.sta-newsletter__ok { color: var(--sta-green); font-weight: 600; margin: 0; }

.sta-footer__bar { border-top: 1px solid var(--sta-line); }
.sta-footer__bar-inner { max-width: var(--sta-wrap); margin: 0 auto; padding: 1.1rem var(--sta-gutter); display: flex; align-items: center; gap: 1.5rem; flex-wrap: wrap; font-size: .82rem; color: var(--sta-muted); }
.sta-footer__copy { margin: 0; }
.sta-footer__legal { list-style: none; display: flex; gap: 1.25rem; margin: 0; padding: 0; }
.sta-footer__legal a { color: var(--sta-muted); text-decoration: underline; }
.sta-footer__lang { margin-left: auto; }

@media (max-width: 900px) {
	.sta-footer__inner { grid-template-columns: 1fr 1fr; }
	.sta-footer__brand, .sta-footer__col--wide { grid-column: 1 / -1; }
}
@media (max-width: 560px) {
	.sta-footer__inner { grid-template-columns: 1fr; }
	.sta-footer__bar-inner { flex-direction: column; align-items: flex-start; }
	.sta-footer__lang { margin-left: 0; }
}

@media (prefers-reduced-motion: reduce) {
	* { animation-duration: .001ms !important; transition-duration: .001ms !important; }
}
