/* iWild Casino — surface.css
   TYPO-02 / SPACE-04 / CONT-05 / BP-08 / GEO-01 / MOTION-02
   HEAD-06 / FOOT-06 / HERO-10 / PHEAD-04 / GRID-02 / FAQ-03 / CTA-01
*/

:root {
  /* Colors */
  --color-primary: #ffc905;
  --color-accent: #d351ff;
  --color-bg: #0c0311;
  --color-bg-elevated: #16091e;
  --color-bg-deep: #07020c;
  --color-accent-pressed: #c029fd;
  --color-gradient-light: #903bc5;
  --color-gradient-mid: #4c1bae;
  --color-text: #ffffff;
  --color-text-muted: #c0bfbf;
  --color-line: rgba(255,255,255,0.08);
  --color-rg-banner: #dc2626;

  /* Type scale TYPO-02 (modular, generous) */
  --font-display: "Poppins", "Inter", system-ui, sans-serif;
  --font-body: "Inter", system-ui, sans-serif;
  --fs-12: 0.75rem;
  --fs-14: 0.875rem;
  --fs-15: 0.9375rem;
  --fs-16: 1rem;
  --fs-18: 1.125rem;
  --fs-20: 1.25rem;
  --fs-22: 1.375rem;
  --fs-26: 1.625rem;
  --fs-32: 2rem;
  --fs-40: 2.5rem;
  --fs-52: 3.25rem;
  --fs-64: 4rem;
  --lh-tight: 1.15;
  --lh-snug: 1.3;
  --lh-normal: 1.55;
  --lh-loose: 1.7;

  /* Spacing SPACE-04 */
  --space-2xs: 4px;
  --space-xs: 8px;
  --space-sm: 12px;
  --space-md: 18px;
  --space-lg: 28px;
  --space-xl: 44px;
  --space-2xl: 68px;
  --space-3xl: 96px;

  /* Container CONT-05 */
  --container-site: 1180px;
  --container-readable: 720px;
  --container-padding-desktop: 28px;
  --container-padding-mobile: 16px;

  /* Geometry GEO-01 (soft radii) */
  --radius-sm: 6px;
  --radius-md: 12px;
  --radius-lg: 18px;
  --radius-pill: 999px;

  /* Motion MOTION-02 */
  --t-fast: 140ms;
  --t-base: 220ms;
  --t-slow: 380ms;
  --ease-out: cubic-bezier(0.22, 0.61, 0.36, 1);

  /* Header height */
  --header-h-desktop: 96px;
  --header-h-mobile: 72px;
}

/* Reset */
*, *::before, *::after { box-sizing: border-box; }
html, body { margin: 0; padding: 0; overflow-x: clip; }
html { scroll-behavior: smooth; }
body {
  background: var(--color-bg);
  color: var(--color-text);
  font-family: var(--font-body);
  font-size: var(--fs-16);
  line-height: var(--lh-normal);
  -webkit-font-smoothing: antialiased;
}
img { max-width: 100%; height: auto; display: block; }
a { color: var(--color-primary); text-decoration: none; transition: color var(--t-fast) var(--ease-out); }
a:hover { color: var(--color-accent); }
button { font-family: inherit; cursor: pointer; }
h1, h2, h3, h4 { font-family: var(--font-display); font-weight: 700; line-height: var(--lh-tight); margin: 0 0 var(--space-sm); }
h1 { font-size: var(--fs-52); }
h2 { font-size: var(--fs-32); }
h3 { font-size: var(--fs-22); }
p { margin: 0 0 var(--space-md); }
ul, ol { margin: 0 0 var(--space-md); padding-left: 1.25em; }
li { margin-bottom: var(--space-xs); }

/* Skip-link off-screen */
.skip-link:not(:focus) { position: absolute; top: -200px !important; left: 0; }
.skip-link:focus {
  position: fixed; top: 12px; left: 12px; z-index: 9999;
  background: var(--color-primary); color: #1a0f00;
  padding: 10px 18px; border-radius: var(--radius-md);
  font-weight: 600;
}

/* A11y utility */
.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;
}

/* Body padding-top to accommodate fixed header */
body { padding-top: var(--header-h-desktop); }

/* =====================================
   HEADER — HEAD-06 (Magazine Logo)
   sticky=STICKY-02 (fixed), AUTH-NONE
   NAV-03 two rows: ceil(7/2)=4 top, 3 bottom
   ===================================== */
.cornice-fresh {
  position: fixed; top: 0; left: 0; right: 0; z-index: 100;
  background: linear-gradient(180deg, rgba(12,3,17,0.97) 0%, rgba(12,3,17,0.88) 100%);
  backdrop-filter: blur(12px);
  border-bottom: 1px solid var(--color-line);
  transition: padding var(--t-base) var(--ease-out), background var(--t-base) var(--ease-out);
}
.cornice-fresh.is-shrunk {
  background: rgba(7, 2, 12, 0.98);
  border-bottom-color: rgba(208,75,255,0.18);
}
.cornice-fresh-inner {
  max-width: 1440px;
  margin: 0 auto;
  padding-inline: var(--container-padding-desktop);
  padding-block: 14px;
  display: flex;
  align-items: center;
  gap: var(--space-xl);
}
.cornice-fresh-logo {
  display: inline-flex; align-items: center;
  flex-shrink: 0;
}
.cornice-fresh-logo, .cornice-fresh-logo img { flex-shrink: 0; }
.cornice-fresh-logo-img {
  height: 88px;
  width: auto;
  display: block;
}
.is-shrunk .cornice-fresh-logo-img { height: 72px; }

.cornice-fresh-nav {
  display: flex;
  flex-direction: column;
  flex: 1;
  align-items: flex-end;
  gap: 6px;
}
.cornice-fresh-nav-row {
  display: flex;
  list-style: none;
  margin: 0;
  padding: 0;
  gap: var(--space-lg);
  flex-wrap: nowrap;
}
.cornice-fresh-nav-row li { margin: 0; }
.cornice-fresh-nav-row a {
  color: var(--color-text);
  font-size: var(--fs-15);
  font-weight: 500;
  letter-spacing: 0.01em;
  padding: 4px 2px;
  border-bottom: 2px solid transparent;
  transition: color var(--t-fast) var(--ease-out), border-color var(--t-fast) var(--ease-out);
}
.cornice-fresh-nav-row a:hover,
.cornice-fresh-nav-row a[aria-current="page"] {
  color: var(--color-primary);
  border-bottom-color: var(--color-primary);
}
.cornice-fresh-nav-divider {
  display: block;
  height: 1px;
  width: 100%;
  background: linear-gradient(90deg, transparent, var(--color-line) 30%, var(--color-line) 70%, transparent);
}
.cornice-fresh-toggle {
  display: none;
  margin-left: auto !important;
  background: transparent;
  border: 1px solid var(--color-line);
  border-radius: var(--radius-md);
  padding: 10px 12px;
  width: 46px; height: 42px;
  flex-direction: column;
  justify-content: center;
  gap: 5px;
  align-items: center;
}
.cornice-fresh-toggle-bar {
  display: block;
  width: 22px;
  height: 2px;
  background: var(--color-text);
  border-radius: 2px;
}
.cornice-fresh-mobile {
  display: none;
  background: var(--color-bg-elevated);
  border-top: 1px solid var(--color-line);
  padding: var(--space-md) var(--container-padding-mobile);
}
.cornice-fresh-mobile[hidden] { display: none; }
.cornice-fresh-mobile.is-open { display: block; }
.cornice-fresh-mobile-list {
  list-style: none; margin: 0; padding: 0;
  display: flex; flex-direction: column; gap: 4px;
}
.cornice-fresh-mobile-list a {
  display: block;
  color: var(--color-text);
  font-size: var(--fs-18);
  padding: 12px 8px;
  border-radius: var(--radius-md);
}
.cornice-fresh-mobile-list a:hover,
.cornice-fresh-mobile-list a[aria-current="page"] {
  background: rgba(255,201,5,0.08);
  color: var(--color-primary);
}

/* =====================================
   HERO — HERO-10 (full-vh centered)
   ===================================== */
.arche-grave {
  display: flex;
  align-items: center;
  min-height: calc(100vh - var(--header-h-desktop));
  padding: var(--space-2xl) 0;
  background:
    radial-gradient(ellipse 60% 40% at 80% 20%, rgba(211,81,255,0.25), transparent 60%),
    radial-gradient(ellipse 50% 50% at 10% 80%, rgba(76,27,174,0.32), transparent 60%),
    linear-gradient(180deg, var(--color-bg) 0%, var(--color-bg-deep) 100%);
  position: relative;
  overflow: hidden;
}
.arche-grave::before {
  content: "";
  position: absolute; inset: 0;
  background: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='400' height='400'%3E%3Cfilter id='n'%3E%3CfeTurbulence baseFrequency='0.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.04'/%3E%3C/svg%3E");
  pointer-events: none;
}
.arche-grave-inner {
  max-width: calc(var(--container-site) + 2 * var(--container-padding-desktop));
  margin: 0 auto;
  padding-inline: var(--container-padding-desktop);
  display: grid;
  grid-template-columns: 1.1fr 0.9fr;
  gap: var(--space-2xl);
  align-items: center;
  position: relative;
}
.arche-grave-text { max-width: 100%; }
.arche-grave-eyebrow {
  text-transform: uppercase;
  letter-spacing: 0.16em;
  font-size: var(--fs-12);
  font-weight: 600;
  color: var(--color-primary);
  margin-bottom: var(--space-md);
}
.arche-grave-h1 {
  font-size: var(--fs-64);
  line-height: 1.05;
  margin-bottom: var(--space-md);
  background: linear-gradient(90deg, var(--color-text) 0%, var(--color-primary) 65%, var(--color-accent) 100%);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}
.arche-grave-sub {
  font-size: var(--fs-18);
  line-height: var(--lh-normal);
  color: var(--color-text-muted);
  max-width: 540px;
  margin-bottom: var(--space-xl);
}
.arche-grave-cta-wrap { margin: 0; }
.arche-grave-cta {
  display: inline-flex;
  align-items: center;
  background: var(--color-primary);
  color: #1a0f00;
  font-weight: 700;
  padding: 16px 32px;
  border-radius: var(--radius-pill);
  font-size: var(--fs-16);
  letter-spacing: 0.02em;
  text-transform: uppercase;
  box-shadow: 0 10px 32px -8px rgba(255,201,5,0.45);
  transition: transform var(--t-fast) var(--ease-out), background var(--t-fast) var(--ease-out), color var(--t-fast) var(--ease-out);
}
.arche-grave-cta:hover {
  background: var(--color-accent-pressed);
  color: #ffffff;
  transform: translateY(-2px);
}
.arche-grave-media {
  position: relative;
  border-radius: var(--radius-lg);
  overflow: hidden;
  box-shadow: 0 30px 60px -20px rgba(0,0,0,0.6), 0 0 80px -20px rgba(211,81,255,0.35);
  aspect-ratio: 4 / 3;
}
.arche-grave-media img {
  width: 100%; height: 100%;
  object-fit: cover;
  object-position: center;
}

/* =====================================
   PAGE HEADER — PHEAD-04
   ===================================== */
.pergola-raw {
  padding: var(--space-2xl) 0 var(--space-xl);
  background:
    radial-gradient(ellipse 70% 50% at 50% 0%, rgba(144,59,197,0.28), transparent 70%),
    var(--color-bg);
  border-bottom: 1px solid var(--color-line);
}
.pergola-raw-inner {
  max-width: calc(var(--container-site) + 2 * var(--container-padding-desktop));
  margin: 0 auto;
  padding-inline: var(--container-padding-desktop);
  text-align: left;
}
.pergola-raw-eyebrow {
  text-transform: uppercase;
  letter-spacing: 0.16em;
  font-size: var(--fs-12);
  font-weight: 600;
  color: var(--color-accent);
  margin-bottom: var(--space-sm);
}
.pergola-raw-h1 {
  font-size: var(--fs-52);
  margin-bottom: var(--space-md);
  max-width: 880px;
}
.pergola-raw-lede {
  font-size: var(--fs-18);
  color: var(--color-text-muted);
  max-width: 720px;
  margin-bottom: var(--space-md);
}
.pergola-raw-meta {
  font-size: var(--fs-14);
  color: var(--color-text-muted);
  margin: 0;
}
.pergola-raw-meta time { color: var(--color-text); font-weight: 500; }

/* =====================================
   PROSE — PROSE-03
   ===================================== */
.billet-noble {
  padding: var(--space-2xl) 0;
}
.billet-noble-inner {
  max-width: calc(var(--container-site) + 2 * var(--container-padding-desktop));
  margin: 0 auto;
  padding-inline: var(--container-padding-desktop);
}
.billet-noble--lead { padding-top: var(--space-xl); }
.billet-noble h2 {
  font-size: var(--fs-32);
  margin-bottom: var(--space-lg);
  position: relative;
  padding-left: 20px;
}
.billet-noble h2::before {
  content: ""; position: absolute; left: 0; top: 0.3em; bottom: 0.3em;
  width: 4px; border-radius: 2px;
  background: linear-gradient(180deg, var(--color-primary), var(--color-accent));
}
.billet-noble p {
  font-size: var(--fs-16);
  line-height: var(--lh-loose);
  color: var(--color-text);
  max-width: 880px;
}
.billet-noble ul, .billet-noble ol {
  max-width: 880px;
  font-size: var(--fs-16);
  line-height: var(--lh-loose);
}
.billet-noble li { margin-bottom: 10px; }
.billet-noble strong { color: var(--color-primary); }
.billet-noble a { color: var(--color-accent); text-decoration: underline; text-underline-offset: 3px; }
.billet-noble a:hover { color: var(--color-primary); }

/* =====================================
   ITEMS GRID — GRID-02 (card grid 3-up)
   ===================================== */
.gallery-core {
  padding: var(--space-2xl) 0;
  background:
    linear-gradient(180deg, transparent 0%, rgba(144,59,197,0.05) 50%, transparent 100%);
}
.gallery-core-inner {
  max-width: calc(var(--container-site) + 2 * var(--container-padding-desktop));
  margin: 0 auto;
  padding-inline: var(--container-padding-desktop);
}
.gallery-core-h {
  margin-bottom: var(--space-xl);
  font-size: var(--fs-40);
}
.gallery-core-list {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-lg);
}
.gallery-core-card {
  background: var(--color-bg-elevated);
  border: 1px solid var(--color-line);
  border-radius: var(--radius-lg);
  padding: var(--space-lg);
  transition: transform var(--t-base) var(--ease-out), border-color var(--t-base) var(--ease-out), box-shadow var(--t-base) var(--ease-out);
}
.gallery-core-card:hover {
  transform: translateY(-4px);
  border-color: rgba(211,81,255,0.4);
  box-shadow: 0 18px 40px -16px rgba(211,81,255,0.35);
}
.gallery-core-card-title {
  font-size: var(--fs-20);
  margin-bottom: var(--space-sm);
  color: var(--color-primary);
}
.gallery-core-card-text {
  margin: 0;
  font-size: var(--fs-15);
  line-height: var(--lh-normal);
  color: var(--color-text-muted);
}

/* =====================================
   FAQ — FAQ-03 (always-bordered accordion)
   ===================================== */
.trellis-fine {
  padding: var(--space-2xl) 0;
}
.trellis-fine-inner {
  max-width: calc(var(--container-site) + 2 * var(--container-padding-desktop));
  margin: 0 auto;
  padding-inline: var(--container-padding-desktop);
}
.trellis-fine-h {
  margin-bottom: var(--space-xl);
  font-size: var(--fs-40);
}
.trellis-fine-list {
  display: flex; flex-direction: column;
  gap: 14px;
}
.trellis-fine-item {
  background: var(--color-bg-elevated);
  border: 1px solid var(--color-line);
  border-radius: var(--radius-md);
  padding: 0;
  overflow: hidden;
  transition: border-color var(--t-base) var(--ease-out);
}
.trellis-fine-item[open] {
  border-color: rgba(255,201,5,0.35);
}
.trellis-fine-q {
  display: block;
  padding: 18px 56px 18px 22px;
  font-weight: 600;
  font-size: var(--fs-18);
  color: var(--color-text);
  cursor: pointer;
  list-style: none;
  position: relative;
}
.trellis-fine-q::-webkit-details-marker { display: none; }
.trellis-fine-q::after {
  content: "+";
  position: absolute;
  right: 24px; top: 50%;
  transform: translateY(-50%);
  color: var(--color-primary);
  font-size: 24px;
  font-weight: 400;
  transition: transform var(--t-fast) var(--ease-out);
}
.trellis-fine-item[open] .trellis-fine-q::after { content: "−"; }
.trellis-fine-a {
  padding: 4px 22px 22px;
  color: var(--color-text-muted);
  font-size: var(--fs-16);
  line-height: var(--lh-loose);
}
.trellis-fine-a p { margin: 0; }

/* =====================================
   CTA BLOCK — CTA-01
   ===================================== */
.crest-apex {
  padding: var(--space-3xl) 0;
  background:
    linear-gradient(135deg, var(--color-gradient-mid) 0%, var(--color-gradient-light) 60%, var(--color-accent) 100%);
  position: relative;
  overflow: hidden;
}
.crest-apex::before {
  content: ""; position: absolute; inset: 0;
  background: radial-gradient(ellipse 60% 40% at 50% 50%, rgba(255,201,5,0.18), transparent 70%);
  pointer-events: none;
}
.crest-apex-inner {
  max-width: calc(var(--container-site) + 2 * var(--container-padding-desktop));
  margin: 0 auto;
  padding-inline: var(--container-padding-desktop);
  text-align: center;
  position: relative;
}
.crest-apex-title {
  font-size: var(--fs-40);
  margin-bottom: var(--space-md);
  color: #ffffff;
}
.crest-apex-text {
  font-size: var(--fs-18);
  color: rgba(255,255,255,0.92);
  max-width: 720px;
  margin: 0 auto var(--space-xl);
}
.crest-apex-actions { margin: 0; }
.crest-apex-btn {
  display: inline-flex;
  background: var(--color-primary);
  color: #1a0f00;
  font-weight: 700;
  padding: 18px 40px;
  border-radius: var(--radius-pill);
  font-size: var(--fs-18);
  text-transform: uppercase;
  letter-spacing: 0.05em;
  box-shadow: 0 12px 32px -8px rgba(0,0,0,0.5);
  transition: transform var(--t-fast) var(--ease-out), background var(--t-fast) var(--ease-out), color var(--t-fast) var(--ease-out);
}
.crest-apex-btn:hover {
  background: #ffffff;
  color: var(--color-accent-pressed);
  transform: translateY(-2px);
}

/* =====================================
   TABLE — TABLE-02
   ===================================== */
.dossier-solid {
  padding: var(--space-xl) 0;
}
.dossier-solid-inner {
  max-width: calc(var(--container-site) + 2 * var(--container-padding-desktop));
  margin: 0 auto;
  padding-inline: var(--container-padding-desktop);
}
.dossier-solid-scroll {
  overflow-x: auto;
  border-radius: var(--radius-md);
  border: 1px solid var(--color-line);
}
.dossier-solid table {
  width: 100%;
  border-collapse: collapse;
  background: var(--color-bg-elevated);
  font-size: var(--fs-15);
  min-width: 640px;
}
.dossier-solid th, .dossier-solid td {
  padding: 14px 18px;
  text-align: left;
  border-bottom: 1px solid var(--color-line);
}
.dossier-solid th {
  background: rgba(144,59,197,0.15);
  font-weight: 600;
  color: var(--color-primary);
  text-transform: uppercase;
  letter-spacing: 0.04em;
  font-size: var(--fs-12);
}
.dossier-solid tr:last-child td { border-bottom: none; }
.dossier-solid tr:hover td { background: rgba(255,201,5,0.04); }

/* =====================================
   PAGE IMAGES
   ===================================== */
.page-images {
  padding: var(--space-xl) 0;
}
.page-images-inner {
  max-width: calc(var(--container-site) + 2 * var(--container-padding-desktop));
  margin: 0 auto;
  padding-inline: var(--container-padding-desktop);
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: var(--space-md);
}
.page-image {
  margin: 0;
  border-radius: var(--radius-lg);
  overflow: hidden;
  border: 1px solid var(--color-line);
}
.page-image img {
  width: 100%;
  aspect-ratio: 1;
  object-fit: cover;
}

/* =====================================
   AUTHOR BYLINE — BYLINE-01
   ===================================== */
.etiquette-crisp {
  padding: var(--space-xl) 0;
  border-top: 1px solid var(--color-line);
  margin-top: var(--space-xl);
}
.etiquette-crisp-inner {
  max-width: calc(var(--container-site) + 2 * var(--container-padding-desktop));
  margin: 0 auto;
  padding-inline: var(--container-padding-desktop);
  display: flex;
  align-items: center;
  gap: var(--space-md);
}
.etiquette-crisp-portrait {
  width: 72px; height: 72px;
  border-radius: 50%;
  object-fit: cover;
  border: 2px solid var(--color-primary);
  flex-shrink: 0;
}
.etiquette-crisp-meta { flex: 1; }
.etiquette-crisp-byline-label {
  text-transform: uppercase;
  letter-spacing: 0.16em;
  font-size: var(--fs-12);
  color: var(--color-text-muted);
  margin: 0 0 4px;
}
.etiquette-crisp-name {
  margin: 0;
  font-size: var(--fs-16);
  font-weight: 500;
  color: var(--color-text);
}
.etiquette-crisp-name a {
  color: var(--color-primary);
  font-weight: 600;
  text-decoration: none;
}
.etiquette-crisp-name a:hover { color: var(--color-accent); }
.etiquette-crisp-sep { margin: 0 8px; color: var(--color-text-muted); }
.etiquette-crisp-role { color: var(--color-text-muted); }
.etiquette-crisp-date { color: var(--color-text-muted); }

/* =====================================
   AUTHOR CARD — AUTH-01
   ===================================== */
.medaillon-sharp {
  padding: var(--space-2xl) 0;
}
.medaillon-sharp-inner {
  max-width: calc(var(--container-site) + 2 * var(--container-padding-desktop));
  margin: 0 auto;
  padding-inline: var(--container-padding-desktop);
}
.medaillon-sharp-card {
  display: grid;
  grid-template-columns: 220px 1fr;
  gap: var(--space-xl);
  align-items: center;
  background: var(--color-bg-elevated);
  border: 1px solid var(--color-line);
  border-radius: var(--radius-lg);
  padding: var(--space-xl);
}
.medaillon-sharp-portrait {
  width: 200px; height: 200px;
  border-radius: 50%;
  object-fit: cover;
  border: 3px solid var(--color-primary);
}
.medaillon-sharp-name {
  font-size: var(--fs-40);
  margin: 0 0 var(--space-2xs);
}
.medaillon-sharp-role {
  text-transform: uppercase;
  letter-spacing: 0.14em;
  font-size: var(--fs-12);
  color: var(--color-accent);
  font-weight: 600;
  margin: 0 0 var(--space-md);
}
.medaillon-sharp-bio {
  color: var(--color-text-muted);
  margin-bottom: var(--space-md);
  max-width: 720px;
}
.medaillon-sharp-expertise {
  list-style: none; padding: 0;
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
  gap: 8px;
}
.medaillon-sharp-expertise li {
  font-size: var(--fs-14);
  color: var(--color-text-muted);
  padding-left: 24px;
  position: relative;
  margin: 0;
}
.medaillon-sharp-expertise li::before {
  content: "✦";
  position: absolute; left: 0;
  color: var(--color-primary);
}
.medaillon-sharp-articles {
  padding: var(--space-xl) 0 var(--space-2xl);
}
.medaillon-sharp-articles-inner {
  max-width: calc(var(--container-site) + 2 * var(--container-padding-desktop));
  margin: 0 auto;
  padding-inline: var(--container-padding-desktop);
}
.medaillon-sharp-articles-heading {
  font-size: var(--fs-26);
  margin-bottom: var(--space-md);
}
.medaillon-sharp-articles-list {
  list-style: none; padding: 0;
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: var(--space-sm);
}
.medaillon-sharp-articles-list li {
  background: var(--color-bg-elevated);
  border: 1px solid var(--color-line);
  border-radius: var(--radius-md);
  padding: 14px 18px;
  margin: 0;
}
.medaillon-sharp-articles-list a {
  color: var(--color-primary);
  font-weight: 500;
  font-size: var(--fs-15);
  text-decoration: none;
}
.medaillon-sharp-articles-list a:hover { color: var(--color-accent); }

/* =====================================
   LEGAL SECTION — LEGAL-05
   ===================================== */
.vitrail-warm {
  padding: var(--space-2xl) 0;
}
.vitrail-warm-inner {
  max-width: calc(var(--container-site) + 2 * var(--container-padding-desktop));
  margin: 0 auto;
  padding-inline: var(--container-padding-desktop);
}
.vitrail-warm-head { margin-bottom: var(--space-2xl); }
.vitrail-warm-title {
  font-size: var(--fs-52);
  margin-bottom: var(--space-md);
}
.vitrail-warm-intro {
  font-size: var(--fs-18);
  color: var(--color-text-muted);
  max-width: 820px;
  margin-bottom: var(--space-sm);
}
.vitrail-warm-meta {
  font-size: var(--fs-14);
  color: var(--color-text-muted);
  margin: 0;
}
.vitrail-warm-section {
  margin-bottom: var(--space-xl);
  padding-top: var(--space-md);
  border-top: 1px solid var(--color-line);
}
.vitrail-warm-h {
  font-size: var(--fs-26);
  color: var(--color-primary);
  margin-bottom: var(--space-md);
}
.vitrail-warm-section p {
  color: var(--color-text);
  line-height: var(--lh-loose);
  max-width: 880px;
}
.vitrail-warm-contacts ul { list-style: none; padding: 0; }
.vitrail-warm-contacts li {
  padding: 10px 0 10px 24px;
  position: relative;
  border-bottom: 1px solid var(--color-line);
}
.vitrail-warm-contacts li::before {
  content: "→"; position: absolute; left: 0;
  color: var(--color-primary);
}
.vitrail-warm-disclaimer {
  margin-top: var(--space-xl);
  padding: var(--space-md) var(--space-lg);
  background: rgba(220,38,38,0.08);
  border-left: 4px solid var(--color-rg-banner);
  border-radius: var(--radius-sm);
}
.vitrail-warm-disclaimer p {
  margin: 0;
  color: var(--color-text-muted);
  font-size: var(--fs-15);
}

/* =====================================
   CONTACT FORM — FORM-02
   ===================================== */
.harbor-fast {
  padding: var(--space-xl) 0 var(--space-2xl);
}
.harbor-fast-inner {
  max-width: calc(var(--container-site) + 2 * var(--container-padding-desktop));
  margin: 0 auto;
  padding-inline: var(--container-padding-desktop);
}
.harbor-fast-intro {
  font-size: var(--fs-18);
  color: var(--color-text-muted);
  max-width: 720px;
  margin-bottom: var(--space-xl);
}
.harbor-fast-form {
  display: grid;
  gap: var(--space-md);
  max-width: 640px;
  padding: var(--space-xl);
  background: var(--color-bg-elevated);
  border: 1px solid var(--color-line);
  border-radius: var(--radius-lg);
}
.harbor-fast-label {
  display: flex;
  flex-direction: column;
  gap: 6px;
  font-size: var(--fs-14);
  color: var(--color-text-muted);
  text-transform: uppercase;
  letter-spacing: 0.08em;
}
.harbor-fast-label input,
.harbor-fast-label textarea {
  font-family: inherit;
  font-size: var(--fs-16);
  background: var(--color-bg-deep);
  color: var(--color-text);
  border: 1px solid var(--color-line);
  border-radius: var(--radius-md);
  padding: 12px 14px;
  transition: border-color var(--t-fast) var(--ease-out);
}
.harbor-fast-label input:focus,
.harbor-fast-label textarea:focus {
  outline: none;
  border-color: var(--color-primary);
}
.harbor-fast-submit {
  justify-self: flex-start;
  background: var(--color-primary);
  color: #1a0f00;
  font-weight: 700;
  font-size: var(--fs-15);
  padding: 14px 32px;
  border-radius: var(--radius-pill);
  border: none;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  transition: background var(--t-fast) var(--ease-out), color var(--t-fast) var(--ease-out), transform var(--t-fast) var(--ease-out);
}
.harbor-fast-submit:hover {
  background: var(--color-accent-pressed);
  color: #ffffff;
  transform: translateY(-1px);
}
.harbor-fast-success {
  background: rgba(255,201,5,0.1);
  border: 1px solid var(--color-primary);
  color: var(--color-primary);
  padding: var(--space-md);
  border-radius: var(--radius-md);
  font-weight: 500;
}

/* =====================================
   COOKIE BANNER — COOK-04
   ===================================== */
.ardoise-raw {
  position: fixed;
  left: 16px; right: 16px;
  bottom: 16px;
  z-index: 95;
  background: var(--color-bg-elevated);
  border: 1px solid var(--color-line);
  border-radius: var(--radius-lg);
  box-shadow: 0 24px 60px -12px rgba(0,0,0,0.7);
  padding: var(--space-md) var(--space-lg);
  max-width: 720px;
  margin-left: auto; margin-right: auto;
}
.ardoise-raw[hidden] { display: none; }
.ardoise-raw-inner {
  display: flex;
  align-items: center;
  gap: var(--space-md);
  flex-wrap: wrap;
}
.ardoise-raw-text {
  margin: 0;
  flex: 1 1 280px;
  font-size: var(--fs-14);
  color: var(--color-text);
  line-height: var(--lh-normal);
}
.ardoise-raw-actions {
  display: flex;
  gap: 10px;
  flex-shrink: 0;
}
.ardoise-raw-button {
  font-family: inherit;
  font-size: var(--fs-14);
  font-weight: 600;
  padding: 10px 20px;
  border-radius: var(--radius-pill);
  border: 1px solid transparent;
  cursor: pointer;
  transition: background var(--t-fast) var(--ease-out), color var(--t-fast) var(--ease-out);
}
.ardoise-raw-button--accept {
  background: var(--color-primary);
  color: #1a0f00;
}
.ardoise-raw-button--accept:hover { background: var(--color-accent-pressed); color: #ffffff; }
.ardoise-raw-button--decline {
  background: transparent;
  color: var(--color-text);
  border-color: var(--color-line);
}
.ardoise-raw-button--decline:hover { border-color: var(--color-text-muted); }

/* =====================================
   ERROR — ERR-08
   ===================================== */
.deck-pure {
  min-height: calc(100vh - var(--header-h-desktop));
  display: flex;
  align-items: center;
}
.deck-pure-inner {
  max-width: 680px;
  margin: 0 auto;
  padding: var(--space-2xl) var(--container-padding-desktop);
  text-align: center;
}
.deck-pure-code {
  font-family: var(--font-display);
  font-size: 12rem;
  line-height: 1;
  font-weight: 700;
  background: linear-gradient(180deg, var(--color-primary), var(--color-accent));
  -webkit-background-clip: text; background-clip: text; color: transparent;
  margin: 0;
}
.deck-pure-title {
  font-size: var(--fs-40);
  margin: var(--space-md) 0;
}
.deck-pure-text {
  color: var(--color-text-muted);
  font-size: var(--fs-18);
  margin-bottom: var(--space-xl);
}
.deck-pure-btn {
  display: inline-flex;
  background: var(--color-primary); color: #1a0f00;
  font-weight: 700;
  padding: 14px 28px;
  border-radius: var(--radius-pill);
  text-transform: uppercase;
  letter-spacing: 0.04em;
}
.deck-pure-btn:hover { background: var(--color-accent-pressed); color: #ffffff; }

/* =====================================
   FOOTER — FOOT-06
   ===================================== */
.window-cool {
  background: linear-gradient(180deg, var(--color-bg) 0%, var(--color-bg-deep) 100%);
  border-top: 1px solid var(--color-line);
  padding: var(--space-2xl) 0 var(--space-md);
}
.window-cool-inner {
  max-width: calc(var(--container-site) + 2 * var(--container-padding-desktop));
  margin: 0 auto;
  padding-inline: var(--container-padding-desktop);
}
.window-cool-grid {
  display: grid;
  grid-template-columns: 1.4fr 1fr 1fr 1.3fr;
  gap: var(--space-xl);
  margin-bottom: var(--space-xl);
}
.window-cool-brand { display: flex; flex-direction: column; gap: var(--space-sm); }
.window-cool-logo img { height: 72px; width: auto; }
.window-cool-tagline {
  color: var(--color-text-muted);
  font-size: var(--fs-14);
  line-height: var(--lh-normal);
  margin: 0;
}
.window-cool-licence {
  font-size: var(--fs-12);
  color: rgba(255,255,255,0.5);
  margin: 0;
}
.window-cool-h {
  font-size: var(--fs-14);
  text-transform: uppercase;
  letter-spacing: 0.14em;
  color: var(--color-primary);
  margin-bottom: var(--space-md);
  font-weight: 600;
}
.window-cool-col ul { list-style: none; padding: 0; margin: 0; }
.window-cool-col li { margin-bottom: 10px; }
.window-cool-col a {
  color: var(--color-text);
  font-size: var(--fs-14);
  text-decoration: none;
}
.window-cool-col a:hover { color: var(--color-primary); }
.window-cool-col--about p {
  color: var(--color-text-muted);
  font-size: var(--fs-14);
  margin: 0 0 10px;
}
.window-cool-rg { color: var(--color-text-muted); font-size: var(--fs-12) !important; }
.window-cool-rg a { color: var(--color-accent); text-decoration: underline; }
.window-cool-bottom {
  border-top: 1px solid var(--color-line);
  padding-top: var(--space-md);
  display: flex;
  justify-content: space-between;
  align-items: center;
  flex-wrap: wrap;
  gap: var(--space-sm);
}
.window-cool-copy, .window-cool-age {
  margin: 0;
  font-size: var(--fs-12);
  color: rgba(255,255,255,0.5);
  letter-spacing: 0.04em;
}

/* prefers-reduced-motion */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: 0.001ms !important;
    transition-duration: 0.001ms !important;
  }
  html { scroll-behavior: auto; }
}

/* =====================================
   RESPONSIVE — BP-08
   ===================================== */
@media (max-width: 1080px) {
  .cornice-fresh-nav-row { gap: var(--space-md); }
  .arche-grave-inner { grid-template-columns: 1fr; gap: var(--space-xl); }
  .arche-grave-media { max-width: 600px; margin: 0 auto; }
  .gallery-core-list { grid-template-columns: repeat(2, 1fr); }
  .window-cool-grid { grid-template-columns: 1fr 1fr; }
}

@media (max-width: 720px) {
  :root {
    --container-padding-desktop: 16px;
  }
  body { padding-top: var(--header-h-mobile); font-size: var(--fs-15); }
  h1 { font-size: var(--fs-32); }
  h2 { font-size: var(--fs-26); }
  .arche-grave-h1 { font-size: var(--fs-40); }
  .arche-grave-sub { font-size: var(--fs-16); }
  .pergola-raw-h1 { font-size: var(--fs-32); }
  .crest-apex-title { font-size: var(--fs-32); }
  .vitrail-warm-title { font-size: var(--fs-32); }
  .gallery-core-h, .trellis-fine-h { font-size: var(--fs-26); }
  .deck-pure-code { font-size: 6rem; }
  .cornice-fresh-inner {
    padding-block: 12px;
    padding-inline: var(--container-padding-mobile);
    gap: var(--space-sm);
  }
  .cornice-fresh-logo-img { height: 60px; }
  .is-shrunk .cornice-fresh-logo-img { height: 56px; }
  .cornice-fresh-nav { display: none; }
  .cornice-fresh-toggle { display: flex; }
  .gallery-core-list { grid-template-columns: 1fr; }
  .arche-grave { min-height: calc(100vh - var(--header-h-mobile)); padding: var(--space-xl) 0; }
  .crest-apex { padding: var(--space-2xl) 0; }
  .medaillon-sharp-card { grid-template-columns: 1fr; text-align: center; gap: var(--space-md); padding: var(--space-md); }
  .medaillon-sharp-portrait { margin: 0 auto; width: 160px; height: 160px; }
  .medaillon-sharp-expertise li { text-align: left; }
  .window-cool-grid { grid-template-columns: 1fr; gap: var(--space-lg); }
  .ardoise-raw, .ardoise-raw-inner {
    padding: 12px 14px !important;
    gap: 8px !important;
    font-size: 13px !important;
    line-height: 1.35 !important;
  }
  .ardoise-raw-button {
    padding: 8px 14px !important;
    font-size: 12px !important;
    min-height: 36px !important;
  }
  .harbor-fast-form { padding: var(--space-md); }
}
