/* Company 31 — components */

/* Hero */
.hero { padding-block: var(--c31-space-10) var(--c31-space-9); }
.hero__eyebrow {
  display: inline-block;
  color: var(--c31-text-muted);
  font-size: var(--c31-fs-sm);
  font-weight: 500;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  margin-block-end: var(--c31-space-5);
}
.hero__title {
  max-inline-size: 18ch;
  margin-block-end: var(--c31-space-5);
}
.hero__lead {
  max-inline-size: 60ch;
  font-size: var(--c31-fs-md);
  color: var(--c31-text-soft);
  margin-block-end: var(--c31-space-6);
}
.hero__actions {
  display: inline-flex;
  flex-wrap: wrap;
  gap: var(--c31-space-4);
}

/* Buttons */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--c31-space-2);
  padding: var(--c31-space-3) var(--c31-space-5);
  border-radius: var(--c31-radius-pill);
  font-weight: 500;
  font-size: var(--c31-fs-sm);
  line-height: 1.2;
  transition: background-color var(--c31-dur) var(--c31-ease), color var(--c31-dur) var(--c31-ease), transform var(--c31-dur) var(--c31-ease), box-shadow var(--c31-dur) var(--c31-ease);
  text-align: center;
}
.btn:hover { transform: translateY(-1px); }
.btn:active { transform: translateY(0); }

.btn--primary {
  background: var(--c31-accent);
  color: var(--c31-palette-white);
  box-shadow: 0 1px 2px rgba(37, 99, 235, 0.18);
}
.btn--primary:hover { background: var(--c31-accent-hover); color: var(--c31-palette-white); }

.btn--ghost {
  background: transparent;
  color: var(--c31-text);
  border: 1px solid var(--c31-border-strong);
}
.btn--ghost:hover { background: var(--c31-bg-muted); color: var(--c31-text); }

/* Section headings */
.section-eyebrow {
  display: inline-block;
  color: var(--c31-text-muted);
  font-size: var(--c31-fs-sm);
  font-weight: 500;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  margin-block-end: var(--c31-space-4);
}
.section-lead {
  max-inline-size: 58ch;
  font-size: var(--c31-fs-md);
  color: var(--c31-text-soft);
  margin-block: var(--c31-space-4) var(--c31-space-7);
}

/* Discipline cards */
.card {
  background: var(--c31-surface);
  border: 1px solid var(--c31-border);
  border-radius: var(--c31-radius-lg);
  padding: var(--c31-space-6);
  display: flex;
  flex-direction: column;
  gap: var(--c31-space-4);
  transition: transform var(--c31-dur) var(--c31-ease), border-color var(--c31-dur) var(--c31-ease), box-shadow var(--c31-dur) var(--c31-ease);
}
.card:hover { transform: translateY(-4px); border-color: var(--c31-border-strong); box-shadow: var(--c31-shadow-lift); }
.card__number {
  color: var(--c31-accent);
  font-size: var(--c31-fs-sm);
  font-weight: 600;
  letter-spacing: 0.08em;
}
.card__title { font-size: var(--c31-fs-lg); }
.card__body { color: var(--c31-text-soft); font-size: var(--c31-fs-sm); }

.link-more {
  display: inline-flex;
  align-items: center;
  gap: var(--c31-space-2);
  color: var(--c31-accent);
  font-weight: 500;
  font-size: var(--c31-fs-sm);
  margin-block-start: auto;
  padding-block-start: var(--c31-space-3);
}
.link-more::after { content: " \2192"; transition: transform var(--c31-dur) var(--c31-ease); }
.link-more:hover::after { transform: translateX(3px); }
[dir="rtl"] .link-more::after { content: " \2190"; }
[dir="rtl"] .link-more:hover::after { transform: translateX(-3px); }

/* Principles list */
.principles {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--c31-space-6) var(--c31-space-7);
}
@media (max-inline-size: 820px) { .principles { grid-template-columns: 1fr; gap: var(--c31-space-6); } }
.principle__number {
  color: var(--c31-accent);
  font-size: var(--c31-fs-sm);
  font-weight: 600;
  letter-spacing: 0.08em;
  display: block;
  margin-block-end: var(--c31-space-2);
}
.principle__title {
  font-size: var(--c31-fs-md);
  margin-block-end: var(--c31-space-2);
}
.principle__body {
  color: var(--c31-text-soft);
  font-size: var(--c31-fs-sm);
}

/* Pull quote */
.pull-quote {
  background: var(--c31-bg-subtle);
  border-inline-start: 4px solid var(--c31-accent);
  padding: var(--c31-space-6) var(--c31-space-7);
  border-radius: var(--c31-radius-md);
  max-inline-size: 60ch;
  margin-inline: auto;
}
.pull-quote__text {
  font-size: var(--c31-fs-lg);
  font-style: italic;
  color: var(--c31-text);
  line-height: 1.45;
}
.pull-quote__cite {
  display: block;
  margin-block-start: var(--c31-space-4);
  font-size: var(--c31-fs-sm);
  color: var(--c31-text-muted);
  font-style: normal;
}

/* Practice deep sections */
.practice-section {
  padding-block: var(--c31-space-8);
  border-block-end: 1px solid var(--c31-border);
}
.practice-section:last-child { border-block-end: 0; }
.practice-section__heading { margin-block-end: var(--c31-space-4); }
.practice-section__body { max-inline-size: 72ch; }
.practice-section__body p + p { margin-block-start: var(--c31-space-4); }
.practice-section__tags {
  display: flex;
  flex-wrap: wrap;
  gap: var(--c31-space-2);
  margin-block-start: var(--c31-space-5);
}
.tag {
  display: inline-block;
  padding: var(--c31-space-2) var(--c31-space-4);
  border-radius: var(--c31-radius-pill);
  background: var(--c31-accent-soft);
  color: var(--c31-accent);
  font-size: var(--c31-fs-xs);
  font-weight: 500;
  letter-spacing: 0.02em;
}

/* Engagement cards on contact */
.engagement {
  background: var(--c31-surface);
  border: 1px solid var(--c31-border);
  border-radius: var(--c31-radius-lg);
  padding: var(--c31-space-6);
  display: flex;
  flex-direction: column;
  gap: var(--c31-space-3);
}
.engagement__title { font-size: var(--c31-fs-md); }
.engagement__body { color: var(--c31-text-soft); font-size: var(--c31-fs-sm); flex: 1; }

/* Privacy / long form content */
.prose { max-inline-size: 72ch; margin-inline: auto; }
.prose h2 { margin-block: var(--c31-space-7) var(--c31-space-4); font-size: var(--c31-fs-xl); }
.prose h3 { margin-block: var(--c31-space-6) var(--c31-space-3); font-size: var(--c31-fs-lg); }
.prose p { margin-block-start: var(--c31-space-4); }
.prose ul { margin-block-start: var(--c31-space-4); padding-inline-start: var(--c31-space-5); list-style: disc; }
.prose ul li { margin-block-start: var(--c31-space-2); color: var(--c31-text-soft); }
.prose table {
  width: 100%;
  margin-block-start: var(--c31-space-5);
  border-collapse: collapse;
  font-size: var(--c31-fs-sm);
}
.prose th, .prose td {
  padding: var(--c31-space-3) var(--c31-space-4);
  text-align: start;
  border-block-end: 1px solid var(--c31-border);
  vertical-align: top;
}
.prose th { color: var(--c31-text); font-weight: 600; background: var(--c31-bg-subtle); }
.prose td { color: var(--c31-text-soft); }
.prose a { text-decoration: underline; text-underline-offset: 3px; }
.prose code {
  font-family: ui-monospace, SFMono-Regular, Menlo, monospace;
  font-size: 0.92em;
  padding: 0.1em 0.4em;
  background: var(--c31-bg-muted);
  border-radius: var(--c31-radius-sm);
}

.legal-notice {
  padding: var(--c31-space-4) var(--c31-space-5);
  background: var(--c31-bg-subtle);
  border: 1px solid var(--c31-border);
  border-radius: var(--c31-radius-md);
  font-size: var(--c31-fs-sm);
  color: var(--c31-text-muted);
  margin-block-end: var(--c31-space-6);
}

/* Theme toggle & language switcher */
.icon-button {
  inline-size: 40px;
  block-size: 40px;
  border-radius: var(--c31-radius-pill);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: var(--c31-text);
  border: 1px solid transparent;
  transition: background-color var(--c31-dur-fast) var(--c31-ease), border-color var(--c31-dur-fast) var(--c31-ease), color var(--c31-dur-fast) var(--c31-ease);
}
.icon-button:hover { background: var(--c31-bg-muted); border-color: var(--c31-border); }
.icon-button svg { inline-size: 20px; block-size: 20px; }

.theme-toggle__sun { display: none; }
.theme-toggle__moon { display: block; }
:root[data-theme="dark"] .theme-toggle__sun { display: block; }
:root[data-theme="dark"] .theme-toggle__moon { display: none; }
@media (prefers-color-scheme: dark) {
  :root:not([data-theme]) .theme-toggle__sun { display: block; }
  :root:not([data-theme]) .theme-toggle__moon { display: none; }
}

/* Language switcher */
.lang-switcher { position: relative; }
.lang-switcher__button {
  display: inline-flex;
  align-items: center;
  gap: var(--c31-space-2);
  padding: var(--c31-space-2) var(--c31-space-4);
  border-radius: var(--c31-radius-pill);
  border: 1px solid var(--c31-border);
  color: var(--c31-text);
  font-size: var(--c31-fs-sm);
  font-weight: 500;
  transition: background-color var(--c31-dur-fast) var(--c31-ease), border-color var(--c31-dur-fast) var(--c31-ease);
}
.lang-switcher__button:hover { background: var(--c31-bg-muted); border-color: var(--c31-border-strong); }
.lang-switcher__button::after {
  content: " \25BE";
  font-size: 0.8em;
  color: var(--c31-text-muted);
}
.lang-switcher__menu {
  position: absolute;
  inset-block-start: calc(100% + 0.5rem);
  inset-inline-end: 0;
  min-inline-size: 220px;
  background: var(--c31-surface);
  border: 1px solid var(--c31-border);
  border-radius: var(--c31-radius-md);
  box-shadow: var(--c31-shadow-lift);
  padding: var(--c31-space-2);
  display: none;
  z-index: 30;
}
.lang-switcher.is-open .lang-switcher__menu { display: block; }
.lang-switcher__menu a {
  display: block;
  padding: var(--c31-space-2) var(--c31-space-4);
  border-radius: var(--c31-radius-sm);
  color: var(--c31-text);
  font-size: var(--c31-fs-sm);
}
.lang-switcher__menu a:hover { background: var(--c31-bg-muted); color: var(--c31-text); }
.lang-switcher__menu a[aria-current="true"] {
  color: var(--c31-accent);
  font-weight: 600;
}

/* Language suggestion banner */
.lang-suggest {
  position: fixed;
  inset-block-end: var(--c31-space-5);
  inset-inline-start: var(--c31-space-5);
  max-inline-size: 360px;
  background: var(--c31-surface);
  border: 1px solid var(--c31-border);
  border-radius: var(--c31-radius-md);
  box-shadow: var(--c31-shadow-lift);
  padding: var(--c31-space-4) var(--c31-space-5);
  display: none;
  flex-direction: column;
  gap: var(--c31-space-3);
  z-index: 50;
  font-size: var(--c31-fs-sm);
}
.lang-suggest.is-visible { display: flex; }
.lang-suggest__actions {
  display: flex;
  gap: var(--c31-space-3);
  flex-wrap: wrap;
}

/* Consent banner */
.consent {
  position: fixed;
  inset-block-end: var(--c31-space-5);
  inset-inline-end: var(--c31-space-5);
  max-inline-size: 440px;
  background: var(--c31-surface);
  border: 1px solid var(--c31-border);
  border-radius: var(--c31-radius-md);
  box-shadow: var(--c31-shadow-lift);
  padding: var(--c31-space-5);
  z-index: 60;
  display: none;
  flex-direction: column;
  gap: var(--c31-space-4);
}
.consent.is-visible { display: flex; }
.consent__title { font-size: var(--c31-fs-md); }
.consent__body { color: var(--c31-text-soft); font-size: var(--c31-fs-sm); }
.consent__actions {
  display: flex;
  gap: var(--c31-space-3);
  flex-wrap: wrap;
}
.consent__manage {
  display: none;
  flex-direction: column;
  gap: var(--c31-space-3);
  padding-block-start: var(--c31-space-4);
  border-block-start: 1px solid var(--c31-border);
}
.consent.is-managing .consent__manage { display: flex; }
.consent__option {
  display: flex;
  align-items: flex-start;
  gap: var(--c31-space-3);
  font-size: var(--c31-fs-sm);
}
.consent__option input { margin-block-start: 0.2em; }
.consent__option-text strong { display: block; color: var(--c31-text); }
.consent__option-text span { color: var(--c31-text-muted); }

@media (max-inline-size: 540px) {
  .consent {
    inset: auto 0 0 0;
    max-inline-size: none;
    border-radius: var(--c31-radius-md) var(--c31-radius-md) 0 0;
  }
  .lang-suggest {
    inset: auto 0 0 0;
    max-inline-size: none;
    border-radius: var(--c31-radius-md) var(--c31-radius-md) 0 0;
  }
}

/* Scroll reveal */
.reveal {
  opacity: 0;
  transform: translateY(14px);
  transition: opacity var(--c31-dur-slow) var(--c31-ease), transform var(--c31-dur-slow) var(--c31-ease);
}
.reveal.is-visible { opacity: 1; transform: none; }
@media (prefers-reduced-motion: reduce) {
  .reveal { opacity: 1; transform: none; }
}

/* 404 */
.notfound {
  min-block-size: 60vh;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  gap: var(--c31-space-5);
}
.notfound__code { font-size: var(--c31-fs-3xl); color: var(--c31-text-muted); }
.notfound__title { max-inline-size: 20ch; }

/* Utility */
.text-muted { color: var(--c31-text-muted); }
.mt-6 { margin-block-start: var(--c31-space-6); }
