/**
 * =============================================================
 * @subpackage	RAXO Bricks Module Layout
 * -------------------------------------------------------------
 * @copyright	Copyright (C) 2009-2026 RAXO Group
 * @link		https://www.raxo.org
 * @license		RAXO Commercial License
 * 				This file is forbidden for redistribution
 * =============================================================
 */


/* ----- RESET & DEFAULT Styles ----- */
.raxo-bricks {
	container: raxo-bricks / inline-size;
	margin-block: 2rem;
	box-sizing: border-box;
	word-break: break-word;

	&:first-child { margin-block-start: 0; }
	& *, & ::before, & ::after { box-sizing: inherit; }

	& article, & h3, & h4,
	& img, & a {
		margin: 0;
		padding: 0;
		background: transparent none;
		border: 0 none;
	}
	& a {
		appearance: none;
		outline: 0;
		text-decoration: none;
		transition: all .25s ease-out;
	}
	& a:hover { background: transparent none; }
}


/* ----- Module BLOCK ----- */
.raxo-bricks {
	/* --- Layout SETTINGS --- */
	--top-font-size: 16px;
	--nor-font-size: 14px;
	--spacing-base: 8px;

	line-height: 1.375;

	/* --- Block HEADER --- */
	& .raxo-header {
		display: flex;
		flex-wrap: wrap;
		justify-content: flex-end;
		align-items: flex-start;
		margin-bottom: 14px;
		padding: 4px 10px;
		border-top: 2px solid var(--raxo-theme-color);
	}

	/* --- Block NAME --- */
	& .raxo-block-name {
		flex: 1 1 128px;
		margin: 0 2px;
		font: bold 18px/24px Tahoma, Helvetica, Arial, sans-serif;
		color: var(--raxo-text-deep);

		& a { color: inherit; }
	}

	/* --- Block BUTTON --- */
	& .raxo-block-button {
		margin: 2px;
	}

	/* --- Block INTRO --- */
	& .raxo-block-intro {
		flex: 1 100%;
		order: 3;
		margin: 12px 2px 4px;
		font-size: 16px;
		color: var(--raxo-text-base);
	}



	/* ----- MODULE Items ----- */
	& .raxo-top {
		font-size: var(--top-font-size);
		--icon-size: var(--top-font-size);
		--size-md: calc(var(--spacing-base) * 4);
		--size-lg: calc(var(--spacing-base) * 6);
	}
	& .raxo-normal {
		font-size: var(--nor-font-size);
		--icon-size: var(--nor-font-size);
		--size-md: calc(var(--spacing-base) * 3);
		--size-lg: calc(var(--spacing-base) * 4);
	}

	& article {
		position: relative;
		margin-bottom: var(--size-lg);
	}
	& article .raxo-wrap {
		background-color: var(--raxo-gray-100);
		border-radius: 4px 4px 3px 3px;
		box-shadow: 0 1px 2px var(--raxo-shadow-light);
		overflow: hidden;
	}
	& .raxo-wrap > div:first-child {
		border: solid var(--raxo-theme-color);
		border-width: 3px 0 0;
	}

	/* --- TOP Items --- */
	& .raxo-top .raxo-wrap {
		display: flex;
		flex-wrap: wrap;
		border-top: 1px solid rgba(0,0,0,0.05);
	}
	& .raxo-top article:nth-child(2n) .raxo-wrap {
		flex-direction: row-reverse;
	}
	& .raxo-top .raxo-wrap > div {
		margin-left: -3px;
		flex: 1 1 320px;
		min-width: 192px;
	}

	/* --- NORMAL Items --- */
	& .raxo-normal {
		display: flex;
		flex-wrap: wrap;
		padding-top: 2px;

		& article { flex: 1 0 240px; }
	}


	/* ----- Item IMAGE ----- */
	& .raxo-image {
		margin: -3px;
		border-width: 3px !important;

		& img {
			display: block;
			width: 100%; max-width: 100%;
			height: auto;
			transition: opacity .3s ease-out;
			image-rendering: -webkit-optimize-contrast;
		}
	}
	& .raxo-normal .raxo-image {
		margin-bottom: 0;
	}
	& article:hover .raxo-image img {
		opacity: 0.85;
	}
	& .raxo-top .raxo-image img {
		height: 100%;
		object-fit: cover;
	}


	/* ----- Item CATEGORY ----- */
	& .raxo-category {
		position: absolute;
		left: -4px;
		top: var(--size-lg);
	}
	& .raxo-top article:nth-child(2n) .raxo-category {
		left: unset;
		right: -4px;
	}


	/* ----- Item CONTENT ----- */
	& .raxo-content {
		display: flex;
		flex-direction: column;
		column-gap: .5em;
		padding: var(--size-md) clamp(16px, 10%, var(--size-lg));
		overflow: hidden;

		& > :first-child { margin-top: 0; }
	}

	& .raxo-title {
		margin: 8px 0;
		font-size: clamp(16px, 1.3cqi, 20px);
		line-height: 1.25;
		font-weight: bold;
		text-transform: none;

		& a { color: var(--raxo-text-deep); }
	}
	& .raxo-top .raxo-title {
		font-size: clamp(20px, 2.8cqi, 28px);
		line-height: 1.15;
	}

	& .raxo-text {
		margin-top: 18px;
		color: var(--raxo-text-base);

		& a:hover { text-decoration: underline; }
	}


	/* ----- Item FIELDS ----- */
	& .raxo-info,
	& .raxo-meta {
		display: flex;
		flex-wrap: wrap;
		gap: .25em 1em;
		color: var(--raxo-text-muted);
	}
	& .raxo-normal .raxo-meta {
		padding: var(--spacing-base) clamp(16px, 10%, var(--size-lg));
		background-color: var(--raxo-gray-120);
		border-top: 1px solid var(--raxo-gray-200);
	}
	& .raxo-meta span {
		display: flex;
		align-items: center;
		font-size: .93em;
		line-height: 1.2;
	}
	& .raxo-meta svg {
		width: var(--icon-size);
		height: var(--icon-size);
		margin-right: 4px;
		fill: currentColor;
	}


	/* --- Item READMORE --- */
	& .raxo-top .raxo-readmore {
		align-self: flex-start;
		margin-top: 24px;

		& a { padding: 8px 16px; }
	}
	& .raxo-normal .raxo-readmore {
		margin-left: auto;
	}


	/* ----- BUTTON Styles ----- */
	& .raxo-btn {
		padding: 2px 12px;
		font-size: .93em;
		color: var(--raxo-gray-100);
		background-color: var(--raxo-theme-color);
		border-radius: 2px;
		transition: opacity .25s ease-out;

		& a {
			display: inline-block;
			margin: -2px -12px;
			padding: 2px 12px;
			color: inherit;
			text-decoration: none;
		}
		&:has(a):hover { opacity: 0.75; }
	}
}


/* ----- COLOR Schemes ----- */
.raxo-bricks {
	/* --- LIGHT Color Mode (default) --- */
	--raxo-color-base: oklch(0.48 0.19 267.8);
	--raxo-theme-color: var(--raxo-color-base);

	--raxo-gray-100: hsl(232, 1%, 98%);
	--raxo-gray-120: hsl(232, 1%, 96%);
	--raxo-gray-200: hsl(232, 2%, 88%);
	--raxo-gray-300: hsl(232, 3%, 69%);
	--raxo-gray-400: hsl(232, 4%, 45%);
	--raxo-gray-500: hsl(232, 5%, 30%);
	--raxo-gray-600: hsl(232, 5%, 22%);
	--raxo-gray-900: hsl(232, 7%,  6%);

	--raxo-text-deep:  var(--raxo-gray-900);
	--raxo-text-base:  var(--raxo-gray-500);
	--raxo-text-muted: var(--raxo-gray-400);
	--raxo-text-light: var(--raxo-gray-300);

	--raxo-shadow-light: hsla(232, 5%, 30%, 0.3);

	/* --- DARK Color Mode --- */
	&.dark-mode, &.mode-dark {
		--raxo-theme-color: oklch(
			from var(--raxo-color-base) calc(l * 1.1) calc(c * 0.8) h
		);

		--raxo-gray-100: hsl(232, 8%,  5%);
		--raxo-gray-120: hsl(232, 8%,  8%);
		--raxo-gray-200: hsl(232, 6%, 16%);
		--raxo-gray-300: hsl(232, 5%, 29%);
		--raxo-gray-400: hsl(232, 3%, 51%);
		--raxo-gray-500: hsl(232, 2%, 66%);
		--raxo-gray-600: hsl(232, 2%, 73%);
		--raxo-gray-900: hsl(232, 1%, 87%);

		--raxo-shadow-light: hsla(232, 2%, 66%, 0.3);
	}

	/* --- COLOR Palette --- */
	/* Backwards compatibility with previous module classes: bricks-colorname */
	&.color-red,    &.bricks-red		{ --raxo-color-base: oklch(0.53 0.19 28.82); }
	&.color-pink,   &.bricks-pink		{ --raxo-color-base: oklch(0.58 0.19 354.7); }
	&.color-orange, &.bricks-orange		{ --raxo-color-base: oklch(0.61 0.18 45.23); }
	&.color-yellow, &.bricks-yellow		{ --raxo-color-base: oklch(0.82 0.17 94.64); }
	&.color-brown						{ --raxo-color-base: oklch(0.44 0.05 39.62); }
	&.color-green,  &.bricks-green		{ --raxo-color-base: oklch(0.54 0.17 140.3); }
	&.color-teal,   &.bricks-turquoise	{ --raxo-color-base: oklch(0.58 0.11 186.8); }
	&.color-blue,   &.bricks-blue		{ --raxo-color-base: oklch(0.48 0.18 259.4); }
	&.color-sky,    &.bricks-lightblue	{ --raxo-color-base: oklch(0.62 0.15 243.2); }
	&.color-violet, &.bricks-violet		{ --raxo-color-base: oklch(0.48 0.19 287.4); }
	&.color-purple						{ --raxo-color-base: oklch(0.48 0.19 303.4); }
	&.color-gray,   &.bricks-gray		{ --raxo-color-base: oklch(0.38 0.0186 254); }

	/* --- COLOR Tuning --- */
	& :where(.raxo-block-name, .raxo-title, .raxo-text) a:hover {
		color: var(--raxo-theme-color);
	}
}