/* stevemota.dev — CV Steve Mota
   Esthétique Japandi : sable / encre / sienne · serif Playfair Display
   Layout inspiré de la référence (cv-html-mock), réinterprété light/clair. */

:root {
	/* Palette Japandi */
	--sand:        #F4F1EA;
	--sand-d:      #EAE5D8;
	--sand-m:      #DDD8CC;
	--sand-paper:  #FBFAF5;
	--ink:         #2E2D2A;
	--ink-m:       #4A4742;
	--ink-l:       #8A8478;
	--ink-dim:     #B4AE9F;
	--ink-g:       rgba(46,45,42,0.10);
	--ink-g2:      rgba(46,45,42,0.05);
	--sienna:      #A0522D;
	--sienna-d:    #8B4423;
	--sienna-soft: rgba(160,82,45,0.10);
	--green:       #4A7A5A;

	/* Typo */
	--font-ui:   'DM Sans', system-ui, sans-serif;
	--serif:     'Playfair Display', Georgia, serif;
	--mono:      'JetBrains Mono', ui-monospace, monospace;

	/* Form */
	--r:         14px;
	--r-sm:      9px;
	--sh:        0 1px 4px rgba(46,45,42,0.06);
	--sh-m:      0 8px 28px rgba(46,45,42,0.08);
}

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; }
body {
	min-height: 100dvh;
	background: var(--sand);
	color: var(--ink);
	font-family: var(--font-ui);
	font-weight: 400;
	font-size: 15px;
	line-height: 1.7;
	-webkit-font-smoothing: antialiased;
	overflow-x: hidden;
}

a {
	color: var(--sienna);
	text-decoration: none;
	border-bottom: 1px solid transparent;
	transition: color .2s, border-color .2s;
}
a:hover { color: var(--sienna-d); border-bottom-color: var(--sienna-d); }
:focus-visible { outline: 2px solid var(--sienna); outline-offset: 3px; border-radius: 3px; }

/* ============================================================
   NAV
============================================================ */
.nav {
	position: fixed;
	top: 0; left: 0; right: 0;
	z-index: 200;
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 1.5rem;
	padding: 1rem 3.5rem;
	background: rgba(244,241,234,0.82);
	backdrop-filter: saturate(140%) blur(14px);
	-webkit-backdrop-filter: saturate(140%) blur(14px);
	border-bottom: 1px solid var(--ink-g);
}
.nav-logo {
	font-family: var(--mono);
	font-size: .68rem;
	letter-spacing: .22em;
	color: var(--sienna);
	text-transform: uppercase;
	font-weight: 500;
	border-bottom: none;
}
.nav-logo:hover { color: var(--sienna-d); border-bottom-color: transparent; }
.nav-logo-sep { color: var(--ink-dim); margin: 0 .3em; }

.nav-links {
	display: flex;
	gap: 2.25rem;
	list-style: none;
}
.nav-links a {
	font-family: var(--mono);
	font-size: .68rem;
	font-weight: 400;
	letter-spacing: .14em;
	text-transform: uppercase;
	color: var(--ink-l);
	border-bottom: none;
	transition: color .2s;
}
.nav-links a:hover { color: var(--sienna); }

.lang-toggle {
	display: inline-flex;
	gap: 2px;
	padding: 3px;
	background: var(--sand-d);
	border: 1px solid var(--ink-g);
	border-radius: 999px;
}
.lang-btn {
	font-family: var(--mono);
	font-size: .62rem;
	font-weight: 500;
	letter-spacing: .14em;
	color: var(--ink-l);
	background: transparent;
	border: none;
	padding: .35rem .65rem;
	border-radius: 999px;
	cursor: pointer;
	transition: background .2s, color .2s;
	min-height: 32px;
	min-width: 36px;
}
.lang-btn:hover { color: var(--ink); }
.lang-btn.active {
	background: var(--sienna);
	color: #fff;
}

/* ============================================================
   HERO
============================================================ */
.hero {
	min-height: 100vh;
	display: flex;
	flex-direction: column;
	justify-content: flex-end;
	padding: 0 3.5rem 5rem;
	position: relative;
	border-bottom: 1px solid var(--ink-g);
	overflow: hidden;
}
.hero-bg {
	position: absolute;
	right: 1.5rem;
	bottom: -3rem;
	font-family: var(--serif);
	font-style: italic;
	font-weight: 500;
	font-size: 24vw;
	color: rgba(160,82,45,0.05);
	pointer-events: none;
	user-select: none;
	line-height: 1;
	white-space: nowrap;
}
.hero-eye {
	font-family: var(--mono);
	font-size: .68rem;
	font-weight: 500;
	letter-spacing: .22em;
	color: var(--sienna);
	text-transform: uppercase;
	margin-bottom: 1.25rem;
	animation: fadeUp .9s cubic-bezier(.16,1,.3,1) both;
}
.hero-name {
	font-family: var(--serif);
	font-size: clamp(4rem, 11vw, 9.5rem);
	font-weight: 500;
	line-height: .88;
	letter-spacing: -0.03em;
	color: var(--ink);
	animation: fadeUp .9s cubic-bezier(.16,1,.3,1) .12s both;
}
.hero-name em {
	font-style: italic;
	color: var(--sienna);
	font-weight: 500;
}
.hero-foot {
	display: flex;
	align-items: flex-end;
	justify-content: space-between;
	flex-wrap: wrap;
	gap: 2rem;
	margin-top: 2.5rem;
	animation: fadeUp .9s cubic-bezier(.16,1,.3,1) .26s both;
}
.hero-role {
	font-size: 1rem;
	color: var(--ink-m);
	border-left: 2px solid var(--sienna);
	padding-left: 1.1rem;
	max-width: 460px;
	line-height: 1.6;
}
.hero-role strong { color: var(--ink); font-weight: 600; }

.hero-meta {
	font-family: var(--mono);
	font-size: .68rem;
	color: var(--ink-l);
	letter-spacing: .08em;
	text-align: right;
	display: flex;
	flex-direction: column;
	gap: .3rem;
}
.hero-meta a { color: var(--ink-l); }
.hero-meta a:hover { color: var(--sienna); }

.hero-line {
	position: absolute;
	bottom: 0; left: 0; right: 0;
	height: 1px;
	background: linear-gradient(90deg, transparent 0%, var(--sienna) 40%, transparent 100%);
	opacity: .3;
}

/* ============================================================
   SECTIONS GÉNÉRIQUES
============================================================ */
.section {
	padding: 6rem 3.5rem;
	border-bottom: 1px solid var(--ink-g);
}

.sh {
	display: flex;
	align-items: baseline;
	gap: 1.25rem;
	margin-bottom: 3.5rem;
}
.sn {
	font-family: var(--mono);
	font-size: .65rem;
	color: var(--sienna);
	letter-spacing: .2em;
	white-space: nowrap;
	font-weight: 500;
}
.st {
	font-family: var(--serif);
	font-size: clamp(2rem, 4vw, 2.8rem);
	font-weight: 500;
	color: var(--ink);
	white-space: nowrap;
}
.sr {
	flex: 1;
	height: 1px;
	background: var(--ink-g);
	margin-left: .75rem;
}

/* ============================================================
   ABOUT
============================================================ */
.about-grid {
	display: grid;
	grid-template-columns: 3fr 2fr;
	gap: 5rem;
	align-items: start;
}
.about-bio {
	font-family: var(--serif);
	font-size: 1.35rem;
	font-weight: 400;
	line-height: 1.6;
	color: var(--ink);
}
.about-bio em {
	color: var(--sienna);
	font-style: italic;
}
.about-bio p + p { margin-top: 1rem; }

.drow {
	display: flex;
	justify-content: space-between;
	align-items: baseline;
	padding: .8rem 0;
	border-bottom: 1px solid var(--ink-g);
	gap: 1rem;
}
.dlbl {
	font-family: var(--mono);
	font-size: .62rem;
	letter-spacing: .14em;
	text-transform: uppercase;
	color: var(--ink-l);
	white-space: nowrap;
	font-weight: 500;
}
.dval {
	font-size: .85rem;
	color: var(--ink-m);
	text-align: right;
}
.dval a { color: var(--sienna); }

/* ============================================================
   EXPÉRIENCE — bloc Chiliz
============================================================ */
.cblock {
	background: var(--sand-paper);
	border: 1px solid var(--ink-g);
	border-radius: var(--r);
	margin-bottom: 3.5rem;
	position: relative;
	overflow: hidden;
	box-shadow: var(--sh);
}
.cblock::before {
	content: '';
	position: absolute;
	top: 0; left: 0; right: 0;
	height: 2px;
	background: linear-gradient(90deg, var(--sienna), transparent 70%);
}
.chdr {
	display: flex;
	align-items: baseline;
	justify-content: space-between;
	flex-wrap: wrap;
	gap: 1rem;
	padding: 1.75rem 2rem 1.25rem;
	border-bottom: 1px solid var(--ink-g);
}
.cname {
	font-family: var(--serif);
	font-size: 1.7rem;
	font-weight: 500;
	color: var(--ink);
}
.cdur {
	font-family: var(--mono);
	font-size: .65rem;
	color: var(--ink-l);
	letter-spacing: .12em;
}

.rlist { padding: 0 2rem; }
.ritem {
	display: grid;
	grid-template-columns: 175px 1fr;
	gap: 2.5rem;
	padding: 2rem 0;
	border-bottom: 1px solid var(--ink-g);
}
.ritem:last-child { border-bottom: none; }

.rperiod {
	font-family: var(--mono);
	font-size: .62rem;
	color: var(--sienna);
	letter-spacing: .12em;
	text-transform: uppercase;
	margin-bottom: .5rem;
	font-weight: 500;
}
.rbadge {
	display: inline-block;
	font-family: var(--mono);
	font-size: .58rem;
	letter-spacing: .12em;
	text-transform: uppercase;
	padding: .25rem .65rem;
	border: 1px solid var(--sienna);
	color: var(--sienna);
	background: var(--sienna-soft);
	border-radius: 3px;
	font-weight: 500;
}
.rtitle {
	font-family: var(--serif);
	font-size: 1.5rem;
	font-weight: 500;
	color: var(--ink);
	margin-bottom: .7rem;
	line-height: 1.2;
}
.rdesc {
	font-size: .88rem;
	color: var(--ink-m);
	line-height: 1.75;
	margin-bottom: 1.1rem;
}
.rdesc strong { color: var(--ink); font-weight: 600; }

.tags {
	display: flex;
	flex-wrap: wrap;
	gap: .4rem;
}
.tag {
	font-family: var(--mono);
	font-size: .6rem;
	font-weight: 500;
	letter-spacing: .1em;
	text-transform: uppercase;
	padding: .3rem .65rem;
	border: 1px solid var(--sienna);
	color: var(--sienna);
	background: rgba(160,82,45,0.04);
	border-radius: 3px;
}
.tag-soft {
	color: var(--ink-l);
	border-color: var(--ink-g);
	background: transparent;
}

/* expériences précédentes — liste minimaliste */
.prev {
	display: flex;
	flex-direction: column;
}
.pi {
	display: grid;
	grid-template-columns: 220px 1fr;
	gap: 2.5rem;
	padding: 2rem 0;
	border-bottom: 1px solid var(--ink-g);
	transition: background .2s;
	border-radius: 4px;
}
.pi:hover { background: var(--ink-g2); }
.pi:first-child { padding-top: 0; }
.pco {
	font-family: var(--mono);
	font-size: .65rem;
	color: var(--sienna);
	letter-spacing: .12em;
	text-transform: uppercase;
	margin-bottom: .4rem;
	font-weight: 500;
}
.pper { font-size: .76rem; color: var(--ink-l); }
.ptitle {
	font-family: var(--serif);
	font-size: 1.3rem;
	font-weight: 500;
	color: var(--ink);
	margin-bottom: .5rem;
	line-height: 1.25;
}
.pdesc {
	font-size: .85rem;
	color: var(--ink-m);
	line-height: 1.75;
}
.pdesc strong { color: var(--ink); font-weight: 600; }

/* ============================================================
   SKILLS
============================================================ */
.swrap {
	display: grid;
	grid-template-columns: 3fr 2fr;
	gap: 5rem;
}
.scolt {
	font-family: var(--mono);
	font-size: .65rem;
	font-weight: 500;
	letter-spacing: .2em;
	text-transform: uppercase;
	color: var(--sienna);
	margin-bottom: 1.25rem;
	padding-bottom: .75rem;
	border-bottom: 1px solid var(--sienna-soft);
}
.srow {
	display: flex;
	justify-content: space-between;
	align-items: center;
	padding: .75rem 0;
	border-bottom: 1px solid var(--ink-g);
	font-size: .88rem;
	color: var(--ink-m);
	gap: 1rem;
}
.dots {
	display: inline-flex;
	gap: 4px;
	flex-shrink: 0;
}
.dot {
	width: 6px;
	height: 6px;
	border-radius: 50%;
	background: var(--ink-g);
	display: inline-block;
}
.dot.on { background: var(--sienna); }

/* ============================================================
   EDUCATION
============================================================ */
.egrid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
	gap: 1.5rem;
}
.ecard {
	background: var(--sand-paper);
	border: 1px solid var(--ink-g);
	border-radius: var(--r);
	padding: 1.75rem;
	position: relative;
	overflow: hidden;
	box-shadow: var(--sh);
}
.ecard::after {
	content: '';
	position: absolute;
	top: 0; left: 0; right: 0;
	height: 2px;
	background: linear-gradient(90deg, var(--sienna) 0%, transparent 60%);
}
.eyr {
	font-family: var(--mono);
	font-size: .65rem;
	color: var(--sienna);
	letter-spacing: .15em;
	margin-bottom: .6rem;
	font-weight: 500;
}
.edeg {
	font-family: var(--serif);
	font-size: 1.25rem;
	font-weight: 500;
	color: var(--ink);
	margin-bottom: .35rem;
	line-height: 1.3;
}
.esch { font-size: .8rem; color: var(--ink-l); }

/* ============================================================
   CONTACT
============================================================ */
.section-contact {
	background: var(--sand-d);
	border-bottom: none;
}
.cwrap {
	display: flex;
	align-items: center;
	justify-content: space-between;
	flex-wrap: wrap;
	gap: 3rem;
}
.ccta {
	font-family: var(--serif);
	font-size: clamp(2.2rem, 5vw, 4.2rem);
	font-weight: 500;
	line-height: 1.05;
	max-width: 540px;
	color: var(--ink);
}
.ccta em {
	color: var(--sienna);
	font-style: italic;
}
.clinks {
	display: flex;
	flex-direction: column;
	min-width: 320px;
}
.clnk {
	display: flex;
	align-items: center;
	justify-content: space-between;
	color: var(--ink);
	font-size: .9rem;
	letter-spacing: .02em;
	padding: 1rem 0;
	border-bottom: 1px solid var(--ink-g);
	transition: color .2s;
	gap: 1rem;
}
.clnk:hover { color: var(--sienna); border-bottom-color: var(--ink-g); }
.clnk-static { color: var(--ink-m); cursor: default; }
.clnk-static:hover { color: var(--ink-m); }
.clbl {
	font-family: var(--mono);
	font-size: .6rem;
	font-weight: 500;
	letter-spacing: .16em;
	text-transform: uppercase;
	color: var(--ink-l);
}
.cval { font-family: var(--mono); font-size: .82rem; }

/* ============================================================
   FOOTER
============================================================ */
.footer {
	padding: 1.5rem 3.5rem;
	display: flex;
	justify-content: space-between;
	align-items: center;
	gap: 1rem;
	background: var(--sand-d);
	border-top: 1px solid var(--ink-g);
}
.footer span {
	font-family: var(--mono);
	font-size: .65rem;
	color: var(--ink-l);
	letter-spacing: .1em;
}

/* ============================================================
   ANIMATIONS
============================================================ */
@keyframes fadeUp {
	from { opacity: 0; transform: translateY(28px); }
	to   { opacity: 1; transform: translateY(0); }
}
.reveal {
	opacity: 0;
	transform: translateY(18px);
	transition: opacity .7s ease, transform .7s ease;
}
.reveal.visible {
	opacity: 1;
	transform: translateY(0);
}

@media (prefers-reduced-motion: reduce) {
	html { scroll-behavior: auto; }
	*, *::before, *::after {
		animation-duration: 0.001s !important;
		transition-duration: 0.001s !important;
	}
	.reveal { opacity: 1; transform: none; }
}

/* ============================================================
   PRINT — CV PDF friendly
============================================================ */
@media print {
	:root {
		--sand: #fff;
		--sand-d: #f6f4ed;
		--sand-paper: #fff;
		--ink: #1a1a1a;
		--ink-m: #3a3a3a;
		--ink-l: #6b6b6b;
		--ink-g: rgba(0,0,0,0.12);
	}
	body { background: #fff; color: #1a1a1a; font-size: 11.5px; line-height: 1.55; }
	.nav, .lang-toggle, .hero-bg, .hero-line { display: none !important; }
	.hero { min-height: auto; padding: 2rem 1.5rem 1.5rem; border-bottom: 1px solid var(--ink-g); }
	.hero-name { font-size: 3.2rem; }
	.section { padding: 1.5rem 1.5rem; page-break-inside: avoid; }
	.cblock, .ecard { box-shadow: none; break-inside: avoid; }
	.ritem, .pi { break-inside: avoid; }
	.section-contact { background: #fff; }
	.footer { background: #fff; }
	.reveal { opacity: 1 !important; transform: none !important; }
	a { color: var(--sienna); }
}

/* ============================================================
   RESPONSIVE
============================================================ */
@media (max-width: 960px) {
	.nav { padding: .9rem 1.25rem; gap: .75rem; }
	.nav-links { display: none; }
	.hero, .section { padding-left: 1.5rem; padding-right: 1.5rem; }
	.hero { padding-bottom: 3rem; }
	.section { padding-top: 4rem; padding-bottom: 4rem; }
	.about-grid, .swrap { grid-template-columns: 1fr; gap: 2.5rem; }
	.ritem, .pi { grid-template-columns: 1fr; gap: .75rem; }
	.ritem-meta { display: flex; align-items: center; gap: .75rem; flex-wrap: wrap; }
	.ritem-meta .rperiod { margin-bottom: 0; }
	.hero-foot { flex-direction: column; align-items: flex-start; }
	.hero-meta { text-align: left; }
	.chdr { flex-direction: column; align-items: flex-start; }
	.cwrap { flex-direction: column; align-items: flex-start; }
	.clinks { width: 100%; min-width: 0; }
	.footer { flex-direction: column; gap: .5rem; padding: 1.5rem; text-align: center; }
	.rlist { padding: 0 1.5rem; }
	/* Empêche le lien LinkedIn long de déborder en mode mobile */
	.hero-meta a { word-break: break-all; overflow-wrap: anywhere; }
	/* Touch target nav links si jamais affichés en futur menu */
	.nav-links a { padding: .4rem 0; }
}

@media (max-width: 520px) {
	.nav { padding: .75rem 1rem; gap: .5rem; }
	.nav-logo { font-size: .62rem; }
	.lang-toggle { padding: 2px; }
	.lang-btn {
		padding: .5rem .8rem;
		font-size: .6rem;
		min-height: 38px;
		min-width: 44px;
	}
	.hero { padding: 0 1.25rem 2.5rem; }
	.hero-bg { font-size: 36vw; right: -1rem; }
	.hero-role { padding-left: .9rem; font-size: .95rem; }
	.hero-meta { font-size: .65rem; word-break: break-word; overflow-wrap: anywhere; }
	.section { padding: 3rem 1.25rem; }
	.sh { gap: .9rem; margin-bottom: 2.5rem; }
	.st { white-space: normal; }
	.about-bio { font-size: 1.15rem; }
	.drow { flex-wrap: wrap; gap: .25rem 1rem; }
	.dval { text-align: left; overflow-wrap: anywhere; }
	.cname { font-size: 1.45rem; }
	.rtitle, .ptitle { font-size: 1.2rem; }
	.rdesc, .pdesc { font-size: .92rem; line-height: 1.7; }
	.rlist { padding: 0 1.25rem; }
	.chdr { padding: 1.25rem 1.25rem 1rem; gap: .5rem; }
	.cdur { font-size: .62rem; line-height: 1.7; }
	.tag {
		font-size: .68rem;
		padding: .35rem .7rem;
		letter-spacing: .08em;
	}
	.srow { font-size: .92rem; gap: .75rem; }
	.ccta { font-size: 2rem; }
	.clnk { padding: 1rem 0; min-height: 56px; gap: .75rem; }
	.cval { font-size: .8rem; overflow-wrap: anywhere; }
	.clbl { font-size: .62rem; }
	.footer span { font-size: .6rem; }
}

/* Très petits écrans (iPhone SE 1ère gen ~320px) */
@media (max-width: 360px) {
	.hero, .section { padding-left: 1rem; padding-right: 1rem; }
	.rlist { padding: 0 1rem; }
	.chdr { padding: 1.25rem 1rem 1rem; }
	.hero-name { font-size: 3.5rem; }
	.ccta { font-size: 1.8rem; }
}

/* ============================================================
   DARK MODE — léger, palette japandi
============================================================ */
@media (prefers-color-scheme: dark) {
	:root {
		--sand:        #1A1815;
		--sand-d:      #221F1B;
		--sand-m:      #2E2A24;
		--sand-paper:  #211E1A;
		--ink:         #EAE5D8;
		--ink-m:       #C8C2B3;
		--ink-l:       #8A8478;
		--ink-dim:     #5C574E;
		--ink-g:       rgba(234,229,216,0.10);
		--ink-g2:      rgba(234,229,216,0.04);
		--sienna:      #D9986C;
		--sienna-d:    #E6AC85;
		--sienna-soft: rgba(217,152,108,0.12);
	}
	.nav { background: rgba(26,24,21,0.82); }
	.tag { background: rgba(217,152,108,0.06); }
	.rbadge { background: rgba(217,152,108,0.15); }
}
