/* ==========================================================================
	Torskint Elementor Banner Pro — banners.css  v1.1.0
	10 premium masonry ecommerce banner layouts
	BEM · CSS Grid · Mobile-first · No Elementor hacks
	========================================================================== */


/* ─────────────────────────────────────────────────────────────────────────
	DESIGN TOKENS
	───────────────────────────────────────────────────────────────────────── */

:root {
	--tbp-gap:               12px;
	--tbp-gap-lg:            16px;
	--tbp-gap-xl:            20px;
	--tbp-radius:            4px;
	--tbp-ease:              cubic-bezier(0.25, 0.46, 0.45, 0.94);
	--tbp-duration:          0.38s;
	--tbp-transition:        var(--tbp-duration) var(--tbp-ease);

	/* Overlay */
	--tbp-overlay-base:      rgba(0, 0, 0, 0.0);
	--tbp-overlay-end:       rgba(0, 0, 0, 0.62);
	--tbp-overlay-mid:       rgba(0, 0, 0, 0.28);

	/* Typography */
	--tbp-white:             #ffffff;
	--tbp-kicker-color:      rgba(255, 255, 255, 0.72);
	--tbp-desc-color:        rgba(255, 255, 255, 0.80);

	/* CTA pill */
	--tbp-cta-bg:            #F86009;
	--tbp-cta-bg-hover:      #4D4645;
	--tbp-cta-border:        #F86009;
	--tbp-cta-border-hover:  #4D4645;

	/* Shadows */
	/*--tbp-shadow:            0 3px 18px rgba(0, 0, 0, 0.14), 0 1px 4px rgba(0, 0, 0, 0.08);*/
	/*--tbp-shadow-hover:      0 8px 36px rgba(0, 0, 0, 0.26), 0 2px 8px rgba(0, 0, 0, 0.12);*/

	/* Section header */
	--tbp-header-mb:         20px;
	--tbp-header-pb:         16px;
}


/* ─────────────────────────────────────────────────────────────────────────
	SECTION WRAPPER
	───────────────────────────────────────────────────────────────────────── */

.torskint-banner {
	width: 100%;
	font-family: inherit;
	box-sizing: border-box;
}

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


/* ─────────────────────────────────────────────────────────────────────────
	SECTION HEADER
	───────────────────────────────────────────────────────────────────────── */

.torskint-banner__header {
	display: flex;
	align-items: flex-end;
	justify-content: space-between;
	gap: 16px;
	margin-bottom: var(--tbp-header-mb);
	padding-bottom: var(--tbp-header-pb);
	/*border-bottom: 1px solid rgba(0, 0, 0, 0.09);*/
}

.torskint-banner__header-text {
	display: flex;
	flex-direction: column;
	gap: 3px;
}

.torskint-banner__section-title {
	margin: 0;
	/*font-size: clamp(1.2rem, 2vw, 1.7rem);*/
	font-weight: 700;
	letter-spacing: -0.022em;
	line-height: 1.15;
	color: inherit;
	margin-bottom: 10px;
}

.torskint-banner__section-subtitle {
	margin: 0;
	/*font-size: 0.875rem;*/
	color: rgba(0, 0, 0, 0.5);
	line-height: 1.4;
}

.torskint-banner__section-link {
	display: inline-flex;
	align-items: center;
	gap: 5px;
	font-size: 0.8125rem;
	font-weight: 600;
	letter-spacing: 0.01em;
	color: inherit;
	text-decoration: none;
	white-space: nowrap;
	opacity: 0.65;
	transition: opacity var(--tbp-transition);
}

.torskint-banner__section-link:hover,
.torskint-banner__section-link:focus-visible {
	opacity: 1;
	text-decoration: underline;
	text-underline-offset: 3px;
}


/* ─────────────────────────────────────────────────────────────────────────
	BASE CARD
	───────────────────────────────────────────────────────────────────────── */

.torskint-banner__card {
	position: relative;
	overflow: hidden;
	border-radius: var(--tbp-radius);
	/*box-shadow: var(--tbp-shadow);*/
	background-color: #111;
	cursor: pointer;
	min-height: 200px;
	/* Initial state for scroll-reveal — JS adds .is-visible to trigger entry */
	opacity: 0;
	transform: translateY(14px);
	transition:
		opacity    0.52s cubic-bezier(0.22, 1, 0.36, 1),
		transform  0.52s cubic-bezier(0.22, 1, 0.36, 1);
}

/* Stagger entrance delay per card index */
.torskint-banner__card--item-1 { transition-delay: 0.00s; }
.torskint-banner__card--item-2 { transition-delay: 0.06s; }
.torskint-banner__card--item-3 { transition-delay: 0.12s; }
.torskint-banner__card--item-4 { transition-delay: 0.18s; }
.torskint-banner__card--item-5 { transition-delay: 0.24s; }

/* Revealed state */
.torskint-banner__card.is-visible {
	opacity: 1;
	transform: translateY(0);
}

/* Hover (only once card is visible) */
.torskint-banner__card.is-visible:hover {
	/*box-shadow: var(--tbp-shadow-hover);*/
	transform: translateY(-2px);
}

/* Elementor editor: bypass reveal so cards are always visible while editing */
.elementor-editor-active .torskint-banner__card {
	opacity: 1 !important;
	transform: none !important;
	transition-delay: 0s !important;
}

/* Gradient overlay (main atmospheric layer) */
.torskint-banner__card::after {
	content: '';
	position: absolute;
	inset: 0;
	background: linear-gradient(
		160deg,
		var(--tbp-overlay-base)  0%,
		var(--tbp-overlay-mid)  45%,
		var(--tbp-overlay-end)  100%
	);
	z-index: 1;
	transition: opacity var(--tbp-transition);
	opacity: 1;
}

/* Hover: slightly deeper gradient */
.torskint-banner__card:hover::after {
	opacity: 0.88;
}

/* Subtle top vignette for legibility (decorative absolute element) */
.torskint-banner__card::before {
	content: '';
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	height: 45%;
	background: linear-gradient(
		to bottom,
		rgba(0, 0, 0, 0.22) 0%,
		rgba(0, 0, 0, 0.00) 100%
	);
	z-index: 1;
	pointer-events: none;
	opacity: 0;
	transition: opacity var(--tbp-transition);
}

.torskint-banner__card--hero::before {
	opacity: 1;
}


/* ─────────────────────────────────────────────────────────────────────────
	BACKGROUND IMAGE
	───────────────────────────────────────────────────────────────────────── */

.torskint-banner__bg {
	position: absolute;
	inset: 0;
	z-index: 0;
	background-position: center;
	background-size: cover;
	background-repeat: no-repeat;
}

.torskint-banner__bg-img {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	object-fit: cover;
	object-position: center;
	transition: transform calc(var(--tbp-duration) * 1.4) var(--tbp-ease);
	display: none;
}

.torskint-banner__card:hover .torskint-banner__bg-img {
	transform: scale(1.045);
}


/* ─────────────────────────────────────────────────────────────────────────
	CARD OVERLAY CONTENT
	───────────────────────────────────────────────────────────────────────── */

.torskint-banner__overlay {
	position: absolute;
	bottom: 0;
	left: 0;
	right: 0;
	z-index: 2;
	padding: 20px 22px 22px;
	display: flex;
	flex-direction: column;
	gap: 5px;
	pointer-events: none;
}

.torskint-banner__kicker {
	display: inline-block;
	/*font-size: 0.675rem;*/
	font-weight: 700;
	letter-spacing: 0.11em;
	text-transform: uppercase;
	color: var(--tbp-kicker-color);
	margin-bottom: 1px;
}

/* Kicker badge variant — floated dot before text */
/*.torskint-banner__kicker::before {
	content: '';
	content: '●';
	font-size: 0.45em;
	margin-right: 5px;
	vertical-align: middle;
	opacity: 0.65;
}*/

.torskint-banner__title {
	margin: 0;
	font-size: clamp(0.95rem, 1.8vw, 1.4rem);
	font-weight: 700;
	line-height: 1.2;
	letter-spacing: -0.015em;
	color: var(--tbp-white);
}

.torskint-banner__desc {
	margin: 0;
	/*font-size: 0.82rem;*/
	line-height: 1.5;
	color: var(--tbp-desc-color);
	/*max-width: 38ch;*/
}

.torskint-banner__cta {
	display: inline-flex;
	align-items: center;
	margin-top: 10px;
	padding: 7px 16px 7px 14px;
	/*font-size: 0.73rem;*/
	font-weight: 700;
	letter-spacing: 0.07em;
	text-transform: uppercase;
	color: var(--tbp-white);
	background: var(--tbp-cta-bg);
	border: 1px solid var(--tbp-cta-border);
	border-radius: var(--tbp-radius);
	backdrop-filter: blur(8px);
	-webkit-backdrop-filter: blur(8px);
	align-self: flex-start;
	transition:
		background     var(--tbp-transition),
		border-color   var(--tbp-transition),
		transform      calc(var(--tbp-duration) * 0.7) var(--tbp-ease);
}

.torskint-banner__cta::after {
	content: '→';
	margin-left: 6px;
	font-size: 0.9em;
	transition: transform calc(var(--tbp-duration) * 0.7) var(--tbp-ease);
}

.torskint-banner__card:hover .torskint-banner__cta {
	background: var(--tbp-cta-bg-hover);
	border-color: var(--tbp-cta-border-hover);
}

.torskint-banner__card:hover .torskint-banner__cta::after {
	transform: translateX(3px);
}


/* ─────────────────────────────────────────────────────────────────────────
	LINK MASK (full card click area)
	───────────────────────────────────────────────────────────────────────── */

.torskint-banner__link-mask {
	position: absolute;
	inset: 0;
	z-index: 3;
	display: block;
	text-indent: -9999px;
	overflow: hidden;
	border-radius: var(--tbp-radius);
}

.torskint-banner__link-mask:focus-visible {
	outline: 3px solid rgba(255, 255, 255, 0.9);
	outline-offset: -4px;
}


/* ─────────────────────────────────────────────────────────────────────────
	ROLE VARIANTS — visual differentiation per card role
	───────────────────────────────────────────────────────────────────────── */

/* Hero: bigger title, deeper padding */
.torskint-banner__card--hero .torskint-banner__title {
	font-size: clamp(1.2rem, 2.6vw, 2rem);
}

.torskint-banner__card--hero .torskint-banner__overlay {
	padding: 26px 28px 28px;
}

/* Tall: slightly larger title */
.torskint-banner__card--tall .torskint-banner__title {
	font-size: clamp(1.05rem, 2vw, 1.6rem);
}

/* Accent / compact: smaller text, no desc */
.torskint-banner__card--accent .torskint-banner__title {
	font-size: clamp(0.875rem, 1.4vw, 1.1rem);
}

.torskint-banner__card--accent .torskint-banner__desc {
	display: none;
}

.torskint-banner__card--accent .torskint-banner__overlay {
	padding: 14px 16px 16px;
}

.torskint-banner__card--accent .torskint-banner__cta {
	padding: 5px 12px;
	/*font-size: 0.68rem;*/
}

/* Support: standard, nothing special */
.torskint-banner__card--support .torskint-banner__title {
	font-size: clamp(0.95rem, 1.7vw, 1.35rem);
}


/* ─────────────────────────────────────────────────────────────────────────
	LAYOUT 01
	4 items — dominant tall hero (left) + vertical right stack
	Desktop 3-col: item_1 col 1 / rows 1–3 | items 2–4 col 2-3 stacked
	───────────────────────────────────────────────────────────────────────── */

.torskint-banner--layout-01 .torskint-banner__grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--tbp-gap);
}

/* Mobile defaults */
.torskint-banner--layout-01 .torskint-banner__card--item-1 { min-height: 320px; }
.torskint-banner--layout-01 .torskint-banner__card--item-2 { min-height: 210px; }
.torskint-banner--layout-01 .torskint-banner__card--item-3 { min-height: 210px; }
.torskint-banner--layout-01 .torskint-banner__card--item-4 { min-height: 150px; }

/* Tablet: 2-col, hero spans full left */
@media ( min-width: 640px ) {
	.torskint-banner--layout-01 .torskint-banner__grid {
		grid-template-columns: 1.3fr 1fr;
		grid-template-rows: 220px 180px 140px;
		gap: var(--tbp-gap);
	}

	.torskint-banner--layout-01 .torskint-banner__card--item-1 {
		grid-column: 1 / 2;
		grid-row: 1 / 4;
		min-height: unset;
	}

	.torskint-banner--layout-01 .torskint-banner__card--item-2 {
		grid-column: 2 / 3;
		grid-row: 1 / 2;
		min-height: unset;
	}

	.torskint-banner--layout-01 .torskint-banner__card--item-3 {
		grid-column: 2 / 3;
		grid-row: 2 / 3;
		min-height: unset;
	}

	.torskint-banner--layout-01 .torskint-banner__card--item-4 {
		grid-column: 2 / 3;
		grid-row: 3 / 4;
		min-height: unset;
	}
}

/* Desktop: 3-col — hero left, 2-col right stack */
@media ( min-width: 960px ) {
	.torskint-banner--layout-01 .torskint-banner__grid {
		grid-template-columns: 1.15fr 1fr 1fr;
		grid-template-rows: 240px 210px 160px;
		gap: var(--tbp-gap);
	}

	/* Hero still in col 1 */
	.torskint-banner--layout-01 .torskint-banner__card--item-2 {
		grid-column: 2 / 4;
	}

	.torskint-banner--layout-01 .torskint-banner__card--item-3 {
		grid-column: 2 / 4;
	}

	.torskint-banner--layout-01 .torskint-banner__card--item-4 {
		grid-column: 2 / 4;
	}
}

@media ( min-width: 1200px ) {
	.torskint-banner--layout-01 .torskint-banner__grid {
		grid-template-rows: 260px 220px 170px;
		gap: var(--tbp-gap-lg);
	}
}

/* Desktop: accent card shows desc */
@media ( min-width: 960px ) {
	.torskint-banner--layout-01 .torskint-banner__card--item-4 .torskint-banner__desc {
		display: block;
	}
}


/* ─────────────────────────────────────────────────────────────────────────
	LAYOUT 02
	3 items — asymmetric 2-col: tall hero left | medium + short stacked right
	Desktop: grid-template-columns driven by --l02-total and --l02-top-pct CSS vars
	───────────────────────────────────────────────────────────────────────── */

.torskint-banner--layout-02 .torskint-banner__grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--tbp-gap);
	--l02-total: 540px;
	--l02-top-pct: 60%;
}

.torskint-banner--layout-02 .torskint-banner__card--item-1 { min-height: 340px; }
.torskint-banner--layout-02 .torskint-banner__card--item-2 { min-height: 220px; }
.torskint-banner--layout-02 .torskint-banner__card--item-3 { min-height: 160px; }

@media ( min-width: 640px ) {
	.torskint-banner--layout-02 .torskint-banner__grid {
		grid-template-columns: 62% 1fr;
		grid-template-rows:
			calc(var(--l02-total) * 0.6)
			calc(var(--l02-total) * 0.4);
		gap: var(--tbp-gap);
	}

	.torskint-banner--layout-02 .torskint-banner__card--item-1 {
		grid-column: 1 / 2;
		grid-row: 1 / 3;
		min-height: unset;
	}

	.torskint-banner--layout-02 .torskint-banner__card--item-2 {
		grid-column: 2 / 3;
		grid-row: 1 / 2;
		min-height: unset;
	}

	.torskint-banner--layout-02 .torskint-banner__card--item-3 {
		grid-column: 2 / 3;
		grid-row: 2 / 3;
		min-height: unset;
	}
}

@media ( min-width: 1100px ) {
	.torskint-banner--layout-02 .torskint-banner__grid {
		--l02-total: 600px;
		gap: var(--tbp-gap-lg);
	}
}


/* ─────────────────────────────────────────────────────────────────────────
	LAYOUT 03
	3 items — 3-column editorial: medium left | tall hero center | short right
	Center spans 3 rows; left spans 2; right spans 1 (breathing space below).
	───────────────────────────────────────────────────────────────────────── */

.torskint-banner--layout-03 .torskint-banner__grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--tbp-gap);
}

/* Mobile: center hero first (order swap) */
.torskint-banner--layout-03 .torskint-banner__card--item-1 { min-height: 240px; order: 2; }
.torskint-banner--layout-03 .torskint-banner__card--item-2 { min-height: 360px; order: 1; }
.torskint-banner--layout-03 .torskint-banner__card--item-3 { min-height: 200px; order: 3; }

@media ( min-width: 640px ) {
	.torskint-banner--layout-03 .torskint-banner__grid {
		grid-template-columns: 1fr 1.3fr 1fr;
		grid-template-rows: 160px 160px 120px;
		gap: var(--tbp-gap);
	}

	.torskint-banner--layout-03 .torskint-banner__card--item-1 {
		grid-column: 1 / 2;
		grid-row: 1 / 3;
		min-height: unset;
		order: 0;
	}

	/* Center hero: full height (all 3 rows) */
	.torskint-banner--layout-03 .torskint-banner__card--item-2 {
		grid-column: 2 / 3;
		grid-row: 1 / 4;
		min-height: unset;
		order: 0;
	}

	/* Short right: only row 1 — leaves visual breathing space below */
	.torskint-banner--layout-03 .torskint-banner__card--item-3 {
		grid-column: 3 / 4;
		grid-row: 1 / 2;
		min-height: unset;
		order: 0;
	}
}

@media ( min-width: 1100px ) {
	.torskint-banner--layout-03 .torskint-banner__grid {
		grid-template-rows: 185px 175px 130px;
		gap: var(--tbp-gap-lg);
	}
}


/* ─────────────────────────────────────────────────────────────────────────
	LAYOUT 04
	5 items — bento grid
	Desktop 4-col:
	  item_1 → col 1-4 / row 1 (hero wide landscape)
	  item_2 → col 1-2 / row 2 | item_3 → col 3-4 / row 2
	  item_4 → col 1-2 / row 3 | item_5 → col 3-4 / row 3
	───────────────────────────────────────────────────────────────────────── */

.torskint-banner--layout-04 .torskint-banner__grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--tbp-gap);
}

.torskint-banner--layout-04 .torskint-banner__card--item-1 { min-height: 260px; }
.torskint-banner--layout-04 .torskint-banner__card--item-2 { min-height: 210px; }
.torskint-banner--layout-04 .torskint-banner__card--item-3 { min-height: 210px; }
.torskint-banner--layout-04 .torskint-banner__card--item-4 { min-height: 155px; }
.torskint-banner--layout-04 .torskint-banner__card--item-5 { min-height: 155px; }

@media ( min-width: 540px ) {
	.torskint-banner--layout-04 .torskint-banner__grid {
		grid-template-columns: 1fr 1fr;
		gap: var(--tbp-gap);
	}

	.torskint-banner--layout-04 .torskint-banner__card--item-1 {
		grid-column: 1 / 3;
	}
}

@media ( min-width: 900px ) {
	.torskint-banner--layout-04 .torskint-banner__grid {
		grid-template-columns: 1fr 1fr 1fr 1fr;
		grid-template-rows: 260px 200px 155px;
		gap: var(--tbp-gap);
	}

	.torskint-banner--layout-04 .torskint-banner__card--item-1 {
		grid-column: 1 / 5;
		grid-row: 1 / 2;
		min-height: unset;
	}

	.torskint-banner--layout-04 .torskint-banner__card--item-2 {
		grid-column: 1 / 3;
		grid-row: 2 / 3;
		min-height: unset;
	}

	.torskint-banner--layout-04 .torskint-banner__card--item-3 {
		grid-column: 3 / 5;
		grid-row: 2 / 3;
		min-height: unset;
	}

	.torskint-banner--layout-04 .torskint-banner__card--item-4 {
		grid-column: 1 / 3;
		grid-row: 3 / 4;
		min-height: unset;
	}

	.torskint-banner--layout-04 .torskint-banner__card--item-5 {
		grid-column: 3 / 5;
		grid-row: 3 / 4;
		min-height: unset;
	}
}

@media ( min-width: 1200px ) {
	.torskint-banner--layout-04 .torskint-banner__grid {
		grid-template-rows: 290px 220px 168px;
		gap: var(--tbp-gap-lg);
	}
}

/* Accent row: hide desc at all sizes */
.torskint-banner--layout-04 .torskint-banner__card--item-4 .torskint-banner__desc,
.torskint-banner--layout-04 .torskint-banner__card--item-5 .torskint-banner__desc {
	display: none;
}


/* ─────────────────────────────────────────────────────────────────────────
	LAYOUT 05
	4 items — full-width hero top + 3 uneven cards below
	Desktop 3-col:
	  item_1 → col 1-3 / row 1
	  item_2 → col 1   / row 2     (medium)
	  item_3 → col 2   / rows 2-3  (tall center — 2 rows)
	  item_4 → col 3   / row 2     (accent compact)
	───────────────────────────────────────────────────────────────────────── */

.torskint-banner--layout-05 .torskint-banner__grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--tbp-gap);
}

.torskint-banner--layout-05 .torskint-banner__card--item-1 { min-height: 280px; }
.torskint-banner--layout-05 .torskint-banner__card--item-2 { min-height: 200px; }
.torskint-banner--layout-05 .torskint-banner__card--item-3 { min-height: 260px; }
.torskint-banner--layout-05 .torskint-banner__card--item-4 { min-height: 160px; }

@media ( min-width: 540px ) {
	.torskint-banner--layout-05 .torskint-banner__grid {
		grid-template-columns: 1fr 1fr;
		gap: var(--tbp-gap);
	}

	.torskint-banner--layout-05 .torskint-banner__card--item-1 {
		grid-column: 1 / 3;
	}

	.torskint-banner--layout-05 .torskint-banner__card--item-3 {
		grid-column: 1 / 3;
	}
}

@media ( min-width: 900px ) {
	.torskint-banner--layout-05 .torskint-banner__grid {
		grid-template-columns: 1fr 1.2fr 1fr;
		grid-template-rows: 280px 190px 190px;
		gap: var(--tbp-gap);
	}

	.torskint-banner--layout-05 .torskint-banner__card--item-1 {
		grid-column: 1 / 4;
		grid-row: 1 / 2;
		min-height: unset;
	}

	.torskint-banner--layout-05 .torskint-banner__card--item-2 {
		grid-column: 1 / 2;
		grid-row: 2 / 3;
		min-height: unset;
	}

	/* Tall center: 2 rows */
	.torskint-banner--layout-05 .torskint-banner__card--item-3 {
		grid-column: 2 / 3;
		grid-row: 2 / 4;
		min-height: unset;
	}

	.torskint-banner--layout-05 .torskint-banner__card--item-4 {
		grid-column: 3 / 4;
		grid-row: 2 / 3;
		min-height: unset;
	}
}

@media ( min-width: 1200px ) {
	.torskint-banner--layout-05 .torskint-banner__grid {
		grid-template-rows: 310px 200px 200px;
		gap: var(--tbp-gap-lg);
	}
}

/* Accent item: no desc */
.torskint-banner--layout-05 .torskint-banner__card--item-4 .torskint-banner__desc {
	display: none;
}


/* ─────────────────────────────────────────────────────────────────────────
	LAYOUT 06
	5 items — compressed left rail + dominant right block
	DOM order: item_1, item_2, item_3, item_4, item_5
	Grid placement:
	  item_1 → col 1-2 / row 1   (support wide top-left)
	  item_2 → col 1-2 / row 2   (support wide mid-left)
	  item_3 → col 3   / rows 1-3 (hero — right block, full height)
	  item_4 → col 1   / row 3   (accent compact)
	  item_5 → col 2   / row 3   (accent compact)
	Note: col 3 is assigned to item_3 which appears 3rd in DOM.
			CSS grid-column/row explicitly overrides DOM order on desktop.
	───────────────────────────────────────────────────────────────────────── */

.torskint-banner--layout-06 .torskint-banner__grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--tbp-gap);
}

/* Mobile: hero first for priority */
.torskint-banner--layout-06 .torskint-banner__card--item-1 { min-height: 200px; order: 2; }
.torskint-banner--layout-06 .torskint-banner__card--item-2 { min-height: 200px; order: 3; }
.torskint-banner--layout-06 .torskint-banner__card--item-3 { min-height: 320px; order: 1; }
.torskint-banner--layout-06 .torskint-banner__card--item-4 { min-height: 135px; order: 4; }
.torskint-banner--layout-06 .torskint-banner__card--item-5 { min-height: 135px; order: 5; }

@media ( min-width: 540px ) {
	.torskint-banner--layout-06 .torskint-banner__grid {
		grid-template-columns: 1fr 1fr;
		gap: var(--tbp-gap);
	}

	.torskint-banner--layout-06 .torskint-banner__card--item-3 {
		grid-column: 1 / 3;
		order: 1;
	}

	.torskint-banner--layout-06 .torskint-banner__card--item-1 { order: 2; }
	.torskint-banner--layout-06 .torskint-banner__card--item-2 { order: 3; }
	.torskint-banner--layout-06 .torskint-banner__card--item-4 { order: 4; }
	.torskint-banner--layout-06 .torskint-banner__card--item-5 { order: 5; }
}

@media ( min-width: 860px ) {
	.torskint-banner--layout-06 .torskint-banner__grid {
		grid-template-columns: 1fr 1fr 1.7fr;
		grid-template-rows: 190px 190px 140px;
		gap: var(--tbp-gap);
	}

	/* Reset all order overrides */
	.torskint-banner--layout-06 .torskint-banner__card { order: 0; }

	/* Left rail top — wide (spans 2 left cols) */
	.torskint-banner--layout-06 .torskint-banner__card--item-1 {
		grid-column: 1 / 3;
		grid-row: 1 / 2;
		min-height: unset;
	}

	/* Left rail mid — wide */
	.torskint-banner--layout-06 .torskint-banner__card--item-2 {
		grid-column: 1 / 3;
		grid-row: 2 / 3;
		min-height: unset;
	}

	/* Hero — right col, full height */
	.torskint-banner--layout-06 .torskint-banner__card--item-3 {
		grid-column: 3 / 4;
		grid-row: 1 / 4;
		min-height: unset;
	}

	/* Accent pair bottom-left */
	.torskint-banner--layout-06 .torskint-banner__card--item-4 {
		grid-column: 1 / 2;
		grid-row: 3 / 4;
		min-height: unset;
	}

	.torskint-banner--layout-06 .torskint-banner__card--item-5 {
		grid-column: 2 / 3;
		grid-row: 3 / 4;
		min-height: unset;
	}
}

@media ( min-width: 1200px ) {
	.torskint-banner--layout-06 .torskint-banner__grid {
		grid-template-rows: 220px 200px 155px;
		gap: var(--tbp-gap-lg);
	}
}

/* Compact accents: no desc */
.torskint-banner--layout-06 .torskint-banner__card--item-4 .torskint-banner__desc,
.torskint-banner--layout-06 .torskint-banner__card--item-5 .torskint-banner__desc {
	display: none;
}


/* ─────────────────────────────────────────────────────────────────────────
	LAYOUT 07
	5 items — staggered stepped rhythm
	Desktop 3-col:
	  item_1 → col 1 / rows 1-2 (tall left)
	  item_2 → col 2 / row 1    (short center top)
	  item_3 → col 3 / rows 1-3 (hero, full height anchor)
	  item_4 → col 1 / row 3    (short bottom left)
	  item_5 → col 2 / rows 2-3 (tall center bottom)
	───────────────────────────────────────────────────────────────────────── */

.torskint-banner--layout-07 .torskint-banner__grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--tbp-gap);
}

.torskint-banner--layout-07 .torskint-banner__card--item-1 { min-height: 260px; }
.torskint-banner--layout-07 .torskint-banner__card--item-2 { min-height: 170px; }
.torskint-banner--layout-07 .torskint-banner__card--item-3 { min-height: 340px; }
.torskint-banner--layout-07 .torskint-banner__card--item-4 { min-height: 150px; }
.torskint-banner--layout-07 .torskint-banner__card--item-5 { min-height: 260px; }

@media ( min-width: 540px ) {
	.torskint-banner--layout-07 .torskint-banner__grid {
		grid-template-columns: 1fr 1fr;
		gap: var(--tbp-gap);
	}

	.torskint-banner--layout-07 .torskint-banner__card--item-3 {
		grid-column: 1 / 3;
	}
}

@media ( min-width: 900px ) {
	.torskint-banner--layout-07 .torskint-banner__grid {
		grid-template-columns: 1fr 1.1fr 1fr;
		grid-template-rows: 195px 200px 165px;
		gap: var(--tbp-gap);
	}

	/* Left tall: rows 1-2 */
	.torskint-banner--layout-07 .torskint-banner__card--item-1 {
		grid-column: 1 / 2;
		grid-row: 1 / 3;
		min-height: unset;
	}

	/* Short top-center: row 1 */
	.torskint-banner--layout-07 .torskint-banner__card--item-2 {
		grid-column: 2 / 3;
		grid-row: 1 / 2;
		min-height: unset;
	}

	/* Hero: right col, full height anchor */
	.torskint-banner--layout-07 .torskint-banner__card--item-3 {
		grid-column: 3 / 4;
		grid-row: 1 / 4;
		min-height: unset;
	}

	/* Short bottom-left: row 3 */
	.torskint-banner--layout-07 .torskint-banner__card--item-4 {
		grid-column: 1 / 2;
		grid-row: 3 / 4;
		min-height: unset;
	}

	/* Tall center-bottom: rows 2-3 */
	.torskint-banner--layout-07 .torskint-banner__card--item-5 {
		grid-column: 2 / 3;
		grid-row: 2 / 4;
		min-height: unset;
	}
}

@media ( min-width: 1200px ) {
	.torskint-banner--layout-07 .torskint-banner__grid {
		grid-template-rows: 215px 215px 175px;
		gap: var(--tbp-gap-lg);
	}
}

/* Short cards: no desc */
.torskint-banner--layout-07 .torskint-banner__card--item-2 .torskint-banner__desc,
.torskint-banner--layout-07 .torskint-banner__card--item-4 .torskint-banner__desc {
	display: none;
}


/* ─────────────────────────────────────────────────────────────────────────
	LAYOUT 08
	4 items — magazine editorial collage
	Desktop 3-col (30% | 1fr | 1fr):
	  item_1 → col 1   / rows 1-2 (portrait hero, tall)
	  item_2 → col 2-3 / row 1    (wide landscape support)
	  item_3 → col 2   / row 2    (compact support)
	  item_4 → col 3   / row 2    (compact accent)
	───────────────────────────────────────────────────────────────────────── */

.torskint-banner--layout-08 .torskint-banner__grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--tbp-gap);
}

.torskint-banner--layout-08 .torskint-banner__card--item-1 { min-height: 340px; }
.torskint-banner--layout-08 .torskint-banner__card--item-2 { min-height: 220px; }
.torskint-banner--layout-08 .torskint-banner__card--item-3 { min-height: 180px; }
.torskint-banner--layout-08 .torskint-banner__card--item-4 { min-height: 180px; }

@media ( min-width: 540px ) {
	.torskint-banner--layout-08 .torskint-banner__grid {
		grid-template-columns: 1fr 1fr;
		gap: var(--tbp-gap);
	}

	.torskint-banner--layout-08 .torskint-banner__card--item-1 {
		grid-column: 1 / 2;
		grid-row: 1 / 3;
	}

	.torskint-banner--layout-08 .torskint-banner__card--item-2 {
		grid-column: 2 / 3;
	}

	.torskint-banner--layout-08 .torskint-banner__card--item-3 {
		grid-column: 2 / 3;
	}
}

@media ( min-width: 900px ) {
	.torskint-banner--layout-08 .torskint-banner__grid {
		grid-template-columns: 30% 1fr 1fr;
		grid-template-rows: 265px 225px;
		gap: var(--tbp-gap);
	}

	/* Portrait hero: col 1, both rows */
	.torskint-banner--layout-08 .torskint-banner__card--item-1 {
		grid-column: 1 / 2;
		grid-row: 1 / 3;
		min-height: unset;
	}

	/* Wide landscape: cols 2-3, row 1 */
	.torskint-banner--layout-08 .torskint-banner__card--item-2 {
		grid-column: 2 / 4;
		grid-row: 1 / 2;
		min-height: unset;
	}

	/* Compact pair: row 2 */
	.torskint-banner--layout-08 .torskint-banner__card--item-3 {
		grid-column: 2 / 3;
		grid-row: 2 / 3;
		min-height: unset;
	}

	.torskint-banner--layout-08 .torskint-banner__card--item-4 {
		grid-column: 3 / 4;
		grid-row: 2 / 3;
		min-height: unset;
	}
}

@media ( min-width: 1200px ) {
	.torskint-banner--layout-08 .torskint-banner__grid {
		grid-template-rows: 300px 240px;
		gap: var(--tbp-gap-lg);
	}
}

/* Compact cards: no desc */
.torskint-banner--layout-08 .torskint-banner__card--item-3 .torskint-banner__desc,
.torskint-banner--layout-08 .torskint-banner__card--item-4 .torskint-banner__desc {
	display: none;
}

@media ( min-width: 900px ) {
	.torskint-banner--layout-08 .torskint-banner__card--item-3 .torskint-banner__desc,
	.torskint-banner--layout-08 .torskint-banner__card--item-4 .torskint-banner__desc {
		display: block;
	}
}


/* ─────────────────────────────────────────────────────────────────────────
	LAYOUT 09
	4 items — L-shape masonry
	Desktop 2-col:
	  item_1 → col 1 / rows 1-2 (hero tall)
	  item_2 → col 2 / row 1    (support small)
	  item_3 → col 2 / row 2    (support small)
	  item_4 → col 1-2 / row 3  (wide panoramic bottom)
	───────────────────────────────────────────────────────────────────────── */

.torskint-banner--layout-09 .torskint-banner__grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--tbp-gap);
}

.torskint-banner--layout-09 .torskint-banner__card--item-1 { min-height: 320px; }
.torskint-banner--layout-09 .torskint-banner__card--item-2 { min-height: 175px; }
.torskint-banner--layout-09 .torskint-banner__card--item-3 { min-height: 175px; }
.torskint-banner--layout-09 .torskint-banner__card--item-4 { min-height: 215px; }

@media ( min-width: 540px ) {
	.torskint-banner--layout-09 .torskint-banner__grid {
		grid-template-columns: 55% 1fr;
		grid-template-rows: 225px 225px auto;
		gap: var(--tbp-gap);
	}

	/* Hero: col 1, rows 1-2 */
	.torskint-banner--layout-09 .torskint-banner__card--item-1 {
		grid-column: 1 / 2;
		grid-row: 1 / 3;
		min-height: unset;
	}

	/* Small support pair: col 2, rows 1+2 */
	.torskint-banner--layout-09 .torskint-banner__card--item-2 {
		grid-column: 2 / 3;
		grid-row: 1 / 2;
		min-height: unset;
	}

	.torskint-banner--layout-09 .torskint-banner__card--item-3 {
		grid-column: 2 / 3;
		grid-row: 2 / 3;
		min-height: unset;
	}

	/* Wide panoramic bottom: spans both cols */
	.torskint-banner--layout-09 .torskint-banner__card--item-4 {
		grid-column: 1 / 3;
		grid-row: 3 / 4;
		min-height: 215px;
	}
}

@media ( min-width: 1100px ) {
	.torskint-banner--layout-09 .torskint-banner__grid {
		grid-template-rows: 255px 240px auto;
		gap: var(--tbp-gap-lg);
	}

	.torskint-banner--layout-09 .torskint-banner__card--item-4 {
		min-height: 230px;
	}
}

/* Small support cards: desc only on desktop */
.torskint-banner--layout-09 .torskint-banner__card--item-2 .torskint-banner__desc,
.torskint-banner--layout-09 .torskint-banner__card--item-3 .torskint-banner__desc {
	display: none;
}

@media ( min-width: 1100px ) {
	.torskint-banner--layout-09 .torskint-banner__card--item-2 .torskint-banner__desc,
	.torskint-banner--layout-09 .torskint-banner__card--item-3 .torskint-banner__desc {
		display: block;
	}
}


/* ─────────────────────────────────────────────────────────────────────────
	LAYOUT 10
	5 items — complex promotional mosaic
	Desktop 3-col (1.2fr 1fr 1fr):
	  item_1 → col 1-2 / rows 1-2 (dominant hero)
	  item_2 → col 3   / row 1    (medium stacked)
	  item_3 → col 3   / row 2    (medium stacked)
	  item_4 → col 1   / row 3    (accent narrow)
	  item_5 → col 2-3 / row 3    (accent wide — inverted weight)
	───────────────────────────────────────────────────────────────────────── */

.torskint-banner--layout-10 .torskint-banner__grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--tbp-gap);
}

.torskint-banner--layout-10 .torskint-banner__card--item-1 { min-height: 340px; }
.torskint-banner--layout-10 .torskint-banner__card--item-2 { min-height: 200px; }
.torskint-banner--layout-10 .torskint-banner__card--item-3 { min-height: 200px; }
.torskint-banner--layout-10 .torskint-banner__card--item-4 { min-height: 155px; }
.torskint-banner--layout-10 .torskint-banner__card--item-5 { min-height: 155px; }

@media ( min-width: 540px ) {
	.torskint-banner--layout-10 .torskint-banner__grid {
		grid-template-columns: 1fr 1fr;
		gap: var(--tbp-gap);
	}

	.torskint-banner--layout-10 .torskint-banner__card--item-1 {
		grid-column: 1 / 3;
	}
}

@media ( min-width: 900px ) {
	.torskint-banner--layout-10 .torskint-banner__grid {
		grid-template-columns: 1.2fr 1fr 1fr;
		grid-template-rows: 245px 200px 155px;
		gap: var(--tbp-gap);
	}

	/* Dominant hero: cols 1-2, rows 1-2 */
	.torskint-banner--layout-10 .torskint-banner__card--item-1 {
		grid-column: 1 / 3;
		grid-row: 1 / 3;
		min-height: unset;
	}

	/* Right stack */
	.torskint-banner--layout-10 .torskint-banner__card--item-2 {
		grid-column: 3 / 4;
		grid-row: 1 / 2;
		min-height: unset;
	}

	.torskint-banner--layout-10 .torskint-banner__card--item-3 {
		grid-column: 3 / 4;
		grid-row: 2 / 3;
		min-height: unset;
	}

	/* Bottom row: narrow left + wide right (inverted weight vs hero) */
	.torskint-banner--layout-10 .torskint-banner__card--item-4 {
		grid-column: 1 / 2;
		grid-row: 3 / 4;
		min-height: unset;
	}

	.torskint-banner--layout-10 .torskint-banner__card--item-5 {
		grid-column: 2 / 4;
		grid-row: 3 / 4;
		min-height: unset;
	}
}

@media ( min-width: 1200px ) {
	.torskint-banner--layout-10 .torskint-banner__grid {
		grid-template-rows: 270px 215px 170px;
		gap: var(--tbp-gap-lg);
	}
}

/* Accent bottom: no desc */
.torskint-banner--layout-10 .torskint-banner__card--item-4 .torskint-banner__desc,
.torskint-banner--layout-10 .torskint-banner__card--item-5 .torskint-banner__desc {
	display: none;
}

/* Medium stacked right: no desc at mid-sizes */
@media ( max-width: 1199px ) {
	.torskint-banner--layout-10 .torskint-banner__card--item-2 .torskint-banner__desc,
	.torskint-banner--layout-10 .torskint-banner__card--item-3 .torskint-banner__desc {
		display: none;
	}
}

@media ( min-width: 1200px ) {
	.torskint-banner--layout-10 .torskint-banner__card--item-2 .torskint-banner__desc,
	.torskint-banner--layout-10 .torskint-banner__card--item-3 .torskint-banner__desc {
		display: block;
	}
}


/* ─────────────────────────────────────────────────────────────────────────
	ACCESSIBILITY & MOTION PREFERENCES
	───────────────────────────────────────────────────────────────────────── */

@media ( prefers-reduced-motion: reduce ) {
	.torskint-banner__card,
	.torskint-banner__bg-img,
	.torskint-banner__card::after,
	.torskint-banner__card::before,
	.torskint-banner__cta,
	.torskint-banner__cta::after,
	.torskint-banner__section-link {
		transition: none;
	}

	.torskint-banner__card:hover {
		transform: none;
	}

	.torskint-banner__card:hover .torskint-banner__bg-img {
		transform: none;
	}

	.torskint-banner__card:hover .torskint-banner__cta::after {
		transform: none;
	}
}


/* ─────────────────────────────────────────────────────────────────────────
	TOUCH HOVER STATE — brief highlight on mobile tap
	───────────────────────────────────────────────────────────────────────── */

.torskint-banner__card.is-touched::after {
	opacity: 0.75;
}


/* ─────────────────────────────────────────────────────────────────────────
	KICKER BADGE VARIANT — floating top-left badge on hero cards
	───────────────────────────────────────────────────────────────────────── */

/* Move overlay content down to avoid kicker overlap on hero */
.torskint-banner__card--hero .torskint-banner__overlay {
	padding-top: 56px;
}


/* ─────────────────────────────────────────────────────────────────────────
	DECORATIVE OVERFLOW ELEMENT — subtle corner accent on tall cards
	A position:absolute decorative strip that overflows the card edge.
	───────────────────────────────────────────────────────────────────────── */

.torskint-banner__card--tall::after {
	/* Override the gradient-only ::after with a richer version */
	background: linear-gradient(
		145deg,
		rgba(0, 0, 0, 0.00)  0%,
		rgba(0, 0, 0, 0.18) 40%,
		rgba(0, 0, 0, 0.68) 100%
	);
}

/* ─────────────────────────────────────────────────────────────────────────
	MOBILE ONLY — uniformiser tous les layouts en flex stack
	Conserve Grid sur tablette/desktop
	À placer tout en bas du fichier
	───────────────────────────────────────────────────────────────────────── */

@media (max-width: 1024px) {

	.torskint-banner__header {
		flex-direction: column;
		align-items: flex-start;
		gap: 8px;
	}

	.torskint-banner__section-link {
		font-size: 0.8rem;
	}

	.torskint-banner__bg-img {
		display: block !important;
	}

	/* Tous les layouts passent en flex vertical */
	[class*="torskint-banner--layout-"] .torskint-banner__grid {
		display: flex !important;
		flex-direction: column;
		flex-wrap: nowrap;
		gap: var(--tbp-gap);
	}

	/* Toutes les cards prennent toute la largeur */
	[class*="torskint-banner--layout-"] .torskint-banner__card {
		width: 100%;
		flex: 0 0 100%;
		min-height: 220px;
	}

	/* Hero légèrement plus haute */
	[class*="torskint-banner--layout-"] .torskint-banner__card--hero,
	[class*="torskint-banner--layout-"] .torskint-banner__card--item-1 {
		min-height: 320px;
	}

	/* Cartes accent plus compactes */
	[class*="torskint-banner--layout-"] .torskint-banner__card--accent,
	[class*="torskint-banner--layout-"] .torskint-banner__card--item-4,
	[class*="torskint-banner--layout-"] .torskint-banner__card--item-5 {
		min-height: 160px;
	}

	/* Reset placements Grid desktop/tablette */
	[class*="torskint-banner--layout-"] .torskint-banner__card {
		grid-column: auto !important;
		grid-row: auto !important;
	}

	/* Reset des order spécifiques pour garder le DOM naturel en mobile */
	[class*="torskint-banner--layout-"] .torskint-banner__card {
		order: 0 !important;
	}

	/* Overlay un peu plus compact en mobile */
	.torskint-banner__overlay {
		padding: 16px 16px 18px;
		gap: 4px;
	}

	.torskint-banner__card--hero .torskint-banner__overlay {
		padding: 52px 18px 20px;
	}

	/* Typo mobile plus stable */
	.torskint-banner__title {
		font-size: clamp(1rem, 4.6vw, 1.25rem);
		line-height: 1.2;
	}

	.torskint-banner__card--hero .torskint-banner__title {
		font-size: clamp(1.15rem, 5.2vw, 1.5rem);
	}

	.torskint-banner__desc {
		max-width: 100%;
		line-height: 1.45;
	}

	/* CTA plus confortable au touch */
	.torskint-banner__cta {
		min-height: 44px;
		padding: 10px 14px;
	}
}