/* ============================================================
   IPHIGENAI — sito / il diario
   Token e componenti dal design system Iphigenai
   (Newsreader serif · Hanken Grotesk sans · Spline Sans Mono)
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Newsreader:ital,opsz,wght@0,6..72,300..600;1,6..72,300..500&family=Hanken+Grotesk:wght@400;500;600;700;800&family=Spline+Sans+Mono:wght@400;500;600&display=swap');

/* ---------------- Tokens: colore ---------------- */
:root {
  --forest-50:  #E9F0EB;
  --forest-100: #D0E1D6;
  --forest-200: #A6C6B2;
  --forest-300: #74A188;
  --forest-400: #437A60;
  --forest-500: #235C45;
  --forest-600: #1A4A37;
  --forest-700: #133A2B;
  --forest-800: #0D2A20;
  --forest-900: #081B14;

  --gold-50:  #FAF2DA;
  --gold-100: #F2E2B2;
  --gold-200: #E7CD82;
  --gold-300: #DBB85A;
  --gold-400: #CBA23D;
  --gold-500: #BC9230;
  --gold-600: #98731F;
  --gold-700: #6F5414;

  --bone-0:   #FFFFFF;
  --bone-50:  #FAFAF6;
  --bone-100: #F2F2EC;
  --bone-150: #EAEAE2;
  --bone-200: #E0E0D6;
  --bone-300: #CCCCC0;
  --bone-400: #A9A99C;

  --ink-500:  #7E827A;
  --ink-600:  #5B5F57;
  --ink-700:  #43473F;
  --ink-800:  #2A2E27;
  --ink-900:  #161A14;
  --ink-950:  #0B0F0A;

  --green-100: #D6E7D4;
  --green-500: #3F7D52;
  --green-700: #2C5A3A;
  --red-100:   #F2D6CF;
  --red-500:   #B23A2E;
  --red-700:   #842419;

  /* Semantic */
  --surface-page:     var(--bone-50);
  --surface-card:     var(--bone-0);
  --text-primary:     var(--ink-900);
  --text-secondary:   var(--ink-700);
  --text-muted:       var(--ink-600);
  --text-faint:       var(--ink-500);
  --text-brand:       var(--forest-600);
  --text-gold:        var(--gold-600);
  --border-hairline:  var(--bone-200);
  --border-default:   var(--bone-300);
  --border-focus:     var(--forest-500);
  --action-primary:        var(--forest-500);
  --action-primary-hover:  var(--forest-600);
  --action-primary-active: var(--forest-700);
  --action-secondary:        var(--ink-900);
  --action-secondary-hover:  var(--ink-800);
  --action-secondary-active: var(--ink-950);
  --feedback-danger:       var(--red-500);
  --feedback-success-soft: var(--green-100);
  --focus-ring: color-mix(in srgb, var(--forest-500) 42%, transparent);

  /* ---------------- Tokens: tipografia ---------------- */
  --font-serif: 'Newsreader', 'Iowan Old Style', Georgia, 'Times New Roman', serif;
  --font-sans:  'Hanken Grotesk', system-ui, -apple-system, 'Segoe UI', sans-serif;
  --font-mono:  'Spline Sans Mono', ui-monospace, 'SFMono-Regular', Menlo, monospace;

  --weight-regular:  400;
  --weight-medium:   500;
  --weight-semibold: 600;
  --weight-bold:     700;

  --text-2xs: 0.6875rem;
  --text-xs:  0.75rem;
  --text-sm:  0.875rem;
  --text-base:1rem;
  --text-md:  1.125rem;
  --text-lg:  1.375rem;
  --text-xl:  1.75rem;
  --text-2xl: 2.25rem;
  --text-3xl: 2.9375rem;

  --leading-tight:   1.08;
  --leading-snug:    1.2;
  --leading-normal:  1.5;
  --leading-relaxed: 1.7;

  --tracking-snug:    -0.01em;
  --tracking-eyebrow: 0.18em;

  /* ---------------- Tokens: spaziatura e raggi ---------------- */
  --space-1:  0.25rem;
  --space-2:  0.5rem;
  --space-3:  0.75rem;
  --space-4:  1rem;
  --space-5:  1.5rem;
  --space-6:  2rem;
  --space-7:  2.5rem;
  --space-8:  3rem;
  --space-9:  4rem;
  --space-10: 5rem;
  --space-11: 6rem;

  --radius-xs:   3px;
  --radius-sm:   5px;
  --radius-md:   8px;
  --radius-lg:   12px;
  --radius-pill: 999px;

  --container-sm: 640px;
  --container-md: 820px;
  --container-lg: 1080px;
  --container-xl: 1280px;

  /* ---------------- Tokens: elevazione e movimento ---------------- */
  --shadow-color: 16 24 19;
  --shadow-sm: 0 1px 3px rgba(var(--shadow-color) / 0.07),
               0 1px 2px rgba(var(--shadow-color) / 0.05);
  --shadow-md: 0 2px 6px rgba(var(--shadow-color) / 0.08),
               0 4px 12px rgba(var(--shadow-color) / 0.06);
  --ring-focus: 0 0 0 3px var(--focus-ring);
  --ease-standard: cubic-bezier(0.4, 0, 0.2, 1);
  --duration-fast:   120ms;
  --duration-normal: 200ms;
  --texture-grain: radial-gradient(rgba(20 50 36 / 0.035) 1px, transparent 1px);
  --texture-grain-size: 4px 4px;
}

/* ---------------- Base ---------------- */
* { box-sizing: border-box; }

html { scroll-behavior: smooth; }

body {
  margin: 0;
  background: var(--surface-page);
  background-image: var(--texture-grain);
  background-size: var(--texture-grain-size);
  color: var(--text-primary);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  font-family: var(--font-serif);
}

::selection { background: var(--gold-100); }

a:focus-visible, button:focus-visible, input:focus-visible,
select:focus-visible, textarea:focus-visible {
  outline: none;
  box-shadow: var(--ring-focus);
  outline-offset: 2px;
}

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

/* Lingua: il toggle mostra/nasconde gli elementi marcati */
html[data-lang="it"] [data-lang="en"] { display: none !important; }
html[data-lang="en"] [data-lang="it"] { display: none !important; }

/* ---------------- Header ---------------- */
.site-header {
  position: sticky;
  top: 0;
  z-index: 100;
  background: color-mix(in srgb, var(--bone-50) 88%, transparent);
  backdrop-filter: saturate(180%) blur(8px);
  -webkit-backdrop-filter: saturate(180%) blur(8px);
  border-bottom: 1px solid var(--border-hairline);
}

.site-header__inner {
  max-width: var(--container-lg);
  margin: 0 auto;
  padding: 12px var(--space-6);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-6);
}

.site-header__brand { display: flex; align-items: center; }
.site-header__brand img { height: 30px; display: block; }

.site-header__right { display: flex; align-items: center; gap: var(--space-5); }

.site-nav { display: flex; gap: var(--space-5); align-items: center; }

.site-nav a {
  font-family: var(--font-sans);
  font-size: var(--text-sm);
  font-weight: var(--weight-medium);
  color: var(--text-secondary);
  text-decoration: none;
  transition: color var(--duration-fast) var(--ease-standard);
}
.site-nav a:hover { color: var(--forest-600); }

.lang-switch {
  display: flex;
  border-radius: var(--radius-pill);
  border: 1px solid var(--border-default);
  overflow: hidden;
}

.lang-switch button {
  border: none;
  cursor: pointer;
  padding: 5px 12px;
  font-family: var(--font-mono);
  font-size: var(--text-2xs);
  text-transform: uppercase;
  letter-spacing: 0.08em;
  background: transparent;
  color: var(--ink-600);
  transition: background var(--duration-fast) var(--ease-standard),
              color var(--duration-fast) var(--ease-standard);
}
.lang-switch button[aria-pressed="true"] {
  background: var(--forest-500);
  color: var(--bone-0);
}

/* ---------------- Bottoni ---------------- */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  white-space: nowrap;
  cursor: pointer;
  text-decoration: none;
  font-family: var(--font-sans);
  font-weight: var(--weight-semibold);
  letter-spacing: 0.01em;
  line-height: 1;
  border: 1px solid transparent;
  transition: background var(--duration-fast) var(--ease-standard),
              transform var(--duration-fast) var(--ease-standard),
              box-shadow var(--duration-fast) var(--ease-standard);
}
.btn:active { transform: translateY(0.5px); }

.btn--sm { font-size: var(--text-sm); padding: 0.4rem 0.85rem; border-radius: var(--radius-sm); gap: 0.4rem; }
.btn--md { font-size: var(--text-sm); padding: 0.6rem 1.15rem; border-radius: var(--radius-md); gap: 0.5rem; }
.btn--lg { font-size: var(--text-base); padding: 0.8rem 1.5rem; border-radius: var(--radius-md); gap: 0.6rem; }
.btn--full { width: 100%; }

.btn--primary { background: var(--action-primary); color: var(--bone-0); }
.btn--primary:hover { background: var(--action-primary-hover); }
.btn--primary:active { background: var(--action-primary-active); }

.btn--secondary { background: var(--action-secondary); color: var(--bone-0); }
.btn--secondary:hover { background: var(--action-secondary-hover); }
.btn--secondary:active { background: var(--action-secondary-active); }

.btn--outline {
  background: transparent;
  color: var(--text-primary);
  border-color: var(--border-default);
}
.btn--outline:hover { background: var(--bone-100); }
.btn--outline:active { background: var(--bone-150); }

/* ---------------- Badge ---------------- */
.badge {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  font-family: var(--font-sans);
  font-size: var(--text-xs);
  font-weight: var(--weight-semibold);
  letter-spacing: 0.01em;
  padding: 0.2rem 0.6rem;
  border-radius: var(--radius-pill);
  background: var(--bone-150);
  color: var(--ink-700);
}

/* ---------------- Masthead (testata del diario) ---------------- */
.masthead {
  text-align: center;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-4);
  margin-bottom: var(--space-8);
}
.masthead img { height: 44px; }

.masthead__inner {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-4);
}

.masthead__eyebrow {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: var(--tracking-eyebrow);
  color: var(--text-gold);
}

.masthead__statement {
  font-family: var(--font-serif);
  font-size: clamp(1.5rem, 3vw, var(--text-xl));
  line-height: 1.4;
  color: var(--text-primary);
  margin: 0;
  max-width: 30ch;
  text-wrap: balance;
}

.masthead__motto {
  font-family: var(--font-mono);
  font-size: var(--text-2xs);
  text-transform: uppercase;
  letter-spacing: 0.14em;
  color: var(--text-muted);
}

/* Doppio filetto old-school */
.double-rule { border-top: 2px solid var(--ink-900); margin-bottom: 3px; }
.double-rule + .single-rule { border-top: 1px solid var(--ink-900); margin-bottom: var(--space-2); }

/* ---------------- Indice: voci del diario ---------------- */
.journal { max-width: var(--container-md); margin: 0 auto; padding: var(--space-10) var(--space-6) var(--space-11); }

.entry {
  display: grid;
  grid-template-columns: 132px 1fr;
  gap: var(--space-6);
  padding: var(--space-6) 0;
  border-bottom: 1px solid var(--border-hairline);
}
.entry:last-of-type { border-bottom: none; }

.entry__meta { display: flex; flex-direction: column; gap: 6px; padding-top: 6px; }

.entry__date {
  font-family: var(--font-mono);
  font-size: var(--text-2xs);
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--text-muted);
}

.entry__section {
  font-family: var(--font-mono);
  font-size: var(--text-2xs);
  text-transform: uppercase;
  letter-spacing: 0.14em;
  color: var(--text-gold);
}

.entry__body { display: flex; flex-direction: column; gap: var(--space-2); align-items: flex-start; }

.entry__title {
  font-family: var(--font-serif);
  font-weight: var(--weight-medium);
  font-size: var(--text-xl);
  line-height: var(--leading-snug);
  letter-spacing: var(--tracking-snug);
  color: var(--text-primary);
  margin: 0;
  text-wrap: pretty;
}
a.entry__title { text-decoration: none; transition: color var(--duration-fast) var(--ease-standard); }
a.entry__title:hover { color: var(--forest-600); }

.entry__excerpt {
  font-family: var(--font-serif);
  font-size: var(--text-base);
  line-height: var(--leading-relaxed);
  color: var(--ink-700);
  margin: 0;
  text-wrap: pretty;
}

.entry__read {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: var(--text-brand);
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  margin-top: var(--space-1);
  transition: color var(--duration-fast) var(--ease-standard);
}
.entry__read:hover { color: var(--forest-700); }

@media (max-width: 560px) {
  .entry { grid-template-columns: 1fr; gap: var(--space-3); }
  .entry__meta { flex-direction: row; gap: var(--space-4); padding-top: 0; }
}

/* Striscia pattern di chiusura */
.pattern-strip { display: flex; justify-content: center; margin-top: var(--space-8); }
.pattern-strip > div {
  width: 204px;
  height: 12px;
  background-image: url('../img/iphigenai-pattern.svg');
  background-repeat: repeat-x;
  background-size: auto 100%;
}

/* ---------------- Articolo ---------------- */
.article-page { max-width: var(--container-sm); margin: 0 auto; padding: var(--space-9) var(--space-6) var(--space-11); }

.article-back {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: var(--text-muted);
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  transition: color var(--duration-fast) var(--ease-standard);
}
.article-back:hover { color: var(--forest-600); }

.article-meta {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  margin: var(--space-6) 0 var(--space-3);
}
.article-meta__dot { width: 4px; height: 4px; border-radius: 50%; background: var(--bone-300); }

.article-title {
  font-family: var(--font-serif);
  font-weight: var(--weight-medium);
  font-size: clamp(2rem, 4.5vw, var(--text-3xl));
  line-height: var(--leading-snug);
  letter-spacing: var(--tracking-snug);
  color: var(--text-primary);
  margin: 0 0 var(--space-5);
  text-wrap: pretty;
}

.article-standfirst {
  font-family: var(--font-serif);
  font-style: italic;
  font-size: var(--text-md);
  line-height: var(--leading-relaxed);
  color: var(--ink-700);
  margin: 0 0 var(--space-6);
  text-wrap: pretty;
}

.article-body {
  border-top: 1px solid var(--border-hairline);
  padding-top: var(--space-6);
  display: flex;
  flex-direction: column;
  gap: var(--space-5);
}

.article-body p {
  font-family: var(--font-serif);
  font-size: var(--text-md);
  line-height: var(--leading-relaxed);
  color: var(--ink-800);
  margin: 0;
  text-wrap: pretty;
}

.article-body h2 {
  font-family: var(--font-serif);
  font-weight: var(--weight-medium);
  font-size: var(--text-lg);
  color: var(--text-primary);
  margin: var(--space-2) 0 0;
}

.article-body ul {
  font-family: var(--font-serif);
  font-size: var(--text-md);
  line-height: var(--leading-relaxed);
  color: var(--ink-800);
  margin: 0;
  padding-left: 1.2em;
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}
.article-body li { padding-left: 0.3em; }
.article-body strong { font-weight: var(--weight-semibold); }

/* Box CTA «Parliamone» */
.cta-box {
  margin-top: var(--space-8);
  background: var(--forest-700);
  background-image: var(--texture-grain);
  background-size: var(--texture-grain-size);
  border-radius: var(--radius-lg);
  padding: var(--space-7);
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
  align-items: flex-start;
}

.cta-box__eyebrow {
  font-family: var(--font-mono);
  font-size: var(--text-2xs);
  text-transform: uppercase;
  letter-spacing: var(--tracking-eyebrow);
  color: var(--gold-300);
}

.cta-box__statement {
  font-family: var(--font-serif);
  font-size: var(--text-lg);
  line-height: 1.4;
  color: var(--bone-0);
  margin: 0;
  text-wrap: pretty;
}

.cta-box__actions { display: flex; flex-wrap: wrap; gap: var(--space-4); align-items: center; }

.email-link {
  font-family: var(--font-mono);
  font-size: var(--text-sm);
  color: var(--gold-300);
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  gap: 10px;
  transition: color var(--duration-fast) var(--ease-standard);
}
.email-link:hover { color: var(--gold-200); }

/* ---------------- Contatti ---------------- */
.contact {
  background: var(--forest-700);
  background-image: var(--texture-grain);
  background-size: var(--texture-grain-size);
  scroll-margin-top: 72px;
}

.contact__pattern {
  height: 12px;
  background-image: url('../img/iphigenai-pattern.svg');
  background-repeat: repeat-x;
  background-size: auto 100%;
}

.contact__inner {
  max-width: var(--container-xl);
  margin: 0 auto;
  padding: var(--space-10) var(--space-6);
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(320px, 1fr));
  gap: var(--space-9);
  align-items: center;
}

.contact__eyebrow {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: var(--tracking-eyebrow);
  color: var(--gold-300);
  margin-bottom: var(--space-3);
}

.contact__title {
  font-family: var(--font-serif);
  font-weight: var(--weight-medium);
  font-size: clamp(2rem, 4vw, var(--text-3xl));
  letter-spacing: var(--tracking-snug);
  color: var(--bone-0);
  margin: 0 0 var(--space-4);
}

.contact__text {
  font-family: var(--font-serif);
  font-size: var(--text-md);
  line-height: var(--leading-relaxed);
  color: var(--forest-100);
  margin: 0 0 var(--space-6);
  max-width: 46ch;
  text-wrap: pretty;
}

/* Card (form) */
.card {
  background: var(--surface-card);
  border: 1px solid var(--border-hairline);
  border-radius: var(--radius-lg);
  padding: var(--space-6);
  box-shadow: var(--shadow-md);
}

/* ---------------- Form ---------------- */
.form { display: flex; flex-direction: column; gap: var(--space-4); }

.field { display: flex; flex-direction: column; gap: 0.35rem; }

.field__label {
  font-family: var(--font-sans);
  font-size: var(--text-sm);
  font-weight: var(--weight-semibold);
  color: var(--text-secondary);
}

.field__hint { font-family: var(--font-sans); font-size: var(--text-xs); color: var(--text-muted); }

.field__error {
  font-family: var(--font-sans);
  font-size: var(--text-xs);
  color: var(--feedback-danger);
  display: none;
}
.field.is-invalid .field__error { display: block; }

.field input[type="text"],
.field input[type="email"],
.field textarea,
.field select {
  width: 100%;
  font-family: var(--font-sans);
  font-size: var(--text-base);
  color: var(--text-primary);
  background: var(--surface-card);
  border: 1px solid var(--border-default);
  border-radius: var(--radius-md);
  padding: 0.55rem 0.75rem;
  min-height: 42px;
  outline: none;
  transition: border-color var(--duration-fast) var(--ease-standard),
              box-shadow var(--duration-fast) var(--ease-standard);
}
.field textarea { resize: vertical; line-height: var(--leading-normal); min-height: 0; }
.field input::placeholder, .field textarea::placeholder { color: var(--text-faint); }

.field input:focus, .field textarea:focus, .field select:focus {
  border-color: var(--border-focus);
  box-shadow: var(--ring-focus);
}
.field.is-invalid input, .field.is-invalid select, .field.is-invalid textarea {
  border-color: var(--feedback-danger);
}

/* Select con chevron */
.field--select { position: relative; }
.field--select select {
  appearance: none;
  -webkit-appearance: none;
  padding-right: 2.2rem;
  cursor: pointer;
}
.field--select .field__chevron {
  position: absolute;
  right: 12px;
  bottom: 14px;
  pointer-events: none;
  color: var(--text-faint);
  display: inline-flex;
}

/* Checkbox */
.checkbox {
  display: flex;
  align-items: center;
  gap: 0.6rem;
  cursor: pointer;
  position: relative;
}
.checkbox input {
  position: absolute;
  opacity: 0;
  width: 20px;
  height: 20px;
  margin: 0;
  cursor: inherit;
}
.checkbox__box {
  width: 20px;
  height: 20px;
  flex-shrink: 0;
  border-radius: var(--radius-xs);
  border: 1.5px solid var(--border-default);
  background: var(--surface-card);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  transition: background var(--duration-fast) var(--ease-standard),
              border-color var(--duration-fast) var(--ease-standard);
}
.checkbox__box svg { display: none; }
.checkbox input:checked + .checkbox__box { background: var(--forest-500); border-color: var(--forest-500); }
.checkbox input:checked + .checkbox__box svg { display: block; }
.checkbox input:focus-visible + .checkbox__box { box-shadow: var(--ring-focus); }
.checkbox__label {
  font-family: var(--font-sans);
  font-size: var(--text-sm);
  font-weight: var(--weight-medium);
  color: var(--text-primary);
}

/* Callout (conferma invio) */
.callout {
  display: flex;
  gap: 0.75rem;
  border: 1px solid var(--green-500);
  border-left-width: 3px;
  border-radius: var(--radius-md);
  padding: var(--space-4);
  background: var(--feedback-success-soft);
}
.callout__icon { display: inline-flex; flex-shrink: 0; color: var(--green-500); margin-top: 1px; }
.callout__content { display: flex; flex-direction: column; gap: 0.2rem; min-width: 0; }
.callout__title {
  font-family: var(--font-sans);
  font-size: var(--text-sm);
  font-weight: var(--weight-bold);
  color: var(--green-700);
}
.callout__body {
  font-family: var(--font-sans);
  font-size: var(--text-sm);
  line-height: var(--leading-normal);
  color: var(--text-secondary);
}

.form-fail {
  display: none;
  font-family: var(--font-sans);
  font-size: var(--text-sm);
  line-height: var(--leading-normal);
  color: var(--feedback-danger);
  margin: 0;
}
.form-fail.is-visible { display: block; }

.btn:disabled { opacity: 0.5; cursor: not-allowed; }

.form-success {
  display: none;
  flex-direction: column;
  gap: var(--space-4);
  min-height: 320px;
  justify-content: center;
}
.card.is-sent .form-success { display: flex; }
.card.is-sent .form { display: none; }

/* ---------------- Footer ---------------- */
.site-footer { background: var(--ink-900); color: var(--bone-200); }

.site-footer__inner {
  max-width: var(--container-xl);
  margin: 0 auto;
  padding: var(--space-4) var(--space-6);
  display: flex;
  justify-content: space-between;
  align-items: center;
  flex-wrap: wrap;
  gap: var(--space-3);
}

.site-footer__text { font-family: var(--font-sans); font-size: var(--text-xs); color: var(--bone-400); }
.site-footer__inner img { height: 22px; opacity: 0.7; }

@media (max-width: 640px) {
  .site-header__inner { padding: 12px var(--space-4); gap: var(--space-3); }
  .site-header__right { gap: var(--space-3); }
  .site-nav { display: none; }
  .journal { padding: var(--space-8) var(--space-4) var(--space-9); }
  .article-page { padding: var(--space-8) var(--space-4) var(--space-9); }
  .contact__inner { padding: var(--space-8) var(--space-4); gap: var(--space-6); }
  .cta-box { padding: var(--space-5); }
}
