/**
 * Brutalist Utilities
 * Utility classes for the Executive Brutalism design system.
 * Grid backgrounds, hard shadows, backdrop effects, layout helpers.
 */

/* ========================================
   HARD SHADOWS — BRUTAL OFFSET STYLE
   ======================================== */
.shadow-brutal {
	box-shadow: 4px 4px 0 var(--wp--preset--color--contrast);
}

.shadow-brutal-lg {
	box-shadow: 8px 8px 0 var(--wp--preset--color--contrast);
}

.shadow-brutal-pink {
	box-shadow: 4px 4px 0 var(--wp--preset--color--accent);
}

.shadow-brutal-cyan {
	box-shadow: 4px 4px 0 var(--wp--preset--color--accent-4);
}

.shadow-none {
	box-shadow: none;
}

/* ========================================
   GRID BACKGROUND PATTERNS
   ======================================== */
.bg-grid {
	background-image:
		linear-gradient(rgba(0, 0, 0, 0.05) 1px, transparent 1px),
		linear-gradient(90deg, rgba(0, 0, 0, 0.05) 1px, transparent 1px);
	background-size: 24px 24px;
}

.bg-grid-dense {
	background-image:
		linear-gradient(rgba(0, 0, 0, 0.05) 1px, transparent 1px),
		linear-gradient(90deg, rgba(0, 0, 0, 0.05) 1px, transparent 1px);
	background-size: 12px 12px;
}

.bg-grid-dark {
	background-image:
		linear-gradient(rgba(255, 255, 255, 0.05) 1px, transparent 1px),
		linear-gradient(90deg, rgba(255, 255, 255, 0.05) 1px, transparent 1px);
	background-size: 24px 24px;
}

.bg-dot-grid {
	background-image: radial-gradient(circle, rgba(0, 0, 0, 0.1) 1px, transparent 1px);
	background-size: 20px 20px;
}

/* ========================================
   DIAGONAL STRIPES (Legacy / "Old Way")
   ======================================== */
.bg-stripes {
	background-image: repeating-linear-gradient(
		45deg,
		transparent,
		transparent 10px,
		rgba(0, 0, 0, 0.03) 10px,
		rgba(0, 0, 0, 0.03) 20px
	);
}

/* ========================================
   BACKDROP BLUR
   ======================================== */
.backdrop-blur {
	backdrop-filter: blur(8px);
	-webkit-backdrop-filter: blur(8px);
}

.backdrop-blur-lg {
	backdrop-filter: blur(16px);
	-webkit-backdrop-filter: blur(16px);
}

/* ========================================
   LAYOUT HELPERS
   ======================================== */
.layout-sidebar {
	display: grid;
	grid-template-columns: 256px 1fr;
	min-height: 100vh;
}

.layout-sidebar-right {
	display: grid;
	grid-template-columns: 1fr 300px;
	min-height: 100vh;
}

.layout-split {
	display: grid;
	grid-template-columns: 1fr 1fr;
	min-height: 100vh;
}

.layout-asymmetric {
	display: grid;
	grid-template-columns: 2fr 1fr;
	gap: 0;
}

.layout-bento {
	display: grid;
	grid-template-columns: repeat(12, 1fr);
	gap: 0;
}

/* ========================================
   FULL BLEED / WIDE
   ======================================== */
.full-bleed {
	width: 100vw;
	position: relative;
	left: 50%;
	right: 50%;
	margin-left: -50vw;
	margin-right: -50vw;
}

/* ========================================
   ASPECT RATIO BOXES
   ======================================== */
.aspect-square {
	aspect-ratio: 1 / 1;
}

.aspect-video {
	aspect-ratio: 16 / 9;
}

.aspect-wide {
	aspect-ratio: 21 / 9;
}

/* ========================================
   RESPONSIVE GRID COLUMNS
   ======================================== */
.grid-cols-1 { grid-template-columns: repeat(1, 1fr); }
.grid-cols-2 { grid-template-columns: repeat(2, 1fr); }
.grid-cols-3 { grid-template-columns: repeat(3, 1fr); }
.grid-cols-4 { grid-template-columns: repeat(4, 1fr); }

@media (max-width: 1024px) {
	.layout-sidebar { grid-template-columns: 1fr; }
	.layout-sidebar-right { grid-template-columns: 1fr; }
	.layout-split { grid-template-columns: 1fr; }
	.layout-asymmetric { grid-template-columns: 1fr; }
	.grid-cols-4 { grid-template-columns: repeat(2, 1fr); }
	.grid-cols-3 { grid-template-columns: repeat(2, 1fr); }

	.brutal-sidebar {
		position: relative;
		width: 100%;
		min-height: auto;
		border-right: none;
		border-bottom: 4px solid var(--wp--preset--color--contrast);
	}
}

@media (max-width: 640px) {
	.grid-cols-4 { grid-template-columns: 1fr; }
	.grid-cols-3 { grid-template-columns: 1fr; }
	.grid-cols-2 { grid-template-columns: 1fr; }

	.brutal-header {
		height: 64px;
		padding: 0 1rem;
	}
}

/* ========================================
   OVERFLOW UTILITIES
   ======================================== */
.overflow-hidden { overflow: hidden; }
.overflow-x-auto { overflow-x: auto; }
.overflow-y-auto { overflow-y: auto; }

/* ========================================
   SVG DIAGRAM STYLES
   ======================================== */
.diagram-path {
	stroke: var(--wp--preset--color--contrast-3);
	stroke-width: 1;
	fill: none;
	stroke-dasharray: 4 4;
}

.diagram-path--active {
	stroke: var(--wp--preset--color--accent-4);
	stroke-width: 2;
	stroke-dasharray: none;
}

.diagram-node {
	fill: var(--wp--preset--color--base);
	stroke: var(--wp--preset--color--contrast);
	stroke-width: 4;
}

.diagram-node--active {
	fill: var(--wp--preset--color--accent);
	stroke: var(--wp--preset--color--contrast);
}

/* ========================================
   MINI BAR CHART
   ======================================== */
.mini-bar-chart {
	display: flex;
	align-items: flex-end;
	gap: 2px;
	height: 60px;
}

.mini-bar-chart__bar {
	flex: 1;
	background-color: var(--wp--preset--color--contrast);
	min-width: 4px;
	transition: background-color 0.15s;
}

.mini-bar-chart__bar:hover {
	background-color: var(--wp--preset--color--accent);
}

/* ========================================
   PRINT STYLES
   ======================================== */
@media print {
	.brutal-header,
	.brutal-sidebar,
	.brutal-fab,
	.marquee-ticker {
		display: none !important;
	}

	* {
		box-shadow: none !important;
		border-color: #000 !important;
	}
}
