/* ==========================================================================
   SURVIVAL APPS — foglio di stile unico del sito
   Palette "manuale di campo" (vedi docs/identita-e-stile.md):
   sfondo chiaro come una pagina ingiallita di manuale tecnico militare,
   accenti neon (magenta/ciano) e analogici (ruggine/kaki).
   ========================================================================== */

/* ---- font self-hosted (niente richieste a servizi terzi) --------------- */
@font-face{
  font-family:'Oswald'; font-style:normal; font-weight:200 700;
  font-display:swap; src:url('fonts/oswald.woff2') format('woff2');
}
@font-face{
  font-family:'EB Garamond'; font-style:normal; font-weight:400 800;
  font-display:swap; src:url('fonts/ebgaramond.woff2') format('woff2');
}
@font-face{
  font-family:'EB Garamond'; font-style:italic; font-weight:400 800;
  font-display:swap; src:url('fonts/ebgaramond-italic.woff2') format('woff2');
}
@font-face{
  font-family:'Share Tech Mono'; font-style:normal; font-weight:400;
  font-display:swap; src:url('fonts/sharetechmono.woff2') format('woff2');
}

:root{
  --paper:#F2EFE6;        /* bianco sporco — sfondo */
  --paper-dim:#e7e2d2;    /* carta più scura — riquadri */
  --ink:#1A1A18;          /* nero quasi puro — testo */
  --ink-soft:#4A4A38;     /* kaki scuro — testo secondario */
  --magenta:#D6006E;      /* magenta neon — Zona 2, link, segnali */
  --cyan:#0090A8;         /* ciano petrolio — Zona 1, callout */
  --cyan-scuro:#007085;   /* solo per testi piccoli: contrasto AA su carta */
  --rust:#A3441F;         /* ruggine — Zona 3, hardware */
  --rule:#cfc9b4;         /* linee di separazione */
}
*{ box-sizing:border-box; }
body{
  margin:0;
  background:var(--paper);
  color:var(--ink);
  font-family:'EB Garamond', serif;
  font-size:18px;
  line-height:1.65;
}
.wrap{ max-width:760px; margin:0 auto; padding:0 24px; }
img{ max-width:100%; height:auto; }
p, li, td, figcaption{ overflow-wrap:break-word; }
a{ color:var(--magenta); text-decoration:none; }
a:hover{ text-decoration:underline; }
code{ font-family:'Share Tech Mono', monospace; font-size:0.88em; background:var(--paper-dim); padding:1px 5px; border-radius:2px; }

/* ---- intestazione del sito ---------------------------------------- */
.site-header{ padding:34px 0 0; }
.coords{
  font-family:'Share Tech Mono', monospace;
  font-size:0.72rem;
  color:var(--magenta);
  letter-spacing:0.18em;
  text-transform:uppercase;
  margin-bottom:6px;
}
.logo{
  font-family:'Oswald', sans-serif;
  font-weight:700;
  font-size:2rem;
  letter-spacing:0.14em;
  color:var(--ink);
  text-transform:uppercase;
  display:inline-flex; align-items:center; gap:12px;
}
.logo:hover{ text-decoration:none; color:var(--magenta); }
.logo-emblema{
  width:46px; height:46px; flex:none;
  border:1px solid var(--rule); border-radius:2px;
  background:#0d0210;
}
.claim{
  font-family:'Share Tech Mono', monospace;
  font-size:0.78rem;
  color:var(--ink-soft);
  letter-spacing:0.06em;
  margin:2px 0 16px;
}
.site-nav{
  display:flex; flex-wrap:wrap; gap:8px;
  border-top:1px solid var(--rule);
  border-bottom:2px solid var(--ink);
  padding:10px 0;
  margin-bottom:40px;
}
.nav-zona{
  font-family:'Share Tech Mono', monospace;
  font-size:0.7rem;
  letter-spacing:0.1em;
  color:var(--ink-soft);
  border:1px solid var(--rule);
  border-radius:2px;
  padding:4px 10px;
}
.nav-zona:hover{ text-decoration:none; color:var(--ink); border-color:var(--ink); }
.nav-zona.zona-1:hover{ color:var(--cyan); border-color:var(--cyan); }
.nav-zona.zona-2:hover{ color:var(--magenta); border-color:var(--magenta); }
.nav-zona.zona-3:hover{ color:var(--rust); border-color:var(--rust); }

/* ---- home / elenchi ------------------------------------------------ */
.insegna{ margin:0 0 34px; }
.insegna img{
  display:block; width:100%; max-width:560px; margin:0 auto;
  border:1px solid var(--ink); border-radius:2px;
  box-shadow:0 0 24px rgba(214,0,110,.18);
}
.hero-home h1{
  font-family:'Oswald', sans-serif; font-weight:700; text-transform:uppercase;
  font-size:1.9rem; letter-spacing:0.02em; line-height:1.15; margin:0 0 10px;
}
.hero-home .lead{ color:var(--ink-soft); font-size:1.08rem; margin:0 0 34px; }
.zona-tag{
  display:inline-block;
  font-family:'Share Tech Mono', monospace;
  font-size:0.7rem; letter-spacing:0.14em;
  padding:3px 9px; border:1px solid currentColor; border-radius:2px;
  margin-bottom:12px; color:var(--ink-soft);
}
.zona-tag.zona-1{ color:var(--cyan); }
.zona-tag.zona-2{ color:var(--magenta); }
.zona-tag.zona-3{ color:var(--rust); }

.mappa-zone{ display:grid; grid-template-columns:repeat(auto-fit,minmax(210px,1fr)); gap:14px; margin-bottom:48px; }
.zona-box{
  display:block; color:var(--ink);
  background:var(--paper-dim);
  border:1px solid var(--rule); border-top:3px solid var(--ink-soft);
  border-radius:2px; padding:16px 18px;
}
.zona-box:hover{ text-decoration:none; border-color:var(--ink); }
.zona-box.zona-1{ border-top-color:var(--cyan); }
.zona-box.zona-2{ border-top-color:var(--magenta); }
.zona-box.zona-3{ border-top-color:var(--rust); }
.zona-box h3{ font-family:'Oswald', sans-serif; text-transform:uppercase; font-size:1.05rem; margin:6px 0 8px; }
.zona-box p{ font-size:0.88rem; color:var(--ink-soft); margin:0; }
.zona-box .zona-tag{ margin-bottom:0; }

.titolo-sezione{
  font-family:'Share Tech Mono', monospace;
  font-size:0.8rem; letter-spacing:0.14em; color:var(--ink-soft);
  border-bottom:1px solid var(--rule); padding-bottom:8px; margin:0 0 18px;
  font-weight:400;
}
.card{
  display:block; color:var(--ink);
  border:1px solid var(--rule); border-left:3px solid var(--ink-soft);
  border-radius:2px; padding:16px 18px; margin-bottom:14px;
  background:var(--paper);
}
.card:hover{ text-decoration:none; background:var(--paper-dim); border-color:var(--ink-soft); }
.card.zona-1{ border-left-color:var(--cyan); }
.card.zona-2{ border-left-color:var(--magenta); }
.card.zona-3{ border-left-color:var(--rust); }
.card-meta{
  display:flex; justify-content:space-between; flex-wrap:wrap; gap:2px 10px;
  font-family:'Share Tech Mono', monospace; font-size:0.7rem;
  letter-spacing:0.1em; color:var(--ink-soft); margin-bottom:4px;
}
.card-num{ color:var(--magenta); }
.card-zona{
  font-family:'Share Tech Mono', monospace; font-size:0.66rem;
  letter-spacing:0.12em; color:var(--ink-soft); margin-bottom:8px;
}
.card h3{
  font-family:'Oswald', sans-serif; font-weight:700; text-transform:uppercase;
  font-size:1.15rem; line-height:1.2; margin:0 0 8px;
}
.card p{ font-size:0.92rem; color:var(--ink-soft); margin:0; }

/* ---- articolo ------------------------------------------------------- */
.post{ padding-bottom:20px; }
.transmission{
  font-family:'Share Tech Mono', monospace;
  font-size:0.78rem; color:var(--ink-soft); letter-spacing:0.1em;
  display:flex; justify-content:space-between; flex-wrap:wrap; gap:6px;
  border-bottom:1px solid var(--rule);
  padding-bottom:10px; margin-bottom:26px;
}
.transmission a{ color:var(--ink-soft); }
.transmission a:hover{ color:var(--magenta); }
h1{
  font-family:'Oswald', sans-serif; font-weight:700; text-transform:uppercase;
  font-size:2.1rem; letter-spacing:0.02em; line-height:1.15;
  margin:0 0 6px; color:var(--ink);
}
.subhead{
  font-family:'Share Tech Mono', monospace; color:var(--cyan-scuro);
  font-size:0.85rem; letter-spacing:0.08em; text-transform:uppercase;
  margin-bottom:30px;
}
h2{
  font-family:'Oswald', sans-serif; font-weight:700; text-transform:uppercase;
  font-size:1.25rem; letter-spacing:0.03em; color:var(--ink);
  margin:38px 0 12px; padding-bottom:6px;
  border-bottom:2px solid var(--ink); display:inline-block;
}
p{ margin:0 0 16px; }

.incharacter{
  font-style:italic; color:var(--ink-soft);
  border-left:3px solid var(--magenta);
  padding:4px 0 4px 18px; margin:0 0 32px; font-size:1.08rem;
}
.incharacter p{ margin:0 0 12px; }
.incharacter p:last-child{ margin-bottom:0; }

figure.hero{ margin:0 0 34px; }
figure.hero img{ width:100%; height:auto; border-radius:2px; display:block; }
figure.hero.ritratto img{ max-width:480px; margin:0 auto; border:1px solid var(--rule); }
.img-placeholder{
  width:100%; aspect-ratio:16/9;
  background:repeating-linear-gradient(45deg, var(--paper-dim), var(--paper-dim) 10px, var(--paper) 10px, var(--paper) 20px);
  border:2px dashed var(--rust); border-radius:2px;
  display:flex; flex-direction:column; align-items:center; justify-content:center;
  text-align:center; padding:20px;
}
.img-placeholder .icon{ font-size:2rem; margin-bottom:8px; color:var(--rust); }
.img-placeholder .label{
  font-family:'Share Tech Mono', monospace; font-size:0.78rem;
  color:var(--ink-soft); letter-spacing:0.05em; max-width:420px;
}
figcaption{
  font-family:'Share Tech Mono', monospace; font-size:0.72rem;
  color:var(--ink-soft); letter-spacing:0.04em; margin-top:8px; text-align:center;
}

sup.note-ref a{
  font-family:'Share Tech Mono', monospace; font-size:0.72em;
  color:var(--cyan-scuro); font-style:normal;
}
.callout{
  background:var(--paper-dim);
  border:1px solid var(--rule); border-left:3px solid var(--cyan);
  padding:16px 18px; margin:24px 0; font-size:0.98rem;
}
.callout .tag{
  font-family:'Share Tech Mono', monospace; font-size:0.7rem;
  color:var(--cyan-scuro); letter-spacing:0.1em; text-transform:uppercase;
  display:block; margin-bottom:8px;
}
.callout.warning{ border-left-color:var(--rust); }
.callout.warning .tag{ color:var(--rust); }

/* ---- iconografia funzionale: stato dei progetti ---------------------- */
.tag-stato{
  display:inline-block; vertical-align:middle;
  font-family:'Share Tech Mono', monospace; font-size:0.64rem;
  letter-spacing:0.14em; text-transform:uppercase; font-style:normal;
  border:1px solid currentColor; border-radius:2px; padding:2px 8px;
}
.tag-stato.contaminato{ color:var(--rust); background:rgba(163,68,31,.08); }   /* progetto deprecato */
.tag-stato.quarantena{ color:var(--ink-soft); border-style:dashed; }           /* in sviluppo */
.tag-stato.operativo{ color:var(--cyan); }                                     /* rilasciato e mantenuto */

ul.feature-list{ list-style:none; padding:0; margin:0 0 20px; }
ul.feature-list li{
  padding:10px 0 10px 14px;
  border-left:2px solid var(--rust);
  margin-bottom:8px; font-size:0.98rem;
}
ul.feature-list b{
  color:var(--rust); font-family:'Share Tech Mono', monospace;
  font-size:0.85rem; letter-spacing:0.03em;
}

.terminal{
  background:var(--ink); color:#c9f0d8;
  font-family:'Share Tech Mono', monospace; font-size:0.85rem;
  padding:14px 16px; border-radius:2px; margin:20px 0; overflow-x:auto;
}
.terminal .prompt{ color:var(--cyan); }
.terminal .alert{ color:var(--magenta); }

/* ---- blocco di codice (import Markdown ```...```) --------------------- */
pre.blocco-codice{
  background:var(--ink); color:#c9f0d8;
  font-family:'Share Tech Mono', monospace; font-size:0.82rem; line-height:1.5;
  padding:14px 16px; border-radius:2px; margin:20px 0;
  overflow-x:auto; white-space:pre;
}

/* ---- citazione (import Markdown "> ...") ------------------------------ */
.post blockquote{
  border-left:3px solid var(--ink-soft); margin:20px 0;
  padding:4px 0 4px 18px; color:var(--ink-soft); font-style:italic;
}
.post blockquote p{ margin:0 0 8px; }
.post blockquote p:last-child{ margin-bottom:0; }

/* ---- sotto-sezione h3 e linea orizzontale (import Markdown) ----------- */
.post h3{
  font-family:'Oswald', sans-serif; font-weight:700; text-transform:uppercase;
  font-size:1.05rem; letter-spacing:0.03em; color:var(--ink);
  margin:26px 0 10px;
}
.post hr{ border:none; border-top:1px solid var(--rule); margin:30px 0; }

.signoff{
  font-style:italic; color:var(--ink-soft);
  border-left:3px solid var(--magenta);
  padding:4px 0 4px 18px; margin:36px 0 30px;
}

.notes{ margin-top:44px; padding-top:18px; border-top:1px solid var(--rule); }
.notes h3{
  font-family:'Share Tech Mono', monospace; font-size:0.78rem;
  letter-spacing:0.1em; text-transform:uppercase;
  color:var(--ink-soft); margin:0 0 12px; font-weight:400;
}
.notes ol{ padding-left:20px; margin:0; font-size:0.9rem; color:var(--ink-soft); }
.notes li{ margin-bottom:8px; }
.notes li strong{ color:var(--ink); }
.notes a{ font-family:'Share Tech Mono', monospace; font-size:0.75rem; }

.post-nav{
  display:flex; justify-content:space-between; flex-wrap:wrap; gap:12px;
  font-family:'Share Tech Mono', monospace; font-size:0.75rem;
  letter-spacing:0.08em;
  border-top:1px solid var(--rule); padding-top:16px; margin-top:40px;
}

/* ---- piè di pagina --------------------------------------------------- */
.site-footer{
  font-family:'Share Tech Mono', monospace; font-size:0.72rem;
  color:var(--ink-soft); letter-spacing:0.1em; text-transform:uppercase;
  border-top:1px solid var(--rule);
  padding:14px 0 40px; margin-top:60px;
}
.footer-row{ display:flex; justify-content:space-between; flex-wrap:wrap; gap:6px; }
.footer-sub{ margin-top:8px; opacity:0.75; text-transform:none; }
.site-footer a{ color:var(--ink-soft); }
.site-footer a:hover{ color:var(--magenta); }

/* ---- tabelle tecniche ------------------------------------------------ */
.table-scroll{ overflow-x:auto; margin:20px 0; }
table.tech{
  width:100%; border-collapse:collapse; font-size:0.9rem;
}
table.tech th{
  font-family:'Share Tech Mono', monospace; font-size:0.7rem;
  letter-spacing:0.1em; text-transform:uppercase; color:var(--ink-soft);
  text-align:left; border-bottom:2px solid var(--ink); padding:8px 10px;
}
table.tech td{ border-bottom:1px solid var(--rule); padding:8px 10px; vertical-align:top; }

/* ---- stampa: il manuale di campo su carta vera ------------------------ */
@media print{
  body{ background:#fff; color:#000; font-size:11.5pt; }
  .site-nav, .site-footer, .post-nav, .insegna, .logo-emblema{ display:none; }
  .site-header{ padding-top:0; }
  .wrap{ max-width:none; padding:0; }
  a{ color:#000; text-decoration:underline; }
  .post a[href^="http"]::after{
    content:" (" attr(href) ")";
    font-family:'Share Tech Mono', monospace; font-size:0.72em;
  }
  .terminal{ background:#fff; color:#000; border:1px solid #000; }
  .terminal .prompt, .terminal .alert{ color:#000; font-weight:bold; }
  figure.hero, .callout, .terminal, table.tech{ break-inside:avoid; }
  .card, .zona-box{ border-color:#000; }
}

@media (max-width:600px){
  body{ font-size:17px; }
  h1{ font-size:1.7rem; }
  .logo{ font-size:1.5rem; gap:9px; }
  .logo-emblema{ width:38px; height:38px; }
  .wrap{ padding:0 16px; }
  .site-header{ padding-top:22px; }
  .site-nav{ gap:6px; margin-bottom:28px; }
  .nav-zona{ padding:5px 8px; font-size:0.66rem; }
  .hero-home h1{ font-size:1.55rem; }
  .zona-box, .card{ padding:13px 14px; }
  .terminal{ font-size:0.78rem; padding:12px; }
  figure.hero.ritratto img{ max-width:100%; }
  .incharacter, .signoff{ padding-left:14px; font-size:1.03rem; }
  .footer-row{ flex-direction:column; gap:3px; }
}
