/* ==========================================================================
   ANCIC Tools Page — Nos outils
   Sections: hero · tool sections
   ========================================================================== */

/* ---------------------------------------------------------------------------
   1. Hero — [ancic_tools_hero]
   --------------------------------------------------------------------------- */

.ancic-tools-hero {
	background: linear-gradient(150deg, var(--ancic-blue, #00A1D7) 0%, #0081ad 55%, #005f80 100%);
	padding-block: var(--sp-20, 5rem) var(--sp-16, 4rem);
	overflow: hidden;
}

.ancic-tools-hero__inner {
	display: grid;
	grid-template-columns: 1fr 320px;
	gap: var(--sp-12, 3rem);
	align-items: center;
}

.ancic-tools-hero__overline {
	font-family: var(--font-ui, 'Inter', system-ui, sans-serif);
	font-size: var(--text-xs, 0.75rem);
	font-weight: 600;
	letter-spacing: var(--tracking-widest, 0.1em);
	text-transform: uppercase;
	color: rgba(255, 255, 255, 0.65);
	margin: 0 0 var(--sp-3, 0.75rem);
}

.ancic-tools-hero__title {
	font-family: var(--font-ui, 'Inter', system-ui, sans-serif);
	font-size: clamp(1.875rem, 4vw, 3rem);
	font-weight: 800;
	line-height: 1.15;
	letter-spacing: -0.025em;
	color: #fff;
	margin: 0 0 var(--sp-5, 1.25rem);
}

.ancic-tools-hero__lead {
	font-family: var(--font-body, 'Source Serif 4', Georgia, serif);
	font-size: var(--text-lg, 1.125rem);
	line-height: 1.65;
	color: rgba(255, 255, 255, 0.82);
	margin: 0;
	max-width: 520px;
}

.ancic-tools-hero__visual {
	display: flex;
	align-items: center;
	justify-content: center;
}

.ancic-tools-hero__icon-grid {
	display: grid;
	grid-template-columns: repeat(3, 80px);
	grid-template-rows: repeat(2, 80px);
	gap: 10px;
}

.ancic-tools-hero__icon-tile {
	display: flex !important;
	align-items: center !important;
	justify-content: center !important;
	width: 80px !important;
	height: 80px !important;
	background: rgba(0, 0, 0, 0.18) !important;
	border: 1px solid rgba(255, 255, 255, 0.2) !important;
	border-radius: 16px !important;
	overflow: hidden !important;
}

.ancic-tools-hero__icon-tile--accent {
	background: rgba(255, 255, 255, 0.18) !important;
}

.ancic-tools-hero__icon-tile svg {
	display: block !important;
	width: 30px !important;
	height: 30px !important;
	min-width: 30px !important;
	max-width: 30px !important;
	min-height: 30px !important;
	max-height: 30px !important;
	color: #fff !important;
	stroke: #fff !important;
	flex-shrink: 0 !important;
}

@media (max-width: 1024px) {
	.ancic-tools-hero__inner {
		grid-template-columns: 1fr;
	}
	.ancic-tools-hero__visual {
		display: none;
	}
}

@media (max-width: 720px) {
	.ancic-tools-hero {
		padding-block: var(--sp-12, 3rem) var(--sp-10, 2.5rem);
	}
	.ancic-tools-hero__title {
		font-size: var(--text-3xl, 1.875rem);
	}
}

/* ---------------------------------------------------------------------------
   2. Tool sections — shared layout
   --------------------------------------------------------------------------- */

.ancic-tool-section {
	padding-block: var(--sp-14, 3.5rem);
	border-bottom: 1px solid var(--ancic-rule, #e5e5ea);
}

.ancic-tool-section:last-of-type {
	border-bottom: none;
}

.ancic-tool-section--white {
	background: var(--ancic-white, #fff);
}

.ancic-tool-section--surface {
	background: var(--ancic-surface, #f5f5f7);
}

/* Section header row: icon + badge + title */
.ancic-tool-section__header {
	display: flex;
	align-items: flex-start;
	gap: var(--sp-5, 1.25rem);
	margin-bottom: var(--sp-8, 2rem);
}

.ancic-tool-section__icon-wrap {
	width: 56px !important;
	height: 56px !important;
	min-width: 56px !important;
	display: flex !important;
	align-items: center !important;
	justify-content: center !important;
	border-radius: 14px !important;
	overflow: hidden !important;
	flex-shrink: 0 !important;
	align-self: flex-start !important;
}

.ancic-tool-section__icon-wrap--blue {
	background: var(--ancic-blue-faint, #e8f7fd) !important;
}

.ancic-tool-section__icon-wrap--teal {
	background: rgba(0, 129, 173, 0.1) !important;
}

.ancic-tool-section__icon-wrap svg {
	display: block !important;
	width: 24px !important;
	height: 24px !important;
	min-width: 24px !important;
	max-width: 24px !important;
	min-height: 24px !important;
	max-height: 24px !important;
	flex-shrink: 0 !important;
}

.ancic-tool-section__icon-wrap--blue svg {
	color: var(--ancic-blue, #00A1D7) !important;
	stroke: var(--ancic-blue, #00A1D7) !important;
}

.ancic-tool-section__icon-wrap--teal svg {
	color: #0081ad !important;
	stroke: #0081ad !important;
}

.ancic-tool-section__header-text {
	display: block;
}

.ancic-tool-section__title {
	font-family: var(--font-ui, 'Inter', system-ui, sans-serif);
	font-size: clamp(1.125rem, 2.5vw, 1.5rem);
	font-weight: 800;
	line-height: 1.25;
	letter-spacing: -0.02em;
	color: var(--ancic-blue, #1a3a5c);
	margin: 0;
}

/* Layout variants */
.ancic-tool-section__layout {
	display: grid;
	gap: var(--sp-10, 2.5rem);
	align-items: start;
}

.ancic-tool-section__layout--video {
	grid-template-columns: 1fr 520px;
}

.ancic-tool-section__layout--preview {
	grid-template-columns: 1fr 240px;
}

.ancic-tool-section__layout--preview-wide {
	grid-template-columns: 1fr 400px;
}

/* Body text */
.ancic-tool-section__body p {
	font-family: var(--font-body, 'Source Serif 4', Georgia, serif);
	font-size: var(--text-base, 1rem);
	line-height: 1.65;
	color: var(--ancic-ink-mid, #3a3a3c);
	margin: 0 0 var(--sp-4, 1rem);
}

.ancic-tool-section__body p:last-child {
	margin-bottom: 0;
}

/* Blockquote */
.ancic-tool-section__quote {
	background: var(--ancic-blue-faint, #f0f5fa);
	border-left: 3px solid var(--ancic-blue, #00A1D7);
	border-radius: 0 var(--r-lg, 10px) var(--r-lg, 10px) 0;
	padding: var(--sp-4, 1rem) var(--sp-5, 1.25rem);
	margin: var(--sp-4, 1rem) 0;
}

.ancic-tool-section__quote p {
	font-family: var(--font-body, 'Source Serif 4', Georgia, serif);
	font-size: var(--text-base, 1rem);
	font-style: italic;
	line-height: 1.65;
	color: var(--ancic-blue, #1a3a5c);
	margin: 0 !important;
}

/* Credits */
.ancic-tool-section__credits {
	margin-top: var(--sp-6, 1.5rem);
	padding-top: var(--sp-6, 1.5rem);
	border-top: 1px solid var(--ancic-rule, #e5e5ea);
}

.ancic-tool-section__credits p {
	font-family: var(--font-ui, 'Inter', system-ui, sans-serif) !important;
	font-size: var(--text-sm, 0.875rem) !important;
	line-height: 1.55 !important;
	color: var(--ancic-ink-light, #636366) !important;
}

.ancic-tool-section__credits-list {
	list-style: none;
	padding: 0;
	margin: var(--sp-2, 0.5rem) 0 var(--sp-4, 1rem);
}

.ancic-tool-section__credits-list li {
	font-family: var(--font-ui, 'Inter', system-ui, sans-serif);
	font-size: var(--text-sm, 0.875rem);
	line-height: 1.6;
	color: var(--ancic-ink-light, #636366);
	padding-left: var(--sp-4, 1rem);
	position: relative;
}

.ancic-tool-section__credits-list li::before {
	content: '—';
	position: absolute;
	left: 0;
	color: var(--ancic-rule, #c0c0c8);
}

.ancic-tool-section__credits-footer {
	font-family: var(--font-ui, 'Inter', system-ui, sans-serif) !important;
	font-size: 0.8125rem !important;
	color: var(--ancic-ink-light, #636366) !important;
}

/* List */
.ancic-tool-section__list {
	list-style: none;
	padding: 0;
	margin: var(--sp-2, 0.5rem) 0 var(--sp-4, 1rem);
	display: flex;
	flex-direction: column;
	gap: var(--sp-3, 0.75rem);
}

.ancic-tool-section__list li {
	font-family: var(--font-body, 'Source Serif 4', Georgia, serif);
	font-size: var(--text-base, 1rem);
	line-height: 1.6;
	color: var(--ancic-ink-mid, #3a3a3c);
	padding-left: var(--sp-5, 1.25rem);
	position: relative;
}

.ancic-tool-section__list li::before {
	content: '';
	position: absolute;
	left: 0;
	top: 0.6em;
	width: 6px;
	height: 6px;
	background: var(--ancic-blue, #00A1D7);
	border-radius: 50%;
}

/* Hint */
.ancic-tool-section__hint {
	font-family: var(--font-ui, 'Inter', system-ui, sans-serif) !important;
	font-size: var(--text-sm, 0.875rem) !important;
	color: var(--ancic-ink-light, #636366) !important;
	font-style: italic;
}

/* Video embed */
.ancic-tool-section__video-wrap {
	position: relative;
	width: 100%;
	padding-bottom: 56.25%;
	border-radius: var(--r-xl, 16px);
	overflow: hidden;
	background: var(--ancic-blue, #1a3a5c);
	box-shadow: 0 8px 32px rgba(0, 0, 0, 0.16);
}

.ancic-tool-section__video-wrap iframe {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	border: none;
}

/* Preview thumbnail */
.ancic-tool-section__preview {
	display: flex;
	align-items: flex-start;
	justify-content: center;
}

.ancic-tool-section__preview-link {
	position: relative;
	display: block;
	border-radius: var(--r-xl, 14px);
	overflow: hidden;
	box-shadow: 0 4px 20px rgba(0, 0, 0, 0.12);
	transition: transform 220ms cubic-bezier(0.16, 1, 0.3, 1),
	            box-shadow 220ms cubic-bezier(0.16, 1, 0.3, 1);
	text-decoration: none;
}

.ancic-tool-section__preview-link:hover {
	transform: translateY(-3px);
	box-shadow: 0 8px 28px rgba(0, 0, 0, 0.18);
}

.ancic-tool-section__preview-img {
	display: block;
	width: 100%;
	height: auto;
}

.ancic-tool-section__preview-overlay {
	position: absolute;
	inset: 0;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	gap: var(--sp-2, 0.5rem);
	background: rgba(0, 0, 0, 0);
	color: #fff;
	font-family: var(--font-ui, 'Inter', system-ui, sans-serif);
	font-size: var(--text-sm, 0.875rem);
	font-weight: 600;
	text-align: center;
	padding: var(--sp-3, 0.75rem);
	opacity: 0;
	transition: background 200ms ease, opacity 200ms ease;
}

.ancic-tool-section__preview-link:hover .ancic-tool-section__preview-overlay {
	background: rgba(0, 80, 120, 0.72);
	opacity: 1;
}

.ancic-tool-section__preview-overlay svg {
	display: block !important;
	width: 28px !important;
	height: 28px !important;
	color: #fff !important;
	stroke: #fff !important;
}

/* Multi-preview (two documents side by side) */
.ancic-tool-section__multi-preview {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: var(--sp-6, 1.5rem);
	max-width: 640px;
	margin-bottom: var(--sp-8, 2rem);
}

/* Order block */
.ancic-tool-section__order-block {
	display: flex;
	align-items: flex-start;
	gap: var(--sp-3, 0.75rem);
	background: var(--ancic-blue-faint, #e8f7fd);
	border: 1px solid rgba(0, 161, 215, 0.15);
	border-radius: var(--r-lg, 10px);
	padding: var(--sp-5, 1.25rem);
	margin-bottom: var(--sp-6, 1.5rem);
}

.ancic-tool-section__order-block--standalone {
	max-width: 640px;
	margin-bottom: 0;
}

.ancic-tool-section__order-icon {
	display: flex !important;
	align-items: center !important;
	justify-content: center !important;
	width: 36px !important;
	height: 36px !important;
	min-width: 36px !important;
	background: rgba(0, 161, 215, 0.15) !important;
	border-radius: 8px !important;
	flex-shrink: 0 !important;
	margin-top: 2px;
}

.ancic-tool-section__order-icon svg {
	display: block !important;
	width: 16px !important;
	height: 16px !important;
	min-width: 16px !important;
	max-width: 16px !important;
	color: var(--ancic-blue, #0081ad) !important;
	stroke: var(--ancic-blue, #0081ad) !important;
}

.ancic-tool-section__order-block p {
	font-family: var(--font-body, 'Source Serif 4', Georgia, serif);
	font-size: var(--text-sm, 0.875rem);
	line-height: 1.65;
	color: var(--ancic-ink-mid, #3a3a3c);
	margin: 0;
}

.ancic-tool-section__mailto {
	color: var(--ancic-blue, #0081ad);
	font-weight: 600;
	text-decoration: none;
}

.ancic-tool-section__mailto:hover {
	text-decoration: underline;
}

/* CTA button inside section */
.ancic-tool-section__cta {
	display: inline-flex !important;
	align-items: center !important;
	gap: var(--sp-2, 0.5rem) !important;
	margin-top: var(--sp-2, 0.5rem);
}

.ancic-tool-section__cta svg {
	display: block !important;
	width: 16px !important;
	height: 16px !important;
	min-width: 16px !important;
	max-width: 16px !important;
	flex-shrink: 0 !important;
}

/* ---------------------------------------------------------------------------
   3. Badge
   --------------------------------------------------------------------------- */

.ancic-tool-badge {
	display: inline-flex;
	align-items: center;
	font-family: var(--font-ui, 'Inter', system-ui, sans-serif);
	font-size: 0.6875rem;
	font-weight: 700;
	letter-spacing: 0.06em;
	text-transform: uppercase;
	padding: 3px 10px;
	border-radius: 100px;
	line-height: 1.4;
	margin-bottom: 4px;
}

.ancic-tool-badge--pdf {
	background: rgba(0, 161, 215, 0.1);
	color: #0081ad;
}

.ancic-tool-badge--video {
	background: rgba(255, 59, 48, 0.1);
	color: #c0392b;
}

.ancic-tool-badge--kit {
	background: rgba(255, 149, 0, 0.12);
	color: #a05900;
}

.ancic-tool-badge--study {
	background: rgba(90, 90, 120, 0.1);
	color: #3a3a5c;
}

/* Preview figure wrapper (thumbnail + caption) */
.ancic-tool-section__preview-figure {
	display: flex;
	flex-direction: column;
	gap: var(--sp-2, 0.5rem);
}

.ancic-tool-section__preview-caption {
	font-family: var(--font-ui, 'Inter', system-ui, sans-serif);
	font-size: var(--text-xs, 0.75rem);
	line-height: 1.4;
	color: var(--ancic-ink-light, #636366);
	text-align: center;
	margin: 0;
	padding: 0 var(--sp-1, 0.25rem);
}

/* Multi-preview wide variant (study / double-doc sections) */
.ancic-tool-section__multi-preview--wide {
	max-width: 560px;
}

/* External CTA block (site link) */
.ancic-tool-section__external-cta {
	display: flex;
	flex-direction: column;
	align-items: flex-start;
	gap: var(--sp-4, 1rem);
}

.ancic-tool-section__external-desc {
	font-family: var(--font-body, 'Source Serif 4', Georgia, serif);
	font-size: var(--text-base, 1rem);
	line-height: 1.65;
	color: var(--ancic-ink-mid, #3a3a3c);
	margin: 0;
	max-width: 520px;
}

/* Intro body text (above multi-preview) */
.ancic-tool-section__body--intro {
	margin-bottom: var(--sp-6, 1.5rem);
}

.ancic-tool-section__body--intro p {
	font-family: var(--font-body, 'Source Serif 4', Georgia, serif);
	font-size: var(--text-base, 1rem);
	line-height: 1.65;
	color: var(--ancic-ink-mid, #3a3a3c);
	margin: 0;
}

/* ---------------------------------------------------------------------------
   4. Responsive
   --------------------------------------------------------------------------- */

@media (max-width: 1200px) {
	.ancic-tool-section__layout--video {
		grid-template-columns: 1fr 420px;
	}
}

@media (max-width: 1024px) {
	.ancic-tool-section__layout--video,
	.ancic-tool-section__layout--preview,
	.ancic-tool-section__layout--preview-wide {
		grid-template-columns: 1fr;
	}

	.ancic-tool-section__layout--preview .ancic-tool-section__preview,
	.ancic-tool-section__layout--preview-wide .ancic-tool-section__preview {
		justify-content: flex-start;
	}

	.ancic-tool-section__layout--preview .ancic-tool-section__preview-link {
		max-width: 260px;
	}

	.ancic-tool-section__layout--preview-wide .ancic-tool-section__preview-link {
		max-width: 100%;
	}
}

@media (max-width: 720px) {
	.ancic-tool-section {
		padding-block: var(--sp-10, 2.5rem);
	}

	.ancic-tool-section__header {
		flex-direction: column;
		gap: var(--sp-3, 0.75rem);
	}

	.ancic-tool-section__multi-preview {
		grid-template-columns: 1fr 1fr;
		max-width: 100%;
	}
}

@media (max-width: 480px) {
	.ancic-tool-section__multi-preview {
		grid-template-columns: 1fr;
		max-width: 280px;
	}
}

/* ---------------------------------------------------------------------------
   5. Accordion dynamique — [ancic_outils_dynamiques]
   --------------------------------------------------------------------------- */

.ancic-outils-accordion {
	display: flex;
	flex-direction: column;
	gap: 0;
	border: 1px solid var(--ancic-rule, #e5e5ea);
	border-radius: var(--r-xl, 16px);
	overflow: hidden;
}

.ancic-outils-empty {
	font-family: var(--font-body, 'Source Serif 4', Georgia, serif);
	font-size: var(--text-base, 1rem);
	color: var(--ancic-ink-light, #636366);
	text-align: center;
	padding: var(--sp-10, 2.5rem);
}

.ancic-outil-accordion__item {
	border-bottom: 1px solid var(--ancic-rule, #e5e5ea);
}

.ancic-outil-accordion__item:last-child {
	border-bottom: none;
}

/* Trigger — header row */
.ancic-outil-accordion__trigger {
	width: 100%;
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: var(--sp-4, 1rem);
	padding: var(--sp-5, 1.25rem) var(--sp-6, 1.5rem);
	background: var(--ancic-white, #fff);
	border: none;
	cursor: pointer;
	text-align: left;
	transition: background var(--dur-base, 220ms);
	min-height: 72px;
}

.ancic-outil-accordion__trigger:hover {
	background: var(--ancic-blue-faint, #e8f7fd);
}

.ancic-outil-accordion__item--open .ancic-outil-accordion__trigger {
	background: var(--ancic-blue-faint, #e8f7fd);
	border-bottom: 1px solid var(--ancic-blue-light, #cceef9);
}

.ancic-outil-accordion__trigger-left {
	display: flex;
	align-items: center;
	gap: var(--sp-4, 1rem);
	flex: 1;
	min-width: 0;
}

/* Numbered index */
.ancic-outil-accordion__index {
	font-family: var(--font-ui, 'Inter', system-ui, sans-serif);
	font-size: var(--text-xs, 0.75rem);
	font-weight: 700;
	color: var(--ancic-blue, #00A1D7);
	min-width: 28px;
	flex-shrink: 0;
	opacity: 0.7;
}

/* Thumbnail */
.ancic-outil-accordion__thumb {
	width: 48px;
	height: 48px;
	border-radius: var(--r-md, 6px);
	overflow: hidden;
	flex-shrink: 0;
	background: var(--ancic-surface, #f5f5f7);
}

.ancic-outil-accordion__thumb img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}

/* Title + badge */
.ancic-outil-accordion__title-wrap {
	display: flex;
	flex-direction: column;
	gap: 3px;
	min-width: 0;
}

.ancic-outil-accordion__title {
	font-family: var(--font-ui, 'Inter', system-ui, sans-serif);
	font-size: var(--text-base, 1rem);
	font-weight: 700;
	color: var(--ancic-blue, #1a3a5c);
	line-height: 1.3;
	white-space: normal;
}

.ancic-outil-accordion__item--open .ancic-outil-accordion__title {
	color: var(--ancic-blue, #00A1D7);
}

.ancic-outil-accordion__badge {
	display: inline-flex;
	align-items: center;
	font-family: var(--font-ui, 'Inter', system-ui, sans-serif);
	font-size: 0.65rem;
	font-weight: 700;
	letter-spacing: 0.06em;
	text-transform: uppercase;
	padding: 2px 8px;
	border-radius: 100px;
	background: rgba(0, 161, 215, 0.1);
	color: #0081ad;
	width: fit-content;
}

/* Chevron icon */
.ancic-outil-accordion__chevron {
	display: flex;
	align-items: center;
	flex-shrink: 0;
	color: var(--ancic-ink-light, #636366);
	transition: transform var(--dur-base, 220ms) cubic-bezier(0.16, 1, 0.3, 1),
	            color var(--dur-base, 220ms);
}

.ancic-outil-accordion__chevron svg {
	width: 20px;
	height: 20px;
}

.ancic-outil-accordion__item--open .ancic-outil-accordion__chevron {
	transform: rotate(180deg);
	color: var(--ancic-blue, #00A1D7);
}

/* Panel — collapsed by default */
.ancic-outil-accordion__panel {
	max-height: 0;
	overflow: hidden;
	transition: max-height 400ms cubic-bezier(0.16, 1, 0.3, 1);
}

.ancic-outil-accordion__panel-inner {
	padding: var(--sp-8, 2rem) var(--sp-6, 1.5rem);
	background: var(--ancic-white, #fff);
}

/* Reset article/section padding inside the panel since we wrap it */
.ancic-outil-accordion__panel-inner .ancic-tool-section,
.ancic-outil-accordion__panel-inner .ancic-page__wrap {
	padding-inline: 0 !important;
}

.ancic-outil-accordion__panel-inner .ancic-tool-section {
	padding-block: 0 !important;
	background: transparent !important;
}

.ancic-outil-accordion__panel-inner .ancic-tool-section--white,
.ancic-outil-accordion__panel-inner .ancic-tool-section--surface {
	background: transparent !important;
}

@media (max-width: 720px) {
	.ancic-outil-accordion__trigger {
		padding: var(--sp-4, 1rem);
		min-height: 60px;
	}

	.ancic-outil-accordion__index {
		display: none;
	}

	.ancic-outil-accordion__panel-inner {
		padding: var(--sp-5, 1.25rem) var(--sp-4, 1rem);
	}
}

@media (max-width: 480px) {
	.ancic-outil-accordion__thumb {
		display: none;
	}
}
