/*
 * AiBacco — section styles for custom-coded identity blocks.
 * 1:1 port of the React/Babel prototype in `landing-page.html`.
 * Tokens consumed via var(--ai-*); palette extended via :root below.
 */

/* ── Hello Elementor reset ────────────────────────────────────────────
 * Hello Elementor wraps everything in a centered max-width 1140px box and
 * adds vertical padding to .site-main. Each section in this theme renders
 * full-bleed (the section itself owns its background colour, the inner
 * .aib-container clamps to 1200px). Neutralise the parent's layout here.
 */
body { margin: 0; padding: 0; }

.site,
.site-content,
.site-main,
.site .site-main,
main#content {
	max-width: none;
	width: 100%;
	margin: 0;
	padding: 0;
}

/* Hello Elementor's footer wrapper, if present. */
.site-footer {
	margin: 0;
	padding: 0;
	max-width: none;
}


:root {
	--ai-bordeaux-900: #1A0D14;
	--ai-bordeaux-800: #3F012A;
	--ai-bordeaux-600: #7A4760;
	--ai-bordeaux-200: #EAD6DE;
	--ai-bordeaux-100: #F4DDE6;
	--ai-cream-50:     #FBF7F1;
	--ai-cream-100:    #F8F1E9;
	--ai-cream-200:    #EFE5D8;
	--ai-gold-500:     #DFBC1F;
	--ai-gold-600:     #B89A18;
	--ai-success:      #2F5D3F;
	--ai-success-bg:   #DCEAE0;
	--ai-error:        #9A1B2C;
	--ai-easing:       cubic-bezier(0.2, 0.8, 0.2, 1);
}

/* ── Keyframes ────────────────────────────────────────────────────────── */
@keyframes aib-spin     { to { transform: rotate(360deg); } }
@keyframes aib-fadein   { from { opacity: 0; transform: translateY(10px); } to { opacity: 1; transform: translateY(0); } }
@keyframes aib-pulse-ring { 0% { transform: scale(1); opacity: 0.55; } 100% { transform: scale(2.6); opacity: 0; } }

/* ── Layout helpers ───────────────────────────────────────────────────── */
.aib-container {
	max-width: 1200px;
	margin: 0 auto;
	padding: 0 48px;
}
.aib-container--wide { max-width: 1320px; }

@media (max-width: 960px) {
	.aib-container { padding: 0 24px; }
}

.aib-eyebrow {
	font-family: var(--ai-font-body);
	font-size: 12px;
	font-weight: 600;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	color: var(--ai-magenta);
	margin-bottom: 14px;
}
.aib-eyebrow--gold { color: var(--ai-gold-500); }

.aib-section-header {
	max-width: 680px;
	margin: 0 auto 64px;
	text-align: center;
}
.aib-section-header__title {
	font-family: var(--ai-font-display);
	font-size: clamp(26px, 3vw, 44px);
	font-weight: 400;
	line-height: 1.12;
	color: var(--ai-bordeaux-900);
	margin: 0 0 16px;
	letter-spacing: -0.005em;
}
.aib-section-header__lede {
	font-family: var(--ai-font-body);
	font-size: 17px;
	color: var(--ai-bordeaux-600);
	line-height: 1.6;
	margin: 0;
}

/* Reveal-on-scroll (consumed by .ai-reveal in tokens.css) is shared. */

/* ── Buttons ──────────────────────────────────────────────────────────── */
.aib-btn {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	font-family: var(--ai-font-body);
	font-weight: 600;
	letter-spacing: 0.02em;
	border-radius: 999px;
	cursor: pointer;
	text-decoration: none;
	transition: all 120ms ease-out;
	border: none;
	white-space: nowrap;
}
.aib-btn--sm { padding: 8px 20px;  min-height: 36px; font-size: 14px; }
.aib-btn--md { padding: 12px 28px; min-height: 44px; font-size: 15px; }
.aib-btn--lg { padding: 16px 36px; min-height: 54px; font-size: 17px; }

.aib-btn--primary {
	background: var(--ai-gold-500);
	color: var(--ai-bordeaux-900);
}
.aib-btn--primary:hover {
	background: var(--ai-gold-600);
	color: var(--ai-bordeaux-900);
	transform: translateY(-1px);
	box-shadow: 0 4px 14px rgba(223, 188, 31, 0.35);
}

.aib-btn--secondary {
	background: transparent;
	color: var(--ai-bordeaux-900);
	border: 1.5px solid var(--ai-bordeaux-900);
}
.aib-btn--secondary:hover {
	background: var(--ai-bordeaux-100);
	color: var(--ai-bordeaux-900);
	transform: translateY(-1px);
}

.aib-btn--inverse {
	background: rgba(255, 255, 255, 0.10);
	color: var(--ai-cream-50);
	border: 1.5px solid rgba(255, 255, 255, 0.35);
}
.aib-btn--inverse:hover {
	background: rgba(255, 255, 255, 0.18);
	color: var(--ai-cream-50);
}

/* ── HERO ─────────────────────────────────────────────────────────────── */
.aib-hero {
	position: relative;
	min-height: 92dvh;
	display: flex;
	flex-direction: column;
	color: var(--ai-cream-50);
	overflow: hidden;
	isolation: isolate;
}
.aib-hero__bg       { position: absolute; inset: 0; z-index: -2; background-size: cover; background-position: center 30%; }
.aib-hero__overlay  { position: absolute; inset: 0; z-index: -1;
	background: linear-gradient(105deg, rgba(26,13,20,0.88) 0%, rgba(26,13,20,0.75) 50%, rgba(26,13,20,0.30) 100%);
}
.aib-hero__inner    { flex: 1; max-width: 1200px; width: 100%; margin: 0 auto; padding: 80px 48px; display: flex; align-items: center; }
.aib-hero__content  { max-width: 580px; display: flex; flex-direction: column; gap: 28px; }
.aib-hero__eyebrow  { display: inline-flex; align-items: center; gap: 8px; font-family: var(--ai-font-body); font-size: 12px; font-weight: 600; letter-spacing: 0.08em; text-transform: uppercase; color: var(--ai-gold-500); }
.aib-hero__title    { font-family: var(--ai-font-display); font-size: clamp(40px, 5.5vw, 72px); font-weight: 400; line-height: 1.04; color: var(--ai-cream-50); margin: 0; letter-spacing: -0.005em; }
.aib-hero__subtitle { font-family: var(--ai-font-body); font-size: clamp(16px, 1.4vw, 20px); line-height: 1.6; color: rgba(251,247,241,0.75); margin: 0; max-width: 520px; }
.aib-hero__ctas     { display: flex; gap: 14px; flex-wrap: wrap; margin-top: 4px; }

.aib-hero__proof    { display: flex; align-items: center; gap: 14px; padding-top: 20px; margin-top: 8px; border-top: 1px solid rgba(251,247,241,0.15); }
.aib-hero__proof-dots { display: flex; }
.aib-hero__proof-dot  { width: 30px; height: 30px; border-radius: 50%; border: 2px solid rgba(26,13,20,0.6); }
.aib-hero__proof-dot + .aib-hero__proof-dot { margin-left: -9px; }
.aib-hero__proof-dot--bordeaux { background: var(--ai-bordeaux-600); }
.aib-hero__proof-dot--magenta  { background: var(--ai-magenta); }
.aib-hero__proof-dot--oro      { background: var(--ai-gold-500); }
.aib-hero__proof-text { font-family: var(--ai-font-body); font-size: 14px; font-weight: 500; color: rgba(251,247,241,0.78); line-height: 1.4; max-width: 320px; margin: 0; }

.aib-hero__strip { background: rgba(26,13,20,0.72); -webkit-backdrop-filter: blur(12px); backdrop-filter: blur(12px); border-top: 1px solid rgba(251,247,241,0.07); padding: 0 48px; display: flex; align-items: center; height: 64px; }
.aib-hero__strip-label  { font-family: var(--ai-font-body); font-size: 9px; font-weight: 700; letter-spacing: 0.14em; text-transform: uppercase; color: rgba(251,247,241,0.32); white-space: nowrap; flex-shrink: 0; }
.aib-hero__strip-divider { width: 1px; height: 32px; background: rgba(251,247,241,0.12); margin: 0 24px; flex-shrink: 0; }
.aib-hero__strip-list   { display: flex; align-items: stretch; overflow: hidden; list-style: none; margin: 0; padding: 0; flex: 1; min-width: 0; }
.aib-hero__strip-item   { display: flex; flex-direction: column; justify-content: center; gap: 3px; padding: 6px 22px; white-space: nowrap; transition: transform 240ms cubic-bezier(0.2,0.7,0.2,1); position: relative; }
.aib-hero__strip-item:first-child { padding-left: 0; }
.aib-hero__strip-name   { font-family: var(--ai-font-display); font-style: italic; font-size: 16px; font-weight: 400; line-height: 1; color: rgba(251,247,241,0.92); letter-spacing: 0.005em; }
.aib-hero__strip-meta   { font-family: var(--ai-font-mono); font-size: 9px; font-weight: 500; line-height: 1; letter-spacing: 0.16em; text-transform: uppercase; color: rgba(223,188,31,0.55); transition: color 240ms ease; }
.aib-hero__strip-item::after { content: ""; position: absolute; left: 22px; right: 22px; bottom: 4px; height: 1px; background: var(--ai-gold-500); transform: scaleX(0); transform-origin: left center; transition: transform 280ms cubic-bezier(0.2,0.7,0.2,1); }
.aib-hero__strip-item:first-child::after { left: 0; }
.aib-hero__strip-item:hover { transform: translateY(-2px); }
.aib-hero__strip-item:hover .aib-hero__strip-meta { color: var(--ai-gold-500); }
.aib-hero__strip-item:hover::after { transform: scaleX(1); }
.aib-hero__strip-rule   { width: 1px; align-self: center; height: 28px; background: rgba(160,59,107,0.32); flex-shrink: 0; }

@media (max-width: 768px) {
	.aib-hero__inner { padding: 64px 24px; }
	.aib-hero__strip { padding: 14px 24px; height: auto; flex-wrap: wrap; gap: 10px 0; align-items: flex-start; }
	.aib-hero__strip-divider { display: none; }
	.aib-hero__strip-label { width: 100%; margin-bottom: 4px; }
	.aib-hero__strip-list { overflow-x: auto; overflow-y: hidden; scrollbar-width: none; flex-wrap: nowrap; align-items: center; padding-bottom: 2px; }
	.aib-hero__strip-list::-webkit-scrollbar { display: none; }
	.aib-hero__strip-item { padding: 4px 16px; gap: 2px; }
	.aib-hero__strip-item:first-child { padding-left: 0; }
	.aib-hero__strip-name { font-size: 14px; }
	.aib-hero__strip-meta { font-size: 8px; letter-spacing: 0.14em; }
	.aib-hero__strip-rule { height: 24px; }
}

@media (prefers-reduced-motion: reduce) {
	.aib-hero__strip-item,
	.aib-hero__strip-item::after,
	.aib-hero__strip-meta { transition: none; }
}

/* ── MANIFESTO ────────────────────────────────────────────────────────── */
.aib-manifesto { background: var(--ai-cream-50); padding: 96px 0; }
.aib-manifesto__inner {
	max-width: 820px;
	margin: 0 auto;
	text-align: center;
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 28px;
}
.aib-manifesto__rule {
	width: 40px;
	height: 2px;
	background: var(--ai-gold-500);
	border-radius: 2px;
}
.aib-manifesto__quote {
	font-family: var(--ai-font-display);
	font-size: clamp(22px, 2.6vw, 32px);
	font-weight: 400;
	line-height: 1.45;
	color: var(--ai-bordeaux-900);
	margin: 0;
	max-width: none;
}
.aib-manifesto__quote em {
	color: var(--ai-magenta);
	font-style: italic;
}

/* ── PER CHI ─────────────────────────────────────────────────────────── */
.aib-perchi { background: var(--ai-cream-100); padding: 96px 0; }
.aib-perchi__title-accent { color: var(--ai-magenta); }
.aib-perchi__grid {
	display: grid;
	grid-template-columns: 1fr 1fr;
	border: 1px solid var(--ai-bordeaux-200);
	border-radius: 16px;
	overflow: hidden;
	background: var(--ai-cream-50);
}
.aib-perchi__card {
	padding: clamp(36px, 4vw, 48px);
	display: flex;
	flex-direction: column;
	gap: 18px;
}
.aib-perchi__card--first { border-right: 1px solid var(--ai-bordeaux-200); }
.aib-perchi__card-tag {
	font-family: var(--ai-font-body);
	font-size: 11px;
	font-weight: 700;
	letter-spacing: 0.14em;
	text-transform: uppercase;
}
.aib-perchi__card-tag--gold    { color: var(--ai-gold-600); }
.aib-perchi__card-tag--magenta { color: var(--ai-magenta); }
.aib-perchi__card-title {
	font-family: var(--ai-font-display);
	font-size: clamp(22px, 2.4vw, 30px);
	font-weight: 400;
	line-height: 1.2;
	color: var(--ai-bordeaux-900);
	margin: 0;
}
.aib-perchi__card-body {
	font-family: var(--ai-font-body);
	font-size: 16px;
	color: var(--ai-bordeaux-600);
	line-height: 1.65;
	margin: 0;
}

@media (max-width: 960px) {
	.aib-perchi__grid { grid-template-columns: 1fr; }
	.aib-perchi__card--first { border-right: none; border-bottom: 1px solid var(--ai-bordeaux-200); }
}

/* ── STATS ───────────────────────────────────────────────────────────── */
.aib-stats { background: var(--ai-bordeaux-800); padding: 80px 0; }
.aib-stats__row {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	border: 1px solid rgba(248,241,233,0.10);
	border-radius: 16px;
	overflow: hidden;
}
.aib-stats__cell {
	padding: 48px 40px;
	background: rgba(255,255,255,0.04);
}
.aib-stats__cell + .aib-stats__cell { border-left: 1px solid rgba(248,241,233,0.08); }
.aib-stats__num {
	font-family: var(--ai-font-display);
	font-size: clamp(40px, 4vw, 60px);
	color: var(--ai-gold-500);
	line-height: 1;
	margin-bottom: 14px;
}
.aib-stats__label {
	font-family: var(--ai-font-body);
	font-size: 16px;
	font-weight: 600;
	color: var(--ai-cream-50);
	margin-bottom: 6px;
}
.aib-stats__sub {
	font-family: var(--ai-font-body);
	font-size: 13px;
	color: rgba(251,247,241,0.45);
}

@media (max-width: 960px) {
	.aib-stats__row { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 600px) {
	.aib-stats__row { grid-template-columns: 1fr; }
	.aib-stats__cell + .aib-stats__cell { border-left: none; border-top: 1px solid rgba(248,241,233,0.08); }
}

/* ── PRODUCT (composite hero + flow switcher) ────────────────────────── */
.aib-product {
	background: var(--ai-cream-50);
	padding: 120px 0 110px;
	position: relative;
	overflow: hidden;
}
.aib-product__ambient-1,
.aib-product__ambient-2 {
	position: absolute;
	pointer-events: none;
}
.aib-product__ambient-1 {
	top: 8%;
	right: -14%;
	width: 60%;
	height: 70%;
	background: radial-gradient(circle, rgba(160,59,107,0.08), transparent 65%);
}
.aib-product__ambient-2 {
	bottom: 10%;
	left: -10%;
	width: 45%;
	height: 55%;
	background: radial-gradient(circle, rgba(223,188,31,0.06), transparent 60%);
}
.aib-product__inner { position: relative; }
.aib-product__header {
	display: grid;
	grid-template-columns: 1.4fr 0.85fr;
	column-gap: clamp(40px, 6vw, 96px);
	align-items: flex-end;
	margin-bottom: clamp(64px, 8vw, 96px);
}
.aib-product__title {
	font-family: var(--ai-font-display);
	font-size: clamp(32px, 4vw, 56px);
	font-weight: 400;
	line-height: 1.05;
	color: var(--ai-bordeaux-900);
	margin: 0;
	letter-spacing: -0.005em;
}
.aib-product__title-accent { color: var(--ai-magenta); }
.aib-product__lede {
	font-family: var(--ai-font-body);
	font-size: clamp(15px, 1.2vw, 17px);
	color: var(--ai-bordeaux-600);
	line-height: 1.65;
	margin: 0;
	padding: 0 0 6px 22px;
	border-left: 2px solid var(--ai-gold-500);
	max-width: none;
}

.aib-product__composite {
	position: relative;
	max-width: 1080px;
	margin: 0 auto;
	padding-right: clamp(64px, 12vw, 180px);
	padding-bottom: clamp(32px, 5vw, 72px);
}
.aib-product__desktop { position: relative; z-index: 1; }
.aib-product__phone   { position: absolute; right: 0; bottom: 0; width: clamp(180px, 19vw, 248px); z-index: 2; }

@media (max-width: 960px) {
	.aib-product__header { grid-template-columns: 1fr; gap: 20px; align-items: flex-start; }
	.aib-product__composite { padding-right: 0; padding-bottom: 0; }
	.aib-product__phone { position: static; width: min(60%, 260px); margin: 32px auto 0; right: auto; bottom: auto; }
}

/* Frames (DesktopFrame + PhoneFrame) */
.aib-frame-desktop {
	background: var(--ai-bordeaux-900);
	border-radius: 18px;
	padding: 8px;
	box-shadow: 0 32px 60px -28px rgba(63,1,42,0.40), 0 6px 18px -10px rgba(63,1,42,0.20);
	border: 1px solid var(--ai-bordeaux-800);
}
.aib-frame-desktop__bar {
	display: flex;
	align-items: center;
	gap: 10px;
	padding: 8px 14px 12px;
}
.aib-frame-desktop__dot {
	position: relative;
	display: inline-flex;
	width: 8px;
	height: 8px;
	flex-shrink: 0;
}
.aib-frame-desktop__dot::before,
.aib-frame-desktop__dot::after {
	content: '';
	position: absolute;
	inset: 0;
	width: 8px;
	height: 8px;
	border-radius: 50%;
	background: var(--ai-gold-500);
}
.aib-frame-desktop__dot::before {
	opacity: 0.55;
	animation: aib-pulse-ring 2.4s ease-out infinite;
}
.aib-frame-desktop__url {
	font-family: var(--ai-font-body);
	font-size: 11px;
	color: rgba(248,241,233,0.50);
	letter-spacing: 0.02em;
}
.aib-frame-desktop__label {
	margin-left: auto;
	font-family: var(--ai-font-body);
	font-size: 9px;
	font-weight: 700;
	letter-spacing: 0.16em;
	text-transform: uppercase;
	color: var(--ai-gold-500);
	opacity: 0.85;
}
.aib-frame-desktop__img-wrap,
.aib-frame-phone__img-wrap {
	overflow: hidden;
}
.aib-frame-desktop__img-wrap { border-radius: 10px; }
.aib-frame-desktop__img,
.aib-frame-phone__img {
	width: 100%;
	display: block;
	object-fit: cover;
}
.aib-frame-desktop__img { border-radius: 10px; }
.aib-frame-desktop[data-active="true"] .aib-frame-desktop__img,
.aib-frame-phone[data-active="true"] .aib-frame-phone__img {
	animation: aib-fadein 360ms ease-out;
}

.aib-frame-phone {
	width: 100%;
	max-width: 280px;
	margin: 0 auto;
	background: var(--ai-bordeaux-900);
	border-radius: 38px;
	padding: 12px 8px 8px;
	box-shadow: 0 28px 60px -22px rgba(63,1,42,0.42), inset 0 0 0 2px rgba(255,255,255,0.06);
}
.aib-frame-phone__notch {
	width: 92px;
	height: 22px;
	border-radius: 999px;
	background: #0A0207;
	margin: 0 auto 10px;
	border: 1px solid rgba(255,255,255,0.04);
}
.aib-frame-phone__img-wrap {
	border-radius: 28px;
	background: #fff;
}
.aib-frame-phone__img { max-height: 520px; }
.aib-frame-phone__handle {
	width: 80px;
	height: 4px;
	background: rgba(255,255,255,0.18);
	border-radius: 999px;
	margin: 12px auto 4px;
}

/* Flow switcher */
.aib-flow {
	margin-top: clamp(64px, 8vw, 112px);
	max-width: 1080px;
	margin-left: auto;
	margin-right: auto;
}
.aib-flow__tabs {
	position: relative;
	display: grid;
	grid-template-columns: repeat(5, 1fr);
	border-top: 1px solid var(--ai-bordeaux-200);
}
.aib-flow__progress {
	position: absolute;
	top: -1px;
	left: 0;
	height: 2px;
	background: var(--ai-gold-500);
	transition: width 520ms var(--ai-easing);
	width: 20%;
}
.aib-flow__tab {
	display: flex;
	flex-direction: column;
	align-items: flex-start;
	gap: 10px;
	padding: 18px 16px;
	background: transparent;
	border: none;
	border-radius: 6px;
	cursor: pointer;
	text-align: left;
	transition: background 200ms ease-out;
	color: inherit;
}
/* Pin Hello Elementor's generic button:hover rule (red bg, white text)
 * — same pattern used on .aib-faq__btn. Senza questo, le tab "lampeggiano"
 * di rosso al passaggio del mouse. */
.aib-flow__tab:hover,
.aib-flow__tab:focus,
.aib-flow__tab:focus-visible,
.aib-flow__tab:active {
	background: rgba(63,1,42,0.04);
	color: inherit;
	outline: none;
	box-shadow: none;
}
.aib-flow__tab[aria-selected="true"]:hover,
.aib-flow__tab[aria-selected="true"]:focus { background: rgba(63,1,42,0.06); }
.aib-flow__tab-num {
	font-family: var(--ai-font-display);
	font-size: 14px;
	color: var(--ai-bordeaux-600);
	letter-spacing: 0.04em;
	transition: color 240ms ease-out;
}
.aib-flow__tab[aria-selected="true"] .aib-flow__tab-num { color: var(--ai-gold-500); }
.aib-flow__tab-title {
	font-family: var(--ai-font-body);
	font-size: 13px;
	font-weight: 600;
	line-height: 1.35;
	color: var(--ai-bordeaux-600);
	transition: color 240ms ease-out;
}
.aib-flow__tab[aria-selected="true"] .aib-flow__tab-title { color: var(--ai-bordeaux-900); }
.aib-flow__tab:hover .aib-flow__tab-title { color: var(--ai-bordeaux-900); }
.aib-flow__desc-wrap {
	margin-top: 36px;
	display: grid;
	grid-template-columns: 1fr;
	max-width: 640px;
}
.aib-flow__desc {
	font-family: var(--ai-font-body);
	font-size: clamp(15px, 1.3vw, 17px);
	line-height: 1.65;
	color: var(--ai-bordeaux-600);
	margin: 0;
	max-width: none;
	animation: aib-fadein 360ms ease-out;
}

@media (max-width: 960px) {
	.aib-flow__tabs { grid-template-columns: repeat(5, minmax(140px, 1fr)); overflow-x: auto; scrollbar-width: none; }
	.aib-flow__tabs::-webkit-scrollbar { display: none; }
}

/* ── TRE DOLORI ──────────────────────────────────────────────────────── */
.aib-dolori { background: var(--ai-cream-200); padding: 96px 0; }
.aib-dolori__list { display: flex; flex-direction: column; gap: 64px; }
.aib-dolore {
	display: grid;
	grid-template-columns: 1fr 1fr;
	column-gap: 64px;
	row-gap: 28px;
	align-items: center;
}
.aib-dolore__obs {
	display: flex;
	gap: 24px;
	align-items: flex-start;
}
.aib-dolore--reverse .aib-dolore__obs { order: 2; }
.aib-dolore--reverse .aib-dolore__ans { order: 1; }
.aib-dolore__num {
	font-family: var(--ai-font-display);
	font-size: clamp(56px, 7vw, 104px);
	color: var(--ai-bordeaux-200);
	line-height: 0.85;
	flex-shrink: 0;
	font-weight: 400;
}
.aib-dolore__obs-text {
	font-family: var(--ai-font-display);
	font-style: italic;
	font-size: clamp(19px, 1.9vw, 26px);
	color: var(--ai-bordeaux-900);
	line-height: 1.35;
	margin: 0;
	padding-top: 6px;
	max-width: none;
}
.aib-dolore__ans {
	padding-left: 22px;
	border-left: 2px solid var(--ai-gold-500);
}
.aib-dolore__ans-tag {
	font-family: var(--ai-font-body);
	font-size: 11px;
	font-weight: 700;
	letter-spacing: 0.14em;
	text-transform: uppercase;
	color: var(--ai-magenta);
	margin-bottom: 10px;
}
.aib-dolore__ans-text {
	font-family: var(--ai-font-body);
	font-size: clamp(16px, 1.4vw, 18px);
	font-weight: 500;
	color: var(--ai-bordeaux-900);
	line-height: 1.55;
	margin: 0;
	max-width: none;
}

@media (max-width: 768px) {
	.aib-dolore { grid-template-columns: 1fr; column-gap: 0; row-gap: 20px; }
	.aib-dolore--reverse .aib-dolore__obs,
	.aib-dolore--reverse .aib-dolore__ans { order: 0; }
}

/* ── ANTI-CLAIM ──────────────────────────────────────────────────────── */
.aib-anti {
	background: var(--ai-bordeaux-800);
	padding: 96px 0;
	overflow: hidden;
	position: relative;
}
.aib-anti__bg-x {
	position: absolute;
	right: -40px;
	top: 50%;
	transform: translateY(-50%);
	font-family: var(--ai-font-display);
	font-size: clamp(300px, 30vw, 480px);
	color: rgba(255,255,255,0.03);
	line-height: 1;
	pointer-events: none;
	user-select: none;
	font-weight: 400;
}
.aib-anti__inner { position: relative; z-index: 1; }
.aib-anti__header {
	display: flex;
	flex-direction: column;
	align-items: center;
	text-align: center;
	margin-bottom: 64px;
	gap: 16px;
}
.aib-anti__title {
	font-family: var(--ai-font-display);
	font-size: clamp(28px, 3vw, 44px);
	font-weight: 400;
	line-height: 1.1;
	color: var(--ai-cream-50);
	margin: 0;
}
.aib-anti__rule { width: 48px; height: 3px; background: var(--ai-gold-500); flex-shrink: 0; }
.aib-anti__grid {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 2px;
}
.aib-anti__card {
	padding: 40px;
	display: flex;
	flex-direction: column;
	gap: 16px;
	transition: background 200ms ease-out;
}
.aib-anti__card:hover { background: rgba(255,255,255,0.04); }
.aib-anti__card--top-right  { border-left: 1px solid rgba(251,247,241,0.08); }
.aib-anti__card--bot-left   { border-top:  1px solid rgba(251,247,241,0.08); }
.aib-anti__card--bot-right  { border-top:  1px solid rgba(251,247,241,0.08); border-left: 1px solid rgba(251,247,241,0.08); }
.aib-anti__symbol-row {
	display: flex;
	align-items: center;
	gap: 14px;
}
.aib-anti__circle {
	width: 44px; height: 44px; border-radius: 50%;
	border: 1.5px solid rgba(251,247,241,0.20);
	display: flex; align-items: center; justify-content: center;
	transition: border-color 200ms ease-out;
	flex-shrink: 0;
}
.aib-anti__symbol {
	font-family: var(--ai-font-body);
	font-size: 22px;
	font-weight: 300;
	color: rgba(251,247,241,0.40);
	line-height: 1;
	transition: color 200ms ease-out;
}
.aib-anti__dash {
	width: 24px;
	height: 1px;
	background: rgba(251,247,241,0.15);
	transition: background 200ms ease-out;
}
.aib-anti__card:hover .aib-anti__circle { border-color: var(--ai-gold-500); }
.aib-anti__card:hover .aib-anti__symbol { color: var(--ai-gold-500); }
.aib-anti__card:hover .aib-anti__dash   { background: var(--ai-gold-500); }
.aib-anti__text {
	font-family: var(--ai-font-display);
	font-style: italic;
	font-size: clamp(17px, 1.7vw, 22px);
	color: var(--ai-cream-50);
	margin: 0;
	line-height: 1.35;
	max-width: none;
}
.aib-anti__sub {
	font-family: var(--ai-font-body);
	font-size: 14px;
	color: rgba(251,247,241,0.45);
	margin: 0;
	line-height: 1.6;
	max-width: 380px;
}

@media (max-width: 960px) {
	.aib-anti__grid { grid-template-columns: 1fr; }
	.aib-anti__card--top-right,
	.aib-anti__card--bot-right { border-left: none; }
	.aib-anti__card + .aib-anti__card { border-top: 1px solid rgba(251,247,241,0.08); }
}

/* ── TESTIMONIALS ────────────────────────────────────────────────────── */
.aib-testi { background: var(--ai-cream-50); padding: 96px 0; }
.aib-testi__header {
	display: flex;
	flex-direction: column;
	align-items: center;
	text-align: center;
	margin-bottom: 48px;
	gap: 14px;
}
.aib-testi__title {
	font-family: var(--ai-font-display);
	font-size: clamp(26px, 3vw, 40px);
	font-weight: 400;
	line-height: 1.15;
	color: var(--ai-bordeaux-900);
	margin: 0;
}
.aib-testi__lede {
	font-family: var(--ai-font-body);
	font-size: 14px;
	color: var(--ai-bordeaux-600);
	line-height: 1.6;
	margin: 0;
	max-width: 520px;
}
.aib-testi__grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 20px;
}
.aib-testi__card {
	background: var(--ai-cream-50);
	border: 1px solid var(--ai-bordeaux-200);
	border-radius: 16px;
	padding: 28px 24px;
	display: flex;
	flex-direction: column;
	gap: 20px;
	box-shadow: 0 2px 8px rgba(26,13,20,0.04);
	transition: all 200ms ease-out;
}
.aib-testi__card:hover {
	background: var(--ai-cream-100);
	box-shadow: 0 6px 24px rgba(26,13,20,0.07);
	transform: translateY(-2px);
}
.aib-testi__quote-mark {
	font-family: var(--ai-font-display);
	font-size: 36px;
	line-height: 0.6;
	color: var(--ai-gold-500);
	height: 12px;
}
.aib-testi__quote {
	font-family: var(--ai-font-display);
	font-style: italic;
	font-size: 17px;
	color: var(--ai-bordeaux-900);
	line-height: 1.45;
	margin: 0;
	flex: 1;
	max-width: none;
}
.aib-testi__meta {
	padding-top: 16px;
	border-top: 1px solid var(--ai-bordeaux-200);
	display: flex;
	flex-direction: column;
	gap: 4px;
}
.aib-testi__name { font-family: var(--ai-font-body); font-size: 14px; font-weight: 600; color: var(--ai-bordeaux-900); }
.aib-testi__place { font-family: var(--ai-font-body); font-size: 13px; color: var(--ai-bordeaux-600); }
.aib-testi__tag {
	font-family: var(--ai-font-body);
	font-size: 12px;
	font-weight: 600;
	color: var(--ai-magenta);
	background: var(--ai-bordeaux-100);
	border-radius: 999px;
	padding: 3px 10px;
	width: fit-content;
	margin-top: 4px;
}

@media (max-width: 960px) {
	.aib-testi__grid { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 600px) {
	.aib-testi__grid { grid-template-columns: 1fr; }
}

/* ── FAQ ─────────────────────────────────────────────────────────────── */
.aib-faq { background: var(--ai-cream-100); padding: 96px 0; }
.aib-faq__inner {
	display: grid;
	grid-template-columns: 1fr 1.5fr;
	gap: 64px;
	align-items: start;
}
.aib-faq__intro-title {
	font-family: var(--ai-font-display);
	font-size: clamp(26px, 3vw, 38px);
	font-weight: 400;
	line-height: 1.15;
	color: var(--ai-bordeaux-900);
	margin: 0 0 16px;
}
.aib-faq__intro-title-accent { color: var(--ai-magenta); }
.aib-faq__intro-text {
	font-family: var(--ai-font-body);
	font-size: 15px;
	color: var(--ai-bordeaux-600);
	line-height: 1.6;
	margin: 0 0 28px;
	max-width: none;
}
.aib-faq__intro-mail { color: var(--ai-magenta); font-weight: 500; }
.aib-faq__list {
	border: 1px solid var(--ai-bordeaux-200);
	border-radius: 14px;
	overflow: hidden;
	background: var(--ai-cream-100);
}
.aib-faq__item + .aib-faq__item { border-top: 1px solid var(--ai-bordeaux-200); }
.aib-faq__btn {
	width: 100%;
	display: flex;
	align-items: center;
	justify-content: space-between;
	padding: 18px 22px;
	background: var(--ai-cream-100);
	border: none;
	cursor: pointer;
	gap: 12px;
	text-align: left;
	font-family: var(--ai-font-body);
	font-size: 15px;
	font-weight: 600;
	color: var(--ai-bordeaux-900);
	transition: background 120ms ease-out;
}
/* Hello Elementor sets a generic `button:hover { color: #fff; background: #...}`
 * rule that bleeds onto our accordion buttons. Pin both states explicitly. */
.aib-faq__btn:hover,
.aib-faq__btn:focus,
.aib-faq__btn:focus-visible,
.aib-faq__btn:active {
	color: var(--ai-bordeaux-900);
	background: var(--ai-cream-50);
	outline: none;
	box-shadow: none;
}
.aib-faq__item[data-open="true"] .aib-faq__btn,
.aib-faq__item[data-open="true"] .aib-faq__btn:hover,
.aib-faq__item[data-open="true"] .aib-faq__btn:focus {
	background: var(--ai-cream-50);
	color: var(--ai-bordeaux-900);
}
.aib-faq__btn:focus-visible {
	box-shadow: 0 0 0 3px rgba(223, 188, 31, 0.25);
}
.aib-faq__chevron {
	flex-shrink: 0;
	transition: transform 200ms var(--ai-easing);
	stroke: var(--ai-bordeaux-600);
}
.aib-faq__item[data-open="true"] .aib-faq__chevron { transform: rotate(180deg); }
.aib-faq__panel {
	overflow: hidden;
	max-height: 0;
	transition: max-height 200ms var(--ai-easing);
}
.aib-faq__item[data-open="true"] .aib-faq__panel { max-height: 600px; }
.aib-faq__answer {
	font-family: var(--ai-font-body);
	font-size: 15px;
	color: var(--ai-bordeaux-600);
	line-height: 1.65;
	padding: 4px 22px 20px;
	margin: 0;
	max-width: none;
}
/* When the answer comes from the WP editor it's wrapped in <p> elements;
 * normalise them so the rendered text matches the original prototype. */
.aib-faq__answer p {
	margin: 0;
	max-width: none;
	font: inherit;
	color: inherit;
	line-height: inherit;
}
.aib-faq__answer p + p { margin-top: 0.75em; }
.aib-faq__answer a { color: var(--ai-magenta); text-decoration: underline; text-decoration-color: var(--ai-bordeaux-200); }
.aib-faq__answer a:hover { text-decoration-color: var(--ai-magenta); }

@media (max-width: 960px) {
	.aib-faq__inner { grid-template-columns: 1fr; gap: 32px; }
}

/* ── FORM ────────────────────────────────────────────────────────────── */
.aib-formsec { background: var(--ai-cream-200); padding: 96px 0; }
.aib-formsec__inner {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 72px;
	align-items: start;
}
.aib-formsec__left { display: flex; flex-direction: column; gap: 28px; }
.aib-formsec__title {
	font-family: var(--ai-font-display);
	font-size: clamp(28px, 3vw, 42px);
	font-weight: 400;
	line-height: 1.1;
	color: var(--ai-bordeaux-900);
	margin: 0 0 16px;
}
.aib-formsec__title-accent { color: var(--ai-magenta); }
.aib-formsec__lede {
	font-family: var(--ai-font-body);
	font-size: 16px;
	color: var(--ai-bordeaux-600);
	line-height: 1.6;
	margin: 0;
	max-width: 420px;
}
.aib-formsec__bullets { display: flex; flex-direction: column; gap: 14px; list-style: none; padding: 0; margin: 0; }
.aib-formsec__bullet { display: flex; align-items: center; gap: 10px; }
.aib-formsec__bullet-icon {
	width: 22px; height: 22px; border-radius: 50%;
	background: var(--ai-success-bg);
	display: flex; align-items: center; justify-content: center;
	flex-shrink: 0;
	color: var(--ai-success);
}
.aib-formsec__bullet-text { font-family: var(--ai-font-body); font-size: 15px; color: var(--ai-bordeaux-900); }

.aib-formsec__card {
	background: var(--ai-cream-50);
	border-radius: 16px;
	padding: 36px 32px;
	box-shadow: 0 4px 24px rgba(26,13,20,0.08);
	border: 1px solid var(--ai-bordeaux-200);
}
.aib-formsec__intro-title { font-family: var(--ai-font-body); font-size: 17px; font-weight: 700; color: var(--ai-bordeaux-900); margin-bottom: 4px; }
.aib-formsec__intro-sub   { font-family: var(--ai-font-body); font-size: 13px; color: var(--ai-bordeaux-600); }
.aib-formsec__form { display: flex; flex-direction: column; gap: 16px; }
.aib-formsec__form-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
.aib-formsec__field { display: flex; flex-direction: column; gap: 6px; }
.aib-formsec__label {
	font-family: var(--ai-font-body);
	font-size: 13px;
	font-weight: 600;
	color: var(--ai-bordeaux-900);
}
.aib-formsec__required { color: var(--ai-error); }
.aib-formsec__input-wrap { position: relative; }
.aib-formsec__input,
.aib-formsec__select {
	font-family: var(--ai-font-body);
	font-size: 15px;
	color: var(--ai-bordeaux-900);
	background: var(--ai-cream-50);
	width: 100%;
	min-height: 46px;
	border-radius: 8px;
	padding: 11px 14px;
	border: 1px solid var(--ai-bordeaux-200);
	outline: none;
	transition: border 120ms ease-out, box-shadow 120ms ease-out;
}
.aib-formsec__select { cursor: pointer; }
.aib-formsec__input:focus,
.aib-formsec__select:focus {
	border: 2px solid var(--ai-gold-500);
	box-shadow: 0 0 0 3px rgba(223,188,31,0.15);
}
.aib-formsec__input[aria-invalid="true"] { border: 1.5px solid var(--ai-error); }
.aib-formsec__error-msg {
	font-family: var(--ai-font-body);
	font-size: 12px;
	color: var(--ai-error);
}
.aib-formsec__check {
	display: flex;
	align-items: flex-start;
	gap: 10px;
	margin-top: 4px;
}
.aib-formsec__check input {
	width: 16px; height: 16px;
	margin-top: 2px;
	accent-color: var(--ai-gold-500);
	cursor: pointer;
	flex-shrink: 0;
}
.aib-formsec__check label {
	font-family: var(--ai-font-body);
	font-size: 13px;
	color: var(--ai-bordeaux-600);
	cursor: pointer;
	line-height: 1.5;
}
.aib-formsec__submit {
	background: var(--ai-gold-500);
	color: var(--ai-bordeaux-900);
	border: none;
	border-radius: 999px;
	padding: 15px 28px;
	min-height: 52px;
	font-family: var(--ai-font-body);
	font-size: 16px;
	font-weight: 600;
	letter-spacing: 0.02em;
	cursor: pointer;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 8px;
	margin-top: 4px;
	transition: background 120ms;
}
.aib-formsec__submit:hover { background: var(--ai-gold-600); }
.aib-formsec__submit[aria-busy="true"] { background: var(--ai-gold-600); cursor: wait; }
.aib-formsec__spinner {
	width: 16px; height: 16px;
	border: 2px solid var(--ai-bordeaux-900);
	border-top-color: transparent;
	border-radius: 50%;
	animation: aib-spin 0.7s linear infinite;
	display: inline-block;
}
.aib-formsec__legal {
	font-family: var(--ai-font-body);
	font-size: 12px;
	color: var(--ai-bordeaux-600);
	text-align: center;
	line-height: 1.5;
	margin: 0;
	max-width: none;
}
.aib-formsec__success {
	text-align: center;
	padding: 32px 0;
	animation: aib-fadein 300ms ease-out;
}
.aib-formsec__success-icon {
	width: 56px; height: 56px;
	background: var(--ai-success-bg);
	color: var(--ai-success);
	border-radius: 50%;
	display: flex; align-items: center; justify-content: center;
	margin: 0 auto 20px;
}
.aib-formsec__success-title { font-family: var(--ai-font-body); font-size: 18px; font-weight: 600; color: var(--ai-bordeaux-900); margin-bottom: 8px; }
.aib-formsec__success-sub   { font-family: var(--ai-font-body); font-size: 15px; color: var(--ai-bordeaux-600); line-height: 1.6; }
.aib-formsec__success[hidden] { display: none; }

@media (max-width: 960px) {
	.aib-formsec__inner { grid-template-columns: 1fr; }
}
@media (max-width: 600px) {
	.aib-formsec__form-grid { grid-template-columns: 1fr; }
}

/* ── Elementor Pro Form widget — token override ──────────────────────
 * Applies only inside .aib-formsec__elementor-wrap so it doesn't bleed
 * into other Elementor forms elsewhere. Goal: make Elementor's default
 * form widget render visually consistent with our hardcoded form
 * (cream-50 inputs, bordeaux-200 borders, gold pill submit, magenta
 * accent on focus).
 */
.aib-formsec__elementor-wrap .elementor-form-fields-wrapper {
	gap: 16px;
	display: flex;
	flex-direction: column;
}
.aib-formsec__elementor-wrap .elementor-field-group {
	margin-bottom: 0;
	padding-right: 0 !important;
}
.aib-formsec__elementor-wrap .elementor-field-label {
	font-family: var(--ai-font-body);
	font-size: 13px;
	font-weight: 600;
	color: var(--ai-bordeaux-900);
	margin-bottom: 6px;
}
.aib-formsec__elementor-wrap .elementor-field-required-indicator {
	color: var(--ai-error);
	font-weight: 600;
}
.aib-formsec__elementor-wrap input[type="text"].elementor-field,
.aib-formsec__elementor-wrap input[type="email"].elementor-field,
.aib-formsec__elementor-wrap input[type="tel"].elementor-field,
.aib-formsec__elementor-wrap input[type="url"].elementor-field,
.aib-formsec__elementor-wrap textarea.elementor-field,
.aib-formsec__elementor-wrap select.elementor-field {
	font-family: var(--ai-font-body);
	font-size: 15px;
	color: var(--ai-bordeaux-900);
	background: var(--ai-cream-50);
	min-height: 46px;
	border-radius: 8px;
	padding: 11px 14px;
	border: 1px solid var(--ai-bordeaux-200);
	width: 100%;
	transition: border 120ms ease-out, box-shadow 120ms ease-out;
}
.aib-formsec__elementor-wrap input.elementor-field:focus,
.aib-formsec__elementor-wrap textarea.elementor-field:focus,
.aib-formsec__elementor-wrap select.elementor-field:focus {
	border: 2px solid var(--ai-gold-500);
	box-shadow: 0 0 0 3px rgba(223, 188, 31, 0.15);
	outline: none;
}
.aib-formsec__elementor-wrap input.elementor-field.elementor-error,
.aib-formsec__elementor-wrap textarea.elementor-field.elementor-error {
	border-color: var(--ai-error);
}
.aib-formsec__elementor-wrap .elementor-field-type-acceptance .elementor-field-subgroup {
	display: flex;
	align-items: flex-start;
	gap: 10px;
}
.aib-formsec__elementor-wrap .elementor-field-type-acceptance input[type="checkbox"] {
	width: 16px;
	height: 16px;
	margin-top: 2px;
	accent-color: var(--ai-gold-500);
	cursor: pointer;
	flex-shrink: 0;
}
.aib-formsec__elementor-wrap .elementor-field-type-acceptance label,
.aib-formsec__elementor-wrap .elementor-field-type-acceptance .elementor-acceptance-label {
	font-family: var(--ai-font-body);
	font-size: 13px;
	color: var(--ai-bordeaux-600);
	line-height: 1.5;
}
.aib-formsec__elementor-wrap .elementor-button,
.aib-formsec__elementor-wrap button.elementor-button[type="submit"] {
	background: var(--ai-gold-500);
	color: var(--ai-bordeaux-900);
	border: none;
	border-radius: 999px;
	padding: 15px 28px;
	min-height: 52px;
	font-family: var(--ai-font-body);
	font-size: 16px;
	font-weight: 600;
	letter-spacing: 0.02em;
	cursor: pointer;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 8px;
	transition: background 120ms ease-out, transform 120ms ease-out;
}
.aib-formsec__elementor-wrap .elementor-button:hover {
	background: var(--ai-gold-600);
	transform: translateY(-1px);
	box-shadow: 0 4px 14px rgba(223, 188, 31, 0.35);
	color: var(--ai-bordeaux-900);
}
.aib-formsec__elementor-wrap .elementor-message {
	font-family: var(--ai-font-body);
	font-size: 14px;
	line-height: 1.5;
	border-radius: 8px;
	padding: 12px 16px;
	margin-top: 12px;
}
.aib-formsec__elementor-wrap .elementor-message-success {
	background: var(--ai-success-bg);
	color: var(--ai-success);
}
.aib-formsec__elementor-wrap .elementor-message-danger,
.aib-formsec__elementor-wrap .elementor-message-error {
	background: rgba(154, 27, 44, 0.08);
	color: var(--ai-error);
}

/* ── HEADER ──────────────────────────────────────────────────────────── */
.aib-header {
	position: fixed;
	top: 0; left: 0; right: 0;
	z-index: 100;
	background: transparent;
	border-bottom: 1px solid transparent;
	transition: background 200ms var(--ai-easing), border-color 200ms var(--ai-easing), box-shadow 200ms var(--ai-easing), backdrop-filter 200ms var(--ai-easing);
}
/* WP admin bar: spinge il nostro header fisso sotto la barra di /wp-admin
 * (32px desktop, 46px sotto i 783px), così non si sovrappongono. */
body.admin-bar .aib-header { top: 32px; }
@media (max-width: 782px) {
	body.admin-bar .aib-header { top: 46px; }
}
.aib-header[data-scrolled="true"],
body.aib-light-hero .aib-header {
	background: rgba(251,247,241,0.96);
	-webkit-backdrop-filter: blur(12px);
	backdrop-filter: blur(12px);
	border-bottom-color: var(--ai-bordeaux-200);
	box-shadow: 0 2px 16px rgba(26,13,20,0.07);
}
.aib-header__inner {
	max-width: 1200px;
	margin: 0 auto;
	padding: 0 48px;
	height: 68px;
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 32px;
}
.aib-header__logo { display: block; cursor: pointer; line-height: 0; }
.aib-header__logo img {
	height: 36px;
	width: auto;
	display: block;
}

/* Single-logo mode: only the main logo is uploaded, so we invert it via CSS
 * filter on dark backgrounds and remove the filter on light backgrounds. */
.aib-header__logo .aib-logo--needs-filter {
	filter: brightness(0) invert(1);
	transition: filter 200ms var(--ai-easing);
}
.aib-header[data-scrolled="true"] .aib-header__logo .aib-logo--needs-filter,
body.aib-light-hero .aib-header__logo .aib-logo--needs-filter { filter: none; }

/* Two-logo mode: a light variant is uploaded. Toggle visibility based on
 * the header's scrolled state — no CSS filter needed. */
.aib-header__logo .aib-logo--default { display: none; }
.aib-header__logo .aib-logo--light   { display: block; }
.aib-header[data-scrolled="true"] .aib-header__logo .aib-logo--default,
body.aib-light-hero .aib-header__logo .aib-logo--default { display: block; }
.aib-header[data-scrolled="true"] .aib-header__logo .aib-logo--light,
body.aib-light-hero .aib-header__logo .aib-logo--light { display: none; }
.aib-header__nav { display: flex; gap: 28px; }
.aib-header__nav a {
	font-family: var(--ai-font-body);
	font-size: 15px;
	font-weight: 500;
	color: var(--ai-cream-50);
	text-decoration: none;
	padding-bottom: 2px;
	opacity: 0.85;
	transition: color 120ms ease-out, opacity 120ms ease-out;
}
.aib-header[data-scrolled="true"] .aib-header__nav a,
body.aib-light-hero .aib-header__nav a { color: var(--ai-bordeaux-900); }
.aib-header__nav a:hover { opacity: 1; color: var(--ai-magenta); }
.aib-header__cta-wrap { display: flex; gap: 12px; align-items: center; }
.aib-header__mobile-btn {
	display: none;
	background: none;
	border: none;
	cursor: pointer;
	color: var(--ai-cream-50);
	padding: 4px;
}
.aib-header[data-scrolled="true"] .aib-header__mobile-btn,
body.aib-light-hero .aib-header__mobile-btn { color: var(--ai-bordeaux-900); }

@media (max-width: 960px) {
	.aib-header__inner { padding: 0 24px; }
	.aib-header__nav,
	.aib-header__cta-wrap { display: none; }
	.aib-header__mobile-btn { display: flex; }
}

.aib-mobile-menu {
	position: fixed;
	inset: 0;
	z-index: 200;
	background: rgba(26,13,20,0.6);
	display: none;
}
.aib-mobile-menu[data-open="true"] { display: block; }
.aib-mobile-menu__panel {
	position: absolute;
	top: 0; right: 0; bottom: 0;
	width: 80%;
	max-width: 320px;
	background: var(--ai-bordeaux-800);
	padding: 24px 28px;
	animation: aib-fadein 200ms ease-out;
	display: flex;
	flex-direction: column;
}
.aib-mobile-menu__head {
	display: flex;
	justify-content: space-between;
	align-items: center;
	margin-bottom: 32px;
}
.aib-mobile-menu__head img {
	height: 36px;
}
.aib-mobile-menu__head .aib-logo--needs-filter { filter: brightness(0) invert(1); }
.aib-mobile-menu__close {
	background: none;
	border: none;
	cursor: pointer;
	color: var(--ai-cream-50);
}
.aib-mobile-menu__panel a {
	display: block;
	font-family: var(--ai-font-body);
	font-size: 17px;
	font-weight: 500;
	color: var(--ai-cream-50);
	text-decoration: none;
	border-bottom: 1px solid rgba(248,241,233,0.12);
	padding: 14px 0;
}
.aib-mobile-menu__cta { margin-top: 28px; }
.aib-mobile-menu__cta .aib-btn { width: 100%; justify-content: center; }

/* ── FOOTER ──────────────────────────────────────────────────────────── */
.aib-footer {
	background: var(--ai-bordeaux-800);
	color: var(--ai-cream-50);
	position: relative;
	overflow: hidden;
}
.aib-footer__bg-b {
	position: absolute;
	right: -6%;
	bottom: -32%;
	font-family: var(--ai-font-display);
	font-size: clamp(360px, 50vw, 680px);
	line-height: 0.85;
	font-weight: 400;
	color: rgba(223,188,31,0.045);
	pointer-events: none;
	user-select: none;
}
.aib-footer__inner {
	max-width: 1320px;
	margin: 0 auto;
	padding: 0 48px;
	position: relative;
}
.aib-footer__cta {
	display: grid;
	grid-template-columns: 1.55fr 0.85fr;
	column-gap: clamp(40px, 6vw, 96px);
	align-items: center;
	padding: clamp(72px, 9vw, 112px) 0;
	border-bottom: 1px solid rgba(248,241,233,0.10);
}
.aib-footer__cta-title {
	font-family: var(--ai-font-display);
	font-size: clamp(32px, 3.8vw, 52px);
	font-weight: 400;
	line-height: 1.05;
	color: var(--ai-cream-50);
	margin: 0;
	letter-spacing: -0.005em;
}
.aib-footer__cta-title-accent { color: var(--ai-gold-500); }
.aib-footer__cta-text {
	font-family: var(--ai-font-body);
	font-size: clamp(14px, 1.1vw, 16px);
	color: rgba(248,241,233,0.55);
	line-height: 1.65;
	margin: 20px 0 0;
	max-width: 480px;
}
.aib-footer__cta-btn-wrap { justify-self: end; }

.aib-footer__grid {
	display: grid;
	grid-template-columns: 1.5fr 0.8fr 0.8fr 0.9fr;
	column-gap: clamp(32px, 4vw, 64px);
	padding: clamp(56px, 7vw, 88px) 0 56px;
}
.aib-footer__brand {
	display: flex;
	flex-direction: column;
	gap: 18px;
	max-width: 320px;
}
.aib-footer__brand img {
	height: 56px;
	width: auto;
}
.aib-footer__brand .aib-logo--needs-filter { filter: brightness(0) invert(1); }
.aib-footer__tagline {
	font-family: var(--ai-font-display);
	font-style: italic;
	font-size: 19px;
	color: var(--ai-gold-500);
	margin: 0;
	letter-spacing: 0.01em;
	line-height: 1;
}
.aib-footer__brand-text {
	font-family: var(--ai-font-body);
	font-size: 14px;
	color: rgba(248,241,233,0.55);
	line-height: 1.65;
	margin: 0;
	max-width: none;
}
.aib-footer__legal-mini {
	font-family: var(--ai-font-body);
	font-size: 12px;
	color: rgba(248,241,233,0.42);
	line-height: 1.7;
	margin: 0;
	padding-top: 4px;
}

.aib-footer__col { display: flex; flex-direction: column; gap: 14px; }
.aib-footer__col-h {
	font-family: var(--ai-font-body);
	font-size: 11px;
	font-weight: 700;
	letter-spacing: 0.18em;
	text-transform: uppercase;
	color: rgba(248,241,233,0.42);
	margin-bottom: 4px;
}
.aib-footer__link {
	font-family: var(--ai-font-body);
	font-size: 14px;
	color: rgba(248,241,233,0.65);
	text-decoration: none;
	display: inline-flex;
	align-items: center;
	gap: 8px;
	transition: color 200ms ease-out;
	width: fit-content;
}
.aib-footer__link::before {
	content: '';
	width: 0;
	height: 1px;
	background: var(--ai-gold-500);
	flex-shrink: 0;
	transition: width 240ms var(--ai-easing);
}
.aib-footer__link:hover {
	color: var(--ai-gold-500);
}
.aib-footer__link:hover::before { width: 14px; }

.aib-footer__rule {
	border-top: 1px solid rgba(248,241,233,0.10);
	padding: 22px 0 28px;
	display: flex;
	align-items: center;
	justify-content: space-between;
	flex-wrap: wrap;
	gap: 16px;
}
.aib-footer__copyright { font-family: var(--ai-font-body); font-size: 12px; color: rgba(248,241,233,0.40); letter-spacing: 0.02em; }
.aib-footer__made-in {
	display: inline-flex;
	align-items: center;
	gap: 10px;
	font-family: var(--ai-font-body);
	font-size: 11px;
	font-weight: 600;
	letter-spacing: 0.18em;
	text-transform: uppercase;
	color: rgba(248,241,233,0.48);
}
.aib-footer__made-in::before {
	content: '';
	width: 18px;
	height: 1px;
	background: var(--ai-gold-500);
	opacity: 0.8;
}

@media (max-width: 960px) {
	.aib-footer__inner { padding: 0 24px; }
	.aib-footer__cta { grid-template-columns: 1fr; align-items: flex-start; row-gap: 28px; }
	.aib-footer__cta-btn-wrap { justify-self: flex-start; }
	.aib-footer__grid { grid-template-columns: 1fr 1fr; row-gap: 40px; }
}
@media (max-width: 600px) {
	.aib-footer__grid { grid-template-columns: 1fr; }
}

/* Push <main> below the fixed header */
.aib-front-page { padding-top: 0; }

/* ────────────────────────────────────────────────────────────────────────── */
/*                          INNER PAGE BUILDING BLOCKS                        */
/* ────────────────────────────────────────────────────────────────────────── */

/* ── PAGE HERO (editorial chapter intro) ─────────────────────────────── */
/* Distinto dalla homepage hero (bordeaux full-bleed, cream-on-dark) per
 * inversione di superficie: crema-su-bordeaux + watermark numero capitolo. */
.aib-pagehero {
	position: relative;
	display: flex;
	flex-direction: column;
	/* Tonalità leggermente più calda/profonda della cream-50 usata da
	 * .aib-pullquote / .aib-manifesto, così la pagehero non si amalgama
	 * con la sezione successiva. Resta dentro la palette warm-neutral. */
	background: var(--ai-cream-200);
	padding-top: 128px;
	padding-bottom: 88px;
	overflow: hidden;
	isolation: isolate;
}
.aib-pagehero__bg {
	position: absolute;
	inset: 0;
	z-index: -1;
	background:
		radial-gradient(ellipse at 85% -10%, rgba(160,59,107,0.06), transparent 55%),
		radial-gradient(ellipse at -10% 110%, rgba(63,1,42,0.04), transparent 60%);
}
.aib-pagehero__chapter-mark {
	position: absolute;
	top: 64px;
	right: max(-24px, calc((100vw - 1200px) / 2 - 24px));
	z-index: -1;
	font-family: var(--ai-font-display);
	font-size: clamp(160px, 22vw, 280px);
	font-weight: 400;
	line-height: 0.85;
	color: rgba(63,1,42,0.06);
	letter-spacing: -0.04em;
	user-select: none;
	pointer-events: none;
}
.aib-pagehero__inner {
	display: flex;
	align-items: center;
	gap: 64px;
}
.aib-pagehero__content {
	position: relative;
	flex: 1;
	max-width: 560px;
	display: flex;
	flex-direction: column;
	gap: 24px;
	padding-left: 28px;
}
.aib-pagehero__rail {
	position: absolute;
	left: 0;
	top: 4px;
	bottom: 4px;
	width: 3px;
	background: var(--ai-bordeaux-200);
	border-radius: 2px;
}
.aib-pagehero--accent-magenta .aib-pagehero__rail { background: var(--ai-magenta); opacity: 0.7; }
.aib-pagehero--accent-verde   .aib-pagehero__rail { background: var(--ai-success); opacity: 0.7; }

.aib-pagehero__eyebrow {
	font-family: var(--ai-font-mono);
	font-size: 11px;
	font-weight: 500;
	letter-spacing: 0.18em;
	text-transform: uppercase;
	color: var(--ai-bordeaux-600);
	margin-bottom: 4px;
}
.aib-pagehero__title {
	font-family: var(--ai-font-display);
	font-size: clamp(40px, 5.2vw, 72px);
	font-weight: 400;
	line-height: 1.04;
	color: var(--ai-bordeaux-900);
	margin: 0;
	letter-spacing: -0.01em;
}
.aib-pagehero__title em {
	font-style: italic;
	color: var(--ai-magenta);
	font-weight: 400;
}
.aib-pagehero--accent-verde .aib-pagehero__title em { color: var(--ai-success); }

.aib-pagehero__subhead {
	font-family: var(--ai-font-body);
	font-size: clamp(16px, 1.35vw, 19px);
	line-height: 1.6;
	color: var(--ai-bordeaux-600);
	margin: 0;
	max-width: 540px;
}
.aib-pagehero__ctas { display: flex; gap: 24px; flex-wrap: wrap; align-items: center; margin-top: 12px; }
.aib-pagehero__cta-secondary {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	font-family: var(--ai-font-body);
	font-size: 14px;
	font-weight: 600;
	letter-spacing: 0.01em;
	color: var(--ai-bordeaux-900);
	text-decoration: none;
	padding: 4px 0;
	position: relative;
}
.aib-pagehero__cta-secondary::after {
	content: "";
	position: absolute;
	left: 0; right: 22px; bottom: 0;
	height: 1px;
	background: currentColor;
	opacity: 0.25;
	transition: opacity 200ms var(--ai-easing), right 240ms var(--ai-easing);
}
.aib-pagehero__cta-secondary:hover::after { opacity: 0.7; right: 0; }
.aib-pagehero__cta-secondary svg { transition: transform 240ms var(--ai-easing); }
.aib-pagehero__cta-secondary:hover svg { transform: translateX(3px); }

.aib-pagehero__visual {
	flex: 0 0 auto;
	max-width: 480px;
	position: relative;
}

@media (max-width: 960px) {
	.aib-pagehero { padding-top: 104px; padding-bottom: 72px; }
	.aib-pagehero__inner { flex-direction: column; align-items: stretch; gap: 48px; }
	.aib-pagehero__content { max-width: 100%; }
	.aib-pagehero__visual { max-width: 100%; align-self: center; }
}
@media (max-width: 768px) {
	.aib-pagehero__chapter-mark { display: none; }
	.aib-pagehero__content { padding-left: 20px; gap: 20px; }
}

/* ── PULL QUOTE ──────────────────────────────────────────────────────── */
.aib-pullquote { background: var(--ai-cream-50); padding: 80px 0; }
.aib-pullquote__inner {
	max-width: 820px;
	margin: 0 auto;
	text-align: center;
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 20px;
}
.aib-pullquote__rule {
	width: 40px;
	height: 2px;
	background: var(--ai-gold-500);
	border-radius: 2px;
}
.aib-pullquote__text {
	font-family: var(--ai-font-display);
	font-style: italic;
	font-size: clamp(20px, 2.4vw, 30px);
	font-weight: 400;
	line-height: 1.45;
	color: var(--ai-bordeaux-900);
	margin: 0;
	max-width: none;
}

/* ── CAPABILITY ──────────────────────────────────────────────────────── */
.aib-cap {
	background: var(--ai-cream-50);
	padding: 64px 0;
}
.aib-cap--bg-cream100 { background: var(--ai-cream-100); }
.aib-cap--compact { padding: 40px 0; }

.aib-cap__row {
	display: grid;
	grid-template-columns: 1fr 1fr;
	column-gap: 64px;
	row-gap: 28px;
	align-items: center;
}
.aib-cap--solo .aib-cap__row { grid-template-columns: 1fr; }
.aib-cap--reverse .aib-cap__text   { order: 2; }
.aib-cap--reverse .aib-cap__visual { order: 1; }

.aib-cap__text { max-width: 540px; }
.aib-cap--solo .aib-cap__text { max-width: 820px; }

.aib-cap__eyebrow {
	font-family: var(--ai-font-body);
	font-size: 11px;
	font-weight: 700;
	letter-spacing: 0.14em;
	text-transform: uppercase;
	color: var(--ai-magenta);
	margin-bottom: 12px;
}
.aib-cap__title {
	font-family: var(--ai-font-display);
	font-size: clamp(24px, 2.6vw, 36px);
	font-weight: 400;
	line-height: 1.18;
	color: var(--ai-bordeaux-900);
	margin: 0 0 16px;
}
.aib-cap--compact .aib-cap__title {
	font-size: clamp(20px, 2vw, 26px);
}
.aib-cap__body {
	font-family: var(--ai-font-body);
	font-size: clamp(15px, 1.2vw, 17px);
	color: var(--ai-bordeaux-600);
	line-height: 1.65;
	margin: 0;
	max-width: none;
}
.aib-cap--compact .aib-cap__body { font-size: 14px; }

@media (max-width: 960px) {
	.aib-cap__row { grid-template-columns: 1fr !important; }
	.aib-cap--reverse .aib-cap__text,
	.aib-cap--reverse .aib-cap__visual { order: 0; }
	.aib-cap__text { max-width: 100%; }
}

/* ── BEFORE / AFTER ──────────────────────────────────────────────────── */
.aib-ba { background: var(--ai-cream-200); padding: 80px 0; }
.aib-ba__table {
	background: var(--ai-cream-50);
	border: 1px solid var(--ai-bordeaux-200);
	border-radius: 16px;
	overflow: hidden;
}
.aib-ba__head {
	display: grid;
	grid-template-columns: 1fr 1fr;
	background: var(--ai-cream-100);
	border-bottom: 1px solid var(--ai-bordeaux-200);
}
.aib-ba__head-cell {
	padding: 18px 24px;
	font-family: var(--ai-font-body);
	font-size: 12px;
	font-weight: 700;
	letter-spacing: 0.14em;
	text-transform: uppercase;
}
.aib-ba__head-cell--before {
	color: var(--ai-bordeaux-600);
	border-right: 1px solid var(--ai-bordeaux-200);
}
.aib-ba__head-cell--after {
	color: var(--ai-gold-600);
}
.aib-ba__row {
	display: grid;
	grid-template-columns: 1fr 1fr;
}
.aib-ba__row + .aib-ba__row { border-top: 1px solid var(--ai-bordeaux-200); }
.aib-ba__cell {
	padding: 24px;
	font-family: var(--ai-font-body);
	font-size: 15px;
	line-height: 1.55;
}
.aib-ba__cell--before {
	color: var(--ai-bordeaux-600);
	border-right: 1px solid var(--ai-bordeaux-200);
}
.aib-ba__cell--after {
	color: var(--ai-bordeaux-900);
	font-weight: 500;
}

@media (max-width: 768px) {
	.aib-ba__head, .aib-ba__row { grid-template-columns: 1fr; }
	.aib-ba__head-cell--before, .aib-ba__cell--before { border-right: none; border-bottom: 1px solid var(--ai-bordeaux-200); }
}

/* ── SCENARIO ────────────────────────────────────────────────────────── */
.aib-scenario { background: var(--ai-cream-100); padding: 88px 0; }
.aib-scenario__inner {
	max-width: 760px;
	margin: 0 auto;
	position: relative;
}
.aib-scenario__quote-mark {
	position: absolute;
	left: -40px;
	top: -32px;
	font-family: var(--ai-font-display);
	font-size: 96px;
	color: var(--ai-gold-500);
	opacity: 0.5;
	line-height: 0.6;
	font-weight: 400;
	pointer-events: none;
	user-select: none;
}
.aib-scenario__text {
	font-family: var(--ai-font-display);
	font-style: italic;
	font-size: clamp(18px, 1.7vw, 22px);
	font-weight: 400;
	line-height: 1.6;
	color: var(--ai-bordeaux-900);
	margin: 0;
	padding-left: 16px;
	max-width: none;
}
.aib-scenario__text em { font-style: italic; }

@media (max-width: 600px) {
	.aib-scenario__quote-mark { left: -8px; top: -20px; font-size: 64px; }
}

/* ── COMPARISON ──────────────────────────────────────────────────────── */
.aib-cmp { background: var(--ai-bordeaux-800); padding: 64px 0; }
.aib-cmp .aib-container { max-width: 1000px; }
.aib-cmp__title {
	font-family: var(--ai-font-display);
	font-size: clamp(22px, 2.4vw, 30px);
	font-weight: 400;
	line-height: 1.2;
	color: var(--ai-cream-50);
	margin: 0 0 32px;
	text-align: center;
}
.aib-cmp__table {
	background: rgba(255,255,255,0.04);
	border: 1px solid rgba(248,241,233,0.12);
	border-radius: 16px;
	overflow: hidden;
}
.aib-cmp__head {
	display: grid;
	grid-template-columns: 1.2fr 1fr 1fr;
	border-bottom: 1px solid rgba(248,241,233,0.10);
}
.aib-cmp__head-cell {
	padding: 16px 22px;
	font-family: var(--ai-font-body);
	font-size: 11px;
	font-weight: 700;
	letter-spacing: 0.14em;
	text-transform: uppercase;
	text-align: center;
	color: rgba(248,241,233,0.40);
	border-left: 1px solid rgba(248,241,233,0.08);
}
.aib-cmp__head-cell:first-child { border-left: none; text-align: left; }
.aib-cmp__head-cell--left  { color: rgba(248,241,233,0.55); }
.aib-cmp__head-cell--right { color: var(--ai-gold-500); }
.aib-cmp__row {
	display: grid;
	grid-template-columns: 1.2fr 1fr 1fr;
}
.aib-cmp__row + .aib-cmp__row { border-top: 1px solid rgba(248,241,233,0.08); }
.aib-cmp__cell {
	padding: 18px 22px;
	font-family: var(--ai-font-body);
	font-size: 14px;
	border-left: 1px solid rgba(248,241,233,0.06);
}
.aib-cmp__cell:first-child { border-left: none; }
.aib-cmp__cell--topic { color: var(--ai-cream-50); }
.aib-cmp__cell--left  { color: rgba(248,241,233,0.55); text-align: center; }
.aib-cmp__cell--right { color: var(--ai-cream-50); font-weight: 600; text-align: center; }

@media (max-width: 720px) {
	.aib-cmp__head, .aib-cmp__row { grid-template-columns: 1fr; }
	.aib-cmp__cell, .aib-cmp__head-cell { border-left: none; text-align: left; }
}

/* ── MINI FAQ — inherits from .aib-faq, with its own padding ── */
.aib-faq--mini { padding: 88px 0; }

/* ── SECTION GRID ────────────────────────────────────────────────────── */
.aib-grid { background: var(--ai-cream-50); padding: 64px 0; }
.aib-grid--bg-cream100 { background: var(--ai-cream-100); }
.aib-grid .aib-container { max-width: 1000px; }
.aib-grid__header {
	margin-bottom: 32px;
	text-align: center;
}
.aib-grid__title {
	font-family: var(--ai-font-display);
	font-size: clamp(22px, 2.4vw, 30px);
	font-weight: 400;
	line-height: 1.2;
	color: var(--ai-bordeaux-900);
	margin: 0;
}
.aib-grid__items {
	display: grid;
	grid-template-columns: 1fr 1fr 1fr;
	gap: 24px;
}
.aib-grid__card {
	background: var(--ai-cream-100);
	border: 1px solid var(--ai-bordeaux-200);
	border-radius: 12px;
	padding: 24px;
	display: flex;
	flex-direction: column;
	gap: 10px;
}
.aib-grid--bg-cream100 .aib-grid__card { background: var(--ai-cream-50); }
.aib-grid__card-rule {
	width: 24px;
	height: 2px;
	background: var(--ai-gold-500);
}
.aib-grid__card-title {
	font-family: var(--ai-font-body);
	font-size: 14px;
	font-weight: 600;
	color: var(--ai-bordeaux-900);
	line-height: 1.35;
	margin: 0;
}
.aib-grid__card-body {
	font-family: var(--ai-font-body);
	font-size: 13px;
	color: var(--ai-bordeaux-600);
	line-height: 1.6;
	margin: 0;
	max-width: none;
}

@media (max-width: 768px) {
	.aib-grid__items { grid-template-columns: 1fr; }
}

/* ── PERIMETRO HEADER ────────────────────────────────────────────────── */
.aib-perimetro {
	background: var(--ai-cream-100);
	padding: 88px 0 32px;
}
.aib-perimetro__inner {
	text-align: center;
	max-width: 760px;
	margin: 0 auto;
}
.aib-perimetro__title {
	font-family: var(--ai-font-display);
	font-size: clamp(26px, 3vw, 38px);
	font-weight: 400;
	line-height: 1.15;
	color: var(--ai-bordeaux-900);
	margin: 0;
}

/* ── FINAL CTA ───────────────────────────────────────────────────────── */
.aib-final-cta {
	background: var(--ai-bordeaux-900);
	padding: clamp(72px, 9vw, 112px) 0;
	position: relative;
	overflow: hidden;
}
.aib-final-cta__bg-b {
	position: absolute;
	right: -6%;
	bottom: -32%;
	font-family: var(--ai-font-display);
	font-size: clamp(360px, 50vw, 680px);
	line-height: 0.85;
	font-weight: 400;
	color: rgba(223,188,31,0.045);
	pointer-events: none;
	user-select: none;
}
.aib-final-cta__inner { position: relative; z-index: 1; }
.aib-final-cta__row {
	display: grid;
	grid-template-columns: 1.55fr 0.85fr;
	column-gap: clamp(40px, 6vw, 96px);
	align-items: center;
}
.aib-final-cta__title {
	font-family: var(--ai-font-display);
	font-size: clamp(30px, 3.6vw, 48px);
	font-weight: 400;
	line-height: 1.05;
	color: var(--ai-cream-50);
	margin: 0;
	letter-spacing: -0.005em;
}
.aib-final-cta__sub {
	font-family: var(--ai-font-body);
	font-size: clamp(14px, 1.1vw, 16px);
	color: rgba(248,241,233,0.55);
	line-height: 1.65;
	margin: 20px 0 0;
	max-width: 480px;
}
.aib-final-cta__btn-wrap { justify-self: end; }

@media (max-width: 960px) {
	.aib-final-cta__row { grid-template-columns: 1fr; align-items: flex-start; row-gap: 28px; }
	.aib-final-cta__btn-wrap { justify-self: flex-start; }
}

/* ────────────────────────────────────────────────────────────────────────── */
/*                                MOCKUPS                                     */
/* ────────────────────────────────────────────────────────────────────────── */

/* ── Pairing Flow Mock ───────────────────────────────────────────────── */
.aib-mock-pairing {
	width: 100%;
	max-width: 280px;
	margin: 0 auto;
	background: var(--ai-bordeaux-900);
	border-radius: 38px;
	padding: 12px 8px 8px;
	box-shadow: 0 28px 60px -22px rgba(63,1,42,0.42);
}
.aib-mock-pairing__notch {
	width: 92px;
	height: 22px;
	border-radius: 999px;
	background: #0A0207;
	margin: 0 auto 10px;
	border: 1px solid rgba(255,255,255,0.04);
}
.aib-mock-pairing__screen {
	border-radius: 28px;
	background: var(--ai-cream-50);
	padding: 20px 16px;
	min-height: 460px;
	overflow: hidden;
}
.aib-mock-pairing__eyebrow {
	font-family: var(--ai-font-body);
	font-size: 10px;
	font-weight: 700;
	letter-spacing: 0.16em;
	text-transform: uppercase;
	color: var(--ai-magenta);
	margin-bottom: 14px;
}
.aib-mock-pairing__phase { animation: aib-fadein 360ms ease-out; }
.aib-mock-pairing__phase[hidden] { display: none; }
.aib-mock-pairing__title {
	font-family: var(--ai-font-display);
	font-size: 18px;
	color: var(--ai-bordeaux-900);
	line-height: 1.3;
	margin-bottom: 16px;
}
.aib-mock-pairing__title--small { font-size: 16px; margin-bottom: 12px; }
.aib-mock-pairing__dish {
	padding: 10px 14px;
	margin-bottom: 8px;
	background: var(--ai-cream-100);
	border: 1px solid var(--ai-bordeaux-200);
	border-radius: 8px;
	font-family: var(--ai-font-body);
	font-size: 13px;
	color: var(--ai-bordeaux-600);
}
.aib-mock-pairing__dish--active {
	background: var(--ai-bordeaux-100);
	border-color: var(--ai-magenta);
	color: var(--ai-magenta);
	font-weight: 600;
}
.aib-mock-pairing__qa {
	padding: 10px 14px;
	margin-bottom: 8px;
	background: var(--ai-cream-100);
	border: 1px solid var(--ai-bordeaux-200);
	border-radius: 8px;
}
.aib-mock-pairing__qa-q {
	font-family: var(--ai-font-body);
	font-size: 11px;
	color: var(--ai-bordeaux-600);
	margin-bottom: 4px;
}
.aib-mock-pairing__qa-a {
	font-family: var(--ai-font-body);
	font-size: 13px;
	color: var(--ai-bordeaux-900);
	font-weight: 600;
}
.aib-mock-pairing__wine {
	padding: 8px 12px;
	margin-bottom: 6px;
	background: var(--ai-cream-100);
	border-left: 3px solid var(--ai-gold-500);
	border-radius: 4px;
}
.aib-mock-pairing__wine-row {
	display: flex;
	justify-content: space-between;
	gap: 8px;
	align-items: baseline;
}
.aib-mock-pairing__wine-name {
	font-family: var(--ai-font-body);
	font-size: 12px;
	color: var(--ai-bordeaux-900);
	font-weight: 500;
}
.aib-mock-pairing__wine-match {
	font-family: var(--ai-font-body);
	font-size: 11px;
	color: var(--ai-gold-600);
	font-weight: 700;
}
.aib-mock-pairing__wine-price {
	font-family: var(--ai-font-body);
	font-size: 11px;
	color: var(--ai-bordeaux-600);
	margin-top: 2px;
}
.aib-mock-pairing__handle {
	width: 80px;
	height: 4px;
	background: rgba(255,255,255,0.18);
	border-radius: 999px;
	margin: 12px auto 4px;
}

/* ── MultiLang Card Mock ─────────────────────────────────────────────── */
.aib-mock-multilang {
	display: flex;
	gap: 16px;
	justify-content: center;
	align-items: center;
}
.aib-mock-multilang__card {
	width: 100%;
	max-width: 220px;
	background: var(--ai-bordeaux-900);
	border-radius: 32px;
	padding: 10px 6px 6px;
	box-shadow: 0 20px 40px -16px rgba(63,1,42,0.42);
}
.aib-mock-multilang__notch {
	width: 70px;
	height: 16px;
	border-radius: 999px;
	background: #0A0207;
	margin: 0 auto 8px;
}
.aib-mock-multilang__screen {
	border-radius: 24px;
	overflow: hidden;
	background: var(--ai-cream-50);
	padding: 16px 14px;
}
.aib-mock-multilang__lang {
	font-family: var(--ai-font-body);
	font-size: 10px;
	font-weight: 700;
	letter-spacing: 0.14em;
	text-transform: uppercase;
	color: var(--ai-magenta);
	margin-bottom: 10px;
}
.aib-mock-multilang__title {
	font-family: var(--ai-font-display);
	font-size: 16px;
	color: var(--ai-bordeaux-900);
	margin-bottom: 4px;
	line-height: 1.2;
}
.aib-mock-multilang__producer {
	font-family: var(--ai-font-body);
	font-size: 11px;
	color: var(--ai-bordeaux-600);
	margin-bottom: 12px;
}
.aib-mock-multilang__desc {
	font-family: var(--ai-font-body);
	font-size: 11px;
	color: var(--ai-bordeaux-900);
	line-height: 1.55;
}
.aib-mock-multilang__handle {
	width: 60px;
	height: 3px;
	background: rgba(255,255,255,0.18);
	border-radius: 999px;
	margin: 8px auto 2px;
}

@media (max-width: 600px) {
	.aib-mock-multilang { flex-direction: column; }
}

/* ── AI Generation Mock ──────────────────────────────────────────────── */
.aib-mock-aigen {
	background: var(--ai-bordeaux-900);
	border-radius: 18px;
	padding: 24px;
	border: 1px solid var(--ai-bordeaux-800);
	box-shadow: 0 32px 60px -28px rgba(63,1,42,0.40);
	max-width: 480px;
}
.aib-mock-aigen__eyebrow {
	font-family: var(--ai-font-body);
	font-size: 11px;
	font-weight: 700;
	letter-spacing: 0.14em;
	text-transform: uppercase;
	color: var(--ai-gold-500);
	margin-bottom: 12px;
	opacity: 0.85;
}
.aib-mock-aigen__input {
	background: rgba(255,255,255,0.06);
	border-radius: 8px;
	padding: 12px 16px;
	font-family: var(--ai-font-body);
	font-size: 14px;
	color: var(--ai-cream-50);
	margin-bottom: 16px;
	border: 1px solid rgba(255,255,255,0.10);
}
.aib-mock-aigen__rows { display: flex; flex-direction: column; gap: 8px; }
.aib-mock-aigen__row {
	display: flex;
	justify-content: space-between;
	gap: 16px;
	padding: 8px 12px;
	background: rgba(255,255,255,0.03);
	border-left: 2px solid rgba(255,255,255,0.10);
	border-radius: 4px;
	opacity: 0.35;
	transition: opacity 360ms ease-out, border-color 360ms ease-out;
}
.aib-mock-aigen__row[data-active="true"] {
	opacity: 1;
	border-left-color: var(--ai-gold-500);
}
.aib-mock-aigen__row-label {
	font-family: var(--ai-font-body);
	font-size: 12px;
	color: rgba(248,241,233,0.55);
}
.aib-mock-aigen__row-value {
	font-family: var(--ai-font-body);
	font-size: 13px;
	color: var(--ai-cream-50);
	font-weight: 500;
}
.aib-mock-aigen__footer {
	margin-top: 16px;
	font-family: var(--ai-font-body);
	font-size: 11px;
	color: rgba(248,241,233,0.40);
	text-align: right;
}
