/* =========================================================
   BATIPROCONNECT — Design System (Premium Artisan)
   Tokens · Typography · Buttons · Sections · Cards · FAQ
   Extrait & consolidé depuis landing-batipro/style.css
   ========================================================= */

/* ---------- Tokens ---------- */
:root {
	/* Palette artisan (overridable depuis WP Options) */
	--c-ink:        #0b1d3a;
	--c-blue:       #1e3a8a;
	--c-blue-2:     #2d4ea0;
	--c-blue-deep:  #07142e;
	--c-cream:      #f5efe4;
	--c-cream-2:    #ece4d3;
	--c-paper:      #faf6ee;
	--c-ocre:       #c87a2c;
	--c-ocre-soft:  #e6a456;
	--c-gold:       #f59e0b;
	--c-gold-2:     #d97706;
	--c-yellow:     #fef3c7;
	--c-line:       #d8cdb8;
	--c-line-soft:  rgba(11, 29, 58, 0.08);
	--c-success:    #16a34a;
	--c-error:      #dc2626;

	--c-text:       #1c2a44;
	--c-text-soft:  #5b6478;
	--c-white:      #ffffff;

	--ff-display: -apple-system, BlinkMacSystemFont, "Segoe UI Variable", "Segoe UI", "Helvetica Neue", Helvetica, Arial, sans-serif;
	--ff-sans:    -apple-system, BlinkMacSystemFont, "Segoe UI Variable", "Segoe UI", "Helvetica Neue", Helvetica, Arial, sans-serif;
	--ff-serif:   "New York", "Times New Roman", Georgia, serif;
	--ff-mono:    ui-monospace, "SF Mono", Menlo, Consolas, monospace;

	--container: 1200px;
	--container-narrow: 880px;
	--radius-sm: 6px;
	--radius:    12px;
	--radius-lg: 18px;

	--shadow-sm: 0 1px 2px rgba(11,29,58,.05), 0 1px 3px rgba(11,29,58,.06);
	--shadow:    0 4px 12px rgba(11,29,58,.08), 0 2px 6px rgba(11,29,58,.06);
	--shadow-lg: 0 18px 50px rgba(11,29,58,.18), 0 4px 14px rgba(11,29,58,.08);
	--shadow-cta: 0 8px 22px rgba(245,158,11,.35);

	--t-fast: 160ms cubic-bezier(.4,0,.2,1);
	--t:      280ms cubic-bezier(.4,0,.2,1);
	--t-slow: 600ms cubic-bezier(.22,.61,.36,1);
}

/* ---------- Reset & base scoped to .batipro-page (won't fight WP admin / DirectoryList shells) ---------- */
.batipro-page,
.batipro-page * ,
.batipro-page *::before,
.batipro-page *::after { box-sizing: border-box; }
.batipro-page {
	font-family: var(--ff-sans);
	font-size: 17px;
	line-height: 1.6;
	color: var(--c-text);
	background: var(--c-paper);
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
	overflow-x: hidden;
}
.batipro-page img { max-width: 100%; height: auto; display: block; }
.batipro-page a { color: var(--c-blue-2); text-decoration: none; transition: color var(--t-fast); }
.batipro-page a:hover { color: var(--c-blue); }
.batipro-page button { font-family: inherit; cursor: pointer; border: 0; background: none; }
.batipro-page ul, .batipro-page ol { margin: 0; padding: 0; list-style: none; }
.batipro-page fieldset { border: 0; margin: 0; padding: 0; }
.batipro-page legend { padding: 0; }

.batipro-page h1, .batipro-page h2, .batipro-page h3, .batipro-page h4 {
	font-family: var(--ff-display);
	font-weight: 800;
	color: var(--c-ink);
	line-height: 1.05;
	margin: 0 0 .6em;
	letter-spacing: -0.035em;
	text-wrap: balance;
}
.batipro-page h1 { font-size: clamp(40px, 6vw, 76px); }
.batipro-page h2 { font-size: clamp(32px, 4.6vw, 52px); }
.batipro-page h3 { font-size: clamp(20px, 2.2vw, 24px); letter-spacing: -0.02em; font-weight: 700; }
.batipro-page p { margin: 0 0 1em; text-wrap: pretty; }

.batipro-page em, .batipro-page .italic-serif {
	font-family: var(--ff-serif);
	font-style: italic;
	font-weight: 500;
	letter-spacing: -0.005em;
}

.bp-skip-link {
	position: absolute; top: -40px; left: 0;
	background: var(--c-ink); color: #fff;
	padding: 8px 16px; z-index: 1000;
	border-radius: 0 0 6px 0;
}
.bp-skip-link:focus { top: 0; }

.batipro-page .container { width: 100%; max-width: var(--container); margin: 0 auto; padding: 0 24px; }
.batipro-page .container.narrow { max-width: var(--container-narrow); }
.batipro-page .text-center { text-align: center; }

.batipro-page .section { padding: clamp(64px, 9vw, 120px) 0; position: relative; }
.batipro-page .section-head { text-align: center; max-width: 760px; margin: 0 auto clamp(40px, 6vw, 64px); }
.batipro-page .section-head .lead { color: var(--c-text-soft); font-size: clamp(17px, 1.5vw, 19px); margin-top: 8px; }
.batipro-page .section-head h2 { margin-bottom: 0; }

.batipro-page .eyebrow {
	display: inline-flex; align-items: center; gap: 10px;
	font-family: var(--ff-sans);
	font-size: 12px; letter-spacing: 0.18em; text-transform: uppercase;
	font-weight: 700; color: var(--c-ocre);
	margin-bottom: 16px;
}
.batipro-page .eyebrow::before { content: ""; width: 28px; height: 2px; background: currentColor; }

/* ---------- Buttons ---------- */
.batipro-page .btn {
	display: inline-flex; align-items: center; justify-content: center; gap: 10px;
	padding: 15px 30px;
	font-family: var(--ff-sans);
	font-weight: 700; font-size: 15px;
	letter-spacing: 0.015em;
	border-radius: 999px;
	border: 2px solid transparent;
	transition: transform 220ms cubic-bezier(.22,.61,.36,1), box-shadow 220ms cubic-bezier(.22,.61,.36,1), background 220ms ease, color 220ms ease, border-color 220ms ease;
	white-space: nowrap;
	text-align: center;
	position: relative;
	cursor: pointer;
	-webkit-tap-highlight-color: transparent;
	text-decoration: none;
}
.batipro-page .btn-cta {
	background: linear-gradient(135deg, #ea8a14 0%, #d97706 50%, #b9590a 100%);
	color: #fff;
	box-shadow:
		0 1px 0 rgba(255,255,255,.18) inset,
		0 -1px 0 rgba(0,0,0,.12) inset,
		0 6px 14px rgba(217,119,6,.28),
		0 2px 4px rgba(217,119,6,.14);
}
.batipro-page .btn-cta:hover {
	background: linear-gradient(135deg, #f0951f 0%, #e07f0a 50%, #c2660a 100%);
	color: #fff;
	transform: translateY(-2px);
	box-shadow:
		0 1px 0 rgba(255,255,255,.22) inset,
		0 -1px 0 rgba(0,0,0,.14) inset,
		0 14px 26px rgba(217,119,6,.34),
		0 3px 8px rgba(217,119,6,.18);
}
.batipro-page .btn-cta:active { transform: translateY(0); }
.batipro-page .btn-cta:focus-visible { outline: 3px solid rgba(217,119,6,.35); outline-offset: 3px; }

.batipro-page .btn-ghost {
	background: #fff; color: var(--c-ink);
	border-color: var(--c-line);
	box-shadow: 0 1px 2px rgba(11,29,58,.04);
}
.batipro-page .btn-ghost:hover {
	background: var(--c-cream); border-color: var(--c-ink);
	color: var(--c-ink);
	transform: translateY(-1px);
	box-shadow: 0 6px 14px rgba(11,29,58,.08);
}
.batipro-page .btn-ghost:focus-visible { outline: 3px solid rgba(11,29,58,.18); outline-offset: 3px; }
.batipro-page .btn-sm { padding: 10px 20px; font-size: 14px; }
.batipro-page .btn-lg { padding: 18px 36px; font-size: 17px; letter-spacing: 0.02em; }
.batipro-page .btn-block { display: flex; width: 100%; }

/* ---------- Reveal animations ---------- */
.batipro-page .reveal { opacity: 0; transform: translateY(28px); transition: opacity var(--t-slow), transform var(--t-slow); }
.batipro-page .reveal.in { opacity: 1; transform: none; }
@media (prefers-reduced-motion: reduce) {
	.batipro-page .reveal { opacity: 1; transform: none; transition: none; }
	.batipro-page html { scroll-behavior: auto; }
}

/* ---------- Header / Navbar ---------- */
.bp-navbar {
	position: sticky; top: 0; z-index: 50;
	background: rgba(250,246,238,0.78);
	backdrop-filter: saturate(180%) blur(16px);
	-webkit-backdrop-filter: saturate(180%) blur(16px);
	border-bottom: 1px solid rgba(11,29,58,.06);
	transition: border-color var(--t-fast), background var(--t-fast), box-shadow var(--t-fast), padding var(--t-fast);
}
.bp-navbar::after {
	content: ""; position: absolute; left: 0; right: 0; bottom: -1px;
	height: 1px;
	background: linear-gradient(90deg, transparent 0%, rgba(217,119,6,.30) 50%, transparent 100%);
	opacity: 0; transition: opacity var(--t-fast);
}
.bp-navbar.scrolled {
	background: rgba(250,246,238,0.96);
	border-bottom-color: var(--c-line);
	box-shadow: 0 4px 20px rgba(11,29,58,.08);
}
.bp-navbar.scrolled::after { opacity: 1; }

.bp-nav-inner { display: flex; align-items: center; justify-content: space-between; height: 96px; transition: height var(--t-fast); }
.bp-navbar.scrolled .bp-nav-inner { height: 80px; }

.bp-nav-logo { display: inline-flex; align-items: center; transition: transform var(--t-fast); }
.bp-nav-logo:hover { transform: scale(1.03); }
.bp-nav-logo img { height: 80px; width: auto; transition: height var(--t-fast); }
.bp-navbar.scrolled .bp-nav-logo img { height: 64px; }

.bp-nav-links { display: flex; align-items: center; gap: 32px; }
.bp-nav-links a:not(.btn) {
	color: var(--c-ink);
	font-weight: 600;
	font-size: 15px;
	position: relative;
	padding: 6px 0;
	transition: color var(--t-fast);
}
.bp-nav-links a:not(.btn)::after {
	content: ""; position: absolute; left: 0; right: 100%; bottom: 0;
	height: 2px; background: var(--c-ocre); transition: right var(--t-fast);
}
.bp-nav-links a:not(.btn):hover { color: var(--c-ocre); }
.bp-nav-links a:not(.btn):hover::after { right: 0; }
.bp-nav-links a.current-menu-item, .bp-nav-links a[aria-current="page"] { color: var(--c-ocre); }
.bp-nav-links a.current-menu-item::after, .bp-nav-links a[aria-current="page"]::after { right: 0; }

.bp-navbar .bp-nav-toggle { display: none; width: 44px; height: 44px; flex-direction: column; align-items: center; justify-content: center; gap: 5px; }
.bp-navbar .bp-nav-toggle span { display: block; width: 22px; height: 2px; background: var(--c-ink); transition: transform var(--t-fast), opacity var(--t-fast); }
.bp-navbar a.bp-nav-cta-mobile { display: none; }

@media (max-width: 860px) {
	.bp-navbar .bp-nav-toggle { display: flex; }
	.bp-navbar a.bp-nav-cta-mobile { display: inline-flex; margin-left: auto; padding: 9px 16px; font-size: 13px; gap: 6px; }
	.bp-nav-logo img { height: 56px; }
	.bp-navbar.scrolled .bp-nav-logo img { height: 48px; }
	.bp-nav-inner { height: 80px; }
	.bp-navbar.scrolled .bp-nav-inner { height: 70px; }
	.bp-nav-links {
		position: absolute; top: 100%; left: 0; right: 0;
		flex-direction: column; align-items: stretch; gap: 0;
		background: var(--c-paper);
		border-bottom: 1px solid var(--c-line);
		padding: 8px 24px 20px;
		transform: translateY(-12px); opacity: 0; pointer-events: none;
		transition: opacity var(--t-fast), transform var(--t-fast);
	}
	.bp-nav-links.open { opacity: 1; transform: none; pointer-events: auto; }
	.bp-nav-links a:not(.btn) { padding: 12px 0; border-bottom: 1px solid var(--c-line-soft); }
	.bp-nav-links .btn { margin-top: 12px; align-self: flex-start; }
	.bp-nav-links a.btn-cta { display: none; }
}
@media (max-width: 480px) {
	.bp-nav-cta-mobile { padding: 8px 12px; font-size: 12.5px; }
	.bp-nav-cta-mobile span { display: none; }
}

/* ---------- Hero (generic, used on all pages with .bp-hero) ---------- */
.bp-hero { position: relative; padding: clamp(40px, 6vw, 80px) 0 clamp(60px, 8vw, 110px); overflow: hidden; }
.bp-hero-bg {
	position: absolute; inset: 0; z-index: 0;
	background:
		radial-gradient(1200px 600px at 80% -10%, rgba(200,122,44,0.18), transparent 60%),
		radial-gradient(900px 500px at 0% 110%, rgba(30,58,138,0.10), transparent 60%),
		var(--c-paper);
}
.bp-hero-grain {
	position: absolute; inset: 0; z-index: 1; pointer-events: none;
	background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='160' height='160'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 0.07 0 0 0 0 0.11 0 0 0 0 0.22 0 0 0 0.18 0'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>");
	opacity: 0.5; mix-blend-mode: multiply;
}
.bp-hero-inner {
	position: relative; z-index: 2;
	display: grid; grid-template-columns: 1.1fr 1fr;
	gap: clamp(32px, 5vw, 72px); align-items: center;
}
.bp-hero-copy { max-width: 640px; }

.bp-kicker {
	display: inline-flex; align-items: center; gap: 12px;
	font-size: 12px; letter-spacing: 0.16em; text-transform: uppercase;
	font-weight: 700; color: var(--c-ocre);
	background: rgba(200,122,44,0.10);
	border: 1px solid rgba(200,122,44,0.25);
	padding: 8px 14px; border-radius: 999px;
	margin-bottom: 24px;
}
.bp-kicker-bar { width: 18px; height: 2px; background: var(--c-ocre); }

.bp-hero-title { font-size: clamp(40px, 6vw, 76px); line-height: 1.04; margin: 0 0 24px; }
.bp-hero-title em { font-style: italic; color: var(--c-ocre); font-weight: 500; }
.bp-hero-title .hl {
	position: relative; display: inline-block; font-weight: 900; white-space: nowrap;
}
.bp-hero-title .hl::after {
	content: ""; position: absolute; left: -4px; right: -4px; bottom: 4px;
	height: 0.42em; background: var(--c-yellow);
	z-index: -1; border-radius: 2px; transform: skew(-6deg);
}
.bp-hero-sub { font-size: clamp(17px, 1.6vw, 20px); color: var(--c-text-soft); max-width: 560px; margin-bottom: 32px; }
.bp-hero-cta { margin-bottom: 22px; display: flex; gap: 14px; flex-wrap: wrap; }
.bp-hero-promises { display: flex; flex-wrap: wrap; gap: 10px; margin: 0; }
.bp-hero-promises li {
	display: inline-flex; align-items: center; gap: 10px;
	padding: 12px 18px 12px 14px;
	background: #fff; border: 1.5px solid var(--c-line);
	border-radius: 999px;
	font-size: 15px; font-weight: 600; color: var(--c-ink);
	letter-spacing: -0.005em; box-shadow: var(--shadow-sm);
	transition: transform var(--t), box-shadow var(--t), border-color var(--t);
}
.bp-hero-promises li:hover { transform: translateY(-2px); box-shadow: var(--shadow); border-color: var(--c-success); }
.bp-check {
	display: inline-grid; place-items: center;
	width: 24px; height: 24px; border-radius: 50%;
	background: var(--c-success); color: #fff;
	font-size: 13px; font-weight: 800; flex-shrink: 0;
	box-shadow: 0 2px 6px rgba(22,163,74,0.35);
}

/* Hero search box (marketplace double search) */
.bp-hero-search {
	background: #fff;
	border: 1px solid var(--c-line);
	border-radius: var(--radius-lg);
	padding: 22px;
	box-shadow: var(--shadow-lg);
	max-width: 560px;
	margin-top: 8px;
}
.bp-hero-search h3 { font-size: 18px; margin: 0 0 14px; color: var(--c-ink); }
.bp-search-tabs { display: flex; gap: 6px; padding: 4px; background: var(--c-cream); border-radius: 999px; margin-bottom: 14px; }
.bp-search-tab {
	flex: 1; padding: 10px 14px; border-radius: 999px;
	font-size: 14px; font-weight: 700; color: var(--c-text-soft);
	background: transparent; transition: all var(--t-fast);
}
.bp-search-tab.active { background: #fff; color: var(--c-ink); box-shadow: var(--shadow-sm); }
.bp-search-form { display: grid; grid-template-columns: 1fr 1fr auto; gap: 10px; }
.bp-search-form input, .bp-search-form select {
	width: 100%; padding: 13px 14px; font-size: 15px; font-family: inherit; color: var(--c-ink);
	background: var(--c-cream); border: 1.5px solid transparent;
	border-radius: var(--radius); transition: border-color var(--t-fast), background var(--t-fast);
}
.bp-search-form input:focus, .bp-search-form select:focus {
	outline: none; background: #fff; border-color: var(--c-ocre);
}
@media (max-width: 640px) { .bp-search-form { grid-template-columns: 1fr; } }

/* Hero visual placeholder (laptop mockup, optional) */
.bp-hero-visual { position: relative; min-height: 460px; display: flex; align-items: center; justify-content: center; }
.bp-hero-card {
	width: 100%; max-width: 540px;
	background: #fff;
	border-radius: var(--radius-lg);
	overflow: hidden;
	box-shadow:
		0 38px 80px -20px rgba(11,29,58,.35),
		0 18px 40px -12px rgba(11,29,58,.22);
	border: 1px solid var(--c-line);
}
.bp-hero-card img { display: block; width: 100%; height: auto; }
@media (max-width: 900px) {
	.bp-hero-inner { grid-template-columns: 1fr; }
	.bp-hero-visual { order: -1; max-width: 480px; margin: 0 auto; min-height: auto; }
}

/* ---------- Marquee ---------- */
.bp-marquee {
	background: var(--c-blue-deep);
	border-top: 1px solid rgba(255,255,255,.06);
	border-bottom: 1px solid rgba(255,255,255,.06);
	padding: 18px 0;
	overflow: hidden; position: relative;
}
.bp-marquee::before, .bp-marquee::after {
	content: ""; position: absolute; top: 0; bottom: 0;
	width: 80px; z-index: 2; pointer-events: none;
}
.bp-marquee::before { left: 0;  background: linear-gradient(90deg, var(--c-blue-deep), transparent); }
.bp-marquee::after  { right: 0; background: linear-gradient(-90deg, var(--c-blue-deep), transparent); }
.bp-marquee-track { display: flex; width: max-content; animation: bpMarquee 36s linear infinite; }
@keyframes bpMarquee { to { transform: translateX(-50%); } }
.bp-marquee-set { display: flex; align-items: center; }
.bp-marquee-set span {
	font-family: var(--ff-display); font-size: 1.35rem; font-weight: 600;
	color: #fff; letter-spacing: -0.015em; padding: 0 1.5rem; white-space: nowrap;
}
.bp-marquee-set i { display: inline-block; width: 8px; height: 8px; border-radius: 50%; background: var(--c-gold); margin: 0 .25rem; }
.bp-marquee:hover .bp-marquee-track { animation-play-state: paused; }
@media (max-width: 768px) { .bp-marquee-set span { font-size: 1.05rem; padding: 0 1rem; } .bp-marquee-track { animation-duration: 28s; } }
@media (prefers-reduced-motion: reduce) { .bp-marquee-track { animation: none; } }

/* ---------- Différenciation block ---------- */
.bp-section-diff {
	background: var(--c-cream);
	border-top: 1px solid var(--c-line);
	border-bottom: 1px solid var(--c-line);
	padding: clamp(72px, 8vw, 110px) 0;
}
.bp-diff-card { max-width: 880px; margin: 0 auto; text-align: center; position: relative; }
.bp-diff-mark {
	width: 64px; height: 64px; margin: 0 auto 24px;
	display: grid; place-items: center;
	color: var(--c-ocre); background: #fff;
	border: 2px solid var(--c-ocre); border-radius: 50%;
	box-shadow: 0 6px 0 var(--c-ocre);
}
.bp-diff-mark svg { width: 32px; height: 32px; }
.bp-diff-eyebrow {
	display: inline-block;
	font-size: 13px; font-weight: 800;
	letter-spacing: 0.18em; text-transform: uppercase;
	color: var(--c-ocre);
	background: rgba(217,119,6,.10); border: 1px solid rgba(217,119,6,.28);
	padding: 8px 18px; border-radius: 999px;
	margin-bottom: 22px;
	box-shadow: 0 4px 12px rgba(217,119,6,.15);
}
.bp-diff-card h2 em {
	font-family: var(--ff-serif); font-style: italic; font-weight: 500;
	color: var(--c-ocre); display: block; margin-top: 6px;
}
.bp-diff-card h2 { margin-bottom: 24px; }
.bp-diff-card p { font-size: clamp(17px, 1.6vw, 20px); color: var(--c-text); max-width: 720px; margin: 0 auto; }

/* ---------- Process editorial (numbered steps with serif italic numerals) ---------- */
.bp-process { background: var(--c-cream); position: relative; }
.bp-process::before {
	content: ""; position: absolute; inset: 0;
	background-image:
		linear-gradient(rgba(11,29,58,.035) 1px, transparent 1px),
		linear-gradient(90deg, rgba(11,29,58,.035) 1px, transparent 1px);
	background-size: 32px 32px;
	pointer-events: none;
	mask-image: linear-gradient(to bottom, transparent, black 20%, black 80%, transparent);
}
.bp-process > .container { position: relative; }
.bp-process-list {
	display: grid; grid-template-columns: repeat(3, 1fr);
	gap: 56px 40px; margin-top: 32px; padding: 0; list-style: none;
}
.bp-step { display: flex; flex-direction: column; align-items: flex-start; gap: 18px; }
.bp-step-num {
	font-family: var(--ff-serif); font-style: italic; font-weight: 600;
	font-size: clamp(72px, 7vw, 108px); line-height: 0.85;
	color: var(--c-ocre); letter-spacing: -0.02em; margin-bottom: 4px;
}
.bp-step-icon {
	width: 44px; height: 44px; color: var(--c-ink);
	display: inline-flex; align-items: center; justify-content: flex-start;
}
.bp-step-icon svg { width: 100%; height: 100%; }
.bp-step h3 {
	font-family: var(--ff-serif); font-weight: 600;
	font-size: clamp(20px, 1.6vw, 24px);
	color: var(--c-ink); letter-spacing: -.005em; line-height: 1.2; margin: 0;
}
.bp-step p { font-size: 15px; line-height: 1.65; color: var(--c-text-soft); margin: 0; }
@media (max-width: 1000px) { .bp-process-list { grid-template-columns: repeat(2, 1fr); gap: 48px 32px; } }
@media (max-width: 640px)  { .bp-process-list { grid-template-columns: 1fr; gap: 44px; } .bp-step-num { font-size: 88px; } }

/* ---------- Generic card grid (advantages, trades…) ---------- */
.bp-card-grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 22px;
	align-items: stretch;
}
.bp-card {
	position: relative;
	background: #fff;
	border: 1px solid var(--c-line-soft);
	border-radius: var(--radius-lg);
	padding: 32px 28px;
	display: flex; flex-direction: column;
	transition: transform var(--t), box-shadow var(--t), border-color var(--t);
}
.bp-card:hover { transform: translateY(-4px); box-shadow: var(--shadow-lg); border-color: rgba(200,122,44,0.30); }
.bp-card-icon {
	width: 56px; height: 56px;
	display: grid; place-items: center;
	color: var(--c-ocre);
	background: rgba(217,119,6,0.08);
	border-radius: var(--radius);
	margin-bottom: 18px;
}
.bp-card-icon svg { width: 28px; height: 28px; }
.bp-card h3 { margin-bottom: 10px; font-family: var(--ff-display); font-size: 19px; }
.bp-card p { color: var(--c-text-soft); font-size: 15px; line-height: 1.65; flex: 1; margin: 0; }
.bp-card-link {
	margin-top: 16px; font-weight: 700; font-size: 14px;
	color: var(--c-ocre); display: inline-flex; align-items: center; gap: 6px;
	transition: gap var(--t-fast);
}
.bp-card-link:hover { gap: 10px; color: var(--c-gold-2); }

@media (max-width: 1000px) { .bp-card-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 640px)  { .bp-card-grid { grid-template-columns: 1fr; } }

.bp-card-grid--two { grid-template-columns: repeat(2, 1fr); }
@media (max-width: 700px) { .bp-card-grid--two { grid-template-columns: 1fr; } }

/* ---------- Trade card (large copy block) ---------- */
.bp-trade-card { padding: 28px 26px; }
.bp-trade-card .bp-card-icon {
	color: var(--c-ink);
	background: var(--c-cream);
	border: 1px solid var(--c-line);
}
.bp-trade-card--energy { background: linear-gradient(180deg, #fffaf0 0%, #fff 100%); border-color: rgba(200,122,44,.30); }
.bp-trade-card--energy .bp-card-icon { color: var(--c-ocre); background: rgba(217,119,6,.10); border-color: rgba(217,119,6,.30); }

/* ---------- FAQ accordion ---------- */
.bp-faq-list { display: flex; flex-direction: column; gap: 12px; }
.bp-faq-item {
	background: #fff;
	border: 1px solid var(--c-line);
	border-radius: var(--radius);
	overflow: hidden;
	transition: border-color var(--t-fast), box-shadow var(--t-fast);
}
.bp-faq-item[open] { border-color: var(--c-ocre); box-shadow: var(--shadow); }
.bp-faq-item summary {
	list-style: none; cursor: pointer;
	padding: 22px 24px;
	display: flex; align-items: center; justify-content: space-between; gap: 20px;
	font-weight: 700; color: var(--c-ink);
	font-size: clamp(15px, 1.4vw, 17px);
	transition: color var(--t-fast);
}
.bp-faq-item summary::-webkit-details-marker { display: none; }
.bp-faq-item summary:hover { color: var(--c-ocre); }
.bp-faq-chevron {
	width: 22px; height: 22px; flex-shrink: 0;
	color: var(--c-ocre);
	transition: transform var(--t-fast);
}
.bp-faq-item[open] .bp-faq-chevron { transform: rotate(180deg); }
.bp-faq-a { padding: 0 24px 22px; color: var(--c-text-soft); }
.bp-faq-a p { margin: 0 0 10px; }
.bp-faq-a p:last-child { margin: 0; }

/* ---------- Contact strip ---------- */
.bp-contact-strip {
	background: linear-gradient(135deg, var(--c-blue-deep) 0%, #0a1d4a 100%);
	border-radius: var(--radius-lg);
	padding: clamp(36px, 5vw, 56px);
	color: #fff;
	display: grid;
	grid-template-columns: 1fr auto;
	gap: 32px;
	align-items: center;
	box-shadow: var(--shadow-lg);
}
.bp-contact-strip h2 { color: #fff; margin: 0; }
.bp-contact-strip h2 em { color: var(--c-gold); }
.bp-contact-strip .eyebrow { color: var(--c-gold); }
.bp-contact-pills { display: flex; gap: 12px; flex-wrap: wrap; }
.bp-contact-pill {
	display: inline-flex; align-items: center; gap: 12px;
	background: rgba(255,255,255,0.06);
	border: 1px solid rgba(255,255,255,0.14);
	border-radius: 999px;
	padding: 12px 20px;
	color: #fff;
	transition: background var(--t-fast), border-color var(--t-fast), transform var(--t-fast);
}
.bp-contact-pill:hover { background: rgba(255,255,255,0.10); border-color: var(--c-gold); transform: translateY(-2px); color: #fff; }
.bp-contact-pill-icon { width: 22px; height: 22px; color: var(--c-gold); }
.bp-contact-pill-body { display: flex; flex-direction: column; line-height: 1.2; }
.bp-contact-pill-body span { font-size: 11px; letter-spacing: .12em; text-transform: uppercase; color: rgba(255,255,255,0.60); }
.bp-contact-pill-body strong { font-size: 15px; }
@media (max-width: 800px) { .bp-contact-strip { grid-template-columns: 1fr; } }

/* ---------- Footer ---------- */
.bp-footer {
	background: var(--c-blue-deep);
	color: rgba(255,255,255,0.78);
	padding: clamp(56px, 7vw, 80px) 0 0;
	margin-top: clamp(40px, 6vw, 80px);
}
.bp-footer-inner {
	display: grid;
	grid-template-columns: 1.4fr repeat(3, 1fr);
	gap: 40px;
	padding-bottom: 56px;
	border-bottom: 1px solid rgba(255,255,255,0.10);
}
.bp-footer h4 {
	color: #fff;
	font-size: 13px;
	letter-spacing: .14em;
	text-transform: uppercase;
	margin: 0 0 16px;
}
.bp-footer ul { display: flex; flex-direction: column; gap: 10px; }
.bp-footer a { color: rgba(255,255,255,0.72); }
.bp-footer a:hover { color: var(--c-gold); }
.bp-footer-logo img { max-height: 64px; width: auto; margin-bottom: 14px; }
.bp-footer-tagline { color: rgba(255,255,255,0.72); font-size: 14px; line-height: 1.6; max-width: 320px; }
.bp-footer-bottom { padding: 22px 0; font-size: 13px; color: rgba(255,255,255,0.55); text-align: center; }
@media (max-width: 900px) { .bp-footer-inner { grid-template-columns: 1fr 1fr; } }
@media (max-width: 560px) { .bp-footer-inner { grid-template-columns: 1fr; gap: 32px; } }

/* ---------- Cookie banner ---------- */
.bp-cookie-banner {
	position: fixed; left: 16px; right: 16px; bottom: 16px; z-index: 9000;
	background: var(--c-ink); color: rgba(255,255,255,0.92);
	border-radius: var(--radius);
	padding: 18px 22px;
	display: flex; gap: 22px; align-items: center; justify-content: space-between;
	flex-wrap: wrap;
	box-shadow: 0 24px 60px rgba(0,0,0,0.35);
	animation: bpCookieIn .4s ease-out;
}
@keyframes bpCookieIn { from { opacity: 0; transform: translateY(20px); } to { opacity: 1; transform: none; } }
.bp-cookie-banner strong { display: block; color: #fff; font-size: 15px; margin-bottom: 4px; }
.bp-cookie-banner span { font-size: 13px; line-height: 1.5; color: rgba(255,255,255,0.72); }
.bp-cookie-actions { display: flex; gap: 10px; }
.bp-cookie-actions .btn { padding: 9px 18px; font-size: 13px; }

/* ---------- Utility ---------- */
.bp-sr { position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px; overflow: hidden; clip: rect(0,0,0,0); white-space: nowrap; border: 0; }
