/* ODDEYE — Design System Showcase
   Design read: microsite interno de marca para el equipo ODDEYE, lenguaje editorial /
   ancestral, base oscura fija (Ancestral), acento único (Púrpura fenicio),
   display Menorca + Plus Jakarta Sans.
   Dials: DESIGN_VARIANCE 8, MOTION_INTENSITY 5, VISUAL_DENSITY 3. */

*, *::before, *::after { box-sizing: border-box; }

html { scroll-behavior: smooth; overflow-anchor: none; }

@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
}

body {
  margin: 0;
  background: var(--color-bg);
  color: var(--color-fg);
  font-family: var(--font-body);
  font-size: 16px;
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
}

img { max-width: 100%; display: block; }

a { color: inherit; }

h1, h2, h3, p, ol, ul, blockquote, figure { margin: 0; }

.skip-link {
  position: absolute;
  left: -9999px;
  top: 0;
  background: var(--color-accent);
  color: var(--color-bg);
  padding: var(--space-1) var(--space-2);
  z-index: 100;
  font-weight: 700;
}
.skip-link:focus { left: var(--space-2); top: var(--space-2); }

:focus-visible {
  outline: 2px solid var(--color-accent-text);
  outline-offset: 3px;
}

.section__inner {
  max-width: var(--container-max);
  margin: 0 auto;
  padding-left: var(--container-pad);
  padding-right: var(--container-pad);
}

/* ------------------------------------------------------------------ */
/* NAV                                                                 */
/* ------------------------------------------------------------------ */
.site-nav {
  position: sticky;
  top: 0;
  z-index: 50;
  background: rgb(13 11 9 / 0.82);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
  border-bottom: var(--border-hairline);
}

.site-nav__inner {
  max-width: var(--container-max);
  margin: 0 auto;
  padding: 0 var(--container-pad);
  height: 68px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-3);
}

.site-nav__mark {
  display: flex;
  align-items: center;
  gap: var(--space-1);
  text-decoration: none;
  font-family: var(--font-display);
  text-transform: uppercase;
  font-size: 1.15rem;
  letter-spacing: 0.02em;
  color: var(--color-fg);
  flex-shrink: 0;
}
.site-nav__mark img { filter: invert(94%); transform: translateY(-3.5px); }

.site-nav__links {
  display: flex;
  gap: var(--space-4);
}
.site-nav__links a {
  text-decoration: none;
  font-size: var(--type-small);
  font-weight: 600;
  color: var(--color-fg-muted);
  padding: 0.4rem 0.1rem;
  border-bottom: 1px solid transparent;
  transition: color var(--duration-fast) var(--ease-out), border-color var(--duration-fast) var(--ease-out);
  white-space: nowrap;
}
.site-nav__links a:hover,
.site-nav__links a.is-active {
  color: var(--color-fg);
  border-bottom-color: var(--color-accent);
}

.site-nav__toggle {
  display: none;
  background: none;
  border: var(--border-hairline);
  border-radius: var(--radius-sm);
  color: var(--color-fg);
  width: 40px;
  height: 40px;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  font-size: 1.35rem;
}

.site-nav__mobile {
  display: none;
  flex-direction: column;
  padding: var(--space-2) var(--container-pad) var(--space-3);
  border-top: var(--border-hairline);
}
.site-nav__mobile a {
  text-decoration: none;
  color: var(--color-fg);
  font-size: var(--type-body-lg);
  padding: var(--space-2) 0;
  border-bottom: var(--border-hairline);
}
.site-nav__mobile a:last-child { border-bottom: none; }

.site-nav.is-open .site-nav__mobile { display: flex; }

@media (max-width: 860px) {
  .site-nav__links { display: none; }
  .site-nav__toggle { display: flex; }
}

/* ------------------------------------------------------------------ */
/* HERO                                                                 */
/* ------------------------------------------------------------------ */
.hero {
  padding-top: clamp(var(--space-6), 10vh, var(--space-7));
  padding-bottom: var(--space-8);
  overflow: hidden;
}

.hero__inner {
  max-width: var(--container-max);
  margin: 0 auto;
  padding: 0 var(--container-pad);
  display: grid;
  grid-template-columns: 1.1fr 0.9fr;
  align-items: center;
  gap: var(--space-6);
}

.hero__headline {
  font-family: var(--font-display);
  text-transform: uppercase;
  font-size: clamp(2rem, 5vw, 4.5rem);
  line-height: 1.2;
  font-weight: 400;
  letter-spacing: -0.005em;
  color: var(--color-fg);
  max-width: 15ch;
}

.hero__sub {
  margin-top: var(--space-3);
  font-size: var(--type-body-lg);
  color: var(--color-fg-muted);
  max-width: 42ch;
}

.hero__actions {
  margin-top: var(--space-4);
  display: flex;
  gap: var(--space-2);
  flex-wrap: wrap;
}

.hero__visual {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
}
.hero__visual::before {
  content: '';
  position: absolute;
  top: 50%;
  left: 50%;
  width: clamp(320px, 60vw, 640px);
  height: clamp(320px, 60vw, 640px);
  transform: translate(-50%, -50%);
  background: radial-gradient(circle, #3D2B1F 0%, rgb(61 43 31 / 0.5) 45%, transparent 75%);
  z-index: -1;
}

.hero__isotipo {
  display: block;
  width: min(380px, 100%);
  height: auto;
  opacity: 0.94;
  filter: drop-shadow(0 30px 70px rgb(196 163 90 / 0.3));
  overflow: visible;
}
.hero__isotipo path {
  fill: #C4A35A;
  transform-box: fill-box;
  transform-origin: 50% 50%;
}

@media (prefers-reduced-motion: no-preference) {
  .hero__isotipo path {
    opacity: 0;
    animation: concentric-pulse 0.6s cubic-bezier(0.16, 1, 0.3, 1) both;
  }
  .hero__isotipo path.hero__isotipo-dot   { animation-delay: 0s; }
  .hero__isotipo path.hero__isotipo-ring  { animation-delay: 0.12s; }
  .hero__isotipo path.hero__isotipo-arm   { animation-delay: 0.24s; }
  .hero__isotipo path.hero__isotipo-outer { animation-delay: 0.36s; }
  .hero__isotipo { animation: spark-spin 90s linear infinite; animation-delay: 1s; }
}
@media (prefers-reduced-motion: reduce) {
  .hero__isotipo path { opacity: 1; }
}
@keyframes concentric-pulse {
  0% { opacity: 0; transform: scale(0.4); }
  55% { opacity: 1; transform: scale(1.12); }
  100% { opacity: 1; transform: scale(1); }
}
@keyframes spark-spin {
  to { transform: rotate(360deg); }
}

@media (max-width: 900px) {
  .hero__inner { grid-template-columns: 1fr; }
  .hero__visual { order: -1; }
  .hero__isotipo { width: min(260px, 60vw); }
}

/* ------------------------------------------------------------------ */
/* SECTIONS (general)                                                   */
/* ------------------------------------------------------------------ */
.section {
  padding: var(--space-8) 0;
  border-top: var(--border-hairline);
}
.section--tight { padding: var(--space-7) 0; }

.section__title {
  font-family: var(--font-display);
  text-transform: uppercase;
  font-size: var(--type-h1);
  line-height: 1.2;
  font-weight: 400;
  letter-spacing: -0.01em;
  max-width: 16ch;
}

.lede {
  margin-top: var(--space-3);
  font-size: var(--type-body-lg);
  color: var(--color-fg-muted);
  max-width: 60ch;
}

.footnote {
  margin-top: var(--space-5);
  font-size: var(--type-small);
  color: var(--color-fg-muted);
  max-width: 56ch;
  border-top: var(--border-hairline);
  padding-top: var(--space-3);
}

.closing-note {
  margin-top: var(--space-6);
  font-size: var(--type-body-lg);
  color: var(--color-fg-muted);
  max-width: 62ch;
}

/* reveal-on-scroll: opacity/transform only, respects reduced motion */
.reveal {
  opacity: 0;
  transform: translateY(20px);
}
.reveal.is-visible {
  opacity: 1;
  transform: none;
  transition: opacity var(--duration-slow) var(--ease-out), transform var(--duration-slow) var(--ease-out);
}
@media (prefers-reduced-motion: reduce) {
  .reveal { opacity: 1; transform: none; }
}

/* ------------------------------------------------------------------ */
/* HISTORIA — ref cards                                                 */
/* ------------------------------------------------------------------ */
.ref-card {
  background: var(--color-bg-overlay);
  border: var(--border-hairline);
  border-radius: var(--radius-md);
  overflow: hidden;
}

.ref-card--featured {
  margin-top: var(--space-6);
  display: grid;
  grid-template-columns: 0.9fr 1.1fr;
  align-items: stretch;
}
.ref-card--featured .ref-card__media { min-height: 320px; }
.ref-card--featured .ref-card__body { padding: var(--space-5); display: flex; flex-direction: column; justify-content: center; gap: var(--space-1); }

.ref-card__media { position: relative; }
.ref-card__media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  filter: grayscale(15%) contrast(1.05) saturate(0.9);
}
.ref-card__media--tall { aspect-ratio: 4 / 3; }
.ref-card__media--tall img { aspect-ratio: 4 / 3; }

.ref-card-duo {
  margin-top: var(--space-3);
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-3);
}
.ref-card-duo .ref-card__body { padding: var(--space-4); display: flex; flex-direction: column; gap: var(--space-1); }

.ref-card__palette-tag {
  align-self: flex-start;
  font-size: var(--type-micro);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  padding: 0.3rem 0.65rem;
  border-radius: var(--radius-pill);
  margin-bottom: var(--space-1);
}
.ref-card__palette-tag--ancestral { background: rgb(135 81 244 / 0.16); color: var(--color-accent-text); }
.ref-card__palette-tag--mediterraneo { background: rgb(74 124 142 / 0.22); color: #8FC0D1; }
.ref-card__palette-tag--solar { background: rgb(240 192 64 / 0.18); color: #F0C040; }

.ref-card__founder {
  font-family: var(--font-display);
  text-transform: uppercase;
  font-size: var(--type-h3);
  font-weight: 400;
}
.ref-card__ref {
  font-size: var(--type-small);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--color-gold);
}
.ref-card__text {
  color: var(--color-fg-muted);
  max-width: 46ch;
}

@media (max-width: 760px) {
  .ref-card--featured { grid-template-columns: 1fr; }
  .ref-card--featured .ref-card__media { min-height: 220px; }
  .ref-card-duo { grid-template-columns: 1fr; }
}

/* pull quote */
.pull-quote {
  margin-top: var(--space-7);
  padding-top: var(--space-6);
  border-top: var(--border-hairline);
  display: grid;
  grid-template-columns: 1.4fr 0.8fr;
  gap: var(--space-5);
  align-items: end;
}
.pull-quote blockquote p {
  font-family: var(--font-display);
  text-transform: uppercase;
  font-size: clamp(1.75rem, 4vw, 3rem);
  line-height: 1.2;
  color: var(--color-fg);
  max-width: 18ch;
}
.pull-quote figcaption {
  display: flex;
  align-items: center;
  gap: var(--space-2);
}
.pull-quote figcaption img {
  width: 100px;
  height: 100px;
  object-fit: cover;
  border-radius: var(--radius-sm);
  flex-shrink: 0;
}
.pull-quote figcaption span {
  font-size: var(--type-small);
  color: var(--color-fg-muted);
}

@media (max-width: 760px) {
  .pull-quote { grid-template-columns: 1fr; }
}

/* ------------------------------------------------------------------ */
/* VIBES                                                                */
/* ------------------------------------------------------------------ */
.vibes-list {
  list-style: none;
  padding: 0;
  margin-top: var(--space-6);
}
.vibes-list__item {
  display: grid;
  grid-template-columns: 90px 1fr;
  gap: var(--space-4);
  padding: var(--space-4) 0;
  border-top: var(--border-hairline);
}
.vibes-list__item:last-child { border-bottom: var(--border-hairline); }
.vibes-list__num {
  font-family: var(--font-display);
  text-transform: uppercase;
  font-size: 1.5rem;
  color: var(--color-gold);
}
.vibes-list__item h3 {
  font-family: var(--font-accent);
  font-style: italic;
  font-weight: 600;
  font-size: calc(var(--type-h3) * 1.15);
  margin-bottom: var(--space-1);
}
.vibes-list__item p {
  color: var(--color-fg-muted);
  max-width: 60ch;
}

@media (max-width: 600px) {
  .vibes-list__item { grid-template-columns: 1fr; gap: var(--space-1); }
}

/* ------------------------------------------------------------------ */
/* TIPOGRAFÍA                                                           */
/* ------------------------------------------------------------------ */
.type-specimen {
  margin-top: var(--space-6);
  padding: var(--space-6) 0;
  border-top: var(--border-hairline);
}
.type-specimen__display {
  font-family: var(--font-display);
  text-transform: uppercase;
  font-size: clamp(5rem, 18vw, 11rem);
  line-height: 0.85;
  font-weight: 400;
  color: var(--color-fg);
}
.type-specimen__display--sans { font-family: var(--font-body); font-weight: 800; }
.type-specimen__display--accent {
  font-family: var(--font-accent);
  font-style: italic;
  font-weight: 500;
  text-transform: none;
  line-height: 1.1;
  padding-bottom: 0.08em;
}
.type-specimen__sample--accent { font-family: var(--font-accent); font-style: italic; font-weight: 600; font-size: var(--type-h1); line-height: 1.2; padding-bottom: 0.1em; }
.type-specimen__word {
  font-family: var(--font-display);
  text-transform: uppercase;
  font-size: clamp(2rem, 6vw, 4rem);
  letter-spacing: 0.03em;
  color: var(--color-accent-text);
  margin-top: var(--space-2);
}
.type-specimen__sample {
  font-size: var(--type-h3);
  font-weight: 500;
  max-width: 40ch;
  margin-top: var(--space-2);
}
.type-specimen__meta {
  margin-top: var(--space-3);
  color: var(--color-fg-muted);
  font-size: var(--type-small);
  max-width: 56ch;
}

.type-pairing {
  margin-top: var(--space-2);
}
.type-pairing__row {
  display: grid;
  grid-template-columns: 60px 1fr auto;
  align-items: center;
  gap: var(--space-3);
  padding: var(--space-3) 0;
  border-top: var(--border-hairline);
}
.type-pairing__num { font-family: var(--font-display); text-transform: uppercase; color: var(--color-gold); }
.type-pairing__role { font-weight: 600; }
.type-pairing__font { color: var(--color-fg-muted); font-size: var(--type-small); text-align: right; }

@media (max-width: 600px) {
  .type-pairing__row { grid-template-columns: 40px 1fr; }
  .type-pairing__font { grid-column: 2; text-align: left; }
}

/* ------------------------------------------------------------------ */
/* COLOR                                                                */
/* ------------------------------------------------------------------ */
.palette-block {
  margin-top: var(--space-6);
  padding-top: var(--space-5);
  border-top: var(--border-hairline);
}
.palette-block__head h3 {
  font-family: var(--font-display);
  text-transform: uppercase;
  font-size: var(--type-h2);
  font-weight: 400;
}
.palette-block__head p {
  color: var(--color-fg-muted);
  margin-top: 0.25rem;
  max-width: 56ch;
}

.swatch-row {
  margin-top: var(--space-3);
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
  gap: var(--space-2);
}

.palette-showcase {
  margin-top: var(--space-3);
  border-radius: var(--radius-md);
  padding: var(--space-5);
  display: grid;
  grid-template-columns: 1.3fr 0.7fr;
  grid-template-areas:
    "logos  tiles"
    "caption caption";
  gap: var(--space-4);
  align-items: start;
}

.palette-showcase__logos {
  grid-area: logos;
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
  justify-content: center;
  min-height: 140px;
}
.mark-logo {
  display: block;
  width: min(220px, 80%);
  aspect-ratio: 331.94 / 106.24;
  background-color: var(--mark-color);
  -webkit-mask-image: url('../assets/logo/isologo-horizontal.svg');
  mask-image: url('../assets/logo/isologo-horizontal.svg');
  -webkit-mask-repeat: no-repeat;
  mask-repeat: no-repeat;
  -webkit-mask-size: contain;
  mask-size: contain;
  -webkit-mask-position: left center;
  mask-position: left center;
}

.palette-showcase__tiles {
  grid-area: tiles;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-2);
}
.mark-tile {
  position: relative;
  aspect-ratio: 1;
  border-radius: var(--radius-sm);
}
.mark-tile::after {
  content: '';
  position: absolute;
  inset: 24%;
  background-color: var(--mark-color);
  -webkit-mask-image: url('../assets/logo/brandmark.svg');
  mask-image: url('../assets/logo/brandmark.svg');
  -webkit-mask-repeat: no-repeat;
  mask-repeat: no-repeat;
  -webkit-mask-size: contain;
  mask-size: contain;
  -webkit-mask-position: center;
  mask-position: center;
}

.palette-showcase__caption {
  grid-area: caption;
  padding-top: var(--space-3);
  border-top: 1px solid currentColor;
  opacity: 0.94;
}
.palette-showcase__caption h4 {
  font-family: var(--font-body);
  text-transform: uppercase;
  font-weight: 800;
  font-size: var(--type-small);
  letter-spacing: 0.03em;
}
.palette-showcase__caption p {
  margin-top: var(--space-1);
  font-size: var(--type-small);
  max-width: 60ch;
  opacity: 0.85;
}

@media (max-width: 700px) {
  .palette-showcase {
    grid-template-columns: 1fr;
    grid-template-areas: "logos" "tiles" "caption";
  }
  .palette-showcase__tiles { grid-template-columns: repeat(4, 1fr); max-width: 240px; }
}

.swatch {
  position: relative;
  background: var(--sw);
  color: inherit;
  border: 1px solid rgb(239 230 223 / 0.14);
  border-radius: var(--radius-md);
  aspect-ratio: 1.4 / 1;
  padding: var(--space-2);
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  gap: 0.2rem;
  cursor: pointer;
  text-align: left;
  font-family: var(--font-body);
  transition: transform var(--duration-fast) var(--ease-out);
}
.swatch:hover { transform: translateY(-3px); }
.swatch:active { transform: scale(0.98); }
.swatch span { font-weight: 700; font-size: var(--type-small); }
.swatch__copy-icon {
  position: absolute;
  top: var(--space-1);
  right: var(--space-1);
  font-size: 0.95rem;
  opacity: 0.5;
  transition: opacity var(--duration-fast) var(--ease-out);
}
.swatch:hover .swatch__copy-icon { opacity: 0.9; }
.swatch code { font-size: var(--type-micro); opacity: 0.75; }

/* ------------------------------------------------------------------ */
/* ISOTIPO                                                              */
/* ------------------------------------------------------------------ */
.lockup-grid {
  margin-top: var(--space-6);
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--space-3);
}
.lockup-card {
  background: var(--color-bg-overlay);
  border: var(--border-hairline);
  border-radius: var(--radius-md);
  padding: var(--space-4);
  text-align: center;
}
.lockup-card__media {
  height: 120px;
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: var(--space-3);
}
.lockup-card__media img { max-height: 100%; width: auto; filter: invert(94%); }
.lockup-card p {
  font-size: var(--type-small);
  font-weight: 600;
  color: var(--color-fg-muted);
}

@media (max-width: 980px) {
  .lockup-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 540px) {
  .lockup-grid { grid-template-columns: 1fr; }
}

.spec-tiles {
  margin-top: var(--space-6);
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(190px, 1fr));
  gap: 0;
  border-top: var(--border-hairline);
  border-left: var(--border-hairline);
}
.spec-tile {
  border-right: var(--border-hairline);
  border-bottom: var(--border-hairline);
  padding: var(--space-4);
  display: flex;
  flex-direction: column;
  gap: var(--space-1);
}
.spec-tile__num {
  font-family: var(--font-display);
  text-transform: uppercase;
  font-size: var(--type-h2);
  color: var(--color-accent-text);
}
.spec-tile__label {
  font-size: var(--type-small);
  color: var(--color-fg-muted);
}

/* ------------------------------------------------------------------ */
/* CLAIM                                                                */
/* ------------------------------------------------------------------ */
.claim {
  padding: var(--space-8) 0;
  border-top: var(--border-hairline);
  text-align: center;
}
.claim__line {
  font-family: var(--font-accent);
  font-style: italic;
  font-weight: 500;
  font-size: clamp(2.5rem, 8vw, 6rem);
  line-height: 1.2;
  padding-bottom: 0.15em;
}
.claim__note {
  margin: var(--space-3) auto 0;
  max-width: 46ch;
  color: var(--color-fg-muted);
  font-size: var(--type-small);
}

/* ------------------------------------------------------------------ */
/* COMPONENTES                                                          */
/* ------------------------------------------------------------------ */
.component-grid {
  margin-top: var(--space-6);
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-3);
}
.component-tile {
  background: var(--color-bg-overlay);
  border: var(--border-hairline);
  border-radius: var(--radius-md);
  padding: var(--space-4);
}
.component-tile__label {
  font-size: var(--type-small);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--color-fg-muted);
  margin-bottom: var(--space-3);
}
.component-tile__row {
  display: flex;
  gap: var(--space-2);
  align-items: center;
}
.component-tile__row--wrap { flex-wrap: wrap; }

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

/* buttons */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  font-family: var(--font-body);
  font-weight: 700;
  font-size: var(--type-small);
  padding: 0.85rem 1.4rem;
  border-radius: var(--radius-sm);
  border: 1px solid transparent;
  text-decoration: none;
  cursor: pointer;
  transition: transform var(--duration-fast) var(--ease-out), background var(--duration-fast) var(--ease-out), border-color var(--duration-fast) var(--ease-out);
  white-space: nowrap;
}
.btn:active { transform: scale(0.97); }

.btn--primary {
  background: var(--color-fg);
  color: var(--color-bg);
}
.btn--primary:hover { background: var(--color-accent-text); color: var(--color-bg); }

.btn--secondary {
  background: transparent;
  color: var(--color-fg);
  border-color: var(--color-border);
}
.btn--secondary:hover { border-color: var(--color-accent); color: var(--color-accent-text); }

.btn--ghost {
  background: transparent;
  color: var(--color-accent-text);
  border-color: var(--color-accent);
}
.btn--ghost:hover { background: rgb(135 81 244 / 0.12); }

.btn--text {
  background: transparent;
  color: var(--color-fg-muted);
  padding-left: 0.2rem;
  padding-right: 0.2rem;
}
.btn--text:hover { color: var(--color-fg); }

/* tags */
.tag {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  background: var(--color-bg);
  border: var(--border-hairline);
  color: var(--color-fg);
  border-radius: var(--radius-pill);
  padding: 0.45rem 0.9rem 0.45rem 0.6rem;
  font-size: var(--type-small);
  font-weight: 600;
}
.tag i { font-size: 1.05em; color: var(--color-accent-text); }

/* form field */
.field { display: flex; flex-direction: column; gap: 0.4rem; }
.field label { font-size: var(--type-small); font-weight: 700; }
.field input {
  font-family: var(--font-body);
  font-size: var(--type-body);
  background: var(--color-bg);
  border: var(--border-hairline);
  border-radius: var(--radius-sm);
  padding: 0.75rem 0.9rem;
  color: var(--color-fg);
}
.field input::placeholder { color: var(--color-fg-muted); }
.field input:focus { border-color: var(--color-accent); outline: none; }
.field__help { font-size: var(--type-micro); color: var(--color-fg-muted); }

/* demo card */
.demo-card {
  background: var(--color-bg);
  border: var(--border-hairline);
  border-radius: var(--radius-md);
  padding: var(--space-3);
}
.demo-card__eyebrow {
  font-size: var(--type-micro);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--color-gold);
}
.demo-card h3 {
  font-family: var(--font-display);
  text-transform: uppercase;
  font-size: var(--type-h3);
  font-weight: 400;
  margin-top: var(--space-1);
}
.demo-card p {
  color: var(--color-fg-muted);
  margin-top: var(--space-1);
  font-size: var(--type-small);
}

/* ------------------------------------------------------------------ */
/* FOOTER                                                               */
/* ------------------------------------------------------------------ */
.site-footer {
  border-top: var(--border-hairline);
  padding: var(--space-5) 0;
}
.site-footer__inner {
  max-width: var(--container-max);
  margin: 0 auto;
  padding: 0 var(--container-pad);
  display: flex;
  align-items: center;
  gap: var(--space-2);
}
.site-footer p {
  font-size: var(--type-small);
  color: var(--color-fg-muted);
}
.site-footer__inner img { filter: invert(94%); }

/* ------------------------------------------------------------------ */
/* TOAST                                                                */
/* ------------------------------------------------------------------ */
.toast {
  position: fixed;
  left: 50%;
  bottom: var(--space-4);
  transform: translate(-50%, 12px);
  background: var(--color-fg);
  color: var(--color-bg);
  font-size: var(--type-small);
  font-weight: 700;
  padding: 0.7rem 1.1rem;
  border-radius: var(--radius-pill);
  opacity: 0;
  pointer-events: none;
  transition: opacity var(--duration-base) var(--ease-out), transform var(--duration-base) var(--ease-out);
  z-index: 200;
}
.toast.is-visible {
  opacity: 1;
  transform: translate(-50%, 0);
}
