/* ==========================================================================
   Croc'Color – base.css
   Variables, reset léger, typographie globale.
   Palette « Cahier Doux » : crème + orange chaud.
   ========================================================================== */

:root {
	/* Couleurs principales */
	--color-cream:        #FDF6E8;
	--color-cream-soft:   #FBF1DC;
	--color-cream-dark:   #F3E5C9;
	--color-paper:        #FFFCF5;

	--color-orange:       #F4A261;
	--color-orange-deep:  #E76F51;
	--color-orange-soft:  #FFC79A;
	--color-coral:        #FF8C61;
	--color-mustard:      #E9B44C;

	--color-text:         #3D3027;
	--color-text-soft:    #6B5D4F;
	--color-text-mute:    #9C8B7A;
	--color-line:         #EAD9BD;
	--color-line-soft:    #F2E5CC;

	--color-white:        #FFFFFF;
	--color-black:        #1F1812;

	--color-success:      #6FAE7A;
	--color-error:        #D26565;

	/* Typographie */
	--font-display: "Baloo 2", "Comic Sans MS", "Trebuchet MS", system-ui, sans-serif;
	--font-body:    "Nunito", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;

	--fs-base: 1rem;       /* 16px */
	--fs-sm:   0.875rem;   /* 14px */
	--fs-xs:   0.75rem;    /* 12px */
	--fs-lg:   1.125rem;   /* 18px */
	--fs-xl:   1.375rem;   /* 22px */
	--fs-2xl:  1.75rem;    /* 28px */
	--fs-3xl:  2.25rem;    /* 36px */
	--fs-4xl:  2.875rem;   /* 46px */
	--fs-5xl:  3.5rem;     /* 56px */

	--lh-tight:  1.15;
	--lh-snug:   1.3;
	--lh-normal: 1.55;
	--lh-loose:  1.75;

	/* Rayons / ombres */
	--radius-xs: 6px;
	--radius-sm: 10px;
	--radius-md: 16px;
	--radius-lg: 24px;
	--radius-xl: 36px;
	--radius-pill: 999px;

	--shadow-soft:  0 6px 18px rgba(231, 111, 81, 0.08);
	--shadow-card:  0 12px 28px rgba(61, 48, 39, 0.08);
	--shadow-hover: 0 20px 40px rgba(231, 111, 81, 0.18);

	/* Espacements (échelle 4px) */
	--sp-1:  0.25rem;
	--sp-2:  0.5rem;
	--sp-3:  0.75rem;
	--sp-4:  1rem;
	--sp-5:  1.25rem;
	--sp-6:  1.5rem;
	--sp-8:  2rem;
	--sp-10: 2.5rem;
	--sp-12: 3rem;
	--sp-16: 4rem;
	--sp-20: 5rem;
	--sp-24: 6rem;

	/* Layout */
	--container-max: 1200px;
	--container-pad: clamp(1rem, 4vw, 2rem);

	/* Transitions */
	--ease: cubic-bezier(0.4, 0, 0.2, 1);
	--t-fast: 150ms var(--ease);
	--t-base: 250ms var(--ease);
	--t-slow: 400ms var(--ease);
}

/* Reset léger */
*, *::before, *::after { box-sizing: border-box; }

html {
	-webkit-text-size-adjust: 100%;
	scroll-behavior: smooth;
}

body {
	margin: 0;
	background-color: var(--color-cream);
	color: var(--color-text);
	font-family: var(--font-body);
	font-size: var(--fs-base);
	line-height: var(--lh-normal);
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
	background-image:
		radial-gradient(circle at 20% 12%, rgba(255, 199, 154, 0.18), transparent 38%),
		radial-gradient(circle at 85% 80%, rgba(255, 140, 97, 0.10), transparent 42%);
	background-attachment: fixed;
	min-height: 100vh;
}

img, svg, video, canvas, picture {
	max-width: 100%;
	height: auto;
	display: block;
}

a {
	color: var(--color-orange-deep);
	text-decoration: none;
	transition: color var(--t-fast);
}

a:hover, a:focus-visible {
	color: var(--color-coral);
}

button, input, select, textarea {
	font: inherit;
	color: inherit;
}

button {
	cursor: pointer;
	border: 0;
	background: none;
	padding: 0;
}

ul, ol {
	margin: 0;
	padding: 0;
	list-style: none;
}

p { margin: 0 0 var(--sp-4); }

h1, h2, h3, h4, h5, h6 {
	font-family: var(--font-display);
	font-weight: 700;
	color: var(--color-text);
	line-height: var(--lh-tight);
	margin: 0 0 var(--sp-3);
	letter-spacing: -0.01em;
}

h1 { font-size: clamp(2rem, 4vw, var(--fs-4xl)); font-weight: 800; }
h2 { font-size: clamp(1.6rem, 3vw, var(--fs-3xl)); }
h3 { font-size: var(--fs-2xl); }
h4 { font-size: var(--fs-xl); }
h5 { font-size: var(--fs-lg); }
h6 { font-size: var(--fs-base); text-transform: uppercase; letter-spacing: 0.06em; }

strong, b { font-weight: 700; }
em, i    { font-style: italic; }

small { font-size: var(--fs-sm); color: var(--color-text-soft); }

blockquote {
	margin: var(--sp-6) 0;
	padding: var(--sp-5) var(--sp-6);
	background: var(--color-cream-soft);
	border-left: 4px solid var(--color-orange);
	border-radius: var(--radius-md);
	font-family: var(--font-display);
	font-size: var(--fs-lg);
	color: var(--color-text);
}

code, pre, kbd, samp {
	font-family: ui-monospace, SFMono-Regular, "SF Mono", Consolas, monospace;
	font-size: 0.95em;
}

code {
	background: var(--color-cream-soft);
	padding: 0.1em 0.4em;
	border-radius: var(--radius-xs);
	color: var(--color-orange-deep);
}

pre {
	background: var(--color-cream-soft);
	padding: var(--sp-4);
	border-radius: var(--radius-md);
	overflow-x: auto;
}

hr {
	border: 0;
	border-top: 2px dashed var(--color-line);
	margin: var(--sp-8) 0;
}

table {
	width: 100%;
	border-collapse: collapse;
	margin-bottom: var(--sp-6);
}

th, td {
	padding: var(--sp-3) var(--sp-4);
	text-align: left;
	border-bottom: 1px solid var(--color-line);
}

th { background: var(--color-cream-soft); font-family: var(--font-display); }

/* Sélection */
::selection {
	background: var(--color-orange-soft);
	color: var(--color-text);
}

/* Focus accessible */
:focus-visible {
	outline: 3px solid var(--color-orange);
	outline-offset: 3px;
	border-radius: var(--radius-xs);
}

/* Skip link */
.skip-link {
	position: absolute;
	left: -9999px;
	top: 0;
	background: var(--color-text);
	color: var(--color-paper);
	padding: var(--sp-3) var(--sp-4);
	z-index: 9999;
	border-radius: 0 0 var(--radius-md) 0;
	font-weight: 700;
}

.skip-link:focus,
.skip-link:focus-visible {
	left: 0;
	color: var(--color-paper);
}

.screen-reader-text {
	border: 0;
	clip: rect(1px, 1px, 1px, 1px);
	clip-path: inset(50%);
	height: 1px;
	margin: -1px;
	overflow: hidden;
	padding: 0;
	position: absolute;
	width: 1px;
	word-wrap: normal !important;
}

/* Scrollbar */
@supports (scrollbar-color: auto) {
	body { scrollbar-color: var(--color-orange) var(--color-cream-soft); }
}

/* Préférences utilisateur */
@media (prefers-reduced-motion: reduce) {
	* {
		animation-duration: 0.01ms !important;
		animation-iteration-count: 1 !important;
		transition-duration: 0.01ms !important;
		scroll-behavior: auto !important;
	}
}
