/* =============================================================================
   Coming Soon — orchestrazione layout
   Usa SOLO i token definiti in color.css e typography.css.
   Niente colori/font/dimensioni hardcoded.
   ============================================================================= */

/* Reset essenziale */
*, *::before, *::after { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }

/* ---------- BODY ---------- */
body {
  font-family: var(--font-sans);
  color: var(--color-text-primary);
  background-color: var(--color-bg);
  min-height: 100dvh;
  display: flex;
  flex-direction: column;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-rendering: optimizeLegibility;
}

/* ---------- HEADER ---------- */
.site-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--space-4); /* 24px */
}

.brand {
  display: inline-flex;
  align-items: center;
  text-decoration: none;
  border-radius: 4px;
}

.brand-logo {
  display: block;
  height: 56px;
  width: auto;
}

/* Swap logo light/dark — default mostra il logo nero su chiaro */
.brand-logo--dark { display: none; }

@media (prefers-color-scheme: dark) {
  .brand-logo--light { display: none; }
  .brand-logo--dark  { display: block; }
}

/* Override manuale via classe .dark (toggle utente — vince sul media query) */
html.dark .brand-logo--light { display: none; }
html.dark .brand-logo--dark  { display: block; }

/* In light mode forzato (override esplicito), ripristina il nero */
html:not(.dark) .brand-logo--light { display: block; }
html:not(.dark) .brand-logo--dark  { display: none; }

/* ---------- THEME TOGGLE ---------- */
.theme-toggle {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 36px;
  height: 36px;
  padding: 0;
  border: none;
  border-radius: 9999px;
  background: transparent;
  color: var(--ghost-text);
  cursor: pointer;
  transition: background-color 150ms ease, color 150ms ease;
}
.theme-toggle:hover {
  background-color: var(--ghost-bg-hover);
  color: var(--ghost-text-hover);
}
.theme-toggle:active {
  background-color: var(--ghost-bg-active);
}

/* Visibilità icona in base al tema */
.theme-toggle .icon-moon { display: none; }
.theme-toggle .icon-sun  { display: block; }

@media (prefers-color-scheme: dark) {
  .theme-toggle .icon-sun  { display: none; }
  .theme-toggle .icon-moon { display: block; }
}

html.dark .theme-toggle .icon-sun  { display: none; }
html.dark .theme-toggle .icon-moon { display: block; }

html:not(.dark) .theme-toggle .icon-sun  { display: block; }
html:not(.dark) .theme-toggle .icon-moon { display: none; }

/* ---------- MAIN HERO ---------- */
.hero {
  flex: 1;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  justify-content: center;
  width: 100%;
  max-width: 720px;
  margin: 0 auto;
  padding: var(--space-5) var(--space-4); /* 32px 24px */
  gap: var(--space-3); /* 16px */
}

.eyebrow {
  margin: 0;
  color: var(--type-eyebrow);
}

.title {
  margin: 0;
  color: var(--type-display);
}

.subtitle {
  margin: 0;
  color: var(--type-h2);
}

.lead {
  margin: 0;
  color: var(--type-body);
  /* il DS imposta max-width: 70ch su .text-body, va bene */
}

/* Blocco contatti: email + telefono + indirizzo */
.contacts {
  margin: var(--space-2) 0 0; /* 12px sopra */
  font-style: normal; /* override default di <address> */
  display: flex;
  flex-direction: column;
  gap: var(--space-1); /* 8px tra le righe */
}

.contact-line {
  margin: 0;
  color: var(--color-text-primary);
}

.contact-address {
  margin: var(--space-2) 0 0; /* 12px di stacco dall'ultima riga di contatto */
  color: var(--color-text-caption);
}

/* Link inline coerente col DS */
.link-inline {
  color: var(--link-inline-text);
  text-decoration: underline;
  text-decoration-color: var(--link-inline-underline);
  text-underline-offset: 3px;
  text-decoration-thickness: 1px;
  padding: 2px 4px;
  margin: -2px -4px;
  border-radius: 4px;
  transition: background-color 120ms ease;
}
.link-inline:hover {
  background-color: var(--link-inline-bg-hover);
}

/* ---------- FOOTER ---------- */
.site-footer {
  padding: var(--space-4); /* 24px */
  text-align: center;
}

.site-footer p {
  margin: 0;
  color: var(--color-text-caption);
}

/* ---------- RIDUZIONE MOVIMENTO ---------- */
@media (prefers-reduced-motion: reduce) {
  .theme-toggle,
  .link-inline {
    transition: none;
  }
}
