/* ============================================
   BICOUCHE.FR — DESIGN SYSTEM
   Direction : Chantier premium
   Couleurs : blanc chaud + graphite + orange chantier + vert profond
   Typo : IBM Plex Serif (display) + IBM Plex Sans (body)
   ============================================ */

:root {
  /* COLOR PALETTE */
  --anthracite: #1c1c1c;
  --anthracite-soft: #252827;
  --anthracite-light: #353938;

  --orange: #f26522;
  --orange-dark: #d84f12;
  --orange-light: #ff8a43;
  --orange-soft: #ffe1d0;

  --cream: #f6f6f4;
  --cream-soft: #fbfaf7;
  --paper: #ffffff;

  --stone: #68706a;
  --stone-light: #c9d0c8;
  --stone-soft: #e5e7e3;

  --ink: #1c1c1c;
  --ink-soft: #363a38;
  --ink-muted: #606b64;

  --vert-kraft: #1f3d2e;
  --vert-soft: #dbe7df;
  --concrete: #eef1ee;
  --ochre: #b98b4b;

  /* TYPOGRAPHY */
  --font-display: 'IBM Plex Sans', system-ui, sans-serif;
  --font-body: 'IBM Plex Sans', system-ui, sans-serif;
  --font-mono: 'IBM Plex Mono', monospace;

  /* SPACING */
  --space-xs: 4px;
  --space-sm: 8px;
  --space-md: 16px;
  --space-lg: 24px;
  --space-xl: 40px;
  --space-2xl: 64px;
  --space-3xl: 96px;

  /* RADII — plus carrés que mondehors, plus technique */
  --r-sm: 2px;
  --r-md: 4px;
  --r-lg: 6px;
  --r-xl: 10px;

  /* SHADOWS — soft mais nettes */
  --shadow-sm: 0 1px 2px rgba(18, 22, 21, 0.06);
  --shadow-md: 0 8px 22px rgba(18, 22, 21, 0.08), 0 1px 2px rgba(18, 22, 21, 0.04);
  --shadow-lg: 0 18px 48px rgba(18, 22, 21, 0.12), 0 4px 10px rgba(18, 22, 21, 0.06);
  --shadow-orange: 0 10px 24px rgba(216, 111, 40, 0.24);
}

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

html {
  scroll-behavior: smooth;
  font-size: 16px;
}

body {
  font-family: var(--font-body);
  color: var(--ink);
  background: var(--cream);
  line-height: 1.6;
  font-weight: 400;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-rendering: optimizeLegibility;
}

/* ============================================
   TYPOGRAPHY
   ============================================ */

h1, h2, h3, h4, h5, h6 {
  font-family: var(--font-display);
  font-weight: 800;
  line-height: 1.05;
  letter-spacing: 0;
  color: var(--anthracite);
}

h1 {
  font-size: clamp(2.25rem, 5vw, 4rem);
  font-weight: 800;
  letter-spacing: 0;
}

h2 {
  font-size: clamp(1.75rem, 3.5vw, 2.5rem);
  font-weight: 800;
  letter-spacing: 0;
}

h3 {
  font-size: clamp(1.25rem, 2.2vw, 1.625rem);
  font-weight: 800;
}

h4 {
  font-size: 1.125rem;
  font-weight: 600;
  font-family: var(--font-body);
  letter-spacing: -0.005em;
  color: var(--anthracite);
}

p {
  font-size: 1.0625rem;
  line-height: 1.7;
  color: var(--ink-soft);
}

a {
  color: var(--orange-dark);
  text-decoration: none;
  transition: color 0.2s ease;
}
a:hover { color: var(--orange); }

/* Eyebrow — étiquette technique */
.eyebrow {
  display: inline-block;
  font-family: var(--font-mono);
  font-size: 0.75rem;
  font-weight: 500;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--orange-dark);
}

.eyebrow-stone { color: var(--stone); }
.eyebrow-green { color: var(--vert-kraft); }

.lede {
  font-size: clamp(1.125rem, 1.7vw, 1.3125rem);
  line-height: 1.55;
  color: var(--ink-soft);
  font-weight: 400;
}

.h-orange {
  color: var(--orange);
  font-style: italic;
  font-weight: 400;
}

strong { color: var(--anthracite); font-weight: 600; }

/* ============================================
   LAYOUT
   ============================================ */

.container {
  max-width: 1240px;
  margin: 0 auto;
  padding: 0 24px;
}

.container-narrow {
  max-width: 840px;
  margin: 0 auto;
  padding: 0 24px;
}

.container-wide {
  max-width: 1440px;
  margin: 0 auto;
  padding: 0 24px;
}

/* ============================================
   BUTTONS — plus carrés, plus techniques
   ============================================ */

.btn {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 13px 24px;
  font-family: var(--font-body);
  font-size: 0.9375rem;
  font-weight: 600;
  letter-spacing: -0.005em;
  text-decoration: none;
  border-radius: 4px;
  border: none;
  cursor: pointer;
  transition: all 0.2s cubic-bezier(0.4, 0, 0.2, 1);
  white-space: nowrap;
}

.btn-primary {
  background: var(--vert-kraft);
  color: var(--cream-soft);
  box-shadow: var(--shadow-md);
}
.btn-primary:hover {
  background: var(--anthracite);
  color: var(--paper);
  transform: translateY(-1px);
  box-shadow: var(--shadow-lg);
}

.btn-orange {
  background: var(--orange);
  color: var(--paper);
  box-shadow: 0 14px 28px rgba(242, 101, 34, 0.32);
}
.btn-orange:hover {
  background: var(--orange-dark);
  transform: translateY(-1px);
}

.btn-ghost {
  background: transparent;
  color: var(--anthracite);
  border: 1.5px solid rgba(18, 22, 21, 0.72);
}
.btn-ghost:hover {
  background: var(--vert-kraft);
  border-color: var(--vert-kraft);
  color: var(--cream-soft);
}

.btn-outline-orange {
  background: transparent;
  color: var(--orange-dark);
  border: 1.5px solid var(--orange);
}
.btn-outline-orange:hover {
  background: var(--orange);
  color: var(--paper);
}

.btn-large { padding: 17px 32px; font-size: 1rem; }
.btn-sm { padding: 9px 18px; font-size: 0.875rem; }

.btn-arrow::after {
  content: '→';
  font-family: var(--font-body);
  transition: transform 0.3s ease;
}
.btn-arrow:hover::after {
  transform: translateX(3px);
}

/* ============================================
   FORMS
   ============================================ */

.input,
input[type="text"],
input[type="email"],
input[type="tel"],
input[type="number"],
select,
textarea {
  width: 100%;
  padding: 12px 16px;
  font-family: var(--font-body);
  font-size: 0.9375rem;
  color: var(--ink);
  background: var(--paper);
  border: 1.5px solid var(--stone-light);
  border-radius: var(--r-md);
  transition: all 0.2s ease;
  font-weight: 400;
}

.input:focus,
input:focus,
select:focus,
textarea:focus {
  outline: none;
  border-color: var(--anthracite);
  background: var(--paper);
  box-shadow: 0 0 0 3px rgba(32, 59, 50, 0.12);
}

label {
  display: block;
  font-size: 0.8125rem;
  font-weight: 600;
  color: var(--ink-soft);
  margin-bottom: 7px;
  letter-spacing: 0.005em;
}

/* ============================================
   CARDS
   ============================================ */

.card {
  background: var(--paper);
  border: 1px solid var(--stone-light);
  border-radius: var(--r-lg);
  padding: 28px;
  transition: all 0.25s ease;
}

.card:hover {
  border-color: var(--anthracite);
  box-shadow: var(--shadow-md);
}

.card-dark {
  background: var(--anthracite);
  color: var(--cream);
}
.card-dark h3 { color: var(--cream-soft); }
.card-dark p { color: rgba(244, 241, 234, 0.78); }

/* ============================================
   BADGES
   ============================================ */

.badge {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 5px 10px;
  background: var(--cream-soft);
  border: 1px solid var(--stone-light);
  border-radius: var(--r-sm);
  font-family: var(--font-mono);
  font-size: 0.6875rem;
  font-weight: 500;
  color: var(--ink-soft);
  letter-spacing: 0.04em;
  text-transform: uppercase;
}

.badge-anthracite { background: var(--anthracite); color: var(--cream-soft); border-color: var(--anthracite); }
.badge-orange { background: var(--orange); color: var(--paper); border-color: var(--orange); }
.badge-vert { background: var(--vert-kraft); color: var(--cream-soft); border-color: var(--vert-kraft); }
.badge-dot::before {
  content: '';
  width: 5px;
  height: 5px;
  border-radius: 50%;
  background: currentColor;
  display: inline-block;
}

/* ============================================
   ANIMATIONS
   ============================================ */

@keyframes reveal-up {
  from { opacity: 0; transform: translateY(20px); }
  to { opacity: 1; transform: translateY(0); }
}

@keyframes reveal-in {
  from { opacity: 0; }
  to { opacity: 1; }
}

.reveal-up,
.reveal-stagger > * {
  opacity: 1;
  transform: none;
}

@media (prefers-reduced-motion: no-preference) {
  .reveal-up { animation: reveal-up 0.7s cubic-bezier(0.16, 1, 0.3, 1) both; }

  .reveal-stagger > * {
    animation: reveal-up 0.7s cubic-bezier(0.16, 1, 0.3, 1) both;
  }
  .reveal-stagger > *:nth-child(1) { animation-delay: 0.04s; }
  .reveal-stagger > *:nth-child(2) { animation-delay: 0.12s; }
  .reveal-stagger > *:nth-child(3) { animation-delay: 0.20s; }
  .reveal-stagger > *:nth-child(4) { animation-delay: 0.28s; }
  .reveal-stagger > *:nth-child(5) { animation-delay: 0.36s; }
}

/* ============================================
   UTILITIES
   ============================================ */

.text-center { text-align: center; }
.text-stone { color: var(--stone); }
.text-orange { color: var(--orange-dark); }
.text-anthracite { color: var(--anthracite); }

.mb-xs { margin-bottom: 4px; }
.mb-sm { margin-bottom: 8px; }
.mb-md { margin-bottom: 16px; }
.mb-lg { margin-bottom: 24px; }
.mb-xl { margin-bottom: 40px; }

.section-pad {
  padding: clamp(56px, 7vw, 100px) 0;
}

.section-pad-sm {
  padding: clamp(40px, 5vw, 72px) 0;
}

.grid-2 { display: grid; grid-template-columns: repeat(2, 1fr); gap: 24px; }
.grid-3 { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; }
.grid-4 { display: grid; grid-template-columns: repeat(4, 1fr); gap: 20px; }

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

/* ============================================
   ARTICLE CONTENT (pages SEO long-form)
   ============================================ */

.article-content {
  padding: 40px 0 80px;
  background: var(--cream);
}

.article-content .content-block {
  margin-bottom: 64px;
  scroll-margin-top: 100px;
}

.article-content .content-block:last-child { margin-bottom: 0; }

.article-content h2 {
  font-size: clamp(1.625rem, 3vw, 2.125rem);
  margin-bottom: 18px;
  position: relative;
  padding-top: 20px;
  border-top: 2px solid var(--anthracite);
}

.article-content h3 {
  font-family: var(--font-body);
  font-size: 1.1875rem;
  font-weight: 600;
  margin: 28px 0 12px;
  color: var(--anthracite);
  letter-spacing: -0.005em;
}

.article-content p {
  font-size: 1.0625rem;
  line-height: 1.75;
  color: var(--ink-soft);
  margin-bottom: 16px;
}

.article-content ul, .article-content ol {
  padding-left: 22px;
  margin: 14px 0 20px;
}

.article-content li {
  font-size: 1.0625rem;
  line-height: 1.7;
  color: var(--ink-soft);
  margin-bottom: 8px;
}

/* ============================================
   BREADCRUMB
   ============================================ */

.breadcrumb {
  display: flex;
  gap: 8px;
  align-items: center;
  font-family: var(--font-mono);
  font-size: 0.75rem;
  color: var(--stone);
  margin-bottom: 28px;
  flex-wrap: wrap;
  letter-spacing: 0.02em;
}

.breadcrumb a {
  color: var(--stone);
  text-decoration: none;
  transition: color 0.2s ease;
}
.breadcrumb a:hover { color: var(--orange-dark); }
.breadcrumb span:last-child { color: var(--anthracite); font-weight: 500; }
.breadcrumb .sep { opacity: 0.4; }

/* ============================================
   TABLES — important pour le contenu technique
   ============================================ */

.tech-table {
  width: 100%;
  background: var(--paper);
  border: 1px solid var(--stone-light);
  border-radius: var(--r-md);
  overflow: hidden;
  border-collapse: collapse;
  margin: 24px 0;
}

.tech-table th {
  background: var(--anthracite);
  color: var(--cream-soft);
  font-family: var(--font-mono);
  font-size: 0.75rem;
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  padding: 14px 18px;
  text-align: left;
  border-bottom: 1px solid var(--anthracite-light);
}

.tech-table td {
  padding: 14px 18px;
  border-bottom: 1px solid var(--stone-light);
  font-size: 0.9375rem;
  color: var(--ink-soft);
}

.tech-table tr:last-child td { border-bottom: none; }
.tech-table tr:hover td { background: var(--cream-soft); }

.tech-table td strong {
  color: var(--orange-dark);
  font-family: var(--font-mono);
  font-weight: 500;
}

/* ============================================
   KEY-VALUE / SPECS — encart technique
   ============================================ */

.specs {
  background: var(--anthracite);
  color: var(--cream-soft);
  border-radius: var(--r-md);
  padding: 24px 28px;
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
  gap: 24px;
  margin: 24px 0;
}

.specs > div {
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.specs-label {
  font-family: var(--font-mono);
  font-size: 0.6875rem;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--orange-light);
  font-weight: 500;
}

.specs-value {
  font-family: var(--font-display);
  font-size: 1.375rem;
  font-weight: 500;
  color: var(--cream-soft);
  letter-spacing: -0.01em;
}

.specs-unit {
  font-size: 0.8125rem;
  color: rgba(244, 241, 234, 0.6);
}

/* ============================================
   CALLOUT — encart attention/expert
   ============================================ */

.callout {
  background: var(--cream-soft);
  border-left: 3px solid var(--orange);
  padding: 20px 24px;
  border-radius: 0 var(--r-md) var(--r-md) 0;
  margin: 24px 0;
}

.callout-head {
  display: flex;
  align-items: center;
  gap: 10px;
  font-family: var(--font-mono);
  font-size: 0.75rem;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--orange-dark);
  font-weight: 600;
  margin-bottom: 8px;
}

.callout p {
  margin: 0;
  font-size: 0.9375rem;
  line-height: 1.65;
}

.callout-marc {
  background: var(--cream-soft);
  border-left: 3px solid var(--anthracite);
}
.callout-marc .callout-head { color: var(--anthracite); }

/* ============================================
   SEO PAGES WITH ILLUSTRATION
   ============================================ */

.page-hero-illustrated {
  padding: 56px 0 44px;
  background: var(--cream);
}

.hero-article-grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(280px, 380px);
  gap: clamp(28px, 5vw, 56px);
  align-items: center;
}

.hero-copy .lede {
  margin-top: 18px;
}

.hero-photo {
  position: relative;
  overflow: hidden;
  border-radius: var(--r-lg);
  border: 1px solid var(--stone-light);
  background: var(--paper);
  box-shadow: var(--shadow-md);
  aspect-ratio: 4 / 3;
}

.hero-photo img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.hero-photo figcaption {
  position: absolute;
  left: 14px;
  right: 14px;
  bottom: 14px;
  padding: 8px 10px;
  border-radius: var(--r-md);
  background: rgba(28, 28, 28, 0.82);
  color: var(--cream-soft);
  font-family: var(--font-mono);
  font-size: 0.6875rem;
  line-height: 1.45;
}

.article-meta {
  margin-top: 20px;
  font-family: var(--font-mono);
  font-size: 0.75rem;
  color: var(--stone);
  letter-spacing: 0.02em;
}

.article-meta strong {
  color: var(--anthracite);
  font-weight: 600;
}

.article-meta .sep {
  opacity: 0.4;
  margin: 0 8px;
}

.fact-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
  margin: 24px 0;
}

.fact-card,
.decision-card {
  background: var(--paper);
  border: 1px solid var(--stone-light);
  border-radius: var(--r-md);
  padding: 22px;
}

.fact-label {
  display: block;
  font-family: var(--font-mono);
  font-size: 0.6875rem;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--stone);
  margin-bottom: 8px;
}

.fact-value {
  display: block;
  font-size: 1.35rem;
  line-height: 1.2;
  font-weight: 800;
  color: var(--anthracite);
}

.decision-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 16px;
  margin: 24px 0;
}

.decision-card h3 {
  margin-top: 0;
}

.estimate-cta {
  background: var(--paper);
  border-radius: var(--r-lg);
  padding: 40px;
  border: 1px solid var(--stone-light);
  border-top: 4px solid var(--orange);
}

.estimate-cta h2 {
  border: none;
  padding-top: 0;
  margin: 8px 0 12px;
  font-size: 1.75rem;
}

.estimate-cta p {
  margin-bottom: 28px;
}

.cta-row {
  display: flex;
  align-items: center;
  gap: 12px;
  flex-wrap: wrap;
}

@media (max-width: 820px) {
  .hero-article-grid,
  .decision-grid {
    grid-template-columns: 1fr;
  }

  .hero-photo {
    max-width: 520px;
  }

  .fact-grid {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 640px) {
  .estimate-cta {
    padding: 28px 20px;
  }
}
.hdr[data-astro-cid-3ef6ksr2]{position:sticky;top:0;z-index:50;background:#151716;backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);border-bottom:1px solid rgba(255,255,255,0.08)}.hdr-inner[data-astro-cid-3ef6ksr2]{display:flex;align-items:center;justify-content:space-between;padding:18px 0;gap:22px}.hdr-logo[data-astro-cid-3ef6ksr2]{display:flex;align-items:center;gap:10px;text-decoration:none;color:var(--paper);flex-shrink:0}.logo-icon[data-astro-cid-3ef6ksr2]{width:32px;height:32px;display:inline-flex;align-items:center;justify-content:center;flex-shrink:0}.logo-icon[data-astro-cid-3ef6ksr2] svg[data-astro-cid-3ef6ksr2]{width:100%;height:100%;display:block}.logo-text[data-astro-cid-3ef6ksr2]{font-family:var(--font-body);font-size:1.25rem;font-weight:800;color:var(--paper);letter-spacing:-0.03em;line-height:1;text-transform:uppercase}.logo-word[data-astro-cid-3ef6ksr2]{color:var(--paper)}.logo-tld[data-astro-cid-3ef6ksr2]{color:var(--orange);font-weight:800}.hdr-nav[data-astro-cid-3ef6ksr2]{display:flex;align-items:center;gap:22px;flex:1;justify-content:center}.hdr-menu[data-astro-cid-3ef6ksr2]{position:relative;display:flex;align-items:center}.hdr-link[data-astro-cid-3ef6ksr2]{font-family:var(--font-body);font-size:0.8125rem;font-weight:700;color:rgba(255,255,255,0.76);text-decoration:none;transition:color 0.2s ease;position:relative;padding:7px 0}.hdr-menu-trigger[data-astro-cid-3ef6ksr2]{appearance:none;background:transparent;border:0;cursor:pointer}.hdr-menu-trigger[data-astro-cid-3ef6ksr2] span[data-astro-cid-3ef6ksr2]{display:inline-block;margin-left:4px;color:var(--orange-light);font-size:0.68rem;transform:translateY(-1px)}.hdr-link[data-astro-cid-3ef6ksr2]::after{content:"";position:absolute;bottom:-2px;left:0;width:100%;height:2px;background:var(--orange);transform:scaleX(0);transform-origin:left;transition:transform 0.3s ease}.hdr-link[data-astro-cid-3ef6ksr2]:hover{color:var(--paper)}.hdr-link[data-astro-cid-3ef6ksr2]:hover::after,.hdr-link[data-astro-cid-3ef6ksr2].active::after,.hdr-menu[data-astro-cid-3ef6ksr2].active>.hdr-link[data-astro-cid-3ef6ksr2]::after,.hdr-menu[data-astro-cid-3ef6ksr2]:hover>.hdr-link[data-astro-cid-3ef6ksr2]::after,.hdr-menu[data-astro-cid-3ef6ksr2]:focus-within>.hdr-link[data-astro-cid-3ef6ksr2]::after{transform:scaleX(1)}.hdr-link[data-astro-cid-3ef6ksr2].active,.hdr-menu[data-astro-cid-3ef6ksr2].active>.hdr-link[data-astro-cid-3ef6ksr2],.hdr-menu[data-astro-cid-3ef6ksr2]:hover>.hdr-link[data-astro-cid-3ef6ksr2],.hdr-menu[data-astro-cid-3ef6ksr2]:focus-within>.hdr-link[data-astro-cid-3ef6ksr2]{color:var(--paper);font-weight:800}.hdr-submenu[data-astro-cid-3ef6ksr2]{position:absolute;top:calc(100% + 16px);left:50%;width:280px;padding:10px;background:var(--paper);border:1px solid rgba(28,28,28,0.12);border-radius:var(--r-lg);box-shadow:var(--shadow-lg);opacity:0;visibility:hidden;pointer-events:none;transform:translate(-50%,8px);transition:opacity 0.18s ease,transform 0.18s ease,visibility 0.18s ease}.hdr-submenu[data-astro-cid-3ef6ksr2]::before{content:"";position:absolute;left:0;right:0;top:-18px;height:18px}.hdr-menu[data-astro-cid-3ef6ksr2]:hover .hdr-submenu[data-astro-cid-3ef6ksr2],.hdr-menu[data-astro-cid-3ef6ksr2]:focus-within .hdr-submenu[data-astro-cid-3ef6ksr2]{opacity:1;visibility:visible;pointer-events:auto;transform:translate(-50%,0)}.hdr-submenu[data-astro-cid-3ef6ksr2] a[data-astro-cid-3ef6ksr2]{display:block;padding:12px;border-radius:var(--r-md);color:var(--anthracite);text-decoration:none}.hdr-submenu[data-astro-cid-3ef6ksr2] a[data-astro-cid-3ef6ksr2]:hover{background:var(--cream);color:var(--anthracite)}.hdr-submenu[data-astro-cid-3ef6ksr2] strong[data-astro-cid-3ef6ksr2]{display:block;font-size:0.9rem;line-height:1.25;color:var(--anthracite)}.hdr-submenu[data-astro-cid-3ef6ksr2] span[data-astro-cid-3ef6ksr2]{display:block;margin-top:3px;font-size:0.78rem;line-height:1.35;color:var(--stone)}.hdr-cta[data-astro-cid-3ef6ksr2]{flex-shrink:0}.cta-arrow[data-astro-cid-3ef6ksr2]{transition:transform 0.3s ease}.hdr-cta[data-astro-cid-3ef6ksr2]:hover .cta-arrow[data-astro-cid-3ef6ksr2]{transform:translateX(3px)}.hdr-burger[data-astro-cid-3ef6ksr2]{display:none;background:none;border:none;cursor:pointer;padding:8px;flex-direction:column;gap:4px}.hdr-burger[data-astro-cid-3ef6ksr2] span[data-astro-cid-3ef6ksr2]{display:block;width:20px;height:2px;background:var(--paper);transition:all 0.3s ease}.hdr-mobile[data-astro-cid-3ef6ksr2]{display:none;flex-direction:column;gap:14px;padding:16px 0 20px;border-top:1px solid rgba(255,255,255,0.1)}.hdr-mobile[data-astro-cid-3ef6ksr2] a[data-astro-cid-3ef6ksr2]{color:var(--paper);font-size:1rem;font-weight:500;padding:6px 0}.hdr-mobile-group[data-astro-cid-3ef6ksr2]{display:flex;flex-direction:column;gap:7px;padding-bottom:12px;border-bottom:1px solid rgba(255,255,255,0.08)}.hdr-mobile-group[data-astro-cid-3ef6ksr2] span[data-astro-cid-3ef6ksr2]{font-family:var(--font-mono);font-size:0.7rem;text-transform:uppercase;letter-spacing:0.08em;color:var(--orange-light)}.hdr-mobile-group[data-astro-cid-3ef6ksr2] a[data-astro-cid-3ef6ksr2]{padding:2px 0;font-size:0.94rem;color:rgba(255,255,255,0.82)}.hdr-mobile[data-astro-cid-3ef6ksr2].open{display:flex}@media (max-width: 900px){.hdr-inner[data-astro-cid-3ef6ksr2]{gap:14px}.hdr-nav[data-astro-cid-3ef6ksr2]{gap:14px}.hdr-link[data-astro-cid-3ef6ksr2]{font-size:0.72rem}.hdr-submenu[data-astro-cid-3ef6ksr2]{width:250px}.logo-icon[data-astro-cid-3ef6ksr2]{width:30px;height:30px}.logo-text[data-astro-cid-3ef6ksr2]{font-size:1.05rem}.hdr-cta[data-astro-cid-3ef6ksr2]{padding:8px 12px;font-size:0.78rem}}@media (max-width: 820px){.hdr-nav[data-astro-cid-3ef6ksr2],.hdr-cta[data-astro-cid-3ef6ksr2]{display:none}.hdr-burger[data-astro-cid-3ef6ksr2]{display:flex}}.ftr[data-astro-cid-sz7xmlte]{background:#151716;color:var(--cream);padding:72px 0 28px;position:relative;overflow:hidden;border-top:4px solid var(--orange)}.ftr-top[data-astro-cid-sz7xmlte]{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr 1fr;gap:48px;margin-bottom:48px}.ftr-brand[data-astro-cid-sz7xmlte] .ftr-logo[data-astro-cid-sz7xmlte]{display:flex;align-items:center;gap:10px;margin-bottom:18px}.logo-icon[data-astro-cid-sz7xmlte]{width:32px;height:32px;display:inline-flex;align-items:center;justify-content:center;flex-shrink:0}.logo-icon[data-astro-cid-sz7xmlte] svg[data-astro-cid-sz7xmlte]{width:100%;height:100%;display:block}.logo-text[data-astro-cid-sz7xmlte]{font-family:var(--font-body);font-size:1.25rem;font-weight:800;color:var(--cream);letter-spacing:-0.03em;line-height:1;text-transform:uppercase}.logo-word[data-astro-cid-sz7xmlte]{color:var(--cream)}.logo-tld[data-astro-cid-sz7xmlte]{color:var(--orange);font-weight:800}.ftr-tag[data-astro-cid-sz7xmlte]{font-size:0.9375rem;color:rgba(250,249,245,0.72);line-height:1.6;max-width:320px;margin-bottom:18px}.ftr-badges[data-astro-cid-sz7xmlte]{display:flex;gap:8px;flex-wrap:wrap}.ftr-badges[data-astro-cid-sz7xmlte] .badge[data-astro-cid-sz7xmlte]{background:rgba(250,249,245,0.08);color:var(--cream);border-color:rgba(250,249,245,0.18)}.ftr-col[data-astro-cid-sz7xmlte]{display:flex;flex-direction:column;gap:10px}.ftr-col-title[data-astro-cid-sz7xmlte]{font-family:var(--font-mono);font-size:0.6875rem;font-weight:600;text-transform:uppercase;letter-spacing:0.12em;color:var(--orange-light);margin-bottom:8px}.ftr-col[data-astro-cid-sz7xmlte] a[data-astro-cid-sz7xmlte]{color:rgba(250,249,245,0.76);font-size:0.875rem;text-decoration:none;transition:color 0.2s ease}.ftr-col[data-astro-cid-sz7xmlte] a[data-astro-cid-sz7xmlte]:hover{color:var(--cream)}.ftr-divider[data-astro-cid-sz7xmlte]{height:1px;background:rgba(250,249,245,0.13);border:none;margin:0 0 24px}.ftr-bottom[data-astro-cid-sz7xmlte]{display:flex;justify-content:space-between;align-items:flex-start;gap:32px;flex-wrap:wrap}.ftr-copyright[data-astro-cid-sz7xmlte]{font-family:var(--font-mono);font-size:0.75rem;color:rgba(250,249,245,0.55);letter-spacing:0.02em}.ftr-disclaimer[data-astro-cid-sz7xmlte]{font-size:0.75rem;color:rgba(250,249,245,0.55);max-width:640px;line-height:1.5;text-align:right}@media (max-width: 1100px){.ftr-top[data-astro-cid-sz7xmlte]{grid-template-columns:1fr 1fr 1fr}.ftr-brand[data-astro-cid-sz7xmlte]{grid-column:1 / -1;max-width:480px}}@media (max-width: 700px){.ftr-top[data-astro-cid-sz7xmlte]{grid-template-columns:1fr 1fr}.ftr-bottom[data-astro-cid-sz7xmlte]{flex-direction:column}.ftr-disclaimer[data-astro-cid-sz7xmlte]{text-align:left}}@media (max-width: 460px){.ftr-top[data-astro-cid-sz7xmlte]{grid-template-columns:1fr}}