/* ==========================
   RESET MODERNE UNIQUE
========================== */

*,
*::before,
*::after {
	margin: 0;
	padding: 0;
	box-sizing: border-box;
}

html {
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
	-webkit-text-size-adjust: 100%;
	height: 100%;
	word-wrap: break-word;
	overflow-y: scroll;
	overflow-x: hidden;
}

html,
body {
	height: 100%;
	height: 100dvh;
}

body {
	margin: 0;
	line-height: 1;
	font-family: Arial, sans-serif;
	overflow-x: hidden;
}

/* ==========================
   BASE ELEMENTS
========================== */

ol,
ul {
	list-style: none;
}

table {
	border-collapse: collapse;
	border-spacing: 0;
}

blockquote,
q {
	quotes: none;
}

blockquote::before,
blockquote::after,
q::before,
q::after {
	content: "";
}

a {
	color: inherit;
	text-decoration: none;
}

a:focus,
a:active,
a:focus-visible {
	outline: none;
}

img {
	display: block;
	width: 100%;
	max-width: 100%;
	object-fit: cover;
	cursor: pointer;
	will-change: transform;
}

/* ==========================
   FONT
========================== */

@font-face {
	font-family: "Source X";
	src: url("/fonts/source-x.woff2") format("woff2");
	font-weight: normal;
	font-style: normal;
}

/* ==========================
   HEADER
========================== */

.header-fixed {
	position: relative;
	width: 100%;
	background: #fff;
	z-index: 999;
}

.header-top {
	display: flex;
	justify-content: space-between;
	align-items: flex-start;
	padding: 32.5px 34.7px 4.46px;
}

.header-left,
.header-center,
.header-right {
	flex: 1;
	text-align: center;
}

@media (min-width: 768px) and (hover: hover) and (pointer: fine) {
	.header-fixed-right:hover {
		position: relative;
		transition: all 150ms ease;
		display: inline;
		text-decoration: none;
		background-image: linear-gradient(
			transparent calc(100% - 4px),
			currentColor calc(100% - 4px),
			currentColor calc(100% - 2px),
			transparent calc(100% - 2px)
		);
		background-position: 100% 100%;
		background-repeat: no-repeat;
		padding-bottom: 0.2em;
	}
}

@media (hover: hover) and (pointer: fine) {
	.header-fixed-right.nofocus:hover {
		background-image: none;
		text-decoration: none;
		padding-bottom: 0;
	}
}

.header-left {
	text-align: left;
}
.header-right {
	text-align: right;
}

.header-left a,
.header-center a,
.header-right a {
	display: inline-block;
	font-size: 18px;

	letter-spacing: 0.03em;
	line-height: 20.764px;
}

@media (max-width: 767px) {
	.header-center {
		text-align: left;
	}

	.header-right {
		display: none;
	}

	.header-actions.header-left {
		max-width: 114px;
	}

	.header-actions.header-left a {
		max-width: 114px;
	}
}

@media (hover: none), (pointer: coarse) {
	.header-center a:hover {
		background-image: none;
		text-decoration: none;
		padding-bottom: 0;
	}
}

@media (min-width: 1px) {
	.header-top {
		padding: 18px 13.334px 0px;
	}

	.o-grid__infos {
		padding: 16px 13.334px 48px;
	}

	.o-grid__cell {
		padding: 13.334px;
	}
}

@media (min-width: 900px) {
	.header-top {
		padding: 32.5px 34.7px 4.46px;
	}

	.o-grid__infos {
		padding: 32.5px 34.7px 48px;
	}

	.o-grid__cell {
		padding: 13.54px;
	}
}
/* ==========================
   GRID FLEX SYSTEM
========================== */

.container {
	width: 100%;
	min-height: 100dvh;
}

.o-grid {
	display: flex;
	flex-wrap: wrap;
	width: 100%;
}

.o-grid__cell {
	position: relative;
	flex-shrink: 0;
}

/* ==========================
   12 COLUMN GRID
========================== */

.col-1,
.col-h1,
.col-v1 {
	flex: 0 0 8.333%;
}
.col-2,
.col-h2,
.col-v2 {
	flex: 0 0 16.666%;
}
.col-3,
.col-h3,
.col-v3 {
	flex: 0 0 25%;
}
.col-4,
.col-h4,
.col-v4 {
	flex: 0 0 33.333%;
}
.col-5,
.col-h5,
.col-v5 {
	flex: 0 0 41.666%;
}
.col-6,
.col-h6,
.col-v6 {
	flex: 0 0 50%;
}
.col-7,
.col-h7,
.col-v7 {
	flex: 0 0 58.333%;
}
.col-8,
.col-h8,
.col-v8 {
	flex: 0 0 66.666%;
}
.col-9,
.col-h9,
.col-v9 {
	flex: 0 0 75%;
}
.col-10,
.col-h10,
.col-v10 {
	flex: 0 0 83.333%;
}
.col-11,
.col-h11,
.col-v11 {
	flex: 0 0 91.666%;
}
.col-12,
.col-h12,
.col-v12 {
	flex: 0 0 100%;
}

/* ==========================
   CLICK OVERLAY
========================== */

.click-overlay {
	position: absolute;
	inset: 0;
	cursor: pointer;
}

/* ==========================
   TYPO / CAPTIONS
========================== */

.article-inline__caption,
.type-specimen__caption {
	text-align: center;
	margin-top: 20px;
	font-size: 12.6879px;
	line-height: 1.38035;
	letter-spacing: 1px;
}

.type-specimen__block-content img {
	max-width: 99%;
}

/* ==========================
   PROJECT INFOS GRID
========================== */

.o-grid__infos {
	display: grid;
	grid-template-columns: repeat(4, minmax(0, 1fr));
	gap: 12.118px 36px;
	font-size: 12.6879px;
	line-height: 14.6255px;
	letter-spacing: 0.0204em;
}

@media (max-width: 1200px) {
	.o-grid__infos {
		grid-template-columns: repeat(3, 1fr);
	}
}

@media (max-width: 900px) {
	.o-grid__infos {
		grid-template-columns: repeat(2, 1fr);
	}
}

@media (max-width: 600px) {
	.o-grid__infos {
		grid-template-columns: 1fr;
	}
}

/* ==========================
   PROJECT STRUCTURE
========================== */

.project-line {
	display: flex;
	flex-direction: column;
	break-inside: avoid;
}

.project-text {
	opacity: 1;
}

.range {
	font-size: 8.88px;
	line-height: 1;
	letter-spacing: 0.02em;
	letter-spacing: 1px;
	vertical-align: super;
	white-space: nowrap;
}

/* ==========================
   PRINT
========================== */

@media print {
	.o-grid__infos {
		break-before: page;
	}

	.project-line,
	.o-grid__infos > div {
		break-inside: avoid;
	}

	.header-center {
		display: none;
	}
}
