/* ============================================================
   DESIGN TOKENS
   ============================================================ */
:root,
[data-theme='light'] {
  --color-bg: #f5f4f0;
  --color-surface: #fafaf8;
  --color-surface-2: #ffffff;
  --color-surface-offset: #eeece8;
  --color-border: #d6d3cc;
  --color-divider: #e0ddd8;
  --color-text: #252420;
  --color-text-muted: #78776f;
  --color-text-faint: #b8b6b1;
  --color-text-inverse: #f8f7f4;

  /* Terre / Stone palette — earth, gravel, minerals */
  --color-primary: #5c7a3e;           /* vert forêt – terrain, végétation */
  --color-primary-hover: #4a6330;
  --color-primary-active: #384c24;
  --color-primary-highlight: #dce8cf;
  --color-stone: #8a7560;             /* brun pierre – gravier calcaire */
  --color-stone-light: #c4b9a8;
  --color-stone-highlight: #f0ece6;

  --color-success: #437a22;
  --color-success-highlight: #d4dfcc;
  --color-warning: #96611a;
  --color-warning-highlight: #eddcca;
  --color-error: #9b2f2f;
  --color-error-highlight: #f0d4d4;

  --shadow-sm: 0 1px 3px rgba(37,36,32,0.06);
  --shadow-md: 0 4px 16px rgba(37,36,32,0.09);
  --shadow-lg: 0 12px 40px rgba(37,36,32,0.12);

  --radius-sm: 0.375rem;
  --radius-md: 0.5rem;
  --radius-lg: 0.875rem;
  --radius-xl: 1.25rem;
  --radius-full: 9999px;

  --transition: 180ms cubic-bezier(0.16, 1, 0.3, 1);

  --text-xs:   clamp(0.75rem, 0.7rem + 0.25vw, 0.875rem);
  --text-sm:   clamp(0.875rem, 0.8rem + 0.35vw, 1rem);
  --text-base: clamp(1rem, 0.95rem + 0.25vw, 1.125rem);
  --text-lg:   clamp(1.125rem, 1rem + 0.75vw, 1.5rem);
  --text-xl:   clamp(1.5rem, 1.2rem + 1.25vw, 2.25rem);
  --text-2xl:  clamp(2rem, 1.2rem + 2.5vw, 3.5rem);

  --font-display: 'DM Serif Display', Georgia, serif;
  --font-body: 'DM Sans', 'Helvetica Neue', sans-serif;

  --space-1: 0.25rem; --space-2: 0.5rem; --space-3: 0.75rem;
  --space-4: 1rem;    --space-5: 1.25rem;--space-6: 1.5rem;
  --space-8: 2rem;    --space-10:2.5rem; --space-12:3rem;
  --space-16:4rem;

  --content-narrow: 640px;
  --content-default: 980px;
  --content-wide: 1240px;
}

[data-theme='dark'] {
  --color-bg: #16160f;
  --color-surface: #1c1b14;
  --color-surface-2: #211f17;
  --color-surface-offset: #1a1912;
  --color-border: #38362c;
  --color-divider: #2b2921;
  --color-text: #ceccbf;
  --color-text-muted: #79776c;
  --color-text-faint: #58574e;
  --color-text-inverse: #29271e;
  --color-primary: #7aaa53;
  --color-primary-hover: #5c8c3a;
  --color-primary-active: #48712b;
  --color-primary-highlight: #2c3a21;
  --color-stone: #b8a48a;
  --color-stone-light: #7a6d5a;
  --color-stone-highlight: #2a261e;
  --color-success: #6daa45;
  --color-success-highlight: #2a3b22;
  --color-warning: #d08a3a;
  --color-warning-highlight: #3b2e18;
  --color-error: #d44b4b;
  --color-error-highlight: #3a1e1e;
  --shadow-sm: 0 1px 3px rgba(0,0,0,0.2);
  --shadow-md: 0 4px 16px rgba(0,0,0,0.3);
  --shadow-lg: 0 12px 40px rgba(0,0,0,0.4);
}

@media (prefers-color-scheme: dark) {
  :root:not([data-theme]) {
    --color-bg: #16160f; --color-surface: #1c1b14; --color-surface-2: #211f17;
    --color-surface-offset: #1a1912; --color-border: #38362c; --color-divider: #2b2921;
    --color-text: #ceccbf; --color-text-muted: #79776c; --color-text-faint: #58574e;
    --color-text-inverse: #29271e; --color-primary: #7aaa53; --color-primary-hover: #5c8c3a;
    --color-primary-active: #48712b; --color-primary-highlight: #2c3a21;
    --color-stone: #b8a48a; --color-stone-light: #7a6d5a; --color-stone-highlight: #2a261e;
    --color-success: #6daa45; --color-success-highlight: #2a3b22;
    --color-warning: #d08a3a; --color-warning-highlight: #3b2e18;
    --color-error: #d44b4b; --color-error-highlight: #3a1e1e;
    --shadow-sm: 0 1px 3px rgba(0,0,0,0.2); --shadow-md: 0 4px 16px rgba(0,0,0,0.3);
    --shadow-lg: 0 12px 40px rgba(0,0,0,0.4);
  }
}

/* ============================================================
   BASE RESET
   ============================================================ */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html {
  -webkit-text-size-adjust: none; text-size-adjust: none;
  -webkit-font-smoothing: antialiased; scroll-behavior: smooth;
}
body {
  min-height: 100dvh; line-height: 1.6;
  font-family: var(--font-body); font-size: var(--text-base);
  color: var(--color-text); background-color: var(--color-bg);
}
img, svg { display: block; max-width: 100%; height: auto; }
input, button, select { font: inherit; color: inherit; }
h1, h2, h3, h4 { text-wrap: balance; line-height: 1.2; font-family: var(--font-display); }
p, li { text-wrap: pretty; }
button { cursor: pointer; background: none; border: none; }
table { border-collapse: collapse; width: 100%; }
:focus-visible { outline: 2px solid var(--color-primary); outline-offset: 3px; border-radius: var(--radius-sm); }
::selection { background: color-mix(in oklab, var(--color-primary) 20%, transparent); }
a, button, input, select { transition: color var(--transition), background var(--transition), border-color var(--transition), box-shadow var(--transition); }
.hidden { display: none !important; }

/* ============================================================
   HEADER
   ============================================================ */
.site-header {
  position: sticky; top: 0; z-index: 100;
  background: var(--color-surface); border-bottom: 1px solid var(--color-divider);
  box-shadow: var(--shadow-sm);
}
.header-inner {
  max-width: var(--content-wide); margin: 0 auto;
  padding: var(--space-4) var(--space-6);
  display: flex; align-items: center; justify-content: space-between;
}
.logo { display: flex; align-items: center; gap: var(--space-3); }
.logo-text {
  font-family: var(--font-display); font-size: var(--text-lg);
  color: var(--color-text); letter-spacing: -0.01em;
}
.theme-toggle {
  width: 40px; height: 40px; border-radius: var(--radius-full);
  display: flex; align-items: center; justify-content: center;
  color: var(--color-text-muted); border: 1px solid var(--color-border);
}
.theme-toggle:hover { background: var(--color-surface-offset); color: var(--color-text); }

/* ============================================================
   MAIN LAYOUT
   ============================================================ */
.main-layout {
  max-width: var(--content-wide); margin: 0 auto;
  padding: var(--space-8) var(--space-6);
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-8);
  align-items: start;
}
@media (max-width: 900px) { .main-layout { grid-template-columns: 1fr; gap: var(--space-6); } }
@media (max-width: 600px) { .main-layout { padding: var(--space-6) var(--space-4); } }

/* ============================================================
   FORM PANEL
   ============================================================ */
.form-panel {
  background: var(--color-surface); border: 1px solid var(--color-border);
  border-radius: var(--radius-xl); padding: var(--space-8);
  box-shadow: var(--shadow-md);
}
.form-title {
  font-size: var(--text-xl); color: var(--color-text); margin-bottom: var(--space-2);
}
.form-subtitle { color: var(--color-text-muted); font-size: var(--text-sm); margin-bottom: var(--space-6); }

/* MODE TOGGLE */
.input-mode-toggle {
  display: flex; gap: var(--space-2); margin-bottom: var(--space-6);
  background: var(--color-surface-offset); padding: var(--space-1);
  border-radius: var(--radius-md); width: fit-content;
}
.mode-btn {
  padding: var(--space-2) var(--space-4); border-radius: var(--radius-sm);
  font-size: var(--text-sm); font-weight: 500; color: var(--color-text-muted);
}
.mode-btn.active {
  background: var(--color-surface-2); color: var(--color-text);
  box-shadow: var(--shadow-sm);
}
.mode-btn:hover:not(.active) { color: var(--color-text); }

/* INPUT BLOCKS */
.input-block { margin-bottom: var(--space-6); }
.field-label {
  display: flex; align-items: center; gap: var(--space-2);
  font-size: var(--text-sm); font-weight: 600; color: var(--color-text);
  margin-bottom: var(--space-2);
}
.field-label-sm { font-size: var(--text-xs); font-weight: 600; color: var(--color-text-muted); margin-bottom: var(--space-1); }
.unit-tag {
  font-size: var(--text-xs); font-weight: 500;
  background: var(--color-stone-highlight); color: var(--color-stone);
  padding: 2px 6px; border-radius: var(--radius-full);
}
.field-input {
  width: 100%; padding: var(--space-3) var(--space-4);
  border: 1.5px solid var(--color-border); border-radius: var(--radius-md);
  background: var(--color-surface-2); color: var(--color-text);
  font-size: var(--text-base); appearance: textfield;
  -moz-appearance: textfield;
}
.field-input::-webkit-outer-spin-button,
.field-input::-webkit-inner-spin-button { -webkit-appearance: none; margin: 0; }
.field-input:hover { border-color: var(--color-stone-light); }
.field-input:focus { border-color: var(--color-primary); outline: none; box-shadow: 0 0 0 3px var(--color-primary-highlight); }
.field-hint { font-size: var(--text-xs); color: var(--color-text-faint); margin-top: var(--space-2); display: block; }

.inline-fields { display: grid; grid-template-columns: 1fr 1fr; gap: var(--space-4); margin-bottom: var(--space-4); }
.computed-volume {
  margin-top: var(--space-3); padding: var(--space-3);
  background: var(--color-primary-highlight); border-radius: var(--radius-md);
  font-size: var(--text-sm); color: var(--color-primary);
}

/* INFO ICON + TOOLTIP */
.info-icon {
  display: inline-flex; align-items: center; justify-content: center;
  width: 16px; height: 16px; border-radius: var(--radius-full);
  background: var(--color-surface-offset); border: 1px solid var(--color-border);
  font-size: 10px; color: var(--color-text-muted); cursor: help;
  font-family: var(--font-body); font-weight: 700;
}
.info-tooltip {
  display: none; background: var(--color-text); color: var(--color-text-inverse);
  font-size: var(--text-xs); padding: var(--space-3) var(--space-4);
  border-radius: var(--radius-md); margin-top: var(--space-2);
  line-height: 1.5; max-width: 340px;
}
.info-icon:focus + .info-tooltip,
.info-icon:hover + .info-tooltip { display: block; }

/* GRAVEL CARDS */
.gravel-cards {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--space-3);
}
@media (max-width: 480px) { .gravel-cards { grid-template-columns: 1fr; } }
.gravel-card {
  padding: var(--space-4) var(--space-3); border-radius: var(--radius-lg);
  border: 2px solid var(--color-border); background: var(--color-surface-2);
  display: flex; flex-direction: column; align-items: center; gap: var(--space-2);
  text-align: center; cursor: pointer;
}
.gravel-card:hover { border-color: var(--color-stone-light); background: var(--color-stone-highlight); }
.gravel-card.active { border-color: var(--color-primary); background: var(--color-primary-highlight); }
.gravel-icon { font-size: 1.5rem; }
.gravel-name { font-size: var(--text-xs); font-weight: 600; color: var(--color-text); }
.gravel-density { font-size: var(--text-xs); color: var(--color-text-muted); }
.gravel-card.active .gravel-name { color: var(--color-primary); }

/* TOGGLE GROUP */
.toggle-group { display: flex; gap: var(--space-3); }
.toggle-btn {
  display: flex; align-items: center; gap: var(--space-2);
  padding: var(--space-3) var(--space-5); border-radius: var(--radius-md);
  border: 1.5px solid var(--color-border); background: var(--color-surface-2);
  font-size: var(--text-sm); font-weight: 500; color: var(--color-text-muted);
}
.toggle-btn:hover { border-color: var(--color-stone-light); color: var(--color-text); }
.toggle-btn.active { border-color: var(--color-primary); background: var(--color-primary-highlight); color: var(--color-primary); }
.badge {
  font-size: var(--text-xs); background: var(--color-warning-highlight);
  color: var(--color-warning); padding: 2px 6px; border-radius: var(--radius-full); font-weight: 600;
}

/* SLIDER */
.slider-row { display: flex; align-items: center; gap: var(--space-4); margin-top: var(--space-2); }
.range-input {
  -webkit-appearance: none; appearance: none;
  width: 100%; height: 6px; border-radius: var(--radius-full);
  background: var(--color-border); cursor: pointer;
}
.range-input::-webkit-slider-thumb {
  -webkit-appearance: none; appearance: none;
  width: 20px; height: 20px; border-radius: var(--radius-full);
  background: var(--color-primary); border: 3px solid var(--color-surface-2);
  box-shadow: var(--shadow-sm); cursor: pointer;
}
.range-input::-moz-range-thumb {
  width: 20px; height: 20px; border-radius: var(--radius-full);
  background: var(--color-primary); border: 3px solid var(--color-surface-2);
  box-shadow: var(--shadow-sm); cursor: pointer;
}
.slider-value {
  min-width: 42px; text-align: right; font-size: var(--text-sm);
  font-weight: 700; color: var(--color-primary);
}
.slider-labels {
  display: flex; justify-content: space-between;
  font-size: var(--text-xs); color: var(--color-text-faint);
  margin-top: var(--space-1);
}

/* PRICE ROW */
.price-row { display: grid; grid-template-columns: 1fr auto 1fr; gap: var(--space-3); align-items: end; }
.price-sep { font-size: var(--text-xs); color: var(--color-text-faint); padding-bottom: var(--space-3); text-align: center; }

/* BUTTONS */
.btn-calc {
  width: 100%; padding: var(--space-4);
  background: var(--color-primary); color: white;
  border-radius: var(--radius-lg); font-size: var(--text-base); font-weight: 600;
  letter-spacing: 0.02em; box-shadow: var(--shadow-sm);
  margin-top: var(--space-2);
}
.btn-calc:hover { background: var(--color-primary-hover); box-shadow: var(--shadow-md); }
.btn-calc:active { background: var(--color-primary-active); }

.btn-reset {
  width: 100%; padding: var(--space-3) var(--space-4);
  border: 1.5px solid var(--color-border); border-radius: var(--radius-md);
  font-size: var(--text-sm); color: var(--color-text-muted);
  margin-top: var(--space-6);
}
.btn-reset:hover { border-color: var(--color-primary); color: var(--color-primary); }

/* ============================================================
   RESULTS PANEL
   ============================================================ */
.results-panel {
  background: var(--color-surface); border: 1px solid var(--color-border);
  border-radius: var(--radius-xl); padding: var(--space-8);
  box-shadow: var(--shadow-md); min-height: 400px;
  display: flex; align-items: flex-start;
}
.results-placeholder {
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  gap: var(--space-4); text-align: center; color: var(--color-text-muted);
  font-size: var(--text-sm); width: 100%; padding: var(--space-12) var(--space-4);
}
.placeholder-icon { opacity: 0.5; }
.results-content { width: 100%; }

/* RESULT HEADLINE */
.result-headline {
  background: linear-gradient(135deg, var(--color-primary-highlight), var(--color-stone-highlight));
  border: 1px solid var(--color-primary-highlight);
  border-radius: var(--radius-lg); padding: var(--space-6);
  margin-bottom: var(--space-6); text-align: center;
}
.result-label { font-size: var(--text-xs); text-transform: uppercase; letter-spacing: 0.1em; color: var(--color-primary); font-weight: 600; margin-bottom: var(--space-2); }
.result-main { display: flex; align-items: baseline; justify-content: center; gap: var(--space-3); }
.result-value { font-family: var(--font-display); font-size: var(--text-2xl); color: var(--color-text); line-height: 1; }
.result-unit { font-size: var(--text-lg); color: var(--color-text-muted); }
.result-secondary { font-size: var(--text-sm); color: var(--color-text-muted); margin-top: var(--space-2); }
.result-range-note { font-size: var(--text-xs); color: var(--color-text-faint); margin-top: var(--space-1); }

/* COST BLOCK */
.cost-block {
  background: var(--color-surface-2); border: 1px solid var(--color-border);
  border-radius: var(--radius-lg); padding: var(--space-5);
  margin-bottom: var(--space-5);
}
.cost-title, .recap-title, .compare-title {
  font-size: var(--text-sm); font-weight: 700; color: var(--color-text);
  margin-bottom: var(--space-4); text-transform: uppercase; letter-spacing: 0.07em;
}
.cost-grid { display: grid; gap: var(--space-3); }
.cost-item {
  display: flex; justify-content: space-between; align-items: center;
  padding: var(--space-3) var(--space-4); border-radius: var(--radius-md);
  background: var(--color-surface-offset);
}
.cost-item-label { font-size: var(--text-sm); color: var(--color-text-muted); }
.cost-item-value { font-size: var(--text-base); font-weight: 700; color: var(--color-success); }

/* RECAP BLOCK */
.recap-block {
  background: var(--color-surface-2); border: 1px solid var(--color-border);
  border-radius: var(--radius-lg); padding: var(--space-5);
  margin-bottom: var(--space-5);
}
.recap-grid { display: grid; grid-template-columns: 1fr 1fr; gap: var(--space-2); }
.recap-item {
  display: flex; flex-direction: column; gap: 2px;
  padding: var(--space-3); background: var(--color-surface-offset);
  border-radius: var(--radius-md);
}
.recap-key { font-size: var(--text-xs); color: var(--color-text-muted); }
.recap-val { font-size: var(--text-sm); font-weight: 600; color: var(--color-text); }

/* COMPARE TABLE */
.compare-block {
  background: var(--color-surface-2); border: 1px solid var(--color-border);
  border-radius: var(--radius-lg); padding: var(--space-5);
}
.table-wrapper { overflow-x: auto; }
.compare-table {
  width: 100%; font-size: var(--text-xs);
}
.compare-table thead th {
  padding: var(--space-3) var(--space-4); text-align: left;
  background: var(--color-surface-offset); color: var(--color-text-muted);
  font-size: var(--text-xs); font-weight: 600; text-transform: uppercase;
  letter-spacing: 0.06em; white-space: nowrap;
}
.compare-table thead th:first-child { border-radius: var(--radius-sm) 0 0 var(--radius-sm); }
.compare-table thead th:last-child { border-radius: 0 var(--radius-sm) var(--radius-sm) 0; }
.compare-table tbody tr { border-bottom: 1px solid var(--color-divider); }
.compare-table tbody tr:last-child { border-bottom: none; }
.compare-table tbody td { padding: var(--space-3) var(--space-4); color: var(--color-text); vertical-align: middle; }
.compare-table tbody tr.active-row { background: var(--color-primary-highlight); }
.compare-table tbody tr.active-row td:first-child { font-weight: 700; color: var(--color-primary); }
.td-num { font-variant-numeric: tabular-nums; font-weight: 600; }

/* FOOTER */
.site-footer {
  text-align: center; padding: var(--space-8) var(--space-6);
  font-size: var(--text-xs); color: var(--color-text-faint);
  border-top: 1px solid var(--color-divider);
}
