/* ============================================================
   Galaad — components.css
   Boutons, liens, portes, filets. Tout dessiné à la main.
   ============================================================ */

/* ---------- Bouton primaire (CTA "acte") ---------- */

.btn-primary {
  display: inline-block;
  padding: 22px 48px;
  border: 1.5px solid var(--galaad-ink);
  border-radius: 0;
  background: transparent;
  color: var(--galaad-ink);
  font-family: var(--font-voice);
  font-weight: 500;
  font-size: 22px;
  letter-spacing: 0;
  text-decoration: none;
  cursor: pointer;
  transition: background-color 400ms ease-out, color 400ms ease-out;
}

.btn-primary:hover,
.btn-primary:focus-visible {
  background-color: var(--galaad-ink);
  color: var(--galaad-cream);
}

/* Version inversée sur fond encre */
.section--ink .btn-primary {
  border-color: var(--galaad-cream);
  color: var(--galaad-cream);
}

.section--ink .btn-primary:hover,
.section--ink .btn-primary:focus-visible {
  background-color: var(--galaad-cream);
  color: var(--galaad-ink);
}

/* ---------- Lien secondaire (italique, souligné) ---------- */

.link-secondary {
  display: inline-block;
  padding: 22px 0;
  font-family: var(--font-voice);
  font-weight: 400;
  font-style: italic;
  font-size: 22px;
  color: var(--galaad-ink);
  text-decoration: none;
  border-bottom: 1px solid var(--galaad-rule-strong);
  transition: border-bottom-color 400ms ease-out;
}

.link-secondary:hover,
.link-secondary:focus-visible {
  border-bottom-color: var(--galaad-ink);
}

.link-secondary__arrow {
  display: inline-block;
  margin-left: var(--space-8);
  transition: transform 300ms ease-out;
}

.link-secondary:hover .link-secondary__arrow,
.link-secondary:focus-visible .link-secondary__arrow {
  transform: translateX(4px);
}

/* ---------- Lien inline (dans paragraphe) ---------- */

.link-inline {
  color: var(--galaad-ink);
  text-decoration: underline;
  text-decoration-thickness: 1px;
  text-underline-offset: 0.15em;
  text-decoration-color: var(--galaad-rule-strong);
  transition: text-decoration-color 300ms ease-out;
}

.link-inline:hover,
.link-inline:focus-visible {
  text-decoration-color: var(--galaad-accent);
}

/* ---------- Porte (Section 04) ---------- */

.doors {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0;
  margin-top: var(--space-80);
}

@media (max-width: 720px) {
  .doors {
    grid-template-columns: 1fr;
  }
}

.door {
  position: relative;
  padding: var(--space-40) var(--space-24) var(--space-40);
  border-top: 1.5px solid var(--galaad-ink);
  text-decoration: none;
  color: inherit;
  transition: background-color 300ms ease-out;
  cursor: pointer;
}

.door:hover,
.door:focus-visible {
  background-color: rgba(15, 20, 25, 0.03);
}

.door:nth-child(1),
.door:nth-child(3) {
  border-right: 1px solid var(--galaad-rule);
}

.door:nth-child(3),
.door:nth-child(4) {
  border-top: 1px solid var(--galaad-rule);
}

@media (max-width: 720px) {
  .door {
    border-right: none !important;
  }
  .door:nth-child(n+2) {
    border-top: 1px solid var(--galaad-rule);
  }
}

.door__num {
  font-family: var(--font-mono);
  font-size: 13px;
  font-weight: 500;
  color: var(--galaad-ink-soft);
  letter-spacing: 0.08em;
}

.door__title {
  font-family: var(--font-voice);
  font-weight: 500;
  font-size: 42px;
  line-height: 1.0;
  color: var(--galaad-ink);
  margin-top: var(--space-16);
  letter-spacing: -0.01em;
}

.door__desc {
  font-family: var(--font-voice);
  font-weight: 400;
  font-style: italic;
  font-size: 19px;
  line-height: 1.5;
  color: var(--galaad-ink-soft);
  margin-top: var(--space-16);
  max-width: 440px;
}

.door__arrow {
  position: absolute;
  right: var(--space-24);
  top: calc(var(--space-40) + 4px);
  font-family: var(--font-voice);
  font-size: 22px;
  color: var(--galaad-ink);
  transition: transform 300ms ease-out;
}

.door:hover .door__arrow,
.door:focus-visible .door__arrow {
  transform: translateX(6px);
}

/* ---------- Filet séparateur ---------- */

.rule {
  border: none;
  border-top: 1px solid var(--galaad-rule-strong);
  margin: var(--space-40) 0;
}

.section--ink .rule {
  border-top-color: rgba(250, 247, 240, 0.22);
}
