:root {
  --color-primary: #186aa4;
  --color-accent: #f4a41d;
  --color-accent-pressed: #ec9d0a;
  --color-bg: #0c1b35;
  --color-bg-elevated: #122546;
  --color-gradient-light: #ffffff;
  --color-gradient-mid: #01b4fb;
  --color-text: #ffffff;
  --color-text-muted: #c1c1c1;
  --color-rg-banner: #dc2626;
  --color-border: rgba(255,255,255,0.12);
  --color-border-soft: rgba(255,255,255,0.08);

  --font-display: "Oswald", "Helvetica Neue", Arial, sans-serif;
  --font-body: "Source Sans 3", "Segoe UI", Arial, sans-serif;

  --fs-h1: 52px;
  --fs-h2: 32px;
  --fs-h3: 24px;
  --fs-h4: 19px;
  --fs-h5: 16px;
  --fs-h6: 14px;
  --fs-body: 17px;
  --fs-small: 14px;
  --fs-micro: 12px;

  --lh-tight: 1.15;
  --lh-normal: 1.55;
  --lh-loose: 1.7;
  --ls-tight: 0;
  --ls-normal: 0;
  --ls-wide: 0.02em;
  --fw-regular: 400;
  --fw-medium: 500;
  --fw-bold: 700;

  --space-2xs: 6px;
  --space-xs: 14px;
  --space-sm: 20px;
  --space-md: 32px;
  --space-lg: 48px;
  --space-xl: 72px;
  --space-2xl: 112px;
  --space-3xl: 160px;

  --container-narrow: 720px;
  --container-readable: 650px;
  --container-default: 980px;
  --container-wide: 1140px;
  --container-site: 1140px;
  --container-padding-mobile: 16px;
  --container-padding-tablet: 32px;
  --container-padding-desktop: 48px;

  --bp-sm: 540px;
  --bp-md: 880px;
  --bp-lg: 1120px;
  --bp-xl: 1440px;

  --radius-xs: 0;
  --radius-sm: 0;
  --radius-md: 0;
  --radius-lg: 0;
  --radius-pill: 0;
  --radius-circle: 50%;
  --shadow-xs: none;
  --shadow-sm: 0 1px 0 rgba(0,0,0,0.08);
  --shadow-md: 0 2px 0 rgba(0,0,0,0.12);
  --shadow-lg: 0 4px 0 rgba(0,0,0,0.16);
  --border-thin: 1px;
  --border-medium: 2px;
  --border-thick: 4px;

  --dur-fast: 120ms;
  --dur-base: 180ms;
  --dur-slow: 260ms;
  --ease-out: cubic-bezier(0.3, 0.7, 0.4, 1.0);
  --ease-in: cubic-bezier(0.6, 0.0, 0.7, 0.3);
  --ease-in-out: cubic-bezier(0.5, 0.0, 0.5, 1.0);
  --ease-spring: cubic-bezier(0.5, 0.0, 0.5, 1.0);
}

@media (max-width: 880px) {
  :root {
    --fs-h1: 30px;
    --fs-h2: 24px;
    --fs-h3: 20px;
    --fs-h4: 17px;
    --fs-h5: 15px;
    --fs-h6: 13px;
    --fs-body: 16px;
    --fs-small: 13px;
    --fs-micro: 11px;
  }
}

*, *::before, *::after { box-sizing: border-box; }
html, body { margin: 0; padding: 0; overflow-x: clip; }
body {
  background: var(--color-bg);
  color: var(--color-text);
  font-family: var(--font-body);
  font-size: var(--fs-body);
  line-height: var(--lh-normal);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}
img { max-width: 100%; height: auto; display: block; }
a { color: var(--color-accent); text-decoration: none; transition: color var(--dur-fast) var(--ease-out); }
a:hover { color: var(--color-accent-pressed); }
h1, h2, h3, h4, h5, h6 { font-family: var(--font-display); font-weight: var(--fw-bold); line-height: var(--lh-tight); margin: 0; }
h1 { font-size: var(--fs-h1); }
h2 { font-size: var(--fs-h2); }
h3 { font-size: var(--fs-h3); font-family: var(--font-body); font-weight: var(--fw-medium); font-style: italic; }
h4 { font-size: var(--fs-h4); font-family: var(--font-body); font-weight: var(--fw-medium); }
h5 { font-size: var(--fs-h5); font-family: var(--font-body); font-weight: var(--fw-medium); }
h6 { font-size: var(--fs-h6); font-family: var(--font-body); font-weight: var(--fw-medium); }
p { margin: 0 0 var(--space-sm); }
ul, ol { margin: 0 0 var(--space-sm); padding-left: var(--space-md); }
strong { font-weight: var(--fw-bold); color: var(--color-text); }
em { font-style: italic; }

.sr-only { position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px; overflow: hidden; clip: rect(0,0,0,0); white-space: nowrap; border: 0; }
.skip-link { position: absolute; top: -200px !important; left: 0; padding: var(--space-sm) var(--space-md); background: var(--color-accent); color: var(--color-bg); font-weight: var(--fw-bold); z-index: 200; }
.skip-link:focus { top: 0 !important; }
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after { animation-duration: 0.01ms !important; transition-duration: 0.01ms !important; }
}

/* ============== HEADER (HEAD-02 + NAV-03 + AUTH-LOGIN) ============== */
.desk-grand { background: var(--color-bg); border-bottom: var(--border-thin) solid var(--color-border-soft); position: static; }
.desk-grand-inner {
  max-width: calc(var(--container-site) + 2 * var(--container-padding-desktop));
  margin-inline: auto;
  padding: var(--space-md) var(--container-padding-desktop);
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-sm);
}
.desk-grand-top { display: flex; align-items: center; justify-content: center; width: 100%; position: relative; }
.desk-grand-logo { flex-shrink: 0; display: inline-block; }
.desk-grand-logo img { height: 88px; width: auto; flex-shrink: 0; display: block; }
.desk-grand-nav { display: flex; flex-direction: column; gap: var(--space-2xs); align-items: center; width: 100%; }
.desk-grand-nav-list { display: flex; flex-wrap: nowrap; gap: var(--space-md); list-style: none; margin: 0; padding: 0; align-items: center; justify-content: center; }
.desk-grand-nav-list--top { /* top row of nav items */ }
.desk-grand-nav-list--bottom { padding-top: var(--space-xs); border-top: 1px solid var(--color-border-soft); width: 100%; justify-content: center; }
.desk-grand-nav-item { display: inline-flex; align-items: center; }
.desk-grand-link {
  font-family: var(--font-body);
  font-weight: var(--fw-medium);
  font-size: var(--fs-small);
  letter-spacing: var(--ls-wide);
  text-transform: uppercase;
  color: var(--color-text);
  white-space: nowrap;
  padding-block: var(--space-2xs);
  transition: color var(--dur-fast) var(--ease-out);
}
.desk-grand-link:hover { color: var(--color-accent); }
.desk-grand-link[aria-current="page"] { color: var(--color-accent); }
.desk-grand-auth { display: inline-flex; align-items: center; margin-left: var(--space-md); }
.desk-grand-auth-btn {
  font-family: var(--font-body);
  font-weight: var(--fw-medium);
  font-size: var(--fs-small);
  letter-spacing: var(--ls-wide);
  text-transform: uppercase;
  background: transparent;
  border: 1px solid var(--color-text);
  color: var(--color-text);
  padding: var(--space-2xs) var(--space-lg);
  white-space: nowrap;
  flex-shrink: 0;
  transition: background var(--dur-fast) var(--ease-out), color var(--dur-fast) var(--ease-out);
}
.desk-grand-auth-btn:hover { background: var(--color-text); color: var(--color-bg); }
.desk-grand-toggle {
  display: none;
  background: transparent;
  border: 0;
  color: var(--color-text);
  padding: var(--space-2xs);
  font-size: 24px;
  cursor: pointer;
  margin-left: auto !important;
}
.desk-grand-toggle-bar { display: block; width: 26px; height: 2px; background: currentColor; margin: 5px 0; }

.desk-grand-mobile {
  display: none;
  position: fixed;
  inset: 0 40% 0 0;
  background: var(--color-bg);
  z-index: 120;
  padding: var(--space-xl) var(--space-md);
  flex-direction: column;
  gap: var(--space-sm);
  overflow-y: auto;
  border-right: var(--border-thin) solid var(--color-border);
}
.desk-grand-mobile.is-open { display: flex; }
.desk-grand-mobile-list { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: var(--space-sm); }
.desk-grand-mobile-link { font-size: var(--fs-h5); color: var(--color-text); text-transform: uppercase; letter-spacing: var(--ls-wide); }
.desk-grand-mobile-backdrop {
  display: none;
  position: fixed;
  inset: 0 0 0 60%;
  background: rgba(0,0,0,0.6);
  z-index: 115;
}
.desk-grand-mobile-backdrop.is-open { display: block; }

@media (max-width: 880px) {
  .desk-grand-inner { flex-direction: row; justify-content: space-between; padding: var(--space-sm) var(--container-padding-mobile); gap: var(--space-sm); }
  .desk-grand-top { width: auto; }
  .desk-grand-logo img { height: 60px; }
  .desk-grand-nav, .desk-grand-auth { display: none; }
  .desk-grand-toggle { display: inline-flex; flex-direction: column; align-items: center; justify-content: center; }
}

/* ============== BREADCRUMBS (BREAD-04) ============== */
.lozenge-bold { padding-block: var(--space-md); }
.lozenge-bold-inner {
  max-width: calc(var(--container-site) + 2 * var(--container-padding-desktop));
  margin-inline: auto;
  padding-inline: var(--container-padding-desktop);
}
.lozenge-bold-list { list-style: none; margin: 0; padding: 0; display: flex; flex-wrap: wrap; align-items: center; gap: 0; }
.lozenge-bold-item { display: inline-flex; align-items: baseline; }
.lozenge-bold-num { font-family: var(--font-display); font-weight: var(--fw-bold); font-size: var(--fs-h6); color: var(--color-accent); margin-right: var(--space-2xs); }
.lozenge-bold-link, .lozenge-bold-current { font-family: var(--font-body); font-size: var(--fs-small); text-transform: uppercase; letter-spacing: var(--ls-wide); }
.lozenge-bold-link { color: var(--color-text-muted); }
.lozenge-bold-link:hover { color: var(--color-text); }
.lozenge-bold-current { color: var(--color-text); }
.lozenge-bold-sep { color: rgba(255,255,255,0.4); margin-inline: var(--space-sm); }
@media (max-width: 880px) { .lozenge-bold-inner { padding-inline: var(--container-padding-mobile); } }

/* ============== HERO (HERO-06) ============== */
.parquet-raw { position: relative; overflow: hidden; padding-block: var(--space-lg);}
.parquet-raw-inner {
  max-width: calc(var(--container-site) + 2 * var(--container-padding-desktop));
  margin-inline: auto;
  padding-inline: var(--container-padding-desktop);
  min-height: 640px;
  display: flex;
  align-items: center;
  position: relative;
}
.parquet-raw-content { position: relative; z-index: 2; width: 50%; padding-right: var(--space-lg); }
.parquet-raw-eyebrow { display: inline-block; font-family: var(--font-display); font-weight: var(--fw-bold); font-size: var(--fs-small); text-transform: uppercase; letter-spacing: var(--ls-wide); color: var(--color-accent); margin-bottom: var(--space-sm); }
.parquet-raw-content h1 { color: var(--color-text); margin-bottom: var(--space-md); }
.parquet-raw-subtitle { font-size: var(--fs-h5); color: var(--color-text-muted); line-height: var(--lh-loose); max-width: 480px; margin-bottom: var(--space-lg); }
.parquet-raw-cta {
  display: inline-block;
  background: var(--color-accent);
  color: #1a1a1a;
  font-family: var(--font-body);
  font-weight: var(--fw-medium);
  font-size: var(--fs-body);
  letter-spacing: var(--ls-wide);
  padding: var(--space-sm) var(--space-2xl);
  text-transform: uppercase;
  transition: background var(--dur-fast) var(--ease-out), transform var(--dur-base) var(--ease-out);
}
.parquet-raw-cta:hover { background: var(--color-accent-pressed); color: #1a1a1a; transform: scale(1.02); }
.parquet-raw-figure {
  position: absolute;
  right: var(--container-padding-desktop);
  top: -40px;
  width: 60%;
  height: calc(100% + 80px);
  margin: 0;
  overflow: visible;
  transform: rotate(2deg);
  box-shadow: var(--shadow-lg);
  transition: transform var(--dur-slow) var(--ease-out);
}
.parquet-raw-figure img { width: 100%; height: 100%; object-fit: cover; display: block; }
.parquet-raw-figure:hover { transform: rotate(0deg) scale(1.02); }
@media (max-width: 880px) {
  .parquet-raw-inner { flex-direction: column; min-height: auto; padding-block: var(--space-md); padding-inline: var(--container-padding-mobile); }
  .parquet-raw-content { width: 100%; padding-right: 0; margin-bottom: var(--space-lg); }
  .parquet-raw-figure { position: static; width: 100%; height: auto; transform: none; box-shadow: var(--shadow-sm); }
  .parquet-raw-figure img { height: 240px; }
}

/* ============== PAGE-HEADER (PHEAD-07) ============== */
.chevron-pure { padding-block: var(--space-lg);}
.chevron-pure-inner {
  max-width: calc(var(--container-site) + 2 * var(--container-padding-desktop));
  margin-inline: auto;
  padding-inline: var(--container-padding-desktop);
  display: grid;
  grid-template-columns: 120px 1fr;
  gap: var(--space-lg);
}
.chevron-pure-number { font-family: var(--font-display); font-weight: var(--fw-bold); font-size: calc(var(--fs-h1) * 1.4); color: var(--color-accent); line-height: 1; align-self: start; }
.chevron-pure-title h1 { color: var(--color-text); margin-bottom: var(--space-sm); }
.chevron-pure-desc { font-size: var(--fs-body); color: var(--color-text-muted); line-height: var(--lh-loose); }
.chevron-pure-meta { font-size: var(--fs-small); color: var(--color-text-muted); margin-top: var(--space-sm); }
@media (max-width: 880px) {
  .chevron-pure { padding-block: var(--space-md); }
  .chevron-pure-inner { grid-template-columns: 1fr; gap: var(--space-sm); padding-inline: var(--container-padding-mobile); }
}

/* ============== PROSE (PROSE-08) ============== */
.blason-modern { padding-block: var(--space-lg);}
.blason-modern-inner {
  max-width: calc(var(--container-site) + 2 * var(--container-padding-desktop));
  margin-inline: auto;
  padding-inline: var(--container-padding-desktop);
}
.blason-modern h2 { color: var(--color-text); margin: 0 0 var(--space-md); padding-left: 0; }
.blason-modern h3 { color: var(--color-text); margin: var(--space-lg) 0 var(--space-sm); padding-left: var(--space-2xl); }
.blason-modern p, .blason-modern ul, .blason-modern ol { padding-left: var(--space-2xl); line-height: var(--lh-loose); color: var(--color-text-muted); margin-bottom: var(--space-md); }
.blason-modern p { font-size: var(--fs-body); }
.blason-modern ul, .blason-modern ol { padding-left: calc(var(--space-2xl) + var(--space-md)); }
.blason-modern a { color: var(--color-accent); text-decoration: underline; text-underline-offset: 3px; }
.blason-modern a:hover { color: var(--color-accent-pressed); }
.blason-modern figure { margin: var(--space-lg) 0; padding-left: var(--space-2xl); }
.blason-modern figure img { width: 100%; height: auto; }
.blason-modern figcaption { font-size: var(--fs-small); color: var(--color-text-muted); font-style: italic; margin-top: var(--space-2xs); }
@media (max-width: 880px) {
  .blason-modern { padding-block: var(--space-md); }
  .blason-modern-inner { padding-inline: var(--container-padding-mobile); }
  .blason-modern h3, .blason-modern p, .blason-modern ul, .blason-modern ol, .blason-modern figure { padding-left: var(--space-md); }
  .blason-modern ul, .blason-modern ol { padding-left: calc(var(--space-md) + var(--space-md)); }
}

/* ============== ITEMS-GRID (GRID-03) ============== */
.marque-plus { padding-block: var(--space-lg);}
.marque-plus-inner {
  max-width: calc(var(--container-site) + 2 * var(--container-padding-desktop));
  margin-inline: auto;
  padding-inline: var(--container-padding-desktop);
}
.marque-plus h2 { color: var(--color-text); margin-bottom: var(--space-lg); }
.marque-plus-grid { display: grid; grid-template-columns: 1fr 1fr; gap: var(--space-lg); }
.marque-plus-item {
  padding: var(--space-lg);
  background: var(--color-bg-elevated);
  border: 1px solid rgba(255,255,255,0.08);
  display: flex;
  flex-direction: column;
  gap: var(--space-sm);
}
.marque-plus-item h3 { font-family: var(--font-display); font-weight: var(--fw-bold); font-style: normal; font-size: var(--fs-h4); color: var(--color-text); }
.marque-plus-item p { font-size: var(--fs-body); line-height: var(--lh-normal); color: var(--color-text-muted); margin: 0; }
@media (min-width: 881px) {
  .marque-plus-grid > .marque-plus-item:nth-child(4n+1) { grid-column: span 1; }
  .marque-plus-grid { grid-template-columns: 3fr 2fr; }
  .marque-plus-grid > .marque-plus-item:nth-child(4n+3),
  .marque-plus-grid > .marque-plus-item:nth-child(4n+4) { /* row resets via auto-flow */ }
  .marque-plus-grid > .marque-plus-item:nth-child(4n+3) { grid-column: 1 / 2; }
  .marque-plus-grid > .marque-plus-item:nth-child(4n+4) { grid-column: 2 / 3; }
}
@media (max-width: 880px) {
  .marque-plus { padding-block: var(--space-md); }
  .marque-plus-inner { padding-inline: var(--container-padding-mobile); }
  .marque-plus-grid { grid-template-columns: 1fr; gap: var(--space-md); }
}

/* ============== FAQ (FAQ-01) ============== */
.porche-premium { padding-block: var(--space-lg);}
.porche-premium-inner {
  max-width: calc(var(--container-site) + 2 * var(--container-padding-desktop));
  margin-inline: auto;
  padding-inline: var(--container-padding-desktop);
}
.porche-premium h2 { color: var(--color-text); margin-bottom: var(--space-lg); }
.porche-premium-list { margin: 0; padding: 0; }
.porche-premium-item { border-bottom: 1px solid rgba(255,255,255,0.1); padding-block: var(--space-md); }
.porche-premium-item dt { margin: 0; padding: 0; }
.porche-premium-question {
  width: 100%;
  text-align: left;
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: var(--space-md);
  background: transparent;
  border: 0;
  padding: 0;
  cursor: pointer;
  font-size: var(--fs-h5);
  font-family: var(--font-body);
  font-weight: var(--fw-bold);
  color: var(--color-text);
  transition: color var(--dur-fast) var(--ease-out);
}
.porche-premium-question:hover { color: var(--color-accent); }
.porche-premium-question-text { flex: 1; text-align: left; }
.porche-premium-icon { font-size: 24px; color: var(--color-accent); line-height: 1; flex-shrink: 0; transition: transform var(--dur-base) var(--ease-out); }
.porche-premium-question[aria-expanded="true"] .porche-premium-icon { transform: rotate(45deg); }
.porche-premium-answer { margin: 0; padding-top: var(--space-sm); }
.porche-premium-answer p { font-size: var(--fs-body); line-height: var(--lh-loose); color: var(--color-text-muted); margin: 0; }
@media (max-width: 880px) {
  .porche-premium { padding-block: var(--space-md); }
  .porche-premium-inner { padding-inline: var(--container-padding-mobile); }
}

/* ============== REVIEWS (REV-09) ============== */
.corniche-modern { padding-block: var(--space-lg);}
.corniche-modern-inner {
  max-width: calc(var(--container-site) + 2 * var(--container-padding-desktop));
  margin-inline: auto;
  padding-inline: var(--container-padding-desktop);
}
.corniche-modern h2 { color: var(--color-text); margin-bottom: var(--space-xl); text-align: center; }
.corniche-modern-list { display: flex; flex-direction: column; gap: 0; }
.corniche-modern-item { padding-block: var(--space-lg);text-align: center; }
.corniche-modern-text { font-family: var(--font-display); font-style: italic; font-weight: var(--fw-medium); font-size: var(--fs-h3); line-height: var(--lh-tight); color: var(--color-text); max-width: 720px; margin: 0 auto var(--space-md); }
.corniche-modern-meta { display: flex; flex-direction: column; align-items: center; gap: var(--space-2xs); font-size: var(--fs-small); letter-spacing: var(--ls-wide); text-transform: uppercase; color: var(--color-text-muted); }
.corniche-modern-rating { color: var(--color-accent); }
.corniche-modern-divider { width: 80px; height: 1px; background: rgba(255,255,255,0.2); border: 0; margin: 0 auto; }
@media (max-width: 880px) {
  .corniche-modern { padding-block: var(--space-md); }
  .corniche-modern-inner { padding-inline: var(--container-padding-mobile); }
  .corniche-modern-item { padding-block: var(--space-md); }
}

/* ============== CTA-BLOCK (CTA-02) ============== */
.blason-grave { padding-block: var(--space-lg);}
.blason-grave-inner {
  max-width: calc(var(--container-site) + 2 * var(--container-padding-desktop));
  margin-inline: auto;
  padding-inline: var(--container-padding-desktop);
  text-align: center;
}
.blason-grave-heading { color: var(--color-text); margin-bottom: var(--space-md); }
.blason-grave-text { font-size: var(--fs-body); line-height: var(--lh-loose); color: var(--color-text-muted); max-width: 600px; margin: 0 auto var(--space-lg); }
.blason-grave-button {
  display: inline-block;
  height: 56px;
  line-height: 56px;
  padding-inline: var(--space-2xl);
  background: var(--color-accent);
  color: #1a1a1a;
  font-family: var(--font-body);
  font-weight: var(--fw-medium);
  font-size: var(--fs-body);
  letter-spacing: var(--ls-wide);
  text-transform: uppercase;
  transition: background var(--dur-fast) var(--ease-out), transform var(--dur-base) var(--ease-out);
}
.blason-grave-button:hover { background: var(--color-accent-pressed); color: #1a1a1a; transform: scale(1.02); }
@media (max-width: 880px) { .blason-grave-inner { padding-inline: var(--container-padding-mobile); } .blason-grave { padding-block: var(--space-md); } }

/* ============== INLINE-CTA (INLINE-CTA-03) ============== */
.coupole-raw { padding-block: var(--space-md); }
.coupole-raw-inner {
  max-width: calc(var(--container-site) + 2 * var(--container-padding-desktop));
  margin-inline: auto;
  padding-inline: var(--container-padding-desktop);
  text-align: center;
}
.coupole-raw-line { font-size: var(--fs-h6); line-height: var(--lh-normal); color: var(--color-text); margin: 0; }
.coupole-raw-line strong { color: var(--color-text); font-weight: var(--fw-bold); }
.coupole-raw-link { color: var(--color-accent); text-decoration: underline; text-underline-offset: 3px; text-decoration-thickness: 1px; }
.coupole-raw-link:hover { color: var(--color-accent-pressed); text-decoration-thickness: 2px; }
@media (max-width: 880px) { .coupole-raw-inner { padding-inline: var(--container-padding-mobile); } }

/* ============== DATA-TABLE (TABLE-06) ============== */
.lisere-classic { padding-block: var(--space-lg);}
.lisere-classic-inner {
  max-width: calc(var(--container-site) + 2 * var(--container-padding-desktop));
  margin-inline: auto;
  padding-inline: var(--container-padding-desktop);
}
.lisere-classic-table { width: 100%; border-collapse: collapse; color: var(--color-text); }
.lisere-classic-table caption {
  font-family: var(--font-display);
  font-size: var(--fs-h4);
  font-style: italic;
  color: var(--color-text-muted);
  text-align: center;
  padding-block-end: var(--space-md);
  caption-side: top;
  position: relative;
}
.lisere-classic-table caption::before {
  content: "";
  display: block;
  width: 40px;
  height: 2px;
  background: var(--color-accent);
  margin: 0 auto var(--space-sm);
}
.lisere-classic-table th, .lisere-classic-table td { text-align: left; padding: var(--space-sm) var(--space-md); border-bottom: 1px solid rgba(255,255,255,0.08); font-size: var(--fs-body); }
.lisere-classic-table thead th { font-family: var(--font-display); font-weight: var(--fw-bold); text-transform: uppercase; letter-spacing: var(--ls-wide); color: var(--color-accent); }
.lisere-classic-table tbody tr:hover { background: rgba(255,255,255,0.02); }
@media (max-width: 880px) { .lisere-classic { padding-block: var(--space-md); } .lisere-classic-inner { padding-inline: var(--container-padding-mobile); overflow-x: auto; } .lisere-classic-table { min-width: 540px; } }

/* ============== LEGAL-SECTION (LEGAL-02) ============== */
.borne-deep { padding-block: var(--space-lg);}
.borne-deep-inner {
  max-width: calc(var(--container-site) + 2 * var(--container-padding-desktop));
  margin-inline: auto;
  padding-inline: var(--container-padding-desktop);
}
.borne-deep-intro { font-size: var(--fs-body); line-height: var(--lh-loose); color: var(--color-text-muted); margin-bottom: var(--space-lg); }
.borne-deep-meta { font-size: var(--fs-small); color: var(--color-text-muted); margin-bottom: var(--space-lg); }
.borne-deep-body { counter-reset: legal-section; }
.borne-deep-section { counter-increment: legal-section; margin-bottom: var(--space-xl); }
.borne-deep-section h3 { color: var(--color-text); font-family: var(--font-display); font-weight: var(--fw-bold); font-style: normal; font-size: var(--fs-h3); margin-bottom: var(--space-md); }
.borne-deep-section h3::before { content: counter(legal-section, decimal-leading-zero) ". "; color: var(--color-accent); font-family: var(--font-display); font-weight: var(--fw-bold); margin-right: var(--space-xs); }
.borne-deep-section p, .borne-deep-section ul { padding-left: var(--space-md); font-size: var(--fs-body); line-height: var(--lh-loose); color: var(--color-text-muted); }
.borne-deep-contacts, .borne-deep-disclaimer { margin-top: var(--space-lg); padding: var(--space-md); border-left: 3px solid var(--color-accent); background: var(--color-bg-elevated); font-size: var(--fs-small); color: var(--color-text-muted); line-height: var(--lh-loose); }
.borne-deep-contacts ul { padding-left: var(--space-md); margin: var(--space-2xs) 0 0; }
@media (max-width: 880px) {
  .borne-deep { padding-block: var(--space-md); }
  .borne-deep-inner { padding-inline: var(--container-padding-mobile); }
  .borne-deep-section p, .borne-deep-section ul { padding-left: 0; }
}

/* ============== CONTACT-FORM (FORM-04 fallback to full) ============== */
.beacon-fine { padding-block: var(--space-lg);}
.beacon-fine-inner {
  max-width: calc(var(--container-site) + 2 * var(--container-padding-desktop));
  margin-inline: auto;
  padding-inline: var(--container-padding-desktop);
  max-width: 720px;
}
.beacon-fine-intro { font-size: var(--fs-body); line-height: var(--lh-loose); color: var(--color-text-muted); margin-bottom: var(--space-lg); text-align: center; }
.beacon-fine-form { display: flex; flex-direction: column; gap: var(--space-md); }
.beacon-fine-field { display: flex; flex-direction: column; gap: var(--space-2xs); }
.beacon-fine-label { font-size: var(--fs-small); letter-spacing: var(--ls-wide); text-transform: uppercase; color: var(--color-text-muted); font-weight: var(--fw-medium); }
.beacon-fine-input, .beacon-fine-textarea {
  width: 100%;
  background: var(--color-bg-elevated);
  border: var(--border-medium) solid var(--color-border);
  color: var(--color-text);
  font-family: var(--font-body);
  font-size: var(--fs-body);
  padding: var(--space-sm) var(--space-md);
  border-radius: 0;
}
.beacon-fine-input:focus, .beacon-fine-textarea:focus { outline: none; border-color: var(--color-accent); }
.beacon-fine-textarea { min-height: 160px; resize: vertical; }
.beacon-fine-submit {
  align-self: flex-start;
  background: var(--color-accent);
  color: #1a1a1a;
  font-family: var(--font-body);
  font-weight: var(--fw-medium);
  font-size: var(--fs-body);
  letter-spacing: var(--ls-wide);
  text-transform: uppercase;
  padding: var(--space-sm) var(--space-2xl);
  border: 0;
  cursor: pointer;
  transition: background var(--dur-fast) var(--ease-out);
}
.beacon-fine-submit:hover { background: var(--color-accent-pressed); color: #1a1a1a; }
.beacon-fine-success { display: none; padding: var(--space-md); background: var(--color-bg-elevated); border-left: 3px solid var(--color-accent); font-size: var(--fs-body); color: var(--color-text); }
.beacon-fine-success.is-visible { display: block; }
@media (max-width: 880px) { .beacon-fine { padding-block: var(--space-md); } .beacon-fine-inner { padding-inline: var(--container-padding-mobile); } }

/* ============== AUTHOR-CARD (AUTH-02) ============== */
.lattice-refined { padding-block: var(--space-lg);}
.lattice-refined-inner {
  max-width: calc(var(--container-site) + 2 * var(--container-padding-desktop));
  margin-inline: auto;
  padding-inline: var(--container-padding-desktop);
  text-align: center;
}
.lattice-refined-card { max-width: 600px; margin-inline: auto; }
.lattice-refined-portrait { width: 140px; height: 140px; border-radius: var(--radius-circle); overflow: hidden; margin: 0 auto var(--space-lg); }
.lattice-refined-portrait img { width: 100%; height: 100%; object-fit: cover; object-position: center top; }
.lattice-refined-job { font-size: var(--fs-small); letter-spacing: var(--ls-wide); text-transform: uppercase; color: var(--color-accent); margin-bottom: var(--space-2xs); }
.lattice-refined-name { font-family: var(--font-display); font-size: var(--fs-h2); font-weight: var(--fw-bold); color: var(--color-text); margin-bottom: var(--space-md); }
.lattice-refined-bio { font-size: var(--fs-body); line-height: var(--lh-loose); color: var(--color-text-muted); margin-bottom: var(--space-md); }
.lattice-refined-expertise { list-style: none; padding: 0; margin: 0; display: flex; flex-wrap: wrap; justify-content: center; gap: var(--space-sm); }
.lattice-refined-tag { display: inline-block; padding: var(--space-2xs) var(--space-md); border: 1px solid var(--color-border); font-size: var(--fs-small); color: var(--color-text-muted); }
@media (max-width: 880px) { .lattice-refined { padding-block: var(--space-md); } .lattice-refined-inner { padding-inline: var(--container-padding-mobile); } }

/* ============== AUTHOR-BYLINE (BYLINE-01) ============== */
.tile-neat { padding-block: var(--space-md); }
.tile-neat-inner {
  max-width: calc(var(--container-site) + 2 * var(--container-padding-desktop));
  margin-inline: auto;
  padding-inline: var(--container-padding-desktop);
  display: flex;
  align-items: center;
  gap: var(--space-sm);
}
.tile-neat-portrait { display: block; width: 48px; height: 48px; border-radius: var(--radius-circle); overflow: hidden; flex-shrink: 0; }
.tile-neat-portrait img { width: 100%; height: 100%; object-fit: cover; object-position: center top; }
.tile-neat-text { display: flex; flex-direction: column; }
.tile-neat-attribution { font-family: var(--font-body); font-size: var(--fs-body); color: var(--color-text-muted); margin: 0; }
.tile-neat-name { color: var(--color-accent); text-decoration: underline; text-underline-offset: 3px; }
.tile-neat-name:hover { color: var(--color-accent-pressed); }
.tile-neat-role { font-size: var(--fs-small); font-style: italic; color: var(--color-text-muted); margin: var(--space-2xs) 0 0; }
.tile-neat-date { font-size: var(--fs-small); color: var(--color-text-muted); margin-left: var(--space-sm); }
@media (max-width: 880px) { .tile-neat-inner { padding-inline: var(--container-padding-mobile); } }

/* ============== ERROR-BLOCK (ERR-03) ============== */
.catwalk-cool { padding-block: var(--space-lg);}
.catwalk-cool-inner {
  max-width: calc(var(--container-site) + 2 * var(--container-padding-desktop));
  margin-inline: auto;
  padding-inline: var(--container-padding-desktop);
  text-align: center;
}
.catwalk-cool-card { max-width: 600px; margin-inline: auto; }
.catwalk-cool-title { font-size: var(--fs-h2); color: var(--color-text); margin-bottom: var(--space-md); }
.catwalk-cool-text { font-size: var(--fs-body); line-height: var(--lh-loose); color: var(--color-text-muted); margin-bottom: var(--space-lg); }
.catwalk-cool-button {
  display: inline-block;
  height: 44px;
  line-height: 44px;
  padding-inline: var(--space-lg);
  background: var(--color-accent);
  color: #1a1a1a;
  font-family: var(--font-body);
  font-weight: var(--fw-medium);
  text-transform: uppercase;
  letter-spacing: var(--ls-wide);
  font-size: var(--fs-small);
  transition: background var(--dur-fast) var(--ease-out);
}
.catwalk-cool-button:hover { background: var(--color-accent-pressed); color: #1a1a1a; }
@media (max-width: 880px) { .catwalk-cool { padding-block: var(--space-md); } .catwalk-cool-inner { padding-inline: var(--container-padding-mobile); } }

/* ============== COOKIE-BANNER (COOK-01) ============== */
.belfry-zone {
  position: fixed;
  inset-block-end: var(--space-md);
  inset-inline: var(--space-md);
  max-width: 720px;
  margin-inline: auto;
  z-index: 90;
  display: none;
}
.belfry-zone.is-visible { display: flex; }
.belfry-zone-inner {
  width: 100%;
  background: var(--color-bg-elevated);
  border: var(--border-thin) solid rgba(255,255,255,0.12);
  padding: var(--space-md);
  box-shadow: var(--shadow-md);
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--space-md);
}
.belfry-zone-message { flex: 1 1 280px; font-family: var(--font-body); font-size: var(--fs-small); line-height: var(--lh-normal); color: var(--color-text-muted); margin: 0; }
.belfry-zone-actions { display: flex; gap: var(--space-sm); }
.belfry-zone-button {
  height: 36px;
  padding-inline: var(--space-md);
  font-family: var(--font-display);
  font-weight: var(--fw-bold);
  text-transform: uppercase;
  letter-spacing: var(--ls-wide);
  font-size: var(--fs-micro);
  cursor: pointer;
  border: 0;
  background: var(--color-accent);
  color: var(--color-bg);
  transition: background var(--dur-fast) var(--ease-out);
}
.belfry-zone-button:hover { background: var(--color-accent-pressed); color: var(--color-bg); }
.belfry-zone-button--decline {
  background: transparent;
  border: 1px solid rgba(255,255,255,0.15);
  color: var(--color-text);
}
.belfry-zone-button--decline:hover { background: rgba(255,255,255,0.04); color: var(--color-text); }
@media (max-width: 720px) {
  .belfry-zone, .belfry-zone-inner { padding: 12px 14px !important; gap: 8px !important; font-size: 13px !important; line-height: 1.35 !important; }
  .belfry-zone-title, .belfry-zone-heading { display: none !important; }
  .belfry-zone-button, .belfry-zone button { padding: 8px 14px !important; font-size: 12px !important; min-height: 36px !important; }
  .belfry-zone { flex-direction: column; }
  .belfry-zone-inner { flex-direction: column; align-items: stretch; }
  .belfry-zone-actions { justify-content: stretch; }
  .belfry-zone-actions .belfry-zone-button { flex: 1; }
}

/* ============== FOOTER (FOOT-04 sticky mini) ============== */
.stele-bright {
  position: sticky;
  bottom: 0;
  background: rgba(12,27,53,0.95);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  border-top: var(--border-thin) solid var(--color-border-soft);
  z-index: 50;
}
.stele-bright-inner {
  max-width: calc(var(--container-site) + 2 * var(--container-padding-desktop));
  margin-inline: auto;
  padding: 0 var(--container-padding-desktop);
  height: 64px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-md);
}
.stele-bright-copy { font-size: var(--fs-micro); color: var(--color-text-muted); margin: 0; }
.stele-bright-nav { display: flex; align-items: center; gap: 0; }
.stele-bright-link {
  font-size: var(--fs-micro);
  text-transform: uppercase;
  letter-spacing: var(--ls-wide);
  color: var(--color-text-muted);
  padding-inline: var(--space-sm);
  border-left: 1px solid var(--color-border-soft);
  line-height: 1;
}
.stele-bright-link:first-child { border-left: 0; }
.stele-bright-link:hover { color: var(--color-text); }
@media (max-width: 880px) {
  .stele-bright-inner { height: auto; min-height: 80px; flex-direction: column; padding: var(--space-sm) var(--container-padding-mobile); gap: var(--space-2xs); }
  .stele-bright-nav { flex-wrap: wrap; justify-content: center; }
}

/* ============== PAGE IMAGES (per-page context/detail) ============== */
.page-image { margin: var(--space-lg) 0; }
.page-image img { width: 100%; height: auto; display: block; }
.page-image-caption { font-size: var(--fs-small); color: var(--color-text-muted); font-style: italic; margin-top: var(--space-2xs); padding-left: var(--space-2xl); }
@media (max-width: 880px) { .page-image-caption { padding-left: var(--space-md); } }
